From 9b31a94a144b800f990e85a55cdc33ea547a4963 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Mon, 20 Feb 2023 11:37:15 -0800 Subject: [PATCH 01/53] Added .vscode to git ignore file --- .gitignore | 1 + 1 file changed, 1 insertion(+) diff --git a/.gitignore b/.gitignore index 728a25c41f..7fb1293083 100644 --- a/.gitignore +++ b/.gitignore @@ -9,6 +9,7 @@ node_modules applications .cache .idea +.vscode/ /env/ /Agents/*/{build,dist}/ /Agents/*.egg From eadd342a7b8b195f17b966bc70137215b34eb728 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Mon, 20 Feb 2023 13:09:15 -0800 Subject: [PATCH 02/53] Reformat pycharm-lauch.py --- scripts/pycharm-launch.py | 69 ++++++++++++++++++++++----------------- 1 file changed, 39 insertions(+), 30 deletions(-) diff --git a/scripts/pycharm-launch.py b/scripts/pycharm-launch.py index a2a5694d5c..02a51a35c7 100644 --- a/scripts/pycharm-launch.py +++ b/scripts/pycharm-launch.py @@ -17,12 +17,13 @@ input box put services/core/VolttronCentral/volttroncentral/agent.py. """ import argparse -import shutil -import string -import sys import os import runpy +import shutil +import string import subprocess +import sys + from volttron.platform import jsonapi __author__ = 'Craig Allwardt' @@ -31,16 +32,23 @@ parser = argparse.ArgumentParser() parser.add_argument("agent", help="Path to the agent file to be executed.") -parser.add_argument("-s", "--silence", const=True, dest="silence", nargs="?", +parser.add_argument("-s", + "--silence", + const=True, + dest="silence", + nargs="?", help="Silence the help message.") -parser.add_argument("-n", "--no-config", action="store_true", - help="Don't include the default config in the agent directory.") +parser.add_argument( + "-n", + "--no-config", + action="store_true", + help="Don't include the default config in the agent directory.") parsed = parser.parse_args() mod_name = [os.path.basename(parsed.agent)] if not os.path.isfile(parsed.agent): - sys.stdout.write("Passed argument must be a python file! {}". - format(parsed.agent)) + sys.stdout.write("Passed argument must be a python file! {}".format( + parsed.agent)) sys.exit() abspath = os.path.abspath(os.path.join(parsed.agent, os.pardir)) @@ -60,14 +68,12 @@ def write_required_statement(out=sys.stderr): - out.write( - """Required Environment Variables + out.write("""Required Environment Variables AGENT_VIP_IDENTITY - Required Optional Environmental Variables AGENT_CONFIG - Set to /config by default VOLTTRON_HOME - Set to ~/.volttron by default -""" - ) +""") sys.path.insert(0, abspath) @@ -80,8 +86,9 @@ def write_required_statement(out=sys.stderr): path_found = os.path.join(abspath, cfg) break if not path_found: - sys.stderr.write('AGENT_CONFIG variable not set. Either set it or ' - 'put a config file in the root of the agent dir.') + sys.stderr.write( + 'AGENT_CONFIG variable not set. Either set it or ' + 'put a config file in the root of the agent dir.') sys.exit() os.environ['AGENT_CONFIG'] = path_found @@ -89,9 +96,7 @@ def write_required_statement(out=sys.stderr): if not volttron_home: os.environ['VOLTTRON_HOME'] = os.path.abspath( - os.path.expandvars( - os.path.join( - os.path.expanduser("~"), '.volttron'))) + os.path.expandvars(os.path.join(os.path.expanduser("~"), '.volttron'))) volttron_home = os.environ.get('VOLTTRON_HOME') # Now register the @@ -116,11 +121,12 @@ def write_required_statement(out=sys.stderr): os.makedirs(new_dir) try: output = subprocess.check_output(['vctl', 'auth', 'keypair'], - env=os.environ.copy(), universal_newlines=True, stderr=subprocess.STDOUT) + env=os.environ.copy(), + universal_newlines=True, + stderr=subprocess.STDOUT) except subprocess.CalledProcessError as e: sys.stderr.write("Couldn't get key pair for identity: {}\n".format( - agent_identity - )) + agent_identity)) sys.stderr.write("Call was:\n\tvctl auth keypair\n") sys.stderr.write("Output of command: {}".format(e.output)) sys.stderr.write("Your environment might not be setup correctly!") @@ -135,19 +141,22 @@ def write_required_statement(out=sys.stderr): pubkey = json_obj['public'] try: - params = ['vctl', 'auth', 'add', - '--credentials', "{}".format(pubkey), '--user_id', agent_identity, - '--capabilities', "edit_config_store", - '--comments', "Added from pycharm-launch.py script." - ] - output = subprocess.check_output(params, env=os.environ.copy(), universal_newlines=True) + params = [ + 'vctl', 'auth', 'add', '--credentials', "{}".format(pubkey), + '--user_id', agent_identity, '--capabilities', + "edit_config_store", '--comments', + "Added from pycharm-launch.py script." + ] + output = subprocess.check_output(params, + env=os.environ.copy(), + universal_newlines=True) except subprocess.CalledProcessError as e: sys.stderr.write(str(e)) - sys.stderr.write("Command returned following output: {}".format(e.output)) + sys.stderr.write("Command returned following output: {}".format( + e.output)) shutil.rmtree(new_dir) - sys.stderr.write("Couldn't authenticate agent id: {}\n".format( - agent_identity - )) + sys.stderr.write( + "Couldn't authenticate agent id: {}\n".format(agent_identity)) sys.stderr.write("Call was: {}\n".format(params)) sys.stderr.write("Your environment might not be setup correctly!") write_required_statement() From 97f5710c0ea869988082f0d4029f3633c861fa46 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Mon, 20 Feb 2023 13:13:24 -0800 Subject: [PATCH 03/53] reformatted utils.py file --- volttron/platform/agent/utils.py | 149 +++++++++++++++++++------------ 1 file changed, 91 insertions(+), 58 deletions(-) diff --git a/volttron/platform/agent/utils.py b/volttron/platform/agent/utils.py index 5259b232c4..48cd2ada4f 100644 --- a/volttron/platform/agent/utils.py +++ b/volttron/platform/agent/utils.py @@ -35,24 +35,24 @@ # BATTELLE for the UNITED STATES DEPARTMENT OF ENERGY # under Contract DE-AC05-76RL01830 # }}} - """VOLTTRON platform™ agent helper classes/functions.""" - import argparse import calendar import errno import logging -import warnings import os - import subprocess import sys +import warnings + try: HAS_SYSLOG = True import syslog except ImportError: HAS_SYSLOG = False +import re +import stat import traceback from configparser import ConfigParser from datetime import datetime @@ -60,25 +60,22 @@ import gevent import psutil import pytz -import re -import stat import yaml from dateutil.parser import parse -from dateutil.tz import tzutc, tzoffset +from dateutil.tz import tzoffset, tzutc from tzlocal import get_localzone from watchdog_gevent import Observer -from volttron.platform import get_home, get_address -from volttron.platform import jsonapi -from volttron.utils import VolttronHomeFileReloader, AbsolutePathFileReloader +from volttron.platform import get_address, get_home, jsonapi +from volttron.utils import AbsolutePathFileReloader, VolttronHomeFileReloader from volttron.utils.prompt import prompt_response - -__all__ = ['load_config', 'run_agent', 'start_agent_thread', - 'is_valid_identity', 'load_platform_config', 'get_messagebus', - 'get_fq_identity', 'execute_command', 'get_aware_utc_now', - 'is_secure_mode', 'is_web_enabled', 'is_auth_enabled', - 'wait_for_volttron_shutdown', 'is_volttron_running'] +__all__ = [ + 'load_config', 'run_agent', 'start_agent_thread', 'is_valid_identity', + 'load_platform_config', 'get_messagebus', 'get_fq_identity', + 'execute_command', 'get_aware_utc_now', 'is_secure_mode', 'is_web_enabled', + 'is_auth_enabled', 'wait_for_volttron_shutdown', 'is_volttron_running' +] __author__ = 'Brandon Carpenter ' __copyright__ = 'Copyright (c) 2016, Battelle Memorial Institute' @@ -146,11 +143,15 @@ def strip_comments(string): def load_config(config_path): """Load a JSON-encoded configuration file.""" if config_path is None: - _log.info("AGENT_CONFIG does not exist in environment. load_config returning empty configuration.") + _log.info( + "AGENT_CONFIG does not exist in environment. load_config returning empty configuration." + ) return {} if not os.path.exists(config_path): - raise ValueError(f"Config file specified by AGENT_CONFIG path {config_path} does not exist.") + raise ValueError( + f"Config file specified by AGENT_CONFIG path {config_path} does not exist." + ) # First attempt parsing the file with a yaml parser (allows comments natively) # Then if that fails we fallback to our modified json parser. @@ -194,7 +195,8 @@ def get_platform_instance_name(vhome=None, prompt=False): if not instance_name: instance_name = 'volttron1' instance_name = prompt_response("Name of this volttron instance:", - mandatory=True, default=instance_name) + mandatory=True, + default=instance_name) else: if not instance_name: _log.warning("Using hostname as instance name.") @@ -237,6 +239,7 @@ def get_messagebus(): message_bus = config.get('message-bus', 'zmq') return message_bus + def is_auth_enabled(): """Get type of message bus - zeromq or rabbbitmq.""" allow_auth = os.environ.get('AUTH_ENABLED') @@ -246,6 +249,7 @@ def is_auth_enabled(): allow_auth = False if allow_auth == 'False' else True return allow_auth + def is_web_enabled(): """Returns True if web enabled, False otherwise""" is_web = os.environ.get('BIND_WEB_ADDRESS') @@ -294,7 +298,7 @@ def store_message_bus_config(message_bus, instance_name): config = ConfigParser() config.read(config_path) config.set('volttron', 'message-bus', message_bus) - config.set('volttron','instance-name', instance_name) + config.set('volttron', 'instance-name', instance_name) with open(config_path, 'w') as configfile: config.write(configfile) else: @@ -354,8 +358,11 @@ def parse_json_config(config_str): return jsonapi.loads(strip_comments(config_str)) -def run_agent(cls, subscribe_address=None, publish_address=None, - config_path=None, **kwargs): +def run_agent(cls, + subscribe_address=None, + publish_address=None, + config_path=None, + **kwargs): """Instantiate an agent and run it in the current thread. Attempts to get keyword parameters from the environment if they @@ -395,8 +402,11 @@ def isapipe(fd): return stat.S_ISFIFO(os.fstat(fd).st_mode) -def default_main(agent_class, description=None, argv=sys.argv, - parser_class=argparse.ArgumentParser, **kwargs): +def default_main(agent_class, + description=None, + argv=sys.argv, + parser_class=argparse.ArgumentParser, + **kwargs): """Default main entry point implementation for legacy agents. description and parser_class are depricated. Please avoid using them. @@ -413,8 +423,8 @@ def default_main(agent_class, description=None, argv=sys.argv, sub_addr = os.environ['AGENT_SUB_ADDR'] pub_addr = os.environ['AGENT_PUB_ADDR'] except KeyError as exc: - sys.stderr.write( - 'missing environment variable: {}\n'.format(exc.args[0])) + sys.stderr.write('missing environment variable: {}\n'.format( + exc.args[0])) sys.exit(1) if sub_addr.startswith('ipc://') and sub_addr[6:7] != '@': if not os.path.exists(sub_addr[6:]): @@ -427,7 +437,8 @@ def default_main(agent_class, description=None, argv=sys.argv, config = os.environ.get('AGENT_CONFIG') agent = agent_class(subscribe_address=sub_addr, publish_address=pub_addr, - config_path=config, **kwargs) + config_path=config, + **kwargs) agent.run() except KeyboardInterrupt: pass @@ -445,7 +456,7 @@ def vip_main(agent_class, identity=None, version='0.1', **kwargs): # Quiet printing of KeyboardInterrupt by greenlets Hub = gevent.hub.Hub - Hub.NOT_ERROR = Hub.NOT_ERROR + (KeyboardInterrupt,) + Hub.NOT_ERROR = Hub.NOT_ERROR + (KeyboardInterrupt, ) config = os.environ.get('AGENT_CONFIG') identity = os.environ.get('AGENT_VIP_IDENTITY', identity) @@ -454,8 +465,8 @@ def vip_main(agent_class, identity=None, version='0.1', **kwargs): if not is_valid_identity(identity): _log.warning('Deprecation warining') _log.warning( - 'All characters in {identity} are not in the valid set.' - .format(idenity=identity)) + 'All characters in {identity} are not in the valid set.'. + format(idenity=identity)) address = get_address() agent_uuid = os.environ.get('AGENT_UUID') @@ -463,8 +474,10 @@ def vip_main(agent_class, identity=None, version='0.1', **kwargs): from volttron.platform.auth.certs import Certs certs = Certs() - agent = agent_class(config_path=config, identity=identity, - address=address, agent_uuid=agent_uuid, + agent = agent_class(config_path=config, + identity=identity, + address=address, + agent_uuid=agent_uuid, volttron_home=volttron_home, version=version, message_bus=message_bus, **kwargs) @@ -485,20 +498,24 @@ def vip_main(agent_class, identity=None, version='0.1', **kwargs): # Keep the ability to have system log output for linux # this will fail on windows because no syslog. if HAS_SYSLOG: + class SyslogFormatter(logging.Formatter): - _level_map = {logging.DEBUG: syslog.LOG_DEBUG, - logging.INFO: syslog.LOG_INFO, - logging.WARNING: syslog.LOG_WARNING, - logging.ERROR: syslog.LOG_ERR, - logging.CRITICAL: syslog.LOG_CRIT} + _level_map = { + logging.DEBUG: syslog.LOG_DEBUG, + logging.INFO: syslog.LOG_INFO, + logging.WARNING: syslog.LOG_WARNING, + logging.ERROR: syslog.LOG_ERR, + logging.CRITICAL: syslog.LOG_CRIT + } def format(self, record): level = self._level_map.get(record.levelno, syslog.LOG_INFO) - return '<{}>'.format(level) + super(SyslogFormatter, self).format( - record) + return '<{}>'.format(level) + super(SyslogFormatter, + self).format(record) class JsonFormatter(logging.Formatter): + def format(self, record): dct = record.__dict__.copy() dct["msg"] = record.getMessage() @@ -510,6 +527,7 @@ def format(self, record): class AgentFormatter(logging.Formatter): + def __init__(self, fmt=None, datefmt=None): if fmt is None: fmt = '%(asctime)s %(composite_name)s %(levelname)s: %(message)s' @@ -544,7 +562,8 @@ def setup_logging(level=logging.DEBUG, console=False): handler.setFormatter(JsonFormatter()) elif console: # Below format is more readable for console - handler.setFormatter(logging.Formatter('%(levelname)s: %(message)s')) + handler.setFormatter( + logging.Formatter('%(levelname)s: %(message)s')) else: fmt = '%(asctime)s %(name)s %(levelname)s: %(message)s' handler.setFormatter(logging.Formatter(fmt)) @@ -615,7 +634,8 @@ def parse_timestamp_string(time_stamp_str): try: base_time_stamp_str = time_stamp_str[:26] time_zone_str = time_stamp_str[26:] - time_stamp = datetime.strptime(base_time_stamp_str, "%Y-%m-%dT%H:%M:%S.%f") + time_stamp = datetime.strptime(base_time_stamp_str, + "%Y-%m-%dT%H:%M:%S.%f") # Handle most common case. if time_zone_str == "+00:00": return time_stamp.replace(tzinfo=pytz.UTC) @@ -685,8 +705,9 @@ def process_timestamp(timestamp_string, topic=''): try: timestamp = parse_timestamp_string(timestamp_string) except (ValueError, TypeError): - _log.error("message for {topic} bad timetamp string: {ts_string}" - .format(topic=topic, ts_string=timestamp_string)) + _log.error( + "message for {topic} bad timetamp string: {ts_string}".format( + topic=topic, ts_string=timestamp_string)) return if timestamp.tzinfo is None: @@ -705,12 +726,11 @@ def watch_file(fullpath, callback): """ dirname, filename = os.path.split(fullpath) - _log.info("Adding file watch for %s dirname=%s, filename=%s", fullpath, get_home(), filename) + _log.info("Adding file watch for %s dirname=%s, filename=%s", fullpath, + get_home(), filename) observer = Observer() - observer.schedule( - VolttronHomeFileReloader(filename, callback), - path=get_home() - ) + observer.schedule(VolttronHomeFileReloader(filename, callback), + path=get_home()) observer.start() _log.info("Added file watch for %s", fullpath) @@ -723,10 +743,7 @@ def watch_file_with_fullpath(fullpath, callback): dirname, filename = os.path.split(fullpath) _log.info("Adding file watch for %s", fullpath) _observer = Observer() - _observer.schedule( - AbsolutePathFileReloader(fullpath, callback), - dirname - ) + _observer.schedule(AbsolutePathFileReloader(fullpath, callback), dirname) _log.info("Added file watch for %s", fullpath) _observer.start() @@ -751,7 +768,8 @@ def create_file_if_missing(path, permission=0o660, contents=None): success = False try: if contents: - contents = contents if isinstance(contents, bytes) else contents.encode("utf-8") + contents = contents if isinstance( + contents, bytes) else contents.encode("utf-8") os.write(fd, contents) success = True except Exception as e: @@ -777,11 +795,17 @@ def fix_sqlite3_datetime(sql=None): def parse(time_stamp_bytes): return parse_timestamp_string(time_stamp_bytes.decode("utf-8")) + sql.register_adapter(datetime, format_timestamp) sql.register_converter("timestamp", parse) -def execute_command(cmds, env=None, cwd=None, logger=None, err_prefix=None, use_shell=False) -> str: +def execute_command(cmds, + env=None, + cwd=None, + logger=None, + err_prefix=None, + use_shell=False) -> str: """ Executes a command as a subprocess If the return code of the call is 0 then return stdout otherwise @@ -798,8 +822,12 @@ def execute_command(cmds, env=None, cwd=None, logger=None, err_prefix=None, use_ :raises RuntimeError: if the return code is not 0 from suprocess.run """ - results = subprocess.run(cmds, env=env, cwd=cwd, - stderr=subprocess.PIPE, stdout=subprocess.PIPE, shell=use_shell) + results = subprocess.run(cmds, + env=env, + cwd=cwd, + stderr=subprocess.PIPE, + stdout=subprocess.PIPE, + shell=use_shell) if results.returncode != 0: err_prefix = err_prefix if err_prefix is not None else "Error executing command" err_message = "\n{}: Below Command failed with non zero exit code.\n" \ @@ -814,6 +842,7 @@ def execute_command(cmds, env=None, cwd=None, logger=None, err_prefix=None, use_ return results.stdout.decode('utf-8') + # # def execute_command_p(cmds, env=None, cwd=None, logger=None, err_prefix=None): # """ Executes a given command using a subprocess. @@ -876,7 +905,9 @@ def wait_for_volttron_startup(vhome, timeout): gevent.sleep(3) sleep_time += 3 if sleep_time >= timeout: - raise Exception("Platform startup failed. Please check volttron.log in {}".format(vhome)) + raise Exception( + "Platform startup failed. Please check volttron.log in {}".format( + vhome)) def wait_for_volttron_shutdown(vhome, timeout): @@ -886,4 +917,6 @@ def wait_for_volttron_shutdown(vhome, timeout): gevent.sleep(1) sleep_time += 1 if sleep_time >= timeout: - raise Exception("Platform shutdown failed. Please check volttron.cfg.log in {}".format(vhome)) + raise Exception( + "Platform shutdown failed. Please check volttron.cfg.log in {}". + format(vhome)) From a1bb6d56591251be30a43d099b27908c17dcddf9 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Mon, 20 Feb 2023 13:14:08 -0800 Subject: [PATCH 04/53] Added the ability to use environmental variables for AGENT_PUBLICKEY and AGENT_SECRETKEY --- volttron/platform/agent/utils.py | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/volttron/platform/agent/utils.py b/volttron/platform/agent/utils.py index 48cd2ada4f..42808633e6 100644 --- a/volttron/platform/agent/utils.py +++ b/volttron/platform/agent/utils.py @@ -472,6 +472,12 @@ def vip_main(agent_class, identity=None, version='0.1', **kwargs): agent_uuid = os.environ.get('AGENT_UUID') volttron_home = get_home() + publickey = os.environ.get("AGENT_PUBLICKEY", None) + secretkey = os.environ.get("AGENT_SECRETKEY", None) + + publickey = kwargs.pop('publickey', publickey) + secretkey = kwargs.pop('secretkey', secretkey) + from volttron.platform.auth.certs import Certs certs = Certs() agent = agent_class(config_path=config, @@ -480,8 +486,11 @@ def vip_main(agent_class, identity=None, version='0.1', **kwargs): agent_uuid=agent_uuid, volttron_home=volttron_home, version=version, - message_bus=message_bus, **kwargs) - + message_bus=message_bus, + publickey=publickey, + secretkey=secretkey, + **kwargs) + try: run = agent.run except AttributeError: From 4c0730ce54c8df7b0a3178428a2fda7c8feb4cdd Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Mon, 20 Feb 2023 13:15:22 -0800 Subject: [PATCH 05/53] Added initial agent and simulator code --- services/core/IEEE_2030_5/example.config.yml | 15 + .../core/IEEE_2030_5/ieee_2030_5/__init__.py | 28 + .../core/IEEE_2030_5/ieee_2030_5/agent.py | 179 + .../core/IEEE_2030_5/ieee_2030_5/client.py | 294 + .../ieee_2030_5/models/__init__.py | 594 + .../ieee_2030_5/models/constants.py | 200 + .../ieee_2030_5/models/device_category.py | 63 + .../IEEE_2030_5/ieee_2030_5/models/sep.py | 9580 +++++++++++++++++ .../ieee_2030_5/models/timetype.py | 0 services/core/IEEE_2030_5/requirements.txt | 2 + .../IEEE_2030_5/requirements_simulator.txt | 1 + services/core/IEEE_2030_5/setup.py | 72 + .../simulated_inverter/inverter_runner.py | 312 + 13 files changed, 11340 insertions(+) create mode 100644 services/core/IEEE_2030_5/example.config.yml create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/__init__.py create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/agent.py create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/client.py create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/models/constants.py create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/models/device_category.py create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/models/sep.py create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/models/timetype.py create mode 100644 services/core/IEEE_2030_5/requirements.txt create mode 100644 services/core/IEEE_2030_5/requirements_simulator.txt create mode 100644 services/core/IEEE_2030_5/setup.py create mode 100644 services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py diff --git a/services/core/IEEE_2030_5/example.config.yml b/services/core/IEEE_2030_5/example.config.yml new file mode 100644 index 0000000000..dbf5946298 --- /dev/null +++ b/services/core/IEEE_2030_5/example.config.yml @@ -0,0 +1,15 @@ +# required parameters +cacertfile: ~/tls/certs/ca.pem +keyfile: ~/tls/private/dev1.pem +certfile: ~/tls/certs/dev1.pem +server_hostname: localhost +# the pin number is used to verify the server is the correct server +pin: 12345 + +# SSL defaults to 443 +server_ssl_port: 8443 +# http port defaults to none +server_http_port: 8080 + +subscriptions: + - devices/inverter1/all diff --git a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py new file mode 100644 index 0000000000..ad437ad9c7 --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py @@ -0,0 +1,28 @@ +from __future__ import annotations + +from dataclasses import dataclass, field +from typing import Any, Dict, List + + +@dataclass +class AllPoints: + points: Dict = field(default_factory=dict) + meta: Dict = field(default_factory=dict) + + def add(self, name: str, value: Any, meta: Dict = {}): + self.points[name] = value + self.meta[name] = meta + + def forbus(self) -> List: + return [self.points, self.meta] + + @staticmethod + def frombus(message: List) -> AllPoints: + assert len(message) == 2, "Message must have a length of 2" + + points = AllPoints() + + for k, v in message[0].items(): + points.add(name=k, value=v, meta=message[1].get(k)) + + return points \ No newline at end of file diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py new file mode 100644 index 0000000000..8aef5e62cc --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -0,0 +1,179 @@ +# Copyright 2022 Battelle Memorial Institute +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. +from __future__ import annotations + +import datetime +import logging +import sys +from pathlib import Path +from pprint import pformat + +from ieee_2030_5 import AllPoints +from ieee_2030_5.client import IEEE2030_5_Client + +try: # for modular + from volttron import utils + from volttron.client.messaging.health import STATUS_GOOD + from volttron.client.vip.agent import RPC, Agent, Core, PubSub + from volttron.client.vip.agent.subsystems.query import Query + from volttron.utils.commands import vip_main +except ImportError: + from volttron.platform.agent import utils + from volttron.platform.agent.utils import vip_main + from volttron.platform.vip.agent import RPC, Agent, Core, PubSub + from volttron.platform.vip.agent.subsystems.query import Query + +# from . import __version__ +__version__ = "0.1.0" + +# Setup logging so that it runs within the platform +utils.setup_logging() + +# The logger for this agent is _log and can be used throughout this file. +_log = logging.getLogger(__name__) + + +class IEEE_2030_5_Agent(Agent): + """ + IEEE_2030_5_Agent + """ + + def __init__(self, config_path: str, **kwargs): + super().__init__(**kwargs) + _log.debug("vip_identity: " + self.core.identity) + + config = utils.load_config(config_path) + + self._cacertfile = Path(config['cacertfile']).expanduser() + self._keyfile = Path(config['keyfile']).expanduser() + self._certfile = Path(config['certfile']).expanduser() + self._subscriptions = config["subscriptions"] + self._server_hostname = config["server_hostname"] + self._server_ssl_port = config.get("server_ssl_port", 443) + self._server_http_port = config.get("server_http_port", None) + self._default_config = {"subscriptions": self._subscriptions} + + self._client = IEEE2030_5_Client(cafile=self._cacertfile, + server_hostname=self._server_hostname, + keyfile=self._keyfile, + certfile=self._certfile, + server_ssl_port=self._server_ssl_port) + + # Set a default configuration to ensure that self.configure is called immediately to setup + # the agent. + self.vip.config.set_default("config", self._default_config) + # Hook self.configure up to changes to the configuration file "config". + self.vip.config.subscribe(self.configure, + actions=["NEW", "UPDATE"], + pattern="config") + + def configure(self, config_name, action, contents): + """ + Called after the Agent has connected to the message bus. If a configuration exists at startup + this will be called before onstart. + + Is called every time the configuration in the store changes. + """ + config = self._default_config.copy() + config.update(contents) + + _log.debug("Configuring Agent") + + try: + subscriptions = config['subscriptions'] + except ValueError as e: + _log.error("ERROR PROCESSING CONFIGURATION: {}".format(e)) + return + + for sub in self._subscriptions: + _log.info(f"Removing subscription: {sub}") + self.vip.pubsub.unsubscribe(peer="pubsub", + prefix=sub, + callback=self._data_published) + + self._subscriptions = subscriptions + + for sub in self._subscriptions: + _log.info(f"Subscribing to: {sub}") + self.vip.pubsub.subscribe(peer="pubsub", + prefix=sub, + callback=self._data_published) + + def _data_published(self, peer, sender, bus, topic, headers, message): + """ + Callback triggered by the subscription setup using the topic from the agent's config file + """ + points = AllPoints.frombus(message) + _log.debug(points.__dict__) + + @Core.receiver("onstart") + def onstart(self, sender, **kwargs): + """ + This is method is called once the Agent has successfully connected to the platform. + This is a good place to setup subscriptions if they are not dynamic or + do any other startup activities that require a connection to the message bus. + Called after any configurations methods that are called at startup. + + Usually not needed if using the configuration store. + """ + # Example publish to pubsub + # self.vip.pubsub.publish('pubsub', "some/random/topic", message="HI!") + + # Example RPC call + # self.vip.rpc.call("some_agent", "some_method", arg1, arg2) + pass + + @Core.receiver("onstop") + def onstop(self, sender, **kwargs): + """ + This method is called when the Agent is about to shutdown, but before it disconnects from + the message bus. + """ + pass + + @RPC.export + def rpc_method(self, arg1, arg2, kwarg1=None, kwarg2=None): + """ + RPC method + + May be called from another agent via self.vip.rpc.call + """ + return self.setting1 + arg1 - arg2 + + @PubSub.subscribe('pubsub', '', all_platforms=True) + def on_match(self, peer, sender, bus, topic, headers, message): + """Use match_all to receive all messages and print them out.""" + _log.debug( + "Peer: {0}, Sender: {1}:, Bus: {2}, Topic: {3}, Headers: {4}, " + "Message: \n{5}".format(peer, sender, bus, topic, headers, + pformat(message))) + + +def main(): + """ + Main method called during startup of agent. + :return: + """ + try: + vip_main(IEEE_2030_5_Agent, version=__version__) + except Exception as e: + _log.exception('unhandled exception') + + +if __name__ == '__main__': + # Entry point for script + try: + sys.exit(main()) + except KeyboardInterrupt: + pass diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py new file mode 100644 index 0000000000..0cf8066f75 --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -0,0 +1,294 @@ +from __future__ import annotations + +import atexit +import logging +import ssl +import threading +import xml.dom.minidom +from http.client import HTTPSConnection +from os import PathLike +from pathlib import Path +from threading import Timer +from typing import Dict, Optional, Tuple +import xsdata + +import ieee_2030_5.models as m + + +_log = logging.getLogger(__name__) + + +class IEEE2030_5_Client: + clients: set[IEEE2030_5_Client] = set() + + # noinspection PyUnresolvedReferences + def __init__(self, + cafile: PathLike, + server_hostname: str, + keyfile: PathLike, + certfile: PathLike, + server_ssl_port: Optional[int] = 443, + debug: bool = True): + + cafile = cafile if isinstance(cafile, PathLike) else Path(cafile) + keyfile = keyfile if isinstance(keyfile, PathLike) else Path(keyfile) + certfile = certfile if isinstance(certfile, PathLike) else Path(certfile) + + self._key = keyfile + self._cert = certfile + self._ca = cafile + + assert cafile.exists(), f"cafile doesn't exist ({cafile})" + assert keyfile.exists(), f"keyfile doesn't exist ({keyfile})" + assert certfile.exists(), f"certfile doesn't exist ({certfile})" + + self._ssl_context = ssl.SSLContext(ssl.PROTOCOL_TLS_CLIENT) + self._ssl_context.check_hostname = False + self._ssl_context.verify_mode = ssl.CERT_OPTIONAL # ssl.CERT_REQUIRED + self._ssl_context.load_verify_locations(cafile=cafile) + + # Loads client information from the passed cert and key files. For + # client side validation. + self._ssl_context.load_cert_chain(certfile=certfile, keyfile=keyfile) + + self._http_conn = HTTPSConnection(host=server_hostname, + port=server_ssl_port, + context=self._ssl_context) + self._device_cap: Optional[m.DeviceCapability] = None + self._mup: Optional[m.MirrorUsagePointList] = None + self._upt: Optional[m.UsagePointList] = None + self._edev: Optional[m.EndDeviceListLink] = None + self._end_devices: Optional[m.EndDeviceListLink] = None + self._fsa_list: Optional[m.FunctionSetAssignmentsListLink] = None + self._debug = debug + self._dcap_poll_rate: int = 0 + self._dcap_timer: Optional[Timer] = None + self._disconnect: bool = False + + IEEE2030_5_Client.clients.add(self) + + @property + def http_conn(self) -> HTTPSConnection: + if self._http_conn.sock is None: + self._http_conn.connect() + return self._http_conn + + def register_end_device(self) -> str: + lfid = utils.get_lfdi_from_cert(self._cert) + sfid = utils.get_sfdi_from_lfdi(lfid) + response = self.__post__(dcap.EndDeviceListLink.href, data=utils.dataclass_to_xml(m.EndDevice(sFDI=sfid))) + print(response) + + if response.status in (200, 201): + return response.headers.get("Location") + + raise werkzeug.exceptions.Forbidden() + + + + + def is_end_device_registered(self, end_device: m.EndDevice, pin: int) -> bool: + reg = self.registration(end_device) + return reg.pIN == pin + + def new_uuid(self, url: str = "/uuid") -> str: + res = self.__get_request__(url) + return res + + def end_devices(self) -> m.EndDeviceListLink: + self._end_devices = self.__get_request__(self._device_cap.EndDeviceListLink.href) + return self._end_devices + + def end_device(self, index: Optional[int] = 0) -> m.EndDevice: + if not self._end_devices: + self.end_devices() + + return self._end_devices.EndDevice[index] + + def self_device(self) -> m.EndDevice: + if not self._device_cap: + self.device_capability() + + return self.__get_request__(self._device_cap.SelfDeviceLink.href) + + def function_set_assignment(self) -> m.FunctionSetAssignmentsListLink: + fsa_list = self.__get_request__(self.end_device().FunctionSetAssignmentsListLink.href) + return fsa_list + + def poll_timer(self, fn, args): + if not self._disconnect: + _log.debug(threading.currentThread().name) + fn(args) + threading.currentThread().join() + + def device_capability(self, url: str = "/dcap") -> m.DeviceCapability: + self._device_cap: m.DeviceCapability = self.__get_request__(url) + if self._device_cap.pollRate is not None: + self._dcap_poll_rate = self._device_cap.pollRate + else: + self._dcap_poll_rate = 600 + + _log.debug(f"devcap id {id(self._device_cap)}") + _log.debug(threading.currentThread().name) + _log.debug(f"DCAP: Poll rate: {self._dcap_poll_rate}") + # self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, (self.device_capability, url)) + # self._dcap_timer.start() + return self._device_cap + + def time(self) -> m.Time: + timexml = self.__get_request__(self._device_cap.TimeLink.href) + return timexml + + def der_program_list(self, device: m.EndDevice) -> m.DERProgramList: + fsa: m.FunctionSetAssignments = self.__get_request__(device.FunctionSetAssignmentsListLink.href) + der_programs_list: m.DERProgramList = self.__get_request__(fsa.DERProgramListLink.href) + + return der_programs_list + + def mirror_usage_point_list(self) -> m.MirrorUsagePointList: + self._mup = self.__get_request__(self._device_cap.MirrorUsagePointListLink.href) + return self._mup + + def usage_point_list(self) -> m.UsagePointList: + self._upt = self.__get_request__(self._device_cap.UsagePointListLink.href) + return self._upt + + def registration(self, end_device: m.EndDevice) -> m.Registration: + reg = self.__get_request__(end_device.RegistrationLink.href) + return reg + + def timelink(self): + if self._device_cap is None: + raise ValueError("Request device capability first") + return self.__get_request__(url=self._device_cap.TimeLink.href) + + def disconnect(self): + self._disconnect = True + self._dcap_timer.cancel() + IEEE2030_5_Client.clients.remove(self) + + def request(self, endpoint: str, body: dict = None, method: str = "GET", + headers: dict = None): + + if method.upper() == 'GET': + return self.__get_request__(endpoint, body, headers=headers) + + if method.upper() == 'POST': + print("Doing post") + return self.__post__(endpoint, body, headers=headers) + + def create_mirror_usage_point(self, mirror_usage_point: m.MirrorUsagePoint) -> Tuple[int, str]: + data = dataclass_to_xml(mirror_usage_point) + resp = self.__post__(self._device_cap.MirrorUsagePointListLink.href, data=data) + return resp.status, resp.headers['Location'] + + def __post__(self, url: str, data=None, headers: Optional[Dict[str, str]]=None): + if not headers: + headers = {'Content-Type': 'text/xml'} + + self.http_conn.request(method="POST", headers=headers, + url=url, body=data) + response = self._http_conn.getresponse() + # response_data = response.read().decode("utf-8") + + return response + + def __get_request__(self, url: str, body=None, headers: dict = None): + if headers is None: + headers = {"Connection": "keep-alive", "keep-alive": "timeout=30, max=1000"} + + if self._debug: + print(f"----> GET REQUEST") + print(f"url: {url} body: {body}") + self.http_conn.request(method="GET", url=url, body=body, headers=headers) + response = self._http_conn.getresponse() + response_data = response.read().decode("utf-8") + print(response.headers) + + response_obj = None + try: + response_obj = utils.xml_to_dataclass(response_data) + resp_xml = xml.dom.minidom.parseString(response_data) + if resp_xml and self._debug: + print(f"<---- GET RESPONSE") + print(f"{response_data}") # toprettyxml()}") + + except xsdata.exceptions.ParserError as ex: + if self._debug: + print(f"<---- GET RESPONSE") + print(f"{response_data}") + response_obj = response_data + + return response_obj + + def __close__(self): + self._http_conn.close() + self._ssl_context = None + self._http_conn = None + + +# noinspection PyTypeChecker +def __release_clients__(): + for x in IEEE2030_5_Client.clients: + x.__close__() + IEEE2030_5_Client.clients = None + + +atexit.register(__release_clients__) + +# +# ssl_context = ssl.create_default_context(cafile=str(SERVER_CA_CERT)) +# +# +# con = HTTPSConnection("me.com", 8000, +# key_file=str(KEY_FILE), +# cert_file=str(CERT_FILE), +# context=ssl_context) +# con.request("GET", "/dcap") +# print(con.getresponse().read()) +# con.close() + +if __name__ == '__main__': + SERVER_CA_CERT = Path("~/tls/certs/ca.crt").expanduser().resolve() + KEY_FILE = Path("~/tls/private/dev1.pem").expanduser().resolve() + CERT_FILE = Path("~/tls/certs/dev1.crt").expanduser().resolve() + + headers = {'Connection': 'Keep-Alive', + 'Keep-Alive': "max=1000,timeout=30"} + + h = IEEE2030_5_Client(cafile=SERVER_CA_CERT, + server_hostname="127.0.0.1", + server_ssl_port=8070, + keyfile=KEY_FILE, + certfile=CERT_FILE, + debug=True) + # h2 = IEEE2030_5_Client(cafile=SERVER_CA_CERT, server_hostname="me.com", ssl_port=8000, + # keyfile=KEY_FILE, certfile=KEY_FILE) + dcap = h.device_capability() + end_devices = h.end_devices() + + if not end_devices.all > 0: + print("registering end device.") + ed_href = h.register_end_device() + my_ed = h.end_devices() + + + # ed = h.end_devices()[0] + # resp = h.request("/dcap", headers=headers) + # print(resp) + # resp = h.request("/dcap", headers=headers) + # print(resp) + #dcap = h.device_capability() + # get device list + #dev_list = h.request(dcap.EndDeviceListLink.href).EndDevice + + #ed = h.request(dev_list[0].href) + #print(ed) + # + # print(dcap.mirror_usage_point_list_link) + # # print(h.request(dcap.mirror_usage_point_list_link.href)) + # print(h.request("/dcap", method="post")) + + + # tl = h.timelink() + #print(IEEE2030_5_Client.clients) diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py b/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py new file mode 100644 index 0000000000..eefbd542b8 --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py @@ -0,0 +1,594 @@ +# Copyright 2022 Battelle Memorial Institute +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may not +# use this file except in compliance with the License. You may obtain a copy +# of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. +from ieee_2030_5.models.device_category import DeviceCategoryType + +from ieee_2030_5.models.sep import ( + AbstractDevice, + AccountBalance, + AccountBalanceLink, + AccountingUnit, + ActiveBillingPeriodListLink, + ActiveCreditRegisterListLink, + ActiveDERControlListLink, + ActiveEndDeviceControlListLink, + ActiveFlowReservationListLink, + ActivePower, + ActiveProjectionReadingListLink, + ActiveSupplyInterruptionOverrideListLink, + ActiveTargetReadingListLink, + ActiveTextMessageListLink, + ActiveTimeTariffIntervalListLink, + AmpereHour, + ApparentPower, + ApplianceLoadReduction, + AppliedTargetReduction, + AssociatedDERProgramListLink, + AssociatedUsagePointLink, + BillingMeterReadingBase, + BillingPeriod, + BillingPeriodList, + BillingPeriodListLink, + BillingReading, + BillingReadingList, + BillingReadingListLink, + BillingReadingSet, + BillingReadingSetList, + BillingReadingSetListLink, + Charge, + Condition, + Configuration, + ConfigurationLink, + ConnectStatusType, + ConsumptionTariffInterval, + ConsumptionTariffIntervalList, + ConsumptionTariffIntervalListLink, + CreditRegister, + CreditRegisterList, + CreditRegisterListLink, + CreditTypeChange, + CurrentDERProgramLink, + CurrentRMS, + CurveData, + CustomerAccount, + CustomerAccountLink, + CustomerAccountList, + CustomerAccountListLink, + CustomerAgreement, + CustomerAgreementList, + CustomerAgreementListLink, + DER, + DERAvailability, + DERAvailabilityLink, + DERCapability, + DERCapabilityLink, + DERControl, + DERControlBase, + DERControlList, + DERControlListLink, + DERControlResponse, + DERCurve, + DERCurveLink, + DERCurveList, + DERCurveListLink, + DERLink, + DERList, + DERListLink, + DERProgram, + DERProgramLink, + DERProgramList, + DERProgramListLink, + DERSettings, + DERSettingsLink, + DERStatus, + DERStatusLink, + DRLCCapabilities, + DateTimeInterval, + DefaultDERControl, + DefaultDERControlLink, + DemandResponseProgram, + DemandResponseProgramLink, + DemandResponseProgramList, + DemandResponseProgramListLink, + DeviceCapability, + DeviceCapabilityLink, + DeviceInformation, + DeviceInformationLink, + DeviceStatus, + DeviceStatusLink, + DrResponse, + DutyCycle, + EndDevice, + EndDeviceControl, + EndDeviceControlList, + EndDeviceControlListLink, + EndDeviceLink, + EndDeviceList, + EndDeviceListLink, + EnvironmentalCost, + Error, + Event, + EventStatus, + File, + FileLink, + FileList, + FileListLink, + FileStatus, + FileStatusLink, + FixedPointType, + FixedVar, + FlowReservationRequest, + FlowReservationRequestList, + FlowReservationRequestListLink, + FlowReservationResponse, + FlowReservationResponseList, + FlowReservationResponseListLink, + FlowReservationResponseResponse, + FreqDroopType, + FunctionSetAssignments, + FunctionSetAssignmentsBase, + FunctionSetAssignmentsList, + FunctionSetAssignmentsListLink, + GPSLocationType, + HistoricalReading, + HistoricalReadingList, + HistoricalReadingListLink, + IEEE_802_15_4, + IPAddr, + IPAddrList, + IPAddrListLink, + IPInterface, + IPInterfaceList, + IPInterfaceListLink, + IdentifiedObject, + InverterStatusType, + LLInterface, + LLInterfaceList, + LLInterfaceListLink, + Link, + List_type, + ListLink, + LoadShedAvailability, + LoadShedAvailabilityList, + LoadShedAvailabilityListLink, + LocalControlModeStatusType, + LogEvent, + LogEventList, + LogEventListLink, + ManufacturerStatusType, + MessagingProgram, + MessagingProgramList, + MessagingProgramListLink, + MeterReading, + MeterReadingBase, + MeterReadingLink, + MeterReadingList, + MeterReadingListLink, + MirrorMeterReading, + MirrorMeterReadingList, + MirrorReadingSet, + MirrorUsagePoint, + MirrorUsagePointList, + MirrorUsagePointListLink, + Neighbor, + NeighborList, + NeighborListLink, + Notification, + NotificationList, + NotificationListLink, + Offset, + OperationalModeStatusType, + PEVInfo, + PowerConfiguration, + PowerFactor, + PowerFactorWithExcitation, + PowerStatus, + PowerStatusLink, + PrepayOperationStatus, + PrepayOperationStatusLink, + Prepayment, + PrepaymentLink, + PrepaymentList, + PrepaymentListLink, + PriceResponse, + PriceResponseCfg, + PriceResponseCfgList, + PriceResponseCfgListLink, + ProjectionReading, + ProjectionReadingList, + ProjectionReadingListLink, + RPLInstance, + RPLInstanceList, + RPLInstanceListLink, + RPLSourceRoutes, + RPLSourceRoutesList, + RPLSourceRoutesListLink, + RandomizableEvent, + RateComponent, + RateComponentLink, + RateComponentList, + RateComponentListLink, + ReactivePower, + ReactiveSusceptance, + Reading, + ReadingBase, + ReadingLink, + ReadingList, + ReadingListLink, + ReadingSet, + ReadingSetBase, + ReadingSetList, + ReadingSetListLink, + ReadingType, + ReadingTypeLink, + RealEnergy, + Registration, + RegistrationLink, + RequestStatus, + Resource, + RespondableIdentifiedObject, + RespondableResource, + RespondableSubscribableIdentifiedObject, + Response, + ResponseList, + ResponseListLink, + ResponseSet, + ResponseSetList, + ResponseSetListLink, + SelfDevice, + SelfDeviceLink, + ServiceChange, + ServiceSupplier, + ServiceSupplierLink, + ServiceSupplierList, + SetPoint, + SignedRealEnergy, + StateOfChargeStatusType, + StorageModeStatusType, + SubscribableIdentifiedObject, + SubscribableList, + SubscribableResource, + Subscription, + SubscriptionBase, + SubscriptionList, + SubscriptionListLink, + SupplyInterruptionOverride, + SupplyInterruptionOverrideList, + SupplyInterruptionOverrideListLink, + SupportedLocale, + SupportedLocaleList, + SupportedLocaleListLink, + TargetReading, + TargetReadingList, + TargetReadingListLink, + TargetReduction, + TariffProfile, + TariffProfileLink, + TariffProfileList, + TariffProfileListLink, + Temperature, + TextMessage, + TextMessageList, + TextMessageListLink, + TextResponse, + Time, + TimeConfiguration, + TimeLink, + TimeTariffInterval, + TimeTariffIntervalList, + TimeTariffIntervalListLink, + UnitValueType, + UnsignedFixedPointType, + UsagePoint, + UsagePointBase, + UsagePointLink, + UsagePointList, + UsagePointListLink, + VoltageRMS, + WattHour, + loWPAN, +) + +__all__ = [ + "DERFlexibility", + "DERForecast", + "DERForecastLink", + "ForecastNumericType", + "ForecastParameter", + "ForecastParameterSet", + "ForecastParameterSetList", + "AbstractDevice", + "AccountBalance", + "AccountBalanceLink", + "AccountingUnit", + "ActiveBillingPeriodListLink", + "ActiveCreditRegisterListLink", + "ActiveDERControlListLink", + "ActiveEndDeviceControlListLink", + "ActiveFlowReservationListLink", + "ActivePower", + "ActiveProjectionReadingListLink", + "ActiveSupplyInterruptionOverrideListLink", + "ActiveTargetReadingListLink", + "ActiveTextMessageListLink", + "ActiveTimeTariffIntervalListLink", + "AmpereHour", + "ApparentPower", + "ApplianceLoadReduction", + "AppliedTargetReduction", + "AssociatedDERProgramListLink", + "AssociatedUsagePointLink", + "BillingMeterReadingBase", + "BillingPeriod", + "BillingPeriodList", + "BillingPeriodListLink", + "BillingReading", + "BillingReadingList", + "BillingReadingListLink", + "BillingReadingSet", + "BillingReadingSetList", + "BillingReadingSetListLink", + "Charge", + "Condition", + "Configuration", + "ConfigurationLink", + "ConnectStatusType", + "ConsumptionTariffInterval", + "ConsumptionTariffIntervalList", + "ConsumptionTariffIntervalListLink", + "CreditRegister", + "CreditRegisterList", + "CreditRegisterListLink", + "CreditTypeChange", + "CurrentDERProgramLink", + "CurrentRMS", + "CurveData", + "CustomerAccount", + "CustomerAccountLink", + "CustomerAccountList", + "CustomerAccountListLink", + "CustomerAgreement", + "CustomerAgreementList", + "CustomerAgreementListLink", + "DER", + "DERAvailability", + "DERAvailabilityLink", + "DERCapability", + "DERCapabilityLink", + "DERControl", + "DERControlBase", + "DERControlList", + "DERControlListLink", + "DERControlResponse", + "DERCurve", + "DERCurveLink", + "DERCurveList", + "DERCurveListLink", + "DERLink", + "DERList", + "DERListLink", + "DERProgram", + "DERProgramLink", + "DERProgramList", + "DERProgramListLink", + "DERSettings", + "DERSettingsLink", + "DERStatus", + "DERStatusLink", + "DRLCCapabilities", + "DateTimeInterval", + "DefaultDERControl", + "DefaultDERControlLink", + "DemandResponseProgram", + "DemandResponseProgramLink", + "DemandResponseProgramList", + "DemandResponseProgramListLink", + "DeviceCapability", + "DeviceCapabilityLink", + "DeviceCategoryType", + "DeviceInformation", + "DeviceInformationLink", + "DeviceStatus", + "DeviceStatusLink", + "DrResponse", + "DutyCycle", + "EndDevice", + "EndDeviceControl", + "EndDeviceControlList", + "EndDeviceControlListLink", + "EndDeviceLink", + "EndDeviceList", + "EndDeviceListLink", + "EnvironmentalCost", + "Error", + "Event", + "EventStatus", + "File", + "FileLink", + "FileList", + "FileListLink", + "FileStatus", + "FileStatusLink", + "FixedPointType", + "FixedVar", + "FlowReservationRequest", + "FlowReservationRequestList", + "FlowReservationRequestListLink", + "FlowReservationResponse", + "FlowReservationResponseList", + "FlowReservationResponseListLink", + "FlowReservationResponseResponse", + "FreqDroopType", + "FunctionSetAssignments", + "FunctionSetAssignmentsBase", + "FunctionSetAssignmentsList", + "FunctionSetAssignmentsListLink", + "GPSLocationType", + "HistoricalReading", + "HistoricalReadingList", + "HistoricalReadingListLink", + "IEEE_802_15_4", + "IPAddr", + "IPAddrList", + "IPAddrListLink", + "IPInterface", + "IPInterfaceList", + "IPInterfaceListLink", + "IdentifiedObject", + "InverterStatusType", + "LLInterface", + "LLInterfaceList", + "LLInterfaceListLink", + "Link", + "List_type", + "ListLink", + "LoadShedAvailability", + "LoadShedAvailabilityList", + "LoadShedAvailabilityListLink", + "LocalControlModeStatusType", + "LogEvent", + "LogEventList", + "LogEventListLink", + "ManufacturerStatusType", + "MessagingProgram", + "MessagingProgramList", + "MessagingProgramListLink", + "MeterReading", + "MeterReadingBase", + "MeterReadingLink", + "MeterReadingList", + "MeterReadingListLink", + "MirrorMeterReading", + "MirrorMeterReadingList", + "MirrorReadingSet", + "MirrorUsagePoint", + "MirrorUsagePointList", + "MirrorUsagePointListLink", + "Neighbor", + "NeighborList", + "NeighborListLink", + "Notification", + "NotificationList", + "NotificationListLink", + "Offset", + "OperationalModeStatusType", + "PEVInfo", + "PowerConfiguration", + "PowerFactor", + "PowerFactorWithExcitation", + "PowerStatus", + "PowerStatusLink", + "PrepayOperationStatus", + "PrepayOperationStatusLink", + "Prepayment", + "PrepaymentLink", + "PrepaymentList", + "PrepaymentListLink", + "PriceResponse", + "PriceResponseCfg", + "PriceResponseCfgList", + "PriceResponseCfgListLink", + "ProjectionReading", + "ProjectionReadingList", + "ProjectionReadingListLink", + "RPLInstance", + "RPLInstanceList", + "RPLInstanceListLink", + "RPLSourceRoutes", + "RPLSourceRoutesList", + "RPLSourceRoutesListLink", + "RandomizableEvent", + "RateComponent", + "RateComponentLink", + "RateComponentList", + "RateComponentListLink", + "ReactivePower", + "ReactiveSusceptance", + "Reading", + "ReadingBase", + "ReadingLink", + "ReadingList", + "ReadingListLink", + "ReadingSet", + "ReadingSetBase", + "ReadingSetList", + "ReadingSetListLink", + "ReadingType", + "ReadingTypeLink", + "RealEnergy", + "Registration", + "RegistrationLink", + "RequestStatus", + "Resource", + "RespondableIdentifiedObject", + "RespondableResource", + "RespondableSubscribableIdentifiedObject", + "Response", + "ResponseList", + "ResponseListLink", + "ResponseSet", + "ResponseSetList", + "ResponseSetListLink", + "SelfDevice", + "SelfDeviceLink", + "ServiceChange", + "ServiceSupplier", + "ServiceSupplierLink", + "ServiceSupplierList", + "SetPoint", + "SignedRealEnergy", + "StateOfChargeStatusType", + "StorageModeStatusType", + "SubscribableIdentifiedObject", + "SubscribableList", + "SubscribableResource", + "Subscription", + "SubscriptionBase", + "SubscriptionList", + "SubscriptionListLink", + "SupplyInterruptionOverride", + "SupplyInterruptionOverrideList", + "SupplyInterruptionOverrideListLink", + "SupportedLocale", + "SupportedLocaleList", + "SupportedLocaleListLink", + "TargetReading", + "TargetReadingList", + "TargetReadingListLink", + "TargetReduction", + "TariffProfile", + "TariffProfileLink", + "TariffProfileList", + "TariffProfileListLink", + "Temperature", + "TextMessage", + "TextMessageList", + "TextMessageListLink", + "TextResponse", + "Time", + "TimeConfiguration", + "TimeLink", + "TimeTariffInterval", + "TimeTariffIntervalList", + "TimeTariffIntervalListLink", + "UnitValueType", + "UnsignedFixedPointType", + "UsagePoint", + "UsagePointBase", + "UsagePointLink", + "UsagePointList", + "UsagePointListLink", + "VoltageRMS", + "WattHour", + "loWPAN", +] diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/constants.py b/services/core/IEEE_2030_5/ieee_2030_5/models/constants.py new file mode 100644 index 0000000000..b8e9bbf8fc --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/constants.py @@ -0,0 +1,200 @@ +import enum +""" Metering +""" + + +class RtgNormalCategoryType(enum.IntEnum): + not_specified = 0 + category_a = 1 + category_b = 2 + + +class RtgAbnormalCategoryType(enum.IntEnum): + not_specified = 0 + category_I = 1 + category_II = 2 + category_III = 3 + + +class DataQualifierType(enum.IntEnum): + Not_applicable = 0 + Average = 2 + Maximum = 8 + Minimum = 9 + Normal = 12 + Standard_deviation_of_population = 29 + Standard_deviation_of_sample = 30 + + +class CommodityType(enum.IntEnum): + Not_applicable = 0 + Electricity_secondary_metered = 1 + Electricity_primary_metered = 2 + Air = 4 + NaturalGas = 7 + Propane = 8 + PotableWater = 9 + Steam = 10 + WasteWater = 11 + HeatingFluid = 12 + CoolingFluid = 13 + + +class FlowDirectionType(enum.IntEnum): + Not_applicable = 0 + Forward = 1 + Reverse = 19 + + +class UomType(enum.IntEnum): + Not_applicable = 0 + Amperes = 5 + Kelvin = 6 + Degrees_celsius = 23 + Voltage = 29 + Joule = 31 + Hz = 33 + W = 38 + M_cubed = 42 + VA = 61 + VAr = 63 + CosTheta = 65 + V_squared = 67 + A_squared = 69 + VAh = 71 + Wh = 72 + VArh = 73 + Ah = 106 + Ft_cubed = 119 + Ft_cubed_per_hour = 122 + M_cubed_per_hour = 125 + US_gallons = 128 + UG_gallons_per_hour = 129 + Imperial_gallons = 130 + Imperial_gallons_per_hour = 131 + BTU = 132 + BTU_per_hour = 133 + Liter = 134 + Liter_per_hour = 137 + PA_gauge = 140 + PA_absolute = 155 + Therm = 169 + + +class RoleFlagsType(enum.Flag): + IsMirror = 0 + IsPremiseAggregationPoint = 1 + IsPEV = 2 + IsDER = 4 + IsRevenueQuality = 8 + IsDC = 16 + IsSubmeter = 32 + + +class AccumlationBehaviourType(enum.IntEnum): + Not_applicable = 0 + Cumulative = 3 + DeltaData = 4 + Indicating = 6 + Summation = 9 + Instantaneous = 12 + + +class ServiceKind(enum.IntEnum): + Electricity = 0 + Gas = 1 + Water = 2 + Time = 3 + Pressure = 4 + Heat = 5 + Cooling = 6 + + +class QualityFlagsType(enum.Flag): + Valid = 0 + Manually_edited = 1 + estimated_using_reference_day = 2 + estimated_using_linear_interpolation = 4 + questionable = 8 + derived = 16 + projected = 32 + + +# p163 +class ConsumptionBlockType(enum.IntEnum): + Not_applicable = 0 + Block_1 = 1 + Block_2 = 2 + Block_3 = 3 + Block_4 = 4 + Block_5 = 5 + Block_6 = 6 + Block_7 = 7 + Block_8 = 8 + Block_9 = 9 + Block_10 = 10 + Block_11 = 11 + Block_12 = 12 + Block_13 = 13 + Block_14 = 14 + Block_15 = 15 + Block_16 = 16 + + +# p170 +class TOUType(enum.IntEnum): + Not_applicable = 0 + TOU_A = 1 + TOU_B = 2 + TOU_C = 3 + TOU_D = 4 + TOU_E = 5 + TOU_F = 6 + TOU_G = 7 + TOU_H = 8 + TOU_I = 9 + TOU_J = 10 + TOU_K = 11 + TOU_L = 12 + TOU_M = 13 + TOU_N = 14 + TOU_O = 15 + + +class KindType(enum.IntEnum): + Not_applicable = 0 + Currency = 3 + Demand = 8 + Energy = 12 + Power = 37 + + +class PhaseCode(enum.IntEnum): + Not_applicable = 0 + Phase_C = 32 # and S2 + Phase_CN = 33 # and S2N + Phase_CA = 40 + Phase_B = 64 + Phase_BN = 65 + Phase_BC = 66 + Phase_A = 128 # and S1 + Phase_AN = 129 # and S1N + Phase_AB = 132 + Phase_ABC = 224 + + +""" Subscription/Notification +""" + + +class ResponseRequiredType(enum.Flag): + enddevice_shall_indicate_that_message_was_received = 0 + enddevice_shall_indicate_specific_response = 1 + enduser_customer_response_is_required = 2 + + +class SubscribableType(enum.IntEnum): + resource_does_not_support_subscriptions = 0 + resource_supports_non_conditional_subscriptions = 1 + resource_supports_conditional_subscriptions = 2 + resource_supports_both_conditional_and_non_conditional_subscriptions = 3 diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/device_category.py b/services/core/IEEE_2030_5/ieee_2030_5/models/device_category.py new file mode 100644 index 0000000000..4b8fc3e0b2 --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/device_category.py @@ -0,0 +1,63 @@ +from enum import IntEnum + + +class DeviceCategoryType(IntEnum): + """ + DeviceCategoryType defined from 20305-2018_IIEStandardforSmartEnergyProfileApplicationsProtocol.pdf Appendix + B.2.3.4 Types package + """ + # The Device category types defined. + # Bit positions SHALL be defined as follows: + PROGRAMMABLE_COMMUNICATING_THERMOSTAT = 0 + STRIP_HEATERS = 1 + BASEBOARD_HEATERS = 2 + WATER_HEATER = 3 + POOL_PUMP = 4 + SAUNA = 5 + HOT_TUB = 6 + SMART_APPLIANCE = 7 + IRRIGATION_PUMP = 8 + MANAGED_COMMERCIAL_AND_INDUSTRIAL_LOADS = 9 + SIMPLE_RESIDENTIAL_LOADS = 10 # On/Off loads + EXTERIOR_LIGHTING = 11 + INTERIOR_LIGHTING = 12 + LOAD_CONTROL_SWITCH = 13 + ENERGY_MANAGEMENT_SYSTEM = 14 + SMART_ENERGY_MODULE = 15 + ELECTRIC_VEHICLE = 16 + ELECTRIC_VEHICLE_SUPPLY_EQUIPMENT = 17 + VIRTUAL_OR_MIXED_DER = 18 + RECIPROCATING_ENGINE = 19 # Synchronous Machine + FUEL_CELL = 20 # Battery + PHOTOVOLTAIC_SYSTEM = 21 # Solar + COMBINED_HEAT_AND_POWER = 22 + COMBINED_PV_AND_STORAGE = 23 + OTHER_GENERATION_SYSTEMS = 24 + OTHER_STORAGE_SYSTEMS = 25 + + # Additional here for Aggregator + AGGREGATOR = 99 + OTHER_CLIENT = 100 + + +# 0 - Programmable Communicating Thermostat +# 1 - Strip Heaters +# 2 - Baseboard Heaters +# 3 - Water Heater +# 4 - Pool Pump +# 5 - Sauna +# 6 - Hot tub +# 7 - Smart Appliance +# 8 - Irrigation Pump +# 9 - Managed Commercial and Industrial Loads +# 10 - Simple Residential Loads +# 11 - Exterior Lighting +# 12 - Interior Lighting +# 13 - Electric Vehicle +# 14 - Generation Systems +# 15 - Load Control Switch +# 16 - Smart Inverter +# 17 - EVSE +# 18 - Residential Energy Storage Unit +# 19 - Energy Management System +# 20 - Smart Energy Module diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/sep.py b/services/core/IEEE_2030_5/ieee_2030_5/models/sep.py new file mode 100644 index 0000000000..68fe7fc6da --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/sep.py @@ -0,0 +1,9580 @@ +from __future__ import annotations + +from dataclasses import dataclass, field +from typing import List, Optional + +__NAMESPACE__ = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActivePower: + """The active (real) power P (in W) is the product of root-mean-square + (RMS) voltage, RMS current, and cos(theta) where theta is the phase angle + of current relative to voltage. + + It is the primary measure of the rate of flow of energy. + + :ivar multiplier: Specifies exponent for uom. + :ivar value: Value in watts (uom 38) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class AmpereHour: + """ + Available electric charge. + + :ivar multiplier: Specifies exponent of uom. + :ivar value: Value in ampere-hours (uom 106) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class ApparentPower: + """ + The apparent power S (in VA) is the product of root mean square (RMS) + voltage and RMS current. + + :ivar multiplier: Specifies exponent of uom. + :ivar value: Value in volt-amperes (uom 61) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class ApplianceLoadReduction: + """The ApplianceLoadReduction object is used by a Demand Response service + provider to provide signals for ENERGY STAR compliant appliances. + + See the definition of ApplianceLoadReductionType for more + information. + + :ivar type: Indicates the type of appliance load reduction + requested. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + type: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class AppliedTargetReduction: + """ + Specifies the value of the TargetReduction applied by the device. + + :ivar type: Enumerated field representing the type of reduction + requested. + :ivar value: Indicates the requested amount of the relevant + commodity to be reduced. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + type: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class Charge: + """Charges contain charges on a customer bill. + + These could be items like taxes, levies, surcharges, rebates, or + others. This is meant to allow the HAN device to retrieve enough + information to be able to reconstruct an estimate of what the total + bill would look like. Providers can provide line item billing, + including multiple charge kinds (e.g. taxes, surcharges) at whatever + granularity desired, using as many Charges as desired during a + billing period. There can also be any number of Charges associated + with different ReadingTypes to distinguish between TOU tiers, + consumption blocks, or demand charges. + + :ivar description: A description of the charge. + :ivar kind: The type (kind) of charge. + :ivar value: A monetary charge. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + description: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 20, + } + ) + kind: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class Condition: + """ + Indicates a condition that must be satisfied for the Notification to be + triggered. + + :ivar attributeIdentifier: 0 = Reading value 1-255 = Reserved + :ivar lowerThreshold: The value of the lower threshold + :ivar upperThreshold: The value of the upper threshold + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + attributeIdentifier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + lowerThreshold: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + } + ) + upperThreshold: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + } + ) + + +@dataclass +class ConnectStatusType: + """DER ConnectStatus value (bitmap): + + 0 - Connected + 1 - Available + 2 - Operating + 3 - Test + 4 - Fault / Error + All other values reserved. + + :ivar dateTime: The date and time at which the state applied. + :ivar value: The value indicating the state. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 1, + "format": "base16", + } + ) + + +@dataclass +class CreditTypeChange: + """ + Specifies a change to the credit type. + + :ivar newType: The new credit type, to take effect at the time + specified by startTime + :ivar startTime: The date/time when the change is to take effect. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + newType: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + startTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class CurrentRMS: + """ + Average flow of charge through a conductor. + + :ivar multiplier: Specifies exponent of value. + :ivar value: Value in amperes RMS (uom 5) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class CurveData: + """ + Data point values for defining a curve or schedule. + + :ivar excitation: If yvalue is Power Factor, then this field SHALL + be present. If yvalue is not Power Factor, then this field SHALL + NOT be present. True when DER is absorbing reactive power + (under-excited), false when DER is injecting reactive power + (over-excited). + :ivar xvalue: The data value of the X-axis (independent) variable, + depending on the curve type. See definitions in DERControlBase + for further information. + :ivar yvalue: The data value of the Y-axis (dependent) variable, + depending on the curve type. See definitions in DERControlBase + for further information. If yvalue is Power Factor, the + excitation field SHALL be present and yvalue SHALL be a positive + value. If yvalue is not Power Factor, the excitation field SHALL + NOT be present. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + excitation: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + } + ) + xvalue: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + yvalue: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class DateTimeInterval: + """ + Interval of date and time. + + :ivar duration: Duration of the interval, in seconds. + :ivar start: Date and time of the start of the interval. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + duration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + start: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class DutyCycle: + """Duty cycle control is a device specific issue and is managed by the + device. + + The duty cycle of the device under control should span the shortest + practical time period in accordance with the nature of the device + under control and the intent of the request for demand reduction. + The default factory setting SHOULD be three minutes for each 10% of + duty cycle. This indicates that the default time period over which + a duty cycle is applied is 30 minutes, meaning a 10% duty cycle + would cause a device to be ON for 3 minutes. The “off state” SHALL + precede the “on state”. + + :ivar normalValue: Contains the maximum On state duty cycle applied + by the end device, as a percentage of time. The field not + present indicates that this field has not been used by the end + device. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + normalValue: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class EnvironmentalCost: + """Provides alternative or secondary price information for the relevant + RateComponent. + + Supports jurisdictions that seek to convey the environmental price + per unit of the specified commodity not expressed in currency. + Implementers and consumers can use this attribute to prioritize + operations of their HAN devices (e.g., PEV charging during times of + high availability of renewable electricity resources). + + :ivar amount: The estimated or actual environmental or other cost, + per commodity unit defined by the ReadingType, for this + RateComponent (e.g., grams of carbon dioxide emissions each per + kWh). + :ivar costKind: The kind of cost referred to in the amount. + :ivar costLevel: The relative level of the amount attribute. In + conjunction with numCostLevels, this attribute informs a device + of the relative scarcity of the amount attribute (e.g., a high + or low availability of renewable generation). numCostLevels and + costLevel values SHALL ascend in order of scarcity, where "0" + signals the lowest relative cost and higher values signal + increasing cost. For example, if numCostLevels is equal to “3,” + then if the lowest relative costLevel were equal to “0,” devices + would assume this is the lowest relative period to operate. + Likewise, if the costLevel in the next TimeTariffInterval + instance is equal to “1,” then the device would assume it is + relatively more expensive, in environmental terms, to operate + during this TimeTariffInterval instance than the previous one. + There is no limit to the number of relative price levels other + than that indicated in the attribute type, but for practicality, + service providers should strive for simplicity and recognize the + diminishing returns derived from increasing the numCostLevel + value greater than four. + :ivar numCostLevels: The number of all relative cost levels. In + conjunction with costLevel, numCostLevels signals the relative + scarcity of the commodity for the duration of the + TimeTariffInterval instance (e.g., a relative indication of + cost). This is useful in providing context for nominal cost + signals to consumers or devices that might see a range of amount + values from different service providres or from the same service + provider. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + amount: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + costKind: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + costLevel: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + numCostLevels: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class Error: + """ + Contains information about the nature of an error if a request could not be + completed successfully. + + :ivar maxRetryDuration: Contains the number of seconds the client + SHOULD wait before retrying the request. + :ivar reasonCode: Code indicating the reason for failure. 0 - + Invalid request format 1 - Invalid request values (e.g. invalid + threshold values) 2 - Resource limit reached 3 - Conditional + subscription field not supported 4 - Maximum request frequency + exceeded All other values reserved + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + maxRetryDuration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + reasonCode: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class EventStatus: + """Current status information relevant to a specific object. + + The Status object is used to indicate the current status of an + Event. Devices can read the containing resource (e.g. TextMessage) + to get the most up to date status of the event. Devices can also + subscribe to a specific resource instance to get updates when any of + its attributes change, including the Status object. + + :ivar currentStatus: Field representing the current status type. 0 = + Scheduled This status indicates that the event has been + scheduled and the event has not yet started. The server SHALL + set the event to this status when the event is first scheduled + and persist until the event has become active or has been + cancelled. For events with a start time less than or equal to + the current time, this status SHALL never be indicated, the + event SHALL start with a status of “Active”. 1 = Active This + status indicates that the event is currently active. The server + SHALL set the event to this status when the event reaches its + earliest Effective Start Time. 2 = Cancelled When events are + cancelled, the Status.dateTime attribute SHALL be set to the + time the cancellation occurred, which cannot be in the future. + The server is responsible for maintaining the cancelled event in + its collection for the duration of the original event, or until + the server has run out of space and needs to store a new event. + Client devices SHALL be aware of Cancelled events, determine if + the Cancelled event applies to them, and cancel the event + immediately if applicable. 3 = Cancelled with Randomization The + server is responsible for maintaining the cancelled event in its + collection for the duration of the Effective Scheduled Period. + Client devices SHALL be aware of Cancelled with Randomization + events, determine if the Cancelled event applies to them, and + cancel the event immediately, using the larger of (absolute + value of randomizeStart) and (absolute value of + randomizeDuration) as the end randomization, in seconds. This + Status.type SHALL NOT be used with "regular" Events, only with + specializations of RandomizableEvent. 4 = Superseded Events + marked as Superseded by servers are events that may have been + replaced by new events from the same program that target the + exact same set of deviceCategory's (if applicable) AND + DERControl controls (e.g., opModTargetW) (if applicable) and + overlap for a given period of time. Servers SHALL mark an event + as Superseded at the earliest Effective Start Time of the + overlapping event. Servers are responsible for maintaining the + Superseded event in their collection for the duration of the + Effective Scheduled Period. Client devices encountering a + Superseded event SHALL terminate execution of the event + immediately and commence execution of the new event immediately, + unless the current time is within the start randomization window + of the superseded event, in which case the client SHALL obey the + start randomization of the new event. This Status.type SHALL NOT + be used with TextMessage, since multiple text messages can be + active. All other values reserved. + :ivar dateTime: The dateTime attribute will provide a timestamp of + when the current status was defined. dateTime MUST be set to the + time at which the status change occurred, not a time in the + future or past. + :ivar potentiallySuperseded: Set to true by a server of this event + if there are events that overlap this event in time and also + overlap in some, but not all, deviceCategory's (if applicable) + AND DERControl controls (e.g., opModTargetW) (if applicable) in + the same function set instance. + :ivar potentiallySupersededTime: Indicates the time that the + potentiallySuperseded flag was set. + :ivar reason: The Reason attribute allows a Service provider to + provide a textual explanation of the status. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + currentStatus: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + potentiallySuperseded: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + potentiallySupersededTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + reason: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 192, + } + ) + + +@dataclass +class FixedPointType: + """ + Abstract type for specifying a fixed-point value without a given unit of + measure. + + :ivar multiplier: Specifies exponent of uom. + :ivar value: Dimensionless value + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class FixedVar: + """ + Specifies a signed setpoint for reactive power. + + :ivar refType: Indicates whether to interpret 'value' as %setMaxVar + or %statVarAvail. + :ivar value: Specify a signed setpoint for reactive power in % (see + 'refType' for context). + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + refType: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class FreqDroopType: + """ + Type for Frequency-Droop (Frequency-Watt) operation. + + :ivar dBOF: Frequency droop dead band for over-frequency conditions. + In thousandths of Hz. + :ivar dBUF: Frequency droop dead band for under-frequency + conditions. In thousandths of Hz. + :ivar kOF: Frequency droop per-unit frequency change for over- + frequency conditions corresponding to 1 per-unit power output + change. In thousandths, unitless. + :ivar kUF: Frequency droop per-unit frequency change for under- + frequency conditions corresponding to 1 per-unit power output + change. In thousandths, unitless. + :ivar openLoopTms: Open loop response time, the duration from a step + change in control signal input until the output changes by 90% + of its final change before any overshoot, in hundredths of a + second. Resolution is 1/100 sec. A value of 0 is used to mean no + limit. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dBOF: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + dBUF: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + kOF: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + kUF: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + openLoopTms: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class GPSLocationType: + """ + Specifies a GPS location, expressed in WGS 84 coordinates. + + :ivar lat: Specifies the latitude from equator. -90 (south) to +90 + (north) in decimal degrees. + :ivar lon: Specifies the longitude from Greenwich Meridian. -180 + (west) to +180 (east) in decimal degrees. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + lat: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + lon: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + + +@dataclass +class InverterStatusType: + """DER InverterStatus value: + + 0 - N/A + 1 - off + 2 - sleeping (auto-shutdown) or DER is at low output power/voltage + 3 - starting up or ON but not producing power + 4 - tracking MPPT power point + 5 - forced power reduction/derating + 6 - shutting down + 7 - one or more faults exist + 8 - standby (service on unit) - DER may be at high output voltage/power + 9 - test mode + 10 - as defined in manufacturer status + All other values reserved. + + :ivar dateTime: The date and time at which the state applied. + :ivar value: The value indicating the state. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class Link: + """ + Links provide a reference, via URI, to another resource. + + :ivar href: A URI reference. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + href: Optional[str] = field( + default=None, + metadata={ + "type": "Attribute", + "required": True, + } + ) + + +@dataclass +class LocalControlModeStatusType: + """DER LocalControlModeStatus/value: + + 0 – local control 1 – remote control All other values reserved. + + :ivar dateTime: The date and time at which the state applied. + :ivar value: The value indicating the state. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class ManufacturerStatusType: + """ + DER ManufacturerStatus/value: String data type. + + :ivar dateTime: The date and time at which the state applied. + :ivar value: The value indicating the state. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 6, + } + ) + + +@dataclass +class Offset: + """If a temperature offset is sent that causes the heating or cooling + temperature set point to exceed the limit boundaries that are programmed + into the device, the device SHALL respond by setting the temperature at the + limit. + + If an EDC is being targeted at multiple devices or to a device that + controls multiple devices (e.g., EMS), it can provide multiple + Offset types within one EDC. For events with multiple Offset types, + a client SHALL select the Offset that best fits their operating + function. Alternatively, an event with a single Offset type can be + targeted at an EMS in order to request a percentage load reduction + on the average energy usage of the entire premise. An EMS SHOULD use + the Metering function set to determine the initial load in the + premise, reduce energy consumption by controlling devices at its + disposal, and at the conclusion of the event, once again use the + Metering function set to determine if the desired load reduction was + achieved. + + :ivar coolingOffset: The value change requested for the cooling + offset, in degree C / 10. The value should be added to the + normal set point for cooling, or if loadShiftForward is true, + then the value should be subtracted from the normal set point. + :ivar heatingOffset: The value change requested for the heating + offset, in degree C / 10. The value should be subtracted for + heating, or if loadShiftForward is true, then the value should + be added to the normal set point. + :ivar loadAdjustmentPercentageOffset: The value change requested for + the load adjustment percentage. The value should be subtracted + from the normal setting, or if loadShiftForward is true, then + the value should be added to the normal setting. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + coolingOffset: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + heatingOffset: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + loadAdjustmentPercentageOffset: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class OperationalModeStatusType: + """DER OperationalModeStatus value: + + 0 - Not applicable / Unknown + 1 - Off + 2 - Operational mode + 3 - Test mode + All other values reserved. + + :ivar dateTime: The date and time at which the state applied. + :ivar value: The value indicating the state. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class PowerConfiguration: + """ + Contains configuration related to the device's power sources. + + :ivar batteryInstallTime: Time/Date at which battery was installed, + :ivar lowChargeThreshold: In context of the PowerStatus resource, + this is the value of EstimatedTimeRemaining below which + BatteryStatus "low" is indicated and the PS_LOW_BATTERY is + raised. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + batteryInstallTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + lowChargeThreshold: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class PowerFactor: + """ + Specifies a setpoint for Displacement Power Factor, the ratio between + apparent and active powers at the fundamental frequency (e.g. 60 Hz). + + :ivar displacement: Significand of an unsigned value of cos(theta) + between 0 and 1.0. E.g. a value of 0.95 may be specified as a + displacement of 950 and a multiplier of -3. + :ivar multiplier: Specifies exponent of 'displacement'. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + displacement: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class PowerFactorWithExcitation: + """ + Specifies a setpoint for Displacement Power Factor, the ratio between + apparent and active powers at the fundamental frequency (e.g. 60 Hz) and + includes an excitation flag. + + :ivar displacement: Significand of an unsigned value of cos(theta) + between 0 and 1.0. E.g. a value of 0.95 may be specified as a + displacement of 950 and a multiplier of -3. + :ivar excitation: True when DER is absorbing reactive power (under- + excited), false when DER is injecting reactive power (over- + excited). + :ivar multiplier: Specifies exponent of 'displacement'. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + displacement: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + excitation: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class ReactivePower: + """ + The reactive power Q (in var) is the product of root mean square (RMS) + voltage, RMS current, and sin(theta) where theta is the phase angle of + current relative to voltage. + + :ivar multiplier: Specifies exponent of uom. + :ivar value: Value in volt-amperes reactive (var) (uom 63) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class ReactiveSusceptance: + """ + Reactive susceptance. + + :ivar multiplier: Specifies exponent of uom. + :ivar value: Value in siemens (uom 53) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class RealEnergy: + """ + Real electrical energy. + + :ivar multiplier: Multiplier for 'unit'. + :ivar value: Value of the energy in Watt-hours. (uom 72) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_inclusive": 281474976710655, + } + ) + + +@dataclass +class RequestStatus: + """ + The RequestStatus object is used to indicate the current status of a Flow + Reservation Request. + + :ivar dateTime: The dateTime attribute will provide a timestamp of + when the request status was set. dateTime MUST be set to the + time at which the status change occurred, not a time in the + future or past. + :ivar requestStatus: Field representing the request status type. 0 = + Requested 1 = Cancelled All other values reserved. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + requestStatus: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class Resource: + """ + A resource is an addressable unit of information, either a collection + (List) or instance of an object (identifiedObject, or simply, Resource) + + :ivar href: A reference to the resource address (URI). Required in a + response to a GET, ignored otherwise. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + href: Optional[str] = field( + default=None, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class ServiceChange: + """ + Specifies a change to the service status. + + :ivar newStatus: The new service status, to take effect at the time + specified by startTime + :ivar startTime: The date/time when the change is to take effect. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + newStatus: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + startTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class SetPoint: + """The SetPoint object is used to apply specific temperature set points to + a temperature control device. + + The values of the heatingSetpoint and coolingSetpoint attributes SHALL be calculated as follows: + Cooling/Heating Temperature Set Point / 100 = temperature in degrees Celsius where -273.15°C &lt;= temperature &lt;= 327.67°C, corresponding to a Cooling and/or Heating Temperature Set Point. The maximum resolution this format allows is 0.01°C. + The field not present in a Response indicates that this field has not been used by the end device. + If a temperature is sent that exceeds the temperature limit boundaries that are programmed into the device, the device SHALL respond by setting the temperature at the limit. + + :ivar coolingSetpoint: This attribute represents the cooling + temperature set point in degrees Celsius / 100. (Hundredths of a + degree C) + :ivar heatingSetpoint: This attribute represents the heating + temperature set point in degrees Celsius / 100. (Hundredths of a + degree C) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + coolingSetpoint: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + heatingSetpoint: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class SignedRealEnergy: + """ + Real electrical energy, signed. + + :ivar multiplier: Multiplier for 'unit'. + :ivar value: Value of the energy in Watt-hours. (uom 72) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + } + ) + + +@dataclass +class StateOfChargeStatusType: + """ + DER StateOfChargeStatus value: Percent data type. + + :ivar dateTime: The date and time at which the state applied. + :ivar value: The value indicating the state. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class StorageModeStatusType: + """DER StorageModeStatus value: + + 0 – storage charging 1 – storage discharging 2 – storage holding All + other values reserved. + + :ivar dateTime: The date and time at which the state applied. + :ivar value: The value indicating the state. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class TargetReduction: + """The TargetReduction object is used by a Demand Response service provider + to provide a RECOMMENDED threshold that a device/premises should maintain + its consumption below. + + For example, a service provider can provide a RECOMMENDED threshold + of some kWh for a 3-hour event. This means that the device/premises + would maintain its consumption below the specified limit for the + specified period. + + :ivar type: Indicates the type of reduction requested. + :ivar value: Indicates the requested amount of the relevant + commodity to be reduced. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + type: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class Temperature: + """ + Specification of a temperature. + + :ivar multiplier: Multiplier for 'unit'. + :ivar subject: The subject of the temperature measurement 0 - + Enclosure 1 - Transformer 2 - HeatSink + :ivar value: Value in Degrees Celsius (uom 23). + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + subject: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class TimeConfiguration: + """ + Contains attributes related to the configuration of the time service. + + :ivar dstEndRule: Rule to calculate end of daylight savings time in + the current year. Result of dstEndRule must be greater than + result of dstStartRule. + :ivar dstOffset: Daylight savings time offset from local standard + time. + :ivar dstStartRule: Rule to calculate start of daylight savings time + in the current year. Result of dstEndRule must be greater than + result of dstStartRule. + :ivar tzOffset: Local time zone offset from UTCTime. Does not + include any daylight savings time offsets. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dstEndRule: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + } + ) + dstOffset: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + dstStartRule: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + } + ) + tzOffset: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class UnitValueType: + """ + Type for specification of a specific value, with units and power of ten + multiplier. + + :ivar multiplier: Multiplier for 'unit'. + :ivar unit: Unit in symbol + :ivar value: Value in units specified + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + unit: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class UnsignedFixedPointType: + """ + Abstract type for specifying an unsigned fixed-point value without a given + unit of measure. + + :ivar multiplier: Specifies exponent of uom. + :ivar value: Dimensionless value + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class VoltageRMS: + """ + Average electric potential difference between two points. + + :ivar multiplier: Specifies exponent of uom. + :ivar value: Value in volts RMS (uom 29) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class WattHour: + """ + Active (real) energy. + + :ivar multiplier: Specifies exponent of uom. + :ivar value: Value in watt-hours (uom 72) + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class loWPAN: + """ + Contains information specific to 6LoWPAN. + + :ivar octetsRx: Number of Bytes received + :ivar octetsTx: Number of Bytes transmitted + :ivar packetsRx: Number of packets received + :ivar packetsTx: Number of packets transmitted + :ivar rxFragError: Number of errors receiving fragments + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + octetsRx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + octetsTx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + packetsRx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + packetsTx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + rxFragError: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class AccountBalanceLink(Link): + """ + SHALL contain a Link to an instance of AccountBalance. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class AccountingUnit: + """ + Unit for accounting; use either 'energyUnit' or 'currencyUnit' to specify + the unit for 'value'. + + :ivar energyUnit: Unit of service. + :ivar monetaryUnit: Unit of currency. + :ivar multiplier: Multiplier for the 'energyUnit' or 'monetaryUnit'. + :ivar value: Value of the monetary aspect + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + energyUnit: Optional[RealEnergy] = field( + default=None, + metadata={ + "type": "Element", + } + ) + monetaryUnit: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + multiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class AssociatedUsagePointLink(Link): + """SHALL contain a Link to an instance of UsagePoint. + + If present, this is the submeter that monitors the DER output. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class BillingPeriod(Resource): + """A Billing Period relates to the period of time on which a customer is + billed. + + As an example the billing period interval for a particular customer + might be 31 days starting on July 1, 2011. The start date and + interval can change on each billing period. There may also be + multiple billing periods related to a customer agreement to support + different tariff structures. + + :ivar billLastPeriod: The amount of the bill for the previous + billing period. + :ivar billToDate: The bill amount related to the billing period as + of the statusTimeStamp. + :ivar interval: The time interval for this billing period. + :ivar statusTimeStamp: The date / time of the last update of this + resource. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + billLastPeriod: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + } + ) + billToDate: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + } + ) + interval: Optional[DateTimeInterval] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + statusTimeStamp: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ConfigurationLink(Link): + """ + SHALL contain a Link to an instance of Configuration. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ConsumptionTariffInterval(Resource): + """One of a sequence of thresholds defined in terms of consumption quantity + of a service such as electricity, water, gas, etc. + + It defines the steps or blocks in a step tariff structure, where + startValue simultaneously defines the entry value of this step and + the closing value of the previous step. Where consumption is greater + than startValue, it falls within this block and where consumption is + less than or equal to startValue, it falls within one of the + previous blocks. + + :ivar consumptionBlock: Indicates the consumption block related to + the reading. If not specified, is assumed to be "0 - N/A". + :ivar EnvironmentalCost: + :ivar price: The charge for this rate component, per unit of measure + defined by the associated ReadingType, in currency specified in + TariffProfile. The Pricing service provider determines the + appropriate price attribute value based on its applicable + regulatory rules. For example, price could be net or inclusive + of applicable taxes, fees, or levies. The Billing function set + provides the ability to represent billing information in a more + detailed manner. + :ivar startValue: The lowest level of consumption that defines the + starting point of this consumption step or block. Thresholds + start at zero for each billing period. If specified, the first + ConsumptionTariffInterval.startValue for a TimeTariffInteral + instance SHALL begin at "0." Subsequent + ConsumptionTariffInterval.startValue elements SHALL be greater + than the previous one. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + consumptionBlock: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + EnvironmentalCost: List[EnvironmentalCost] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + price: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + startValue: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_inclusive": 281474976710655, + } + ) + + +@dataclass +class CurrentDERProgramLink(Link): + """SHALL contain a Link to an instance of DERProgram. + + If present, this is the DERProgram containing the currently active + DERControl. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class CustomerAccountLink(Link): + """ + SHALL contain a Link to an instance of CustomerAccount. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERAvailabilityLink(Link): + """ + SHALL contain a Link to an instance of DERAvailability. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERCapability(Resource): + """ + Distributed energy resource type and nameplate ratings. + + :ivar modesSupported: Bitmap indicating the DER Controls implemented + by the device. See DERControlType for values. + :ivar rtgAbnormalCategory: Abnormal operating performance category + as defined by IEEE 1547-2018. One of: 0 - not specified 1 - + Category I 2 - Category II 3 - Category III All other values + reserved. + :ivar rtgMaxA: Maximum continuous AC current capability of the DER, + in Amperes (RMS). + :ivar rtgMaxAh: Usable energy storage capacity of the DER, in + AmpHours. + :ivar rtgMaxChargeRateVA: Maximum apparent power charge rating in + Volt-Amperes. May differ from the maximum apparent power rating. + :ivar rtgMaxChargeRateW: Maximum rate of energy transfer received by + the storage DER, in Watts. + :ivar rtgMaxDischargeRateVA: Maximum apparent power discharge rating + in Volt-Amperes. May differ from the maximum apparent power + rating. + :ivar rtgMaxDischargeRateW: Maximum rate of energy transfer + delivered by the storage DER, in Watts. Required for combined + generation/storage DERs (e.g. DERType == 83). + :ivar rtgMaxV: AC voltage maximum rating. + :ivar rtgMaxVA: Maximum continuous apparent power output capability + of the DER, in VA. + :ivar rtgMaxVar: Maximum continuous reactive power delivered by the + DER, in var. + :ivar rtgMaxVarNeg: Maximum continuous reactive power received by + the DER, in var. If absent, defaults to negative rtgMaxVar. + :ivar rtgMaxW: Maximum continuous active power output capability of + the DER, in watts. Represents combined generation plus storage + output if DERType == 83. + :ivar rtgMaxWh: Maximum energy storage capacity of the DER, in + WattHours. + :ivar rtgMinPFOverExcited: Minimum Power Factor displacement + capability of the DER when injecting reactive power (over- + excited); SHALL be a positive value between 0.0 (typically + &gt; 0.7) and 1.0. If absent, defaults to unity. + :ivar rtgMinPFUnderExcited: Minimum Power Factor displacement + capability of the DER when absorbing reactive power (under- + excited); SHALL be a positive value between 0.0 (typically + &gt; 0.7) and 0.9999. If absent, defaults to + rtgMinPFOverExcited. + :ivar rtgMinV: AC voltage minimum rating. + :ivar rtgNormalCategory: Normal operating performance category as + defined by IEEE 1547-2018. One of: 0 - not specified 1 - + Category A 2 - Category B All other values reserved. + :ivar rtgOverExcitedPF: Specified over-excited power factor. + :ivar rtgOverExcitedW: Active power rating in Watts at specified + over-excited power factor (rtgOverExcitedPF). If present, + rtgOverExcitedPF SHALL be present. + :ivar rtgReactiveSusceptance: Reactive susceptance that remains + connected to the Area EPS in the cease to energize and trip + state. + :ivar rtgUnderExcitedPF: Specified under-excited power factor. + :ivar rtgUnderExcitedW: Active power rating in Watts at specified + under-excited power factor (rtgUnderExcitedPF). If present, + rtgUnderExcitedPF SHALL be present. + :ivar rtgVNom: AC voltage nominal rating. + :ivar type: Type of DER; see DERType object + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + modesSupported: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + } + ) + rtgAbnormalCategory: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxA: Optional[CurrentRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxAh: Optional[AmpereHour] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxChargeRateVA: Optional[ApparentPower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxChargeRateW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxDischargeRateVA: Optional[ApparentPower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxDischargeRateW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxV: Optional[VoltageRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxVA: Optional[ApparentPower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxVar: Optional[ReactivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxVarNeg: Optional[ReactivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMaxW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + rtgMaxWh: Optional[WattHour] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMinPFOverExcited: Optional[PowerFactor] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMinPFUnderExcited: Optional[PowerFactor] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgMinV: Optional[VoltageRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgNormalCategory: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgOverExcitedPF: Optional[PowerFactor] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgOverExcitedW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgReactiveSusceptance: Optional[ReactiveSusceptance] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgUnderExcitedPF: Optional[PowerFactor] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgUnderExcitedW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rtgVNom: Optional[VoltageRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + type: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class DERCapabilityLink(Link): + """ + SHALL contain a Link to an instance of DERCapability. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERCurveLink(Link): + """ + SHALL contain a Link to an instance of DERCurve. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERLink(Link): + """ + SHALL contain a Link to an instance of DER. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERProgramLink(Link): + """ + SHALL contain a Link to an instance of DERProgram. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERSettingsLink(Link): + """ + SHALL contain a Link to an instance of DERSettings. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERStatusLink(Link): + """ + SHALL contain a Link to an instance of DERStatus. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DRLCCapabilities: + """ + Contains information about the static capabilities of the device, to allow + service providers to know what types of functions are supported, what the + normal operating ranges and limits are, and other similar information, in + order to provide better suggestions of applicable programs to receive the + maximum benefit. + + :ivar averageEnergy: The average hourly energy usage when in normal + operating mode. + :ivar maxDemand: The maximum demand rating of this end device. + :ivar optionsImplemented: Bitmap indicating the DRLC options + implemented by the device. 0 - Target reduction (kWh) 1 - Target + reduction (kW) 2 - Target reduction (Watts) 3 - Target reduction + (Cubic Meters) 4 - Target reduction (Cubic Feet) 5 - Target + reduction (US Gallons) 6 - Target reduction (Imperial Gallons) 7 + - Target reduction (BTUs) 8 - Target reduction (Liters) 9 - + Target reduction (kPA (gauge)) 10 - Target reduction (kPA + (absolute)) 11 - Target reduction (Mega Joule) 12 - Target + reduction (Unitless) 13-15 - Reserved 16 - Temperature set point + 17 - Temperature offset 18 - Duty cycle 19 - Load adjustment + percentage 20 - Appliance load reduction 21-31 - Reserved + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + averageEnergy: Optional[RealEnergy] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + maxDemand: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + optionsImplemented: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + } + ) + + +@dataclass +class DefaultDERControlLink(Link): + """SHALL contain a Link to an instance of DefaultDERControl. + + This is the default mode of the DER which MAY be overridden by + DERControl events. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DemandResponseProgramLink(Link): + """ + SHALL contain a Link to an instance of DemandResponseProgram. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DeviceCapabilityLink(Link): + """ + SHALL contain a Link to an instance of DeviceCapability. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DeviceInformationLink(Link): + """ + SHALL contain a Link to an instance of DeviceInformation. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DeviceStatusLink(Link): + """ + SHALL contain a Link to an instance of DeviceStatus. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class EndDeviceLink(Link): + """ + SHALL contain a Link to an instance of EndDevice. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class File(Resource): + """This resource contains various meta-data describing a file's + characteristics. + + The meta-data provides general file information and also is used to + support filtered queries of file lists + + :ivar activateTime: This element MUST be set to the date/time at + which this file is activated. If the activation time is less + than or equal to current time, the LD MUST immediately place the + file into the activated state (in the case of a firmware file, + the file is now the running image). If the activation time is + greater than the current time, the LD MUST wait until the + specified activation time is reached, then MUST place the file + into the activated state. Omission of this element means that + the LD MUST NOT take any action to activate the file until a + subsequent GET to this File resource provides an activateTime. + :ivar fileURI: This element MUST be set to the URI location of the + file binary artifact. This is the BLOB (binary large object) + that is actually loaded by the LD + :ivar lFDI: This element MUST be set to the LFDI of the device for + which this file in targeted. + :ivar mfHwVer: This element MUST be set to the hardware version for + which this file is targeted. + :ivar mfID: This element MUST be set to the manufacturer's Private + Enterprise Number (assigned by IANA). + :ivar mfModel: This element MUST be set to the manufacturer model + number for which this file is targeted. The syntax and semantics + are left to the manufacturer. + :ivar mfSerNum: This element MUST be set to the manufacturer serial + number for which this file is targeted. The syntax and semantics + are left to the manufacturer. + :ivar mfVer: This element MUST be set to the software version + information for this file. The syntax and semantics are left to + the manufacturer. + :ivar size: This element MUST be set to the total size (in bytes) of + the file referenced by fileURI. + :ivar type: A value indicating the type of the file. MUST be one of + the following values: 00 = Software Image 01 = Security + Credential 02 = Configuration 03 = Log 04–7FFF = reserved + 8000-FFFF = Manufacturer defined + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + activateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + fileURI: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + lFDI: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 20, + "format": "base16", + } + ) + mfHwVer: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + mfID: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + mfModel: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + mfSerNum: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + mfVer: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + } + ) + size: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + type: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 2, + "format": "base16", + } + ) + + +@dataclass +class FileLink(Link): + """This element MUST be set to the URI of the most recent File being + loaded/activated by the LD. + + In the case of file status 0, this element MUST be omitted. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class FileStatusLink(Link): + """ + SHALL contain a Link to an instance of FileStatus. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class IdentifiedObject(Resource): + """ + This is a root class to provide common naming attributes for all classes + needing naming attributes. + + :ivar mRID: The global identifier of the object. + :ivar description: The description is a human readable text + describing or naming the object. + :ivar version: Contains the version number of the object. See the + type definition for details. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + mRID: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + description: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + version: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class List_type(Resource): + """Container to hold a collection of object instances or references. + + See Design Pattern section for additional details. + + :ivar all: The number specifying "all" of the items in the list. + Required on a response to a GET, ignored otherwise. + :ivar results: Indicates the number of items in this page of + results. + """ + class Meta: + name = "List" + namespace = "urn:ieee:std:2030.5:ns" + + all: Optional[int] = field( + default=None, + metadata={ + "type": "Attribute", + "required": True, + } + ) + results: Optional[int] = field( + default=None, + metadata={ + "type": "Attribute", + "required": True, + } + ) + + +@dataclass +class ListLink(Link): + """ + ListLinks provide a reference, via URI, to a List. + + :ivar all: Indicates the total number of items in the referenced + list. This attribute SHALL be present if the href is a local or + relative URI. This attribute SHOULD NOT be present if the href + is a remote or absolute URI, as the server may be unaware of + changes to the value. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + all: Optional[int] = field( + default=None, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class LogEvent(Resource): + """ + A time stamped instance of a significant event detected by the device. + + :ivar createdDateTime: The date and time that the event occurred. + :ivar details: Human readable text that MAY be used to transmit + additional details about the event. A host MAY remove this field + when received. + :ivar extendedData: May be used to transmit additional details about + the event. + :ivar functionSet: If the profileID indicates this is IEEE 2030.5, + the functionSet is defined by IEEE 2030.5 and SHALL be one of + the values from the table below (IEEE 2030.5 function set + identifiers). If the profileID is anything else, the functionSet + is defined by the identified profile. 0 General (not + specific to a function set) 1 Publish and Subscribe 2 + End Device 3 Function Set Assignment 4 Response 5 + Demand Response and Load Control 6 Metering 7 + Pricing 8 Messaging 9 Billing 10 Prepayment 11 + Distributed Energy Resources 12 Time 13 Software + Download 14 Device Information 15 Power Status 16 + Network Status 17 Log Event List 18 Configuration 19 + Security All other values are reserved. + :ivar logEventCode: An 8 bit unsigned integer. logEventCodes are + scoped to a profile and a function set. If the profile is IEEE + 2030.5, the logEventCode is defined by IEEE 2030.5 within one of + the function sets of IEEE 2030.5. If the profile is anything + else, the logEventCode is defined by the specified profile. + :ivar logEventID: This 16-bit value, combined with createdDateTime, + profileID, and logEventPEN, should provide a reasonable level of + uniqueness. + :ivar logEventPEN: The Private Enterprise Number(PEN) of the entity + that defined the profileID, functionSet, and logEventCode of the + logEvent. IEEE 2030.5-assigned logEventCodes SHALL use the IEEE + 2030.5 PEN. Combinations of profileID, functionSet, and + logEventCode SHALL have unique meaning within a logEventPEN and + are defined by the owner of the PEN. + :ivar profileID: The profileID identifies which profile (HA, BA, SE, + etc) defines the following event information. 0 Not + profile specific. 1 Vendor Defined 2 IEEE 2030.5 3 + Home Automation 4 Building Automation All other values are + reserved. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + createdDateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + details: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + extendedData: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + functionSet: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + logEventCode: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + logEventID: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + logEventPEN: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + profileID: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class MeterReadingLink(Link): + """ + SHALL contain a Link to an instance of MeterReading. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class Neighbor(Resource): + """ + Contains 802.15.4 link layer specific attributes. + + :ivar isChild: True if the neighbor is a child. + :ivar linkQuality: The quality of the link, as defined by 802.15.4 + :ivar shortAddress: As defined by IEEE 802.15.4 + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + isChild: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + linkQuality: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + shortAddress: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class PEVInfo: + """ + Contains attributes that can be exposed by PEVs and other devices that have + charging requirements. + + :ivar chargingPowerNow: This is the actual power flow in or out of + the charger or inverter. This is calculated by the vehicle based + on actual measurements. This number is positive for charging. + :ivar energyRequestNow: This is the amount of energy that must be + transferred from the grid to EVSE and PEV to achieve the target + state of charge allowing for charger efficiency and any vehicle + and EVSE parasitic loads. This is calculated by the vehicle and + changes throughout the connection as forward or reverse power + flow change the battery state of charge. This number is + positive for charging. + :ivar maxForwardPower: This is maximum power transfer capability + that could be used for charging the PEV to perform the requested + energy transfer. It is the lower of the vehicle or EVSE + physical power limitations. It is not based on economic + considerations. The vehicle may draw less power than this value + based on its charging cycle. The vehicle defines this parameter. + This number is positive for charging power flow. + :ivar minimumChargingDuration: This is computed by the PEV based on + the charging profile to complete the energy transfer if the + maximum power is authorized. The value will never be smaller + than the ratio of the energy request to the power request + because the charging profile may not allow the maximum power to + be used throughout the transfer. This is a critical parameter + for determining whether any slack time exists in the charging + cycle between the current time and the TCIN. + :ivar targetStateOfCharge: This is the target state of charge that + is to be achieved during charging before the time of departure + (TCIN). The default value is 100%. The value cannot be set to a + value less than the actual state of charge. + :ivar timeChargeIsNeeded: Time Charge is Needed (TCIN) is the time + that the PEV is expected to depart. The value is manually + entered using controls and displays in the vehicle or on the + EVSE or using a mobile device. It is authenticated and saved by + the PEV. This value may be updated during a charging session. + :ivar timeChargingStatusPEV: This is the time that the parameters + are updated, except for changes to TCIN. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + chargingPowerNow: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + energyRequestNow: Optional[RealEnergy] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + maxForwardPower: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + minimumChargingDuration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + targetStateOfCharge: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + timeChargeIsNeeded: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + timeChargingStatusPEV: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class PowerStatusLink(Link): + """ + SHALL contain a Link to an instance of PowerStatus. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class PrepayOperationStatus(Resource): + """ + PrepayOperationStatus describes the status of the service or commodity + being conditionally controlled by the Prepayment function set. + + :ivar creditTypeChange: CreditTypeChange is used to define a pending + change of creditTypeInUse, which will activate at a specified + time. + :ivar creditTypeInUse: CreditTypeInUse identifies whether the + present mode of operation is consuming regular credit or + emergency credit. + :ivar serviceChange: ServiceChange is used to define a pending + change of serviceStatus, which will activate at a specified + time. + :ivar serviceStatus: ServiceStatus identifies whether the service is + connected or disconnected, or armed for connection or + disconnection. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + creditTypeChange: Optional[CreditTypeChange] = field( + default=None, + metadata={ + "type": "Element", + } + ) + creditTypeInUse: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + serviceChange: Optional[ServiceChange] = field( + default=None, + metadata={ + "type": "Element", + } + ) + serviceStatus: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class PrepayOperationStatusLink(Link): + """ + SHALL contain a Link to an instance of PrepayOperationStatus. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class PrepaymentLink(Link): + """ + SHALL contain a Link to an instance of Prepayment. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class RPLSourceRoutes(Resource): + """ + A RPL source routes object. + + :ivar DestAddress: See [RFC 6554]. + :ivar SourceRoute: See [RFC 6554]. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DestAddress: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + SourceRoute: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + + +@dataclass +class RateComponentLink(Link): + """ + SHALL contain a Link to an instance of RateComponent. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ReadingBase(Resource): + """Specific value measured by a meter or other asset. + + ReadingBase is abstract, used to define the elements common to + Reading and IntervalReading. + + :ivar consumptionBlock: Indicates the consumption block related to + the reading. REQUIRED if ReadingType numberOfConsumptionBlocks + is non-zero. If not specified, is assumed to be "0 - N/A". + :ivar qualityFlags: List of codes indicating the quality of the + reading, using specification: Bit 0 - valid: data that has gone + through all required validation checks and either passed them + all or has been verified Bit 1 - manually edited: Replaced or + approved by a human Bit 2 - estimated using reference day: data + value was replaced by a machine computed value based on analysis + of historical data using the same type of measurement. Bit 3 - + estimated using linear interpolation: data value was computed + using linear interpolation based on the readings before and + after it Bit 4 - questionable: data that has failed one or more + checks Bit 5 - derived: data that has been calculated (using + logic or mathematical operations), not necessarily measured + directly Bit 6 - projected (forecast): data that has been + calculated as a projection or forecast of future readings + :ivar timePeriod: The time interval associated with the reading. If + not specified, then defaults to the intervalLength specified in + the associated ReadingType. + :ivar touTier: Indicates the time of use tier related to the + reading. REQUIRED if ReadingType numberOfTouTiers is non-zero. + If not specified, is assumed to be "0 - N/A". + :ivar value: Value in units specified by ReadingType + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + consumptionBlock: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + qualityFlags: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 2, + "format": "base16", + } + ) + timePeriod: Optional[DateTimeInterval] = field( + default=None, + metadata={ + "type": "Element", + } + ) + touTier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + value: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + } + ) + + +@dataclass +class ReadingLink(Link): + """ + A Link to a Reading. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ReadingType(Resource): + """Type of data conveyed by a specific Reading. + + See IEC 61968 Part 9 Annex C for full definitions of these values. + + :ivar accumulationBehaviour: The “accumulation behaviour” indicates + how the value is represented to accumulate over time. + :ivar calorificValue: The amount of heat generated when a given mass + of fuel is completely burned. The CalorificValue is used to + convert the measured volume or mass of gas into kWh. The + CalorificValue attribute represents the current active value. + :ivar commodity: Indicates the commodity applicable to this + ReadingType. + :ivar conversionFactor: Accounts for changes in the volume of gas + based on temperature and pressure. The ConversionFactor + attribute represents the current active value. The + ConversionFactor is dimensionless. The default value for the + ConversionFactor is 1, which means no conversion is applied. A + price server can advertise a new/different value at any time. + :ivar dataQualifier: The data type can be used to describe a salient + attribute of the data. Possible values are average, absolute, + and etc. + :ivar flowDirection: Anything involving current might have a flow + direction. Possible values include forward and reverse. + :ivar intervalLength: Default interval length specified in seconds. + :ivar kind: Compound class that contains kindCategory and kindIndex + :ivar maxNumberOfIntervals: To be populated for mirrors of interval + data to set the expected number of intervals per ReadingSet. + Servers may discard intervals received that exceed this number. + :ivar numberOfConsumptionBlocks: Number of consumption blocks. 0 + means not applicable, and is the default if not specified. The + value needs to be at least 1 if any actual prices are provided. + :ivar numberOfTouTiers: The number of TOU tiers that can be used by + any resource configured by this ReadingType. Servers SHALL + populate this value with the largest touTier value that will + <i>ever</i> be used while this ReadingType is in + effect. Servers SHALL set numberOfTouTiers equal to the number + of standard TOU tiers plus the number of CPP tiers that may be + used while this ReadingType is in effect. Servers SHALL specify + a value between 0 and 255 (inclusive) for numberOfTouTiers + (servers providing flat rate pricing SHOULD set numberOfTouTiers + to 0, as in practice there is no difference between having no + tiers and having one tier). + :ivar phase: Contains phase information associated with the type. + :ivar powerOfTenMultiplier: Indicates the power of ten multiplier + applicable to the unit of measure of this ReadingType. + :ivar subIntervalLength: Default sub-interval length specified in + seconds for Readings of ReadingType. Some demand calculations + are done over a number of smaller intervals. For example, in a + rolling demand calculation, the demand value is defined as the + rolling sum of smaller intervals over the intervalLength. The + subintervalLength is the length of the smaller interval in this + calculation. It SHALL be an integral division of the + intervalLength. The number of sub-intervals can be calculated by + dividing the intervalLength by the subintervalLength. + :ivar supplyLimit: Reflects the supply limit set in the meter. This + value can be compared to the Reading value to understand if + limits are being approached or exceeded. Units follow the same + definition as in this ReadingType. + :ivar tieredConsumptionBlocks: Specifies whether or not the + consumption blocks are differentiated by TOUTier or not. Default + is false, if not specified. true = consumption accumulated over + individual tiers false = consumption accumulated over all tiers + :ivar uom: Indicates the measurement type for the units of measure + for the readings of this type. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + accumulationBehaviour: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + calorificValue: Optional[UnitValueType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + commodity: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + conversionFactor: Optional[UnitValueType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + dataQualifier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + flowDirection: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + intervalLength: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + kind: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + maxNumberOfIntervals: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + numberOfConsumptionBlocks: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + numberOfTouTiers: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + phase: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + powerOfTenMultiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + subIntervalLength: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + supplyLimit: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "max_inclusive": 281474976710655, + } + ) + tieredConsumptionBlocks: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + } + ) + uom: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ReadingTypeLink(Link): + """ + SHALL contain a Link to an instance of ReadingType. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class Registration(Resource): + """ + Registration represents an authorization to access the resources on a host. + + :ivar dateTimeRegistered: Contains the time at which this + registration was created, by which clients MAY prioritize + information providers with the most recent registrations, when + no additional direction from the consumer is available. + :ivar pIN: Contains the registration PIN number associated with the + device, including the checksum digit. + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + dateTimeRegistered: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + pIN: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class RegistrationLink(Link): + """ + SHALL contain a Link to an instance of Registration. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class RespondableResource(Resource): + """ + A Resource to which a Response can be requested. + + :ivar replyTo: A reference to the response resource address (URI). + Required on a response to a GET if responseRequired is "true". + :ivar responseRequired: Indicates whether or not a response is + required upon receipt, creation or update of this resource. + Responses shall be posted to the collection specified in + "replyTo". If the resource has a deviceCategory field, devices + that match one or more of the device types indicated in + deviceCategory SHALL respond according to the rules listed + below. If the category does not match, the device SHALL NOT + respond. If the resource does not have a deviceCategory field, a + device receiving the resource SHALL respond according to the + rules listed below. Value encoded as hex according to the + following bit assignments, any combination is possible. See + Table 27 for the list of appropriate Response status codes to be + sent for these purposes. 0 - End device shall indicate that + message was received 1 - End device shall indicate specific + response. 2 - End user / customer response is required. All + other values reserved. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + replyTo: Optional[str] = field( + default=None, + metadata={ + "type": "Attribute", + } + ) + responseRequired: bytes = field( + default=b"\x00", + metadata={ + "type": "Attribute", + "max_length": 1, + "format": "base16", + } + ) + + +@dataclass +class Response(Resource): + """ + The Response object is the generic response data repository which is + extended for specific function sets. + + :ivar createdDateTime: The createdDateTime field contains the date + and time when the acknowledgement/status occurred in the client. + The client will provide the timestamp to ensure the proper time + is captured in case the response is delayed in reaching the + server (server receipt time would not be the same as the actual + confirmation time). The time reported from the client should be + relative to the time server indicated by the + FunctionSetAssignment that also indicated the event resource; if + no FunctionSetAssignment exists, the time of the server where + the event resource was hosted. + :ivar endDeviceLFDI: Contains the LFDI of the device providing the + response. + :ivar status: The status field contains the acknowledgement or + status. Each event type (DRLC, DER, Price, or Text) can return + different status information (e.g. an Acknowledge will be + returned for a Price event where a DRLC event can return Event + Received, Event Started, and Event Completed). The Status field + value definitions are defined in Table 27: Response Types by + Function Set. + :ivar subject: The subject field provides a method to match the + response with the originating event. It is populated with the + mRID of the original object. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + createdDateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + endDeviceLFDI: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 20, + "format": "base16", + } + ) + status: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + subject: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + + +@dataclass +class SelfDeviceLink(Link): + """ + SHALL contain a Link to an instance of SelfDevice. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ServiceSupplierLink(Link): + """ + SHALL contain a Link to an instance of ServiceSupplier. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class SubscribableResource(Resource): + """ + A Resource to which a Subscription can be requested. + + :ivar subscribable: Indicates whether or not subscriptions are + supported for this resource, and whether or not conditional + (thresholds) are supported. If not specified, is "not + subscribable" (0). + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + subscribable: int = field( + default=0, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class SubscriptionBase(Resource): + """Holds the information related to a client subscription to receive + updates to a resource automatically. + + The actual resources may be passed in the Notification by specifying + a specific xsi:type for the Resource and passing the full + representation. + + :ivar subscribedResource: The resource for which the subscription + applies. Query string parameters SHALL NOT be specified when + subscribing to list resources. Should a query string parameter + be specified, servers SHALL ignore them. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + subscribedResource: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class SupplyInterruptionOverride(Resource): + """SupplyInterruptionOverride: There may be periods of time when social, regulatory or other concerns mean that service should not be interrupted, even when available credit has been exhausted. Each Prepayment instance links to a List of SupplyInterruptionOverride instances. Each SupplyInterruptionOverride defines a contiguous period of time during which supply SHALL NOT be interrupted. + + :ivar description: The description is a human readable text + describing or naming the object. + :ivar interval: Interval defines the period of time during which + supply should not be interrupted. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + description: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + interval: Optional[DateTimeInterval] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class SupportedLocale(Resource): + """ + Specifies a locale that is supported. + + :ivar locale: The code for a locale that is supported + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + locale: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 42, + } + ) + + +@dataclass +class TariffProfileLink(Link): + """ + SHALL contain a Link to an instance of TariffProfile. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class Time(Resource): + """ + Contains the representation of time, constantly updated. + + :ivar currentTime: The current time, in the format defined by + TimeType. + :ivar dstEndTime: Time at which daylight savings ends (dstOffset no + longer applied). Result of dstEndRule calculation. + :ivar dstOffset: Daylight savings time offset from local standard + time. A typical practice is advancing clocks one hour when + daylight savings time is in effect, which would result in a + positive dstOffset. + :ivar dstStartTime: Time at which daylight savings begins (apply + dstOffset). Result of dstStartRule calculation. + :ivar localTime: Local time: localTime = currentTime + tzOffset (+ + dstOffset when in effect). + :ivar quality: Metric indicating the quality of the time source from + which the service acquired time. Lower (smaller) quality + enumeration values are assumed to be more accurate. 3 - time + obtained from external authoritative source such as NTP 4 - time + obtained from level 3 source 5 - time manually set or obtained + from level 4 source 6 - time obtained from level 5 source 7 - + time intentionally uncoordinated All other values are reserved + for future use. + :ivar tzOffset: Local time zone offset from currentTime. Does not + include any daylight savings time offsets. For American time + zones, a negative tzOffset SHALL be used (eg, EST = GMT-5 which + is -18000). + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + currentTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + dstEndTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + dstOffset: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + dstStartTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + localTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + quality: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + tzOffset: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class TimeLink(Link): + """ + SHALL contain a Link to an instance of Time. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class UsagePointLink(Link): + """ + SHALL contain a Link to an instance of UsagePoint. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class AccountBalance(Resource): + """AccountBalance contains the regular credit and emergency credit balance + for this given service or commodity prepay instance. + + It may also contain status information concerning the balance data. + + :ivar availableCredit: AvailableCredit shows the balance of the sum + of credits minus the sum of charges. In a Central Wallet mode + this value may be passed down to the Prepayment server via an + out-of-band mechanism. In Local or ESI modes, this value may be + calculated based upon summation of CreditRegister transactions + minus consumption charges calculated using Metering (and + possibly Pricing) function set data. This value may be negative; + for instance, if disconnection is prevented due to a Supply + Interruption Override. + :ivar creditStatus: CreditStatus identifies whether the present + value of availableCredit is considered OK, low, exhausted, or + negative. + :ivar emergencyCredit: EmergencyCredit is the amount of credit still + available for the given service or commodity prepayment + instance. If both availableCredit and emergyCredit are + exhausted, then service will typically be disconnected. + :ivar emergencyCreditStatus: EmergencyCreditStatus identifies + whether the present value of emergencyCredit is considered OK, + low, exhausted, or negative. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + availableCredit: Optional[AccountingUnit] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + creditStatus: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + emergencyCredit: Optional[AccountingUnit] = field( + default=None, + metadata={ + "type": "Element", + } + ) + emergencyCreditStatus: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ActiveBillingPeriodListLink(ListLink): + """ + SHALL contain a Link to a List of active BillingPeriod instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveCreditRegisterListLink(ListLink): + """ + SHALL contain a Link to a List of active CreditRegister instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveDERControlListLink(ListLink): + """ + SHALL contain a Link to a List of active DERControl instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveEndDeviceControlListLink(ListLink): + """ + SHALL contain a Link to a List of active EndDeviceControl instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveFlowReservationListLink(ListLink): + """ + SHALL contain a Link to a List of active FlowReservation instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveProjectionReadingListLink(ListLink): + """ + SHALL contain a Link to a List of active ProjectionReading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveSupplyInterruptionOverrideListLink(ListLink): + """ + SHALL contain a Link to a List of active SupplyInterruptionOverride + instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveTargetReadingListLink(ListLink): + """ + SHALL contain a Link to a List of active TargetReading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveTextMessageListLink(ListLink): + """ + SHALL contain a Link to a List of active TextMessage instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ActiveTimeTariffIntervalListLink(ListLink): + """ + SHALL contain a Link to a List of active TimeTariffInterval instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class AssociatedDERProgramListLink(ListLink): + """ + SHALL contain a Link to a List of DERPrograms having the DERControl(s) for + this DER. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class BillingPeriodListLink(ListLink): + """ + SHALL contain a Link to a List of BillingPeriod instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class BillingReading(ReadingBase): + """Data captured at regular intervals of time. + + Interval data could be captured as incremental data, absolute data, + or relative data. The source for the data is usually a tariff + quantity or an engineering quantity. Data is typically captured in + time-tagged, uniform, fixed-length intervals of 5 min, 10 min, 15 + min, 30 min, or 60 min. However, consumption aggregations can also + be represented with this class. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Charge: List[Charge] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class BillingReadingListLink(ListLink): + """ + SHALL contain a Link to a List of BillingReading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class BillingReadingSetListLink(ListLink): + """ + SHALL contain a Link to a List of BillingReadingSet instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ConsumptionTariffIntervalList(List_type): + """ + A List element to hold ConsumptionTariffInterval objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ConsumptionTariffInterval: List[ConsumptionTariffInterval] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ConsumptionTariffIntervalListLink(ListLink): + """ + SHALL contain a Link to a List of ConsumptionTariffInterval instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class CreditRegister(IdentifiedObject): + """CreditRegister instances define a credit-modifying transaction. + + Typically this would be a credit-adding transaction, but may be a + subtracting transaction (perhaps in response to an out-of-band debt + signal). + + :ivar creditAmount: CreditAmount is the amount of credit being added + by a particular CreditRegister transaction. Negative values + indicate that credit is being subtracted. + :ivar creditType: CreditType indicates whether the credit + transaction applies to regular or emergency credit. + :ivar effectiveTime: EffectiveTime identifies the time at which the + credit transaction goes into effect. For credit addition + transactions, this is typically the moment at which the + transaction takes place. For credit subtraction transactions, + (e.g., non-fuel debt recovery transactions initiated from a + back-haul or ESI) this may be a future time at which credit is + deducted. + :ivar token: Token is security data that authenticates the + legitimacy of the transaction. The details of this token are not + defined by IEEE 2030.5. How a Prepayment server handles this + field is left as vendor specific implementation or will be + defined by one or more other standards. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + creditAmount: Optional[AccountingUnit] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + creditType: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + effectiveTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + token: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + + +@dataclass +class CreditRegisterListLink(ListLink): + """ + SHALL contain a Link to a List of CreditRegister instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class CustomerAccountListLink(ListLink): + """ + SHALL contain a Link to a List of CustomerAccount instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class CustomerAgreementListLink(ListLink): + """ + SHALL contain a Link to a List of CustomerAgreement instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERAvailability(SubscribableResource): + """ + Indicates current reserve generation status. + + :ivar availabilityDuration: Indicates number of seconds the DER will + be able to deliver active power at the reservePercent level. + :ivar maxChargeDuration: Indicates number of seconds the DER will be + able to receive active power at the reserveChargePercent level. + :ivar readingTime: The timestamp when the DER availability was last + updated. + :ivar reserveChargePercent: Percent of continuous received active + power (%setMaxChargeRateW) that is estimated to be available in + reserve. + :ivar reservePercent: Percent of continuous delivered active power + (%setMaxW) that is estimated to be available in reserve. + :ivar statVarAvail: Estimated reserve reactive power, in var. + Represents the lesser of received or delivered reactive power. + :ivar statWAvail: Estimated reserve active power, in watts. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + availabilityDuration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + maxChargeDuration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + readingTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + reserveChargePercent: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + reservePercent: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + statVarAvail: Optional[ReactivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + statWAvail: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class DERControlBase: + """ + Distributed Energy Resource (DER) control values. + + :ivar opModConnect: Set DER as connected (true) or disconnected + (false). Used in conjunction with ramp rate when re-connecting. + Implies galvanic isolation. + :ivar opModEnergize: Set DER as energized (true) or de-energized + (false). Used in conjunction with ramp rate when re-energizing. + :ivar opModFixedPFAbsorbW: The opModFixedPFAbsorbW function + specifies a requested fixed Power Factor (PF) setting for when + active power is being absorbed. The actual displacement SHALL be + within the limits established by setMinPFOverExcited and + setMinPFUnderExcited. If issued simultaneously with other + reactive power controls (e.g. opModFixedVar) the control + resulting in least var magnitude SHOULD take precedence. + :ivar opModFixedPFInjectW: The opModFixedPFInjectW function + specifies a requested fixed Power Factor (PF) setting for when + active power is being injected. The actual displacement SHALL be + within the limits established by setMinPFOverExcited and + setMinPFUnderExcited. If issued simultaneously with other + reactive power controls (e.g. opModFixedVar) the control + resulting in least var magnitude SHOULD take precedence. + :ivar opModFixedVar: The opModFixedVar function specifies the + delivered or received reactive power setpoint. The context for + the setpoint value is determined by refType and SHALL be one of + %setMaxW, %setMaxVar, or %statVarAvail. If issued + simultaneously with other reactive power controls (e.g. + opModFixedPFInjectW) the control resulting in least var + magnitude SHOULD take precedence. + :ivar opModFixedW: The opModFixedW function specifies a requested + charge or discharge mode setpoint, in %setMaxChargeRateW if + negative value or %setMaxW or %setMaxDischargeRateW if positive + value (in hundredths). + :ivar opModFreqDroop: Specifies a frequency-watt operation. This + operation limits active power generation or consumption when the + line frequency deviates from nominal by a specified amount. + :ivar opModFreqWatt: Specify DERCurveLink for curveType == 0. The + Frequency-Watt function limits active power generation or + consumption when the line frequency deviates from nominal by a + specified amount. The Frequency-Watt curve is specified as an + array of Frequency-Watt pairs that are interpolated into a + piecewise linear function with hysteresis. The x value of each + pair specifies a frequency in Hz. The y value specifies a + corresponding active power output in %setMaxW. + :ivar opModHFRTMayTrip: Specify DERCurveLink for curveType == 1. The + High Frequency Ride-Through (HFRT) function is specified by one + or two duration-frequency curves that define the operating + region under high frequency conditions. Each HFRT curve is + specified by an array of duration-frequency pairs that will be + interpolated into a piecewise linear function that defines an + operating region. The x value of each pair specifies a duration + (time at a given frequency in seconds). The y value of each pair + specifies a frequency, in Hz. This control specifies the "may + trip" region. + :ivar opModHFRTMustTrip: Specify DERCurveLink for curveType == 2. + The High Frequency Ride-Through (HFRT) function is specified by + a duration-frequency curve that defines the operating region + under high frequency conditions. Each HFRT curve is specified + by an array of duration-frequency pairs that will be + interpolated into a piecewise linear function that defines an + operating region. The x value of each pair specifies a duration + (time at a given frequency in seconds). The y value of each pair + specifies a frequency, in Hz. This control specifies the "must + trip" region. + :ivar opModHVRTMayTrip: Specify DERCurveLink for curveType == 3. The + High Voltage Ride-Through (HVRT) function is specified by one, + two, or three duration-volt curves that define the operating + region under high voltage conditions. Each HVRT curve is + specified by an array of duration-volt pairs that will be + interpolated into a piecewise linear function that defines an + operating region. The x value of each pair specifies a duration + (time at a given voltage in seconds). The y value of each pair + specifies an effective percentage voltage, defined as ((locally + measured voltage - setVRefOfs / setVRef). This control specifies + the "may trip" region. + :ivar opModHVRTMomentaryCessation: Specify DERCurveLink for + curveType == 4. The High Voltage Ride-Through (HVRT) function + is specified by duration-volt curves that define the operating + region under high voltage conditions. Each HVRT curve is + specified by an array of duration-volt pairs that will be + interpolated into a piecewise linear function that defines an + operating region. The x value of each pair specifies a duration + (time at a given voltage in seconds). The y value of each pair + specifies an effective percent voltage, defined as ((locally + measured voltage - setVRefOfs) / setVRef). This control + specifies the "momentary cessation" region. + :ivar opModHVRTMustTrip: Specify DERCurveLink for curveType == 5. + The High Voltage Ride-Through (HVRT) function is specified by + duration-volt curves that define the operating region under high + voltage conditions. Each HVRT curve is specified by an array of + duration-volt pairs that will be interpolated into a piecewise + linear function that defines an operating region. The x value + of each pair specifies a duration (time at a given voltage in + seconds). The y value of each pair specifies an effective + percent voltage, defined as ((locally measured voltage - + setVRefOfs) / setVRef). This control specifies the "must trip" + region. + :ivar opModLFRTMayTrip: Specify DERCurveLink for curveType == 6. The + Low Frequency Ride-Through (LFRT) function is specified by one + or two duration-frequency curves that define the operating + region under low frequency conditions. Each LFRT curve is + specified by an array of duration-frequency pairs that will be + interpolated into a piecewise linear function that defines an + operating region. The x value of each pair specifies a duration + (time at a given frequency in seconds). The y value of each pair + specifies a frequency, in Hz. This control specifies the "may + trip" region. + :ivar opModLFRTMustTrip: Specify DERCurveLink for curveType == 7. + The Low Frequency Ride-Through (LFRT) function is specified by a + duration-frequency curve that defines the operating region under + low frequency conditions. Each LFRT curve is specified by an + array of duration-frequency pairs that will be interpolated into + a piecewise linear function that defines an operating region. + The x value of each pair specifies a duration (time at a given + frequency in seconds). The y value of each pair specifies a + frequency, in Hz. This control specifies the "must trip" region. + :ivar opModLVRTMayTrip: Specify DERCurveLink for curveType == 8. The + Low Voltage Ride-Through (LVRT) function is specified by one, + two, or three duration-volt curves that define the operating + region under low voltage conditions. Each LVRT curve is + specified by an array of duration-volt pairs that will be + interpolated into a piecewise linear function that defines an + operating region. The x value of each pair specifies a duration + (time at a given voltage in seconds). The y value of each pair + specifies an effective percent voltage, defined as ((locally + measured voltage - setVRefOfs) / setVRef). This control + specifies the "may trip" region. + :ivar opModLVRTMomentaryCessation: Specify DERCurveLink for + curveType == 9. The Low Voltage Ride-Through (LVRT) function is + specified by duration-volt curves that define the operating + region under low voltage conditions. Each LVRT curve is + specified by an array of duration-volt pairs that will be + interpolated into a piecewise linear function that defines an + operating region. The x value of each pair specifies a duration + (time at a given voltage in seconds). The y value of each pair + specifies an effective percent voltage, defined as ((locally + measured voltage - setVRefOfs) / setVRef). This control + specifies the "momentary cessation" region. + :ivar opModLVRTMustTrip: Specify DERCurveLink for curveType == 10. + The Low Voltage Ride-Through (LVRT) function is specified by + duration-volt curves that define the operating region under low + voltage conditions. Each LVRT curve is specified by an array of + duration-volt pairs that will be interpolated into a piecewise + linear function that defines an operating region. The x value + of each pair specifies a duration (time at a given voltage in + seconds). The y value of each pair specifies an effective + percent voltage, defined as ((locally measured voltage - + setVRefOfs) / setVRef). This control specifies the "must trip" + region. + :ivar opModMaxLimW: The opModMaxLimW function sets the maximum + active power generation level at the electrical coupling point + as a percentage of set capacity (%setMaxW, in hundredths). This + limitation may be met e.g. by reducing PV output or by using + excess PV output to charge associated storage. + :ivar opModTargetVar: Target reactive power, in var. This control is + likely to be more useful for aggregators, as individual DERs may + not be able to maintain a target setting. + :ivar opModTargetW: Target output power, in Watts. This control is + likely to be more useful for aggregators, as individual DERs may + not be able to maintain a target setting. + :ivar opModVoltVar: Specify DERCurveLink for curveType == 11. The + static volt-var function provides over- or under-excited var + compensation as a function of measured voltage. The volt-var + curve is specified as an array of volt-var pairs that are + interpolated into a piecewise linear function with hysteresis. + The x value of each pair specifies an effective percent voltage, + defined as ((locally measured voltage - setVRefOfs) / setVRef) + and SHOULD support a domain of at least 0 - 135. If VRef is + present in DERCurve, then the x value of each pair is + additionally multiplied by (VRef / 10000). The y value specifies + a target var output interpreted as a signed percentage (-100 to + 100). The meaning of the y value is determined by yRefType and + must be one of %setMaxW, %setMaxVar, or %statVarAvail. + :ivar opModVoltWatt: Specify DERCurveLink for curveType == 12. The + Volt-Watt reduces active power output as a function of measured + voltage. The Volt-Watt curve is specified as an array of Volt- + Watt pairs that are interpolated into a piecewise linear + function with hysteresis. The x value of each pair specifies an + effective percent voltage, defined as ((locally measured voltage + - setVRefOfs) / setVRef) and SHOULD support a domain of at least + 0 - 135. The y value specifies an active power output + interpreted as a percentage (0 - 100). The meaning of the y + value is determined by yRefType and must be one of %setMaxW or + %statWAvail. + :ivar opModWattPF: Specify DERCurveLink for curveType == 13. The + Watt-PF function varies Power Factor (PF) as a function of + delivered active power. The Watt-PF curve is specified as an + array of Watt-PF coordinates that are interpolated into a + piecewise linear function with hysteresis. The x value of each + pair specifies a watt setting in %setMaxW, (0 - 100). The PF + output setting is a signed displacement in y value (PF sign + SHALL be interpreted according to the EEI convention, where + unity PF is considered unsigned). These settings are not + expected to be updated very often during the life of the + installation, therefore only a single curve is required. If + issued simultaneously with other reactive power controls (e.g. + opModFixedPFInjectW) the control resulting in least var + magnitude SHOULD take precedence. + :ivar opModWattVar: Specify DERCurveLink for curveType == 14. The + Watt-Var function varies vars as a function of delivered active + power. The Watt-Var curve is specified as an array of Watt-Var + pairs that are interpolated into a piecewise linear function + with hysteresis. The x value of each pair specifies a watt + setting in %setMaxW, (0-100). The y value specifies a target var + output interpreted as a signed percentage (-100 to 100). The + meaning of the y value is determined by yRefType and must be one + of %setMaxW, %setMaxVar, or %statVarAvail. + :ivar rampTms: Requested ramp time, in hundredths of a second, for + the device to transition from the current DERControl mode + setting(s) to the new mode setting(s). If absent, use default + ramp rate (setGradW). Resolution is 1/100 sec. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + opModConnect: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModEnergize: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModFixedPFAbsorbW: Optional[PowerFactorWithExcitation] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModFixedPFInjectW: Optional[PowerFactorWithExcitation] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModFixedVar: Optional[FixedVar] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModFixedW: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModFreqDroop: Optional[FreqDroopType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModFreqWatt: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModHFRTMayTrip: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModHFRTMustTrip: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModHVRTMayTrip: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModHVRTMomentaryCessation: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModHVRTMustTrip: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModLFRTMayTrip: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModLFRTMustTrip: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModLVRTMayTrip: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModLVRTMomentaryCessation: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModLVRTMustTrip: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModMaxLimW: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModTargetVar: Optional[ReactivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModTargetW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModVoltVar: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModVoltWatt: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModWattPF: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opModWattVar: Optional[DERCurveLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rampTms: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class DERControlListLink(ListLink): + """ + SHALL contain a Link to a List of DERControl instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERControlResponse(Response): + """ + A response to a DERControl. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERCurve(IdentifiedObject): + """DER related curves such as Volt-Var mode curves. + + Relationship between an independent variable (X-axis) and a + dependent variable (Y-axis). + + :ivar autonomousVRefEnable: If the curveType is opModVoltVar, then + this field MAY be present. If the curveType is not opModVoltVar, + then this field SHALL NOT be present. Enable/disable autonomous + vRef adjustment. When enabled, the Volt-Var curve characteristic + SHALL be adjusted autonomously as vRef changes and + autonomousVRefTimeConstant SHALL be present. If a DER is able to + support Volt-Var mode but is unable to support autonomous vRef + adjustment, then the DER SHALL execute the curve without + autonomous vRef adjustment. If not specified, then the value is + false. + :ivar autonomousVRefTimeConstant: If the curveType is opModVoltVar, + then this field MAY be present. If the curveType is not + opModVoltVar, then this field SHALL NOT be present. Adjustment + range for vRef time constant, in hundredths of a second. + :ivar creationTime: The time at which the object was created. + :ivar CurveData: + :ivar curveType: Specifies the associated curve-based control mode. + :ivar openLoopTms: Open loop response time, the time to ramp up to + 90% of the new target in response to the change in voltage, in + hundredths of a second. Resolution is 1/100 sec. A value of 0 is + used to mean no limit. When not present, the device SHOULD + follow its default behavior. + :ivar rampDecTms: Decreasing ramp rate, interpreted as a percentage + change in output capability limit per second (e.g. %setMaxW / + sec). Resolution is in hundredths of a percent/second. A value + of 0 means there is no limit. If absent, ramp rate defaults to + setGradW. + :ivar rampIncTms: Increasing ramp rate, interpreted as a percentage + change in output capability limit per second (e.g. %setMaxW / + sec). Resolution is in hundredths of a percent/second. A value + of 0 means there is no limit. If absent, ramp rate defaults to + rampDecTms. + :ivar rampPT1Tms: The configuration parameter for a low-pass filter, + PT1 is a time, in hundredths of a second, in which the filter + will settle to 95% of a step change in the input value. + Resolution is 1/100 sec. + :ivar vRef: If the curveType is opModVoltVar, then this field MAY be + present. If the curveType is not opModVoltVar, then this field + SHALL NOT be present. The nominal AC voltage (RMS) adjustment to + the voltage curve points for Volt-Var curves. + :ivar xMultiplier: Exponent for X-axis value. + :ivar yMultiplier: Exponent for Y-axis value. + :ivar yRefType: The Y-axis units context. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + autonomousVRefEnable: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + } + ) + autonomousVRefTimeConstant: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + creationTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + CurveData: List[CurveData] = field( + default_factory=list, + metadata={ + "type": "Element", + "min_occurs": 1, + "max_occurs": 10, + } + ) + curveType: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + openLoopTms: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rampDecTms: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rampIncTms: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + rampPT1Tms: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + vRef: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + xMultiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + yMultiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + yRefType: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class DERCurveListLink(ListLink): + """ + SHALL contain a Link to a List of DERCurve instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERListLink(ListLink): + """ + SHALL contain a Link to a List of DER instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERProgramListLink(ListLink): + """ + SHALL contain a Link to a List of DERProgram instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DERSettings(SubscribableResource): + """ + Distributed energy resource settings. + + :ivar modesEnabled: Bitmap indicating the DER Controls enabled on + the device. See DERControlType for values. If a control is + supported (see DERCapability::modesSupported), but not enabled, + the control will not be executed if encountered. + :ivar setESDelay: Enter service delay, in hundredths of a second. + :ivar setESHighFreq: Enter service frequency high. Specified in + hundredths of Hz. + :ivar setESHighVolt: Enter service voltage high. Specified as an + effective percent voltage, defined as (100% * (locally measured + voltage - setVRefOfs) / setVRef), in hundredths of a percent. + :ivar setESLowFreq: Enter service frequency low. Specified in + hundredths of Hz. + :ivar setESLowVolt: Enter service voltage low. Specified as an + effective percent voltage, defined as (100% * (locally measured + voltage - setVRefOfs) / setVRef), in hundredths of a percent. + :ivar setESRampTms: Enter service ramp time, in hundredths of a + second. + :ivar setESRandomDelay: Enter service randomized delay, in + hundredths of a second. + :ivar setGradW: Set default rate of change (ramp rate) of active + power output due to command or internal action, defined in + %setWMax / second. Resolution is in hundredths of a + percent/second. A value of 0 means there is no limit. + Interpreted as a percentage change in output capability limit + per second when used as a default ramp rate. + :ivar setMaxA: AC current maximum. Maximum AC current in RMS + Amperes. + :ivar setMaxAh: Maximum usable energy storage capacity of the DER, + in AmpHours. Note: this may be different from physical + capability. + :ivar setMaxChargeRateVA: Apparent power charge maximum. Maximum + apparent power the DER can absorb from the grid in Volt-Amperes. + May differ from the apparent power maximum (setMaxVA). + :ivar setMaxChargeRateW: Maximum rate of energy transfer received by + the storage device, in Watts. Defaults to rtgMaxChargeRateW. + :ivar setMaxDischargeRateVA: Apparent power discharge maximum. + Maximum apparent power the DER can deliver to the grid in Volt- + Amperes. May differ from the apparent power maximum (setMaxVA). + :ivar setMaxDischargeRateW: Maximum rate of energy transfer + delivered by the storage device, in Watts. Defaults to + rtgMaxDischargeRateW. + :ivar setMaxV: AC voltage maximum setting. + :ivar setMaxVA: Set limit for maximum apparent power capability of + the DER (in VA). Defaults to rtgMaxVA. + :ivar setMaxVar: Set limit for maximum reactive power delivered by + the DER (in var). SHALL be a positive value &lt;= rtgMaxVar + (default). + :ivar setMaxVarNeg: Set limit for maximum reactive power received by + the DER (in var). If present, SHALL be a negative value + &gt;= rtgMaxVarNeg (default). If absent, defaults to + negative setMaxVar. + :ivar setMaxW: Set limit for maximum active power capability of the + DER (in W). Defaults to rtgMaxW. + :ivar setMaxWh: Maximum energy storage capacity of the DER, in + WattHours. Note: this may be different from physical capability. + :ivar setMinPFOverExcited: Set minimum Power Factor displacement + limit of the DER when injecting reactive power (over-excited); + SHALL be a positive value between 0.0 (typically &gt; 0.7) + and 1.0. SHALL be &gt;= rtgMinPFOverExcited (default). + :ivar setMinPFUnderExcited: Set minimum Power Factor displacement + limit of the DER when absorbing reactive power (under-excited); + SHALL be a positive value between 0.0 (typically &gt; 0.7) + and 0.9999. If present, SHALL be &gt;= rtgMinPFUnderExcited + (default). If absent, defaults to setMinPFOverExcited. + :ivar setMinV: AC voltage minimum setting. + :ivar setSoftGradW: Set soft-start rate of change (soft-start ramp + rate) of active power output due to command or internal action, + defined in %setWMax / second. Resolution is in hundredths of a + percent/second. A value of 0 means there is no limit. + Interpreted as a percentage change in output capability limit + per second when used as a ramp rate. + :ivar setVNom: AC voltage nominal setting. + :ivar setVRef: The nominal AC voltage (RMS) at the utility's point + of common coupling. + :ivar setVRefOfs: The nominal AC voltage (RMS) offset between the + DER's electrical connection point and the utility's point of + common coupling. + :ivar updatedTime: Specifies the time at which the DER information + was last updated. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + modesEnabled: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 4, + "format": "base16", + } + ) + setESDelay: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESHighFreq: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESHighVolt: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESLowFreq: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESLowVolt: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESRampTms: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESRandomDelay: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setGradW: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + setMaxA: Optional[CurrentRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxAh: Optional[AmpereHour] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxChargeRateVA: Optional[ApparentPower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxChargeRateW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxDischargeRateVA: Optional[ApparentPower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxDischargeRateW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxV: Optional[VoltageRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxVA: Optional[ApparentPower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxVar: Optional[ReactivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxVarNeg: Optional[ReactivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMaxW: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + setMaxWh: Optional[WattHour] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMinPFOverExcited: Optional[PowerFactor] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMinPFUnderExcited: Optional[PowerFactor] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setMinV: Optional[VoltageRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setSoftGradW: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setVNom: Optional[VoltageRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setVRef: Optional[VoltageRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setVRefOfs: Optional[VoltageRMS] = field( + default=None, + metadata={ + "type": "Element", + } + ) + updatedTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class DERStatus(SubscribableResource): + """ + DER status information. + + :ivar alarmStatus: Bitmap indicating the status of DER alarms (see + DER LogEvents for more details). 0 - DER_FAULT_OVER_CURRENT 1 - + DER_FAULT_OVER_VOLTAGE 2 - DER_FAULT_UNDER_VOLTAGE 3 - + DER_FAULT_OVER_FREQUENCY 4 - DER_FAULT_UNDER_FREQUENCY 5 - + DER_FAULT_VOLTAGE_IMBALANCE 6 - DER_FAULT_CURRENT_IMBALANCE 7 - + DER_FAULT_EMERGENCY_LOCAL 8 - DER_FAULT_EMERGENCY_REMOTE 9 - + DER_FAULT_LOW_POWER_INPUT 10 - DER_FAULT_PHASE_ROTATION 11-31 - + Reserved + :ivar genConnectStatus: Connect/status value for generator DER. See + ConnectStatusType for values. + :ivar inverterStatus: DER InverterStatus/value. See + InverterStatusType for values. + :ivar localControlModeStatus: The local control mode status. See + LocalControlModeStatusType for values. + :ivar manufacturerStatus: Manufacturer status code. + :ivar operationalModeStatus: Operational mode currently in use. See + OperationalModeStatusType for values. + :ivar readingTime: The timestamp when the current status was last + updated. + :ivar stateOfChargeStatus: State of charge status. See + StateOfChargeStatusType for values. + :ivar storageModeStatus: Storage mode status. See + StorageModeStatusType for values. + :ivar storConnectStatus: Connect/status value for storage DER. See + ConnectStatusType for values. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + alarmStatus: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 4, + "format": "base16", + } + ) + genConnectStatus: Optional[ConnectStatusType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + inverterStatus: Optional[InverterStatusType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + localControlModeStatus: Optional[LocalControlModeStatusType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + manufacturerStatus: Optional[ManufacturerStatusType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + operationalModeStatus: Optional[OperationalModeStatusType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + readingTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + stateOfChargeStatus: Optional[StateOfChargeStatusType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + storageModeStatus: Optional[StorageModeStatusType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + storConnectStatus: Optional[ConnectStatusType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class DemandResponseProgramListLink(ListLink): + """ + SHALL contain a Link to a List of DemandResponseProgram instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class DeviceStatus(Resource): + """ + Status of device. + + :ivar changedTime: The time at which the reported values were + recorded. + :ivar onCount: The number of times that the device has been turned + on: Count of "device on" times, since the last time the counter + was reset + :ivar opState: Device operational state: 0 - Not applicable / + Unknown 1 - Not operating 2 - Operating 3 - Starting up 4 - + Shutting down 5 - At disconnect level 6 - kW ramping 7 - kVar + ramping + :ivar opTime: Total time device has operated: re-settable: + Accumulated time in seconds since the last time the counter was + reset. + :ivar Temperature: + :ivar TimeLink: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + changedTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + onCount: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opState: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + opTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + Temperature: List[Temperature] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + TimeLink: Optional[TimeLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class DrResponse(Response): + """ + A response to a Demand Response Load Control (EndDeviceControl) message. + + :ivar ApplianceLoadReduction: + :ivar AppliedTargetReduction: + :ivar DutyCycle: + :ivar Offset: + :ivar overrideDuration: Indicates the amount of time, in seconds, + that the client partially opts-out during the demand response + event. When overriding within the allowed override duration, the + client SHALL send a partial opt-out (Response status code 8) for + partial opt-out upon completion, with the total time the event + was overridden (this attribute) populated. The client SHALL send + a no participation status response (status type 10) if the user + partially opts-out for longer than + EndDeviceControl.overrideDuration. + :ivar SetPoint: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ApplianceLoadReduction: Optional[ApplianceLoadReduction] = field( + default=None, + metadata={ + "type": "Element", + } + ) + AppliedTargetReduction: Optional[AppliedTargetReduction] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DutyCycle: Optional[DutyCycle] = field( + default=None, + metadata={ + "type": "Element", + } + ) + Offset: Optional[Offset] = field( + default=None, + metadata={ + "type": "Element", + } + ) + overrideDuration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + SetPoint: Optional[SetPoint] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class EndDeviceControlListLink(ListLink): + """ + SHALL contain a Link to a List of EndDeviceControl instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class EndDeviceListLink(ListLink): + """ + SHALL contain a Link to a List of EndDevice instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class FileList(List_type): + """ + A List element to hold File objects. + + :ivar File: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + File: List[File] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class FileListLink(ListLink): + """ + SHALL contain a Link to a List of File instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class FileStatus(Resource): + """ + This object provides status of device file load and activation operations. + + :ivar activateTime: Date/time at which this File, referred to by + FileLink, will be activated. Omission of or presence and value + of this element MUST exactly match omission or presence and + value of the activateTime element from the File resource. + :ivar FileLink: + :ivar loadPercent: This element MUST be set to the percentage of the + file, indicated by FileLink, that was loaded during the latest + load attempt. This value MUST be reset to 0 each time a load + attempt is started for the File indicated by FileLink. This + value MUST be increased when an LD receives HTTP response + containing file content. This value MUST be set to 100 when the + full content of the file has been received by the LD + :ivar nextRequestAttempt: This element MUST be set to the time at + which the LD will issue its next GET request for file content + from the File indicated by FileLink + :ivar request503Count: This value MUST be reset to 0 when FileLink + is first pointed at a new File. This value MUST be incremented + each time an LD receives a 503 error from the FS. + :ivar requestFailCount: This value MUST be reset to 0 when FileLink + is first pointed at a new File. This value MUST be incremented + each time a GET request for file content failed. 503 errors MUST + be excluded from this counter. + :ivar status: Current loading status of the file indicated by + FileLink. This element MUST be set to one of the following + values: 0 - No load operation in progress 1 - File load in + progress (first request for file content has been issued by LD) + 2 - File load failed 3 - File loaded successfully (full content + of file has been received by the LD), signature verification in + progress 4 - File signature verification failed 5 - File + signature verified, waiting to activate file. 6 - File + activation failed 7 - File activation in progress 8 - File + activated successfully (this state may not be reached/persisted + through an image activation) 9-255 - Reserved for future use. + :ivar statusTime: This element MUST be set to the time at which file + status transitioned to the value indicated in the status + element. + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + activateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + FileLink: Optional[FileLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + loadPercent: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + nextRequestAttempt: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + request503Count: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + requestFailCount: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + status: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + statusTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class FlowReservationRequest(IdentifiedObject): + """Used to request flow transactions. + + Client EndDevices submit a request for charging or discharging from + the server. The server creates an associated FlowReservationResponse + containing the charging parameters and interval to provide a lower + aggregated demand at the premises, or within a larger part of the + distribution system. + + :ivar creationTime: The time at which the request was created. + :ivar durationRequested: A value that is calculated by the storage + device that defines the minimum duration, in seconds, that it + will take to complete the actual flow transaction, including any + ramp times and conditioning times, if applicable. + :ivar energyRequested: Indicates the total amount of energy, in + Watt-Hours, requested to be transferred between the storage + device and the electric power system. Positive values indicate + charging and negative values indicate discharging. This sign + convention is different than for the DER function where + discharging is positive. Note that the energyRequestNow + attribute in the PowerStatus Object must always represent a + charging solution and it is not allowed to have a negative + value. + :ivar intervalRequested: The time window during which the flow + reservation is needed. For example, if an electric vehicle is + set with a 7:00 AM time charge is needed, and price drops to the + lowest tier at 11:00 PM, then this window would likely be from + 11:00 PM until 7:00 AM. + :ivar powerRequested: Indicates the sustained level of power, in + Watts, that is requested. For charging this is calculated by the + storage device and it represents the charging system capability + (which for an electric vehicle must also account for any power + limitations due to the EVSE control pilot). For discharging, a + lower value than the inverter capability can be used as a + target. + :ivar RequestStatus: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + creationTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + durationRequested: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + energyRequested: Optional[SignedRealEnergy] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + intervalRequested: Optional[DateTimeInterval] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + powerRequested: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + RequestStatus: Optional[RequestStatus] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class FlowReservationRequestListLink(ListLink): + """ + SHALL contain a Link to a List of FlowReservationRequest instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class FlowReservationResponseListLink(ListLink): + """ + SHALL contain a Link to a List of FlowReservationResponse instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class FlowReservationResponseResponse(Response): + """ + A response to a FlowReservationResponse. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class FunctionSetAssignmentsListLink(ListLink): + """ + SHALL contain a Link to a List of FunctionSetAssignments instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class HistoricalReadingListLink(ListLink): + """ + SHALL contain a Link to a List of HistoricalReading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class IPAddrListLink(ListLink): + """ + SHALL contain a Link to a List of IPAddr instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class IPInterfaceListLink(ListLink): + """ + SHALL contain a Link to a List of IPInterface instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class LLInterfaceListLink(ListLink): + """ + SHALL contain a Link to a List of LLInterface instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class LoadShedAvailability(Resource): + """ + Indicates current consumption status and ability to shed load. + + :ivar availabilityDuration: Indicates for how many seconds the + consuming device will be able to reduce consumption at the + maximum response level. + :ivar DemandResponseProgramLink: + :ivar sheddablePercent: Maximum percent of current operating load + that is estimated to be sheddable. + :ivar sheddablePower: Maximum amount of current operating load that + is estimated to be sheddable, in Watts. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + availabilityDuration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DemandResponseProgramLink: Optional[DemandResponseProgramLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + sheddablePercent: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + sheddablePower: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class LoadShedAvailabilityListLink(ListLink): + """ + SHALL contain a Link to a List of LoadShedAvailability instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class LogEventListLink(ListLink): + """ + SHALL contain a Link to a List of LogEvent instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class MessagingProgramListLink(ListLink): + """ + SHALL contain a Link to a List of MessagingProgram instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class MeterReadingBase(IdentifiedObject): + """ + A container for associating ReadingType, Readings and ReadingSets. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class MeterReadingListLink(ListLink): + """ + SHALL contain a Link to a List of MeterReading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class MirrorUsagePointListLink(ListLink): + """ + SHALL contain a Link to a List of MirrorUsagePoint instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class NeighborList(List_type): + """ + List of 15.4 neighbors. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Neighbor: List[Neighbor] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class NeighborListLink(ListLink): + """ + SHALL contain a Link to a List of Neighbor instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class Notification(SubscriptionBase): + """Holds the information related to a client subscription to receive + updates to a resource automatically. + + The actual resources may be passed in the Notification by specifying + a specific xsi:type for the Resource and passing the full + representation. + + :ivar newResourceURI: The new location of the resource, if moved. + This attribute SHALL be a fully-qualified absolute URI, not a + relative reference. + :ivar Resource: + :ivar status: 0 = Default Status 1 = Subscription canceled, no + additional information 2 = Subscription canceled, resource moved + 3 = Subscription canceled, resource definition changed (e.g., a + new version of IEEE 2030.5) 4 = Subscription canceled, resource + deleted All other values reserved. + :ivar subscriptionURI: The subscription from which this notification + was triggered. This attribute SHALL be a fully-qualified + absolute URI, not a relative reference. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + newResourceURI: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + } + ) + Resource: Optional[Resource] = field( + default=None, + metadata={ + "type": "Element", + } + ) + status: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + subscriptionURI: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class NotificationListLink(ListLink): + """ + SHALL contain a Link to a List of Notification instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class PowerStatus(Resource): + """ + Contains the status of the device's power sources. + + :ivar batteryStatus: Battery system status 0 = unknown 1 = normal + (more than LowChargeThreshold remaining) 2 = low (less than + LowChargeThreshold remaining) 3 = depleted (0% charge remaining) + 4 = not applicable (mains powered only) + :ivar changedTime: The time at which the reported values were + recorded. + :ivar currentPowerSource: This value will be fixed for devices + powered by a single source. This value may change for devices + able to transition between multiple power sources (mains to + battery backup, etc.). + :ivar estimatedChargeRemaining: Estimate of remaining battery charge + as a percent of full charge. + :ivar estimatedTimeRemaining: Estimated time (in seconds) to total + battery charge depletion (under current load) + :ivar PEVInfo: + :ivar sessionTimeOnBattery: If the device has a battery, this is the + time since the device last switched to battery power, or the + time since the device was restarted, whichever is less, in + seconds. + :ivar totalTimeOnBattery: If the device has a battery, this is the + total time the device has been on battery power, in seconds. It + may be reset when the battery is replaced. + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + batteryStatus: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + changedTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + currentPowerSource: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + estimatedChargeRemaining: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + estimatedTimeRemaining: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + PEVInfo: Optional[PEVInfo] = field( + default=None, + metadata={ + "type": "Element", + } + ) + sessionTimeOnBattery: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + totalTimeOnBattery: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class PrepaymentListLink(ListLink): + """ + SHALL contain a Link to a List of Prepayment instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class PriceResponse(Response): + """ + A response related to a price message. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class PriceResponseCfg(Resource): + """ + Configuration data that specifies how price responsive devices SHOULD + respond to price changes while acting upon a given RateComponent. + + :ivar consumeThreshold: Price responsive clients acting upon the + associated RateComponent SHOULD consume the associated commodity + while the price is less than this threshold. + :ivar maxReductionThreshold: Price responsive clients acting upon + the associated RateComponent SHOULD reduce consumption to the + maximum extent possible while the price is greater than this + threshold. + :ivar RateComponentLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + consumeThreshold: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + maxReductionThreshold: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + RateComponentLink: Optional[RateComponentLink] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class PriceResponseCfgListLink(ListLink): + """ + SHALL contain a Link to a List of PriceResponseCfg instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ProjectionReadingListLink(ListLink): + """ + SHALL contain a Link to a List of ProjectionReading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class RPLInstanceListLink(ListLink): + """ + SHALL contain a Link to a List of RPLInterface instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class RPLSourceRoutesList(List_type): + """ + List or RPL source routes if the hosting device is the DODAGroot. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + RPLSourceRoutes: List[RPLSourceRoutes] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class RPLSourceRoutesListLink(ListLink): + """ + SHALL contain a Link to a List of RPLSourceRoutes instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class RateComponentListLink(ListLink): + """ + SHALL contain a Link to a List of RateComponent instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class Reading(ReadingBase): + """ + Specific value measured by a meter or other asset. + + :ivar localID: The local identifier for this reading within the + reading set. localIDs are assigned in order of creation time. + For interval data, this value SHALL increase with each interval + time, and for block/tier readings, localID SHALL not be + specified. + :ivar subscribable: Indicates whether or not subscriptions are + supported for this resource, and whether or not conditional + (thresholds) are supported. If not specified, is "not + subscribable" (0). + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + localID: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 2, + "format": "base16", + } + ) + subscribable: int = field( + default=0, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class ReadingListLink(ListLink): + """ + SHALL contain a Link to a List of Reading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ReadingSetBase(IdentifiedObject): + """A set of Readings of the ReadingType indicated by the parent + MeterReading. + + ReadingBase is abstract, used to define the elements common to + ReadingSet and IntervalBlock. + + :ivar timePeriod: Specifies the time range during which the + contained readings were taken. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + timePeriod: Optional[DateTimeInterval] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class ReadingSetListLink(ListLink): + """ + SHALL contain a Link to a List of ReadingSet instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class RespondableIdentifiedObject(RespondableResource): + """ + An IdentifiedObject to which a Response can be requested. + + :ivar mRID: The global identifier of the object. + :ivar description: The description is a human readable text + describing or naming the object. + :ivar version: Contains the version number of the object. See the + type definition for details. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + mRID: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + description: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + version: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class RespondableSubscribableIdentifiedObject(RespondableResource): + """ + An IdentifiedObject to which a Response can be requested. + + :ivar mRID: The global identifier of the object. + :ivar description: The description is a human readable text + describing or naming the object. + :ivar version: Contains the version number of the object. See the + type definition for details. + :ivar subscribable: Indicates whether or not subscriptions are + supported for this resource, and whether or not conditional + (thresholds) are supported. If not specified, is "not + subscribable" (0). + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + mRID: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + description: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + version: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + subscribable: int = field( + default=0, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class ResponseList(List_type): + """ + A List element to hold Response objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Response: List[Response] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ResponseListLink(ListLink): + """ + SHALL contain a Link to a List of Response instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ResponseSetListLink(ListLink): + """ + SHALL contain a Link to a List of ResponseSet instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class ServiceSupplier(IdentifiedObject): + """ + Organisation that provides services to Customers. + + :ivar email: E-mail address for this service supplier. + :ivar phone: Human-readable phone number for this service supplier. + :ivar providerID: Contains the IANA PEN for the commodity provider. + :ivar web: Website URI address for this service supplier. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + email: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + phone: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 20, + } + ) + providerID: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + web: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 42, + } + ) + + +@dataclass +class SubscribableIdentifiedObject(SubscribableResource): + """ + An IdentifiedObject to which a Subscription can be requested. + + :ivar mRID: The global identifier of the object. + :ivar description: The description is a human readable text + describing or naming the object. + :ivar version: Contains the version number of the object. See the + type definition for details. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + mRID: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + description: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + version: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class SubscribableList(SubscribableResource): + """ + A List to which a Subscription can be requested. + + :ivar all: The number specifying "all" of the items in the list. + Required on GET, ignored otherwise. + :ivar results: Indicates the number of items in this page of + results. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + all: Optional[int] = field( + default=None, + metadata={ + "type": "Attribute", + "required": True, + } + ) + results: Optional[int] = field( + default=None, + metadata={ + "type": "Attribute", + "required": True, + } + ) + + +@dataclass +class Subscription(SubscriptionBase): + """ + Holds the information related to a client subscription to receive updates + to a resource automatically. + + :ivar Condition: + :ivar encoding: 0 - application/sep+xml 1 - application/sep-exi + 2-255 - reserved + :ivar level: Contains the preferred schema and extensibility level + indication such as "+S1" + :ivar limit: This element is used to indicate the maximum number of + list items that should be included in a notification when the + subscribed resource changes. This limit is meant to be + functionally equivalent to the ‘limit’ query string parameter, + but applies to both list resources as well as other resources. + For list resources, if a limit of ‘0’ is specified, then + notifications SHALL contain a list resource with results=’0’ + (equivalent to a simple change notification). For list + resources, if a limit greater than ‘0’ is specified, then + notifications SHALL contain a list resource with results equal + to the limit specified (or less, should the list contain fewer + items than the limit specified or should the server be unable to + provide the requested number of items for any reason) and follow + the same rules for list resources (e.g., ordering). For non- + list resources, if a limit of ‘0’ is specified, then + notifications SHALL NOT contain a resource representation + (equivalent to a simple change notification). For non-list + resources, if a limit greater than ‘0’ is specified, then + notifications SHALL contain the representation of the changed + resource. + :ivar notificationURI: The resource to which to post the + notifications about the requested subscribed resource. Because + this URI will exist on a server other than the one being POSTed + to, this attribute SHALL be a fully-qualified absolute URI, not + a relative reference. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Condition: Optional[Condition] = field( + default=None, + metadata={ + "type": "Element", + } + ) + encoding: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + level: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + } + ) + limit: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + notificationURI: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class SubscriptionListLink(ListLink): + """ + SHALL contain a Link to a List of Subscription instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class SupplyInterruptionOverrideList(List_type): + """ + A List element to hold SupplyInterruptionOverride objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + SupplyInterruptionOverride: List[SupplyInterruptionOverride] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class SupplyInterruptionOverrideListLink(ListLink): + """ + SHALL contain a Link to a List of SupplyInterruptionOverride instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class SupportedLocaleList(List_type): + """ + A List element to hold SupportedLocale objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + SupportedLocale: List[SupportedLocale] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class SupportedLocaleListLink(ListLink): + """ + SHALL contain a Link to a List of SupportedLocale instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class TargetReadingListLink(ListLink): + """ + SHALL contain a Link to a List of TargetReading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class TariffProfileListLink(ListLink): + """ + SHALL contain a Link to a List of TariffProfile instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class TextMessageListLink(ListLink): + """ + SHALL contain a Link to a List of TextMessage instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class TextResponse(Response): + """ + A response to a text message. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class TimeTariffIntervalListLink(ListLink): + """ + SHALL contain a Link to a List of TimeTariffInterval instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class UsagePointBase(IdentifiedObject): + """Logical point on a network at which consumption or production is either + physically measured (e.g. metered) or estimated (e.g. unmetered street + lights). + + A container for associating ReadingType, Readings and ReadingSets. + + :ivar roleFlags: Specifies the roles that apply to the usage point. + :ivar serviceCategoryKind: The kind of service provided by this + usage point. + :ivar status: Specifies the current status of the service at this + usage point. 0 = off 1 = on + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + roleFlags: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 2, + "format": "base16", + } + ) + serviceCategoryKind: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + status: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class UsagePointListLink(ListLink): + """ + SHALL contain a Link to a List of UsagePoint instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class AbstractDevice(SubscribableResource): + """ + The EndDevice providing the resources available within the + DeviceCapabilities. + + :ivar ConfigurationLink: + :ivar DERListLink: + :ivar deviceCategory: This field is for use in devices that can + adjust energy usage (e.g., demand response, distributed energy + resources). For devices that do not respond to + EndDeviceControls or DERControls (for instance, an ESI), this + field should not have any bits set. + :ivar DeviceInformationLink: + :ivar DeviceStatusLink: + :ivar FileStatusLink: + :ivar IPInterfaceListLink: + :ivar lFDI: Long form of device identifier. See the Security section + for additional details. + :ivar LoadShedAvailabilityListLink: + :ivar LogEventListLink: + :ivar PowerStatusLink: + :ivar sFDI: Short form of device identifier, WITH the checksum + digit. See the Security section for additional details. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ConfigurationLink: Optional[ConfigurationLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DERListLink: Optional[DERListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + deviceCategory: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 4, + "format": "base16", + } + ) + DeviceInformationLink: Optional[DeviceInformationLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DeviceStatusLink: Optional[DeviceStatusLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + FileStatusLink: Optional[FileStatusLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + IPInterfaceListLink: Optional[IPInterfaceListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + lFDI: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 20, + "format": "base16", + } + ) + LoadShedAvailabilityListLink: Optional[LoadShedAvailabilityListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LogEventListLink: Optional[LogEventListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + PowerStatusLink: Optional[PowerStatusLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + sFDI: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_inclusive": 281474976710655, + } + ) + + +@dataclass +class BillingMeterReadingBase(MeterReadingBase): + """ + Contains historical, target, and projection readings of various types, + possibly associated with charges. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + BillingReadingSetListLink: Optional[BillingReadingSetListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ReadingTypeLink: Optional[ReadingTypeLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class BillingPeriodList(SubscribableList): + """ + A List element to hold BillingPeriod objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + BillingPeriod: List[BillingPeriod] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class BillingReadingList(List_type): + """ + A List element to hold BillingReading objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + BillingReading: List[BillingReading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class BillingReadingSet(ReadingSetBase): + """ + Time sequence of readings of the same reading type. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + BillingReadingListLink: Optional[BillingReadingListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class Configuration(SubscribableResource): + """ + This resource contains various settings to control the operation of the + device. + + :ivar currentLocale: [RFC 4646] identifier of the language-region + currently in use. + :ivar PowerConfiguration: + :ivar PriceResponseCfgListLink: + :ivar TimeConfiguration: + :ivar userDeviceName: User assigned, convenience name used for + network browsing displays, etc. Example "My Thermostat" + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + currentLocale: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 42, + } + ) + PowerConfiguration: Optional[PowerConfiguration] = field( + default=None, + metadata={ + "type": "Element", + } + ) + PriceResponseCfgListLink: Optional[PriceResponseCfgListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + TimeConfiguration: Optional[TimeConfiguration] = field( + default=None, + metadata={ + "type": "Element", + } + ) + userDeviceName: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class CreditRegisterList(List_type): + """ + A List element to hold CreditRegister objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + CreditRegister: List[CreditRegister] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class CustomerAccount(IdentifiedObject): + """Assignment of a group of products and services purchased by the Customer + through a CustomerAgreement, used as a mechanism for customer billing and + payment. + + It contains common information from the various types of + CustomerAgreements to create billings (invoices) for a Customer and + receive payment. + + :ivar currency: The ISO 4217 code indicating the currency applicable + to the bill amounts in the summary. See list at + http://www.unece.org/cefact/recommendations/rec09/rec09_ecetrd203.pdf + :ivar customerAccount: The account number for the customer (if + applicable). + :ivar CustomerAgreementListLink: + :ivar customerName: The name of the customer. + :ivar pricePowerOfTenMultiplier: Indicates the power of ten + multiplier for the prices in this function set. + :ivar ServiceSupplierLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + currency: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + customerAccount: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 42, + } + ) + CustomerAgreementListLink: Optional[CustomerAgreementListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + customerName: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 42, + } + ) + pricePowerOfTenMultiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + ServiceSupplierLink: Optional[ServiceSupplierLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class CustomerAgreement(IdentifiedObject): + """Agreement between the customer and the service supplier to pay for + service at a specific service location. + + It records certain billing information about the type of service + provided at the service location and is used during charge creation + to determine the type of service. + + :ivar ActiveBillingPeriodListLink: + :ivar ActiveProjectionReadingListLink: + :ivar ActiveTargetReadingListLink: + :ivar BillingPeriodListLink: + :ivar HistoricalReadingListLink: + :ivar PrepaymentLink: + :ivar ProjectionReadingListLink: + :ivar serviceAccount: The account number of the service account (if + applicable). + :ivar serviceLocation: The address or textual description of the + service location. + :ivar TargetReadingListLink: + :ivar TariffProfileLink: + :ivar UsagePointLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ActiveBillingPeriodListLink: Optional[ActiveBillingPeriodListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ActiveProjectionReadingListLink: Optional[ActiveProjectionReadingListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ActiveTargetReadingListLink: Optional[ActiveTargetReadingListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + BillingPeriodListLink: Optional[BillingPeriodListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + HistoricalReadingListLink: Optional[HistoricalReadingListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + PrepaymentLink: Optional[PrepaymentLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ProjectionReadingListLink: Optional[ProjectionReadingListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + serviceAccount: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 42, + } + ) + serviceLocation: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 42, + } + ) + TargetReadingListLink: Optional[TargetReadingListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + TariffProfileLink: Optional[TariffProfileLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + UsagePointLink: Optional[UsagePointLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class DER(SubscribableResource): + """ + Contains links to DER resources. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + AssociatedDERProgramListLink: Optional[AssociatedDERProgramListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + AssociatedUsagePointLink: Optional[AssociatedUsagePointLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + CurrentDERProgramLink: Optional[CurrentDERProgramLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DERAvailabilityLink: Optional[DERAvailabilityLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DERCapabilityLink: Optional[DERCapabilityLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DERSettingsLink: Optional[DERSettingsLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DERStatusLink: Optional[DERStatusLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class DERCurveList(List_type): + """ + A List element to hold DERCurve objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DERCurve: List[DERCurve] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class DERProgram(SubscribableIdentifiedObject): + """ + Distributed Energy Resource program. + + :ivar ActiveDERControlListLink: + :ivar DefaultDERControlLink: + :ivar DERControlListLink: + :ivar DERCurveListLink: + :ivar primacy: Indicates the relative primacy of the provider of + this Program. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ActiveDERControlListLink: Optional[ActiveDERControlListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DefaultDERControlLink: Optional[DefaultDERControlLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DERControlListLink: Optional[DERControlListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DERCurveListLink: Optional[DERCurveListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + primacy: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class DefaultDERControl(SubscribableIdentifiedObject): + """ + Contains control mode information to be used if no active DERControl is + found. + + :ivar DERControlBase: + :ivar setESDelay: Enter service delay, in hundredths of a second. + When present, this value SHALL update the value of the + corresponding setting (DERSettings::setESDelay). + :ivar setESHighFreq: Enter service frequency high. Specified in + hundredths of Hz. When present, this value SHALL update the + value of the corresponding setting (DERSettings::setESHighFreq). + :ivar setESHighVolt: Enter service voltage high. Specified as an + effective percent voltage, defined as (100% * (locally measured + voltage - setVRefOfs) / setVRef), in hundredths of a percent. + When present, this value SHALL update the value of the + corresponding setting (DERSettings::setESHighVolt). + :ivar setESLowFreq: Enter service frequency low. Specified in + hundredths of Hz. When present, this value SHALL update the + value of the corresponding setting (DERSettings::setESLowFreq). + :ivar setESLowVolt: Enter service voltage low. Specified as an + effective percent voltage, defined as (100% * (locally measured + voltage - setVRefOfs) / setVRef), in hundredths of a percent. + When present, this value SHALL update the value of the + corresponding setting (DERSettings::setESLowVolt). + :ivar setESRampTms: Enter service ramp time, in hundredths of a + second. When present, this value SHALL update the value of the + corresponding setting (DERSettings::setESRampTms). + :ivar setESRandomDelay: Enter service randomized delay, in + hundredths of a second. When present, this value SHALL update + the value of the corresponding setting + (DERSettings::setESRandomDelay). + :ivar setGradW: Set default rate of change (ramp rate) of active + power output due to command or internal action, defined in + %setWMax / second. Resolution is in hundredths of a + percent/second. A value of 0 means there is no limit. + Interpreted as a percentage change in output capability limit + per second when used as a default ramp rate. When present, this + value SHALL update the value of the corresponding setting + (DERSettings::setGradW). + :ivar setSoftGradW: Set soft-start rate of change (soft-start ramp + rate) of active power output due to command or internal action, + defined in %setWMax / second. Resolution is in hundredths of a + percent/second. A value of 0 means there is no limit. + Interpreted as a percentage change in output capability limit + per second when used as a ramp rate. When present, this value + SHALL update the value of the corresponding setting + (DERSettings::setSoftGradW). + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DERControlBase: Optional[DERControlBase] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + setESDelay: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESHighFreq: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESHighVolt: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESLowFreq: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESLowVolt: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESRampTms: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setESRandomDelay: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setGradW: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + setSoftGradW: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class DemandResponseProgram(IdentifiedObject): + """ + Demand response program. + + :ivar ActiveEndDeviceControlListLink: + :ivar availabilityUpdatePercentChangeThreshold: This attribute + allows program providers to specify the requested granularity of + updates to LoadShedAvailability sheddablePercent. If not + present, or set to 0, then updates to LoadShedAvailability SHALL + NOT be provided. If present and greater than zero, then clients + SHALL provide their LoadShedAvailability if it has not + previously been provided, and thereafter if the difference + between the previously provided value and the current value of + LoadShedAvailability sheddablePercent is greater than + availabilityUpdatePercentChangeThreshold. + :ivar availabilityUpdatePowerChangeThreshold: This attribute allows + program providers to specify the requested granularity of + updates to LoadShedAvailability sheddablePower. If not present, + or set to 0, then updates to LoadShedAvailability SHALL NOT be + provided. If present and greater than zero, then clients SHALL + provide their LoadShedAvailability if it has not previously been + provided, and thereafter if the difference between the + previously provided value and the current value of + LoadShedAvailability sheddablePower is greater than + availabilityUpdatePowerChangeThreshold. + :ivar EndDeviceControlListLink: + :ivar primacy: Indicates the relative primacy of the provider of + this program. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ActiveEndDeviceControlListLink: Optional[ActiveEndDeviceControlListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + availabilityUpdatePercentChangeThreshold: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + availabilityUpdatePowerChangeThreshold: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + } + ) + EndDeviceControlListLink: Optional[EndDeviceControlListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + primacy: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class DeviceInformation(Resource): + """ + Contains identification and other information about the device that changes + very infrequently, typically only when updates are applied, if ever. + + :ivar DRLCCapabilities: + :ivar functionsImplemented: Bitmap indicating the function sets used + by the device as a client. 0 - Device Capability 1 - Self Device + Resource 2 - End Device Resource 3 - Function Set Assignments 4 + - Subscription/Notification Mechanism 5 - Response 6 - Time 7 - + Device Information 8 - Power Status 9 - Network Status 10 - Log + Event 11 - Configuration Resource 12 - Software Download 13 - + DRLC 14 - Metering 15 - Pricing 16 - Messaging 17 - Billing 18 - + Prepayment 19 - Flow Reservation 20 - DER Control + :ivar gpsLocation: GPS location of this device. + :ivar lFDI: Long form device identifier. See the Security section + for full details. + :ivar mfDate: Date/time of manufacture + :ivar mfHwVer: Manufacturer hardware version + :ivar mfID: The manufacturer's IANA Enterprise Number. + :ivar mfInfo: Manufacturer dependent information related to the + manufacture of this device + :ivar mfModel: Manufacturer's model number + :ivar mfSerNum: Manufacturer assigned serial number + :ivar primaryPower: Primary source of power. + :ivar secondaryPower: Secondary source of power + :ivar SupportedLocaleListLink: + :ivar swActTime: Activation date/time of currently running software + :ivar swVer: Currently running software version + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DRLCCapabilities: Optional[DRLCCapabilities] = field( + default=None, + metadata={ + "type": "Element", + } + ) + functionsImplemented: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 8, + "format": "base16", + } + ) + gpsLocation: Optional[GPSLocationType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + lFDI: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 20, + "format": "base16", + } + ) + mfDate: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + mfHwVer: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + mfID: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + mfInfo: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + mfModel: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + mfSerNum: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + primaryPower: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + secondaryPower: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + SupportedLocaleListLink: Optional[SupportedLocaleListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + swActTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + swVer: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class Event(RespondableSubscribableIdentifiedObject): + """An Event indicates information that applies to a particular period of + time. + + Events SHALL be executed relative to the time of the server, as + described in the Time function set section 11.1. + + :ivar creationTime: The time at which the Event was created. + :ivar EventStatus: + :ivar interval: The period during which the Event applies. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + creationTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + EventStatus: Optional[EventStatus] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + interval: Optional[DateTimeInterval] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class FlowReservationRequestList(List_type): + """ + A List element to hold FlowReservationRequest objects. + + :ivar FlowReservationRequest: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + FlowReservationRequest: List[FlowReservationRequest] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class FunctionSetAssignmentsBase(Resource): + """ + Defines a collection of function set instances that are to be used by one + or more devices as indicated by the EndDevice object(s) of the server. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + CustomerAccountListLink: Optional[CustomerAccountListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DemandResponseProgramListLink: Optional[DemandResponseProgramListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + DERProgramListLink: Optional[DERProgramListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + FileListLink: Optional[FileListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + MessagingProgramListLink: Optional[MessagingProgramListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + PrepaymentListLink: Optional[PrepaymentListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ResponseSetListLink: Optional[ResponseSetListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + TariffProfileListLink: Optional[TariffProfileListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + TimeLink: Optional[TimeLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + UsagePointListLink: Optional[UsagePointListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class IEEE_802_15_4: + """ + Contains 802.15.4 link layer specific attributes. + + :ivar capabilityInfo: As defined by IEEE 802.15.4 + :ivar NeighborListLink: + :ivar shortAddress: As defined by IEEE 802.15.4 + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + capabilityInfo: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 1, + "format": "base16", + } + ) + NeighborListLink: Optional[NeighborListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + shortAddress: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class IPAddr(Resource): + """ + An Internet Protocol address object. + + :ivar address: An IP address value. + :ivar RPLInstanceListLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + address: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + RPLInstanceListLink: Optional[RPLInstanceListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class IPInterface(Resource): + """Specific IPInterface resource. + + This resource may be thought of as network status information for a + specific network (IP) layer interface. + + :ivar ifDescr: Use rules from [RFC 2863]. + :ivar ifHighSpeed: Use rules from [RFC 2863]. + :ivar ifInBroadcastPkts: Use rules from [RFC 2863]. + :ivar ifIndex: Use rules from [RFC 2863]. + :ivar ifInDiscards: Use rules from [RFC 2863]. Can be thought of as + Input Datagrams Discarded. + :ivar ifInErrors: Use rules from [RFC 2863]. + :ivar ifInMulticastPkts: Use rules from [RFC 2863]. Can be thought + of as Multicast Datagrams Received. + :ivar ifInOctets: Use rules from [RFC 2863]. Can be thought of as + Bytes Received. + :ivar ifInUcastPkts: Use rules from [RFC 2863]. Can be thought of as + Datagrams Received. + :ivar ifInUnknownProtos: Use rules from [RFC 2863]. Can be thought + of as Datagrams with Unknown Protocol Received. + :ivar ifMtu: Use rules from [RFC 2863]. + :ivar ifName: Use rules from [RFC 2863]. + :ivar ifOperStatus: Use rules and assignments from [RFC 2863]. + :ivar ifOutBroadcastPkts: Use rules from [RFC 2863]. Can be thought + of as Broadcast Datagrams Sent. + :ivar ifOutDiscards: Use rules from [RFC 2863]. Can be thought of as + Output Datagrams Discarded. + :ivar ifOutErrors: Use rules from [RFC 2863]. + :ivar ifOutMulticastPkts: Use rules from [RFC 2863]. Can be thought + of as Multicast Datagrams Sent. + :ivar ifOutOctets: Use rules from [RFC 2863]. Can be thought of as + Bytes Sent. + :ivar ifOutUcastPkts: Use rules from [RFC 2863]. Can be thought of + as Datagrams Sent. + :ivar ifPromiscuousMode: Use rules from [RFC 2863]. + :ivar ifSpeed: Use rules from [RFC 2863]. + :ivar ifType: Use rules and assignments from [RFC 2863]. + :ivar IPAddrListLink: + :ivar lastResetTime: Similar to ifLastChange in [RFC 2863]. + :ivar lastUpdatedTime: The date/time of the reported status. + :ivar LLInterfaceListLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ifDescr: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 192, + } + ) + ifHighSpeed: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifInBroadcastPkts: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifIndex: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifInDiscards: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifInErrors: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifInMulticastPkts: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifInOctets: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifInUcastPkts: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifInUnknownProtos: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifMtu: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifName: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 16, + } + ) + ifOperStatus: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifOutBroadcastPkts: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifOutDiscards: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifOutErrors: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifOutMulticastPkts: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifOutOctets: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifOutUcastPkts: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifPromiscuousMode: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifSpeed: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ifType: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + IPAddrListLink: Optional[IPAddrListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + lastResetTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + lastUpdatedTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLInterfaceListLink: Optional[LLInterfaceListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class LoadShedAvailabilityList(List_type): + """ + A List element to hold LoadShedAvailability objects. + + :ivar LoadShedAvailability: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + LoadShedAvailability: List[LoadShedAvailability] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class LogEventList(SubscribableList): + """ + A List element to hold LogEvent objects. + + :ivar LogEvent: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + LogEvent: List[LogEvent] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class MessagingProgram(SubscribableIdentifiedObject): + """ + Provides a container for collections of text messages. + + :ivar ActiveTextMessageListLink: + :ivar locale: Indicates the language and region of the messages in + this collection. + :ivar primacy: Indicates the relative primacy of the provider of + this program. + :ivar TextMessageListLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ActiveTextMessageListLink: Optional[ActiveTextMessageListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + locale: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 42, + } + ) + primacy: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + TextMessageListLink: Optional[TextMessageListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class MeterReading(MeterReadingBase): + """ + Set of values obtained from the meter. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + RateComponentListLink: Optional[RateComponentListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ReadingLink: Optional[ReadingLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ReadingSetListLink: Optional[ReadingSetListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ReadingTypeLink: Optional[ReadingTypeLink] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class MirrorReadingSet(ReadingSetBase): + """ + A set of Readings of the ReadingType indicated by the parent MeterReading. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Reading: List[Reading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class NotificationList(List_type): + """ + A List element to hold Notification objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Notification: List[Notification] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class PriceResponseCfgList(List_type): + """ + A List element to hold PriceResponseCfg objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + PriceResponseCfg: List[PriceResponseCfg] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class RPLInstance(Resource): + """Specific RPLInstance resource. + + This resource may be thought of as network status information for a + specific RPL instance associated with IPInterface. + + :ivar DODAGid: See [RFC 6550]. + :ivar DODAGroot: See [RFC 6550]. + :ivar flags: See [RFC 6550]. + :ivar groundedFlag: See [RFC 6550]. + :ivar MOP: See [RFC 6550]. + :ivar PRF: See [RFC 6550]. + :ivar rank: See [RFC 6550]. + :ivar RPLInstanceID: See [RFC 6550]. + :ivar RPLSourceRoutesListLink: + :ivar versionNumber: See [RFC 6550]. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DODAGid: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + DODAGroot: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + flags: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + groundedFlag: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + MOP: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + PRF: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + rank: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + RPLInstanceID: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + RPLSourceRoutesListLink: Optional[RPLSourceRoutesListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + versionNumber: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class RateComponent(IdentifiedObject): + """ + Specifies the applicable charges for a single component of the rate, which + could be generation price or consumption price, for example. + + :ivar ActiveTimeTariffIntervalListLink: + :ivar flowRateEndLimit: Specifies the maximum flow rate (e.g. kW for + electricity) for which this RateComponent applies, for the usage + point and given rate / tariff. In combination with + flowRateStartLimit, allows a service provider to define the + demand or output characteristics for the particular tariff + design. If a server includes the flowRateEndLimit attribute, + then it SHALL also include flowRateStartLimit attribute. For + example, a service provider’s tariff limits customers to 20 kWs + of demand for the given rate structure. Above this threshold + (from 20-50 kWs), there are different demand charges per unit of + consumption. The service provider can use flowRateStartLimit + and flowRateEndLimit to describe the demand characteristics of + the different rates. Similarly, these attributes can be used to + describe limits on premises DERs that might be producing a + commodity and sending it back into the distribution network. + Note: At the time of writing, service provider tariffs with + demand-based components were not originally identified as being + in scope, and service provider tariffs vary widely in their use + of demand components and the method for computing charges. It + is expected that industry groups (e.g., OpenSG) will document + requirements in the future that the IEEE 2030.5 community can + then use as source material for the next version of IEEE 2030.5. + :ivar flowRateStartLimit: Specifies the minimum flow rate (e.g., kW + for electricity) for which this RateComponent applies, for the + usage point and given rate / tariff. In combination with + flowRateEndLimit, allows a service provider to define the demand + or output characteristics for the particular tariff design. If + a server includes the flowRateStartLimit attribute, then it + SHALL also include flowRateEndLimit attribute. + :ivar ReadingTypeLink: Provides indication of the ReadingType with + which this price is associated. + :ivar roleFlags: Specifies the roles that this usage point has been + assigned. + :ivar TimeTariffIntervalListLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ActiveTimeTariffIntervalListLink: Optional[ActiveTimeTariffIntervalListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + flowRateEndLimit: Optional[UnitValueType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + flowRateStartLimit: Optional[UnitValueType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ReadingTypeLink: Optional[ReadingTypeLink] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + roleFlags: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 2, + "format": "base16", + } + ) + TimeTariffIntervalListLink: Optional[TimeTariffIntervalListLink] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class ReadingList(SubscribableList): + """ + A List element to hold Reading objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Reading: List[Reading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ReadingSet(ReadingSetBase): + """ + A set of Readings of the ReadingType indicated by the parent MeterReading. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ReadingListLink: Optional[ReadingListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ResponseSet(IdentifiedObject): + """ + A container for a ResponseList. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ResponseListLink: Optional[ResponseListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ServiceSupplierList(List_type): + """ + A List element to hold ServiceSupplier objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ServiceSupplier: List[ServiceSupplier] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class SubscriptionList(List_type): + """ + A List element to hold Subscription objects. + + :ivar Subscription: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Subscription: List[Subscription] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class TariffProfile(IdentifiedObject): + """ + A schedule of charges; structure that allows the definition of tariff + structures such as step (block) and time of use (tier) when used in + conjunction with TimeTariffInterval and ConsumptionTariffInterval. + + :ivar currency: The currency code indicating the currency for this + TariffProfile. + :ivar pricePowerOfTenMultiplier: Indicates the power of ten + multiplier for the price attribute. + :ivar primacy: Indicates the relative primacy of the provider of + this program. + :ivar rateCode: The rate code for this tariff profile. Provided by + the Pricing service provider per its internal business needs and + practices and provides a method to identify the specific rate + code for the TariffProfile instance. This would typically not + be communicated to the user except to facilitate troubleshooting + due to its service provider-specific technical nature. + :ivar RateComponentListLink: + :ivar serviceCategoryKind: The kind of service provided by this + usage point. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + currency: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + pricePowerOfTenMultiplier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + primacy: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + rateCode: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 20, + } + ) + RateComponentListLink: Optional[RateComponentListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + serviceCategoryKind: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class UsagePoint(UsagePointBase): + """ + Logical point on a network at which consumption or production is either + physically measured (e.g. metered) or estimated (e.g. unmetered street + lights). + + :ivar deviceLFDI: The LFDI of the source device. This attribute + SHALL be present when mirroring. + :ivar MeterReadingListLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + deviceLFDI: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 20, + "format": "base16", + } + ) + MeterReadingListLink: Optional[MeterReadingListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class BillingReadingSetList(SubscribableList): + """ + A List element to hold BillingReadingSet objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + BillingReadingSet: List[BillingReadingSet] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class CustomerAccountList(SubscribableList): + """ + A List element to hold CustomerAccount objects. + + :ivar CustomerAccount: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + CustomerAccount: List[CustomerAccount] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class CustomerAgreementList(SubscribableList): + """ + A List element to hold CustomerAgreement objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + CustomerAgreement: List[CustomerAgreement] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class DERList(List_type): + """ + A List element to hold DER objects. + + :ivar DER: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DER: List[DER] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class DERProgramList(SubscribableList): + """ + A List element to hold DERProgram objects. + + :ivar DERProgram: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DERProgram: List[DERProgram] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class DemandResponseProgramList(SubscribableList): + """ + A List element to hold DemandResponseProgram objects. + + :ivar DemandResponseProgram: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DemandResponseProgram: List[DemandResponseProgram] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class DeviceCapability(FunctionSetAssignmentsBase): + """ + Returned by the URI provided by DNS-SD, to allow clients to find the URIs + to the resources in which they are interested. + + :ivar EndDeviceListLink: + :ivar MirrorUsagePointListLink: + :ivar SelfDeviceLink: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + EndDeviceListLink: Optional[EndDeviceListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + MirrorUsagePointListLink: Optional[MirrorUsagePointListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + SelfDeviceLink: Optional[SelfDeviceLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class EndDevice(AbstractDevice): + """Asset container that performs one or more end device functions. + + Contains information about individual devices in the network. + + :ivar changedTime: The time at which this resource was last modified + or created. + :ivar enabled: This attribute indicates whether or not an EndDevice + is enabled, or registered, on the server. If a server sets this + attribute to false, the device is no longer registered. It + should be noted that servers can delete EndDevice instances, but + using this attribute for some time is more convenient for + clients. + :ivar FlowReservationRequestListLink: + :ivar FlowReservationResponseListLink: + :ivar FunctionSetAssignmentsListLink: + :ivar postRate: POST rate, or how often EndDevice and subordinate + resources should be POSTed, in seconds. A client MAY indicate a + preferred postRate when POSTing EndDevice. A server MAY add or + modify postRate to indicate its preferred posting rate. + :ivar RegistrationLink: + :ivar SubscriptionListLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + changedTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + enabled: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + } + ) + FlowReservationRequestListLink: Optional[FlowReservationRequestListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + FlowReservationResponseListLink: Optional[FlowReservationResponseListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + FunctionSetAssignmentsListLink: Optional[FunctionSetAssignmentsListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + postRate: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + RegistrationLink: Optional[RegistrationLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + SubscriptionListLink: Optional[SubscriptionListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class FlowReservationResponse(Event): + """ + The server may modify the charging or discharging parameters and interval + to provide a lower aggregated demand at the premises, or within a larger + part of the distribution system. + + :ivar energyAvailable: Indicates the amount of energy available. + :ivar powerAvailable: Indicates the amount of power available. + :ivar subject: The subject field provides a method to match the + response with the originating event. It is populated with the + mRID of the corresponding FlowReservationRequest object. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + energyAvailable: Optional[SignedRealEnergy] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + powerAvailable: Optional[ActivePower] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + subject: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + + +@dataclass +class FunctionSetAssignments(FunctionSetAssignmentsBase): + """ + Provides an identifiable, subscribable collection of resources for a + particular device to consume. + + :ivar mRID: The global identifier of the object. + :ivar description: The description is a human readable text + describing or naming the object. + :ivar version: Contains the version number of the object. See the + type definition for details. + :ivar subscribable: Indicates whether or not subscriptions are + supported for this resource, and whether or not conditional + (thresholds) are supported. If not specified, is "not + subscribable" (0). + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + mRID: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + } + ) + description: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 32, + } + ) + version: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + subscribable: int = field( + default=0, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class HistoricalReading(BillingMeterReadingBase): + """To be used to present readings that have been processed and possibly + corrected (as allowed, due to missing or incorrect data) by backend + systems. + + This includes quality codes valid, verified, estimated, and derived + / corrected. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class IPAddrList(List_type): + """ + List of IPAddr instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + IPAddr: List[IPAddr] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class IPInterfaceList(List_type): + """ + List of IPInterface instances. + + :ivar IPInterface: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + IPInterface: List[IPInterface] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class LLInterface(Resource): + """ + A link-layer interface object. + + :ivar CRCerrors: Contains the number of CRC errors since reset. + :ivar EUI64: Contains the EUI-64 of the link layer interface. 48 bit + MAC addresses SHALL be changed into an EUI-64 using the method + defined in [RFC 4291], Appendix A. (The method is to insert + "0xFFFE" as described in the reference.) + :ivar IEEE_802_15_4: + :ivar linkLayerType: Specifies the type of link layer interface + associated with the IPInterface. Values are below. 0 = + Unspecified 1 = IEEE 802.3 (Ethernet) 2 = IEEE 802.11 (WLAN) 3 = + IEEE 802.15 (PAN) 4 = IEEE 1901 (PLC) All other values reserved. + :ivar LLAckNotRx: Number of times an ACK was not received for a + frame transmitted (when ACK was requested). + :ivar LLCSMAFail: Number of times CSMA failed. + :ivar LLFramesDropRx: Number of dropped receive frames. + :ivar LLFramesDropTx: Number of dropped transmit frames. + :ivar LLFramesRx: Number of link layer frames received. + :ivar LLFramesTx: Number of link layer frames transmitted. + :ivar LLMediaAccessFail: Number of times access to media failed. + :ivar LLOctetsRx: Number of Bytes received. + :ivar LLOctetsTx: Number of Bytes transmitted. + :ivar LLRetryCount: Number of MAC transmit retries. + :ivar LLSecurityErrorRx: Number of receive security errors. + :ivar loWPAN: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + CRCerrors: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + EUI64: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 8, + "format": "base16", + } + ) + IEEE_802_15_4: Optional[IEEE_802_15_4] = field( + default=None, + metadata={ + "type": "Element", + } + ) + linkLayerType: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + LLAckNotRx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLCSMAFail: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLFramesDropRx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLFramesDropTx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLFramesRx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLFramesTx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLMediaAccessFail: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLOctetsRx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLOctetsTx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLRetryCount: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + LLSecurityErrorRx: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + loWPAN: Optional[loWPAN] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class MessagingProgramList(SubscribableList): + """ + A List element to hold MessagingProgram objects. + + :ivar MessagingProgram: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + MessagingProgram: List[MessagingProgram] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class MeterReadingList(SubscribableList): + """ + A List element to hold MeterReading objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + MeterReading: List[MeterReading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class MirrorMeterReading(MeterReadingBase): + """ + Mimic of MeterReading used for managing mirrors. + + :ivar lastUpdateTime: The date and time of the last update. + :ivar MirrorReadingSet: + :ivar nextUpdateTime: The date and time of the next planned update. + :ivar Reading: + :ivar ReadingType: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + lastUpdateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + MirrorReadingSet: List[MirrorReadingSet] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + nextUpdateTime: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + Reading: Optional[Reading] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ReadingType: Optional[ReadingType] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class Prepayment(IdentifiedObject): + """ + Prepayment (inherited from CIM SDPAccountingFunction) + + :ivar AccountBalanceLink: + :ivar ActiveCreditRegisterListLink: + :ivar ActiveSupplyInterruptionOverrideListLink: + :ivar creditExpiryLevel: CreditExpiryLevel is the set point for + availableCredit at which the service level may be changed. The + typical value for this attribute is 0, regardless of whether the + account balance is measured in a monetary or commodity basis. + The units for this attribute SHALL match the units used for + availableCredit. + :ivar CreditRegisterListLink: + :ivar lowCreditWarningLevel: LowCreditWarningLevel is the set point + for availableCredit at which the creditStatus attribute in the + AccountBalance resource SHALL indicate that available credit is + low. The units for this attribute SHALL match the units used for + availableCredit. Typically, this value is set by the service + provider. + :ivar lowEmergencyCreditWarningLevel: LowEmergencyCreditWarningLevel + is the set point for emergencyCredit at which the creditStatus + attribute in the AccountBalance resource SHALL indicate that + emergencycredit is low. The units for this attribute SHALL match + the units used for availableCredit. Typically, this value is set + by the service provider. + :ivar prepayMode: PrepayMode specifies whether the given Prepayment + instance is operating in Credit, Central Wallet, ESI, or Local + prepayment mode. The Credit mode indicates that prepayment is + not presently in effect. The other modes are described in the + Overview Section above. + :ivar PrepayOperationStatusLink: + :ivar SupplyInterruptionOverrideListLink: + :ivar UsagePoint: + :ivar UsagePointLink: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + AccountBalanceLink: Optional[AccountBalanceLink] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + ActiveCreditRegisterListLink: Optional[ActiveCreditRegisterListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + ActiveSupplyInterruptionOverrideListLink: Optional[ActiveSupplyInterruptionOverrideListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + creditExpiryLevel: Optional[AccountingUnit] = field( + default=None, + metadata={ + "type": "Element", + } + ) + CreditRegisterListLink: Optional[CreditRegisterListLink] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + lowCreditWarningLevel: Optional[AccountingUnit] = field( + default=None, + metadata={ + "type": "Element", + } + ) + lowEmergencyCreditWarningLevel: Optional[AccountingUnit] = field( + default=None, + metadata={ + "type": "Element", + } + ) + prepayMode: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + PrepayOperationStatusLink: Optional[PrepayOperationStatusLink] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + SupplyInterruptionOverrideListLink: Optional[SupplyInterruptionOverrideListLink] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + UsagePoint: List[UsagePoint] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + UsagePointLink: Optional[UsagePointLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ProjectionReading(BillingMeterReadingBase): + """ + Contains values that forecast a future reading for the time or interval + specified. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class RPLInstanceList(List_type): + """ + List of RPLInstances associated with the IPinterface. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + RPLInstance: List[RPLInstance] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class RandomizableEvent(Event): + """ + An Event that can indicate time ranges over which the start time and + duration SHALL be randomized. + + :ivar randomizeDuration: Number of seconds boundary inside which a + random value must be selected to be applied to the associated + interval duration, to avoid sudden synchronized demand changes. + If related to price level changes, sign may be ignored. Valid + range is -3600 to 3600. If not specified, 0 is the default. + :ivar randomizeStart: Number of seconds boundary inside which a + random value must be selected to be applied to the associated + interval start time, to avoid sudden synchronized demand + changes. If related to price level changes, sign may be ignored. + Valid range is -3600 to 3600. If not specified, 0 is the + default. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + randomizeDuration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + randomizeStart: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class RateComponentList(List_type): + """ + A List element to hold RateComponent objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + RateComponent: List[RateComponent] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ReadingSetList(SubscribableList): + """ + A List element to hold ReadingSet objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ReadingSet: List[ReadingSet] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class ResponseSetList(List_type): + """ + A List element to hold ResponseSet objects. + + :ivar ResponseSet: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ResponseSet: List[ResponseSet] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class SelfDevice(AbstractDevice): + """ + The EndDevice providing the resources available within the + DeviceCapabilities. + + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class TargetReading(BillingMeterReadingBase): + """ + Contains readings that specify a target or goal, such as a consumption + target, to which billing incentives or other contractual ramifications may + be associated. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + +@dataclass +class TariffProfileList(SubscribableList): + """ + A List element to hold TariffProfile objects. + + :ivar TariffProfile: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + TariffProfile: List[TariffProfile] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class TextMessage(Event): + """ + Text message such as a notification. + + :ivar originator: Indicates the human-readable name of the publisher + of the message + :ivar priority: The priority is used to inform the client of the + priority of the particular message. Devices with constrained or + limited resources for displaying Messages should use this + attribute to determine how to handle displaying currently active + Messages (e.g. if a device uses a scrolling method with a single + Message viewable at a time it MAY want to push a low priority + Message to the background and bring a newly received higher + priority Message to the foreground). + :ivar textMessage: The textMessage attribute contains the actual + UTF-8 encoded text to be displayed in conjunction with the + messageLength attribute which contains the overall length of the + textMessage attribute. Clients and servers SHALL support a + reception of a Message of 100 bytes in length. Messages that + exceed the clients display size will be left to the client to + choose what method to handle the message (truncation, scrolling, + etc.). + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + originator: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 20, + } + ) + priority: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + textMessage: Optional[str] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class UsagePointList(SubscribableList): + """ + A List element to hold UsagePoint objects. + + :ivar UsagePoint: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + UsagePoint: List[UsagePoint] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class DERControl(RandomizableEvent): + """ + Distributed Energy Resource (DER) time/event-based control. + + :ivar DERControlBase: + :ivar deviceCategory: Specifies the bitmap indicating the + categories of devices that SHOULD respond. Devices SHOULD ignore + events that do not indicate their device category. If not + present, all devices SHOULD respond. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DERControlBase: Optional[DERControlBase] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + deviceCategory: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "max_length": 4, + "format": "base16", + } + ) + + +@dataclass +class EndDeviceControl(RandomizableEvent): + """ + Instructs an EndDevice to perform a specified action. + + :ivar ApplianceLoadReduction: + :ivar deviceCategory: Specifies the bitmap indicating the + categories of devices that SHOULD respond. Devices SHOULD ignore + events that do not indicate their device category. + :ivar drProgramMandatory: A flag to indicate if the EndDeviceControl + is considered a mandatory event as defined by the service + provider issuing the EndDeviceControl. The drProgramMandatory + flag alerts the client/user that they will be subject to penalty + or ineligibility based on the service provider’s program rules + for that deviceCategory. + :ivar DutyCycle: + :ivar loadShiftForward: Indicates that the event intends to increase + consumption. A value of true indicates the intention to increase + usage value, and a value of false indicates the intention to + decrease usage. + :ivar Offset: + :ivar overrideDuration: The overrideDuration attribute provides a + duration, in seconds, for which a client device is allowed to + override this EndDeviceControl and still meet the contractual + agreement with a service provider without opting out. If + overrideDuration is not specified, then it SHALL default to 0. + :ivar SetPoint: + :ivar TargetReduction: + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ApplianceLoadReduction: Optional[ApplianceLoadReduction] = field( + default=None, + metadata={ + "type": "Element", + } + ) + deviceCategory: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + } + ) + drProgramMandatory: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + DutyCycle: Optional[DutyCycle] = field( + default=None, + metadata={ + "type": "Element", + } + ) + loadShiftForward: Optional[bool] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + Offset: Optional[Offset] = field( + default=None, + metadata={ + "type": "Element", + } + ) + overrideDuration: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + SetPoint: Optional[SetPoint] = field( + default=None, + metadata={ + "type": "Element", + } + ) + TargetReduction: Optional[TargetReduction] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class EndDeviceList(SubscribableList): + """ + A List element to hold EndDevice objects. + + :ivar EndDevice: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + EndDevice: List[EndDevice] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class FlowReservationResponseList(SubscribableList): + """ + A List element to hold FlowReservationResponse objects. + + :ivar FlowReservationResponse: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + FlowReservationResponse: List[FlowReservationResponse] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class FunctionSetAssignmentsList(SubscribableList): + """ + A List element to hold FunctionSetAssignments objects. + + :ivar FunctionSetAssignments: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + FunctionSetAssignments: List[FunctionSetAssignments] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class HistoricalReadingList(List_type): + """ + A List element to hold HistoricalReading objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + HistoricalReading: List[HistoricalReading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class LLInterfaceList(List_type): + """ + List of LLInterface instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + LLInterface: List[LLInterface] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class MirrorMeterReadingList(List_type): + """ + A List of MirrorMeterReading instances. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + MirrorMeterReading: List[MirrorMeterReading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class MirrorUsagePoint(UsagePointBase): + """ + A parallel to UsagePoint to support mirroring. + + :ivar deviceLFDI: The LFDI of the device being mirrored. + :ivar MirrorMeterReading: + :ivar postRate: POST rate, or how often mirrored data should be + POSTed, in seconds. A client MAY indicate a preferred postRate + when POSTing MirrorUsagePoint. A server MAY add or modify + postRate to indicate its preferred posting rate. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + deviceLFDI: Optional[bytes] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 20, + "format": "base16", + } + ) + MirrorMeterReading: List[MirrorMeterReading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + postRate: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class PrepaymentList(SubscribableList): + """ + A List element to hold Prepayment objects. + + :ivar Prepayment: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + Prepayment: List[Prepayment] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class ProjectionReadingList(List_type): + """ + A List element to hold ProjectionReading objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ProjectionReading: List[ProjectionReading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class TargetReadingList(List_type): + """ + A List element to hold TargetReading objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + TargetReading: List[TargetReading] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class TextMessageList(SubscribableList): + """ + A List element to hold TextMessage objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + TextMessage: List[TextMessage] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class TimeTariffInterval(RandomizableEvent): + """ + Describes the time-differentiated portion of the RateComponent, if + applicable, and provides the ability to specify multiple time intervals, + each with its own consumption-based components and other attributes. + + :ivar ConsumptionTariffIntervalListLink: + :ivar touTier: Indicates the time of use tier related to the + reading. If not specified, is assumed to be "0 - N/A". + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ConsumptionTariffIntervalListLink: Optional[ConsumptionTariffIntervalListLink] = field( + default=None, + metadata={ + "type": "Element", + } + ) + touTier: Optional[int] = field( + default=None, + metadata={ + "type": "Element", + "required": True, + } + ) + + +@dataclass +class DERControlList(SubscribableList): + """ + A List element to hold DERControl objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + DERControl: List[DERControl] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class EndDeviceControlList(SubscribableList): + """ + A List element to hold EndDeviceControl objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + EndDeviceControl: List[EndDeviceControl] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + + +@dataclass +class MirrorUsagePointList(List_type): + """ + A List of MirrorUsagePoint instances. + + :ivar MirrorUsagePoint: + :ivar pollRate: The default polling rate for this function set (this + resource and all resources below), in seconds. If not specified, + a default of 900 seconds (15 minutes) is used. It is RECOMMENDED + a client poll the resources of this function set every pollRate + seconds. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + MirrorUsagePoint: List[MirrorUsagePoint] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) + pollRate: int = field( + default=900, + metadata={ + "type": "Attribute", + } + ) + + +@dataclass +class TimeTariffIntervalList(SubscribableList): + """ + A List element to hold TimeTariffInterval objects. + """ + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + TimeTariffInterval: List[TimeTariffInterval] = field( + default_factory=list, + metadata={ + "type": "Element", + } + ) diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/timetype.py b/services/core/IEEE_2030_5/ieee_2030_5/models/timetype.py new file mode 100644 index 0000000000..e69de29bb2 diff --git a/services/core/IEEE_2030_5/requirements.txt b/services/core/IEEE_2030_5/requirements.txt new file mode 100644 index 0000000000..a3cfd8fe1c --- /dev/null +++ b/services/core/IEEE_2030_5/requirements.txt @@ -0,0 +1,2 @@ +xsdata +xsdata[cli] diff --git a/services/core/IEEE_2030_5/requirements_simulator.txt b/services/core/IEEE_2030_5/requirements_simulator.txt new file mode 100644 index 0000000000..d191e62fef --- /dev/null +++ b/services/core/IEEE_2030_5/requirements_simulator.txt @@ -0,0 +1 @@ +pvlib \ No newline at end of file diff --git a/services/core/IEEE_2030_5/setup.py b/services/core/IEEE_2030_5/setup.py new file mode 100644 index 0000000000..cc64769bff --- /dev/null +++ b/services/core/IEEE_2030_5/setup.py @@ -0,0 +1,72 @@ +# -*- coding: utf-8 -*- {{{ +# vim: set fenc=utf-8 ft=python sw=4 ts=4 sts=4 et: +# +# Copyright 2020, Battelle Memorial Institute. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# This material was prepared as an account of work sponsored by an agency of +# the United States Government. Neither the United States Government nor the +# United States Department of Energy, nor Battelle, nor any of their +# employees, nor any jurisdiction or organization that has cooperated in the +# development of these materials, makes any warranty, express or +# implied, or assumes any legal liability or responsibility for the accuracy, +# completeness, or usefulness or any information, apparatus, product, +# software, or process disclosed, or represents that its use would not infringe +# privately owned rights. Reference herein to any specific commercial product, +# process, or service by trade name, trademark, manufacturer, or otherwise +# does not necessarily constitute or imply its endorsement, recommendation, or +# favoring by the United States Government or any agency thereof, or +# Battelle Memorial Institute. The views and opinions of authors expressed +# herein do not necessarily state or reflect those of the +# United States Government or any agency thereof. +# +# PACIFIC NORTHWEST NATIONAL LABORATORY operated by +# BATTELLE for the UNITED STATES DEPARTMENT OF ENERGY +# under Contract DE-AC05-76RL01830 +# }}} + +from os import path +from setuptools import setup, find_packages + +MAIN_MODULE = 'agent' + +# Find the agent package that contains the main module +packages = find_packages('.') +agent_package = '' +for package in find_packages(): + # Because there could be other packages such as tests + if path.isfile(package + '/' + MAIN_MODULE + '.py') is True: + agent_package = package +if not agent_package: + raise RuntimeError('None of the packages under {dir} contain the file ' + '{main_module}'.format(main_module=MAIN_MODULE + '.py', + dir=path.abspath('.'))) + +# Find the version number from the main module +agent_module = agent_package + '.' + MAIN_MODULE +_temp = __import__(agent_module, globals(), locals(), ['__version__'], 0) +__version__ = _temp.__version__ + +# Setup +setup( + name=agent_package + 'agent', + version=__version__, + install_requires=['volttron'], + packages=packages, + entry_points={ + 'setuptools.installation': [ + 'eggsecutable = ' + agent_module + ':main', + ] + } +) diff --git a/services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py b/services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py new file mode 100644 index 0000000000..a115adbbe3 --- /dev/null +++ b/services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py @@ -0,0 +1,312 @@ +from __future__ import annotations + +import logging +import math +import sys +import time +from argparse import ArgumentParser +from dataclasses import dataclass, field +from pathlib import Path +from typing import Any, Dict, Generator, List + +import gevent +import pandas as pd +import pvlib +import yaml + +from volttron.platform.vip.agent.utils import build_agent + +# from typing import List, Optional, Dict +# from threading import Thread +# from threading import Timer + +# from ieee_2030_5.utils import serialize_dataclass + +# @dataclass +# class ZmqCredentials: +# address: str +# publickey: str +# secretkey: str +# serverkey: str = None + + +@dataclass +class AllPoints: + points: Dict = field(default_factory=dict) + meta: Dict = field(default_factory=dict) + + def add(self, name: str, value: Any, meta: Dict = {}): + self.points[name] = value + self.meta[name] = meta + + def forbus(self) -> List: + return [self.points, self.meta] + + @staticmethod + def frombus(message: List) -> AllPoints: + assert len(message) == 2, "Message must have a length of 2" + + points = AllPoints() + + for k, v in message[0].items(): + points.add(name=k, value=v, meta=message[1].get(k)) + + return points + + +def run_inverter(timesteps=50) -> Generator: + # PV module + sandia_modules = pvlib.pvsystem.retrieve_sam('SandiaMod') + module = sandia_modules['Canadian_Solar_CS5P_220M___2009_'] + # Inverter model + sapm_inverters = pvlib.pvsystem.retrieve_sam('cecinverter') + inverter = sapm_inverters['ABB__MICRO_0_25_I_OUTD_US_208__208V_'] + irradiance = [900, 1000, 925] + temperature = [25, 28, 20] + # Assumed constant power factor + PF = 0.99 + # Assumed constant AC voltage + v_ac = 120 + latitude = 32 + longitude = -111.0 + + weather_path = Path("~/weather.txt").expanduser() + if weather_path.exists(): + header = [ + "time(UTC)", "temp_air", "relative_humidity", "ghi", "dni", "dhi", + "IR(h)", "wind_speed", "wind_direction", "pressure" + ] + weather = pd.read_csv(weather_path) + else: + weather = pvlib.iotools.get_pvgis_tmy(latitude, + longitude, + map_variables=True)[0] + result = weather.to_csv(weather_path, header=True) + print(f"The result is: {result}") + + total_solar_radiance = weather['ghi'] + # assumed that the total solar radiance is equal to ghi(global horizontal irradiance) + outdoor_temp = weather["temp_air"] + # both the total_solar_radiace and outdoor_temp has 1hr sampling rate. + # you should be able modify the sampling rate by resampling it + for x, y in zip(total_solar_radiance, outdoor_temp): + dc = pvlib.pvsystem.sapm(x, y, module) + p_ac = pvlib.inverter.sandia(dc['v_mp'], dc['p_mp'], inverter) + s_ac = p_ac / PF + q_ac = math.sqrt(p_ac**2 + s_ac**2) + i_ac = (s_ac / v_ac) * 1000 + print( + f"p_ac = {p_ac}, s_ac = {s_ac}, q_ac= {q_ac}, PF = {PF}, v_ac = {v_ac}, i_ac = {i_ac}" + ) + yield dict(v_mp=dc['v_mp'], + p_mp=dc['p_mp'], + i_x=dc['i_x'], + i_xx=dc['i_xx'], + v_oc=dc['v_oc'], + i_sc=dc['i_sc'], + p_ac=p_ac, + s_ac=p_ac, + q_ac=q_ac, + v_ac=v_ac, + i_ac=i_ac, + PF=PF) + # single phase circuit calculation + + +if __name__ == '__main__': + logging.basicConfig(level=logging.DEBUG) + + # Impersonate the platform driver which is going to publish all messages + # to the bus. + agent = build_agent(identity='platform.driver') + gen = run_inverter(5) + + topic_to_publish = "devices/inverter1/all" + + for inv in gen: + points = AllPoints() + + for k, v in inv.items(): + points.add(k, v) + # publish + agent.vip.pubsub.publish(peer="pubsub", + topic=f"{topic_to_publish}", + message=points.forbus()) + gevent.sleep(10) + + sys.exit() + + while True: + + print(agent.core.connected) + gevent.sleep(5) + + parser = ArgumentParser() + + parser.add_argument("agent_config", help="Agent configuration file.") + + opts = parser.parse_args() + + cfg = Path(opts.agent_config) + + if not cfg.is_file(): + print(f"Config file is not valid: {cfg}") + sys.exit(1) + + yaml.safe_load() + + parser.add_argument( + "--tls-repo", + help="TLS repository directory to use, defaults to ~/tls", + default="~/tls") + parser.add_argument("--server-host", + help="Reference to the utilities server for data.") + parser.add_argument("--server-port", + type=int, + default=443, + help="Port the server is listening on, default to 443") + parser.add_argument("--device-id", + help="The id of the device for this inverter") + parser.add_argument( + "--pin", + type=int, + help= + "PIN for the client to validate that it is connecting to the correct server." + ) + + opts = parser.parse_args() + + path = Path(__file__).parent.parent.parent.joinpath("openssl.cnf") + repo_dir = Path(opts.tls_repo).expanduser().resolve(strict=True) + if not repo_dir.exists(): + raise ValueError(f"Invalid repo directory {str(repo_dir)}") + tls_repo = TLSRepository(repo_dir=repo_dir, + openssl_cnffile_template=path, + serverhost="gridappsd_dev_2004", + clear=False) + + if opts.device_id not in tls_repo.client_list: + raise ValueError( + f"device_id: ({opts.device_id}) not in tls repository") + + # print(new_tls_repository.client_list) + for p in tls_repo.client_list: + if p == opts.device_id: + IEEE2030_5_Client( + cafile=tls_repo.ca_cert_file, + keyfile=tls_repo.__get_key_file__(opts.device_id), + certfile=tls_repo.__get_cert_file__(opts.device_id), + hostname=p, + server_hostname=opts.server_host, + server_ssl_port=opts.server_port) + + # Start up a client from the available in the config file. + client = list(IEEE2030_5_Client.clients)[0] + for i in range(5): + # Device capability provides links to the other resources of interest. + dcap = client.device_capability() + time.sleep(2) + # Time request for offsets to keep things closely aligned. + tm = client.time() + # The device that this class is available for. + device = client.end_device() + # print("EndDevice") + # print(serialize_dataclass(device)) + # + + # # Registration to test if we have the correct pin for the client to be sure + # # that it is talking to the correct server + # reg = client.registration(device) + # assert reg.pIN == opts.pin + # + # curve_list: DERCurveList = client.__get_request__("/curves") + # curve1 = client.__get_request__(curve_list.DERCurve[0].href) + # + # global_programs: DERProgramList = client.__get_request__("/programs") + # program = client.__get_request__(global_programs.DERProgram[0].href) + # + # + # + # der_programs = client.der_program_list(device) + # + # der_programs = client.der_program_list() + + #print(fsa) + # edevs = client.end_devices() + # + # my_device = client.end_device() + # self_device = client.self_device() + # assert my_device == self_device + # end_devices = client.end_devices() + # end_device = client.end_device(0) + # registration = client.registration(end_device) + # + # # edev_config = client.request(end_device.ConfigurationLink.href) + # client.timelink() + # + # assert registration.pIN == opts.pin + # + # der_list = client.__get_request__(end_device.DERListLink.href) + # # uuidstr = client.new_uuid() + # mup = client.mirror_usage_point_list() + # + # mup_uuid = client.new_uuid().encode('utf-8') + # mup_gas_mirroring = MirrorUsagePoint( + # mRID=mup_uuid, + # description="Gas Mirroring", + # roleFlags=bytes(13), + # serviceCategoryKind=1, + # status=1, + # deviceLFDI=end_device.lFDI, + # MirrorMeterReading=[MirrorMeterReading( + # mRID=mup_uuid, + # Reading=Reading( + # value=125 + # ), + # ReadingType=ReadingType( + # accumulationBehaviour=9, + # commodity=7, + # dataQualifier=0, + # flowDirection=1, + # powerOfTenMultiplier=3, + # uom=119 + # ) + # )] + # ) + # + # status, location = client.create_mirror_usage_point(mup_gas_mirroring) + # + # point_list = client.mirror_usage_point_list() + # + # print(point_list) + + # print(client.new_uuid()) + # print(client.usage_point_list()) + # gen = run_inverter(client) + # for output in gen: + # print(output) + + # threads: List[Thread] = [] + # + # for index, client in enumerate(IEEE2030_5_Client.clients): + # th = Thread(target=run_inverter, args=(client,)) + # threads.append(th) + # th.daemon = True + # th.start() + # + # while True: + # alive = False + # for t in threads: + # if t.is_alive(): + # alive = True + # break + # if alive: + # break + # time.sleep(1) + + # while True: + # try: + # time.sleep(0.1) + # except KeyboardInterrupt: + # sys.stderr.write("Exiting program\n") + # sys.exit(0) From a24a89752ce2bc016867d1789d0d72960b1491e0 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Mon, 20 Feb 2023 13:38:26 -0800 Subject: [PATCH 06/53] Removed .travis.yml file from repository. --- .travis.yml | 11 ----------- 1 file changed, 11 deletions(-) delete mode 100644 .travis.yml diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index c4456b33e0..0000000000 --- a/.travis.yml +++ /dev/null @@ -1,11 +0,0 @@ -language: python2.7 - -# Each array entry will execute 1 job. -env: - - NUM_PROCESSES=10 CI="travis" - -services: - - docker - -script: ci-integration/run-test-docker.sh - From 0c0e78725dce40531d1a9d01a1080fd2c5b05bbb Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Mon, 20 Feb 2023 13:39:13 -0800 Subject: [PATCH 07/53] Added pyproject.toml file for yapf formatting. --- pyproject.toml | 13 ++++ .../core/IEEE_2030_5/ieee_2030_5/client.py | 78 ++++++++++++------- 2 files changed, 62 insertions(+), 29 deletions(-) create mode 100644 pyproject.toml diff --git a/pyproject.toml b/pyproject.toml new file mode 100644 index 0000000000..06556a1356 --- /dev/null +++ b/pyproject.toml @@ -0,0 +1,13 @@ +[tool.yapfignore] +ignore_patterns = [ + ".env/**", + ".pytest_cache/**", + "dist/**", + "docs/**", +] + +[tool.yapf] +based_on_style = "pep8" +spaces_before_comment = 4 +column_limit = 99 +split_before_logical_operator = true \ No newline at end of file diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index 0cf8066f75..9c9ac4d838 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -10,10 +10,9 @@ from pathlib import Path from threading import Timer from typing import Dict, Optional, Tuple -import xsdata import ieee_2030_5.models as m - +import xsdata _log = logging.getLogger(__name__) @@ -32,15 +31,17 @@ def __init__(self, cafile = cafile if isinstance(cafile, PathLike) else Path(cafile) keyfile = keyfile if isinstance(keyfile, PathLike) else Path(keyfile) - certfile = certfile if isinstance(certfile, PathLike) else Path(certfile) + certfile = certfile if isinstance(certfile, + PathLike) else Path(certfile) self._key = keyfile self._cert = certfile self._ca = cafile - assert cafile.exists(), f"cafile doesn't exist ({cafile})" - assert keyfile.exists(), f"keyfile doesn't exist ({keyfile})" - assert certfile.exists(), f"certfile doesn't exist ({certfile})" + # We know that these are Path objects now and have a .exists() function based upon above code. + assert cafile.exists(), f"cafile doesn't exist ({cafile})" # type: ignore[attr-defined] + assert keyfile.exists(), f"keyfile doesn't exist ({keyfile})" # type: ignore[attr-defined] + assert certfile.exists(), f"certfile doesn't exist ({certfile})" # type: ignore[attr-defined] self._ssl_context = ssl.SSLContext(ssl.PROTOCOL_TLS_CLIENT) self._ssl_context.check_hostname = False @@ -76,7 +77,9 @@ def http_conn(self) -> HTTPSConnection: def register_end_device(self) -> str: lfid = utils.get_lfdi_from_cert(self._cert) sfid = utils.get_sfdi_from_lfdi(lfid) - response = self.__post__(dcap.EndDeviceListLink.href, data=utils.dataclass_to_xml(m.EndDevice(sFDI=sfid))) + response = self.__post__(dcap.EndDeviceListLink.href, + data=utils.dataclass_to_xml( + m.EndDevice(sFDI=sfid))) print(response) if response.status in (200, 201): @@ -84,10 +87,8 @@ def register_end_device(self) -> str: raise werkzeug.exceptions.Forbidden() - - - - def is_end_device_registered(self, end_device: m.EndDevice, pin: int) -> bool: + def is_end_device_registered(self, end_device: m.EndDevice, + pin: int) -> bool: reg = self.registration(end_device) return reg.pIN == pin @@ -96,7 +97,8 @@ def new_uuid(self, url: str = "/uuid") -> str: return res def end_devices(self) -> m.EndDeviceListLink: - self._end_devices = self.__get_request__(self._device_cap.EndDeviceListLink.href) + self._end_devices = self.__get_request__( + self._device_cap.EndDeviceListLink.href) return self._end_devices def end_device(self, index: Optional[int] = 0) -> m.EndDevice: @@ -112,7 +114,8 @@ def self_device(self) -> m.EndDevice: return self.__get_request__(self._device_cap.SelfDeviceLink.href) def function_set_assignment(self) -> m.FunctionSetAssignmentsListLink: - fsa_list = self.__get_request__(self.end_device().FunctionSetAssignmentsListLink.href) + fsa_list = self.__get_request__( + self.end_device().FunctionSetAssignmentsListLink.href) return fsa_list def poll_timer(self, fn, args): @@ -140,17 +143,21 @@ def time(self) -> m.Time: return timexml def der_program_list(self, device: m.EndDevice) -> m.DERProgramList: - fsa: m.FunctionSetAssignments = self.__get_request__(device.FunctionSetAssignmentsListLink.href) - der_programs_list: m.DERProgramList = self.__get_request__(fsa.DERProgramListLink.href) + fsa: m.FunctionSetAssignments = self.__get_request__( + device.FunctionSetAssignmentsListLink.href) + der_programs_list: m.DERProgramList = self.__get_request__( + fsa.DERProgramListLink.href) return der_programs_list def mirror_usage_point_list(self) -> m.MirrorUsagePointList: - self._mup = self.__get_request__(self._device_cap.MirrorUsagePointListLink.href) + self._mup = self.__get_request__( + self._device_cap.MirrorUsagePointListLink.href) return self._mup def usage_point_list(self) -> m.UsagePointList: - self._upt = self.__get_request__(self._device_cap.UsagePointListLink.href) + self._upt = self.__get_request__( + self._device_cap.UsagePointListLink.href) return self._upt def registration(self, end_device: m.EndDevice) -> m.Registration: @@ -167,7 +174,10 @@ def disconnect(self): self._dcap_timer.cancel() IEEE2030_5_Client.clients.remove(self) - def request(self, endpoint: str, body: dict = None, method: str = "GET", + def request(self, + endpoint: str, + body: dict = None, + method: str = "GET", headers: dict = None): if method.upper() == 'GET': @@ -177,17 +187,24 @@ def request(self, endpoint: str, body: dict = None, method: str = "GET", print("Doing post") return self.__post__(endpoint, body, headers=headers) - def create_mirror_usage_point(self, mirror_usage_point: m.MirrorUsagePoint) -> Tuple[int, str]: + def create_mirror_usage_point( + self, mirror_usage_point: m.MirrorUsagePoint) -> Tuple[int, str]: data = dataclass_to_xml(mirror_usage_point) - resp = self.__post__(self._device_cap.MirrorUsagePointListLink.href, data=data) + resp = self.__post__(self._device_cap.MirrorUsagePointListLink.href, + data=data) return resp.status, resp.headers['Location'] - def __post__(self, url: str, data=None, headers: Optional[Dict[str, str]]=None): + def __post__(self, + url: str, + data=None, + headers: Optional[Dict[str, str]] = None): if not headers: headers = {'Content-Type': 'text/xml'} - self.http_conn.request(method="POST", headers=headers, - url=url, body=data) + self.http_conn.request(method="POST", + headers=headers, + url=url, + body=data) response = self._http_conn.getresponse() # response_data = response.read().decode("utf-8") @@ -195,12 +212,18 @@ def __post__(self, url: str, data=None, headers: Optional[Dict[str, str]]=None): def __get_request__(self, url: str, body=None, headers: dict = None): if headers is None: - headers = {"Connection": "keep-alive", "keep-alive": "timeout=30, max=1000"} + headers = { + "Connection": "keep-alive", + "keep-alive": "timeout=30, max=1000" + } if self._debug: print(f"----> GET REQUEST") print(f"url: {url} body: {body}") - self.http_conn.request(method="GET", url=url, body=body, headers=headers) + self.http_conn.request(method="GET", + url=url, + body=body, + headers=headers) response = self._http_conn.getresponse() response_data = response.read().decode("utf-8") print(response.headers) @@ -253,8 +276,7 @@ def __release_clients__(): KEY_FILE = Path("~/tls/private/dev1.pem").expanduser().resolve() CERT_FILE = Path("~/tls/certs/dev1.crt").expanduser().resolve() - headers = {'Connection': 'Keep-Alive', - 'Keep-Alive': "max=1000,timeout=30"} + headers = {'Connection': 'Keep-Alive', 'Keep-Alive': "max=1000,timeout=30"} h = IEEE2030_5_Client(cafile=SERVER_CA_CERT, server_hostname="127.0.0.1", @@ -272,7 +294,6 @@ def __release_clients__(): ed_href = h.register_end_device() my_ed = h.end_devices() - # ed = h.end_devices()[0] # resp = h.request("/dcap", headers=headers) # print(resp) @@ -289,6 +310,5 @@ def __release_clients__(): # # print(h.request(dcap.mirror_usage_point_list_link.href)) # print(h.request("/dcap", method="post")) - # tl = h.timelink() #print(IEEE2030_5_Client.clients) From 5b2947357822c33b6ab488b7bd338d1ebb8af54b Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Mon, 20 Feb 2023 13:40:49 -0800 Subject: [PATCH 08/53] Added yapf to the extra_requires structure --- requirements.py | 1 + 1 file changed, 1 insertion(+) diff --git a/requirements.py b/requirements.py index bac0d08fcc..dade0ae6a4 100644 --- a/requirements.py +++ b/requirements.py @@ -99,6 +99,7 @@ 'pytest_asyncio==0.19.0', 'pytest_timeout==2.1.0'], 'weather': ['Pint==0.19.2'], + 'yapf': ['yapf'], 'web': ['ws4py==0.5.1', 'PyJWT==1.7.1', 'Jinja2==3.1.2', From 4dcc44c9f5cabd096ddb5751891e4fb5ba95e693 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" Date: Wed, 22 Feb 2023 13:08:25 -0800 Subject: [PATCH 09/53] Add 2030.5 initial code --- services/core/IEEE_2030_5/example.config.yml | 40 ++++- .../core/IEEE_2030_5/ieee_2030_5/__init__.py | 39 +++++ .../core/IEEE_2030_5/ieee_2030_5/agent.py | 153 ++++++++++++------ .../core/IEEE_2030_5/ieee_2030_5/client.py | 126 +++++++++++---- services/core/IEEE_2030_5/keypair.json | 4 + 5 files changed, 282 insertions(+), 80 deletions(-) create mode 100644 services/core/IEEE_2030_5/keypair.json diff --git a/services/core/IEEE_2030_5/example.config.yml b/services/core/IEEE_2030_5/example.config.yml index dbf5946298..b6828148f8 100644 --- a/services/core/IEEE_2030_5/example.config.yml +++ b/services/core/IEEE_2030_5/example.config.yml @@ -7,9 +7,47 @@ server_hostname: localhost pin: 12345 # SSL defaults to 443 -server_ssl_port: 8443 +server_ssl_port: 7443 # http port defaults to none server_http_port: 8080 +MirrorUsagePointList: + # MirrorMeterReading based on Table E.2 IEEE Std 2030.5-18 + - subscription_point: p_ac + mRID: 5509D69F8B3535950000000000009182 + description: DER Inverter Real Power + roleFlags: 49 + serviceCategoryKind: 0 + status: 0 + MirrorMeterReading: + mRID: 5509D69F8B3535950000000000009183 + description: Real Power(W) Set + ReadingType: + accumulationBehavior: 12 + commodity: 1 + dataQualifier: 2 + intervalLength: 300 + powerOfTenMultiplier: 0 + uom: 38 + - subscription_point: q_ac + mRID: 5509D69F8B3535950000000000009184 + description: DER Inverter Reactive Power + roleFlags: 49 + serviceCategoryKind: 0 + status: 0 + MirrorMeterReading: + mRID: 5509D69F8B3535950000000000009185 + description: Reactive Power(VAr) Set + ReadingType: + accumulationBehavior: 12 + commodity: 1 + dataQualifier: 2 + intervalLength: 300 + powerOfTenMultiplier: 0 + uom: 38 + +# publishes on the following subscriptions will +# be available to create and POST readings to the +# 2030.5 server. subscriptions: - devices/inverter1/all diff --git a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py index ad437ad9c7..140cb2dfc3 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py @@ -2,6 +2,45 @@ from dataclasses import dataclass, field from typing import Any, Dict, List +from dataclasses import dataclass, is_dataclass +from pathlib import Path +from typing import Type, Optional + +from xsdata.formats.dataclass.context import XmlContext +from xsdata.formats.dataclass.parsers.config import ParserConfig +from xsdata.formats.dataclass.parsers.xml import XmlParser +from xsdata.formats.dataclass.serializers import XmlSerializer +from xsdata.formats.dataclass.serializers.config import SerializerConfig + +__xml_context__ = XmlContext() +__parser_config__ = ParserConfig(fail_on_unknown_attributes=False, + fail_on_unknown_properties=False) +__xml_parser__ = XmlParser(config=__parser_config__, context=__xml_context__) +__config__ = SerializerConfig(xml_declaration=False, pretty_print=True) +__serializer__ = XmlSerializer(config=__config__) +__ns_map__ = {None: "urn:ieee:std:2030.5:ns"} + + +def serialize_dataclass(obj) -> str: + """ + Serializes a dataclass that was created via xsdata to an xml string for + returning to a client. + """ + if not is_dataclass(obj): + raise ValueError("Invalid object, must be a dataclass object.") + + return __serializer__.render(obj, ns_map=__ns_map__) + + +def xml_to_dataclass(xml: str, type: Optional[Type] = None) -> object: + """ + Parse the xml passed and return result from loaded classes. + """ + return __xml_parser__.from_string(xml, type) + + +def dataclass_to_xml(dc) -> str: + return serialize_dataclass(dc) @dataclass diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index 8aef5e62cc..f26044f58d 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -13,12 +13,14 @@ # under the License. from __future__ import annotations -import datetime import logging import sys +from datetime import datetime from pathlib import Path from pprint import pformat +from typing import Dict +import ieee_2030_5.models as m from ieee_2030_5 import AllPoints from ieee_2030_5.client import IEEE2030_5_Client @@ -58,17 +60,28 @@ def __init__(self, config_path: str, **kwargs): self._cacertfile = Path(config['cacertfile']).expanduser() self._keyfile = Path(config['keyfile']).expanduser() self._certfile = Path(config['certfile']).expanduser() + self._pin = config['pin'] self._subscriptions = config["subscriptions"] self._server_hostname = config["server_hostname"] self._server_ssl_port = config.get("server_ssl_port", 443) self._server_http_port = config.get("server_http_port", None) - self._default_config = {"subscriptions": self._subscriptions} - + self._mirror_usage_point_list = config.get("MirrorUsagePointList", []) + self._default_config = {"subscriptions": self._subscriptions, "MirrorUsagePointList": self._mirror_usage_point_list } + self._server_usage_points: m.UsagePointList self._client = IEEE2030_5_Client(cafile=self._cacertfile, server_hostname=self._server_hostname, keyfile=self._keyfile, certfile=self._certfile, - server_ssl_port=self._server_ssl_port) + server_ssl_port=self._server_ssl_port, + pin=self._pin) + + _log.info(self._client.enddevice) + assert self._client.enddevice + self._point_to_reading_set: Dict[str, str] = {} + self._mirror_usage_points: Dict[str, m.MirrorUsagePoint] = {} + self._mup_readings: Dict[str, m.MirrorMeterReading] = {} + + #assert self._client.is_end_device_registered(), "End device is not registered." # Set a default configuration to ensure that self.configure is called immediately to setup # the agent. @@ -92,6 +105,16 @@ def configure(self, config_name, action, contents): try: subscriptions = config['subscriptions'] + new_usage_points: Dict[str, m.MirrorUsagePoint] = {} + + for mup in config.get("MirrorUsagePointList", []): + subscription_point = mup.pop('subscription_point') + new_usage_points[mup['mRID']] = m.MirrorUsagePoint(**mup) + new_usage_points[mup['mRID']].deviceLFDI = self._client.lfdi + new_usage_points[mup['mRID']].MirrorMeterReading = [] + new_usage_points[mup['mRID']].MirrorMeterReading.append(m.MirrorMeterReading(**mup['MirrorMeterReading'])) + mup['subscription_point'] = subscription_point + except ValueError as e: _log.error("ERROR PROCESSING CONFIGURATION: {}".format(e)) return @@ -103,6 +126,35 @@ def configure(self, config_name, action, contents): callback=self._data_published) self._subscriptions = subscriptions + + self._mup_readings.clear() + self._mirror_usage_points.clear() + + self._mirror_usage_points.update(new_usage_points) + server_usage_points = self._client.mirror_usage_point_list() + if server_usage_points.all == 0 and len(self._mirror_usage_point_list) > 0: + for mRID, mup in self._mirror_usage_points.items(): + response = self._client.create_mirror_usage_point(mup) + mup_reading = m.MirrorMeterReading(mRID=mup.MirrorMeterReading[0].mRID, + description=mup.MirrorMeterReading[0].description) + # new mrid is based upon the mirror reading. + mup_reading.MirrorReadingSet = m.MirrorReadingSet(mRID=mup_reading.mRID + "1", + timePeriod=m.DateTimeInterval()) + mup_reading.MirrorReadingSet.timePeriod.start = int(round(datetime.utcnow().timestamp())) + self._mup_readings[mup_reading.mRID] = mup_reading + + self._server_usage_points = self._client.mirror_usage_point_list() + + # for server_mup in self._server_usage_points.MirrorUsagePoint: + # # TODO: Make the config file have a list of meter readings for the points subscription + # mup_reading = m.MirrorMeterReading(mRID=server_mup.MirrorMeterReading[0].mRID, + # description=server_mup.MirrorMeterReading[0].description) + # # new mrid is based upon the mirror reading. + # mup_reading.MirrorReadingSet = m.MirrorReadingSet(mrid=mup_reading.mRID + "1") + # mup_reading.MirrorReadingSet.timePeriod.start = int(round(datetime.utcnow().timestamp())) + + # self._mup_readings[server_mup.MirrorMeterReading.mRID] = mup_reading + for sub in self._subscriptions: _log.info(f"Subscribing to: {sub}") @@ -114,50 +166,61 @@ def _data_published(self, peer, sender, bus, topic, headers, message): """ Callback triggered by the subscription setup using the topic from the agent's config file """ + _log.debug("DATA Published") points = AllPoints.frombus(message) + + for pt in self._mirror_usage_point_list: + if pt["subscription_point"] in points.points: + reading_mRID = pt["MirrorMeterReading"]['mRID'] + reading = self._mup_readings[reading_mRID] + reading.MirrorReadingSet.Reading.append(m.Reading(value=points.points[pt["subscription_point"]])) + start = reading.MirrorReadingSet.timePeriod.start + reading.MirrorReadingSet.timePeriod.duration = int(round(datetime.utcnow().timestamp())) - start + self._client.post_mirror_reading(reading) + _log.debug(points.__dict__) - @Core.receiver("onstart") - def onstart(self, sender, **kwargs): - """ - This is method is called once the Agent has successfully connected to the platform. - This is a good place to setup subscriptions if they are not dynamic or - do any other startup activities that require a connection to the message bus. - Called after any configurations methods that are called at startup. - - Usually not needed if using the configuration store. - """ - # Example publish to pubsub - # self.vip.pubsub.publish('pubsub', "some/random/topic", message="HI!") - - # Example RPC call - # self.vip.rpc.call("some_agent", "some_method", arg1, arg2) - pass - - @Core.receiver("onstop") - def onstop(self, sender, **kwargs): - """ - This method is called when the Agent is about to shutdown, but before it disconnects from - the message bus. - """ - pass - - @RPC.export - def rpc_method(self, arg1, arg2, kwarg1=None, kwarg2=None): - """ - RPC method - - May be called from another agent via self.vip.rpc.call - """ - return self.setting1 + arg1 - arg2 - - @PubSub.subscribe('pubsub', '', all_platforms=True) - def on_match(self, peer, sender, bus, topic, headers, message): - """Use match_all to receive all messages and print them out.""" - _log.debug( - "Peer: {0}, Sender: {1}:, Bus: {2}, Topic: {3}, Headers: {4}, " - "Message: \n{5}".format(peer, sender, bus, topic, headers, - pformat(message))) + # @Core.receiver("onstart") + # def onstart(self, sender, **kwargs): + # """ + # This is method is called once the Agent has successfully connected to the platform. + # This is a good place to setup subscriptions if they are not dynamic or + # do any other startup activities that require a connection to the message bus. + # Called after any configurations methods that are called at startup. + + # Usually not needed if using the configuration store. + # """ + # # Example publish to pubsub + # # self.vip.pubsub.publish('pubsub', "some/random/topic", message="HI!") + + # # Example RPC call + # # self.vip.rpc.call("some_agent", "some_method", arg1, arg2) + # pass + + # @Core.receiver("onstop") + # def onstop(self, sender, **kwargs): + # """ + # This method is called when the Agent is about to shutdown, but before it disconnects from + # the message bus. + # """ + # pass + + # @RPC.export + # def rpc_method(self, arg1, arg2, kwarg1=None, kwarg2=None): + # """ + # RPC method + + # May be called from another agent via self.vip.rpc.call + # """ + # return self.setting1 + arg1 - arg2 + + # @PubSub.subscribe('pubsub', '', all_platforms=True) + # def on_match(self, peer, sender, bus, topic, headers, message): + # """Use match_all to receive all messages and print them out.""" + # _log.debug( + # "Peer: {0}, Sender: {1}:, Bus: {2}, Topic: {3}, Headers: {4}, " + # "Message: \n{5}".format(peer, sender, bus, topic, headers, + # pformat(message))) def main(): diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index 9c9ac4d838..138de40190 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -3,16 +3,19 @@ import atexit import logging import ssl +import subprocess import threading import xml.dom.minidom -from http.client import HTTPSConnection +from http.client import HTTPMessage, HTTPSConnection from os import PathLike from pathlib import Path from threading import Timer from typing import Dict, Optional, Tuple +from uuid import uuid4 import ieee_2030_5.models as m import xsdata +from ieee_2030_5 import dataclass_to_xml, xml_to_dataclass _log = logging.getLogger(__name__) @@ -26,17 +29,18 @@ def __init__(self, server_hostname: str, keyfile: PathLike, certfile: PathLike, + pin: str, server_ssl_port: Optional[int] = 443, debug: bool = True): cafile = cafile if isinstance(cafile, PathLike) else Path(cafile) keyfile = keyfile if isinstance(keyfile, PathLike) else Path(keyfile) - certfile = certfile if isinstance(certfile, - PathLike) else Path(certfile) + certfile = certfile if isinstance(certfile, PathLike) else Path(certfile) - self._key = keyfile - self._cert = certfile - self._ca = cafile + self._keyfile = keyfile + self._certfile = certfile + self._cafile = cafile + self._pin = pin # We know that these are Path objects now and have a .exists() function based upon above code. assert cafile.exists(), f"cafile doesn't exist ({cafile})" # type: ignore[attr-defined] @@ -55,37 +59,83 @@ def __init__(self, self._http_conn = HTTPSConnection(host=server_hostname, port=server_ssl_port, context=self._ssl_context) - self._device_cap: Optional[m.DeviceCapability] = None - self._mup: Optional[m.MirrorUsagePointList] = None - self._upt: Optional[m.UsagePointList] = None - self._edev: Optional[m.EndDeviceListLink] = None - self._end_devices: Optional[m.EndDeviceListLink] = None - self._fsa_list: Optional[m.FunctionSetAssignmentsListLink] = None + self._response_headers: HTTPMessage + self._response_status = None + + self._device_cap: m.DeviceCapability = m.DeviceCapability() + self._mup: m.MirrorUsagePointList = m.MirrorUsagePointList() + self._upt: m.UsagePointList = m.UsagePointList() + self._edev: m.EndDeviceListLink = m.EndDeviceListLink() + self._end_devices: m.EndDeviceList = m.EndDeviceList() + self._fsa_list: m.FunctionSetAssignmentsList = m.FunctionSetAssignmentsList() + self._der_programs: m.DERProgramList = m.DERProgramList() + self._mup: m.MirrorUsagePoint = m.MirrorUsagePoint() self._debug = debug self._dcap_poll_rate: int = 0 self._dcap_timer: Optional[Timer] = None self._disconnect: bool = False + + # Starts a timer + self.update_state() IEEE2030_5_Client.clients.add(self) + + @property + def lfdi(self) -> str: + cmd = ["openssl", "x509", "-in", str(self._certfile), "-noout", "-fingerprint", "-sha256"] + ret_value = subprocess.check_output(cmd, text=True) + if "=" in ret_value: + ret_value = ret_value.split("=")[1].strip() + + fp = ret_value.replace(":", "") + lfdi = fp[:40] + return lfdi @property def http_conn(self) -> HTTPSConnection: if self._http_conn.sock is None: self._http_conn.connect() return self._http_conn - - def register_end_device(self) -> str: - lfid = utils.get_lfdi_from_cert(self._cert) - sfid = utils.get_sfdi_from_lfdi(lfid) - response = self.__post__(dcap.EndDeviceListLink.href, - data=utils.dataclass_to_xml( - m.EndDevice(sFDI=sfid))) - print(response) - - if response.status in (200, 201): - return response.headers.get("Location") - - raise werkzeug.exceptions.Forbidden() + + @property + def enddevices(self) -> m.EndDeviceList: + return self._end_devices + + @property + def enddevice(self, index: int = 0) -> m.EndDevice: + return self._end_devices.EndDevice[index] + + + def __hash__(self) -> int: + return self._keyfile.read_text().__hash__() # type: ignore[attr-defined] + + + def update_state(self) -> None: + self._device_cap = self.device_capability() + self._end_devices = self.get_enddevices() + ed = self.enddevice + if ed.FunctionSetAssignmentsListLink.href: + self._fsa_list: m.FunctionSetAssignmentsList = self.request(endpoint=ed.FunctionSetAssignmentsListLink.href) + if len(self._fsa_list.FunctionSetAssignments) > 1: + raise ValueError("Server responded with more than one function set assignment.") + for fsa in self._fsa_list.FunctionSetAssignments: + if fsa.DERProgramListLink.href: + self._der_programs = self.request(fsa.DERProgramListLink.href) + + + + # def register_end_device(self) -> str: + # lfid = utils.get_lfdi_from_cert(self._cert) + # sfid = utils.get_sfdi_from_lfdi(lfid) + # response = self.__post__(dcap.EndDeviceListLink.href, + # data=utils.dataclass_to_xml( + # m.EndDevice(sFDI=sfid))) + # print(response) + + # if response.status in (200, 201): + # return response.headers.get("Location") + + # raise werkzeug.exceptions.Forbidden() def is_end_device_registered(self, end_device: m.EndDevice, pin: int) -> bool: @@ -95,11 +145,13 @@ def is_end_device_registered(self, end_device: m.EndDevice, def new_uuid(self, url: str = "/uuid") -> str: res = self.__get_request__(url) return res + + def get_enddevices(self) -> m.EndDeviceList: + return self.__get_request__(self._device_cap.EndDeviceListLink.href) - def end_devices(self) -> m.EndDeviceListLink: - self._end_devices = self.__get_request__( - self._device_cap.EndDeviceListLink.href) - return self._end_devices + # def end_devices(self) -> m.EndDeviceList: + # self._end_devices = self.__get_request__(self._device_cap.EndDeviceListLink.href) + # return self._end_devices def end_device(self, index: Optional[int] = 0) -> m.EndDevice: if not self._end_devices: @@ -134,8 +186,9 @@ def device_capability(self, url: str = "/dcap") -> m.DeviceCapability: _log.debug(f"devcap id {id(self._device_cap)}") _log.debug(threading.currentThread().name) _log.debug(f"DCAP: Poll rate: {self._dcap_poll_rate}") - # self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, (self.device_capability, url)) - # self._dcap_timer.start() + self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, (self.device_capability, url)) + self._dcap_timer.start() + return self._device_cap def time(self) -> m.Time: @@ -150,6 +203,9 @@ def der_program_list(self, device: m.EndDevice) -> m.DERProgramList: return der_programs_list + def post_mirror_reading(self, reading: m.MirrorMeterReading): + print(reading) + def mirror_usage_point_list(self) -> m.MirrorUsagePointList: self._mup = self.__get_request__( self._device_cap.MirrorUsagePointListLink.href) @@ -210,7 +266,7 @@ def __post__(self, return response - def __get_request__(self, url: str, body=None, headers: dict = None): + def __get_request__(self, url: str, body=None, headers: Optional[Dict] = None): if headers is None: headers = { "Connection": "keep-alive", @@ -224,13 +280,15 @@ def __get_request__(self, url: str, body=None, headers: dict = None): url=url, body=body, headers=headers) + response = self._http_conn.getresponse() response_data = response.read().decode("utf-8") - print(response.headers) + self._response_headers = response.headers + self._response_status = response.status response_obj = None try: - response_obj = utils.xml_to_dataclass(response_data) + response_obj = xml_to_dataclass(response_data) resp_xml = xml.dom.minidom.parseString(response_data) if resp_xml and self._debug: print(f"<---- GET RESPONSE") diff --git a/services/core/IEEE_2030_5/keypair.json b/services/core/IEEE_2030_5/keypair.json new file mode 100644 index 0000000000..77d8dd1527 --- /dev/null +++ b/services/core/IEEE_2030_5/keypair.json @@ -0,0 +1,4 @@ +{ + "public": "YrRnX1ifv5hkctAtNsLMut1j3qr7dPf0gppvwH_53wE", + "secret": "C55SSFUKAM38dXZKjMSolRvFVfILbSTF9JkUQWlP8II" +} From 474eb00b23cc25b7d8bb89b548dc02dd36a7a0d8 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Wed, 5 Apr 2023 00:03:57 -0700 Subject: [PATCH 10/53] Update agent readme --- services/core/IEEE_2030_5/README.md | 16 + services/core/IEEE_2030_5/example.config.yml | 36 +- .../core/IEEE_2030_5/ieee_2030_5/__init__.py | 10 +- .../core/IEEE_2030_5/ieee_2030_5/agent.py | 98 +- services/core/IEEE_2030_5/requirements.txt | 1 + .../core/IEEE_2030_5/requirements_demo.txt | 2 + .../IEEE_2030_5/requirements_simulator.txt | 1 - .../simulated_inverter/inverter_runner.py | 343 +- .../simulated_inverter/weather.txt | 8761 +++++++++++++++++ 9 files changed, 9005 insertions(+), 263 deletions(-) create mode 100644 services/core/IEEE_2030_5/README.md create mode 100644 services/core/IEEE_2030_5/requirements_demo.txt delete mode 100644 services/core/IEEE_2030_5/requirements_simulator.txt create mode 100644 services/core/IEEE_2030_5/simulated_inverter/weather.txt diff --git a/services/core/IEEE_2030_5/README.md b/services/core/IEEE_2030_5/README.md new file mode 100644 index 0000000000..ab6dfa7b2f --- /dev/null +++ b/services/core/IEEE_2030_5/README.md @@ -0,0 +1,16 @@ +# VOLTTRON 2030.5 Agent + +The VOLTTRON 2030.5 agent communicates with a 2030.5 server using the IEEE 2030.5(2018) protocol. The primary concern of +this agent is to handle the communication between the platform.driver and the 2030.5 server. The 2030.5 protocol uses a +REQUEST/RESPONSE pattern meaning that all communication with the 2030.5 server will start with a REQUEST being sent +from the client. + +## + +```mermaid + graph TD; + A-->B; + A-->C; + B-->D; + C-->D; +``` diff --git a/services/core/IEEE_2030_5/example.config.yml b/services/core/IEEE_2030_5/example.config.yml index b6828148f8..11ec2677b7 100644 --- a/services/core/IEEE_2030_5/example.config.yml +++ b/services/core/IEEE_2030_5/example.config.yml @@ -2,17 +2,19 @@ cacertfile: ~/tls/certs/ca.pem keyfile: ~/tls/private/dev1.pem certfile: ~/tls/certs/dev1.pem -server_hostname: localhost +server_hostname: 127.0.0.1 # the pin number is used to verify the server is the correct server -pin: 12345 +pin: 111115 # SSL defaults to 443 -server_ssl_port: 7443 +server_ssl_port: 8443 # http port defaults to none server_http_port: 8080 MirrorUsagePointList: # MirrorMeterReading based on Table E.2 IEEE Std 2030.5-18 + # note the mRID in the MirrorMeterReading is the same that is in the + # MirrorUsagePoint. - subscription_point: p_ac mRID: 5509D69F8B3535950000000000009182 description: DER Inverter Real Power @@ -20,7 +22,7 @@ MirrorUsagePointList: serviceCategoryKind: 0 status: 0 MirrorMeterReading: - mRID: 5509D69F8B3535950000000000009183 + mRID: 5509D69F8B3535950000000000009182 description: Real Power(W) Set ReadingType: accumulationBehavior: 12 @@ -36,7 +38,7 @@ MirrorUsagePointList: serviceCategoryKind: 0 status: 0 MirrorMeterReading: - mRID: 5509D69F8B3535950000000000009185 + mRID: 5509D69F8B3535950000000000009184 description: Reactive Power(VAr) Set ReadingType: accumulationBehavior: 12 @@ -51,3 +53,27 @@ MirrorUsagePointList: # 2030.5 server. subscriptions: - devices/inverter1/all + +# Nameplate ratings for this der client will be put to the +# server during startup of the system. +DERCapability: + # modesSupported is a HexBinary31 representation of DERControlType + # See Figure B.34 DER info types for information + # conversion in python is as follows + # "{0:08b}".format(int("500040", 16)) + # '10100000000000001000000' # This is a bitmask + # to generate HexBinary + # hex(int('10100000000000001000000', 2)) + # 0x500040 + modesSupported: 500040 + rtgMaxW: + multiplier: 0 + value: 0 + type: 0 + +DERSettings: + modesEnabled: 100000 + setGradW: 0 + setMaxW: + multiplier: 0 + value: 0 diff --git a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py index 140cb2dfc3..602b20dbcf 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py @@ -1,10 +1,8 @@ from __future__ import annotations -from dataclasses import dataclass, field -from typing import Any, Dict, List -from dataclasses import dataclass, is_dataclass +from dataclasses import dataclass, field, is_dataclass from pathlib import Path -from typing import Type, Optional +from typing import Any, Dict, List, Optional, Type from xsdata.formats.dataclass.context import XmlContext from xsdata.formats.dataclass.parsers.config import ParserConfig @@ -64,4 +62,6 @@ def frombus(message: List) -> AllPoints: for k, v in message[0].items(): points.add(name=k, value=v, meta=message[1].get(k)) - return points \ No newline at end of file + return points + +import ieee_2030_5.models as models diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index f26044f58d..46b3b332ee 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -18,11 +18,11 @@ from datetime import datetime from pathlib import Path from pprint import pformat -from typing import Dict +from typing import Dict, List import ieee_2030_5.models as m from ieee_2030_5 import AllPoints -from ieee_2030_5.client import IEEE2030_5_Client +from ieee_2030_5.client import IEEE_2030_5_Client try: # for modular from volttron import utils @@ -66,23 +66,33 @@ def __init__(self, config_path: str, **kwargs): self._server_ssl_port = config.get("server_ssl_port", 443) self._server_http_port = config.get("server_http_port", None) self._mirror_usage_point_list = config.get("MirrorUsagePointList", []) - self._default_config = {"subscriptions": self._subscriptions, "MirrorUsagePointList": self._mirror_usage_point_list } + self._der_capabilities_info = config.get("DERCapability") + self._der_settings_info = config.get("DERSettings") + self._der_status_info = config.get("DERStatus") + self._default_config = {"subscriptions": self._subscriptions, + "MirrorUsagePointList": self._mirror_usage_point_list } self._server_usage_points: m.UsagePointList - self._client = IEEE2030_5_Client(cafile=self._cacertfile, + self._client = IEEE_2030_5_Client(cafile=self._cacertfile, server_hostname=self._server_hostname, keyfile=self._keyfile, certfile=self._certfile, server_ssl_port=self._server_ssl_port, pin=self._pin) + # Hook up events so we can respond to them appropriately + self._client.der_control_event_started(self._control_event_started) + self._client.der_control_event_ended(self._control_event_ended) + + self._client.start() _log.info(self._client.enddevice) assert self._client.enddevice self._point_to_reading_set: Dict[str, str] = {} self._mirror_usage_points: Dict[str, m.MirrorUsagePoint] = {} self._mup_readings: Dict[str, m.MirrorMeterReading] = {} + self._mup_pollRate: int = 60 + self._times_published: Dict[str, int] = {} - #assert self._client.is_end_device_registered(), "End device is not registered." - + # Set a default configuration to ensure that self.configure is called immediately to setup # the agent. self.vip.config.set_default("config", self._default_config) @@ -90,6 +100,34 @@ def __init__(self, config_path: str, **kwargs): self.vip.config.subscribe(self.configure, actions=["NEW", "UPDATE"], pattern="config") + + @RPC.export + def update_der_settings(self, href: str, new_settings: m.DERSettings) -> int: + resp = self._client.put_der_settings(href, new_settings) + return resp + + @RPC.export + def update_der_availability(self, href: str, new_availability: m.DERAvailability) -> int: + resp = self._client.put_der_availability(href, new_availability) + return resp + + @RPC.export + def update_der_status(self, href: str, new_availability: m.DERAvailability) -> int: + resp = self._client.put_der_status(href, new_availability) + return resp + + @RPC.export + def get_der_references(self) -> List[str]: + return self._client.get_der_hrefs() + + def _control_event_started(self, sender, **kwargs): + _log.debug(f"Control event started {kwargs}") + + def _control_event_ended(self, sender, **kwargs): + _log.debug(f"Control event ended {kwargs}") + + def dcap_updated(self, sender): + _log.debug(f"Dcap was updated by {sender}") def configure(self, config_name, action, contents): """ @@ -130,18 +168,31 @@ def configure(self, config_name, action, contents): self._mup_readings.clear() self._mirror_usage_points.clear() + ed = self._client.end_device self._mirror_usage_points.update(new_usage_points) server_usage_points = self._client.mirror_usage_point_list() - if server_usage_points.all == 0 and len(self._mirror_usage_point_list) > 0: - for mRID, mup in self._mirror_usage_points.items(): - response = self._client.create_mirror_usage_point(mup) + self._mup_pollRate = server_usage_points.pollRate if server_usage_points.pollRate else self._mup_pollRate + + for mup in self._mirror_usage_points.values(): + try: + found = next(filter(lambda x: x.mRID == mup.mRID, server_usage_points.MirrorUsagePoint)) + except StopIteration: + # TODO Create new usage point + location = self._client.create_mirror_usage_point(mup) mup_reading = m.MirrorMeterReading(mRID=mup.MirrorMeterReading[0].mRID, + href=location, description=mup.MirrorMeterReading[0].description) - # new mrid is based upon the mirror reading. - mup_reading.MirrorReadingSet = m.MirrorReadingSet(mRID=mup_reading.mRID + "1", + rs = m.MirrorReadingSet(mRID=mup_reading.mRID + "1", timePeriod=m.DateTimeInterval()) - mup_reading.MirrorReadingSet.timePeriod.start = int(round(datetime.utcnow().timestamp())) + rs.timePeriod.start = int(round(datetime.utcnow().timestamp())) + rs.timePeriod.duration = self._mup_pollRate + + # new mrid is based upon the mirror reading. + mup_reading.MirrorReadingSet.append(rs) + rs.Reading = [] + self._mup_readings[mup_reading.mRID] = mup_reading + self._server_usage_points = self._client.mirror_usage_point_list() @@ -169,14 +220,27 @@ def _data_published(self, peer, sender, bus, topic, headers, message): _log.debug("DATA Published") points = AllPoints.frombus(message) - for pt in self._mirror_usage_point_list: + + + for index, pt in enumerate(self._mirror_usage_point_list): if pt["subscription_point"] in points.points: reading_mRID = pt["MirrorMeterReading"]['mRID'] reading = self._mup_readings[reading_mRID] - reading.MirrorReadingSet.Reading.append(m.Reading(value=points.points[pt["subscription_point"]])) - start = reading.MirrorReadingSet.timePeriod.start - reading.MirrorReadingSet.timePeriod.duration = int(round(datetime.utcnow().timestamp())) - start - self._client.post_mirror_reading(reading) + for rs_index, rs in enumerate(reading.MirrorReadingSet): + rs = reading.MirrorReadingSet[rs_index] + rs.Reading.append(m.Reading(value=points.points[pt["subscription_point"]])) + start = rs.timePeriod.start + if start + self._mup_pollRate * 1000 > int(round(datetime.utcnow().timestamp())): + self._times_published[reading_mRID] = self._times_published.get(reading_mRID, 0) + 1 + rs.mRID = "_".join([reading_mRID, str(self._times_published[reading_mRID])]) + + new_reading_href = self._client.post_mirror_reading(reading) + _log.debug(f"New readings available: {new_reading_href}") + rs.Reading.clear() + rs.timePeriod.start = int(round(datetime.utcnow().timestamp())) + rs.timePeriod.duration = self._mup_pollRate + + _log.debug(points.__dict__) diff --git a/services/core/IEEE_2030_5/requirements.txt b/services/core/IEEE_2030_5/requirements.txt index a3cfd8fe1c..212a0cebb1 100644 --- a/services/core/IEEE_2030_5/requirements.txt +++ b/services/core/IEEE_2030_5/requirements.txt @@ -1,2 +1,3 @@ xsdata xsdata[cli] +blinker diff --git a/services/core/IEEE_2030_5/requirements_demo.txt b/services/core/IEEE_2030_5/requirements_demo.txt new file mode 100644 index 0000000000..9648e20138 --- /dev/null +++ b/services/core/IEEE_2030_5/requirements_demo.txt @@ -0,0 +1,2 @@ +pvlib +nicegui \ No newline at end of file diff --git a/services/core/IEEE_2030_5/requirements_simulator.txt b/services/core/IEEE_2030_5/requirements_simulator.txt deleted file mode 100644 index d191e62fef..0000000000 --- a/services/core/IEEE_2030_5/requirements_simulator.txt +++ /dev/null @@ -1 +0,0 @@ -pvlib \ No newline at end of file diff --git a/services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py b/services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py index a115adbbe3..fcf08a924d 100644 --- a/services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py +++ b/services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py @@ -1,5 +1,6 @@ from __future__ import annotations +import json import logging import math import sys @@ -14,6 +15,8 @@ import pvlib import yaml +from volttron.platform.vip.agent import Agent +from volttron.platform.vip.agent.subsystems.rpc import RPC from volttron.platform.vip.agent.utils import build_agent # from typing import List, Optional, Dict @@ -29,32 +32,28 @@ # secretkey: str # serverkey: str = None - -@dataclass -class AllPoints: - points: Dict = field(default_factory=dict) - meta: Dict = field(default_factory=dict) - - def add(self, name: str, value: Any, meta: Dict = {}): - self.points[name] = value - self.meta[name] = meta - - def forbus(self) -> List: - return [self.points, self.meta] - - @staticmethod - def frombus(message: List) -> AllPoints: - assert len(message) == 2, "Message must have a length of 2" - - points = AllPoints() - - for k, v in message[0].items(): - points.add(name=k, value=v, meta=message[1].get(k)) - - return points - - -def run_inverter(timesteps=50) -> Generator: +class MyInverterAgent(Agent): + def __init__(self, **kwargs): + super().__init__(**kwargs) + + self._points = {} + self._points['pf'] = 0.99 + self._generator = None + + @RPC.export + def set_point(self, point, value): + self._generator = None + self._points[point] = value + + @RPC.export + def get_point(self, point): + return self._points.get(point) + + @property + def reset(self): + return self._generator is not None + +def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Generator: # PV module sandia_modules = pvlib.pvsystem.retrieve_sam('SandiaMod') module = sandia_modules['Canadian_Solar_CS5P_220M___2009_'] @@ -64,13 +63,14 @@ def run_inverter(timesteps=50) -> Generator: irradiance = [900, 1000, 925] temperature = [25, 28, 20] # Assumed constant power factor - PF = 0.99 + PF = pf + print(f"Power Factor: {PF}") # Assumed constant AC voltage v_ac = 120 latitude = 32 longitude = -111.0 - weather_path = Path("~/weather.txt").expanduser() + weather_path = Path(__file__).parent.joinpath("weather.txt") if weather_path.exists(): header = [ "time(UTC)", "temp_air", "relative_humidity", "ghi", "dni", "dhi", @@ -79,10 +79,10 @@ def run_inverter(timesteps=50) -> Generator: weather = pd.read_csv(weather_path) else: weather = pvlib.iotools.get_pvgis_tmy(latitude, - longitude, - map_variables=True)[0] + longitude, + map_variables=True)[0] result = weather.to_csv(weather_path, header=True) - print(f"The result is: {result}") + total_solar_radiance = weather['ghi'] # assumed that the total solar radiance is equal to ghi(global horizontal irradiance) @@ -95,218 +95,91 @@ def run_inverter(timesteps=50) -> Generator: s_ac = p_ac / PF q_ac = math.sqrt(p_ac**2 + s_ac**2) i_ac = (s_ac / v_ac) * 1000 - print( - f"p_ac = {p_ac}, s_ac = {s_ac}, q_ac= {q_ac}, PF = {PF}, v_ac = {v_ac}, i_ac = {i_ac}" - ) - yield dict(v_mp=dc['v_mp'], - p_mp=dc['p_mp'], - i_x=dc['i_x'], - i_xx=dc['i_xx'], - v_oc=dc['v_oc'], - i_sc=dc['i_sc'], - p_ac=p_ac, - s_ac=p_ac, - q_ac=q_ac, - v_ac=v_ac, - i_ac=i_ac, - PF=PF) - # single phase circuit calculation - + # print( + # f"p_ac = {p_ac}, s_ac = {s_ac}, q_ac= {q_ac}, PF = {PF}, v_ac = {v_ac}, i_ac = {i_ac}" + # ) + results = dict(v_mp=dc['v_mp'], + p_mp=dc['p_mp'], + i_x=dc['i_x'], + i_xx=dc['i_xx'], + v_oc=dc['v_oc'], + i_sc=dc['i_sc'], + p_ac=p_ac, + s_ac=p_ac, + q_ac=q_ac, + v_ac=v_ac, + i_ac=i_ac, + PF=PF) + print(json.dumps(results)) + yield results + # single phase circuit calculation -if __name__ == '__main__': - logging.basicConfig(level=logging.DEBUG) - - # Impersonate the platform driver which is going to publish all messages - # to the bus. - agent = build_agent(identity='platform.driver') - gen = run_inverter(5) - - topic_to_publish = "devices/inverter1/all" - - for inv in gen: - points = AllPoints() - for k, v in inv.items(): - points.add(k, v) - # publish - agent.vip.pubsub.publish(peer="pubsub", - topic=f"{topic_to_publish}", - message=points.forbus()) - gevent.sleep(10) - - sys.exit() - - while True: - - print(agent.core.connected) - gevent.sleep(5) - - parser = ArgumentParser() - - parser.add_argument("agent_config", help="Agent configuration file.") - - opts = parser.parse_args() - - cfg = Path(opts.agent_config) - - if not cfg.is_file(): - print(f"Config file is not valid: {cfg}") - sys.exit(1) - - yaml.safe_load() - - parser.add_argument( - "--tls-repo", - help="TLS repository directory to use, defaults to ~/tls", - default="~/tls") - parser.add_argument("--server-host", - help="Reference to the utilities server for data.") - parser.add_argument("--server-port", - type=int, - default=443, - help="Port the server is listening on, default to 443") - parser.add_argument("--device-id", - help="The id of the device for this inverter") - parser.add_argument( - "--pin", - type=int, - help= - "PIN for the client to validate that it is connecting to the correct server." - ) - - opts = parser.parse_args() +@dataclass +class AllPoints: + points: Dict = field(default_factory=dict) + meta: Dict = field(default_factory=dict) - path = Path(__file__).parent.parent.parent.joinpath("openssl.cnf") - repo_dir = Path(opts.tls_repo).expanduser().resolve(strict=True) - if not repo_dir.exists(): - raise ValueError(f"Invalid repo directory {str(repo_dir)}") - tls_repo = TLSRepository(repo_dir=repo_dir, - openssl_cnffile_template=path, - serverhost="gridappsd_dev_2004", - clear=False) + def add(self, name: str, value: Any, meta: Dict = {}): + self.points[name] = value + self.meta[name] = meta - if opts.device_id not in tls_repo.client_list: - raise ValueError( - f"device_id: ({opts.device_id}) not in tls repository") + def forbus(self) -> List: + return [self.points, self.meta] - # print(new_tls_repository.client_list) - for p in tls_repo.client_list: - if p == opts.device_id: - IEEE2030_5_Client( - cafile=tls_repo.ca_cert_file, - keyfile=tls_repo.__get_key_file__(opts.device_id), - certfile=tls_repo.__get_cert_file__(opts.device_id), - hostname=p, - server_hostname=opts.server_host, - server_ssl_port=opts.server_port) + @staticmethod + def frombus(message: List) -> AllPoints: + assert len(message) == 2, "Message must have a length of 2" - # Start up a client from the available in the config file. - client = list(IEEE2030_5_Client.clients)[0] - for i in range(5): - # Device capability provides links to the other resources of interest. - dcap = client.device_capability() - time.sleep(2) - # Time request for offsets to keep things closely aligned. - tm = client.time() - # The device that this class is available for. - device = client.end_device() - # print("EndDevice") - # print(serialize_dataclass(device)) - # + points = AllPoints() - # # Registration to test if we have the correct pin for the client to be sure - # # that it is talking to the correct server - # reg = client.registration(device) - # assert reg.pIN == opts.pin - # - # curve_list: DERCurveList = client.__get_request__("/curves") - # curve1 = client.__get_request__(curve_list.DERCurve[0].href) - # - # global_programs: DERProgramList = client.__get_request__("/programs") - # program = client.__get_request__(global_programs.DERProgram[0].href) - # - # - # - # der_programs = client.der_program_list(device) - # - # der_programs = client.der_program_list() + for k, v in message[0].items(): + points.add(name=k, value=v, meta=message[1].get(k)) - #print(fsa) - # edevs = client.end_devices() - # - # my_device = client.end_device() - # self_device = client.self_device() - # assert my_device == self_device - # end_devices = client.end_devices() - # end_device = client.end_device(0) - # registration = client.registration(end_device) - # - # # edev_config = client.request(end_device.ConfigurationLink.href) - # client.timelink() - # - # assert registration.pIN == opts.pin - # - # der_list = client.__get_request__(end_device.DERListLink.href) - # # uuidstr = client.new_uuid() - # mup = client.mirror_usage_point_list() - # - # mup_uuid = client.new_uuid().encode('utf-8') - # mup_gas_mirroring = MirrorUsagePoint( - # mRID=mup_uuid, - # description="Gas Mirroring", - # roleFlags=bytes(13), - # serviceCategoryKind=1, - # status=1, - # deviceLFDI=end_device.lFDI, - # MirrorMeterReading=[MirrorMeterReading( - # mRID=mup_uuid, - # Reading=Reading( - # value=125 - # ), - # ReadingType=ReadingType( - # accumulationBehaviour=9, - # commodity=7, - # dataQualifier=0, - # flowDirection=1, - # powerOfTenMultiplier=3, - # uom=119 - # ) - # )] - # ) - # - # status, location = client.create_mirror_usage_point(mup_gas_mirroring) - # - # point_list = client.mirror_usage_point_list() - # - # print(point_list) + return points - # print(client.new_uuid()) - # print(client.usage_point_list()) - # gen = run_inverter(client) - # for output in gen: - # print(output) - # threads: List[Thread] = [] - # - # for index, client in enumerate(IEEE2030_5_Client.clients): - # th = Thread(target=run_inverter, args=(client,)) - # threads.append(th) - # th.daemon = True - # th.start() - # - # while True: - # alive = False - # for t in threads: - # if t.is_alive(): - # alive = True - # break - # if alive: - # break - # time.sleep(1) +if __name__ == '__main__': + logging.basicConfig(level=logging.DEBUG) + logging.getLogger('volttron.platform.vip.agent.core').setLevel(logging.WARNING) + + from pathlib import Path - # while True: - # try: - # time.sleep(0.1) - # except KeyboardInterrupt: - # sys.stderr.write("Exiting program\n") - # sys.exit(0) + # Impersonate the platform driver which is going to publish all messages + # to the bus. + agent = build_agent(identity='platform.driver', agent_class=MyInverterAgent) + + control_path = Path('inverter.ctl') + + while True: + + gen = run_inverter() + + topic_to_publish = "devices/inverter1/all" + pf = 0.99 + + for inv in gen: + points = AllPoints() + + for k, v in inv.items(): + if k == 'PF': + points.add(k, pf) + # publish + agent.vip.pubsub.publish(peer="pubsub", + topic=f"{topic_to_publish}", + message=points.forbus()) + gevent.sleep(10) + + if control_path.exists(): + data = control_path.open().read() + try: + obj = json.loads(data) + except json.decoder.JSONDecodeError: + obj = dict(pf=0.99) + + pf = obj.get('pf', 0.99) + + + + + agent.core.stop() \ No newline at end of file diff --git a/services/core/IEEE_2030_5/simulated_inverter/weather.txt b/services/core/IEEE_2030_5/simulated_inverter/weather.txt new file mode 100644 index 0000000000..93dd38ccfe --- /dev/null +++ b/services/core/IEEE_2030_5/simulated_inverter/weather.txt @@ -0,0 +1,8761 @@ +time(UTC),temp_air,relative_humidity,ghi,dni,dhi,IR(h),wind_speed,wind_direction,pressure +2014-01-01 00:00:00+00:00,14.0,40.04,63.0,467.49,24.0,244.12,2.47,87.0,91752.0 +2014-01-01 01:00:00+00:00,13.7,43.34,0.0,0.0,0.0,245.84,2.21,88.0,91764.0 +2014-01-01 02:00:00+00:00,13.4,46.63,0.0,0.0,0.0,247.57,1.95,88.0,91776.0 +2014-01-01 03:00:00+00:00,13.1,49.92,0.0,0.0,0.0,249.29,1.69,91.0,91785.0 +2014-01-01 04:00:00+00:00,12.8,53.21,0.0,0.0,0.0,251.02,1.43,94.0,91794.0 +2014-01-01 05:00:00+00:00,12.5,56.5,0.0,0.0,0.0,252.74,1.16,97.0,91803.0 +2014-01-01 06:00:00+00:00,12.2,59.8,0.0,0.0,0.0,254.47,0.9,96.0,91785.0 +2014-01-01 07:00:00+00:00,11.9,63.09,0.0,0.0,0.0,256.19,0.64,95.0,91767.0 +2014-01-01 08:00:00+00:00,7.14,73.45,0.0,0.0,0.0,247.3,1.48,95.0,91749.0 +2014-01-01 09:00:00+00:00,6.5,74.93,0.0,0.0,0.0,246.42,1.43,93.0,91752.0 +2014-01-01 10:00:00+00:00,5.85,76.41,0.0,0.0,0.0,245.53,1.38,91.0,91755.0 +2014-01-01 11:00:00+00:00,5.21,77.89,0.0,0.0,0.0,244.65,1.34,89.0,91758.0 +2014-01-01 12:00:00+00:00,5.13,78.59,0.0,0.0,0.0,244.43,1.36,89.0,91803.0 +2014-01-01 13:00:00+00:00,5.06,79.3,0.0,0.0,0.0,244.22,1.37,89.0,91848.0 +2014-01-01 14:00:00+00:00,4.99,80.0,0.0,0.0,0.0,244.0,1.39,89.0,91893.0 +2014-01-01 15:00:00+00:00,9.2,63.33,77.0,501.48,27.0,248.6,1.14,74.0,91911.0 +2014-01-01 16:00:00+00:00,13.4,46.66,267.0,792.68,49.0,253.2,0.89,58.0,91929.0 +2014-01-01 17:00:00+00:00,17.61,29.99,439.0,910.25,59.0,257.8,0.63,42.0,91947.0 +2014-01-01 18:00:00+00:00,18.93,26.39,564.0,964.52,65.0,259.65,1.09,32.0,91851.0 +2014-01-01 19:00:00+00:00,20.24,22.78,629.0,987.9,68.0,261.5,1.54,22.0,91755.0 +2014-01-01 20:00:00+00:00,21.55,19.18,627.0,988.38,68.0,263.35,2.0,12.0,91659.0 +2014-01-01 21:00:00+00:00,20.75,21.55,558.0,965.51,65.0,263.0,2.04,12.0,91644.0 +2014-01-01 22:00:00+00:00,19.94,23.91,429.0,909.67,59.0,262.65,2.07,11.0,91629.0 +2014-01-01 23:00:00+00:00,19.13,26.28,255.0,796.83,47.0,262.3,2.11,11.0,91614.0 +2014-01-02 00:00:00+00:00,16.95,31.43,65.0,466.47,25.0,260.33,1.8,20.0,91677.0 +2014-01-02 01:00:00+00:00,14.76,36.59,0.0,0.0,0.0,258.37,1.49,29.0,91740.0 +2014-01-02 02:00:00+00:00,12.57,41.74,0.0,0.0,0.0,256.4,1.17,38.0,91803.0 +2014-01-02 03:00:00+00:00,11.66,44.13,0.0,0.0,0.0,255.55,1.26,48.0,91827.0 +2014-01-02 04:00:00+00:00,10.75,46.51,0.0,0.0,0.0,254.7,1.35,59.0,91851.0 +2014-01-02 05:00:00+00:00,9.83,48.9,0.0,0.0,0.0,253.85,1.43,69.0,91875.0 +2014-01-02 06:00:00+00:00,9.35,51.12,0.0,0.0,0.0,252.73,1.47,73.0,91884.0 +2014-01-02 07:00:00+00:00,8.87,53.35,0.0,0.0,0.0,251.62,1.5,78.0,91893.0 +2014-01-02 08:00:00+00:00,8.38,55.57,0.0,0.0,0.0,250.5,1.53,82.0,91902.0 +2014-01-02 09:00:00+00:00,8.22,56.87,0.0,0.0,0.0,249.98,1.75,80.0,91926.0 +2014-01-02 10:00:00+00:00,8.05,58.17,0.0,0.0,0.0,249.47,1.96,78.0,91950.0 +2014-01-02 11:00:00+00:00,7.89,59.47,0.0,0.0,0.0,248.95,2.18,76.0,91974.0 +2014-01-02 12:00:00+00:00,7.62,60.45,0.0,0.0,0.0,248.67,2.5,76.0,91980.0 +2014-01-02 13:00:00+00:00,7.35,61.42,0.0,0.0,0.0,248.38,2.82,75.0,91986.0 +2014-01-02 14:00:00+00:00,7.08,62.4,0.0,0.0,0.0,248.1,3.14,74.0,91992.0 +2014-01-02 15:00:00+00:00,11.03,51.56,78.0,513.95,27.0,251.62,3.78,77.0,92004.0 +2014-01-02 16:00:00+00:00,14.97,40.73,269.0,800.42,49.0,255.13,4.42,79.0,92016.0 +2014-01-02 17:00:00+00:00,18.92,29.89,442.0,916.96,59.0,258.65,5.06,82.0,92028.0 +2014-01-02 18:00:00+00:00,20.17,26.4,567.0,967.22,66.0,261.18,4.71,87.0,91926.0 +2014-01-02 19:00:00+00:00,21.42,22.92,632.0,991.37,68.0,263.72,4.36,92.0,91824.0 +2014-01-02 20:00:00+00:00,22.67,19.43,629.0,989.41,68.0,266.25,4.01,98.0,91722.0 +2014-01-02 21:00:00+00:00,21.82,23.37,560.0,966.05,65.0,265.8,3.57,96.0,91692.0 +2014-01-02 22:00:00+00:00,20.97,27.31,432.0,912.43,59.0,265.35,3.12,94.0,91662.0 +2014-01-02 23:00:00+00:00,20.11,31.25,257.0,793.84,48.0,264.9,2.68,92.0,91632.0 +2014-01-03 00:00:00+00:00,17.98,36.21,68.0,487.84,25.0,263.38,2.69,87.0,91644.0 +2014-01-03 01:00:00+00:00,15.85,41.18,0.0,0.0,0.0,261.87,2.7,82.0,91656.0 +2014-01-03 02:00:00+00:00,13.71,46.14,0.0,0.0,0.0,260.35,2.72,78.0,91668.0 +2014-01-03 03:00:00+00:00,12.4,49.49,0.0,0.0,0.0,258.92,2.73,78.0,91692.0 +2014-01-03 04:00:00+00:00,11.09,52.84,0.0,0.0,0.0,257.48,2.74,77.0,91716.0 +2014-01-03 05:00:00+00:00,9.78,56.19,0.0,0.0,0.0,256.05,2.74,77.0,91740.0 +2014-01-03 06:00:00+00:00,8.99,59.11,0.0,0.0,0.0,254.3,2.73,79.0,91737.0 +2014-01-03 07:00:00+00:00,8.2,62.02,0.0,0.0,0.0,252.55,2.72,80.0,91734.0 +2014-01-03 08:00:00+00:00,7.4,64.94,0.0,0.0,0.0,250.8,2.7,82.0,91731.0 +2014-01-03 09:00:00+00:00,6.91,66.64,0.0,0.0,0.0,249.37,2.73,83.0,91722.0 +2014-01-03 10:00:00+00:00,6.41,68.35,0.0,0.0,0.0,247.93,2.75,85.0,91713.0 +2014-01-03 11:00:00+00:00,5.92,70.05,0.0,0.0,0.0,246.5,2.77,86.0,91704.0 +2014-01-03 12:00:00+00:00,6.11,71.52,0.0,0.0,0.0,246.5,2.76,90.0,91698.0 +2014-01-03 13:00:00+00:00,6.3,73.0,0.0,0.0,0.0,246.5,2.74,94.0,91692.0 +2014-01-03 14:00:00+00:00,6.5,74.47,0.0,0.0,0.0,246.5,2.73,97.0,91686.0 +2014-01-03 15:00:00+00:00,10.67,60.94,77.0,505.81,27.0,251.18,2.18,113.0,91683.0 +2014-01-03 16:00:00+00:00,14.84,47.4,267.0,796.96,48.0,255.87,1.64,129.0,91680.0 +2014-01-03 17:00:00+00:00,19.01,33.87,439.0,909.09,59.0,260.55,1.09,145.0,91677.0 +2014-01-03 18:00:00+00:00,20.41,29.46,564.0,962.0,65.0,264.4,1.79,175.0,91566.0 +2014-01-03 19:00:00+00:00,21.8,25.05,630.0,985.87,68.0,268.25,2.49,206.0,91455.0 +2014-01-03 20:00:00+00:00,23.19,20.64,628.0,984.97,68.0,272.1,3.19,236.0,91343.0 +2014-01-03 21:00:00+00:00,22.39,22.52,560.0,962.52,65.0,271.3,2.79,240.0,91313.0 +2014-01-03 22:00:00+00:00,21.59,24.41,432.0,907.66,59.0,270.5,2.4,244.0,91283.0 +2014-01-03 23:00:00+00:00,20.79,26.29,258.0,790.66,48.0,269.7,2.0,248.0,91253.0 +2014-01-04 00:00:00+00:00,19.22,30.28,69.0,474.6,26.0,268.3,1.81,245.0,91253.0 +2014-01-04 01:00:00+00:00,17.65,34.27,0.0,0.0,0.0,266.9,1.62,243.0,91253.0 +2014-01-04 02:00:00+00:00,16.07,38.26,0.0,0.0,0.0,265.5,1.43,240.0,91253.0 +2014-01-04 03:00:00+00:00,15.11,43.87,0.0,0.0,0.0,264.5,1.54,234.0,91289.0 +2014-01-04 04:00:00+00:00,14.15,49.49,0.0,0.0,0.0,263.5,1.65,229.0,91325.0 +2014-01-04 05:00:00+00:00,13.19,55.1,0.0,0.0,0.0,262.5,1.75,224.0,91361.0 +2014-01-04 06:00:00+00:00,12.43,56.81,0.0,0.0,0.0,263.95,2.02,224.0,91370.0 +2014-01-04 07:00:00+00:00,11.67,58.52,0.0,0.0,0.0,265.4,2.29,223.0,91379.0 +2014-01-04 08:00:00+00:00,10.91,60.23,0.0,0.0,0.0,266.85,2.55,223.0,91388.0 +2014-01-04 09:00:00+00:00,10.68,60.0,0.0,0.0,0.0,270.98,2.67,222.0,91397.0 +2014-01-04 10:00:00+00:00,10.45,59.78,0.0,0.0,0.0,275.12,2.79,221.0,91406.0 +2014-01-04 11:00:00+00:00,10.22,59.55,0.0,0.0,0.0,279.25,2.91,220.0,91416.0 +2014-01-04 12:00:00+00:00,9.83,58.69,0.0,0.0,0.0,281.52,3.0,217.0,91431.0 +2014-01-04 13:00:00+00:00,9.45,57.83,0.0,0.0,0.0,283.78,3.09,213.0,91446.0 +2014-01-04 14:00:00+00:00,9.07,56.97,0.0,0.0,0.0,286.05,3.19,210.0,91461.0 +2014-01-04 15:00:00+00:00,11.44,48.97,37.0,30.44,34.0,292.5,3.32,217.0,91491.0 +2014-01-04 16:00:00+00:00,13.81,40.96,118.0,40.02,107.0,298.95,3.45,224.0,91521.0 +2014-01-04 17:00:00+00:00,16.18,32.96,228.0,102.77,185.0,305.4,3.59,231.0,91551.0 +2014-01-04 18:00:00+00:00,17.32,29.37,291.0,98.16,240.0,304.75,3.89,241.0,91476.0 +2014-01-04 19:00:00+00:00,18.45,25.77,425.0,281.81,264.0,304.1,4.19,250.0,91400.0 +2014-01-04 20:00:00+00:00,19.58,22.18,383.0,191.17,274.0,303.45,4.5,260.0,91325.0 +2014-01-04 21:00:00+00:00,18.78,24.74,420.0,410.66,208.0,300.3,3.68,261.0,91334.0 +2014-01-04 22:00:00+00:00,17.97,27.3,298.0,307.37,171.0,297.15,2.87,263.0,91343.0 +2014-01-04 23:00:00+00:00,17.16,29.86,173.0,261.2,103.0,294.0,2.06,265.0,91352.0 +2014-01-05 00:00:00+00:00,16.05,33.41,35.0,32.21,32.0,291.22,1.9,264.0,91394.0 +2014-01-05 01:00:00+00:00,14.94,36.97,0.0,0.0,0.0,288.43,1.74,262.0,91437.0 +2014-01-05 02:00:00+00:00,13.82,40.52,0.0,0.0,0.0,285.65,1.59,261.0,91479.0 +2014-01-05 03:00:00+00:00,13.81,40.5,0.0,0.0,0.0,285.07,1.69,259.0,91533.0 +2014-01-05 04:00:00+00:00,13.79,40.47,0.0,0.0,0.0,284.48,1.8,258.0,91587.0 +2014-01-05 05:00:00+00:00,13.77,40.45,0.0,0.0,0.0,283.9,1.9,256.0,91641.0 +2014-01-05 06:00:00+00:00,13.39,40.92,0.0,0.0,0.0,281.9,1.76,258.0,91650.0 +2014-01-05 07:00:00+00:00,13.01,41.39,0.0,0.0,0.0,279.9,1.61,259.0,91659.0 +2014-01-05 08:00:00+00:00,12.62,41.86,0.0,0.0,0.0,277.9,1.46,261.0,91668.0 +2014-01-05 09:00:00+00:00,11.54,47.87,0.0,0.0,0.0,276.43,1.19,285.0,91680.0 +2014-01-05 10:00:00+00:00,10.45,53.88,0.0,0.0,0.0,274.97,0.91,310.0,91692.0 +2014-01-05 11:00:00+00:00,9.36,59.89,0.0,0.0,0.0,273.5,0.63,334.0,91704.0 +2014-01-05 12:00:00+00:00,8.56,63.78,0.0,0.0,0.0,270.8,0.68,1.0,91755.0 +2014-01-05 13:00:00+00:00,7.77,67.67,0.0,0.0,0.0,268.1,0.72,28.0,91806.0 +2014-01-05 14:00:00+00:00,6.98,71.56,0.0,0.0,0.0,265.4,0.76,55.0,91857.0 +2014-01-05 15:00:00+00:00,9.9,58.56,29.0,0.0,29.0,269.25,0.97,47.0,91893.0 +2014-01-05 16:00:00+00:00,12.81,45.57,150.0,138.19,112.0,273.1,1.18,38.0,91929.0 +2014-01-05 17:00:00+00:00,15.73,32.57,333.0,434.42,151.0,276.95,1.39,30.0,91965.0 +2014-01-05 18:00:00+00:00,16.88,27.88,588.0,1002.91,66.0,275.03,1.66,18.0,91884.0 +2014-01-05 19:00:00+00:00,18.02,23.2,657.0,1026.78,69.0,273.12,1.94,7.0,91803.0 +2014-01-05 20:00:00+00:00,19.16,18.51,657.0,1028.11,69.0,271.2,2.21,355.0,91722.0 +2014-01-05 21:00:00+00:00,18.58,17.97,447.0,503.56,186.0,268.82,2.09,356.0,91722.0 +2014-01-05 22:00:00+00:00,18.0,17.43,457.0,955.49,60.0,266.43,1.98,357.0,91722.0 +2014-01-05 23:00:00+00:00,17.41,16.89,199.0,403.0,90.0,264.05,1.86,359.0,91722.0 +2014-01-06 00:00:00+00:00,15.31,20.48,68.0,397.03,30.0,262.72,1.91,9.0,91770.0 +2014-01-06 01:00:00+00:00,13.2,24.08,0.0,0.0,0.0,261.38,1.95,19.0,91818.0 +2014-01-06 02:00:00+00:00,11.09,27.67,0.0,0.0,0.0,260.05,2.0,29.0,91866.0 +2014-01-06 03:00:00+00:00,10.26,27.13,0.0,0.0,0.0,259.27,1.8,37.0,91911.0 +2014-01-06 04:00:00+00:00,9.43,26.58,0.0,0.0,0.0,258.48,1.6,44.0,91956.0 +2014-01-06 05:00:00+00:00,8.6,26.04,0.0,0.0,0.0,257.7,1.41,52.0,92001.0 +2014-01-06 06:00:00+00:00,8.03,26.3,0.0,0.0,0.0,259.3,1.45,56.0,92025.0 +2014-01-06 07:00:00+00:00,7.45,26.55,0.0,0.0,0.0,260.9,1.49,59.0,92049.0 +2014-01-06 08:00:00+00:00,6.87,26.81,0.0,0.0,0.0,262.5,1.53,62.0,92073.0 +2014-01-06 09:00:00+00:00,6.22,28.7,0.0,0.0,0.0,257.18,1.89,64.0,92103.0 +2014-01-06 10:00:00+00:00,5.56,30.59,0.0,0.0,0.0,251.87,2.25,65.0,92133.0 +2014-01-06 11:00:00+00:00,4.9,32.48,0.0,0.0,0.0,246.55,2.61,67.0,92163.0 +2014-01-06 12:00:00+00:00,4.65,34.0,0.0,0.0,0.0,240.67,2.92,68.0,92212.0 +2014-01-06 13:00:00+00:00,4.4,35.52,0.0,0.0,0.0,234.78,3.24,68.0,92260.0 +2014-01-06 14:00:00+00:00,4.15,37.04,0.0,0.0,0.0,228.9,3.56,69.0,92308.0 +2014-01-06 15:00:00+00:00,7.71,30.56,80.0,529.12,28.0,231.67,4.19,70.0,92320.0 +2014-01-06 16:00:00+00:00,11.27,24.08,278.0,832.06,49.0,234.43,4.82,71.0,92332.0 +2014-01-06 17:00:00+00:00,14.83,17.6,456.0,943.79,60.0,237.2,5.45,71.0,92344.0 +2014-01-06 18:00:00+00:00,16.02,15.45,586.0,997.06,66.0,237.42,5.41,75.0,92221.0 +2014-01-06 19:00:00+00:00,17.21,13.3,654.0,1018.95,69.0,237.63,5.37,78.0,92097.0 +2014-01-06 20:00:00+00:00,18.4,11.15,654.0,1019.59,69.0,237.85,5.34,82.0,91974.0 +2014-01-06 21:00:00+00:00,17.88,11.32,586.0,999.09,66.0,236.98,4.75,81.0,91959.0 +2014-01-06 22:00:00+00:00,17.36,11.5,457.0,950.0,60.0,236.12,4.16,81.0,91944.0 +2014-01-06 23:00:00+00:00,16.83,11.67,279.0,842.44,49.0,235.25,3.57,81.0,91929.0 +2014-01-07 00:00:00+00:00,14.82,14.81,81.0,538.85,28.0,234.35,3.19,79.0,91947.0 +2014-01-07 01:00:00+00:00,12.81,17.95,0.0,0.0,0.0,233.45,2.8,77.0,91965.0 +2014-01-07 02:00:00+00:00,10.8,21.09,0.0,0.0,0.0,232.55,2.41,75.0,91983.0 +2014-01-07 03:00:00+00:00,9.75,23.52,0.0,0.0,0.0,231.67,2.56,74.0,92001.0 +2014-01-07 04:00:00+00:00,8.7,25.94,0.0,0.0,0.0,230.78,2.7,74.0,92019.0 +2014-01-07 05:00:00+00:00,7.64,28.37,0.0,0.0,0.0,229.9,2.84,74.0,92037.0 +2014-01-07 06:00:00+00:00,6.87,30.54,0.0,0.0,0.0,229.3,2.86,76.0,92028.0 +2014-01-07 07:00:00+00:00,6.1,32.71,0.0,0.0,0.0,228.7,2.87,79.0,92019.0 +2014-01-07 08:00:00+00:00,5.32,34.88,0.0,0.0,0.0,228.1,2.88,82.0,92010.0 +2014-01-07 09:00:00+00:00,4.68,36.18,0.0,0.0,0.0,227.95,2.89,82.0,92037.0 +2014-01-07 10:00:00+00:00,4.04,37.47,0.0,0.0,0.0,227.8,2.9,82.0,92064.0 +2014-01-07 11:00:00+00:00,3.4,38.77,0.0,0.0,0.0,227.65,2.91,82.0,92091.0 +2014-01-07 12:00:00+00:00,3.62,39.22,0.0,0.0,0.0,229.27,2.97,84.0,92076.0 +2014-01-07 13:00:00+00:00,3.84,39.66,0.0,0.0,0.0,230.88,3.03,86.0,92061.0 +2014-01-07 14:00:00+00:00,4.07,40.11,0.0,0.0,0.0,232.5,3.09,89.0,92046.0 +2014-01-07 15:00:00+00:00,8.02,32.82,79.0,529.13,27.0,236.23,2.38,94.0,92031.0 +2014-01-07 16:00:00+00:00,11.97,25.53,275.0,820.14,49.0,239.97,1.67,99.0,92016.0 +2014-01-07 17:00:00+00:00,15.92,18.24,451.0,930.24,60.0,243.7,0.97,105.0,92001.0 +2014-01-07 18:00:00+00:00,17.67,16.86,579.0,981.47,66.0,247.53,1.38,135.0,91869.0 +2014-01-07 19:00:00+00:00,19.42,15.48,645.0,1000.55,69.0,251.37,1.8,166.0,91737.0 +2014-01-07 20:00:00+00:00,21.16,14.1,643.0,997.06,69.0,255.2,2.22,196.0,91605.0 +2014-01-07 21:00:00+00:00,20.63,15.67,456.0,528.01,180.0,256.52,2.43,213.0,91599.0 +2014-01-07 22:00:00+00:00,20.1,17.23,351.0,499.55,141.0,257.83,2.64,229.0,91593.0 +2014-01-07 23:00:00+00:00,19.57,18.8,181.0,272.1,106.0,259.15,2.86,246.0,91587.0 +2014-01-08 00:00:00+00:00,18.39,21.5,80.0,514.54,28.0,260.02,2.13,245.0,91593.0 +2014-01-08 01:00:00+00:00,17.21,24.21,0.0,0.0,0.0,260.88,1.4,245.0,91599.0 +2014-01-08 02:00:00+00:00,16.03,26.91,0.0,0.0,0.0,261.75,0.68,244.0,91605.0 +2014-01-08 03:00:00+00:00,14.93,27.51,0.0,0.0,0.0,263.52,0.89,235.0,91623.0 +2014-01-08 04:00:00+00:00,13.83,28.1,0.0,0.0,0.0,265.28,1.1,225.0,91641.0 +2014-01-08 05:00:00+00:00,12.72,28.7,0.0,0.0,0.0,267.05,1.31,216.0,91659.0 +2014-01-08 06:00:00+00:00,11.89,31.89,0.0,0.0,0.0,268.95,1.49,214.0,91653.0 +2014-01-08 07:00:00+00:00,11.06,35.08,0.0,0.0,0.0,270.85,1.67,211.0,91647.0 +2014-01-08 08:00:00+00:00,10.23,38.27,0.0,0.0,0.0,272.75,1.85,209.0,91641.0 +2014-01-08 09:00:00+00:00,9.73,41.53,0.0,0.0,0.0,276.63,1.8,209.0,91653.0 +2014-01-08 10:00:00+00:00,9.23,44.78,0.0,0.0,0.0,280.52,1.75,209.0,91665.0 +2014-01-08 11:00:00+00:00,8.73,48.04,0.0,0.0,0.0,284.4,1.7,209.0,91677.0 +2014-01-08 12:00:00+00:00,8.27,49.63,0.0,0.0,0.0,274.35,1.9,203.0,91701.0 +2014-01-08 13:00:00+00:00,7.81,51.23,0.0,0.0,0.0,264.3,2.1,196.0,91725.0 +2014-01-08 14:00:00+00:00,7.36,52.82,0.0,0.0,0.0,254.25,2.3,190.0,91749.0 +2014-01-08 15:00:00+00:00,10.36,42.44,76.0,498.12,27.0,258.35,2.27,198.0,91761.0 +2014-01-08 16:00:00+00:00,13.37,32.05,269.0,797.08,49.0,262.45,2.23,207.0,91773.0 +2014-01-08 17:00:00+00:00,16.37,21.67,445.0,914.13,60.0,266.55,2.19,216.0,91785.0 +2014-01-08 18:00:00+00:00,17.57,18.81,575.0,971.48,66.0,267.3,2.98,227.0,91698.0 +2014-01-08 19:00:00+00:00,18.76,15.95,644.0,995.94,69.0,268.05,3.77,238.0,91611.0 +2014-01-08 20:00:00+00:00,19.95,13.09,646.0,998.75,69.0,268.8,4.57,249.0,91524.0 +2014-01-08 21:00:00+00:00,19.4,13.66,580.0,978.94,66.0,267.18,3.77,257.0,91533.0 +2014-01-08 22:00:00+00:00,18.85,14.22,453.0,929.21,60.0,265.57,2.97,264.0,91542.0 +2014-01-08 23:00:00+00:00,18.29,14.79,278.0,822.79,49.0,263.95,2.18,271.0,91551.0 +2014-01-09 00:00:00+00:00,17.43,16.84,83.0,529.74,28.0,262.03,1.79,265.0,91587.0 +2014-01-09 01:00:00+00:00,16.57,18.89,0.0,0.0,0.0,260.12,1.4,259.0,91623.0 +2014-01-09 02:00:00+00:00,15.71,20.94,0.0,0.0,0.0,258.2,1.01,253.0,91659.0 +2014-01-09 03:00:00+00:00,14.35,25.36,0.0,0.0,0.0,256.22,1.19,231.0,91677.0 +2014-01-09 04:00:00+00:00,12.98,29.79,0.0,0.0,0.0,254.23,1.37,210.0,91695.0 +2014-01-09 05:00:00+00:00,11.61,34.21,0.0,0.0,0.0,252.25,1.56,188.0,91713.0 +2014-01-09 06:00:00+00:00,10.19,39.94,0.0,0.0,0.0,250.85,1.55,179.0,91695.0 +2014-01-09 07:00:00+00:00,8.77,45.66,0.0,0.0,0.0,249.45,1.54,170.0,91677.0 +2014-01-09 08:00:00+00:00,7.35,51.39,0.0,0.0,0.0,248.05,1.53,161.0,91659.0 +2014-01-09 09:00:00+00:00,7.39,52.05,0.0,0.0,0.0,248.05,1.5,165.0,91671.0 +2014-01-09 10:00:00+00:00,7.42,52.72,0.0,0.0,0.0,248.05,1.47,170.0,91683.0 +2014-01-09 11:00:00+00:00,7.45,53.38,0.0,0.0,0.0,248.05,1.43,175.0,91695.0 +2014-01-09 12:00:00+00:00,6.71,54.1,0.0,0.0,0.0,248.37,1.59,157.0,91689.0 +2014-01-09 13:00:00+00:00,5.97,54.83,0.0,0.0,0.0,248.68,1.75,140.0,91683.0 +2014-01-09 14:00:00+00:00,5.24,55.55,0.0,0.0,0.0,249.0,1.9,122.0,91677.0 +2014-01-09 15:00:00+00:00,8.66,44.9,27.0,0.0,27.0,258.43,1.84,137.0,91680.0 +2014-01-09 16:00:00+00:00,12.07,34.25,136.0,86.78,112.0,267.87,1.77,152.0,91683.0 +2014-01-09 17:00:00+00:00,15.49,23.6,286.0,246.38,182.0,277.3,1.71,166.0,91686.0 +2014-01-09 18:00:00+00:00,16.68,21.0,401.0,327.43,229.0,282.88,2.57,189.0,91581.0 +2014-01-09 19:00:00+00:00,17.86,18.4,451.0,329.82,260.0,288.47,3.42,212.0,91476.0 +2014-01-09 20:00:00+00:00,19.04,15.8,438.0,298.35,265.0,294.05,4.28,236.0,91370.0 +2014-01-09 21:00:00+00:00,18.37,16.94,356.0,204.75,248.0,296.87,3.89,243.0,91373.0 +2014-01-09 22:00:00+00:00,17.7,18.08,273.0,195.03,190.0,299.68,3.49,251.0,91376.0 +2014-01-09 23:00:00+00:00,17.02,19.22,191.0,305.97,105.0,302.5,3.1,259.0,91379.0 +2014-01-10 00:00:00+00:00,16.18,21.46,85.0,534.5,28.0,292.97,2.69,257.0,91406.0 +2014-01-10 01:00:00+00:00,15.33,23.7,0.0,0.0,0.0,283.43,2.27,254.0,91434.0 +2014-01-10 02:00:00+00:00,14.48,25.94,0.0,0.0,0.0,273.9,1.85,252.0,91461.0 +2014-01-10 03:00:00+00:00,13.77,27.35,0.0,0.0,0.0,268.6,1.62,244.0,91491.0 +2014-01-10 04:00:00+00:00,13.06,28.76,0.0,0.0,0.0,263.3,1.4,236.0,91521.0 +2014-01-10 05:00:00+00:00,12.34,30.17,0.0,0.0,0.0,258.0,1.17,227.0,91551.0 +2014-01-10 06:00:00+00:00,11.76,30.95,0.0,0.0,0.0,256.43,1.34,239.0,91560.0 +2014-01-10 07:00:00+00:00,11.18,31.72,0.0,0.0,0.0,254.87,1.51,251.0,91569.0 +2014-01-10 08:00:00+00:00,10.59,32.5,0.0,0.0,0.0,253.3,1.68,263.0,91578.0 +2014-01-10 09:00:00+00:00,9.43,34.67,0.0,0.0,0.0,251.58,1.63,286.0,91602.0 +2014-01-10 10:00:00+00:00,8.26,36.84,0.0,0.0,0.0,249.87,1.57,308.0,91626.0 +2014-01-10 11:00:00+00:00,7.1,39.01,0.0,0.0,0.0,248.15,1.52,331.0,91650.0 +2014-01-10 12:00:00+00:00,6.45,45.42,0.0,0.0,0.0,248.23,1.63,293.0,91689.0 +2014-01-10 13:00:00+00:00,5.8,51.84,0.0,0.0,0.0,248.32,1.75,255.0,91728.0 +2014-01-10 14:00:00+00:00,5.16,58.25,0.0,0.0,0.0,248.4,1.86,217.0,91767.0 +2014-01-10 15:00:00+00:00,8.48,47.49,77.0,505.83,27.0,253.97,1.59,232.0,91794.0 +2014-01-10 16:00:00+00:00,11.8,36.73,271.0,800.86,49.0,259.53,1.31,248.0,91821.0 +2014-01-10 17:00:00+00:00,15.12,25.97,448.0,916.92,60.0,265.1,1.03,263.0,91848.0 +2014-01-10 18:00:00+00:00,16.36,23.68,578.0,971.97,66.0,263.75,1.54,277.0,91776.0 +2014-01-10 19:00:00+00:00,17.6,21.38,647.0,994.89,69.0,262.4,2.06,291.0,91704.0 +2014-01-10 20:00:00+00:00,18.83,19.09,649.0,996.45,69.0,261.05,2.57,305.0,91632.0 +2014-01-10 21:00:00+00:00,18.45,20.24,583.0,975.48,66.0,259.95,2.36,310.0,91635.0 +2014-01-10 22:00:00+00:00,18.06,21.39,455.0,922.27,60.0,258.85,2.16,315.0,91638.0 +2014-01-10 23:00:00+00:00,17.67,22.54,281.0,813.68,50.0,257.75,1.96,321.0,91641.0 +2014-01-11 00:00:00+00:00,15.59,26.87,87.0,529.63,29.0,255.57,1.81,322.0,91695.0 +2014-01-11 01:00:00+00:00,13.51,31.2,0.0,0.0,0.0,253.38,1.66,324.0,91749.0 +2014-01-11 02:00:00+00:00,11.43,35.53,0.0,0.0,0.0,251.2,1.5,325.0,91803.0 +2014-01-11 03:00:00+00:00,10.96,36.28,0.0,0.0,0.0,251.13,1.4,336.0,91851.0 +2014-01-11 04:00:00+00:00,10.49,37.02,0.0,0.0,0.0,251.07,1.3,348.0,91899.0 +2014-01-11 05:00:00+00:00,10.01,37.77,0.0,0.0,0.0,251.0,1.2,359.0,91947.0 +2014-01-11 06:00:00+00:00,9.01,43.59,0.0,0.0,0.0,250.32,1.27,23.0,91950.0 +2014-01-11 07:00:00+00:00,8.0,49.41,0.0,0.0,0.0,249.63,1.34,47.0,91953.0 +2014-01-11 08:00:00+00:00,6.99,55.23,0.0,0.0,0.0,248.95,1.41,71.0,91956.0 +2014-01-11 09:00:00+00:00,6.4,57.83,0.0,0.0,0.0,248.52,1.41,77.0,91971.0 +2014-01-11 10:00:00+00:00,5.8,60.43,0.0,0.0,0.0,248.08,1.41,83.0,91986.0 +2014-01-11 11:00:00+00:00,5.2,63.03,0.0,0.0,0.0,247.65,1.41,90.0,92001.0 +2014-01-11 12:00:00+00:00,5.07,64.04,0.0,0.0,0.0,247.85,1.54,92.0,92034.0 +2014-01-11 13:00:00+00:00,4.94,65.05,0.0,0.0,0.0,248.05,1.66,93.0,92067.0 +2014-01-11 14:00:00+00:00,4.82,66.06,0.0,0.0,0.0,248.25,1.79,95.0,92100.0 +2014-01-11 15:00:00+00:00,9.02,52.53,76.0,493.79,27.0,253.08,1.42,97.0,92118.0 +2014-01-11 16:00:00+00:00,13.21,38.99,269.0,791.51,49.0,257.92,1.04,99.0,92136.0 +2014-01-11 17:00:00+00:00,17.41,25.46,445.0,907.36,60.0,262.75,0.66,101.0,92154.0 +2014-01-11 18:00:00+00:00,19.06,23.27,574.0,961.52,66.0,265.48,1.2,108.0,92022.0 +2014-01-11 19:00:00+00:00,20.71,21.07,644.0,986.4,69.0,268.22,1.75,116.0,91890.0 +2014-01-11 20:00:00+00:00,22.35,18.88,646.0,987.37,69.0,270.95,2.29,123.0,91758.0 +2014-01-11 21:00:00+00:00,21.94,20.14,582.0,968.86,66.0,270.78,2.0,65.0,91719.0 +2014-01-11 22:00:00+00:00,21.53,21.39,457.0,920.94,60.0,270.62,1.71,7.0,91680.0 +2014-01-11 23:00:00+00:00,21.12,22.65,284.0,815.96,50.0,270.45,1.42,309.0,91641.0 +2014-01-12 00:00:00+00:00,19.5,26.54,90.0,542.54,29.0,268.88,1.35,327.0,91641.0 +2014-01-12 01:00:00+00:00,17.87,30.43,0.0,0.0,0.0,267.32,1.27,344.0,91641.0 +2014-01-12 02:00:00+00:00,16.24,34.32,0.0,0.0,0.0,265.75,1.2,2.0,91641.0 +2014-01-12 03:00:00+00:00,15.2,38.02,0.0,0.0,0.0,265.23,1.36,43.0,91644.0 +2014-01-12 04:00:00+00:00,14.15,41.73,0.0,0.0,0.0,264.72,1.52,84.0,91647.0 +2014-01-12 05:00:00+00:00,13.1,45.43,0.0,0.0,0.0,264.2,1.68,125.0,91650.0 +2014-01-12 06:00:00+00:00,12.97,48.49,0.0,0.0,0.0,263.0,1.8,149.0,91617.0 +2014-01-12 07:00:00+00:00,12.83,51.56,0.0,0.0,0.0,261.8,1.92,173.0,91584.0 +2014-01-12 08:00:00+00:00,12.69,54.62,0.0,0.0,0.0,260.6,2.04,197.0,91551.0 +2014-01-12 09:00:00+00:00,12.34,54.52,0.0,0.0,0.0,259.72,2.23,202.0,91548.0 +2014-01-12 10:00:00+00:00,11.99,54.43,0.0,0.0,0.0,258.83,2.41,206.0,91545.0 +2014-01-12 11:00:00+00:00,11.64,54.33,0.0,0.0,0.0,257.95,2.59,211.0,91542.0 +2014-01-12 12:00:00+00:00,11.1,54.29,0.0,0.0,0.0,256.42,2.53,213.0,91566.0 +2014-01-12 13:00:00+00:00,10.57,54.25,0.0,0.0,0.0,254.88,2.47,215.0,91590.0 +2014-01-12 14:00:00+00:00,10.04,54.21,0.0,0.0,0.0,253.35,2.41,217.0,91614.0 +2014-01-12 15:00:00+00:00,12.85,44.72,4.0,0.0,4.0,257.45,2.46,230.0,91656.0 +2014-01-12 16:00:00+00:00,15.67,35.23,224.0,538.02,74.0,261.55,2.51,243.0,91698.0 +2014-01-12 17:00:00+00:00,18.48,25.74,359.0,521.67,137.0,265.65,2.57,256.0,91740.0 +2014-01-12 18:00:00+00:00,19.53,23.81,403.0,322.65,232.0,267.07,3.13,264.0,91665.0 +2014-01-12 19:00:00+00:00,20.57,21.89,648.0,989.78,69.0,268.48,3.69,273.0,91590.0 +2014-01-12 20:00:00+00:00,21.61,19.96,653.0,995.27,69.0,269.9,4.25,282.0,91515.0 +2014-01-12 21:00:00+00:00,20.96,21.3,589.0,977.09,66.0,268.57,4.25,285.0,91548.0 +2014-01-12 22:00:00+00:00,20.3,22.64,464.0,928.7,61.0,267.23,4.26,289.0,91581.0 +2014-01-12 23:00:00+00:00,19.64,23.98,289.0,824.93,50.0,265.9,4.26,292.0,91614.0 +2014-01-13 00:00:00+00:00,17.27,30.4,94.0,554.57,30.0,263.27,3.37,294.0,91701.0 +2014-01-13 01:00:00+00:00,14.89,36.82,0.0,0.0,0.0,260.63,2.47,297.0,91788.0 +2014-01-13 02:00:00+00:00,12.51,43.24,0.0,0.0,0.0,258.0,1.57,299.0,91875.0 +2014-01-13 03:00:00+00:00,11.76,44.97,0.0,0.0,0.0,256.63,1.23,313.0,91929.0 +2014-01-13 04:00:00+00:00,11.01,46.69,0.0,0.0,0.0,255.27,0.89,327.0,91983.0 +2014-01-13 05:00:00+00:00,10.25,48.42,0.0,0.0,0.0,253.9,0.55,342.0,92037.0 +2014-01-13 06:00:00+00:00,9.64,49.13,0.0,0.0,0.0,252.1,0.92,358.0,92073.0 +2014-01-13 07:00:00+00:00,9.03,49.85,0.0,0.0,0.0,250.3,1.29,15.0,92109.0 +2014-01-13 08:00:00+00:00,8.42,50.56,0.0,0.0,0.0,248.5,1.66,31.0,92145.0 +2014-01-13 09:00:00+00:00,7.52,53.36,0.0,0.0,0.0,245.65,1.63,43.0,92191.0 +2014-01-13 10:00:00+00:00,6.61,56.17,0.0,0.0,0.0,242.8,1.61,55.0,92236.0 +2014-01-13 11:00:00+00:00,5.71,58.97,0.0,0.0,0.0,239.95,1.59,68.0,92281.0 +2014-01-13 12:00:00+00:00,5.44,62.27,0.0,0.0,0.0,237.87,1.73,71.0,92323.0 +2014-01-13 13:00:00+00:00,5.17,65.58,0.0,0.0,0.0,235.78,1.87,75.0,92365.0 +2014-01-13 14:00:00+00:00,4.9,68.88,0.0,0.0,0.0,233.7,2.01,79.0,92407.0 +2014-01-13 15:00:00+00:00,8.67,55.41,82.0,538.43,28.0,236.47,1.58,79.0,92440.0 +2014-01-13 16:00:00+00:00,12.43,41.93,284.0,836.46,50.0,239.23,1.15,80.0,92473.0 +2014-01-13 17:00:00+00:00,16.2,28.46,467.0,951.01,61.0,242.0,0.72,80.0,92506.0 +2014-01-13 18:00:00+00:00,17.6,23.66,601.0,1004.22,67.0,243.07,1.5,74.0,92410.0 +2014-01-13 19:00:00+00:00,19.0,18.87,673.0,1027.03,70.0,244.13,2.28,69.0,92314.0 +2014-01-13 20:00:00+00:00,20.4,14.07,676.0,1028.4,70.0,245.2,3.06,64.0,92218.0 +2014-01-13 21:00:00+00:00,20.04,13.93,610.0,1007.41,68.0,244.35,3.25,46.0,92218.0 +2014-01-13 22:00:00+00:00,19.68,13.8,481.0,959.09,62.0,243.5,3.44,28.0,92218.0 +2014-01-13 23:00:00+00:00,19.32,13.66,302.0,857.45,51.0,242.65,3.63,10.0,92218.0 +2014-01-14 00:00:00+00:00,16.96,18.4,101.0,591.09,31.0,242.27,2.58,4.0,92233.0 +2014-01-14 01:00:00+00:00,14.6,23.13,0.0,0.0,0.0,241.88,1.53,358.0,92248.0 +2014-01-14 02:00:00+00:00,12.23,27.87,0.0,0.0,0.0,241.5,0.48,352.0,92263.0 +2014-01-14 03:00:00+00:00,11.22,30.76,0.0,0.0,0.0,240.67,0.64,359.0,92284.0 +2014-01-14 04:00:00+00:00,10.21,33.65,0.0,0.0,0.0,239.83,0.8,5.0,92305.0 +2014-01-14 05:00:00+00:00,9.19,36.54,0.0,0.0,0.0,239.0,0.97,12.0,92326.0 +2014-01-14 06:00:00+00:00,8.58,38.48,0.0,0.0,0.0,237.48,1.13,20.0,92317.0 +2014-01-14 07:00:00+00:00,7.97,40.41,0.0,0.0,0.0,235.97,1.3,28.0,92308.0 +2014-01-14 08:00:00+00:00,7.35,42.35,0.0,0.0,0.0,234.45,1.46,36.0,92299.0 +2014-01-14 09:00:00+00:00,6.76,43.84,0.0,0.0,0.0,233.15,1.47,44.0,92302.0 +2014-01-14 10:00:00+00:00,6.16,45.33,0.0,0.0,0.0,231.85,1.48,52.0,92305.0 +2014-01-14 11:00:00+00:00,5.57,46.82,0.0,0.0,0.0,230.55,1.49,61.0,92308.0 +2014-01-14 12:00:00+00:00,5.25,47.78,0.0,0.0,0.0,229.45,1.36,63.0,92335.0 +2014-01-14 13:00:00+00:00,4.93,48.75,0.0,0.0,0.0,228.35,1.23,65.0,92362.0 +2014-01-14 14:00:00+00:00,4.61,49.71,0.0,0.0,0.0,227.25,1.1,67.0,92389.0 +2014-01-14 15:00:00+00:00,8.62,40.41,82.0,534.82,28.0,231.32,1.32,66.0,92419.0 +2014-01-14 16:00:00+00:00,12.64,31.12,282.0,826.21,50.0,235.38,1.54,65.0,92449.0 +2014-01-14 17:00:00+00:00,16.65,21.82,465.0,943.11,61.0,239.45,1.75,64.0,92479.0 +2014-01-14 18:00:00+00:00,18.21,19.6,599.0,996.97,67.0,241.37,2.1,65.0,92383.0 +2014-01-14 19:00:00+00:00,19.77,17.37,672.0,1021.42,70.0,243.28,2.45,65.0,92287.0 +2014-01-14 20:00:00+00:00,21.33,15.15,677.0,1025.61,70.0,245.2,2.8,66.0,92191.0 +2014-01-14 21:00:00+00:00,20.9,15.22,612.0,1005.83,68.0,244.48,2.97,66.0,92203.0 +2014-01-14 22:00:00+00:00,20.47,15.28,485.0,961.65,62.0,243.77,3.13,65.0,92215.0 +2014-01-14 23:00:00+00:00,20.04,15.35,307.0,865.48,51.0,243.05,3.3,65.0,92227.0 +2014-01-15 00:00:00+00:00,17.76,21.32,104.0,600.88,31.0,242.25,2.94,65.0,92239.0 +2014-01-15 01:00:00+00:00,15.47,27.28,0.0,0.0,0.0,241.45,2.59,64.0,92251.0 +2014-01-15 02:00:00+00:00,13.18,33.25,0.0,0.0,0.0,240.65,2.23,64.0,92263.0 +2014-01-15 03:00:00+00:00,12.39,36.34,0.0,0.0,0.0,240.15,1.97,69.0,92287.0 +2014-01-15 04:00:00+00:00,11.59,39.42,0.0,0.0,0.0,239.65,1.71,74.0,92311.0 +2014-01-15 05:00:00+00:00,10.79,42.51,0.0,0.0,0.0,239.15,1.45,79.0,92335.0 +2014-01-15 06:00:00+00:00,10.38,44.96,0.0,0.0,0.0,238.68,1.71,80.0,92338.0 +2014-01-15 07:00:00+00:00,9.96,47.4,0.0,0.0,0.0,238.22,1.98,80.0,92341.0 +2014-01-15 08:00:00+00:00,9.54,49.85,0.0,0.0,0.0,237.75,2.25,80.0,92344.0 +2014-01-15 09:00:00+00:00,8.83,51.57,0.0,0.0,0.0,236.45,2.24,76.0,92359.0 +2014-01-15 10:00:00+00:00,8.11,53.3,0.0,0.0,0.0,235.15,2.24,72.0,92374.0 +2014-01-15 11:00:00+00:00,7.4,55.02,0.0,0.0,0.0,233.85,2.23,68.0,92389.0 +2014-01-15 12:00:00+00:00,6.98,55.72,0.0,0.0,0.0,233.75,2.4,69.0,92389.0 +2014-01-15 13:00:00+00:00,6.56,56.43,0.0,0.0,0.0,233.65,2.56,70.0,92389.0 +2014-01-15 14:00:00+00:00,6.14,57.13,0.0,0.0,0.0,233.55,2.72,70.0,92389.0 +2014-01-15 15:00:00+00:00,10.31,46.13,83.0,540.59,28.0,236.83,2.6,69.0,92416.0 +2014-01-15 16:00:00+00:00,14.47,35.12,285.0,833.48,50.0,240.12,2.49,68.0,92443.0 +2014-01-15 17:00:00+00:00,18.64,24.12,468.0,946.68,61.0,243.4,2.37,68.0,92470.0 +2014-01-15 18:00:00+00:00,20.09,21.18,604.0,1002.66,67.0,245.18,2.5,67.0,92344.0 +2014-01-15 19:00:00+00:00,21.54,18.25,677.0,1025.84,70.0,246.97,2.62,66.0,92218.0 +2014-01-15 20:00:00+00:00,22.99,15.31,681.0,1027.75,70.0,248.75,2.74,65.0,92091.0 +2014-01-15 21:00:00+00:00,22.49,15.57,616.0,1007.8,68.0,248.17,2.64,61.0,92046.0 +2014-01-15 22:00:00+00:00,21.99,15.83,488.0,961.77,62.0,247.58,2.54,57.0,92001.0 +2014-01-15 23:00:00+00:00,21.48,16.09,310.0,863.14,52.0,247.0,2.44,53.0,91956.0 +2014-01-16 00:00:00+00:00,18.78,20.33,107.0,601.94,32.0,245.43,1.94,54.0,91950.0 +2014-01-16 01:00:00+00:00,16.07,24.58,0.0,0.0,0.0,243.87,1.43,55.0,91944.0 +2014-01-16 02:00:00+00:00,13.36,28.82,0.0,0.0,0.0,242.3,0.92,56.0,91938.0 +2014-01-16 03:00:00+00:00,12.28,31.96,0.0,0.0,0.0,241.27,0.92,64.0,91950.0 +2014-01-16 04:00:00+00:00,11.19,35.09,0.0,0.0,0.0,240.23,0.92,73.0,91962.0 +2014-01-16 05:00:00+00:00,10.1,38.23,0.0,0.0,0.0,239.2,0.92,81.0,91974.0 +2014-01-16 06:00:00+00:00,9.35,40.95,0.0,0.0,0.0,238.02,1.12,72.0,91956.0 +2014-01-16 07:00:00+00:00,8.6,43.66,0.0,0.0,0.0,236.83,1.32,64.0,91938.0 +2014-01-16 08:00:00+00:00,7.85,46.38,0.0,0.0,0.0,235.65,1.52,56.0,91920.0 +2014-01-16 09:00:00+00:00,7.28,47.61,0.0,0.0,0.0,235.08,1.46,54.0,91902.0 +2014-01-16 10:00:00+00:00,6.7,48.84,0.0,0.0,0.0,234.52,1.4,51.0,91884.0 +2014-01-16 11:00:00+00:00,6.13,50.07,0.0,0.0,0.0,233.95,1.34,49.0,91866.0 +2014-01-16 12:00:00+00:00,5.81,50.48,0.0,0.0,0.0,233.73,1.36,58.0,91896.0 +2014-01-16 13:00:00+00:00,5.49,50.9,0.0,0.0,0.0,233.52,1.37,68.0,91926.0 +2014-01-16 14:00:00+00:00,5.17,51.31,0.0,0.0,0.0,233.3,1.39,77.0,91956.0 +2014-01-16 15:00:00+00:00,9.73,41.3,83.0,536.01,28.0,238.4,1.06,74.0,91977.0 +2014-01-16 16:00:00+00:00,14.29,31.29,282.0,819.21,50.0,243.5,0.73,70.0,91998.0 +2014-01-16 17:00:00+00:00,18.85,21.28,464.0,933.79,61.0,248.6,0.4,66.0,92019.0 +2014-01-16 18:00:00+00:00,20.27,19.22,598.0,987.67,67.0,251.0,0.96,57.0,91899.0 +2014-01-16 19:00:00+00:00,21.68,17.17,671.0,1011.55,70.0,253.4,1.52,48.0,91779.0 +2014-01-16 20:00:00+00:00,23.09,15.11,675.0,1012.99,70.0,255.8,2.08,38.0,91659.0 +2014-01-16 21:00:00+00:00,22.61,14.61,611.0,994.99,67.0,255.65,2.62,38.0,91656.0 +2014-01-16 22:00:00+00:00,22.12,14.11,485.0,948.3,62.0,255.5,3.15,38.0,91653.0 +2014-01-16 23:00:00+00:00,21.63,13.61,308.0,850.77,51.0,255.35,3.68,37.0,91650.0 +2014-01-17 00:00:00+00:00,19.24,19.16,108.0,594.92,32.0,254.15,2.65,35.0,91677.0 +2014-01-17 01:00:00+00:00,16.85,24.7,0.0,0.0,0.0,252.95,1.61,33.0,91704.0 +2014-01-17 02:00:00+00:00,14.45,30.25,0.0,0.0,0.0,251.75,0.58,31.0,91731.0 +2014-01-17 03:00:00+00:00,13.45,32.18,0.0,0.0,0.0,251.25,0.79,43.0,91761.0 +2014-01-17 04:00:00+00:00,12.45,34.11,0.0,0.0,0.0,250.75,1.0,55.0,91791.0 +2014-01-17 05:00:00+00:00,11.45,36.04,0.0,0.0,0.0,250.25,1.21,67.0,91821.0 +2014-01-17 06:00:00+00:00,10.47,38.48,0.0,0.0,0.0,248.17,1.28,69.0,91833.0 +2014-01-17 07:00:00+00:00,9.48,40.93,0.0,0.0,0.0,246.08,1.34,72.0,91845.0 +2014-01-17 08:00:00+00:00,8.49,43.37,0.0,0.0,0.0,244.0,1.41,74.0,91857.0 +2014-01-17 09:00:00+00:00,7.76,45.29,0.0,0.0,0.0,242.03,1.64,74.0,91881.0 +2014-01-17 10:00:00+00:00,7.02,47.22,0.0,0.0,0.0,240.07,1.88,74.0,91905.0 +2014-01-17 11:00:00+00:00,6.28,49.14,0.0,0.0,0.0,238.1,2.11,73.0,91929.0 +2014-01-17 12:00:00+00:00,5.91,51.2,0.0,0.0,0.0,237.37,2.29,74.0,91953.0 +2014-01-17 13:00:00+00:00,5.54,53.26,0.0,0.0,0.0,236.63,2.46,75.0,91977.0 +2014-01-17 14:00:00+00:00,5.17,55.32,0.0,0.0,0.0,235.9,2.63,77.0,92001.0 +2014-01-17 15:00:00+00:00,9.79,44.03,85.0,550.31,28.0,239.75,3.01,75.0,92037.0 +2014-01-17 16:00:00+00:00,14.42,32.73,287.0,832.91,50.0,243.6,3.38,73.0,92073.0 +2014-01-17 17:00:00+00:00,19.04,21.44,470.0,943.86,61.0,247.45,3.75,71.0,92109.0 +2014-01-17 18:00:00+00:00,20.38,18.83,605.0,996.7,67.0,249.27,3.43,74.0,92001.0 +2014-01-17 19:00:00+00:00,21.72,16.23,679.0,1020.69,70.0,251.08,3.1,78.0,91893.0 +2014-01-17 20:00:00+00:00,23.06,13.62,683.0,1021.55,70.0,252.9,2.77,81.0,91785.0 +2014-01-17 21:00:00+00:00,22.59,13.85,619.0,1002.2,68.0,252.28,2.59,82.0,91749.0 +2014-01-17 22:00:00+00:00,22.12,14.08,491.0,954.92,62.0,251.67,2.4,83.0,91713.0 +2014-01-17 23:00:00+00:00,21.65,14.31,314.0,858.17,52.0,251.05,2.22,84.0,91677.0 +2014-01-18 00:00:00+00:00,19.46,18.55,112.0,603.33,33.0,250.72,1.96,83.0,91677.0 +2014-01-18 01:00:00+00:00,17.26,22.8,0.0,0.0,0.0,250.38,1.7,82.0,91677.0 +2014-01-18 02:00:00+00:00,15.06,27.04,0.0,0.0,0.0,250.05,1.43,81.0,91677.0 +2014-01-18 03:00:00+00:00,13.55,30.88,0.0,0.0,0.0,250.15,1.39,85.0,91698.0 +2014-01-18 04:00:00+00:00,12.04,34.73,0.0,0.0,0.0,250.25,1.34,90.0,91719.0 +2014-01-18 05:00:00+00:00,10.53,38.57,0.0,0.0,0.0,250.35,1.3,94.0,91740.0 +2014-01-18 06:00:00+00:00,9.73,40.47,0.0,0.0,0.0,249.2,1.43,93.0,91737.0 +2014-01-18 07:00:00+00:00,8.93,42.36,0.0,0.0,0.0,248.05,1.55,93.0,91734.0 +2014-01-18 08:00:00+00:00,8.13,44.26,0.0,0.0,0.0,246.9,1.68,92.0,91731.0 +2014-01-18 09:00:00+00:00,7.37,45.81,0.0,0.0,0.0,245.6,1.63,90.0,91737.0 +2014-01-18 10:00:00+00:00,6.6,47.37,0.0,0.0,0.0,244.3,1.58,87.0,91743.0 +2014-01-18 11:00:00+00:00,5.83,48.92,0.0,0.0,0.0,243.0,1.53,85.0,91749.0 +2014-01-18 12:00:00+00:00,5.68,49.63,0.0,0.0,0.0,241.5,1.78,86.0,91782.0 +2014-01-18 13:00:00+00:00,5.53,50.34,0.0,0.0,0.0,240.0,2.03,87.0,91815.0 +2014-01-18 14:00:00+00:00,5.39,51.05,0.0,0.0,0.0,238.5,2.28,88.0,91848.0 +2014-01-18 15:00:00+00:00,10.04,40.09,84.0,535.16,28.0,243.07,1.71,88.0,91887.0 +2014-01-18 16:00:00+00:00,14.69,29.12,284.0,818.2,50.0,247.63,1.15,89.0,91926.0 +2014-01-18 17:00:00+00:00,19.34,18.16,466.0,930.66,61.0,252.2,0.59,89.0,91965.0 +2014-01-18 18:00:00+00:00,20.63,16.07,600.0,983.35,67.0,253.83,1.11,84.0,91878.0 +2014-01-18 19:00:00+00:00,21.92,13.97,674.0,1007.92,70.0,255.47,1.63,79.0,91791.0 +2014-01-18 20:00:00+00:00,23.21,11.88,680.0,1011.66,70.0,257.1,2.15,74.0,91704.0 +2014-01-18 21:00:00+00:00,23.17,12.16,617.0,992.92,68.0,256.52,2.19,75.0,91686.0 +2014-01-18 22:00:00+00:00,23.12,12.45,492.0,950.27,62.0,255.93,2.23,77.0,91668.0 +2014-01-18 23:00:00+00:00,23.07,12.73,316.0,855.55,52.0,255.35,2.28,78.0,91650.0 +2014-01-19 00:00:00+00:00,20.53,17.9,115.0,611.18,33.0,254.28,2.17,82.0,91674.0 +2014-01-19 01:00:00+00:00,17.99,23.08,0.0,0.0,0.0,253.22,2.06,86.0,91698.0 +2014-01-19 02:00:00+00:00,15.45,28.25,0.0,0.0,0.0,252.15,1.96,89.0,91722.0 +2014-01-19 03:00:00+00:00,13.83,30.78,0.0,0.0,0.0,252.3,1.92,87.0,91767.0 +2014-01-19 04:00:00+00:00,12.21,33.3,0.0,0.0,0.0,252.45,1.88,84.0,91812.0 +2014-01-19 05:00:00+00:00,10.58,35.83,0.0,0.0,0.0,252.6,1.83,82.0,91857.0 +2014-01-19 06:00:00+00:00,9.69,36.93,0.0,0.0,0.0,251.45,2.04,81.0,91860.0 +2014-01-19 07:00:00+00:00,8.8,38.02,0.0,0.0,0.0,250.3,2.25,81.0,91863.0 +2014-01-19 08:00:00+00:00,7.91,39.12,0.0,0.0,0.0,249.15,2.46,80.0,91866.0 +2014-01-19 09:00:00+00:00,7.36,40.52,0.0,0.0,0.0,247.48,2.46,80.0,91884.0 +2014-01-19 10:00:00+00:00,6.8,41.91,0.0,0.0,0.0,245.82,2.46,80.0,91902.0 +2014-01-19 11:00:00+00:00,6.24,43.31,0.0,0.0,0.0,244.15,2.46,80.0,91920.0 +2014-01-19 12:00:00+00:00,6.56,42.82,0.0,0.0,0.0,247.52,2.59,80.0,91950.0 +2014-01-19 13:00:00+00:00,6.89,42.34,0.0,0.0,0.0,250.88,2.72,80.0,91980.0 +2014-01-19 14:00:00+00:00,7.22,41.85,0.0,0.0,0.0,254.25,2.86,80.0,92010.0 +2014-01-19 15:00:00+00:00,11.24,34.08,60.0,217.38,37.0,259.37,2.51,84.0,92034.0 +2014-01-19 16:00:00+00:00,15.25,26.31,178.0,222.58,114.0,264.48,2.17,87.0,92058.0 +2014-01-19 17:00:00+00:00,19.27,18.54,240.0,105.23,194.0,269.6,1.82,90.0,92082.0 +2014-01-19 18:00:00+00:00,20.82,16.3,329.0,130.43,258.0,272.32,1.6,113.0,91980.0 +2014-01-19 19:00:00+00:00,22.37,14.06,548.0,583.11,197.0,275.03,1.39,136.0,91878.0 +2014-01-19 20:00:00+00:00,23.92,11.82,553.0,582.56,200.0,277.75,1.17,158.0,91776.0 +2014-01-19 21:00:00+00:00,23.26,12.9,479.0,483.72,210.0,276.6,1.32,183.0,91743.0 +2014-01-19 22:00:00+00:00,22.6,13.99,372.0,445.36,169.0,275.45,1.47,208.0,91710.0 +2014-01-19 23:00:00+00:00,21.94,15.07,246.0,471.31,99.0,274.3,1.61,233.0,91677.0 +2014-01-20 00:00:00+00:00,21.36,16.44,116.0,603.94,33.0,271.18,1.31,201.0,91701.0 +2014-01-20 01:00:00+00:00,20.78,17.81,0.0,0.0,0.0,268.07,1.02,168.0,91725.0 +2014-01-20 02:00:00+00:00,20.2,19.18,0.0,0.0,0.0,264.95,0.72,136.0,91749.0 +2014-01-20 03:00:00+00:00,19.16,21.76,0.0,0.0,0.0,264.52,0.88,143.0,91770.0 +2014-01-20 04:00:00+00:00,18.12,24.34,0.0,0.0,0.0,264.08,1.05,151.0,91791.0 +2014-01-20 05:00:00+00:00,17.08,26.92,0.0,0.0,0.0,263.65,1.21,158.0,91812.0 +2014-01-20 06:00:00+00:00,15.98,30.72,0.0,0.0,0.0,262.42,1.52,164.0,91809.0 +2014-01-20 07:00:00+00:00,14.88,34.53,0.0,0.0,0.0,261.18,1.83,171.0,91806.0 +2014-01-20 08:00:00+00:00,13.77,38.33,0.0,0.0,0.0,259.95,2.14,178.0,91803.0 +2014-01-20 09:00:00+00:00,12.71,40.34,0.0,0.0,0.0,257.83,1.94,158.0,91812.0 +2014-01-20 10:00:00+00:00,11.64,42.34,0.0,0.0,0.0,255.72,1.73,139.0,91821.0 +2014-01-20 11:00:00+00:00,10.58,44.35,0.0,0.0,0.0,253.6,1.53,119.0,91830.0 +2014-01-20 12:00:00+00:00,9.58,45.4,0.0,0.0,0.0,252.0,1.52,107.0,91881.0 +2014-01-20 13:00:00+00:00,8.58,46.45,0.0,0.0,0.0,250.4,1.5,95.0,91932.0 +2014-01-20 14:00:00+00:00,7.59,47.5,0.0,0.0,0.0,248.8,1.49,83.0,91983.0 +2014-01-20 15:00:00+00:00,11.82,37.03,84.0,523.07,28.0,253.13,1.1,76.0,91995.0 +2014-01-20 16:00:00+00:00,16.06,26.57,283.0,805.73,50.0,257.47,0.71,68.0,92007.0 +2014-01-20 17:00:00+00:00,20.29,16.1,465.0,919.94,61.0,261.8,0.32,61.0,92019.0 +2014-01-20 18:00:00+00:00,21.45,14.45,601.0,976.62,67.0,262.67,1.05,30.0,91938.0 +2014-01-20 19:00:00+00:00,22.6,12.8,675.0,1000.48,70.0,263.53,1.78,358.0,91857.0 +2014-01-20 20:00:00+00:00,23.75,11.15,682.0,1003.28,71.0,264.4,2.51,327.0,91776.0 +2014-01-20 21:00:00+00:00,23.4,11.48,620.0,986.84,68.0,263.15,2.42,330.0,91770.0 +2014-01-20 22:00:00+00:00,23.04,11.82,495.0,943.0,62.0,261.9,2.33,333.0,91764.0 +2014-01-20 23:00:00+00:00,22.68,12.15,319.0,846.93,52.0,260.65,2.23,336.0,91758.0 +2014-01-21 00:00:00+00:00,20.22,16.19,119.0,604.0,34.0,259.7,1.96,355.0,91821.0 +2014-01-21 01:00:00+00:00,17.75,20.23,0.0,0.0,0.0,258.75,1.69,14.0,91884.0 +2014-01-21 02:00:00+00:00,15.28,24.27,0.0,0.0,0.0,257.8,1.42,33.0,91947.0 +2014-01-21 03:00:00+00:00,14.12,27.06,0.0,0.0,0.0,257.63,1.36,45.0,92004.0 +2014-01-21 04:00:00+00:00,12.96,29.85,0.0,0.0,0.0,257.47,1.29,58.0,92061.0 +2014-01-21 05:00:00+00:00,11.8,32.64,0.0,0.0,0.0,257.3,1.23,71.0,92118.0 +2014-01-21 06:00:00+00:00,10.93,34.31,0.0,0.0,0.0,255.68,1.37,71.0,92121.0 +2014-01-21 07:00:00+00:00,10.05,35.99,0.0,0.0,0.0,254.07,1.52,72.0,92124.0 +2014-01-21 08:00:00+00:00,9.17,37.66,0.0,0.0,0.0,252.45,1.67,72.0,92127.0 +2014-01-21 09:00:00+00:00,8.53,38.63,0.0,0.0,0.0,251.32,1.81,73.0,92115.0 +2014-01-21 10:00:00+00:00,7.88,39.61,0.0,0.0,0.0,250.18,1.95,74.0,92103.0 +2014-01-21 11:00:00+00:00,7.23,40.58,0.0,0.0,0.0,249.05,2.1,74.0,92091.0 +2014-01-21 12:00:00+00:00,7.2,40.57,0.0,0.0,0.0,248.37,2.58,75.0,92115.0 +2014-01-21 13:00:00+00:00,7.18,40.57,0.0,0.0,0.0,247.68,3.07,76.0,92139.0 +2014-01-21 14:00:00+00:00,7.16,40.56,0.0,0.0,0.0,247.0,3.56,77.0,92163.0 +2014-01-21 15:00:00+00:00,11.47,32.36,86.0,525.76,29.0,252.77,4.12,78.0,92191.0 +2014-01-21 16:00:00+00:00,15.79,24.17,287.0,814.67,50.0,258.53,4.68,80.0,92218.0 +2014-01-21 17:00:00+00:00,20.1,15.97,345.0,398.83,169.0,264.3,5.24,81.0,92245.0 +2014-01-21 18:00:00+00:00,21.38,14.03,435.0,364.1,235.0,268.08,5.18,86.0,92124.0 +2014-01-21 19:00:00+00:00,22.66,12.08,572.0,643.55,181.0,271.87,5.12,90.0,92004.0 +2014-01-21 20:00:00+00:00,23.94,10.14,549.0,547.27,214.0,275.65,5.06,95.0,91884.0 +2014-01-21 21:00:00+00:00,23.51,11.2,624.0,988.13,68.0,274.18,4.3,94.0,91839.0 +2014-01-21 22:00:00+00:00,23.08,12.25,312.0,222.66,209.0,272.72,3.54,93.0,91794.0 +2014-01-21 23:00:00+00:00,22.64,13.31,298.0,768.83,53.0,271.25,2.77,92.0,91749.0 +2014-01-22 00:00:00+00:00,21.35,16.65,51.0,6.94,50.0,283.55,2.48,89.0,91737.0 +2014-01-22 01:00:00+00:00,20.06,19.99,0.0,0.0,0.0,295.85,2.19,86.0,91725.0 +2014-01-22 02:00:00+00:00,18.76,23.33,0.0,0.0,0.0,308.15,1.9,82.0,91713.0 +2014-01-22 03:00:00+00:00,17.94,26.56,0.0,0.0,0.0,308.53,1.83,84.0,91731.0 +2014-01-22 04:00:00+00:00,17.11,29.79,0.0,0.0,0.0,308.92,1.75,86.0,91749.0 +2014-01-22 05:00:00+00:00,16.28,33.02,0.0,0.0,0.0,309.3,1.67,88.0,91767.0 +2014-01-22 06:00:00+00:00,16.06,33.82,0.0,0.0,0.0,307.73,1.77,93.0,91752.0 +2014-01-22 07:00:00+00:00,15.84,34.63,0.0,0.0,0.0,306.17,1.86,99.0,91737.0 +2014-01-22 08:00:00+00:00,15.61,35.43,0.0,0.0,0.0,304.6,1.96,105.0,91722.0 +2014-01-22 09:00:00+00:00,14.78,35.3,0.0,0.0,0.0,311.4,1.97,108.0,91674.0 +2014-01-22 10:00:00+00:00,13.94,35.17,0.0,0.0,0.0,318.2,1.98,111.0,91626.0 +2014-01-22 11:00:00+00:00,13.11,35.04,0.0,0.0,0.0,325.0,1.99,114.0,91578.0 +2014-01-22 12:00:00+00:00,12.89,36.78,0.0,0.0,0.0,322.98,2.03,123.0,91560.0 +2014-01-22 13:00:00+00:00,12.67,38.51,0.0,0.0,0.0,320.97,2.07,132.0,91542.0 +2014-01-22 14:00:00+00:00,12.45,40.25,0.0,0.0,0.0,318.95,2.11,141.0,91524.0 +2014-01-22 15:00:00+00:00,15.47,32.02,85.0,509.72,29.0,315.52,2.07,158.0,91503.0 +2014-01-22 16:00:00+00:00,18.5,23.79,211.0,375.75,101.0,312.08,2.04,176.0,91482.0 +2014-01-22 17:00:00+00:00,21.52,15.56,284.0,191.65,199.0,308.65,2.0,193.0,91461.0 +2014-01-22 18:00:00+00:00,22.46,13.96,535.0,741.08,126.0,307.72,2.63,212.0,91346.0 +2014-01-22 19:00:00+00:00,23.39,12.36,517.0,429.16,255.0,306.78,3.27,231.0,91232.0 +2014-01-22 20:00:00+00:00,24.32,10.76,506.0,383.54,270.0,305.85,3.9,250.0,91118.0 +2014-01-22 21:00:00+00:00,23.85,11.04,621.0,976.93,68.0,303.22,3.94,255.0,91094.0 +2014-01-22 22:00:00+00:00,23.38,11.31,497.0,933.38,62.0,300.58,3.98,260.0,91070.0 +2014-01-22 23:00:00+00:00,22.91,11.59,323.0,838.22,53.0,297.95,4.01,265.0,91046.0 +2014-01-23 00:00:00+00:00,21.17,14.58,123.0,603.73,34.0,303.22,2.77,265.0,91079.0 +2014-01-23 01:00:00+00:00,19.43,17.57,0.0,0.0,0.0,308.48,1.52,265.0,91112.0 +2014-01-23 02:00:00+00:00,17.68,20.56,0.0,0.0,0.0,313.75,0.28,265.0,91145.0 +2014-01-23 03:00:00+00:00,17.32,21.29,0.0,0.0,0.0,308.27,0.74,254.0,91169.0 +2014-01-23 04:00:00+00:00,16.96,22.03,0.0,0.0,0.0,302.78,1.2,243.0,91193.0 +2014-01-23 05:00:00+00:00,16.6,22.76,0.0,0.0,0.0,297.3,1.67,231.0,91217.0 +2014-01-23 06:00:00+00:00,15.49,27.12,0.0,0.0,0.0,292.9,1.85,226.0,91223.0 +2014-01-23 07:00:00+00:00,14.37,31.48,0.0,0.0,0.0,288.5,2.03,221.0,91229.0 +2014-01-23 08:00:00+00:00,13.25,35.84,0.0,0.0,0.0,284.1,2.21,217.0,91235.0 +2014-01-23 09:00:00+00:00,12.39,36.63,0.0,0.0,0.0,280.67,2.22,211.0,91253.0 +2014-01-23 10:00:00+00:00,11.53,37.42,0.0,0.0,0.0,277.23,2.23,206.0,91271.0 +2014-01-23 11:00:00+00:00,10.67,38.21,0.0,0.0,0.0,273.8,2.25,201.0,91289.0 +2014-01-23 12:00:00+00:00,10.02,39.96,0.0,0.0,0.0,272.48,2.11,192.0,91352.0 +2014-01-23 13:00:00+00:00,9.38,41.71,0.0,0.0,0.0,271.17,1.97,183.0,91416.0 +2014-01-23 14:00:00+00:00,8.74,43.46,0.0,0.0,0.0,269.85,1.83,174.0,91479.0 +2014-01-23 15:00:00+00:00,12.02,34.92,49.0,80.78,40.0,273.83,1.56,179.0,91512.0 +2014-01-23 16:00:00+00:00,15.3,26.37,182.0,217.19,118.0,277.82,1.28,184.0,91545.0 +2014-01-23 17:00:00+00:00,18.58,17.83,311.0,264.67,193.0,281.8,1.01,189.0,91578.0 +2014-01-23 18:00:00+00:00,19.76,15.94,460.0,425.54,224.0,284.08,1.24,199.0,91527.0 +2014-01-23 19:00:00+00:00,20.93,14.06,583.0,656.88,180.0,286.37,1.48,208.0,91476.0 +2014-01-23 20:00:00+00:00,22.1,12.17,553.0,551.25,212.0,288.65,1.71,218.0,91425.0 +2014-01-23 21:00:00+00:00,21.77,14.14,508.0,554.88,192.0,288.45,1.81,221.0,91431.0 +2014-01-23 22:00:00+00:00,21.44,16.11,358.0,347.13,195.0,288.25,1.9,223.0,91437.0 +2014-01-23 23:00:00+00:00,21.1,18.08,176.0,113.64,139.0,288.05,2.0,226.0,91443.0 +2014-01-24 00:00:00+00:00,20.25,18.46,101.0,344.82,49.0,292.02,1.89,190.0,91518.0 +2014-01-24 01:00:00+00:00,19.4,18.84,0.0,0.0,0.0,295.98,1.79,155.0,91593.0 +2014-01-24 02:00:00+00:00,18.55,19.22,0.0,0.0,0.0,299.95,1.68,119.0,91668.0 +2014-01-24 03:00:00+00:00,17.01,23.42,0.0,0.0,0.0,303.05,2.28,108.0,91740.0 +2014-01-24 04:00:00+00:00,15.47,27.61,0.0,0.0,0.0,306.15,2.88,97.0,91812.0 +2014-01-24 05:00:00+00:00,13.92,31.81,0.0,0.0,0.0,309.25,3.48,86.0,91884.0 +2014-01-24 06:00:00+00:00,13.38,32.46,0.0,0.0,0.0,305.57,3.83,83.0,91974.0 +2014-01-24 07:00:00+00:00,12.83,33.1,0.0,0.0,0.0,301.88,4.18,80.0,92064.0 +2014-01-24 08:00:00+00:00,12.28,33.75,0.0,0.0,0.0,298.2,4.54,78.0,92154.0 +2014-01-24 09:00:00+00:00,11.6,35.5,0.0,0.0,0.0,295.9,4.63,77.0,92236.0 +2014-01-24 10:00:00+00:00,10.92,37.24,0.0,0.0,0.0,293.6,4.71,77.0,92317.0 +2014-01-24 11:00:00+00:00,10.24,38.99,0.0,0.0,0.0,291.3,4.8,77.0,92398.0 +2014-01-24 12:00:00+00:00,9.92,40.05,0.0,0.0,0.0,287.65,4.82,78.0,92464.0 +2014-01-24 13:00:00+00:00,9.6,41.1,0.0,0.0,0.0,284.0,4.84,80.0,92530.0 +2014-01-24 14:00:00+00:00,9.29,42.16,0.0,0.0,0.0,280.35,4.86,82.0,92596.0 +2014-01-24 15:00:00+00:00,10.6,37.99,39.0,8.85,38.0,282.6,4.89,83.0,92581.0 +2014-01-24 16:00:00+00:00,11.9,33.83,125.0,33.7,115.0,284.85,4.93,84.0,92566.0 +2014-01-24 17:00:00+00:00,13.21,29.66,296.0,216.4,199.0,287.1,4.97,85.0,92551.0 +2014-01-24 18:00:00+00:00,14.47,27.33,597.0,950.92,67.0,296.9,4.49,87.0,92452.0 +2014-01-24 19:00:00+00:00,15.73,24.99,492.0,347.07,278.0,306.7,4.02,88.0,92353.0 +2014-01-24 20:00:00+00:00,16.99,22.66,451.0,241.19,301.0,316.5,3.54,90.0,92254.0 +2014-01-24 21:00:00+00:00,16.9,23.54,365.0,155.33,276.0,321.67,2.87,90.0,92224.0 +2014-01-24 22:00:00+00:00,16.81,24.43,319.0,221.93,214.0,326.83,2.2,90.0,92194.0 +2014-01-24 23:00:00+00:00,16.72,25.31,151.0,51.65,134.0,332.0,1.53,91.0,92163.0 +2014-01-25 00:00:00+00:00,16.41,31.05,51.0,0.0,51.0,334.5,1.58,93.0,92197.0 +2014-01-25 01:00:00+00:00,16.09,36.8,0.0,0.0,0.0,337.0,1.63,96.0,92230.0 +2014-01-25 02:00:00+00:00,15.77,42.54,0.0,0.0,0.0,339.5,1.68,98.0,92263.0 +2014-01-25 03:00:00+00:00,15.01,44.84,0.0,0.0,0.0,338.6,1.64,94.0,92263.0 +2014-01-25 04:00:00+00:00,14.24,47.15,0.0,0.0,0.0,337.7,1.6,89.0,92263.0 +2014-01-25 05:00:00+00:00,13.47,49.45,0.0,0.0,0.0,336.8,1.56,85.0,92263.0 +2014-01-25 06:00:00+00:00,12.87,51.73,0.0,0.0,0.0,335.4,1.56,81.0,92245.0 +2014-01-25 07:00:00+00:00,12.27,54.02,0.0,0.0,0.0,334.0,1.56,76.0,92227.0 +2014-01-25 08:00:00+00:00,11.66,56.3,0.0,0.0,0.0,332.6,1.56,72.0,92209.0 +2014-01-25 09:00:00+00:00,11.4,56.53,0.0,0.0,0.0,335.9,1.42,70.0,92206.0 +2014-01-25 10:00:00+00:00,11.14,56.77,0.0,0.0,0.0,339.2,1.28,68.0,92203.0 +2014-01-25 11:00:00+00:00,10.88,57.0,0.0,0.0,0.0,342.5,1.14,66.0,92200.0 +2014-01-25 12:00:00+00:00,11.01,58.04,0.0,0.0,0.0,330.42,1.27,73.0,92197.0 +2014-01-25 13:00:00+00:00,11.15,59.09,0.0,0.0,0.0,318.33,1.4,80.0,92194.0 +2014-01-25 14:00:00+00:00,11.29,60.13,0.0,0.0,0.0,306.25,1.53,87.0,92191.0 +2014-01-25 15:00:00+00:00,13.54,50.68,86.0,496.56,29.0,302.83,1.15,100.0,92157.0 +2014-01-25 16:00:00+00:00,15.78,41.24,279.0,766.35,50.0,299.42,0.78,114.0,92124.0 +2014-01-25 17:00:00+00:00,18.03,31.79,456.0,876.33,61.0,296.0,0.4,127.0,92091.0 +2014-01-25 18:00:00+00:00,19.25,30.96,588.0,930.01,67.0,298.25,1.18,175.0,91992.0 +2014-01-25 19:00:00+00:00,20.46,30.14,661.0,953.6,70.0,300.5,1.95,222.0,91893.0 +2014-01-25 20:00:00+00:00,21.67,29.31,669.0,957.9,70.0,302.75,2.73,269.0,91794.0 +2014-01-25 21:00:00+00:00,21.48,29.16,610.0,940.09,68.0,306.1,3.07,276.0,91758.0 +2014-01-25 22:00:00+00:00,21.28,29.02,253.0,83.91,213.0,309.45,3.41,283.0,91722.0 +2014-01-25 23:00:00+00:00,21.08,28.87,321.0,805.59,53.0,312.8,3.75,290.0,91686.0 +2014-01-26 00:00:00+00:00,19.32,35.32,127.0,583.57,35.0,309.4,3.17,294.0,91722.0 +2014-01-26 01:00:00+00:00,17.55,41.78,0.0,0.0,0.0,306.0,2.59,298.0,91758.0 +2014-01-26 02:00:00+00:00,15.78,48.23,0.0,0.0,0.0,302.6,2.01,302.0,91794.0 +2014-01-26 03:00:00+00:00,15.54,46.02,0.0,0.0,0.0,300.45,1.6,299.0,91791.0 +2014-01-26 04:00:00+00:00,15.3,43.81,0.0,0.0,0.0,298.3,1.18,296.0,91788.0 +2014-01-26 05:00:00+00:00,15.06,41.6,0.0,0.0,0.0,296.15,0.76,293.0,91785.0 +2014-01-26 06:00:00+00:00,14.68,43.69,0.0,0.0,0.0,292.15,1.01,288.0,91773.0 +2014-01-26 07:00:00+00:00,14.3,45.78,0.0,0.0,0.0,288.15,1.26,283.0,91761.0 +2014-01-26 08:00:00+00:00,13.91,47.87,0.0,0.0,0.0,284.15,1.52,278.0,91749.0 +2014-01-26 09:00:00+00:00,13.1,47.36,0.0,0.0,0.0,282.12,1.29,283.0,91740.0 +2014-01-26 10:00:00+00:00,12.29,46.84,0.0,0.0,0.0,280.08,1.06,287.0,91731.0 +2014-01-26 11:00:00+00:00,11.48,46.33,0.0,0.0,0.0,278.05,0.83,292.0,91722.0 +2014-01-26 12:00:00+00:00,11.08,48.03,0.0,0.0,0.0,276.9,0.87,307.0,91743.0 +2014-01-26 13:00:00+00:00,10.69,49.72,0.0,0.0,0.0,275.75,0.92,323.0,91764.0 +2014-01-26 14:00:00+00:00,10.3,51.42,0.0,0.0,0.0,274.6,0.97,338.0,91785.0 +2014-01-26 15:00:00+00:00,12.76,43.05,89.0,505.92,30.0,278.15,1.08,327.0,91779.0 +2014-01-26 16:00:00+00:00,15.22,34.68,287.0,787.3,50.0,281.7,1.19,316.0,91773.0 +2014-01-26 17:00:00+00:00,17.68,26.31,467.0,895.6,61.0,285.25,1.3,304.0,91767.0 +2014-01-26 18:00:00+00:00,18.84,23.6,601.0,946.47,68.0,286.45,1.77,301.0,91665.0 +2014-01-26 19:00:00+00:00,20.0,20.88,676.0,971.13,71.0,287.65,2.24,298.0,91563.0 +2014-01-26 20:00:00+00:00,21.15,18.17,682.0,971.72,71.0,288.85,2.72,295.0,91461.0 +2014-01-26 21:00:00+00:00,20.92,19.12,621.0,953.22,68.0,287.85,2.77,295.0,91416.0 +2014-01-26 22:00:00+00:00,20.69,20.07,500.0,909.73,63.0,286.85,2.83,295.0,91370.0 +2014-01-26 23:00:00+00:00,20.46,21.02,329.0,820.79,53.0,285.85,2.88,295.0,91325.0 +2014-01-27 00:00:00+00:00,18.47,25.84,132.0,595.87,36.0,283.32,2.32,295.0,91364.0 +2014-01-27 01:00:00+00:00,16.47,30.66,0.0,0.0,0.0,280.78,1.76,295.0,91403.0 +2014-01-27 02:00:00+00:00,14.47,35.48,0.0,0.0,0.0,278.25,1.2,295.0,91443.0 +2014-01-27 03:00:00+00:00,14.26,33.66,0.0,0.0,0.0,278.08,1.26,295.0,91464.0 +2014-01-27 04:00:00+00:00,14.05,31.83,0.0,0.0,0.0,277.92,1.33,295.0,91485.0 +2014-01-27 05:00:00+00:00,13.83,30.01,0.0,0.0,0.0,277.75,1.39,294.0,91506.0 +2014-01-27 06:00:00+00:00,13.81,31.2,0.0,0.0,0.0,282.83,1.55,293.0,91482.0 +2014-01-27 07:00:00+00:00,13.78,32.39,0.0,0.0,0.0,287.92,1.71,291.0,91458.0 +2014-01-27 08:00:00+00:00,13.75,33.58,0.0,0.0,0.0,293.0,1.88,290.0,91434.0 +2014-01-27 09:00:00+00:00,13.2,34.06,0.0,0.0,0.0,292.95,1.64,298.0,91440.0 +2014-01-27 10:00:00+00:00,12.64,34.53,0.0,0.0,0.0,292.9,1.4,306.0,91446.0 +2014-01-27 11:00:00+00:00,12.09,35.01,0.0,0.0,0.0,292.85,1.16,313.0,91452.0 +2014-01-27 12:00:00+00:00,11.94,35.5,0.0,0.0,0.0,290.7,1.0,314.0,91494.0 +2014-01-27 13:00:00+00:00,11.79,35.99,0.0,0.0,0.0,288.55,0.84,314.0,91536.0 +2014-01-27 14:00:00+00:00,11.65,36.48,0.0,0.0,0.0,286.4,0.68,314.0,91578.0 +2014-01-27 15:00:00+00:00,13.68,30.85,91.0,514.58,30.0,286.3,0.75,317.0,91572.0 +2014-01-27 16:00:00+00:00,15.71,25.21,143.0,65.94,123.0,286.2,0.82,320.0,91566.0 +2014-01-27 17:00:00+00:00,17.74,19.58,469.0,894.74,61.0,286.1,0.9,323.0,91560.0 +2014-01-27 18:00:00+00:00,18.75,19.15,602.0,943.2,68.0,284.53,1.72,305.0,91482.0 +2014-01-27 19:00:00+00:00,19.75,18.72,675.0,964.41,71.0,282.97,2.55,287.0,91403.0 +2014-01-27 20:00:00+00:00,20.75,18.29,682.0,966.31,71.0,281.4,3.38,268.0,91325.0 +2014-01-27 21:00:00+00:00,20.54,19.06,622.0,947.26,69.0,280.13,3.77,275.0,91316.0 +2014-01-27 22:00:00+00:00,20.33,19.83,502.0,906.94,63.0,278.87,4.17,282.0,91307.0 +2014-01-27 23:00:00+00:00,20.12,20.6,332.0,817.94,54.0,277.6,4.57,288.0,91298.0 +2014-01-28 00:00:00+00:00,18.3,23.91,136.0,607.59,36.0,276.82,3.66,297.0,91355.0 +2014-01-28 01:00:00+00:00,16.47,27.21,0.0,0.0,0.0,276.03,2.75,306.0,91413.0 +2014-01-28 02:00:00+00:00,14.64,30.52,0.0,0.0,0.0,275.25,1.85,315.0,91470.0 +2014-01-28 03:00:00+00:00,14.11,28.85,0.0,0.0,0.0,274.62,1.55,319.0,91506.0 +2014-01-28 04:00:00+00:00,13.58,27.19,0.0,0.0,0.0,273.98,1.25,323.0,91542.0 +2014-01-28 05:00:00+00:00,13.05,25.52,0.0,0.0,0.0,273.35,0.95,327.0,91578.0 +2014-01-28 06:00:00+00:00,12.4,25.34,0.0,0.0,0.0,269.12,1.09,334.0,91581.0 +2014-01-28 07:00:00+00:00,11.75,25.15,0.0,0.0,0.0,264.88,1.22,341.0,91584.0 +2014-01-28 08:00:00+00:00,11.09,24.97,0.0,0.0,0.0,260.65,1.35,348.0,91587.0 +2014-01-28 09:00:00+00:00,10.58,26.22,0.0,0.0,0.0,258.68,1.31,354.0,91596.0 +2014-01-28 10:00:00+00:00,10.06,27.47,0.0,0.0,0.0,256.72,1.26,360.0,91605.0 +2014-01-28 11:00:00+00:00,9.55,28.72,0.0,0.0,0.0,254.75,1.21,6.0,91614.0 +2014-01-28 12:00:00+00:00,8.65,36.16,0.0,0.0,0.0,253.67,1.17,24.0,91656.0 +2014-01-28 13:00:00+00:00,7.75,43.6,0.0,0.0,0.0,252.58,1.13,42.0,91698.0 +2014-01-28 14:00:00+00:00,6.86,51.04,0.0,0.0,0.0,251.5,1.09,61.0,91740.0 +2014-01-28 15:00:00+00:00,10.34,39.97,98.0,555.73,31.0,255.02,1.07,61.0,91764.0 +2014-01-28 16:00:00+00:00,13.81,28.9,304.0,824.29,52.0,258.53,1.04,61.0,91788.0 +2014-01-28 17:00:00+00:00,17.29,17.83,489.0,928.6,63.0,262.05,1.02,61.0,91812.0 +2014-01-28 18:00:00+00:00,18.58,15.59,626.0,978.49,69.0,262.83,1.54,48.0,91728.0 +2014-01-28 19:00:00+00:00,19.86,13.36,702.0,1000.54,72.0,263.62,2.07,35.0,91644.0 +2014-01-28 20:00:00+00:00,21.14,11.12,709.0,1001.76,72.0,264.4,2.59,22.0,91560.0 +2014-01-28 21:00:00+00:00,21.09,11.24,647.0,982.16,70.0,263.82,2.95,11.0,91536.0 +2014-01-28 22:00:00+00:00,21.03,11.35,523.0,941.03,64.0,263.23,3.31,1.0,91512.0 +2014-01-28 23:00:00+00:00,20.97,11.47,265.0,425.01,119.0,262.65,3.67,350.0,91488.0 +2014-01-29 00:00:00+00:00,18.54,15.44,145.0,642.56,37.0,259.65,2.95,351.0,91530.0 +2014-01-29 01:00:00+00:00,16.11,19.4,0.0,0.0,0.0,256.65,2.23,353.0,91572.0 +2014-01-29 02:00:00+00:00,13.67,23.37,0.0,0.0,0.0,253.65,1.5,354.0,91614.0 +2014-01-29 03:00:00+00:00,13.04,24.82,0.0,0.0,0.0,253.23,1.33,4.0,91644.0 +2014-01-29 04:00:00+00:00,12.41,26.26,0.0,0.0,0.0,252.82,1.15,14.0,91674.0 +2014-01-29 05:00:00+00:00,11.77,27.71,0.0,0.0,0.0,252.4,0.98,24.0,91704.0 +2014-01-29 06:00:00+00:00,10.97,30.39,0.0,0.0,0.0,250.88,0.97,38.0,91695.0 +2014-01-29 07:00:00+00:00,10.17,33.08,0.0,0.0,0.0,249.37,0.96,52.0,91686.0 +2014-01-29 08:00:00+00:00,9.37,35.76,0.0,0.0,0.0,247.85,0.95,66.0,91677.0 +2014-01-29 09:00:00+00:00,8.44,38.06,0.0,0.0,0.0,246.73,1.08,71.0,91668.0 +2014-01-29 10:00:00+00:00,7.51,40.37,0.0,0.0,0.0,245.62,1.21,76.0,91659.0 +2014-01-29 11:00:00+00:00,6.58,42.67,0.0,0.0,0.0,244.5,1.34,81.0,91650.0 +2014-01-29 12:00:00+00:00,6.36,43.33,0.0,0.0,0.0,242.77,1.46,82.0,91683.0 +2014-01-29 13:00:00+00:00,6.15,43.99,0.0,0.0,0.0,241.03,1.59,83.0,91716.0 +2014-01-29 14:00:00+00:00,5.94,44.65,0.0,0.0,0.0,239.3,1.71,84.0,91749.0 +2014-01-29 15:00:00+00:00,10.15,35.5,100.0,562.48,31.0,243.75,1.4,86.0,91758.0 +2014-01-29 16:00:00+00:00,14.37,26.34,306.0,824.15,52.0,248.2,1.09,88.0,91767.0 +2014-01-29 17:00:00+00:00,18.58,17.19,491.0,927.22,63.0,252.65,0.77,90.0,91776.0 +2014-01-29 18:00:00+00:00,19.93,15.81,629.0,978.32,69.0,255.38,1.37,147.0,91665.0 +2014-01-29 19:00:00+00:00,21.27,14.43,705.0,999.85,72.0,258.12,1.96,204.0,91554.0 +2014-01-29 20:00:00+00:00,22.61,13.05,713.0,1002.33,72.0,260.85,2.55,262.0,91443.0 +2014-01-29 21:00:00+00:00,22.63,12.96,652.0,984.41,70.0,260.68,2.5,268.0,91403.0 +2014-01-29 22:00:00+00:00,22.64,12.88,528.0,941.99,65.0,260.52,2.45,275.0,91364.0 +2014-01-29 23:00:00+00:00,22.65,12.79,352.0,855.44,55.0,260.35,2.4,282.0,91325.0 +2014-01-30 00:00:00+00:00,21.68,14.84,148.0,641.07,38.0,260.77,1.99,276.0,91343.0 +2014-01-30 01:00:00+00:00,20.71,16.89,0.0,0.0,0.0,261.18,1.58,270.0,91361.0 +2014-01-30 02:00:00+00:00,19.73,18.94,0.0,0.0,0.0,261.6,1.17,264.0,91379.0 +2014-01-30 03:00:00+00:00,18.89,19.92,0.0,0.0,0.0,262.37,1.29,249.0,91388.0 +2014-01-30 04:00:00+00:00,18.05,20.9,0.0,0.0,0.0,263.13,1.41,233.0,91397.0 +2014-01-30 05:00:00+00:00,17.21,21.88,0.0,0.0,0.0,263.9,1.53,217.0,91406.0 +2014-01-30 06:00:00+00:00,15.65,26.61,0.0,0.0,0.0,263.07,1.66,215.0,91382.0 +2014-01-30 07:00:00+00:00,14.08,31.34,0.0,0.0,0.0,262.23,1.8,213.0,91358.0 +2014-01-30 08:00:00+00:00,12.51,36.07,0.0,0.0,0.0,261.4,1.93,212.0,91334.0 +2014-01-30 09:00:00+00:00,11.83,35.9,0.0,0.0,0.0,260.4,2.18,210.0,91316.0 +2014-01-30 10:00:00+00:00,11.15,35.72,0.0,0.0,0.0,259.4,2.44,208.0,91298.0 +2014-01-30 11:00:00+00:00,10.47,35.55,0.0,0.0,0.0,258.4,2.69,206.0,91280.0 +2014-01-30 12:00:00+00:00,10.13,33.96,0.0,0.0,0.0,257.07,2.77,201.0,91298.0 +2014-01-30 13:00:00+00:00,9.8,32.37,0.0,0.0,0.0,255.73,2.85,196.0,91316.0 +2014-01-30 14:00:00+00:00,9.47,30.78,0.0,0.0,0.0,254.4,2.92,192.0,91334.0 +2014-01-30 15:00:00+00:00,13.2,25.01,91.0,440.44,36.0,259.3,3.63,199.0,91340.0 +2014-01-30 16:00:00+00:00,16.92,19.24,250.0,514.86,90.0,264.2,4.33,206.0,91346.0 +2014-01-30 17:00:00+00:00,20.65,13.47,319.0,243.26,206.0,269.1,5.03,213.0,91352.0 +2014-01-30 18:00:00+00:00,21.82,12.82,513.0,554.16,194.0,270.63,5.67,219.0,91247.0 +2014-01-30 19:00:00+00:00,22.98,12.16,699.0,984.93,72.0,272.17,6.3,225.0,91142.0 +2014-01-30 20:00:00+00:00,24.14,11.51,706.0,985.7,72.0,273.7,6.94,232.0,91037.0 +2014-01-30 21:00:00+00:00,23.6,12.66,645.0,966.39,70.0,274.07,6.63,232.0,90989.0 +2014-01-30 22:00:00+00:00,23.05,13.8,522.0,924.7,64.0,274.43,6.31,232.0,90941.0 +2014-01-30 23:00:00+00:00,22.5,14.95,237.0,267.9,143.0,274.8,6.0,233.0,90893.0 +2014-01-31 00:00:00+00:00,20.82,19.73,112.0,314.09,57.0,273.32,5.98,231.0,90932.0 +2014-01-31 01:00:00+00:00,19.14,24.52,0.0,0.0,0.0,271.83,5.96,229.0,90971.0 +2014-01-31 02:00:00+00:00,17.46,29.3,0.0,0.0,0.0,270.35,5.94,227.0,91010.0 +2014-01-31 03:00:00+00:00,16.77,31.03,0.0,0.0,0.0,268.63,6.2,222.0,91037.0 +2014-01-31 04:00:00+00:00,16.08,32.76,0.0,0.0,0.0,266.92,6.46,217.0,91064.0 +2014-01-31 05:00:00+00:00,15.39,34.49,0.0,0.0,0.0,265.2,6.72,211.0,91091.0 +2014-01-31 06:00:00+00:00,15.0,35.53,0.0,0.0,0.0,263.7,6.55,209.0,91079.0 +2014-01-31 07:00:00+00:00,14.61,36.56,0.0,0.0,0.0,262.2,6.38,207.0,91067.0 +2014-01-31 08:00:00+00:00,14.21,37.6,0.0,0.0,0.0,260.7,6.21,204.0,91055.0 +2014-01-31 09:00:00+00:00,13.83,39.62,0.0,0.0,0.0,260.75,6.11,205.0,91058.0 +2014-01-31 10:00:00+00:00,13.44,41.63,0.0,0.0,0.0,260.8,6.02,206.0,91061.0 +2014-01-31 11:00:00+00:00,13.05,43.65,0.0,0.0,0.0,260.85,5.93,207.0,91064.0 +2014-01-31 12:00:00+00:00,13.33,48.51,0.0,0.0,0.0,264.35,5.8,208.0,91070.0 +2014-01-31 13:00:00+00:00,13.62,53.36,0.0,0.0,0.0,267.85,5.67,209.0,91076.0 +2014-01-31 14:00:00+00:00,13.91,58.22,0.0,0.0,0.0,271.35,5.54,210.0,91082.0 +2014-01-31 15:00:00+00:00,15.23,56.36,52.0,47.18,46.0,274.33,6.23,213.0,91109.0 +2014-01-31 16:00:00+00:00,20.29,51.59,147.0,60.62,128.0,289.08,8.94,216.0,91136.0 +2014-01-31 17:00:00+00:00,19.64,51.99,294.0,171.12,214.0,286.22,8.47,219.0,91163.0 +2014-01-31 18:00:00+00:00,19.0,52.38,429.0,274.63,270.0,283.37,8.0,224.0,91118.0 +2014-01-31 19:00:00+00:00,18.35,52.77,516.0,348.35,293.0,280.51,7.53,229.0,91073.0 +2014-01-31 20:00:00+00:00,17.7,53.17,559.0,451.36,267.0,277.65,7.06,234.0,91028.0 +2014-01-31 21:00:00+00:00,17.05,53.56,432.0,242.14,287.0,274.8,6.59,236.0,91004.0 +2014-01-31 22:00:00+00:00,16.41,53.95,379.0,330.59,214.0,271.94,6.12,237.0,90980.0 +2014-01-31 23:00:00+00:00,15.76,54.35,181.0,84.6,151.0,269.09,5.65,239.0,90956.0 +2006-02-01 00:00:00+00:00,15.11,54.74,155.0,643.73,40.0,266.23,5.18,281.0,91250.0 +2006-02-01 01:00:00+00:00,14.46,55.13,0.0,0.0,0.0,263.38,4.71,291.0,91337.0 +2006-02-01 02:00:00+00:00,13.82,55.52,0.0,0.0,0.0,260.52,4.24,301.0,91425.0 +2006-02-01 03:00:00+00:00,13.17,55.92,0.0,0.0,0.0,257.67,3.77,303.0,91470.0 +2006-02-01 04:00:00+00:00,12.52,56.31,0.0,0.0,0.0,254.81,3.3,305.0,91515.0 +2006-02-01 05:00:00+00:00,11.88,56.7,0.0,0.0,0.0,251.96,2.83,308.0,91560.0 +2006-02-01 06:00:00+00:00,11.23,57.1,0.0,0.0,0.0,249.1,2.36,310.0,91584.0 +2006-02-01 07:00:00+00:00,10.58,57.49,0.0,0.0,0.0,246.24,1.89,313.0,91608.0 +2006-02-01 08:00:00+00:00,9.52,60.71,0.0,0.0,0.0,245.0,1.56,316.0,91632.0 +2006-02-01 09:00:00+00:00,9.22,64.56,0.0,0.0,0.0,244.27,1.25,309.0,91620.0 +2006-02-01 10:00:00+00:00,8.92,68.41,0.0,0.0,0.0,243.53,0.94,301.0,91608.0 +2006-02-01 11:00:00+00:00,8.61,72.26,0.0,0.0,0.0,242.8,0.63,293.0,91596.0 +2006-02-01 12:00:00+00:00,8.2,73.8,0.0,0.0,0.0,242.43,0.61,269.0,91620.0 +2006-02-01 13:00:00+00:00,7.79,75.33,0.0,0.0,0.0,242.07,0.58,244.0,91644.0 +2006-02-01 14:00:00+00:00,7.38,76.87,0.0,0.0,0.0,241.7,0.55,220.0,91668.0 +2006-02-01 15:00:00+00:00,10.29,63.99,105.0,555.77,33.0,246.32,0.92,236.0,91683.0 +2006-02-01 16:00:00+00:00,13.2,51.1,158.0,85.4,131.0,250.93,1.29,253.0,91698.0 +2006-02-01 17:00:00+00:00,16.11,38.22,356.0,342.12,195.0,255.55,1.66,270.0,91713.0 +2006-02-01 18:00:00+00:00,17.41,33.64,480.0,405.26,244.0,258.5,2.38,273.0,91632.0 +2006-02-01 19:00:00+00:00,18.72,29.05,535.0,389.89,284.0,261.45,3.11,277.0,91551.0 +2006-02-01 20:00:00+00:00,20.02,24.47,605.0,593.2,219.0,264.4,3.83,281.0,91470.0 +2006-02-01 21:00:00+00:00,19.9,23.83,662.0,977.31,73.0,264.6,4.09,284.0,91428.0 +2006-02-01 22:00:00+00:00,19.78,23.19,539.0,938.47,67.0,264.8,4.34,287.0,91385.0 +2006-02-01 23:00:00+00:00,19.66,22.55,363.0,853.99,57.0,265.0,4.59,289.0,91343.0 +2006-02-02 00:00:00+00:00,17.65,27.48,158.0,647.68,40.0,261.72,3.82,289.0,91361.0 +2006-02-02 01:00:00+00:00,15.64,32.4,0.0,0.0,0.0,258.43,3.04,289.0,91379.0 +2006-02-02 02:00:00+00:00,13.62,37.33,0.0,0.0,0.0,255.15,2.26,289.0,91397.0 +2006-02-02 03:00:00+00:00,12.82,37.07,0.0,0.0,0.0,254.68,2.11,295.0,91437.0 +2006-02-02 04:00:00+00:00,12.01,36.81,0.0,0.0,0.0,254.22,1.96,301.0,91476.0 +2006-02-02 05:00:00+00:00,11.21,36.55,0.0,0.0,0.0,253.75,1.81,308.0,91515.0 +2006-02-02 06:00:00+00:00,10.67,38.69,0.0,0.0,0.0,252.37,1.42,323.0,91512.0 +2006-02-02 07:00:00+00:00,10.14,40.82,0.0,0.0,0.0,250.98,1.03,338.0,91509.0 +2006-02-02 08:00:00+00:00,9.6,42.96,0.0,0.0,0.0,249.6,0.65,353.0,91506.0 +2006-02-02 09:00:00+00:00,8.75,45.74,0.0,0.0,0.0,248.3,0.62,12.0,91503.0 +2006-02-02 10:00:00+00:00,7.9,48.53,0.0,0.0,0.0,247.0,0.58,31.0,91500.0 +2006-02-02 11:00:00+00:00,7.05,51.31,0.0,0.0,0.0,245.7,0.55,49.0,91497.0 +2006-02-02 12:00:00+00:00,6.84,52.6,0.0,0.0,0.0,244.83,0.58,62.0,91503.0 +2006-02-02 13:00:00+00:00,6.63,53.88,0.0,0.0,0.0,243.97,0.61,75.0,91509.0 +2006-02-02 14:00:00+00:00,6.43,55.17,0.0,0.0,0.0,243.1,0.63,88.0,91515.0 +2006-02-02 15:00:00+00:00,10.25,44.94,109.0,568.08,34.0,247.68,0.64,40.0,91518.0 +2006-02-02 16:00:00+00:00,14.07,34.7,215.0,285.28,124.0,252.27,0.64,351.0,91521.0 +2006-02-02 17:00:00+00:00,17.89,24.47,503.0,924.53,65.0,256.85,0.65,302.0,91524.0 +2006-02-02 18:00:00+00:00,19.46,21.79,641.0,971.34,72.0,258.95,1.46,293.0,91413.0 +2006-02-02 19:00:00+00:00,21.04,19.1,719.0,994.67,75.0,261.05,2.27,284.0,91301.0 +2006-02-02 20:00:00+00:00,22.61,16.42,729.0,999.18,75.0,263.15,3.08,274.0,91190.0 +2006-02-02 21:00:00+00:00,22.32,17.05,668.0,980.93,73.0,263.63,3.65,279.0,91157.0 +2006-02-02 22:00:00+00:00,22.03,17.68,544.0,941.18,67.0,264.12,4.22,283.0,91124.0 +2006-02-02 23:00:00+00:00,21.73,18.31,368.0,856.2,58.0,264.6,4.79,287.0,91091.0 +2006-02-03 00:00:00+00:00,19.47,23.08,162.0,651.44,41.0,263.83,4.1,291.0,91145.0 +2006-02-03 01:00:00+00:00,17.21,27.84,0.0,0.0,0.0,263.07,3.42,295.0,91199.0 +2006-02-03 02:00:00+00:00,14.94,32.61,0.0,0.0,0.0,262.3,2.73,299.0,91253.0 +2006-02-03 03:00:00+00:00,14.18,32.2,0.0,0.0,0.0,261.1,2.46,306.0,91298.0 +2006-02-03 04:00:00+00:00,13.41,31.79,0.0,0.0,0.0,259.9,2.19,312.0,91343.0 +2006-02-03 05:00:00+00:00,12.65,31.38,0.0,0.0,0.0,258.7,1.92,319.0,91388.0 +2006-02-03 06:00:00+00:00,12.15,32.24,0.0,0.0,0.0,257.7,1.96,328.0,91410.0 +2006-02-03 07:00:00+00:00,11.65,33.09,0.0,0.0,0.0,256.7,2.01,336.0,91431.0 +2006-02-03 08:00:00+00:00,11.15,33.95,0.0,0.0,0.0,255.7,2.06,345.0,91452.0 +2006-02-03 09:00:00+00:00,10.53,37.01,0.0,0.0,0.0,255.9,2.12,352.0,91470.0 +2006-02-03 10:00:00+00:00,9.91,40.08,0.0,0.0,0.0,256.1,2.19,360.0,91488.0 +2006-02-03 11:00:00+00:00,9.28,43.14,0.0,0.0,0.0,256.3,2.26,7.0,91506.0 +2006-02-03 12:00:00+00:00,9.2,46.17,0.0,0.0,0.0,255.73,2.19,11.0,91542.0 +2006-02-03 13:00:00+00:00,9.11,49.21,0.0,0.0,0.0,255.17,2.11,16.0,91578.0 +2006-02-03 14:00:00+00:00,9.03,52.24,0.0,0.0,0.0,254.6,2.04,21.0,91614.0 +2006-02-03 15:00:00+00:00,12.49,42.95,111.0,572.13,34.0,257.87,1.97,28.0,91641.0 +2006-02-03 16:00:00+00:00,15.95,33.65,319.0,820.15,55.0,261.13,1.89,34.0,91668.0 +2006-02-03 17:00:00+00:00,19.42,24.36,508.0,926.65,66.0,264.4,1.82,41.0,91695.0 +2006-02-03 18:00:00+00:00,20.87,22.53,649.0,979.12,72.0,265.97,1.99,35.0,91635.0 +2006-02-03 19:00:00+00:00,22.32,20.69,729.0,1004.33,75.0,267.53,2.16,28.0,91575.0 +2006-02-03 20:00:00+00:00,23.77,18.86,739.0,1006.97,76.0,269.1,2.33,22.0,91515.0 +2006-02-03 21:00:00+00:00,23.65,18.37,680.0,994.28,73.0,268.63,2.35,15.0,91476.0 +2006-02-03 22:00:00+00:00,23.52,17.88,556.0,955.56,68.0,268.17,2.37,9.0,91437.0 +2006-02-03 23:00:00+00:00,23.39,17.39,378.0,874.74,58.0,267.7,2.39,2.0,91397.0 +2006-02-04 00:00:00+00:00,20.78,21.73,107.0,200.74,69.0,264.72,2.5,358.0,91458.0 +2006-02-04 01:00:00+00:00,18.17,26.08,0.0,0.0,0.0,261.73,2.61,353.0,91518.0 +2006-02-04 02:00:00+00:00,15.56,30.42,0.0,0.0,0.0,258.75,2.72,348.0,91578.0 +2006-02-04 03:00:00+00:00,14.4,33.15,0.0,0.0,0.0,257.9,2.61,359.0,91617.0 +2006-02-04 04:00:00+00:00,13.24,35.89,0.0,0.0,0.0,257.05,2.51,9.0,91656.0 +2006-02-04 05:00:00+00:00,12.08,38.62,0.0,0.0,0.0,256.2,2.4,19.0,91695.0 +2006-02-04 06:00:00+00:00,11.21,41.15,0.0,0.0,0.0,254.12,2.29,32.0,91701.0 +2006-02-04 07:00:00+00:00,10.34,43.67,0.0,0.0,0.0,252.03,2.17,46.0,91707.0 +2006-02-04 08:00:00+00:00,9.47,46.2,0.0,0.0,0.0,249.95,2.06,59.0,91713.0 +2006-02-04 09:00:00+00:00,8.75,47.96,0.0,0.0,0.0,248.63,2.16,63.0,91713.0 +2006-02-04 10:00:00+00:00,8.03,49.72,0.0,0.0,0.0,247.32,2.27,67.0,91713.0 +2006-02-04 11:00:00+00:00,7.3,51.48,0.0,0.0,0.0,246.0,2.37,71.0,91713.0 +2006-02-04 12:00:00+00:00,7.31,50.93,0.0,0.0,0.0,244.67,2.33,73.0,91740.0 +2006-02-04 13:00:00+00:00,7.31,50.37,0.0,0.0,0.0,243.33,2.29,75.0,91767.0 +2006-02-04 14:00:00+00:00,7.32,49.82,0.0,0.0,0.0,242.0,2.25,76.0,91794.0 +2006-02-04 15:00:00+00:00,11.78,39.55,118.0,604.81,35.0,246.27,2.34,79.0,91773.0 +2006-02-04 16:00:00+00:00,16.24,29.29,334.0,858.77,55.0,250.53,2.43,83.0,91752.0 +2006-02-04 17:00:00+00:00,20.7,19.02,527.0,957.75,67.0,254.8,2.52,86.0,91731.0 +2006-02-04 18:00:00+00:00,22.41,16.49,670.0,1006.95,73.0,256.77,2.64,94.0,91611.0 +2006-02-04 19:00:00+00:00,24.12,13.97,751.0,1030.59,76.0,258.73,2.75,103.0,91491.0 +2006-02-04 20:00:00+00:00,25.83,11.44,760.0,1031.22,77.0,260.7,2.87,112.0,91370.0 +2006-02-04 21:00:00+00:00,25.85,11.07,699.0,1017.18,74.0,260.65,2.35,131.0,91313.0 +2006-02-04 22:00:00+00:00,25.86,10.71,572.0,977.46,69.0,260.6,1.83,150.0,91256.0 +2006-02-04 23:00:00+00:00,25.87,10.34,391.0,898.29,59.0,260.55,1.31,169.0,91199.0 +2006-02-05 00:00:00+00:00,24.29,13.11,126.0,326.66,63.0,258.63,1.07,139.0,91205.0 +2006-02-05 01:00:00+00:00,22.71,15.88,0.0,0.0,0.0,256.72,0.83,109.0,91211.0 +2006-02-05 02:00:00+00:00,21.12,18.65,0.0,0.0,0.0,254.8,0.59,78.0,91217.0 +2006-02-05 03:00:00+00:00,19.81,18.94,0.0,0.0,0.0,255.72,0.76,100.0,91232.0 +2006-02-05 04:00:00+00:00,18.49,19.23,0.0,0.0,0.0,256.63,0.92,122.0,91247.0 +2006-02-05 05:00:00+00:00,17.18,19.52,0.0,0.0,0.0,257.55,1.09,144.0,91262.0 +2006-02-05 06:00:00+00:00,16.19,20.61,0.0,0.0,0.0,256.77,1.25,159.0,91271.0 +2006-02-05 07:00:00+00:00,15.2,21.7,0.0,0.0,0.0,255.98,1.41,174.0,91280.0 +2006-02-05 08:00:00+00:00,14.2,22.79,0.0,0.0,0.0,255.2,1.57,189.0,91289.0 +2006-02-05 09:00:00+00:00,14.11,24.09,0.0,0.0,0.0,254.55,1.54,193.0,91286.0 +2006-02-05 10:00:00+00:00,14.01,25.4,0.0,0.0,0.0,253.9,1.51,196.0,91283.0 +2006-02-05 11:00:00+00:00,13.91,26.7,0.0,0.0,0.0,253.25,1.48,199.0,91280.0 +2006-02-05 12:00:00+00:00,13.59,28.43,0.0,0.0,0.0,253.1,1.62,202.0,91301.0 +2006-02-05 13:00:00+00:00,13.27,30.15,0.0,0.0,0.0,252.95,1.77,204.0,91322.0 +2006-02-05 14:00:00+00:00,12.95,31.88,0.0,0.0,0.0,252.8,1.92,207.0,91343.0 +2006-02-05 15:00:00+00:00,15.81,26.61,86.0,257.2,50.0,257.65,1.97,218.0,91385.0 +2006-02-05 16:00:00+00:00,18.67,21.34,266.0,518.37,96.0,262.5,2.02,229.0,91428.0 +2006-02-05 17:00:00+00:00,21.53,16.07,433.0,618.19,134.0,267.35,2.07,240.0,91470.0 +2006-02-05 18:00:00+00:00,22.57,14.84,477.0,358.75,263.0,271.15,2.96,251.0,91413.0 +2006-02-05 19:00:00+00:00,23.61,13.62,740.0,1007.89,76.0,274.95,3.85,261.0,91355.0 +2006-02-05 20:00:00+00:00,24.65,12.39,638.0,640.88,211.0,278.75,4.74,271.0,91298.0 +2006-02-05 21:00:00+00:00,24.23,12.32,498.0,357.36,277.0,283.68,4.5,275.0,91295.0 +2006-02-05 22:00:00+00:00,23.8,12.24,433.0,453.21,198.0,288.62,4.25,279.0,91292.0 +2006-02-05 23:00:00+00:00,23.37,12.17,353.0,779.39,62.0,293.55,4.0,283.0,91289.0 +2006-02-06 00:00:00+00:00,21.14,13.69,117.0,239.28,70.0,282.75,3.41,286.0,91355.0 +2006-02-06 01:00:00+00:00,18.91,15.2,0.0,0.0,0.0,271.95,2.81,289.0,91422.0 +2006-02-06 02:00:00+00:00,16.67,16.72,0.0,0.0,0.0,261.15,2.22,292.0,91488.0 +2006-02-06 03:00:00+00:00,15.36,18.65,0.0,0.0,0.0,258.92,2.02,306.0,91530.0 +2006-02-06 04:00:00+00:00,14.05,20.57,0.0,0.0,0.0,256.68,1.83,320.0,91572.0 +2006-02-06 05:00:00+00:00,12.74,22.5,0.0,0.0,0.0,254.45,1.63,334.0,91614.0 +2006-02-06 06:00:00+00:00,11.69,23.07,0.0,0.0,0.0,251.5,1.89,355.0,91665.0 +2006-02-06 07:00:00+00:00,10.65,23.64,0.0,0.0,0.0,248.55,2.16,16.0,91716.0 +2006-02-06 08:00:00+00:00,9.6,24.21,0.0,0.0,0.0,245.6,2.43,37.0,91767.0 +2006-02-06 09:00:00+00:00,8.57,25.73,0.0,0.0,0.0,242.93,2.46,45.0,91821.0 +2006-02-06 10:00:00+00:00,7.54,27.25,0.0,0.0,0.0,240.27,2.48,54.0,91875.0 +2006-02-06 11:00:00+00:00,6.51,28.77,0.0,0.0,0.0,237.6,2.51,62.0,91929.0 +2006-02-06 12:00:00+00:00,6.53,29.26,0.0,0.0,0.0,235.98,2.57,65.0,92001.0 +2006-02-06 13:00:00+00:00,6.55,29.74,0.0,0.0,0.0,234.37,2.62,69.0,92073.0 +2006-02-06 14:00:00+00:00,6.58,30.23,0.0,0.0,0.0,232.75,2.68,72.0,92145.0 +2006-02-06 15:00:00+00:00,10.46,24.78,61.0,63.03,52.0,235.43,3.04,74.0,92176.0 +2006-02-06 16:00:00+00:00,14.34,19.32,356.0,903.05,57.0,238.12,3.41,75.0,92206.0 +2006-02-06 17:00:00+00:00,18.23,13.87,555.0,999.75,68.0,240.8,3.78,77.0,92236.0 +2006-02-06 18:00:00+00:00,19.47,11.9,703.0,1046.29,75.0,239.45,4.52,81.0,92163.0 +2006-02-06 19:00:00+00:00,20.71,9.92,785.0,1066.88,78.0,238.1,5.27,85.0,92091.0 +2006-02-06 20:00:00+00:00,21.94,7.95,795.0,1069.74,78.0,236.75,6.01,89.0,92019.0 +2006-02-06 21:00:00+00:00,21.55,7.76,732.0,1053.93,76.0,233.5,5.87,89.0,91995.0 +2006-02-06 22:00:00+00:00,21.15,7.57,601.0,1016.35,70.0,230.25,5.72,89.0,91971.0 +2006-02-06 23:00:00+00:00,20.75,7.38,414.0,938.6,60.0,227.0,5.57,89.0,91947.0 +2006-02-07 00:00:00+00:00,18.93,8.51,193.0,745.05,44.0,224.7,4.92,87.0,91992.0 +2006-02-07 01:00:00+00:00,17.1,9.63,0.0,0.0,0.0,222.4,4.27,85.0,92037.0 +2006-02-07 02:00:00+00:00,15.27,10.76,0.0,0.0,0.0,220.1,3.61,83.0,92082.0 +2006-02-07 03:00:00+00:00,13.54,11.65,0.0,0.0,0.0,218.5,3.48,81.0,92094.0 +2006-02-07 04:00:00+00:00,11.81,12.53,0.0,0.0,0.0,216.9,3.34,79.0,92106.0 +2006-02-07 05:00:00+00:00,10.08,13.42,0.0,0.0,0.0,215.3,3.2,77.0,92118.0 +2006-02-07 06:00:00+00:00,9.11,14.56,0.0,0.0,0.0,216.58,3.11,75.0,92106.0 +2006-02-07 07:00:00+00:00,8.15,15.71,0.0,0.0,0.0,217.87,3.03,73.0,92094.0 +2006-02-07 08:00:00+00:00,7.18,16.85,0.0,0.0,0.0,219.15,2.94,71.0,92082.0 +2006-02-07 09:00:00+00:00,6.51,18.25,0.0,0.0,0.0,221.97,2.91,70.0,92070.0 +2006-02-07 10:00:00+00:00,5.84,19.65,0.0,0.0,0.0,224.78,2.89,70.0,92058.0 +2006-02-07 11:00:00+00:00,5.16,21.05,0.0,0.0,0.0,227.6,2.87,70.0,92046.0 +2006-02-07 12:00:00+00:00,5.35,21.84,0.0,0.0,0.0,228.78,2.85,72.0,92076.0 +2006-02-07 13:00:00+00:00,5.54,22.63,0.0,0.0,0.0,229.97,2.83,73.0,92106.0 +2006-02-07 14:00:00+00:00,5.74,23.42,0.0,0.0,0.0,231.15,2.81,74.0,92136.0 +2006-02-07 15:00:00+00:00,9.77,18.68,69.0,102.96,54.0,235.8,3.03,76.0,92127.0 +2006-02-07 16:00:00+00:00,13.8,13.95,357.0,897.33,57.0,240.45,3.24,77.0,92118.0 +2006-02-07 17:00:00+00:00,17.83,9.21,554.0,990.55,68.0,245.1,3.45,79.0,92109.0 +2006-02-07 18:00:00+00:00,19.57,7.85,472.0,327.83,274.0,249.62,3.57,83.0,91995.0 +2006-02-07 19:00:00+00:00,21.31,6.5,628.0,612.05,220.0,254.13,3.69,86.0,91881.0 +2006-02-07 20:00:00+00:00,23.04,5.14,599.0,505.73,258.0,258.65,3.81,90.0,91767.0 +2006-02-07 21:00:00+00:00,22.99,5.29,507.0,362.35,280.0,264.97,3.74,92.0,91710.0 +2006-02-07 22:00:00+00:00,22.93,5.44,457.0,524.31,181.0,271.28,3.68,93.0,91653.0 +2006-02-07 23:00:00+00:00,22.87,5.59,231.0,170.63,166.0,277.6,3.61,95.0,91596.0 +2006-02-08 00:00:00+00:00,20.71,7.93,81.0,29.48,75.0,281.52,3.23,89.0,91623.0 +2006-02-08 01:00:00+00:00,18.55,10.28,0.0,0.0,0.0,285.43,2.85,84.0,91650.0 +2006-02-08 02:00:00+00:00,16.38,12.62,0.0,0.0,0.0,289.35,2.47,79.0,91677.0 +2006-02-08 03:00:00+00:00,14.97,14.1,0.0,0.0,0.0,290.6,2.35,76.0,91704.0 +2006-02-08 04:00:00+00:00,13.56,15.58,0.0,0.0,0.0,291.85,2.23,73.0,91731.0 +2006-02-08 05:00:00+00:00,12.15,17.06,0.0,0.0,0.0,293.1,2.11,71.0,91758.0 +2006-02-08 06:00:00+00:00,11.32,18.41,0.0,0.0,0.0,287.47,2.13,70.0,91761.0 +2006-02-08 07:00:00+00:00,10.5,19.77,0.0,0.0,0.0,281.83,2.16,69.0,91764.0 +2006-02-08 08:00:00+00:00,9.67,21.12,0.0,0.0,0.0,276.2,2.18,68.0,91767.0 +2006-02-08 09:00:00+00:00,9.19,22.14,0.0,0.0,0.0,273.27,2.23,70.0,91755.0 +2006-02-08 10:00:00+00:00,8.7,23.15,0.0,0.0,0.0,270.33,2.27,72.0,91743.0 +2006-02-08 11:00:00+00:00,8.21,24.17,0.0,0.0,0.0,267.4,2.32,73.0,91731.0 +2006-02-08 12:00:00+00:00,8.45,23.9,0.0,0.0,0.0,262.42,2.37,75.0,91746.0 +2006-02-08 13:00:00+00:00,8.69,23.62,0.0,0.0,0.0,257.43,2.42,77.0,91761.0 +2006-02-08 14:00:00+00:00,8.93,23.35,0.0,0.0,0.0,252.45,2.47,79.0,91776.0 +2006-02-08 15:00:00+00:00,12.87,18.82,125.0,598.6,36.0,256.85,2.61,80.0,91773.0 +2006-02-08 16:00:00+00:00,16.82,14.3,336.0,829.32,56.0,261.25,2.75,82.0,91770.0 +2006-02-08 17:00:00+00:00,20.77,9.77,525.0,926.72,67.0,265.65,2.9,83.0,91767.0 +2006-02-08 18:00:00+00:00,22.43,8.68,667.0,977.33,73.0,268.35,3.2,88.0,91659.0 +2006-02-08 19:00:00+00:00,24.1,7.59,746.0,999.14,76.0,271.05,3.51,94.0,91551.0 +2006-02-08 20:00:00+00:00,25.76,6.5,592.0,468.8,274.0,273.75,3.82,99.0,91443.0 +2006-02-08 21:00:00+00:00,25.65,6.79,518.0,382.23,277.0,275.63,3.79,101.0,91382.0 +2006-02-08 22:00:00+00:00,25.54,7.08,374.0,245.11,244.0,277.52,3.76,103.0,91322.0 +2006-02-08 23:00:00+00:00,25.42,7.37,394.0,870.71,59.0,279.4,3.72,105.0,91262.0 +2006-02-09 00:00:00+00:00,23.34,9.73,184.0,680.81,43.0,274.87,3.46,97.0,91283.0 +2006-02-09 01:00:00+00:00,21.26,12.09,0.0,0.0,0.0,270.33,3.19,89.0,91304.0 +2006-02-09 02:00:00+00:00,19.18,14.45,0.0,0.0,0.0,265.8,2.92,81.0,91325.0 +2006-02-09 03:00:00+00:00,17.57,15.13,0.0,0.0,0.0,270.0,2.79,81.0,91343.0 +2006-02-09 04:00:00+00:00,15.96,15.81,0.0,0.0,0.0,274.2,2.66,81.0,91361.0 +2006-02-09 05:00:00+00:00,14.35,16.49,0.0,0.0,0.0,278.4,2.52,82.0,91379.0 +2006-02-09 06:00:00+00:00,14.1,17.02,0.0,0.0,0.0,287.72,2.35,91.0,91385.0 +2006-02-09 07:00:00+00:00,13.85,17.54,0.0,0.0,0.0,297.03,2.17,100.0,91391.0 +2006-02-09 08:00:00+00:00,13.6,18.07,0.0,0.0,0.0,306.35,2.0,110.0,91397.0 +2006-02-09 09:00:00+00:00,13.4,19.24,0.0,0.0,0.0,303.1,2.07,113.0,91416.0 +2006-02-09 10:00:00+00:00,13.2,20.42,0.0,0.0,0.0,299.85,2.15,117.0,91434.0 +2006-02-09 11:00:00+00:00,13.0,21.59,0.0,0.0,0.0,296.6,2.22,120.0,91452.0 +2006-02-09 12:00:00+00:00,13.27,21.14,0.0,0.0,0.0,307.85,2.02,119.0,91446.0 +2006-02-09 13:00:00+00:00,13.54,20.68,0.0,0.0,0.0,319.1,1.82,118.0,91440.0 +2006-02-09 14:00:00+00:00,13.82,20.23,0.0,0.0,0.0,330.35,1.61,117.0,91434.0 +2006-02-09 15:00:00+00:00,13.71,22.39,3.0,0.0,3.0,330.48,1.44,115.0,91497.0 +2006-02-09 16:00:00+00:00,13.61,24.55,68.0,0.0,68.0,330.62,1.27,113.0,91560.0 +2006-02-09 17:00:00+00:00,13.51,26.71,50.0,0.0,50.0,330.75,1.1,110.0,91623.0 +2006-02-09 18:00:00+00:00,13.84,35.71,91.0,0.0,91.0,324.5,1.29,109.0,91581.0 +2006-02-09 19:00:00+00:00,14.17,44.7,118.0,0.0,118.0,318.25,1.47,107.0,91539.0 +2006-02-09 20:00:00+00:00,14.5,53.7,132.0,0.0,132.0,312.0,1.66,105.0,91497.0 +2006-02-09 21:00:00+00:00,14.57,58.32,274.0,28.37,256.0,308.55,1.51,114.0,91482.0 +2006-02-09 22:00:00+00:00,14.64,62.93,376.0,241.42,247.0,305.1,1.37,122.0,91467.0 +2006-02-09 23:00:00+00:00,14.7,67.55,33.0,0.0,33.0,301.65,1.23,130.0,91452.0 +2006-02-10 00:00:00+00:00,14.76,66.97,109.0,132.91,81.0,299.73,0.92,172.0,91443.0 +2006-02-10 01:00:00+00:00,14.82,66.38,0.0,0.0,0.0,297.82,0.62,214.0,91434.0 +2006-02-10 02:00:00+00:00,14.87,65.8,0.0,0.0,0.0,295.9,0.32,256.0,91425.0 +2006-02-10 03:00:00+00:00,14.08,65.99,0.0,0.0,0.0,296.92,0.64,236.0,91446.0 +2006-02-10 04:00:00+00:00,13.29,66.18,0.0,0.0,0.0,297.93,0.97,215.0,91467.0 +2006-02-10 05:00:00+00:00,12.5,66.37,0.0,0.0,0.0,298.95,1.3,195.0,91488.0 +2006-02-10 06:00:00+00:00,11.79,71.71,0.0,0.0,0.0,300.05,1.42,205.0,91512.0 +2006-02-10 07:00:00+00:00,11.08,77.05,0.0,0.0,0.0,301.15,1.54,216.0,91536.0 +2006-02-10 08:00:00+00:00,10.36,82.39,0.0,0.0,0.0,302.25,1.66,227.0,91560.0 +2006-02-10 09:00:00+00:00,10.23,85.06,0.0,0.0,0.0,314.33,1.53,230.0,91587.0 +2006-02-10 10:00:00+00:00,10.1,87.74,0.0,0.0,0.0,326.42,1.41,233.0,91614.0 +2006-02-10 11:00:00+00:00,9.96,90.41,0.0,0.0,0.0,338.5,1.28,236.0,91641.0 +2006-02-10 12:00:00+00:00,9.66,90.77,0.0,0.0,0.0,335.33,1.18,261.0,91710.0 +2006-02-10 13:00:00+00:00,9.36,91.12,0.0,0.0,0.0,332.17,1.07,286.0,91779.0 +2006-02-10 14:00:00+00:00,9.07,91.48,0.0,0.0,0.0,329.0,0.97,312.0,91848.0 +2006-02-10 15:00:00+00:00,11.11,76.11,134.0,626.22,37.0,327.22,1.3,312.0,91890.0 +2006-02-10 16:00:00+00:00,13.15,60.75,351.0,853.54,57.0,325.43,1.64,313.0,91932.0 +2006-02-10 17:00:00+00:00,15.2,45.38,544.0,949.02,68.0,323.65,1.97,313.0,91974.0 +2006-02-10 18:00:00+00:00,16.8,37.78,687.0,995.85,74.0,311.42,2.71,313.0,91911.0 +2006-02-10 19:00:00+00:00,18.4,30.18,767.0,1016.74,77.0,299.18,3.45,312.0,91848.0 +2006-02-10 20:00:00+00:00,20.0,22.58,775.0,1016.73,77.0,286.95,4.19,312.0,91785.0 +2006-02-10 21:00:00+00:00,19.91,21.88,714.0,1000.54,75.0,278.55,4.26,311.0,91752.0 +2006-02-10 22:00:00+00:00,19.82,21.18,587.0,960.41,70.0,270.15,4.33,310.0,91719.0 +2006-02-10 23:00:00+00:00,19.72,20.48,408.0,887.0,60.0,261.75,4.4,310.0,91686.0 +2006-02-11 00:00:00+00:00,17.73,26.68,195.0,704.92,44.0,259.77,3.82,306.0,91752.0 +2006-02-11 01:00:00+00:00,15.74,32.88,0.0,0.0,0.0,257.78,3.23,302.0,91818.0 +2006-02-11 02:00:00+00:00,13.74,39.08,0.0,0.0,0.0,255.8,2.65,298.0,91884.0 +2006-02-11 03:00:00+00:00,13.28,35.58,0.0,0.0,0.0,254.22,2.36,302.0,91932.0 +2006-02-11 04:00:00+00:00,12.82,32.09,0.0,0.0,0.0,252.63,2.07,306.0,91980.0 +2006-02-11 05:00:00+00:00,12.36,28.59,0.0,0.0,0.0,251.05,1.78,310.0,92028.0 +2006-02-11 06:00:00+00:00,11.91,30.2,0.0,0.0,0.0,248.43,1.72,323.0,92040.0 +2006-02-11 07:00:00+00:00,11.46,31.81,0.0,0.0,0.0,245.82,1.67,336.0,92052.0 +2006-02-11 08:00:00+00:00,11.0,33.42,0.0,0.0,0.0,243.2,1.61,349.0,92064.0 +2006-02-11 09:00:00+00:00,9.76,39.51,0.0,0.0,0.0,241.23,1.77,4.0,92094.0 +2006-02-11 10:00:00+00:00,8.51,45.61,0.0,0.0,0.0,239.27,1.94,19.0,92124.0 +2006-02-11 11:00:00+00:00,7.26,51.7,0.0,0.0,0.0,237.3,2.1,34.0,92154.0 +2006-02-11 12:00:00+00:00,7.05,54.06,0.0,0.0,0.0,236.63,2.07,45.0,92206.0 +2006-02-11 13:00:00+00:00,6.84,56.42,0.0,0.0,0.0,235.97,2.04,55.0,92257.0 +2006-02-11 14:00:00+00:00,6.64,58.78,0.0,0.0,0.0,235.3,2.01,66.0,92308.0 +2006-02-11 15:00:00+00:00,10.37,46.59,143.0,664.03,38.0,238.62,2.17,64.0,92341.0 +2006-02-11 16:00:00+00:00,14.11,34.4,367.0,888.02,58.0,241.93,2.32,61.0,92374.0 +2006-02-11 17:00:00+00:00,17.85,22.21,565.0,981.52,69.0,245.25,2.47,59.0,92407.0 +2006-02-11 18:00:00+00:00,19.05,18.41,711.0,1026.61,75.0,246.72,2.95,60.0,92323.0 +2006-02-11 19:00:00+00:00,20.25,14.6,793.0,1047.28,78.0,248.18,3.43,62.0,92239.0 +2006-02-11 20:00:00+00:00,21.45,10.8,804.0,1049.74,79.0,249.65,3.92,63.0,92154.0 +2006-02-11 21:00:00+00:00,21.23,9.92,741.0,1034.62,76.0,249.53,4.0,66.0,92112.0 +2006-02-11 22:00:00+00:00,21.01,9.05,612.0,997.62,71.0,249.42,4.07,68.0,92070.0 +2006-02-11 23:00:00+00:00,20.78,8.17,428.0,926.47,61.0,249.3,4.15,71.0,92028.0 +2006-02-12 00:00:00+00:00,18.43,10.77,208.0,748.57,45.0,246.62,3.71,74.0,92073.0 +2006-02-12 01:00:00+00:00,16.08,13.37,0.0,0.0,0.0,243.93,3.26,77.0,92118.0 +2006-02-12 02:00:00+00:00,13.73,15.97,0.0,0.0,0.0,241.25,2.81,80.0,92163.0 +2006-02-12 03:00:00+00:00,12.24,18.02,0.0,0.0,0.0,238.63,2.76,79.0,92194.0 +2006-02-12 04:00:00+00:00,10.74,20.07,0.0,0.0,0.0,236.02,2.71,78.0,92224.0 +2006-02-12 05:00:00+00:00,9.24,22.12,0.0,0.0,0.0,233.4,2.66,77.0,92254.0 +2006-02-12 06:00:00+00:00,8.36,24.1,0.0,0.0,0.0,230.4,2.7,76.0,92263.0 +2006-02-12 07:00:00+00:00,7.48,26.09,0.0,0.0,0.0,227.4,2.74,74.0,92272.0 +2006-02-12 08:00:00+00:00,6.6,28.07,0.0,0.0,0.0,224.4,2.79,73.0,92281.0 +2006-02-12 09:00:00+00:00,5.89,30.35,0.0,0.0,0.0,221.97,2.83,72.0,92284.0 +2006-02-12 10:00:00+00:00,5.18,32.62,0.0,0.0,0.0,219.53,2.87,72.0,92287.0 +2006-02-12 11:00:00+00:00,4.46,34.9,0.0,0.0,0.0,217.1,2.91,72.0,92290.0 +2006-02-12 12:00:00+00:00,4.65,36.8,0.0,0.0,0.0,216.08,2.88,73.0,92332.0 +2006-02-12 13:00:00+00:00,4.84,38.71,0.0,0.0,0.0,215.07,2.86,75.0,92374.0 +2006-02-12 14:00:00+00:00,5.03,40.61,0.0,0.0,0.0,214.05,2.83,76.0,92416.0 +2006-02-12 15:00:00+00:00,8.8,33.01,149.0,681.4,39.0,217.32,2.97,78.0,92395.0 +2006-02-12 16:00:00+00:00,12.58,25.4,375.0,901.71,58.0,220.58,3.11,81.0,92374.0 +2006-02-12 17:00:00+00:00,16.36,17.8,574.0,991.82,69.0,223.85,3.26,83.0,92353.0 +2006-02-12 18:00:00+00:00,18.22,14.87,721.0,1036.05,75.0,226.78,3.11,84.0,92242.0 +2006-02-12 19:00:00+00:00,20.09,11.93,803.0,1054.1,79.0,229.72,2.97,84.0,92130.0 +2006-02-12 20:00:00+00:00,21.95,9.0,811.0,1053.54,79.0,232.65,2.83,85.0,92019.0 +2006-02-12 21:00:00+00:00,22.01,8.48,747.0,1037.33,76.0,234.13,2.92,87.0,91953.0 +2006-02-12 22:00:00+00:00,22.07,7.97,617.0,999.5,71.0,235.62,3.02,88.0,91887.0 +2006-02-12 23:00:00+00:00,22.13,7.45,431.0,922.7,62.0,237.1,3.12,90.0,91821.0 +2006-02-13 00:00:00+00:00,19.22,10.67,211.0,745.67,46.0,236.63,2.88,87.0,91836.0 +2006-02-13 01:00:00+00:00,16.31,13.89,0.0,0.0,0.0,236.17,2.65,84.0,91851.0 +2006-02-13 02:00:00+00:00,13.39,17.11,0.0,0.0,0.0,235.7,2.41,81.0,91866.0 +2006-02-13 03:00:00+00:00,11.65,19.86,0.0,0.0,0.0,235.4,2.38,81.0,91908.0 +2006-02-13 04:00:00+00:00,9.91,22.61,0.0,0.0,0.0,235.1,2.34,81.0,91950.0 +2006-02-13 05:00:00+00:00,8.17,25.36,0.0,0.0,0.0,234.8,2.3,82.0,91992.0 +2006-02-13 06:00:00+00:00,7.31,27.81,0.0,0.0,0.0,233.52,2.21,82.0,91989.0 +2006-02-13 07:00:00+00:00,6.46,30.26,0.0,0.0,0.0,232.23,2.12,82.0,91986.0 +2006-02-13 08:00:00+00:00,5.6,32.71,0.0,0.0,0.0,230.95,2.03,82.0,91983.0 +2006-02-13 09:00:00+00:00,5.08,34.96,0.0,0.0,0.0,230.08,1.96,82.0,91974.0 +2006-02-13 10:00:00+00:00,4.56,37.22,0.0,0.0,0.0,229.22,1.89,81.0,91965.0 +2006-02-13 11:00:00+00:00,4.03,39.47,0.0,0.0,0.0,228.35,1.82,81.0,91956.0 +2006-02-13 12:00:00+00:00,4.55,38.59,0.0,0.0,0.0,229.35,1.77,83.0,91965.0 +2006-02-13 13:00:00+00:00,5.07,37.72,0.0,0.0,0.0,230.35,1.73,86.0,91974.0 +2006-02-13 14:00:00+00:00,5.6,36.84,0.0,0.0,0.0,231.35,1.68,89.0,91983.0 +2006-02-13 15:00:00+00:00,10.45,28.68,73.0,66.74,62.0,236.6,1.56,104.0,91974.0 +2006-02-13 16:00:00+00:00,15.3,20.51,370.0,878.36,58.0,241.85,1.44,120.0,91965.0 +2006-02-13 17:00:00+00:00,20.16,12.35,565.0,966.77,69.0,247.1,1.32,136.0,91956.0 +2006-02-13 18:00:00+00:00,21.72,10.86,708.0,1008.64,75.0,250.7,1.82,175.0,91851.0 +2006-02-13 19:00:00+00:00,23.29,9.38,788.0,1027.51,78.0,254.3,2.31,213.0,91746.0 +2006-02-13 20:00:00+00:00,24.85,7.89,798.0,1030.09,78.0,257.9,2.8,252.0,91641.0 +2006-02-13 21:00:00+00:00,24.67,7.5,736.0,1013.88,76.0,259.53,3.05,260.0,91572.0 +2006-02-13 22:00:00+00:00,24.49,7.12,609.0,979.55,70.0,261.17,3.31,267.0,91503.0 +2006-02-13 23:00:00+00:00,24.31,6.73,427.0,906.63,61.0,262.8,3.56,274.0,91434.0 +2006-02-14 00:00:00+00:00,23.15,8.28,210.0,729.55,46.0,263.42,2.92,278.0,91455.0 +2006-02-14 01:00:00+00:00,21.99,9.82,0.0,0.0,0.0,264.03,2.29,281.0,91476.0 +2006-02-14 02:00:00+00:00,20.83,11.37,0.0,0.0,0.0,264.65,1.66,285.0,91497.0 +2006-02-14 03:00:00+00:00,19.28,12.93,0.0,0.0,0.0,266.68,1.16,317.0,91515.0 +2006-02-14 04:00:00+00:00,17.73,14.5,0.0,0.0,0.0,268.72,0.67,349.0,91533.0 +2006-02-14 05:00:00+00:00,16.18,16.06,0.0,0.0,0.0,270.75,0.18,21.0,91551.0 +2006-02-14 06:00:00+00:00,14.22,17.74,0.0,0.0,0.0,271.45,0.8,63.0,91521.0 +2006-02-14 07:00:00+00:00,12.27,19.41,0.0,0.0,0.0,272.15,1.41,106.0,91491.0 +2006-02-14 08:00:00+00:00,10.31,21.09,0.0,0.0,0.0,272.85,2.03,149.0,91461.0 +2006-02-14 09:00:00+00:00,9.95,22.6,0.0,0.0,0.0,272.53,2.25,155.0,91437.0 +2006-02-14 10:00:00+00:00,9.58,24.12,0.0,0.0,0.0,272.22,2.47,162.0,91413.0 +2006-02-14 11:00:00+00:00,9.21,25.63,0.0,0.0,0.0,271.9,2.69,169.0,91388.0 +2006-02-14 12:00:00+00:00,9.82,24.03,0.0,0.0,0.0,271.6,2.73,170.0,91391.0 +2006-02-14 13:00:00+00:00,10.43,22.44,0.0,0.0,0.0,271.3,2.77,171.0,91394.0 +2006-02-14 14:00:00+00:00,11.05,20.84,0.0,0.0,0.0,271.0,2.81,173.0,91397.0 +2006-02-14 15:00:00+00:00,14.44,16.83,47.0,0.0,47.0,276.98,3.2,184.0,91394.0 +2006-02-14 16:00:00+00:00,17.83,12.82,249.0,295.33,143.0,282.97,3.58,196.0,91391.0 +2006-02-14 17:00:00+00:00,21.23,8.81,375.0,278.54,231.0,288.95,3.96,207.0,91388.0 +2006-02-14 18:00:00+00:00,22.09,7.92,513.0,367.28,281.0,292.13,4.93,214.0,91298.0 +2006-02-14 19:00:00+00:00,22.96,7.02,645.0,569.65,249.0,295.32,5.91,222.0,91208.0 +2006-02-14 20:00:00+00:00,23.82,6.13,622.0,487.8,279.0,298.5,6.88,229.0,91118.0 +2006-02-14 21:00:00+00:00,23.34,6.62,517.0,322.1,306.0,295.27,6.71,231.0,91073.0 +2006-02-14 22:00:00+00:00,22.86,7.1,348.0,151.56,264.0,292.03,6.53,233.0,91028.0 +2006-02-14 23:00:00+00:00,22.37,7.59,278.0,260.14,172.0,288.8,6.36,234.0,90983.0 +2006-02-15 00:00:00+00:00,20.52,9.58,144.0,275.95,81.0,280.3,5.73,232.0,91022.0 +2006-02-15 01:00:00+00:00,18.66,11.56,10.0,0.0,10.0,271.8,5.1,229.0,91061.0 +2006-02-15 02:00:00+00:00,16.8,13.55,0.0,0.0,0.0,263.3,4.47,227.0,91100.0 +2006-02-15 03:00:00+00:00,15.67,15.09,0.0,0.0,0.0,260.28,4.25,223.0,91157.0 +2006-02-15 04:00:00+00:00,14.53,16.62,0.0,0.0,0.0,257.27,4.03,219.0,91214.0 +2006-02-15 05:00:00+00:00,13.4,18.16,0.0,0.0,0.0,254.25,3.81,216.0,91271.0 +2006-02-15 06:00:00+00:00,13.19,18.77,0.0,0.0,0.0,252.35,3.94,211.0,91268.0 +2006-02-15 07:00:00+00:00,12.98,19.39,0.0,0.0,0.0,250.45,4.07,207.0,91265.0 +2006-02-15 08:00:00+00:00,12.76,20.0,0.0,0.0,0.0,248.55,4.21,203.0,91262.0 +2006-02-15 09:00:00+00:00,12.57,21.9,0.0,0.0,0.0,248.4,4.25,202.0,91265.0 +2006-02-15 10:00:00+00:00,12.37,23.81,0.0,0.0,0.0,248.25,4.29,202.0,91268.0 +2006-02-15 11:00:00+00:00,12.17,25.71,0.0,0.0,0.0,248.1,4.33,201.0,91271.0 +2006-02-15 12:00:00+00:00,12.23,25.2,0.0,0.0,0.0,246.43,4.07,202.0,91310.0 +2006-02-15 13:00:00+00:00,12.29,24.7,0.0,0.0,0.0,244.77,3.81,203.0,91349.0 +2006-02-15 14:00:00+00:00,12.35,24.19,0.0,0.0,0.0,243.1,3.54,204.0,91388.0 +2006-02-15 15:00:00+00:00,14.67,19.92,155.0,669.4,40.0,246.5,4.83,205.0,91334.0 +2006-02-15 16:00:00+00:00,17.0,15.66,378.0,882.26,58.0,249.9,6.11,206.0,91280.0 +2006-02-15 17:00:00+00:00,19.33,11.39,575.0,971.26,69.0,253.3,7.39,207.0,91226.0 +2006-02-15 18:00:00+00:00,20.38,11.79,720.0,1014.47,75.0,254.6,7.97,212.0,91145.0 +2006-02-15 19:00:00+00:00,21.43,12.18,800.0,1032.35,78.0,255.9,8.55,217.0,91064.0 +2006-02-15 20:00:00+00:00,22.47,12.58,807.0,1030.6,78.0,257.2,9.13,222.0,90983.0 +2006-02-15 21:00:00+00:00,21.81,15.25,743.0,1011.82,76.0,258.33,8.96,224.0,90950.0 +2006-02-15 22:00:00+00:00,21.15,17.92,613.0,972.77,70.0,259.47,8.78,226.0,90917.0 +2006-02-15 23:00:00+00:00,20.49,20.59,430.0,897.31,61.0,260.6,8.61,228.0,90884.0 +2006-02-16 00:00:00+00:00,19.16,26.93,213.0,720.47,46.0,260.77,7.8,229.0,90962.0 +2006-02-16 01:00:00+00:00,17.83,33.27,17.0,0.0,17.0,260.93,6.99,230.0,91040.0 +2006-02-16 02:00:00+00:00,16.5,39.61,0.0,0.0,0.0,261.1,6.18,232.0,91118.0 +2006-02-16 03:00:00+00:00,15.16,46.27,0.0,0.0,0.0,257.68,5.55,229.0,91157.0 +2006-02-16 04:00:00+00:00,13.81,52.92,0.0,0.0,0.0,254.27,4.93,227.0,91196.0 +2006-02-16 05:00:00+00:00,12.47,59.58,0.0,0.0,0.0,250.85,4.3,224.0,91235.0 +2006-02-16 06:00:00+00:00,11.72,64.67,0.0,0.0,0.0,248.0,4.06,225.0,91271.0 +2006-02-16 07:00:00+00:00,10.98,69.75,0.0,0.0,0.0,245.15,3.83,226.0,91307.0 +2006-02-16 08:00:00+00:00,10.23,74.84,0.0,0.0,0.0,242.3,3.59,227.0,91343.0 +2006-02-16 09:00:00+00:00,9.56,78.31,0.0,0.0,0.0,242.03,3.37,229.0,91382.0 +2006-02-16 10:00:00+00:00,8.89,81.77,0.0,0.0,0.0,241.77,3.15,231.0,91422.0 +2006-02-16 11:00:00+00:00,8.21,85.24,0.0,0.0,0.0,241.5,2.94,233.0,91461.0 +2006-02-16 12:00:00+00:00,8.56,82.43,0.0,0.0,0.0,242.62,2.65,233.0,91500.0 +2006-02-16 13:00:00+00:00,8.9,79.62,0.0,0.0,0.0,243.73,2.36,232.0,91539.0 +2006-02-16 14:00:00+00:00,9.25,76.81,0.0,0.0,0.0,244.85,2.07,232.0,91578.0 +2006-02-16 15:00:00+00:00,11.34,63.89,79.0,68.42,67.0,248.25,2.71,236.0,91596.0 +2006-02-16 16:00:00+00:00,13.44,50.96,224.0,182.79,157.0,251.65,3.36,240.0,91614.0 +2006-02-16 17:00:00+00:00,15.54,38.04,577.0,967.61,69.0,255.05,4.0,244.0,91632.0 +2006-02-16 18:00:00+00:00,16.88,32.18,723.0,1012.55,75.0,255.47,4.34,245.0,91563.0 +2006-02-16 19:00:00+00:00,18.23,26.33,805.0,1033.25,78.0,255.88,4.68,247.0,91494.0 +2006-02-16 20:00:00+00:00,19.57,20.47,815.0,1034.33,79.0,256.3,5.02,249.0,91425.0 +2006-02-16 21:00:00+00:00,19.57,19.0,753.0,1020.61,76.0,256.73,4.79,248.0,91379.0 +2006-02-16 22:00:00+00:00,19.57,17.54,622.0,980.13,71.0,257.17,4.56,248.0,91334.0 +2006-02-16 23:00:00+00:00,19.57,16.07,437.0,903.66,62.0,257.6,4.33,247.0,91289.0 +2006-02-17 00:00:00+00:00,18.11,18.87,159.0,348.54,77.0,257.9,3.58,239.0,91298.0 +2006-02-17 01:00:00+00:00,16.64,21.68,19.0,0.0,19.0,258.2,2.83,230.0,91307.0 +2006-02-17 02:00:00+00:00,15.17,24.48,0.0,0.0,0.0,258.5,2.08,222.0,91316.0 +2006-02-17 03:00:00+00:00,14.19,25.83,0.0,0.0,0.0,259.22,2.16,213.0,91355.0 +2006-02-17 04:00:00+00:00,13.21,27.17,0.0,0.0,0.0,259.93,2.23,205.0,91394.0 +2006-02-17 05:00:00+00:00,12.23,28.52,0.0,0.0,0.0,260.65,2.3,196.0,91434.0 +2006-02-17 06:00:00+00:00,12.2,28.51,0.0,0.0,0.0,275.58,2.31,191.0,91419.0 +2006-02-17 07:00:00+00:00,12.18,28.51,0.0,0.0,0.0,290.52,2.32,186.0,91403.0 +2006-02-17 08:00:00+00:00,12.15,28.5,0.0,0.0,0.0,305.45,2.33,181.0,91388.0 +2006-02-17 09:00:00+00:00,12.32,28.37,0.0,0.0,0.0,308.23,2.45,183.0,91379.0 +2006-02-17 10:00:00+00:00,12.48,28.25,0.0,0.0,0.0,311.02,2.57,184.0,91370.0 +2006-02-17 11:00:00+00:00,12.64,28.12,0.0,0.0,0.0,313.8,2.69,185.0,91361.0 +2006-02-17 12:00:00+00:00,12.77,28.85,0.0,0.0,0.0,314.78,2.69,189.0,91406.0 +2006-02-17 13:00:00+00:00,12.9,29.57,0.0,0.0,0.0,315.77,2.7,193.0,91452.0 +2006-02-17 14:00:00+00:00,13.04,30.3,0.0,0.0,0.0,316.75,2.7,197.0,91497.0 +2006-02-17 15:00:00+00:00,13.46,27.21,7.0,0.0,7.0,316.43,3.03,202.0,91545.0 +2006-02-17 16:00:00+00:00,13.88,24.12,50.0,0.0,50.0,316.12,3.37,207.0,91593.0 +2006-02-17 17:00:00+00:00,14.31,21.03,260.0,56.7,230.0,315.8,3.7,211.0,91641.0 +2006-02-17 18:00:00+00:00,13.15,22.04,419.0,156.79,318.0,319.0,3.43,208.0,91626.0 +2006-02-17 19:00:00+00:00,11.99,23.04,46.0,0.0,46.0,322.2,3.17,204.0,91611.0 +2006-02-17 20:00:00+00:00,10.83,24.05,125.0,0.0,125.0,325.4,2.91,200.0,91596.0 +2006-02-17 21:00:00+00:00,10.93,30.59,131.0,0.0,131.0,325.65,2.91,190.0,91572.0 +2006-02-17 22:00:00+00:00,11.03,37.12,25.0,0.0,25.0,325.9,2.9,179.0,91548.0 +2006-02-17 23:00:00+00:00,11.13,43.66,9.0,0.0,9.0,326.15,2.9,168.0,91524.0 +2006-02-18 00:00:00+00:00,12.03,38.73,46.0,0.0,46.0,327.57,2.74,174.0,91503.0 +2006-02-18 01:00:00+00:00,12.93,33.81,4.0,0.0,4.0,328.98,2.58,179.0,91482.0 +2006-02-18 02:00:00+00:00,13.82,28.88,0.0,0.0,0.0,330.4,2.43,185.0,91461.0 +2006-02-18 03:00:00+00:00,13.2,32.45,0.0,0.0,0.0,327.03,2.36,183.0,91503.0 +2006-02-18 04:00:00+00:00,12.58,36.02,0.0,0.0,0.0,323.67,2.29,182.0,91545.0 +2006-02-18 05:00:00+00:00,11.96,39.59,0.0,0.0,0.0,320.3,2.22,180.0,91587.0 +2006-02-18 06:00:00+00:00,11.47,45.23,0.0,0.0,0.0,316.37,2.09,184.0,91602.0 +2006-02-18 07:00:00+00:00,10.98,50.86,0.0,0.0,0.0,312.43,1.96,188.0,91617.0 +2006-02-18 08:00:00+00:00,10.48,56.5,0.0,0.0,0.0,308.5,1.83,192.0,91632.0 +2006-02-18 09:00:00+00:00,9.88,63.13,0.0,0.0,0.0,302.45,1.9,194.0,91638.0 +2006-02-18 10:00:00+00:00,9.28,69.76,0.0,0.0,0.0,296.4,1.97,196.0,91644.0 +2006-02-18 11:00:00+00:00,8.68,76.39,0.0,0.0,0.0,290.35,2.04,197.0,91650.0 +2006-02-18 12:00:00+00:00,9.2,74.47,0.0,0.0,0.0,288.72,2.12,195.0,91665.0 +2006-02-18 13:00:00+00:00,9.72,72.55,0.0,0.0,0.0,287.08,2.21,193.0,91680.0 +2006-02-18 14:00:00+00:00,10.25,70.63,0.0,0.0,0.0,285.45,2.29,191.0,91695.0 +2006-02-18 15:00:00+00:00,12.22,60.33,80.0,60.17,69.0,287.22,2.77,198.0,91686.0 +2006-02-18 16:00:00+00:00,14.2,50.03,243.0,227.02,158.0,288.98,3.25,205.0,91677.0 +2006-02-18 17:00:00+00:00,16.18,39.73,386.0,271.93,241.0,290.75,3.72,213.0,91668.0 +2006-02-18 18:00:00+00:00,17.3,34.72,658.0,800.42,139.0,292.72,4.55,217.0,91578.0 +2006-02-18 19:00:00+00:00,18.42,29.72,654.0,546.25,265.0,294.68,5.37,221.0,91488.0 +2006-02-18 20:00:00+00:00,19.53,24.71,565.0,297.21,351.0,296.65,6.19,226.0,91397.0 +2006-02-18 21:00:00+00:00,19.05,24.46,552.0,370.77,303.0,302.17,5.94,227.0,91364.0 +2006-02-18 22:00:00+00:00,18.57,24.21,442.0,335.04,251.0,307.68,5.68,229.0,91331.0 +2006-02-18 23:00:00+00:00,18.08,23.96,326.0,395.33,159.0,313.2,5.42,231.0,91298.0 +2006-02-19 00:00:00+00:00,16.81,27.11,109.0,66.07,93.0,317.72,4.74,231.0,91373.0 +2006-02-19 01:00:00+00:00,15.54,30.26,11.0,0.0,11.0,322.23,4.06,231.0,91449.0 +2006-02-19 02:00:00+00:00,14.27,33.41,0.0,0.0,0.0,326.75,3.38,231.0,91524.0 +2006-02-19 03:00:00+00:00,13.18,37.37,0.0,0.0,0.0,321.55,3.02,227.0,91560.0 +2006-02-19 04:00:00+00:00,12.09,41.32,0.0,0.0,0.0,316.35,2.66,223.0,91596.0 +2006-02-19 05:00:00+00:00,11.0,45.28,0.0,0.0,0.0,311.15,2.3,219.0,91632.0 +2006-02-19 06:00:00+00:00,10.6,46.61,0.0,0.0,0.0,304.78,2.17,221.0,91641.0 +2006-02-19 07:00:00+00:00,10.2,47.95,0.0,0.0,0.0,298.42,2.03,224.0,91650.0 +2006-02-19 08:00:00+00:00,9.8,49.28,0.0,0.0,0.0,292.05,1.89,226.0,91659.0 +2006-02-19 09:00:00+00:00,9.35,51.2,0.0,0.0,0.0,288.23,1.77,229.0,91659.0 +2006-02-19 10:00:00+00:00,8.9,53.11,0.0,0.0,0.0,284.42,1.64,232.0,91659.0 +2006-02-19 11:00:00+00:00,8.44,55.03,0.0,0.0,0.0,280.6,1.52,235.0,91659.0 +2006-02-19 12:00:00+00:00,8.26,55.74,0.0,0.0,0.0,277.47,1.5,227.0,91722.0 +2006-02-19 13:00:00+00:00,8.08,56.45,0.0,0.0,0.0,274.33,1.48,219.0,91785.0 +2006-02-19 14:00:00+00:00,7.9,57.16,0.0,0.0,0.0,271.2,1.46,211.0,91848.0 +2006-02-19 15:00:00+00:00,10.28,48.65,168.0,675.23,42.0,266.83,2.26,216.0,91830.0 +2006-02-19 16:00:00+00:00,12.67,40.15,392.0,877.32,60.0,262.47,3.05,221.0,91812.0 +2006-02-19 17:00:00+00:00,15.06,31.64,589.0,965.77,70.0,258.1,3.85,226.0,91794.0 +2006-02-19 18:00:00+00:00,16.24,28.19,736.0,1011.22,76.0,256.8,4.66,228.0,91701.0 +2006-02-19 19:00:00+00:00,17.42,24.74,818.0,1030.13,80.0,255.5,5.48,230.0,91608.0 +2006-02-19 20:00:00+00:00,18.59,21.29,828.0,1032.77,80.0,254.2,6.29,232.0,91515.0 +2006-02-19 21:00:00+00:00,18.3,21.55,766.0,1019.7,77.0,253.58,6.14,235.0,91479.0 +2006-02-19 22:00:00+00:00,18.01,21.82,636.0,982.56,72.0,252.97,6.0,238.0,91443.0 +2006-02-19 23:00:00+00:00,17.72,22.08,452.0,912.84,63.0,252.35,5.85,241.0,91406.0 +2006-02-20 00:00:00+00:00,15.87,26.68,232.0,749.21,48.0,250.22,4.83,246.0,91473.0 +2006-02-20 01:00:00+00:00,14.02,31.27,15.0,0.0,15.0,248.08,3.82,251.0,91539.0 +2006-02-20 02:00:00+00:00,12.16,35.87,0.0,0.0,0.0,245.95,2.8,256.0,91605.0 +2006-02-20 03:00:00+00:00,11.57,38.55,0.0,0.0,0.0,243.65,2.41,252.0,91644.0 +2006-02-20 04:00:00+00:00,10.97,41.23,0.0,0.0,0.0,241.35,2.02,248.0,91683.0 +2006-02-20 05:00:00+00:00,10.38,43.91,0.0,0.0,0.0,239.05,1.63,244.0,91722.0 +2006-02-20 06:00:00+00:00,9.9,44.67,0.0,0.0,0.0,237.3,1.48,242.0,91737.0 +2006-02-20 07:00:00+00:00,9.42,45.44,0.0,0.0,0.0,235.55,1.33,240.0,91752.0 +2006-02-20 08:00:00+00:00,8.94,46.2,0.0,0.0,0.0,233.8,1.19,238.0,91767.0 +2006-02-20 09:00:00+00:00,8.32,48.47,0.0,0.0,0.0,232.32,1.05,237.0,91773.0 +2006-02-20 10:00:00+00:00,7.7,50.73,0.0,0.0,0.0,230.83,0.91,236.0,91779.0 +2006-02-20 11:00:00+00:00,7.08,53.0,0.0,0.0,0.0,229.35,0.77,234.0,91785.0 +2006-02-20 12:00:00+00:00,6.82,55.51,0.0,0.0,0.0,230.7,0.9,220.0,91803.0 +2006-02-20 13:00:00+00:00,6.55,58.01,0.0,0.0,0.0,232.05,1.03,205.0,91821.0 +2006-02-20 14:00:00+00:00,6.29,60.52,0.0,0.0,0.0,233.4,1.16,190.0,91839.0 +2006-02-20 15:00:00+00:00,8.99,51.24,173.0,687.78,42.0,237.22,1.8,202.0,91818.0 +2006-02-20 16:00:00+00:00,11.69,41.95,397.0,881.06,60.0,241.03,2.45,214.0,91797.0 +2006-02-20 17:00:00+00:00,14.4,32.67,593.0,963.8,71.0,244.85,3.09,225.0,91776.0 +2006-02-20 18:00:00+00:00,15.53,29.67,737.0,1004.61,77.0,245.73,3.98,229.0,91698.0 +2006-02-20 19:00:00+00:00,16.67,26.68,641.0,493.95,285.0,246.62,4.86,232.0,91620.0 +2006-02-20 20:00:00+00:00,17.8,23.68,655.0,507.89,285.0,247.5,5.75,235.0,91542.0 +2006-02-20 21:00:00+00:00,17.48,24.07,542.0,329.51,318.0,254.28,5.52,238.0,91500.0 +2006-02-20 22:00:00+00:00,17.15,24.47,386.0,190.33,276.0,261.07,5.28,241.0,91458.0 +2006-02-20 23:00:00+00:00,16.82,24.86,272.0,190.77,190.0,267.85,5.05,243.0,91416.0 +2006-02-21 00:00:00+00:00,15.76,28.47,101.0,32.13,93.0,273.72,4.14,244.0,91437.0 +2006-02-21 01:00:00+00:00,14.7,32.09,18.0,0.0,18.0,279.58,3.24,245.0,91458.0 +2006-02-21 02:00:00+00:00,13.64,35.7,0.0,0.0,0.0,285.45,2.33,246.0,91479.0 +2006-02-21 03:00:00+00:00,12.93,38.24,0.0,0.0,0.0,288.37,2.12,239.0,91503.0 +2006-02-21 04:00:00+00:00,12.22,40.79,0.0,0.0,0.0,291.28,1.92,233.0,91527.0 +2006-02-21 05:00:00+00:00,11.51,43.33,0.0,0.0,0.0,294.2,1.71,227.0,91551.0 +2006-02-21 06:00:00+00:00,10.67,44.96,0.0,0.0,0.0,284.5,1.76,229.0,91563.0 +2006-02-21 07:00:00+00:00,9.83,46.6,0.0,0.0,0.0,274.8,1.8,231.0,91575.0 +2006-02-21 08:00:00+00:00,8.98,48.23,0.0,0.0,0.0,265.1,1.85,234.0,91587.0 +2006-02-21 09:00:00+00:00,8.58,48.18,0.0,0.0,0.0,257.7,1.66,237.0,91602.0 +2006-02-21 10:00:00+00:00,8.18,48.12,0.0,0.0,0.0,250.3,1.48,240.0,91617.0 +2006-02-21 11:00:00+00:00,7.77,48.07,0.0,0.0,0.0,242.9,1.3,244.0,91632.0 +2006-02-21 12:00:00+00:00,7.49,50.43,0.0,0.0,0.0,243.18,1.2,237.0,91635.0 +2006-02-21 13:00:00+00:00,7.21,52.8,0.0,0.0,0.0,243.47,1.1,230.0,91638.0 +2006-02-21 14:00:00+00:00,6.93,55.16,0.0,0.0,0.0,243.75,1.01,223.0,91641.0 +2006-02-21 15:00:00+00:00,9.21,45.66,37.0,0.0,37.0,258.57,1.54,225.0,91629.0 +2006-02-21 16:00:00+00:00,11.49,36.15,196.0,80.18,165.0,273.38,2.08,227.0,91617.0 +2006-02-21 17:00:00+00:00,13.77,26.65,499.0,632.03,154.0,288.2,2.62,229.0,91605.0 +2006-02-21 18:00:00+00:00,15.02,23.55,745.0,1010.15,77.0,280.87,3.38,232.0,91512.0 +2006-02-21 19:00:00+00:00,16.27,20.44,827.0,1028.92,81.0,273.53,4.15,235.0,91419.0 +2006-02-21 20:00:00+00:00,17.52,17.34,837.0,1031.74,81.0,266.2,4.91,238.0,91325.0 +2006-02-21 21:00:00+00:00,17.32,16.91,775.0,1017.69,79.0,262.47,4.97,241.0,91274.0 +2006-02-21 22:00:00+00:00,17.11,16.48,645.0,983.1,73.0,258.73,5.04,244.0,91223.0 +2006-02-21 23:00:00+00:00,16.9,16.05,329.0,369.09,169.0,255.0,5.1,246.0,91172.0 +2006-02-22 00:00:00+00:00,15.57,18.59,237.0,744.93,49.0,255.5,4.68,246.0,91217.0 +2006-02-22 01:00:00+00:00,14.24,21.14,23.0,0.0,23.0,256.0,4.25,245.0,91262.0 +2006-02-22 02:00:00+00:00,12.9,23.68,0.0,0.0,0.0,256.5,3.82,244.0,91307.0 +2006-02-22 03:00:00+00:00,11.51,27.12,0.0,0.0,0.0,253.57,3.23,244.0,91373.0 +2006-02-22 04:00:00+00:00,10.11,30.57,0.0,0.0,0.0,250.63,2.64,243.0,91440.0 +2006-02-22 05:00:00+00:00,8.72,34.01,0.0,0.0,0.0,247.7,2.06,243.0,91506.0 +2006-02-22 06:00:00+00:00,8.22,34.29,0.0,0.0,0.0,243.95,1.77,242.0,91518.0 +2006-02-22 07:00:00+00:00,7.73,34.57,0.0,0.0,0.0,240.2,1.48,242.0,91530.0 +2006-02-22 08:00:00+00:00,7.23,34.85,0.0,0.0,0.0,236.45,1.19,242.0,91542.0 +2006-02-22 09:00:00+00:00,6.34,35.58,0.0,0.0,0.0,234.2,0.85,209.0,91557.0 +2006-02-22 10:00:00+00:00,5.45,36.3,0.0,0.0,0.0,231.95,0.51,177.0,91572.0 +2006-02-22 11:00:00+00:00,4.55,37.03,0.0,0.0,0.0,229.7,0.17,145.0,91587.0 +2006-02-22 12:00:00+00:00,4.74,38.2,0.0,0.0,0.0,228.67,0.21,124.0,91632.0 +2006-02-22 13:00:00+00:00,4.93,39.37,0.0,0.0,0.0,227.63,0.26,102.0,91677.0 +2006-02-22 14:00:00+00:00,5.13,40.54,0.0,0.0,0.0,226.6,0.3,81.0,91722.0 +2006-02-22 15:00:00+00:00,7.68,33.5,183.0,700.66,44.0,228.92,0.42,129.0,91719.0 +2006-02-22 16:00:00+00:00,10.23,26.45,410.0,890.53,62.0,231.23,0.53,178.0,91716.0 +2006-02-22 17:00:00+00:00,12.78,19.41,608.0,974.29,72.0,233.55,0.65,226.0,91713.0 +2006-02-22 18:00:00+00:00,13.94,17.96,755.0,1015.58,79.0,234.18,1.21,229.0,91629.0 +2006-02-22 19:00:00+00:00,15.1,16.5,837.0,1035.16,82.0,234.82,1.78,231.0,91545.0 +2006-02-22 20:00:00+00:00,16.25,15.05,847.0,1038.02,82.0,235.45,2.34,234.0,91461.0 +2006-02-22 21:00:00+00:00,16.37,14.53,784.0,1023.27,80.0,239.63,2.27,237.0,91422.0 +2006-02-22 22:00:00+00:00,16.48,14.01,654.0,990.23,74.0,243.82,2.19,240.0,91382.0 +2006-02-22 23:00:00+00:00,16.59,13.49,467.0,919.61,65.0,248.0,2.11,243.0,91343.0 +2006-02-23 00:00:00+00:00,15.31,16.86,199.0,523.98,65.0,246.2,1.65,277.0,91397.0 +2006-02-23 01:00:00+00:00,14.03,20.22,31.0,275.97,18.0,244.4,1.19,310.0,91452.0 +2006-02-23 02:00:00+00:00,12.74,23.59,0.0,0.0,0.0,242.6,0.73,344.0,91506.0 +2006-02-23 03:00:00+00:00,11.61,23.76,0.0,0.0,0.0,248.18,0.93,22.0,91527.0 +2006-02-23 04:00:00+00:00,10.48,23.94,0.0,0.0,0.0,253.77,1.14,60.0,91548.0 +2006-02-23 05:00:00+00:00,9.35,24.11,0.0,0.0,0.0,259.35,1.34,98.0,91569.0 +2006-02-23 06:00:00+00:00,8.45,27.35,0.0,0.0,0.0,261.12,1.51,102.0,91551.0 +2006-02-23 07:00:00+00:00,7.55,30.6,0.0,0.0,0.0,262.88,1.68,105.0,91533.0 +2006-02-23 08:00:00+00:00,6.65,33.84,0.0,0.0,0.0,264.65,1.85,109.0,91515.0 +2006-02-23 09:00:00+00:00,6.0,35.82,0.0,0.0,0.0,263.3,1.89,111.0,91524.0 +2006-02-23 10:00:00+00:00,5.34,37.81,0.0,0.0,0.0,261.95,1.92,113.0,91533.0 +2006-02-23 11:00:00+00:00,4.68,39.79,0.0,0.0,0.0,260.6,1.96,115.0,91542.0 +2006-02-23 12:00:00+00:00,5.07,39.86,0.0,0.0,0.0,254.28,1.85,110.0,91599.0 +2006-02-23 13:00:00+00:00,5.45,39.92,0.0,0.0,0.0,247.97,1.75,106.0,91656.0 +2006-02-23 14:00:00+00:00,5.84,39.99,0.0,0.0,0.0,241.65,1.64,102.0,91713.0 +2006-02-23 15:00:00+00:00,9.47,31.81,168.0,627.38,41.0,245.22,2.13,120.0,91710.0 +2006-02-23 16:00:00+00:00,13.1,23.62,421.0,906.35,63.0,248.78,2.62,139.0,91707.0 +2006-02-23 17:00:00+00:00,16.74,15.44,621.0,988.34,73.0,252.35,3.1,157.0,91704.0 +2006-02-23 18:00:00+00:00,17.84,14.01,769.0,1028.37,80.0,253.87,3.21,173.0,91611.0 +2006-02-23 19:00:00+00:00,18.94,12.57,851.0,1046.77,83.0,255.38,3.32,189.0,91518.0 +2006-02-23 20:00:00+00:00,20.03,11.14,860.0,1048.27,83.0,256.9,3.43,205.0,91425.0 +2006-02-23 21:00:00+00:00,20.01,10.9,796.0,1033.13,81.0,256.77,3.48,213.0,91376.0 +2006-02-23 22:00:00+00:00,19.98,10.66,663.0,997.3,75.0,256.63,3.53,222.0,91328.0 +2006-02-23 23:00:00+00:00,19.95,10.42,475.0,927.94,66.0,256.5,3.57,230.0,91280.0 +2006-02-24 00:00:00+00:00,18.91,11.91,249.0,764.28,51.0,257.42,3.08,225.0,91310.0 +2006-02-24 01:00:00+00:00,17.87,13.4,34.0,298.93,19.0,258.33,2.59,220.0,91340.0 +2006-02-24 02:00:00+00:00,16.82,14.89,0.0,0.0,0.0,259.25,2.1,214.0,91370.0 +2006-02-24 03:00:00+00:00,15.78,15.85,0.0,0.0,0.0,259.33,2.06,201.0,91397.0 +2006-02-24 04:00:00+00:00,14.73,16.82,0.0,0.0,0.0,259.42,2.03,188.0,91425.0 +2006-02-24 05:00:00+00:00,13.69,17.78,0.0,0.0,0.0,259.5,2.0,175.0,91452.0 +2006-02-24 06:00:00+00:00,12.08,20.97,0.0,0.0,0.0,260.23,2.0,167.0,91446.0 +2006-02-24 07:00:00+00:00,10.47,24.16,0.0,0.0,0.0,260.97,2.0,159.0,91440.0 +2006-02-24 08:00:00+00:00,8.85,27.35,0.0,0.0,0.0,261.7,2.0,152.0,91434.0 +2006-02-24 09:00:00+00:00,8.13,28.63,0.0,0.0,0.0,261.92,1.98,143.0,91431.0 +2006-02-24 10:00:00+00:00,7.4,29.9,0.0,0.0,0.0,262.13,1.95,135.0,91428.0 +2006-02-24 11:00:00+00:00,6.67,31.18,0.0,0.0,0.0,262.35,1.93,126.0,91425.0 +2006-02-24 12:00:00+00:00,6.96,32.65,0.0,0.0,0.0,265.9,1.87,120.0,91455.0 +2006-02-24 13:00:00+00:00,7.25,34.12,0.0,0.0,0.0,269.45,1.81,114.0,91485.0 +2006-02-24 14:00:00+00:00,7.54,35.59,0.0,0.0,0.0,273.0,1.75,108.0,91515.0 +2006-02-24 15:00:00+00:00,11.15,28.53,189.0,697.23,45.0,275.37,2.45,132.0,91527.0 +2006-02-24 16:00:00+00:00,14.76,21.48,414.0,879.15,63.0,277.73,3.14,157.0,91539.0 +2006-02-24 17:00:00+00:00,18.38,14.42,609.0,959.17,73.0,280.1,3.83,182.0,91551.0 +2006-02-24 18:00:00+00:00,19.26,13.49,754.0,999.45,80.0,282.37,4.04,198.0,91470.0 +2006-02-24 19:00:00+00:00,20.14,12.57,834.0,1017.58,83.0,284.63,4.24,214.0,91388.0 +2006-02-24 20:00:00+00:00,21.02,11.64,844.0,1020.86,83.0,286.9,4.44,230.0,91307.0 +2006-02-24 21:00:00+00:00,20.97,10.96,782.0,1006.99,81.0,280.97,4.43,241.0,91295.0 +2006-02-24 22:00:00+00:00,20.92,10.28,510.0,485.31,222.0,275.03,4.42,252.0,91283.0 +2006-02-24 23:00:00+00:00,20.86,9.6,469.0,906.92,66.0,269.1,4.41,263.0,91271.0 +2006-02-25 00:00:00+00:00,18.77,11.87,248.0,750.82,51.0,261.98,3.71,275.0,91352.0 +2006-02-25 01:00:00+00:00,16.67,14.14,35.0,300.57,19.0,254.87,3.02,286.0,91434.0 +2006-02-25 02:00:00+00:00,14.57,16.41,0.0,0.0,0.0,247.75,2.32,298.0,91515.0 +2006-02-25 03:00:00+00:00,14.3,16.02,0.0,0.0,0.0,244.87,1.85,318.0,91563.0 +2006-02-25 04:00:00+00:00,14.02,15.63,0.0,0.0,0.0,241.98,1.39,338.0,91611.0 +2006-02-25 05:00:00+00:00,13.74,15.24,0.0,0.0,0.0,239.1,0.92,358.0,91659.0 +2006-02-25 06:00:00+00:00,12.72,15.91,0.0,0.0,0.0,237.15,0.74,30.0,91692.0 +2006-02-25 07:00:00+00:00,11.7,16.58,0.0,0.0,0.0,235.2,0.56,62.0,91725.0 +2006-02-25 08:00:00+00:00,10.67,17.25,0.0,0.0,0.0,233.25,0.37,94.0,91758.0 +2006-02-25 09:00:00+00:00,9.33,20.24,0.0,0.0,0.0,231.97,0.51,86.0,91785.0 +2006-02-25 10:00:00+00:00,7.99,23.24,0.0,0.0,0.0,230.68,0.66,78.0,91812.0 +2006-02-25 11:00:00+00:00,6.65,26.23,0.0,0.0,0.0,229.4,0.8,70.0,91839.0 +2006-02-25 12:00:00+00:00,6.98,26.77,0.0,0.0,0.0,227.97,1.06,74.0,91929.0 +2006-02-25 13:00:00+00:00,7.31,27.32,0.0,0.0,0.0,226.53,1.32,77.0,92019.0 +2006-02-25 14:00:00+00:00,7.64,27.86,0.0,0.0,0.0,225.1,1.59,81.0,92109.0 +2006-02-25 15:00:00+00:00,11.52,22.19,201.0,730.95,47.0,228.72,1.74,79.0,92112.0 +2006-02-25 16:00:00+00:00,15.4,16.51,432.0,909.44,65.0,232.33,1.9,77.0,92115.0 +2006-02-25 17:00:00+00:00,19.29,10.84,632.0,988.99,75.0,235.95,2.06,74.0,92118.0 +2006-02-25 18:00:00+00:00,20.73,9.98,593.0,483.23,265.0,236.98,2.35,77.0,92019.0 +2006-02-25 19:00:00+00:00,22.18,9.13,862.0,1046.65,85.0,238.02,2.65,80.0,91920.0 +2006-02-25 20:00:00+00:00,23.62,8.27,727.0,624.27,259.0,239.05,2.95,83.0,91821.0 +2006-02-25 21:00:00+00:00,23.77,7.99,644.0,559.86,252.0,240.45,2.92,85.0,91761.0 +2006-02-25 22:00:00+00:00,23.92,7.71,521.0,519.04,211.0,241.85,2.89,87.0,91701.0 +2006-02-25 23:00:00+00:00,24.06,7.43,373.0,500.07,149.0,243.25,2.86,89.0,91641.0 +2006-02-26 00:00:00+00:00,21.49,9.63,192.0,417.82,81.0,243.37,2.87,85.0,91683.0 +2006-02-26 01:00:00+00:00,18.92,11.84,27.0,124.41,20.0,243.48,2.89,82.0,91725.0 +2006-02-26 02:00:00+00:00,16.34,14.04,0.0,0.0,0.0,243.6,2.91,78.0,91767.0 +2006-02-26 03:00:00+00:00,14.91,15.94,0.0,0.0,0.0,245.73,2.88,80.0,91794.0 +2006-02-26 04:00:00+00:00,13.48,17.84,0.0,0.0,0.0,247.87,2.85,83.0,91821.0 +2006-02-26 05:00:00+00:00,12.05,19.74,0.0,0.0,0.0,250.0,2.81,85.0,91848.0 +2006-02-26 06:00:00+00:00,11.34,21.48,0.0,0.0,0.0,250.87,2.77,85.0,91821.0 +2006-02-26 07:00:00+00:00,10.63,23.23,0.0,0.0,0.0,251.73,2.72,84.0,91794.0 +2006-02-26 08:00:00+00:00,9.92,24.97,0.0,0.0,0.0,252.6,2.68,84.0,91767.0 +2006-02-26 09:00:00+00:00,9.59,26.94,0.0,0.0,0.0,254.82,2.64,83.0,91749.0 +2006-02-26 10:00:00+00:00,9.26,28.91,0.0,0.0,0.0,257.03,2.61,83.0,91731.0 +2006-02-26 11:00:00+00:00,8.92,30.88,0.0,0.0,0.0,259.25,2.58,82.0,91713.0 +2006-02-26 12:00:00+00:00,9.34,31.18,0.0,0.0,0.0,263.42,2.51,82.0,91764.0 +2006-02-26 13:00:00+00:00,9.76,31.47,0.0,0.0,0.0,267.58,2.44,82.0,91815.0 +2006-02-26 14:00:00+00:00,10.18,31.77,0.0,0.0,0.0,271.75,2.37,83.0,91866.0 +2006-02-26 15:00:00+00:00,14.18,26.27,117.0,158.22,83.0,276.32,2.5,88.0,91869.0 +2006-02-26 16:00:00+00:00,18.18,20.78,274.0,247.62,173.0,280.88,2.63,93.0,91872.0 +2006-02-26 17:00:00+00:00,22.19,15.28,402.0,241.36,265.0,285.45,2.76,98.0,91875.0 +2006-02-26 18:00:00+00:00,23.73,13.12,710.0,846.05,132.0,284.48,3.0,113.0,91770.0 +2006-02-26 19:00:00+00:00,25.27,10.97,617.0,354.89,352.0,283.52,3.24,129.0,91665.0 +2006-02-26 20:00:00+00:00,26.81,8.81,856.0,1022.71,85.0,282.55,3.48,145.0,91560.0 +2006-02-26 21:00:00+00:00,26.63,8.24,616.0,477.13,280.0,280.13,3.42,161.0,91488.0 +2006-02-26 22:00:00+00:00,26.45,7.66,661.0,971.61,77.0,277.72,3.36,176.0,91416.0 +2006-02-26 23:00:00+00:00,26.26,7.09,475.0,901.47,68.0,275.3,3.3,192.0,91343.0 +2006-02-27 00:00:00+00:00,23.67,8.36,190.0,386.73,86.0,273.6,2.91,197.0,91382.0 +2006-02-27 01:00:00+00:00,21.07,9.64,38.0,286.8,21.0,271.9,2.52,202.0,91422.0 +2006-02-27 02:00:00+00:00,18.47,10.91,0.0,0.0,0.0,270.2,2.14,207.0,91461.0 +2006-02-27 03:00:00+00:00,18.03,11.85,0.0,0.0,0.0,271.55,1.97,209.0,91503.0 +2006-02-27 04:00:00+00:00,17.59,12.8,0.0,0.0,0.0,272.9,1.81,210.0,91545.0 +2006-02-27 05:00:00+00:00,17.15,13.74,0.0,0.0,0.0,274.25,1.64,212.0,91587.0 +2006-02-27 06:00:00+00:00,16.56,14.99,0.0,0.0,0.0,270.92,1.55,218.0,91587.0 +2006-02-27 07:00:00+00:00,15.98,16.24,0.0,0.0,0.0,267.58,1.46,224.0,91587.0 +2006-02-27 08:00:00+00:00,15.39,17.49,0.0,0.0,0.0,264.25,1.37,231.0,91587.0 +2006-02-27 09:00:00+00:00,15.23,17.37,0.0,0.0,0.0,261.68,1.25,243.0,91602.0 +2006-02-27 10:00:00+00:00,15.06,17.25,0.0,0.0,0.0,259.12,1.13,255.0,91617.0 +2006-02-27 11:00:00+00:00,14.89,17.13,0.0,0.0,0.0,256.55,1.01,267.0,91632.0 +2006-02-27 12:00:00+00:00,13.94,17.37,0.0,0.0,0.0,256.2,0.71,320.0,91677.0 +2006-02-27 13:00:00+00:00,12.99,17.6,0.0,0.0,0.0,255.85,0.42,13.0,91722.0 +2006-02-27 14:00:00+00:00,12.04,17.84,0.0,0.0,0.0,255.5,0.12,65.0,91767.0 +2006-02-27 15:00:00+00:00,15.52,13.99,187.0,661.66,42.0,259.78,0.29,15.0,91770.0 +2006-02-27 16:00:00+00:00,19.0,10.15,428.0,873.24,68.0,264.07,0.45,326.0,91773.0 +2006-02-27 17:00:00+00:00,22.49,6.3,624.0,952.73,79.0,268.35,0.61,276.0,91776.0 +2006-02-27 18:00:00+00:00,23.7,6.87,768.0,991.86,86.0,268.87,1.41,277.0,91707.0 +2006-02-27 19:00:00+00:00,24.91,7.44,846.0,1007.92,89.0,269.38,2.22,278.0,91638.0 +2006-02-27 20:00:00+00:00,26.11,8.01,722.0,602.84,265.0,269.9,3.02,279.0,91569.0 +2006-02-27 21:00:00+00:00,26.03,9.41,647.0,545.03,261.0,271.55,3.2,281.0,91524.0 +2006-02-27 22:00:00+00:00,25.95,10.81,434.0,244.69,286.0,273.2,3.38,283.0,91479.0 +2006-02-27 23:00:00+00:00,25.86,12.21,467.0,872.52,70.0,274.85,3.56,286.0,91434.0 +2006-02-28 00:00:00+00:00,24.24,13.77,42.0,0.0,42.0,273.63,2.95,288.0,91449.0 +2006-02-28 01:00:00+00:00,22.62,15.32,35.0,224.85,21.0,272.42,2.34,290.0,91464.0 +2006-02-28 02:00:00+00:00,20.99,16.88,0.0,0.0,0.0,271.2,1.72,292.0,91479.0 +2006-02-28 03:00:00+00:00,20.51,17.44,0.0,0.0,0.0,271.83,1.53,288.0,91533.0 +2006-02-28 04:00:00+00:00,20.03,18.0,0.0,0.0,0.0,272.47,1.34,284.0,91587.0 +2006-02-28 05:00:00+00:00,19.55,18.56,0.0,0.0,0.0,273.1,1.14,280.0,91641.0 +2006-02-28 06:00:00+00:00,18.86,19.61,0.0,0.0,0.0,273.12,1.28,281.0,91668.0 +2006-02-28 07:00:00+00:00,18.18,20.66,0.0,0.0,0.0,273.13,1.42,281.0,91695.0 +2006-02-28 08:00:00+00:00,17.49,21.71,0.0,0.0,0.0,273.15,1.56,282.0,91722.0 +2006-02-28 09:00:00+00:00,16.78,23.11,0.0,0.0,0.0,273.43,1.31,297.0,91713.0 +2006-02-28 10:00:00+00:00,16.07,24.52,0.0,0.0,0.0,273.72,1.06,312.0,91704.0 +2006-02-28 11:00:00+00:00,15.36,25.92,0.0,0.0,0.0,274.0,0.81,327.0,91695.0 +2006-02-28 12:00:00+00:00,14.98,26.85,0.0,0.0,0.0,276.3,0.86,19.0,91689.0 +2006-02-28 13:00:00+00:00,14.6,27.78,0.0,0.0,0.0,278.6,0.91,71.0,91683.0 +2006-02-28 14:00:00+00:00,14.23,28.71,0.0,0.0,0.0,280.9,0.97,123.0,91677.0 +2006-02-28 15:00:00+00:00,17.59,23.78,193.0,644.45,49.0,287.42,1.09,161.0,91689.0 +2006-02-28 16:00:00+00:00,26.71,5.07,410.0,823.19,67.0,302.35,3.1,198.0,91701.0 +2006-02-28 17:00:00+00:00,26.16,9.44,469.0,397.23,240.0,304.22,3.08,236.0,91713.0 +2006-02-28 18:00:00+00:00,25.61,13.81,549.0,322.24,326.0,306.1,3.05,245.0,91641.0 +2006-02-28 19:00:00+00:00,25.06,18.19,618.0,340.22,361.0,307.98,3.02,253.0,91569.0 +2006-02-28 20:00:00+00:00,24.51,22.56,711.0,545.74,295.0,309.85,2.99,262.0,91497.0 +2006-02-28 21:00:00+00:00,23.96,26.93,543.0,272.4,349.0,311.73,2.96,264.0,91464.0 +2006-02-28 22:00:00+00:00,23.41,31.3,288.0,46.01,260.0,313.61,2.93,266.0,91431.0 +2006-02-28 23:00:00+00:00,22.86,35.67,220.0,56.71,194.0,315.49,2.9,268.0,91397.0 +2006-03-01 00:00:00+00:00,22.31,40.04,212.0,501.16,74.0,317.36,2.88,277.0,91452.0 +2006-03-01 01:00:00+00:00,21.76,44.42,26.0,61.32,22.0,319.24,2.85,286.0,91506.0 +2006-03-01 02:00:00+00:00,21.21,48.79,0.0,0.0,0.0,321.12,2.82,295.0,91560.0 +2006-03-01 03:00:00+00:00,20.66,53.16,0.0,0.0,0.0,322.99,2.79,303.0,91599.0 +2006-03-01 04:00:00+00:00,20.11,57.53,0.0,0.0,0.0,324.87,2.76,311.0,91638.0 +2006-03-01 05:00:00+00:00,19.56,61.9,0.0,0.0,0.0,326.75,2.73,318.0,91677.0 +2006-03-01 06:00:00+00:00,19.01,66.28,0.0,0.0,0.0,328.62,2.7,329.0,91647.0 +2006-03-01 07:00:00+00:00,18.46,70.65,0.0,0.0,0.0,330.5,2.68,339.0,91617.0 +2006-03-01 08:00:00+00:00,16.13,73.56,0.0,0.0,0.0,315.05,1.63,349.0,91587.0 +2006-03-01 09:00:00+00:00,15.56,76.28,0.0,0.0,0.0,316.6,1.4,9.0,91566.0 +2006-03-01 10:00:00+00:00,14.98,79.0,0.0,0.0,0.0,318.15,1.18,29.0,91545.0 +2006-03-01 11:00:00+00:00,14.4,81.72,0.0,0.0,0.0,319.7,0.95,48.0,91524.0 +2006-03-01 12:00:00+00:00,15.3,80.27,0.0,0.0,0.0,320.75,0.84,104.0,91536.0 +2006-03-01 13:00:00+00:00,16.2,78.83,0.0,0.0,0.0,321.8,0.72,159.0,91548.0 +2006-03-01 14:00:00+00:00,17.1,77.38,0.0,0.0,0.0,322.85,0.61,214.0,91560.0 +2006-03-01 15:00:00+00:00,17.95,70.99,130.0,184.38,88.0,328.12,1.2,242.0,91614.0 +2006-03-01 16:00:00+00:00,18.81,64.59,189.0,42.74,171.0,333.38,1.8,270.0,91668.0 +2006-03-01 17:00:00+00:00,19.66,58.2,112.0,0.0,112.0,338.65,2.4,298.0,91722.0 +2006-03-01 18:00:00+00:00,19.57,60.14,144.0,1.44,143.0,338.38,3.08,298.0,91719.0 +2006-03-01 19:00:00+00:00,19.48,62.07,205.0,9.21,198.0,338.12,3.75,298.0,91716.0 +2006-03-01 20:00:00+00:00,19.39,64.01,106.0,0.0,106.0,337.85,4.43,298.0,91713.0 +2006-03-01 21:00:00+00:00,18.68,67.19,266.0,18.15,253.0,333.98,4.06,301.0,91677.0 +2006-03-01 22:00:00+00:00,17.97,70.37,224.0,14.7,215.0,330.12,3.7,304.0,91641.0 +2006-03-01 23:00:00+00:00,17.26,73.55,297.0,196.99,206.0,326.25,3.34,306.0,91605.0 +2006-03-02 00:00:00+00:00,17.99,74.59,144.0,118.47,111.0,321.53,2.5,301.0,91554.0 +2006-03-02 01:00:00+00:00,18.71,75.64,24.0,29.33,22.0,316.82,1.66,296.0,91503.0 +2006-03-02 02:00:00+00:00,19.44,76.68,0.0,0.0,0.0,312.1,0.81,290.0,91452.0 +2006-03-02 03:00:00+00:00,18.26,78.8,0.0,0.0,0.0,303.73,0.92,266.0,91467.0 +2006-03-02 04:00:00+00:00,17.08,80.92,0.0,0.0,0.0,295.37,1.03,241.0,91482.0 +2006-03-02 05:00:00+00:00,15.9,83.04,0.0,0.0,0.0,287.0,1.14,216.0,91497.0 +2006-03-02 06:00:00+00:00,15.24,83.2,0.0,0.0,0.0,284.48,1.08,222.0,91494.0 +2006-03-02 07:00:00+00:00,14.58,83.36,0.0,0.0,0.0,281.97,1.02,228.0,91491.0 +2006-03-02 08:00:00+00:00,13.91,83.52,0.0,0.0,0.0,279.45,0.95,233.0,91488.0 +2006-03-02 09:00:00+00:00,13.27,85.28,0.0,0.0,0.0,276.9,0.72,247.0,91482.0 +2006-03-02 10:00:00+00:00,12.62,87.04,0.0,0.0,0.0,274.35,0.48,260.0,91476.0 +2006-03-02 11:00:00+00:00,11.98,88.8,0.0,0.0,0.0,271.8,0.25,274.0,91470.0 +2006-03-02 12:00:00+00:00,11.86,84.33,0.0,0.0,0.0,269.65,0.47,219.0,91506.0 +2006-03-02 13:00:00+00:00,11.74,79.87,0.0,0.0,0.0,267.5,0.7,165.0,91542.0 +2006-03-02 14:00:00+00:00,11.63,75.4,12.0,0.0,12.0,265.35,0.92,110.0,91578.0 +2006-03-02 15:00:00+00:00,14.59,63.16,217.0,710.65,52.0,270.08,1.39,137.0,91566.0 +2006-03-02 16:00:00+00:00,17.56,50.92,448.0,885.84,71.0,274.82,1.85,164.0,91554.0 +2006-03-02 17:00:00+00:00,20.52,38.68,649.0,966.77,83.0,279.55,2.32,190.0,91542.0 +2006-03-02 18:00:00+00:00,21.74,33.0,797.0,1008.71,90.0,280.73,3.28,202.0,91458.0 +2006-03-02 19:00:00+00:00,22.96,27.33,880.0,1030.05,93.0,281.92,4.24,213.0,91373.0 +2006-03-02 20:00:00+00:00,24.17,21.65,890.0,1032.97,94.0,283.1,5.2,224.0,91289.0 +2006-03-02 21:00:00+00:00,23.71,19.65,825.0,1019.31,91.0,282.68,5.24,228.0,91241.0 +2006-03-02 22:00:00+00:00,23.24,17.65,690.0,982.14,85.0,282.27,5.28,233.0,91193.0 +2006-03-02 23:00:00+00:00,22.77,15.65,499.0,913.21,74.0,281.85,5.32,237.0,91145.0 +2006-03-03 00:00:00+00:00,21.09,20.8,270.0,752.6,58.0,280.17,4.35,239.0,91169.0 +2006-03-03 01:00:00+00:00,19.4,25.96,48.0,337.55,24.0,278.48,3.37,240.0,91193.0 +2006-03-03 02:00:00+00:00,17.72,31.11,0.0,0.0,0.0,276.8,2.4,242.0,91217.0 +2006-03-03 03:00:00+00:00,16.68,32.62,0.0,0.0,0.0,274.08,2.31,225.0,91253.0 +2006-03-03 04:00:00+00:00,15.63,34.14,0.0,0.0,0.0,271.37,2.23,208.0,91289.0 +2006-03-03 05:00:00+00:00,14.59,35.65,0.0,0.0,0.0,268.65,2.14,191.0,91325.0 +2006-03-03 06:00:00+00:00,13.44,38.31,0.0,0.0,0.0,267.23,2.26,185.0,91328.0 +2006-03-03 07:00:00+00:00,12.29,40.98,0.0,0.0,0.0,265.82,2.39,178.0,91331.0 +2006-03-03 08:00:00+00:00,11.13,43.64,0.0,0.0,0.0,264.4,2.51,172.0,91334.0 +2006-03-03 09:00:00+00:00,10.83,44.21,0.0,0.0,0.0,263.92,2.58,171.0,91322.0 +2006-03-03 10:00:00+00:00,10.53,44.78,0.0,0.0,0.0,263.43,2.66,169.0,91310.0 +2006-03-03 11:00:00+00:00,10.23,45.35,0.0,0.0,0.0,262.95,2.73,168.0,91298.0 +2006-03-03 12:00:00+00:00,11.25,43.7,0.0,0.0,0.0,263.42,2.81,166.0,91340.0 +2006-03-03 13:00:00+00:00,12.27,42.06,0.0,0.0,0.0,263.88,2.9,164.0,91382.0 +2006-03-03 14:00:00+00:00,13.3,40.41,15.0,0.0,15.0,264.35,2.98,162.0,91425.0 +2006-03-03 15:00:00+00:00,15.99,32.66,190.0,557.88,58.0,270.38,3.65,174.0,91428.0 +2006-03-03 16:00:00+00:00,18.69,24.9,383.0,646.39,105.0,276.42,4.31,186.0,91431.0 +2006-03-03 17:00:00+00:00,21.38,17.15,545.0,630.55,173.0,282.45,4.98,197.0,91434.0 +2006-03-03 18:00:00+00:00,22.39,15.29,570.0,341.68,329.0,285.87,5.57,203.0,91364.0 +2006-03-03 19:00:00+00:00,23.4,13.44,546.0,195.22,396.0,289.28,6.16,209.0,91295.0 +2006-03-03 20:00:00+00:00,24.4,11.58,729.0,551.16,302.0,292.7,6.74,215.0,91226.0 +2006-03-03 21:00:00+00:00,23.81,11.72,685.0,595.3,254.0,292.93,6.57,218.0,91193.0 +2006-03-03 22:00:00+00:00,23.22,11.85,557.0,568.05,205.0,293.17,6.4,221.0,91160.0 +2006-03-03 23:00:00+00:00,22.63,11.99,365.0,381.83,186.0,293.4,6.22,224.0,91127.0 +2006-03-04 00:00:00+00:00,21.13,15.14,269.0,737.33,59.0,291.03,5.41,224.0,91163.0 +2006-03-04 01:00:00+00:00,19.64,18.3,49.0,324.31,25.0,288.67,4.59,223.0,91199.0 +2006-03-04 02:00:00+00:00,18.14,21.45,0.0,0.0,0.0,286.3,3.78,222.0,91235.0 +2006-03-04 03:00:00+00:00,17.0,26.02,0.0,0.0,0.0,280.82,3.18,222.0,91307.0 +2006-03-04 04:00:00+00:00,15.85,30.6,0.0,0.0,0.0,275.33,2.57,221.0,91379.0 +2006-03-04 05:00:00+00:00,14.71,35.17,0.0,0.0,0.0,269.85,1.97,220.0,91452.0 +2006-03-04 06:00:00+00:00,13.54,38.19,0.0,0.0,0.0,266.23,1.9,212.0,91464.0 +2006-03-04 07:00:00+00:00,12.37,41.21,0.0,0.0,0.0,262.62,1.83,203.0,91476.0 +2006-03-04 08:00:00+00:00,11.2,44.23,0.0,0.0,0.0,259.0,1.77,194.0,91488.0 +2006-03-04 09:00:00+00:00,10.26,47.26,0.0,0.0,0.0,257.73,1.8,189.0,91476.0 +2006-03-04 10:00:00+00:00,9.31,50.29,0.0,0.0,0.0,256.47,1.83,184.0,91464.0 +2006-03-04 11:00:00+00:00,8.37,53.32,0.0,0.0,0.0,255.2,1.86,179.0,91452.0 +2006-03-04 12:00:00+00:00,9.4,50.92,0.0,0.0,0.0,254.75,1.82,182.0,91485.0 +2006-03-04 13:00:00+00:00,10.43,48.51,0.0,0.0,0.0,254.3,1.77,184.0,91518.0 +2006-03-04 14:00:00+00:00,11.47,46.11,16.0,0.0,16.0,253.85,1.72,187.0,91551.0 +2006-03-04 15:00:00+00:00,14.0,38.99,182.0,468.73,69.0,257.92,2.43,199.0,91578.0 +2006-03-04 16:00:00+00:00,16.53,31.87,232.0,94.34,191.0,261.98,3.14,210.0,91605.0 +2006-03-04 17:00:00+00:00,19.05,24.75,395.0,183.36,286.0,266.05,3.85,222.0,91632.0 +2006-03-04 18:00:00+00:00,20.18,21.71,599.0,397.31,317.0,267.18,4.43,224.0,91581.0 +2006-03-04 19:00:00+00:00,21.3,18.66,733.0,566.87,295.0,268.32,5.02,227.0,91530.0 +2006-03-04 20:00:00+00:00,22.42,15.62,466.0,97.58,390.0,269.45,5.6,229.0,91479.0 +2006-03-04 21:00:00+00:00,22.15,15.89,581.0,321.48,347.0,271.07,5.48,233.0,91473.0 +2006-03-04 22:00:00+00:00,21.87,16.15,692.0,970.66,87.0,272.68,5.35,236.0,91467.0 +2006-03-04 23:00:00+00:00,21.59,16.42,502.0,902.23,76.0,274.3,5.23,239.0,91461.0 +2006-03-05 00:00:00+00:00,19.86,20.65,274.0,743.3,60.0,269.6,4.29,244.0,91515.0 +2006-03-05 01:00:00+00:00,18.13,24.88,52.0,338.19,26.0,264.9,3.34,249.0,91569.0 +2006-03-05 02:00:00+00:00,16.4,29.11,0.0,0.0,0.0,260.2,2.4,254.0,91623.0 +2006-03-05 03:00:00+00:00,16.26,29.38,0.0,0.0,0.0,257.82,1.96,240.0,91671.0 +2006-03-05 04:00:00+00:00,16.13,29.66,0.0,0.0,0.0,255.43,1.53,226.0,91719.0 +2006-03-05 05:00:00+00:00,15.99,29.93,0.0,0.0,0.0,253.05,1.09,211.0,91767.0 +2006-03-05 06:00:00+00:00,14.16,33.84,0.0,0.0,0.0,251.57,1.19,193.0,91791.0 +2006-03-05 07:00:00+00:00,12.32,37.75,0.0,0.0,0.0,250.08,1.28,174.0,91815.0 +2006-03-05 08:00:00+00:00,10.48,41.66,0.0,0.0,0.0,248.6,1.38,155.0,91839.0 +2006-03-05 09:00:00+00:00,9.53,44.92,0.0,0.0,0.0,247.62,1.51,146.0,91839.0 +2006-03-05 10:00:00+00:00,8.57,48.17,0.0,0.0,0.0,246.63,1.64,138.0,91839.0 +2006-03-05 11:00:00+00:00,7.61,51.43,0.0,0.0,0.0,245.65,1.77,129.0,91839.0 +2006-03-05 12:00:00+00:00,8.66,47.04,0.0,0.0,0.0,247.45,1.8,130.0,91878.0 +2006-03-05 13:00:00+00:00,9.71,42.64,0.0,0.0,0.0,249.25,1.84,132.0,91917.0 +2006-03-05 14:00:00+00:00,10.77,38.25,16.0,0.0,16.0,251.05,1.88,133.0,91956.0 +2006-03-05 15:00:00+00:00,14.4,30.25,233.0,720.75,56.0,256.82,2.12,144.0,91968.0 +2006-03-05 16:00:00+00:00,18.04,22.24,366.0,503.24,145.0,262.58,2.37,155.0,91980.0 +2006-03-05 17:00:00+00:00,21.67,14.24,665.0,966.62,86.0,268.35,2.62,166.0,91992.0 +2006-03-05 18:00:00+00:00,23.15,11.99,616.0,448.05,296.0,268.22,2.92,177.0,91914.0 +2006-03-05 19:00:00+00:00,24.63,9.75,756.0,617.8,276.0,268.08,3.22,188.0,91836.0 +2006-03-05 20:00:00+00:00,26.1,7.5,760.0,609.25,283.0,267.95,3.52,200.0,91758.0 +2006-03-05 21:00:00+00:00,25.85,7.35,667.0,534.34,276.0,266.82,3.55,206.0,91719.0 +2006-03-05 22:00:00+00:00,25.6,7.19,701.0,977.85,88.0,265.68,3.58,212.0,91680.0 +2006-03-05 23:00:00+00:00,25.35,7.04,435.0,689.8,107.0,264.55,3.61,219.0,91641.0 +2006-03-06 00:00:00+00:00,24.22,9.14,221.0,470.84,84.0,262.47,3.0,226.0,91674.0 +2006-03-06 01:00:00+00:00,23.09,11.25,32.0,62.71,27.0,260.38,2.39,232.0,91707.0 +2006-03-06 02:00:00+00:00,21.96,13.35,0.0,0.0,0.0,258.3,1.78,239.0,91740.0 +2006-03-06 03:00:00+00:00,21.02,13.86,0.0,0.0,0.0,257.22,1.57,219.0,91761.0 +2006-03-06 04:00:00+00:00,20.08,14.38,0.0,0.0,0.0,256.13,1.37,198.0,91782.0 +2006-03-06 05:00:00+00:00,19.14,14.89,0.0,0.0,0.0,255.05,1.16,178.0,91803.0 +2006-03-06 06:00:00+00:00,16.99,18.65,0.0,0.0,0.0,252.77,1.22,168.0,91809.0 +2006-03-06 07:00:00+00:00,14.84,22.42,0.0,0.0,0.0,250.48,1.29,159.0,91815.0 +2006-03-06 08:00:00+00:00,12.69,26.18,0.0,0.0,0.0,248.2,1.35,150.0,91821.0 +2006-03-06 09:00:00+00:00,11.99,27.22,0.0,0.0,0.0,246.55,1.39,146.0,91806.0 +2006-03-06 10:00:00+00:00,11.29,28.26,0.0,0.0,0.0,244.9,1.43,142.0,91791.0 +2006-03-06 11:00:00+00:00,10.59,29.3,0.0,0.0,0.0,243.25,1.48,139.0,91776.0 +2006-03-06 12:00:00+00:00,11.22,27.19,0.0,0.0,0.0,241.57,1.54,138.0,91809.0 +2006-03-06 13:00:00+00:00,11.85,25.09,0.0,0.0,0.0,239.88,1.61,136.0,91842.0 +2006-03-06 14:00:00+00:00,12.48,22.98,16.0,0.0,16.0,238.2,1.68,135.0,91875.0 +2006-03-06 15:00:00+00:00,16.22,18.29,234.0,711.68,56.0,243.6,1.87,155.0,91863.0 +2006-03-06 16:00:00+00:00,19.96,13.6,463.0,874.42,75.0,249.0,2.05,174.0,91851.0 +2006-03-06 17:00:00+00:00,23.69,8.91,660.0,949.42,87.0,254.4,2.23,193.0,91839.0 +2006-03-06 18:00:00+00:00,24.84,7.53,805.0,989.37,94.0,256.68,2.98,206.0,91758.0 +2006-03-06 19:00:00+00:00,25.99,6.16,772.0,651.55,263.0,258.97,3.72,218.0,91677.0 +2006-03-06 20:00:00+00:00,27.14,4.78,749.0,566.72,303.0,261.25,4.47,230.0,91596.0 +2006-03-06 21:00:00+00:00,26.29,5.72,645.0,474.47,296.0,266.68,4.72,236.0,91581.0 +2006-03-06 22:00:00+00:00,25.44,6.67,591.0,643.99,185.0,272.12,4.97,243.0,91566.0 +2006-03-06 23:00:00+00:00,24.59,7.61,413.0,563.91,143.0,277.55,5.23,249.0,91551.0 +2006-03-07 00:00:00+00:00,22.84,9.82,199.0,326.53,103.0,279.4,4.34,253.0,91590.0 +2006-03-07 01:00:00+00:00,21.1,12.04,40.0,145.33,28.0,281.25,3.45,256.0,91629.0 +2006-03-07 02:00:00+00:00,19.35,14.25,0.0,0.0,0.0,283.1,2.57,260.0,91668.0 +2006-03-07 03:00:00+00:00,19.09,15.84,0.0,0.0,0.0,286.4,2.29,257.0,91704.0 +2006-03-07 04:00:00+00:00,18.84,17.43,0.0,0.0,0.0,289.7,2.02,254.0,91740.0 +2006-03-07 05:00:00+00:00,18.58,19.02,0.0,0.0,0.0,293.0,1.75,252.0,91776.0 +2006-03-07 06:00:00+00:00,17.97,20.9,0.0,0.0,0.0,295.48,1.54,246.0,91761.0 +2006-03-07 07:00:00+00:00,17.36,22.78,0.0,0.0,0.0,297.97,1.34,241.0,91746.0 +2006-03-07 08:00:00+00:00,16.74,24.66,0.0,0.0,0.0,300.45,1.13,235.0,91731.0 +2006-03-07 09:00:00+00:00,16.36,25.99,0.0,0.0,0.0,303.35,1.15,236.0,91725.0 +2006-03-07 10:00:00+00:00,15.98,27.31,0.0,0.0,0.0,306.25,1.18,237.0,91719.0 +2006-03-07 11:00:00+00:00,15.6,28.64,0.0,0.0,0.0,309.15,1.2,237.0,91713.0 +2006-03-07 12:00:00+00:00,15.31,30.45,0.0,0.0,0.0,307.17,1.09,226.0,91731.0 +2006-03-07 13:00:00+00:00,15.02,32.25,0.0,0.0,0.0,305.18,0.98,214.0,91749.0 +2006-03-07 14:00:00+00:00,14.74,34.06,4.0,0.0,4.0,303.2,0.87,202.0,91767.0 +2006-03-07 15:00:00+00:00,16.45,29.61,45.0,0.0,45.0,310.53,1.9,216.0,91752.0 +2006-03-07 16:00:00+00:00,18.16,25.17,125.0,0.0,125.0,317.87,2.94,229.0,91737.0 +2006-03-07 17:00:00+00:00,19.86,20.72,395.0,166.1,294.0,325.2,3.97,243.0,91722.0 +2006-03-07 18:00:00+00:00,20.32,18.97,229.0,11.06,221.0,323.7,4.76,241.0,91632.0 +2006-03-07 19:00:00+00:00,20.77,17.22,310.0,21.64,293.0,322.2,5.54,238.0,91542.0 +2006-03-07 20:00:00+00:00,21.22,15.47,587.0,228.82,406.0,320.7,6.33,236.0,91452.0 +2006-03-07 21:00:00+00:00,20.84,17.08,665.0,509.91,288.0,319.28,6.14,232.0,91382.0 +2006-03-07 22:00:00+00:00,20.46,18.7,553.0,509.48,230.0,317.87,5.95,229.0,91313.0 +2006-03-07 23:00:00+00:00,20.08,20.31,413.0,547.63,149.0,316.45,5.77,226.0,91244.0 +2006-03-08 00:00:00+00:00,19.21,23.83,215.0,404.04,95.0,305.52,5.36,225.0,91265.0 +2006-03-08 01:00:00+00:00,18.35,27.34,55.0,327.95,27.0,294.58,4.95,225.0,91286.0 +2006-03-08 02:00:00+00:00,17.48,30.86,0.0,0.0,0.0,283.65,4.54,224.0,91307.0 +2006-03-08 03:00:00+00:00,16.36,37.37,0.0,0.0,0.0,278.2,4.34,227.0,91340.0 +2006-03-08 04:00:00+00:00,15.24,43.88,0.0,0.0,0.0,272.75,4.13,229.0,91373.0 +2006-03-08 05:00:00+00:00,14.12,50.39,0.0,0.0,0.0,267.3,3.93,232.0,91406.0 +2006-03-08 06:00:00+00:00,13.3,55.26,0.0,0.0,0.0,263.52,3.74,231.0,91400.0 +2006-03-08 07:00:00+00:00,12.48,60.14,0.0,0.0,0.0,259.73,3.54,231.0,91394.0 +2006-03-08 08:00:00+00:00,11.65,65.01,0.0,0.0,0.0,255.95,3.35,231.0,91388.0 +2006-03-08 09:00:00+00:00,10.91,66.44,0.0,0.0,0.0,254.33,3.3,235.0,91400.0 +2006-03-08 10:00:00+00:00,10.16,67.88,0.0,0.0,0.0,252.72,3.24,238.0,91413.0 +2006-03-08 11:00:00+00:00,9.41,69.31,0.0,0.0,0.0,251.1,3.19,242.0,91425.0 +2006-03-08 12:00:00+00:00,9.94,66.71,0.0,0.0,0.0,253.83,3.14,245.0,91416.0 +2006-03-08 13:00:00+00:00,10.47,64.1,0.0,0.0,0.0,256.57,3.09,248.0,91406.0 +2006-03-08 14:00:00+00:00,11.01,61.5,22.0,0.0,22.0,259.3,3.05,251.0,91397.0 +2006-03-08 15:00:00+00:00,12.08,54.98,178.0,339.42,90.0,260.33,4.25,255.0,91382.0 +2006-03-08 16:00:00+00:00,13.16,48.46,464.0,854.48,77.0,261.37,5.45,260.0,91367.0 +2006-03-08 17:00:00+00:00,14.23,41.94,659.0,932.09,88.0,262.4,6.65,264.0,91352.0 +2006-03-08 18:00:00+00:00,14.99,37.03,804.0,974.6,95.0,261.07,7.25,266.0,91283.0 +2006-03-08 19:00:00+00:00,15.74,32.12,884.0,994.05,99.0,259.73,7.84,269.0,91214.0 +2006-03-08 20:00:00+00:00,16.49,27.21,891.0,996.19,99.0,258.4,8.44,272.0,91145.0 +2006-03-08 21:00:00+00:00,16.09,25.54,460.0,119.77,371.0,255.33,8.27,275.0,91118.0 +2006-03-08 22:00:00+00:00,15.68,23.86,18.0,0.0,18.0,252.27,8.1,279.0,91091.0 +2006-03-08 23:00:00+00:00,15.27,22.19,413.0,513.08,164.0,249.2,7.93,283.0,91064.0 +2006-03-09 00:00:00+00:00,14.41,23.87,276.0,713.4,62.0,244.43,6.67,288.0,91118.0 +2006-03-09 01:00:00+00:00,13.54,25.56,58.0,340.27,28.0,239.67,5.4,293.0,91172.0 +2006-03-09 02:00:00+00:00,12.68,27.24,0.0,0.0,0.0,234.9,4.14,297.0,91226.0 +2006-03-09 03:00:00+00:00,11.69,28.85,0.0,0.0,0.0,233.55,3.71,293.0,91268.0 +2006-03-09 04:00:00+00:00,10.7,30.46,0.0,0.0,0.0,232.2,3.27,288.0,91310.0 +2006-03-09 05:00:00+00:00,9.71,32.07,0.0,0.0,0.0,230.85,2.84,284.0,91352.0 +2006-03-09 06:00:00+00:00,9.22,33.48,0.0,0.0,0.0,229.82,2.62,273.0,91340.0 +2006-03-09 07:00:00+00:00,8.72,34.88,0.0,0.0,0.0,228.78,2.4,261.0,91328.0 +2006-03-09 08:00:00+00:00,8.22,36.29,0.0,0.0,0.0,227.75,2.18,250.0,91316.0 +2006-03-09 09:00:00+00:00,7.71,37.7,0.0,0.0,0.0,227.05,2.16,239.0,91289.0 +2006-03-09 10:00:00+00:00,7.19,39.11,0.0,0.0,0.0,226.35,2.13,228.0,91262.0 +2006-03-09 11:00:00+00:00,6.68,40.52,0.0,0.0,0.0,225.65,2.11,217.0,91235.0 +2006-03-09 12:00:00+00:00,7.13,39.29,0.0,0.0,0.0,225.88,1.91,211.0,91241.0 +2006-03-09 13:00:00+00:00,7.59,38.05,0.0,0.0,0.0,226.12,1.71,206.0,91247.0 +2006-03-09 14:00:00+00:00,8.05,36.82,20.0,20.23,19.0,226.35,1.5,201.0,91253.0 +2006-03-09 15:00:00+00:00,10.36,31.36,58.0,0.0,58.0,231.17,2.28,216.0,91205.0 +2006-03-09 16:00:00+00:00,12.67,25.9,325.0,284.14,195.0,235.98,3.05,230.0,91157.0 +2006-03-09 17:00:00+00:00,14.98,20.44,581.0,653.01,178.0,240.8,3.82,245.0,91109.0 +2006-03-09 18:00:00+00:00,16.16,18.92,650.0,493.25,289.0,242.38,4.79,246.0,90986.0 +2006-03-09 19:00:00+00:00,17.33,17.39,733.0,513.91,325.0,243.97,5.76,248.0,90863.0 +2006-03-09 20:00:00+00:00,18.5,15.87,883.0,979.96,100.0,245.55,6.73,249.0,90740.0 +2006-03-09 21:00:00+00:00,18.03,17.38,649.0,452.58,311.0,250.37,6.87,247.0,90662.0 +2006-03-09 22:00:00+00:00,17.56,18.89,456.0,229.36,309.0,255.18,7.02,245.0,90583.0 +2006-03-09 23:00:00+00:00,17.09,20.4,373.0,358.23,198.0,260.0,7.16,242.0,90505.0 +2006-03-10 00:00:00+00:00,16.15,23.5,147.0,85.83,121.0,260.12,6.49,241.0,90520.0 +2006-03-10 01:00:00+00:00,15.2,26.6,38.0,76.98,31.0,260.23,5.83,240.0,90535.0 +2006-03-10 02:00:00+00:00,14.26,29.7,0.0,0.0,0.0,260.35,5.16,238.0,90550.0 +2006-03-10 03:00:00+00:00,13.27,34.26,0.0,0.0,0.0,256.72,5.05,234.0,90577.0 +2006-03-10 04:00:00+00:00,12.27,38.82,0.0,0.0,0.0,253.08,4.95,230.0,90604.0 +2006-03-10 05:00:00+00:00,11.28,43.38,0.0,0.0,0.0,249.45,4.84,226.0,90631.0 +2006-03-10 06:00:00+00:00,10.6,50.31,0.0,0.0,0.0,246.62,4.89,223.0,90631.0 +2006-03-10 07:00:00+00:00,9.92,57.25,0.0,0.0,0.0,243.78,4.94,220.0,90631.0 +2006-03-10 08:00:00+00:00,9.23,64.18,0.0,0.0,0.0,240.95,4.99,217.0,90631.0 +2006-03-10 09:00:00+00:00,8.75,74.9,0.0,0.0,0.0,240.28,4.9,216.0,90650.0 +2006-03-10 10:00:00+00:00,8.27,85.62,0.0,0.0,0.0,239.62,4.8,216.0,90668.0 +2006-03-10 11:00:00+00:00,7.79,96.34,0.0,0.0,0.0,238.95,4.7,215.0,90686.0 +2006-03-10 12:00:00+00:00,8.49,91.89,0.0,0.0,0.0,240.82,4.51,214.0,90713.0 +2006-03-10 13:00:00+00:00,9.19,87.44,0.0,0.0,0.0,242.68,4.33,213.0,90740.0 +2006-03-10 14:00:00+00:00,9.89,82.99,36.0,259.16,22.0,244.55,4.14,211.0,90767.0 +2006-03-10 15:00:00+00:00,10.93,76.39,248.0,700.13,60.0,248.13,5.78,217.0,90791.0 +2006-03-10 16:00:00+00:00,11.97,69.78,476.0,859.05,79.0,251.72,7.43,222.0,90815.0 +2006-03-10 17:00:00+00:00,13.0,63.18,222.0,14.48,213.0,255.3,9.08,228.0,90839.0 +2006-03-10 18:00:00+00:00,13.99,54.74,816.0,976.55,97.0,259.97,9.26,229.0,90779.0 +2006-03-10 19:00:00+00:00,14.98,46.31,894.0,993.61,101.0,264.63,9.43,230.0,90719.0 +2006-03-10 20:00:00+00:00,15.96,37.87,666.0,359.92,377.0,269.3,9.61,231.0,90659.0 +2006-03-10 21:00:00+00:00,15.64,36.94,834.0,980.66,98.0,267.48,9.27,231.0,90622.0 +2006-03-10 22:00:00+00:00,15.31,36.01,700.0,943.6,92.0,265.67,8.93,231.0,90586.0 +2006-03-10 23:00:00+00:00,14.98,35.08,510.0,872.53,81.0,263.85,8.59,230.0,90550.0 +2006-03-11 00:00:00+00:00,14.36,39.49,286.0,732.45,62.0,267.02,8.03,229.0,90607.0 +2006-03-11 01:00:00+00:00,13.74,43.91,63.0,352.29,30.0,270.18,7.46,227.0,90665.0 +2006-03-11 02:00:00+00:00,13.12,48.32,0.0,0.0,0.0,273.35,6.9,226.0,90722.0 +2006-03-11 03:00:00+00:00,12.35,53.18,0.0,0.0,0.0,270.35,6.7,224.0,90779.0 +2006-03-11 04:00:00+00:00,11.59,58.03,0.0,0.0,0.0,267.35,6.51,222.0,90836.0 +2006-03-11 05:00:00+00:00,10.82,62.89,0.0,0.0,0.0,264.35,6.32,220.0,90893.0 +2006-03-11 06:00:00+00:00,10.14,71.29,0.0,0.0,0.0,259.55,6.31,218.0,90905.0 +2006-03-11 07:00:00+00:00,9.45,79.7,0.0,0.0,0.0,254.75,6.3,216.0,90917.0 +2006-03-11 08:00:00+00:00,8.76,88.1,0.0,0.0,0.0,249.95,6.29,214.0,90929.0 +2006-03-11 09:00:00+00:00,8.36,92.07,0.0,0.0,0.0,257.95,6.23,213.0,90920.0 +2006-03-11 10:00:00+00:00,7.95,96.03,0.0,0.0,0.0,265.95,6.16,212.0,90911.0 +2006-03-11 11:00:00+00:00,7.54,100.0,0.0,0.0,0.0,273.95,6.1,211.0,90902.0 +2006-03-11 12:00:00+00:00,7.71,100.0,0.0,0.0,0.0,275.78,6.29,209.0,90920.0 +2006-03-11 13:00:00+00:00,7.88,100.0,0.0,0.0,0.0,277.62,6.48,207.0,90938.0 +2006-03-11 14:00:00+00:00,8.05,100.0,39.0,289.92,22.0,279.45,6.68,206.0,90956.0 +2006-03-11 15:00:00+00:00,8.36,99.86,250.0,702.84,58.0,279.57,7.77,208.0,90989.0 +2006-03-11 16:00:00+00:00,8.67,99.71,476.0,854.82,77.0,279.68,8.87,210.0,91022.0 +2006-03-11 17:00:00+00:00,8.98,99.57,491.0,333.75,282.0,279.8,9.97,213.0,91055.0 +2006-03-11 18:00:00+00:00,9.45,97.19,812.0,968.08,95.0,281.63,10.24,214.0,91007.0 +2006-03-11 19:00:00+00:00,9.92,94.8,708.0,456.21,342.0,283.47,10.51,216.0,90959.0 +2006-03-11 20:00:00+00:00,10.38,92.42,684.0,382.96,375.0,285.3,10.77,217.0,90911.0 +2006-03-11 21:00:00+00:00,10.03,94.95,512.0,168.4,385.0,286.23,10.34,217.0,90884.0 +2006-03-11 22:00:00+00:00,9.68,97.47,403.0,134.32,316.0,287.17,9.9,217.0,90857.0 +2006-03-11 23:00:00+00:00,9.32,100.0,228.0,46.48,205.0,288.1,9.46,217.0,90830.0 +2006-03-12 00:00:00+00:00,9.47,100.0,53.0,0.0,53.0,290.35,9.26,217.0,90890.0 +2006-03-12 01:00:00+00:00,9.62,100.0,7.0,0.0,7.0,292.6,9.05,218.0,90950.0 +2006-03-12 02:00:00+00:00,9.77,100.0,0.0,0.0,0.0,294.85,8.84,218.0,91010.0 +2006-03-12 03:00:00+00:00,9.47,100.0,0.0,0.0,0.0,304.5,9.33,218.0,91067.0 +2006-03-12 04:00:00+00:00,9.17,100.0,0.0,0.0,0.0,314.15,9.82,218.0,91124.0 +2006-03-12 05:00:00+00:00,8.87,100.0,0.0,0.0,0.0,323.8,10.3,218.0,91181.0 +2006-03-12 06:00:00+00:00,8.62,100.0,0.0,0.0,0.0,325.77,10.24,220.0,91217.0 +2006-03-12 07:00:00+00:00,8.36,100.0,0.0,0.0,0.0,327.73,10.17,221.0,91253.0 +2006-03-12 08:00:00+00:00,8.1,100.0,0.0,0.0,0.0,329.7,10.11,222.0,91289.0 +2006-03-12 09:00:00+00:00,7.75,99.79,0.0,0.0,0.0,330.0,9.92,225.0,91346.0 +2006-03-12 10:00:00+00:00,7.39,99.57,0.0,0.0,0.0,330.3,9.72,228.0,91403.0 +2006-03-12 11:00:00+00:00,7.04,99.36,0.0,0.0,0.0,330.6,9.53,231.0,91461.0 +2006-03-12 12:00:00+00:00,6.91,99.53,0.0,0.0,0.0,330.65,8.9,237.0,91569.0 +2006-03-12 13:00:00+00:00,6.78,99.69,0.0,0.0,0.0,330.7,8.26,244.0,91677.0 +2006-03-12 14:00:00+00:00,6.66,99.86,21.0,0.0,21.0,330.75,7.63,251.0,91785.0 +2006-03-12 15:00:00+00:00,6.97,86.41,214.0,478.67,81.0,327.78,7.14,251.0,91839.0 +2006-03-12 16:00:00+00:00,7.28,72.97,493.0,878.24,79.0,324.82,6.65,252.0,91893.0 +2006-03-12 17:00:00+00:00,7.58,59.52,693.0,956.03,90.0,321.85,6.17,253.0,91947.0 +2006-03-12 18:00:00+00:00,8.85,53.5,839.0,995.98,97.0,313.17,6.19,254.0,91884.0 +2006-03-12 19:00:00+00:00,10.12,47.48,760.0,558.04,310.0,304.48,6.21,254.0,91821.0 +2006-03-12 20:00:00+00:00,11.38,41.46,726.0,474.87,341.0,295.8,6.23,255.0,91758.0 +2006-03-12 21:00:00+00:00,11.43,40.77,699.0,539.74,290.0,278.23,5.85,256.0,91722.0 +2006-03-12 22:00:00+00:00,11.48,40.07,719.0,964.58,91.0,260.67,5.46,257.0,91686.0 +2006-03-12 23:00:00+00:00,11.52,39.38,527.0,895.78,81.0,243.1,5.08,258.0,91650.0 +2006-03-13 00:00:00+00:00,10.65,51.25,298.0,751.07,64.0,246.42,4.18,265.0,91737.0 +2006-03-13 01:00:00+00:00,9.79,63.13,70.0,383.49,32.0,249.73,3.28,273.0,91824.0 +2006-03-13 02:00:00+00:00,8.92,75.0,0.0,0.0,0.0,253.05,2.39,280.0,91911.0 +2006-03-13 03:00:00+00:00,8.16,74.32,0.0,0.0,0.0,247.93,2.09,289.0,91971.0 +2006-03-13 04:00:00+00:00,7.39,73.65,0.0,0.0,0.0,242.82,1.79,297.0,92031.0 +2006-03-13 05:00:00+00:00,6.63,72.97,0.0,0.0,0.0,237.7,1.49,306.0,92091.0 +2006-03-13 06:00:00+00:00,5.83,77.51,0.0,0.0,0.0,235.12,1.59,323.0,92112.0 +2006-03-13 07:00:00+00:00,5.03,82.05,0.0,0.0,0.0,232.53,1.69,341.0,92133.0 +2006-03-13 08:00:00+00:00,4.23,86.59,0.0,0.0,0.0,229.95,1.79,358.0,92154.0 +2006-03-13 09:00:00+00:00,3.76,88.42,0.0,0.0,0.0,228.28,1.84,11.0,92145.0 +2006-03-13 10:00:00+00:00,3.29,90.25,0.0,0.0,0.0,226.62,1.89,23.0,92136.0 +2006-03-13 11:00:00+00:00,2.82,92.08,0.0,0.0,0.0,224.95,1.93,35.0,92127.0 +2006-03-13 12:00:00+00:00,3.77,88.25,0.0,0.0,0.0,225.02,1.83,38.0,92163.0 +2006-03-13 13:00:00+00:00,4.73,84.42,0.0,0.0,0.0,225.08,1.72,41.0,92200.0 +2006-03-13 14:00:00+00:00,5.69,80.59,49.0,338.46,26.0,225.15,1.61,44.0,92236.0 +2006-03-13 15:00:00+00:00,7.79,67.75,271.0,739.71,62.0,228.72,1.64,44.0,92215.0 +2006-03-13 16:00:00+00:00,9.89,54.9,504.0,890.69,80.0,232.28,1.66,44.0,92194.0 +2006-03-13 17:00:00+00:00,11.99,42.06,703.0,963.41,91.0,235.85,1.68,44.0,92172.0 +2006-03-13 18:00:00+00:00,13.32,39.92,847.0,999.57,98.0,238.03,1.43,38.0,92061.0 +2006-03-13 19:00:00+00:00,14.65,37.79,926.0,1016.66,102.0,240.22,1.19,32.0,91950.0 +2006-03-13 20:00:00+00:00,15.97,35.65,930.0,1016.45,102.0,242.4,0.94,26.0,91839.0 +2006-03-13 21:00:00+00:00,16.06,35.07,862.0,1002.18,99.0,243.4,1.19,15.0,91779.0 +2006-03-13 22:00:00+00:00,16.14,34.48,725.0,967.35,92.0,244.4,1.43,4.0,91719.0 +2006-03-13 23:00:00+00:00,16.22,33.9,532.0,898.3,82.0,245.4,1.68,353.0,91659.0 +2006-03-14 00:00:00+00:00,14.65,42.87,302.0,753.88,65.0,243.97,2.02,0.0,91695.0 +2006-03-14 01:00:00+00:00,13.09,51.83,72.0,393.06,32.0,242.53,2.35,7.0,91731.0 +2006-03-14 02:00:00+00:00,11.52,60.8,0.0,0.0,0.0,241.1,2.69,14.0,91767.0 +2006-03-14 03:00:00+00:00,10.38,65.21,0.0,0.0,0.0,240.63,2.46,28.0,91770.0 +2006-03-14 04:00:00+00:00,9.25,69.62,0.0,0.0,0.0,240.17,2.23,42.0,91773.0 +2006-03-14 05:00:00+00:00,8.11,74.03,0.0,0.0,0.0,239.7,2.0,57.0,91776.0 +2006-03-14 06:00:00+00:00,7.32,77.77,0.0,0.0,0.0,237.97,2.01,62.0,91740.0 +2006-03-14 07:00:00+00:00,6.53,81.52,0.0,0.0,0.0,236.23,2.03,67.0,91704.0 +2006-03-14 08:00:00+00:00,5.73,85.26,0.0,0.0,0.0,234.5,2.04,72.0,91668.0 +2006-03-14 09:00:00+00:00,5.2,86.18,0.0,0.0,0.0,233.33,2.08,72.0,91629.0 +2006-03-14 10:00:00+00:00,4.66,87.1,0.0,0.0,0.0,232.17,2.11,73.0,91590.0 +2006-03-14 11:00:00+00:00,4.13,88.02,0.0,0.0,0.0,231.0,2.15,73.0,91551.0 +2006-03-14 12:00:00+00:00,5.25,83.45,0.0,0.0,0.0,231.1,2.11,77.0,91614.0 +2006-03-14 13:00:00+00:00,6.38,78.88,0.0,0.0,0.0,231.2,2.08,81.0,91677.0 +2006-03-14 14:00:00+00:00,7.51,74.31,53.0,357.88,27.0,231.3,2.04,84.0,91740.0 +2006-03-14 15:00:00+00:00,11.34,61.56,278.0,748.49,63.0,237.7,2.31,89.0,91671.0 +2006-03-14 16:00:00+00:00,15.17,48.81,510.0,892.5,81.0,244.1,2.58,94.0,91602.0 +2006-03-14 17:00:00+00:00,18.99,36.06,708.0,962.88,92.0,250.5,2.86,99.0,91533.0 +2006-03-14 18:00:00+00:00,20.68,33.06,850.0,996.5,99.0,256.88,3.04,115.0,91422.0 +2006-03-14 19:00:00+00:00,22.37,30.06,925.0,1010.35,102.0,263.27,3.23,131.0,91310.0 +2006-03-14 20:00:00+00:00,24.05,27.06,926.0,1006.84,102.0,269.65,3.42,146.0,91199.0 +2006-03-14 21:00:00+00:00,23.52,26.95,690.0,504.66,304.0,277.7,3.77,170.0,91136.0 +2006-03-14 22:00:00+00:00,22.99,26.84,572.0,498.77,244.0,285.75,4.13,193.0,91073.0 +2006-03-14 23:00:00+00:00,22.45,26.73,246.0,59.53,216.0,293.8,4.48,216.0,91010.0 +2006-03-15 00:00:00+00:00,20.71,37.64,260.0,536.0,90.0,296.1,3.75,216.0,91043.0 +2006-03-15 01:00:00+00:00,18.96,48.54,62.0,268.15,34.0,298.4,3.01,215.0,91076.0 +2006-03-15 02:00:00+00:00,17.22,59.45,0.0,0.0,0.0,300.7,2.28,214.0,91109.0 +2006-03-15 03:00:00+00:00,16.68,62.29,0.0,0.0,0.0,297.27,2.27,214.0,91142.0 +2006-03-15 04:00:00+00:00,16.13,65.12,0.0,0.0,0.0,293.83,2.27,214.0,91175.0 +2006-03-15 05:00:00+00:00,15.59,67.96,0.0,0.0,0.0,290.4,2.26,214.0,91208.0 +2006-03-15 06:00:00+00:00,14.99,69.59,0.0,0.0,0.0,291.32,2.19,215.0,91217.0 +2006-03-15 07:00:00+00:00,14.38,71.23,0.0,0.0,0.0,292.23,2.11,216.0,91226.0 +2006-03-15 08:00:00+00:00,13.77,72.86,0.0,0.0,0.0,293.15,2.04,218.0,91235.0 +2006-03-15 09:00:00+00:00,13.4,71.94,0.0,0.0,0.0,295.77,1.95,224.0,91268.0 +2006-03-15 10:00:00+00:00,13.02,71.02,0.0,0.0,0.0,298.38,1.86,230.0,91301.0 +2006-03-15 11:00:00+00:00,12.64,70.1,0.0,0.0,0.0,301.0,1.77,237.0,91334.0 +2006-03-15 12:00:00+00:00,12.93,65.82,0.0,0.0,0.0,306.33,1.57,219.0,91410.0 +2006-03-15 13:00:00+00:00,13.22,61.54,0.0,0.0,0.0,311.67,1.37,202.0,91485.0 +2006-03-15 14:00:00+00:00,13.51,57.26,53.0,336.06,27.0,317.0,1.17,185.0,91560.0 +2006-03-15 15:00:00+00:00,15.6,48.12,272.0,719.29,62.0,315.85,1.61,201.0,91590.0 +2006-03-15 16:00:00+00:00,17.69,38.98,501.0,867.5,80.0,314.7,2.06,218.0,91620.0 +2006-03-15 17:00:00+00:00,19.77,29.84,699.0,942.2,92.0,313.55,2.5,234.0,91650.0 +2006-03-15 18:00:00+00:00,20.91,27.88,844.0,982.95,99.0,302.8,3.45,239.0,91605.0 +2006-03-15 19:00:00+00:00,22.05,25.92,925.0,1004.14,103.0,292.05,4.4,243.0,91560.0 +2006-03-15 20:00:00+00:00,23.18,23.96,931.0,1007.09,103.0,281.3,5.35,248.0,91515.0 +2006-03-15 21:00:00+00:00,22.86,23.63,863.0,993.02,100.0,278.47,5.27,253.0,91494.0 +2006-03-15 22:00:00+00:00,22.54,23.31,727.0,959.38,93.0,275.63,5.2,258.0,91473.0 +2006-03-15 23:00:00+00:00,22.22,22.98,535.0,891.61,83.0,272.8,5.12,262.0,91452.0 +2006-03-16 00:00:00+00:00,20.35,33.58,305.0,747.06,66.0,271.23,4.23,262.0,91494.0 +2006-03-16 01:00:00+00:00,18.49,44.18,76.0,392.33,34.0,269.67,3.33,261.0,91536.0 +2006-03-16 02:00:00+00:00,16.62,54.78,0.0,0.0,0.0,268.1,2.44,260.0,91578.0 +2006-03-16 03:00:00+00:00,16.63,54.21,0.0,0.0,0.0,266.23,1.98,253.0,91629.0 +2006-03-16 04:00:00+00:00,16.65,53.64,0.0,0.0,0.0,264.37,1.51,245.0,91680.0 +2006-03-16 05:00:00+00:00,16.66,53.07,0.0,0.0,0.0,262.5,1.05,237.0,91731.0 +2006-03-16 06:00:00+00:00,14.87,59.64,0.0,0.0,0.0,261.52,1.05,212.0,91713.0 +2006-03-16 07:00:00+00:00,13.08,66.2,0.0,0.0,0.0,260.53,1.05,187.0,91695.0 +2006-03-16 08:00:00+00:00,11.29,72.77,0.0,0.0,0.0,259.55,1.05,162.0,91677.0 +2006-03-16 09:00:00+00:00,10.33,76.62,0.0,0.0,0.0,258.7,1.31,152.0,91665.0 +2006-03-16 10:00:00+00:00,9.36,80.47,0.0,0.0,0.0,257.85,1.56,142.0,91653.0 +2006-03-16 11:00:00+00:00,8.39,84.32,0.0,0.0,0.0,257.0,1.82,132.0,91641.0 +2006-03-16 12:00:00+00:00,9.94,80.26,0.0,0.0,0.0,258.07,1.76,134.0,91668.0 +2006-03-16 13:00:00+00:00,11.49,76.19,0.0,0.0,0.0,259.13,1.69,135.0,91695.0 +2006-03-16 14:00:00+00:00,13.04,72.13,59.0,365.41,29.0,260.2,1.63,137.0,91722.0 +2006-03-16 15:00:00+00:00,16.07,57.09,285.0,744.93,64.0,264.1,2.2,154.0,91704.0 +2006-03-16 16:00:00+00:00,19.11,42.05,392.0,420.47,186.0,268.0,2.77,171.0,91686.0 +2006-03-16 17:00:00+00:00,22.14,27.01,612.0,645.9,193.0,271.9,3.34,188.0,91668.0 +2006-03-16 18:00:00+00:00,23.12,23.94,852.0,986.64,100.0,274.92,4.09,198.0,91593.0 +2006-03-16 19:00:00+00:00,24.09,20.86,597.0,206.66,427.0,277.93,4.84,208.0,91518.0 +2006-03-16 20:00:00+00:00,25.06,17.79,644.0,272.43,419.0,280.95,5.59,217.0,91443.0 +2006-03-16 21:00:00+00:00,24.28,17.55,636.0,353.71,363.0,288.53,5.56,222.0,91406.0 +2006-03-16 22:00:00+00:00,23.5,17.31,550.0,399.08,285.0,296.12,5.53,227.0,91370.0 +2006-03-16 23:00:00+00:00,22.72,17.07,280.0,100.02,229.0,303.7,5.5,231.0,91334.0 +2006-03-17 00:00:00+00:00,21.57,23.59,78.0,0.0,78.0,306.25,4.75,230.0,91346.0 +2006-03-17 01:00:00+00:00,20.41,30.1,30.0,0.0,30.0,308.8,4.0,229.0,91358.0 +2006-03-17 02:00:00+00:00,19.26,36.62,0.0,0.0,0.0,311.35,3.24,228.0,91370.0 +2006-03-17 03:00:00+00:00,18.01,40.54,0.0,0.0,0.0,307.17,2.9,220.0,91391.0 +2006-03-17 04:00:00+00:00,16.77,44.47,0.0,0.0,0.0,302.98,2.55,212.0,91413.0 +2006-03-17 05:00:00+00:00,15.52,48.39,0.0,0.0,0.0,298.8,2.21,204.0,91434.0 +2006-03-17 06:00:00+00:00,14.33,50.48,0.0,0.0,0.0,286.88,2.24,200.0,91422.0 +2006-03-17 07:00:00+00:00,13.14,52.58,0.0,0.0,0.0,274.97,2.27,196.0,91410.0 +2006-03-17 08:00:00+00:00,11.95,54.67,0.0,0.0,0.0,263.05,2.3,192.0,91397.0 +2006-03-17 09:00:00+00:00,11.48,55.48,0.0,0.0,0.0,261.92,2.26,189.0,91388.0 +2006-03-17 10:00:00+00:00,11.01,56.3,0.0,0.0,0.0,260.78,2.21,186.0,91379.0 +2006-03-17 11:00:00+00:00,10.54,57.11,0.0,0.0,0.0,259.65,2.17,183.0,91370.0 +2006-03-17 12:00:00+00:00,11.65,54.06,0.0,0.0,0.0,265.95,2.13,178.0,91400.0 +2006-03-17 13:00:00+00:00,12.76,51.02,0.0,0.0,0.0,272.25,2.09,173.0,91431.0 +2006-03-17 14:00:00+00:00,13.87,47.97,26.0,0.0,26.0,278.55,2.06,168.0,91461.0 +2006-03-17 15:00:00+00:00,16.22,40.16,63.0,0.0,63.0,289.95,2.89,178.0,91434.0 +2006-03-17 16:00:00+00:00,18.58,32.36,256.0,76.84,218.0,301.35,3.73,187.0,91406.0 +2006-03-17 17:00:00+00:00,20.93,24.55,453.0,206.69,318.0,312.75,4.57,197.0,91379.0 +2006-03-17 18:00:00+00:00,21.73,21.78,702.0,523.22,301.0,314.53,5.44,204.0,91301.0 +2006-03-17 19:00:00+00:00,22.52,19.0,791.0,552.87,334.0,316.32,6.31,211.0,91223.0 +2006-03-17 20:00:00+00:00,23.31,16.23,702.0,397.79,372.0,318.1,7.19,218.0,91145.0 +2006-03-17 21:00:00+00:00,22.88,16.37,859.0,979.08,100.0,313.78,6.99,220.0,91088.0 +2006-03-17 22:00:00+00:00,22.45,16.52,724.0,944.29,94.0,309.47,6.8,223.0,91031.0 +2006-03-17 23:00:00+00:00,22.01,16.66,532.0,875.58,83.0,305.15,6.61,225.0,90974.0 +2006-03-18 00:00:00+00:00,20.73,21.43,305.0,734.6,66.0,299.58,5.62,224.0,90977.0 +2006-03-18 01:00:00+00:00,19.44,26.21,78.0,391.96,34.0,294.02,4.63,223.0,90980.0 +2006-03-18 02:00:00+00:00,18.16,30.98,0.0,0.0,0.0,288.45,3.64,222.0,90983.0 +2006-03-18 03:00:00+00:00,17.05,34.63,0.0,0.0,0.0,295.7,3.27,217.0,90995.0 +2006-03-18 04:00:00+00:00,15.94,38.29,0.0,0.0,0.0,302.95,2.9,211.0,91007.0 +2006-03-18 05:00:00+00:00,14.83,41.94,0.0,0.0,0.0,310.2,2.52,206.0,91019.0 +2006-03-18 06:00:00+00:00,14.3,43.1,0.0,0.0,0.0,312.3,2.59,206.0,91007.0 +2006-03-18 07:00:00+00:00,13.76,44.27,0.0,0.0,0.0,314.4,2.65,207.0,90995.0 +2006-03-18 08:00:00+00:00,13.22,45.43,0.0,0.0,0.0,316.5,2.72,208.0,90983.0 +2006-03-18 09:00:00+00:00,12.64,47.78,0.0,0.0,0.0,314.37,2.7,209.0,90959.0 +2006-03-18 10:00:00+00:00,12.05,50.12,0.0,0.0,0.0,312.23,2.68,210.0,90935.0 +2006-03-18 11:00:00+00:00,11.47,52.47,0.0,0.0,0.0,310.1,2.66,211.0,90911.0 +2006-03-18 12:00:00+00:00,12.29,51.21,0.0,0.0,0.0,302.72,2.79,206.0,90905.0 +2006-03-18 13:00:00+00:00,13.11,49.94,0.0,0.0,0.0,295.33,2.91,202.0,90899.0 +2006-03-18 14:00:00+00:00,13.94,48.68,66.0,382.04,31.0,287.95,3.03,198.0,90893.0 +2006-03-18 15:00:00+00:00,15.24,44.69,290.0,738.29,64.0,284.63,4.54,200.0,90875.0 +2006-03-18 16:00:00+00:00,16.54,40.71,519.0,875.48,82.0,281.32,6.04,203.0,90857.0 +2006-03-18 17:00:00+00:00,17.83,36.72,714.0,944.36,93.0,278.0,7.54,205.0,90839.0 +2006-03-18 18:00:00+00:00,18.39,35.61,853.0,977.15,100.0,275.87,8.54,209.0,90800.0 +2006-03-18 19:00:00+00:00,18.94,34.5,925.0,989.74,103.0,273.73,9.54,212.0,90761.0 +2006-03-18 20:00:00+00:00,19.49,33.39,926.0,987.71,103.0,271.6,10.54,216.0,90722.0 +2006-03-18 21:00:00+00:00,18.63,34.45,855.0,969.72,100.0,270.62,9.99,217.0,90695.0 +2006-03-18 22:00:00+00:00,17.77,35.51,720.0,935.46,93.0,269.63,9.44,219.0,90668.0 +2006-03-18 23:00:00+00:00,16.9,36.57,530.0,866.83,83.0,268.65,8.9,221.0,90640.0 +2006-03-19 00:00:00+00:00,15.92,37.89,304.0,725.57,66.0,265.65,7.76,226.0,90698.0 +2006-03-19 01:00:00+00:00,14.93,39.2,79.0,383.19,35.0,262.65,6.62,231.0,90755.0 +2006-03-19 02:00:00+00:00,13.95,40.52,0.0,0.0,0.0,259.65,5.48,237.0,90812.0 +2006-03-19 03:00:00+00:00,12.83,45.49,0.0,0.0,0.0,257.57,4.87,237.0,90863.0 +2006-03-19 04:00:00+00:00,11.72,50.46,0.0,0.0,0.0,255.48,4.27,238.0,90914.0 +2006-03-19 05:00:00+00:00,10.6,55.43,0.0,0.0,0.0,253.4,3.67,238.0,90965.0 +2006-03-19 06:00:00+00:00,9.85,58.75,0.0,0.0,0.0,249.13,3.35,233.0,90959.0 +2006-03-19 07:00:00+00:00,9.1,62.08,0.0,0.0,0.0,244.87,3.03,227.0,90953.0 +2006-03-19 08:00:00+00:00,8.34,65.4,0.0,0.0,0.0,240.6,2.72,222.0,90947.0 +2006-03-19 09:00:00+00:00,7.81,69.93,0.0,0.0,0.0,238.58,2.72,217.0,90932.0 +2006-03-19 10:00:00+00:00,7.27,74.47,0.0,0.0,0.0,236.57,2.73,213.0,90917.0 +2006-03-19 11:00:00+00:00,6.74,79.0,0.0,0.0,0.0,234.55,2.73,209.0,90902.0 +2006-03-19 12:00:00+00:00,7.05,77.28,0.0,0.0,0.0,242.82,2.95,210.0,90911.0 +2006-03-19 13:00:00+00:00,7.36,75.55,0.0,0.0,0.0,251.08,3.16,211.0,90920.0 +2006-03-19 14:00:00+00:00,7.68,73.83,69.0,383.87,32.0,259.35,3.38,212.0,90929.0 +2006-03-19 15:00:00+00:00,7.89,73.85,257.0,572.65,79.0,263.18,4.75,214.0,90953.0 +2006-03-19 16:00:00+00:00,8.1,73.86,240.0,51.61,214.0,267.02,6.13,215.0,90977.0 +2006-03-19 17:00:00+00:00,8.3,73.88,327.0,51.36,293.0,270.85,7.5,217.0,91001.0 +2006-03-19 18:00:00+00:00,8.8,73.79,414.0,63.24,365.0,269.6,7.51,222.0,90959.0 +2006-03-19 19:00:00+00:00,9.3,73.71,227.0,11.98,217.0,268.35,7.51,227.0,90917.0 +2006-03-19 20:00:00+00:00,9.8,73.62,352.0,26.29,330.0,267.1,7.52,232.0,90875.0 +2006-03-19 21:00:00+00:00,9.12,73.77,308.0,23.02,290.0,270.55,7.2,236.0,90887.0 +2006-03-19 22:00:00+00:00,8.44,73.91,448.0,173.77,331.0,274.0,6.89,240.0,90899.0 +2006-03-19 23:00:00+00:00,7.76,74.06,212.0,25.07,199.0,277.45,6.58,244.0,90911.0 +2006-03-20 00:00:00+00:00,7.48,76.66,135.0,30.24,125.0,277.48,5.7,247.0,91004.0 +2006-03-20 01:00:00+00:00,7.19,79.25,82.0,400.41,35.0,277.52,4.81,249.0,91097.0 +2006-03-20 02:00:00+00:00,6.91,81.85,0.0,0.0,0.0,277.55,3.93,251.0,91190.0 +2006-03-20 03:00:00+00:00,6.77,83.62,0.0,0.0,0.0,286.08,3.64,248.0,91262.0 +2006-03-20 04:00:00+00:00,6.64,85.39,0.0,0.0,0.0,294.62,3.34,245.0,91334.0 +2006-03-20 05:00:00+00:00,6.5,87.16,0.0,0.0,0.0,303.15,3.05,242.0,91406.0 +2006-03-20 06:00:00+00:00,6.03,88.9,0.0,0.0,0.0,292.03,2.8,239.0,91437.0 +2006-03-20 07:00:00+00:00,5.55,90.63,0.0,0.0,0.0,280.92,2.54,236.0,91467.0 +2006-03-20 08:00:00+00:00,5.07,92.37,0.0,0.0,0.0,269.8,2.29,233.0,91497.0 +2006-03-20 09:00:00+00:00,4.57,93.45,0.0,0.0,0.0,260.5,1.94,225.0,91515.0 +2006-03-20 10:00:00+00:00,4.06,94.52,0.0,0.0,0.0,251.2,1.6,218.0,91533.0 +2006-03-20 11:00:00+00:00,3.56,95.6,0.0,0.0,0.0,241.9,1.26,211.0,91551.0 +2006-03-20 12:00:00+00:00,4.5,91.58,0.0,0.0,0.0,236.62,1.28,205.0,91572.0 +2006-03-20 13:00:00+00:00,5.44,87.56,0.0,0.0,0.0,231.33,1.31,200.0,91593.0 +2006-03-20 14:00:00+00:00,6.38,83.54,74.0,405.27,33.0,226.05,1.34,194.0,91614.0 +2006-03-20 15:00:00+00:00,7.83,72.45,301.0,744.73,66.0,234.87,1.59,215.0,91596.0 +2006-03-20 16:00:00+00:00,9.29,61.35,531.0,879.35,84.0,243.68,1.83,236.0,91578.0 +2006-03-20 17:00:00+00:00,10.74,50.26,727.0,948.41,95.0,252.5,2.08,257.0,91560.0 +2006-03-20 18:00:00+00:00,11.89,46.53,606.0,290.15,380.0,247.52,2.57,253.0,91491.0 +2006-03-20 19:00:00+00:00,13.04,42.8,943.0,999.68,105.0,242.53,3.07,248.0,91422.0 +2006-03-20 20:00:00+00:00,14.18,39.07,778.0,497.38,360.0,237.55,3.56,244.0,91352.0 +2006-03-20 21:00:00+00:00,14.35,38.91,695.0,475.06,322.0,238.12,3.77,246.0,91295.0 +2006-03-20 22:00:00+00:00,14.51,38.76,582.0,474.62,261.0,238.68,3.97,247.0,91238.0 +2006-03-20 23:00:00+00:00,14.67,38.6,404.0,372.14,210.0,239.25,4.18,249.0,91181.0 +2006-03-21 00:00:00+00:00,13.62,46.94,235.0,357.07,116.0,238.73,3.49,247.0,91220.0 +2006-03-21 01:00:00+00:00,12.57,55.29,47.0,50.04,41.0,238.22,2.79,245.0,91259.0 +2006-03-21 02:00:00+00:00,11.52,63.63,0.0,0.0,0.0,237.7,2.1,243.0,91298.0 +2006-03-21 03:00:00+00:00,10.81,67.34,0.0,0.0,0.0,239.42,1.95,236.0,91337.0 +2006-03-21 04:00:00+00:00,10.1,71.04,0.0,0.0,0.0,241.13,1.8,229.0,91376.0 +2006-03-21 05:00:00+00:00,9.39,74.75,0.0,0.0,0.0,242.85,1.66,221.0,91416.0 +2006-03-21 06:00:00+00:00,8.4,80.26,0.0,0.0,0.0,241.22,1.72,206.0,91406.0 +2006-03-21 07:00:00+00:00,7.41,85.77,0.0,0.0,0.0,239.58,1.79,191.0,91397.0 +2006-03-21 08:00:00+00:00,6.42,91.28,0.0,0.0,0.0,237.95,1.86,176.0,91388.0 +2006-03-21 09:00:00+00:00,6.07,92.71,0.0,0.0,0.0,236.67,2.01,170.0,91382.0 +2006-03-21 10:00:00+00:00,5.71,94.13,0.0,0.0,0.0,235.38,2.17,164.0,91376.0 +2006-03-21 11:00:00+00:00,5.36,95.56,0.0,0.0,0.0,234.1,2.32,157.0,91370.0 +2006-03-21 12:00:00+00:00,6.88,88.94,0.0,0.0,0.0,235.67,2.34,162.0,91406.0 +2006-03-21 13:00:00+00:00,8.4,82.32,0.0,0.0,0.0,237.23,2.35,167.0,91443.0 +2006-03-21 14:00:00+00:00,9.93,75.7,79.0,415.28,35.0,238.8,2.37,172.0,91479.0 +2006-03-21 15:00:00+00:00,11.81,63.97,307.0,749.39,67.0,243.2,3.27,184.0,91434.0 +2006-03-21 16:00:00+00:00,13.69,52.25,537.0,883.22,84.0,247.6,4.17,196.0,91388.0 +2006-03-21 17:00:00+00:00,15.56,40.52,731.0,948.22,95.0,252.0,5.06,209.0,91343.0 +2006-03-21 18:00:00+00:00,16.5,37.61,871.0,982.11,102.0,253.73,5.84,214.0,91271.0 +2006-03-21 19:00:00+00:00,17.44,34.71,944.0,996.34,105.0,255.47,6.62,219.0,91199.0 +2006-03-21 20:00:00+00:00,18.37,31.8,944.0,994.17,105.0,257.2,7.39,224.0,91127.0 +2006-03-21 21:00:00+00:00,17.8,33.12,871.0,975.39,102.0,257.57,7.36,226.0,91097.0 +2006-03-21 22:00:00+00:00,17.22,34.44,733.0,939.2,95.0,257.93,7.32,228.0,91067.0 +2006-03-21 23:00:00+00:00,16.64,35.76,541.0,872.03,84.0,258.3,7.28,231.0,91037.0 +2006-03-22 00:00:00+00:00,15.64,39.78,314.0,732.47,68.0,257.45,6.39,238.0,91115.0 +2006-03-22 01:00:00+00:00,14.65,43.8,87.0,416.58,36.0,256.6,5.49,245.0,91193.0 +2006-03-22 02:00:00+00:00,13.65,47.82,0.0,0.0,0.0,255.75,4.59,252.0,91271.0 +2006-03-22 03:00:00+00:00,12.58,50.71,0.0,0.0,0.0,253.65,4.12,260.0,91367.0 +2006-03-22 04:00:00+00:00,11.5,53.61,0.0,0.0,0.0,251.55,3.65,268.0,91464.0 +2006-03-22 05:00:00+00:00,10.43,56.5,0.0,0.0,0.0,249.45,3.17,276.0,91560.0 +2006-03-22 06:00:00+00:00,9.57,60.92,0.0,0.0,0.0,247.37,2.94,282.0,91617.0 +2006-03-22 07:00:00+00:00,8.71,65.33,0.0,0.0,0.0,245.28,2.71,288.0,91674.0 +2006-03-22 08:00:00+00:00,7.85,69.75,0.0,0.0,0.0,243.2,2.48,294.0,91731.0 +2006-03-22 09:00:00+00:00,7.13,70.7,0.0,0.0,0.0,240.52,2.33,299.0,91752.0 +2006-03-22 10:00:00+00:00,6.41,71.66,0.0,0.0,0.0,237.83,2.17,304.0,91773.0 +2006-03-22 11:00:00+00:00,5.69,72.61,0.0,0.0,0.0,235.15,2.01,309.0,91794.0 +2006-03-22 12:00:00+00:00,6.78,69.51,0.0,0.0,0.0,234.12,2.0,318.0,91869.0 +2006-03-22 13:00:00+00:00,7.88,66.41,0.0,0.0,0.0,233.08,2.0,328.0,91944.0 +2006-03-22 14:00:00+00:00,8.98,63.31,85.0,442.48,36.0,232.05,1.99,337.0,92019.0 +2006-03-22 15:00:00+00:00,10.47,54.87,318.0,769.32,68.0,232.38,2.44,340.0,92004.0 +2006-03-22 16:00:00+00:00,11.96,46.43,549.0,894.79,86.0,232.72,2.9,342.0,91989.0 +2006-03-22 17:00:00+00:00,13.45,37.99,745.0,959.92,97.0,233.05,3.35,345.0,91974.0 +2006-03-22 18:00:00+00:00,14.73,34.72,886.0,994.83,103.0,233.17,3.37,343.0,91914.0 +2006-03-22 19:00:00+00:00,16.01,31.45,960.0,1008.45,107.0,233.28,3.39,341.0,91854.0 +2006-03-22 20:00:00+00:00,17.29,28.18,963.0,1010.16,107.0,233.4,3.41,340.0,91794.0 +2006-03-22 21:00:00+00:00,17.36,27.31,894.0,998.0,104.0,234.48,3.45,341.0,91776.0 +2006-03-22 22:00:00+00:00,17.43,26.45,755.0,964.48,97.0,235.57,3.5,342.0,91758.0 +2006-03-22 23:00:00+00:00,17.49,25.58,560.0,899.79,86.0,236.65,3.54,343.0,91740.0 +2006-03-23 00:00:00+00:00,16.02,32.25,327.0,762.4,69.0,235.27,3.16,352.0,91830.0 +2006-03-23 01:00:00+00:00,14.54,38.92,93.0,440.27,38.0,233.88,2.77,1.0,91920.0 +2006-03-23 02:00:00+00:00,13.07,45.59,0.0,0.0,0.0,232.5,2.39,10.0,92010.0 +2006-03-23 03:00:00+00:00,12.15,48.74,0.0,0.0,0.0,232.13,2.41,18.0,92055.0 +2006-03-23 04:00:00+00:00,11.24,51.89,0.0,0.0,0.0,231.77,2.44,26.0,92100.0 +2006-03-23 05:00:00+00:00,10.32,55.04,0.0,0.0,0.0,231.4,2.47,34.0,92145.0 +2006-03-23 06:00:00+00:00,9.66,57.37,0.0,0.0,0.0,230.25,2.58,43.0,92127.0 +2006-03-23 07:00:00+00:00,8.99,59.71,0.0,0.0,0.0,229.1,2.7,52.0,92109.0 +2006-03-23 08:00:00+00:00,8.32,62.04,0.0,0.0,0.0,227.95,2.81,60.0,92091.0 +2006-03-23 09:00:00+00:00,8.21,62.74,0.0,0.0,0.0,227.78,3.07,65.0,92067.0 +2006-03-23 10:00:00+00:00,8.1,63.45,0.0,0.0,0.0,227.62,3.32,70.0,92043.0 +2006-03-23 11:00:00+00:00,7.99,64.15,0.0,0.0,0.0,227.45,3.57,75.0,92019.0 +2006-03-23 12:00:00+00:00,8.98,59.44,0.0,0.0,0.0,226.13,3.34,75.0,92061.0 +2006-03-23 13:00:00+00:00,9.97,54.72,0.0,0.0,0.0,224.82,3.11,76.0,92103.0 +2006-03-23 14:00:00+00:00,10.96,50.01,89.0,450.11,37.0,223.5,2.88,76.0,92145.0 +2006-03-23 15:00:00+00:00,13.92,39.07,321.0,764.45,69.0,227.62,4.02,81.0,92124.0 +2006-03-23 16:00:00+00:00,16.88,28.14,553.0,894.71,86.0,231.73,5.15,86.0,92103.0 +2006-03-23 17:00:00+00:00,19.84,17.2,750.0,961.21,97.0,235.85,6.29,91.0,92082.0 +2006-03-23 18:00:00+00:00,21.26,15.23,891.0,994.83,104.0,237.73,6.35,94.0,92001.0 +2006-03-23 19:00:00+00:00,22.67,13.27,964.0,1008.74,107.0,239.62,6.41,96.0,91920.0 +2006-03-23 20:00:00+00:00,24.08,11.3,965.0,1008.45,107.0,241.5,6.47,99.0,91839.0 +2006-03-23 21:00:00+00:00,24.0,11.03,892.0,991.54,104.0,243.28,6.19,99.0,91785.0 +2006-03-23 22:00:00+00:00,23.92,10.76,752.0,956.04,97.0,245.07,5.92,100.0,91731.0 +2006-03-23 23:00:00+00:00,23.84,10.49,558.0,891.44,86.0,246.85,5.64,100.0,91677.0 +2006-03-24 00:00:00+00:00,21.91,13.41,326.0,753.82,69.0,246.37,5.26,97.0,91695.0 +2006-03-24 01:00:00+00:00,19.99,16.33,94.0,439.56,38.0,245.88,4.89,93.0,91713.0 +2006-03-24 02:00:00+00:00,18.06,19.25,0.0,0.0,0.0,245.4,4.51,89.0,91731.0 +2006-03-24 03:00:00+00:00,16.82,20.94,0.0,0.0,0.0,246.22,4.08,87.0,91755.0 +2006-03-24 04:00:00+00:00,15.57,22.63,0.0,0.0,0.0,247.03,3.66,85.0,91779.0 +2006-03-24 05:00:00+00:00,14.33,24.32,0.0,0.0,0.0,247.85,3.23,83.0,91803.0 +2006-03-24 06:00:00+00:00,13.08,27.43,0.0,0.0,0.0,247.25,3.09,79.0,91800.0 +2006-03-24 07:00:00+00:00,11.83,30.53,0.0,0.0,0.0,246.65,2.96,76.0,91797.0 +2006-03-24 08:00:00+00:00,10.57,33.64,0.0,0.0,0.0,246.05,2.83,72.0,91794.0 +2006-03-24 09:00:00+00:00,9.76,36.49,0.0,0.0,0.0,244.88,2.85,70.0,91794.0 +2006-03-24 10:00:00+00:00,8.95,39.35,0.0,0.0,0.0,243.72,2.86,69.0,91794.0 +2006-03-24 11:00:00+00:00,8.14,42.2,0.0,0.0,0.0,242.55,2.88,68.0,91794.0 +2006-03-24 12:00:00+00:00,9.41,40.18,0.0,0.0,0.0,242.83,2.74,70.0,91833.0 +2006-03-24 13:00:00+00:00,10.68,38.16,0.0,0.0,0.0,243.12,2.6,73.0,91872.0 +2006-03-24 14:00:00+00:00,11.96,36.14,93.0,457.15,38.0,243.4,2.46,76.0,91911.0 +2006-03-24 15:00:00+00:00,15.21,30.0,327.0,771.71,69.0,246.33,2.67,82.0,91869.0 +2006-03-24 16:00:00+00:00,18.46,23.85,559.0,896.56,87.0,249.27,2.89,87.0,91827.0 +2006-03-24 17:00:00+00:00,21.7,17.71,755.0,961.08,98.0,252.2,3.1,93.0,91785.0 +2006-03-24 18:00:00+00:00,23.18,15.46,895.0,994.88,104.0,253.55,2.87,103.0,91686.0 +2006-03-24 19:00:00+00:00,24.66,13.21,968.0,1007.9,108.0,254.9,2.63,114.0,91587.0 +2006-03-24 20:00:00+00:00,26.14,10.96,968.0,1006.8,108.0,256.25,2.4,124.0,91488.0 +2006-03-24 21:00:00+00:00,26.14,10.36,896.0,992.72,104.0,256.92,1.96,143.0,91406.0 +2006-03-24 22:00:00+00:00,26.14,9.77,757.0,959.36,97.0,257.58,1.52,163.0,91325.0 +2006-03-24 23:00:00+00:00,26.14,9.17,376.0,255.58,240.0,258.25,1.08,182.0,91244.0 +2006-03-25 00:00:00+00:00,25.53,12.67,221.0,256.24,133.0,257.93,1.04,152.0,91256.0 +2006-03-25 01:00:00+00:00,24.92,16.17,67.0,154.01,47.0,257.62,1.01,122.0,91268.0 +2006-03-25 02:00:00+00:00,24.31,19.67,0.0,0.0,0.0,257.3,0.98,91.0,91280.0 +2006-03-25 03:00:00+00:00,22.81,21.69,0.0,0.0,0.0,258.57,1.2,98.0,91304.0 +2006-03-25 04:00:00+00:00,21.32,23.7,0.0,0.0,0.0,259.83,1.42,105.0,91328.0 +2006-03-25 05:00:00+00:00,19.82,25.72,0.0,0.0,0.0,261.1,1.64,112.0,91352.0 +2006-03-25 06:00:00+00:00,18.33,30.74,0.0,0.0,0.0,259.32,1.72,119.0,91346.0 +2006-03-25 07:00:00+00:00,16.84,35.77,0.0,0.0,0.0,257.53,1.8,126.0,91340.0 +2006-03-25 08:00:00+00:00,15.35,40.79,0.0,0.0,0.0,255.75,1.88,133.0,91334.0 +2006-03-25 09:00:00+00:00,14.12,42.68,0.0,0.0,0.0,254.05,1.89,135.0,91331.0 +2006-03-25 10:00:00+00:00,12.88,44.56,0.0,0.0,0.0,252.35,1.89,136.0,91328.0 +2006-03-25 11:00:00+00:00,11.64,46.45,0.0,0.0,0.0,250.65,1.9,137.0,91325.0 +2006-03-25 12:00:00+00:00,12.61,42.19,0.0,0.0,0.0,250.72,1.67,133.0,91382.0 +2006-03-25 13:00:00+00:00,13.58,37.93,0.0,0.0,0.0,250.78,1.43,129.0,91440.0 +2006-03-25 14:00:00+00:00,14.56,33.67,98.0,471.67,39.0,250.85,1.2,125.0,91497.0 +2006-03-25 15:00:00+00:00,17.95,26.12,332.0,772.9,70.0,255.63,1.67,152.0,91485.0 +2006-03-25 16:00:00+00:00,21.35,18.58,564.0,898.43,87.0,260.42,2.15,179.0,91473.0 +2006-03-25 17:00:00+00:00,24.74,11.03,760.0,962.44,98.0,265.2,2.62,206.0,91461.0 +2006-03-25 18:00:00+00:00,25.63,9.6,901.0,996.23,105.0,265.82,3.2,214.0,91379.0 +2006-03-25 19:00:00+00:00,26.52,8.17,975.0,1011.8,108.0,266.43,3.78,222.0,91298.0 +2006-03-25 20:00:00+00:00,27.41,6.74,975.0,1011.06,108.0,267.05,4.36,231.0,91217.0 +2006-03-25 21:00:00+00:00,27.04,6.58,902.0,995.19,105.0,267.72,4.58,232.0,91154.0 +2006-03-25 22:00:00+00:00,26.67,6.43,761.0,959.81,98.0,268.38,4.81,234.0,91091.0 +2006-03-25 23:00:00+00:00,26.3,6.27,455.0,503.04,186.0,269.05,5.03,236.0,91028.0 +2006-03-26 00:00:00+00:00,24.42,7.93,332.0,757.43,70.0,269.87,4.63,236.0,91067.0 +2006-03-26 01:00:00+00:00,22.54,9.58,98.0,445.93,39.0,270.68,4.22,236.0,91106.0 +2006-03-26 02:00:00+00:00,20.66,11.24,0.0,0.0,0.0,271.5,3.81,237.0,91145.0 +2006-03-26 03:00:00+00:00,19.55,13.93,0.0,0.0,0.0,269.63,3.36,235.0,91205.0 +2006-03-26 04:00:00+00:00,18.43,16.62,0.0,0.0,0.0,267.77,2.91,233.0,91265.0 +2006-03-26 05:00:00+00:00,17.32,19.31,0.0,0.0,0.0,265.9,2.46,231.0,91325.0 +2006-03-26 06:00:00+00:00,16.06,20.78,0.0,0.0,0.0,263.0,2.29,224.0,91319.0 +2006-03-26 07:00:00+00:00,14.8,22.24,0.0,0.0,0.0,260.1,2.11,218.0,91313.0 +2006-03-26 08:00:00+00:00,13.54,23.71,0.0,0.0,0.0,257.2,1.94,211.0,91307.0 +2006-03-26 09:00:00+00:00,12.74,24.75,0.0,0.0,0.0,255.02,1.93,205.0,91301.0 +2006-03-26 10:00:00+00:00,11.93,25.79,0.0,0.0,0.0,252.83,1.91,200.0,91295.0 +2006-03-26 11:00:00+00:00,11.12,26.83,0.0,0.0,0.0,250.65,1.89,194.0,91289.0 +2006-03-26 12:00:00+00:00,12.75,25.55,0.0,0.0,0.0,252.22,1.69,201.0,91331.0 +2006-03-26 13:00:00+00:00,14.38,24.28,0.0,0.0,0.0,253.78,1.49,208.0,91373.0 +2006-03-26 14:00:00+00:00,16.01,23.0,99.0,462.05,39.0,255.35,1.28,215.0,91416.0 +2006-03-26 15:00:00+00:00,18.1,19.74,329.0,753.74,70.0,258.65,2.02,228.0,91416.0 +2006-03-26 16:00:00+00:00,20.2,16.49,435.0,427.75,206.0,261.95,2.75,242.0,91416.0 +2006-03-26 17:00:00+00:00,22.29,13.23,748.0,940.73,97.0,265.25,3.49,255.0,91416.0 +2006-03-26 18:00:00+00:00,23.32,12.68,778.0,605.3,292.0,266.23,3.6,255.0,91340.0 +2006-03-26 19:00:00+00:00,24.35,12.14,805.0,502.05,373.0,267.22,3.71,255.0,91265.0 +2006-03-26 20:00:00+00:00,25.37,11.59,786.0,473.98,378.0,268.2,3.82,255.0,91190.0 +2006-03-26 21:00:00+00:00,25.03,12.16,690.0,425.45,348.0,279.8,3.94,254.0,91145.0 +2006-03-26 22:00:00+00:00,24.69,12.74,522.0,276.85,330.0,291.4,4.06,252.0,91100.0 +2006-03-26 23:00:00+00:00,24.34,13.31,300.0,104.22,244.0,303.0,4.18,250.0,91055.0 +2006-03-27 00:00:00+00:00,23.48,15.98,114.0,0.0,114.0,310.13,3.79,247.0,91097.0 +2006-03-27 01:00:00+00:00,22.61,18.66,47.0,14.84,45.0,317.27,3.41,243.0,91139.0 +2006-03-27 02:00:00+00:00,21.75,21.33,0.0,0.0,0.0,324.4,3.02,240.0,91181.0 +2006-03-27 03:00:00+00:00,20.83,25.89,0.0,0.0,0.0,324.22,2.65,236.0,91232.0 +2006-03-27 04:00:00+00:00,19.91,30.44,0.0,0.0,0.0,324.03,2.29,232.0,91283.0 +2006-03-27 05:00:00+00:00,18.99,35.0,0.0,0.0,0.0,323.85,1.92,229.0,91334.0 +2006-03-27 06:00:00+00:00,18.09,37.36,0.0,0.0,0.0,321.85,1.83,217.0,91322.0 +2006-03-27 07:00:00+00:00,17.18,39.73,0.0,0.0,0.0,319.85,1.74,206.0,91310.0 +2006-03-27 08:00:00+00:00,16.27,42.09,0.0,0.0,0.0,317.85,1.66,195.0,91298.0 +2006-03-27 09:00:00+00:00,16.02,42.47,0.0,0.0,0.0,316.05,1.71,189.0,91307.0 +2006-03-27 10:00:00+00:00,15.76,42.84,0.0,0.0,0.0,314.25,1.76,183.0,91316.0 +2006-03-27 11:00:00+00:00,15.51,43.22,0.0,0.0,0.0,312.45,1.81,178.0,91325.0 +2006-03-27 12:00:00+00:00,16.05,43.94,0.0,0.0,0.0,310.55,1.93,177.0,91358.0 +2006-03-27 13:00:00+00:00,16.59,44.65,0.0,0.0,0.0,308.65,2.06,176.0,91391.0 +2006-03-27 14:00:00+00:00,17.13,45.37,41.0,0.0,41.0,306.75,2.18,175.0,91425.0 +2006-03-27 15:00:00+00:00,18.35,42.4,162.0,60.3,141.0,311.08,2.78,181.0,91470.0 +2006-03-27 16:00:00+00:00,19.57,39.43,466.0,544.67,172.0,315.42,3.38,188.0,91515.0 +2006-03-27 17:00:00+00:00,20.79,36.46,612.0,507.06,259.0,319.75,3.99,195.0,91560.0 +2006-03-27 18:00:00+00:00,21.81,32.07,739.0,506.97,330.0,315.18,4.16,200.0,91512.0 +2006-03-27 19:00:00+00:00,22.82,27.67,691.0,295.13,436.0,310.62,4.33,205.0,91464.0 +2006-03-27 20:00:00+00:00,23.83,23.28,338.0,21.99,319.0,306.05,4.5,210.0,91416.0 +2006-03-27 21:00:00+00:00,23.86,23.09,392.0,43.38,357.0,306.02,4.49,214.0,91361.0 +2006-03-27 22:00:00+00:00,23.89,22.89,599.0,472.54,270.0,305.98,4.49,219.0,91307.0 +2006-03-27 23:00:00+00:00,23.92,22.7,285.0,83.35,240.0,305.95,4.48,223.0,91253.0 +2006-03-28 00:00:00+00:00,23.21,27.2,125.0,8.55,122.0,303.2,4.09,226.0,91274.0 +2006-03-28 01:00:00+00:00,22.51,31.71,27.0,0.0,27.0,300.45,3.7,229.0,91295.0 +2006-03-28 02:00:00+00:00,21.8,36.21,0.0,0.0,0.0,297.7,3.31,231.0,91316.0 +2006-03-28 03:00:00+00:00,20.28,41.46,0.0,0.0,0.0,295.05,3.07,229.0,91367.0 +2006-03-28 04:00:00+00:00,18.76,46.71,0.0,0.0,0.0,292.4,2.83,227.0,91419.0 +2006-03-28 05:00:00+00:00,17.24,51.96,0.0,0.0,0.0,289.75,2.59,225.0,91470.0 +2006-03-28 06:00:00+00:00,16.41,54.8,0.0,0.0,0.0,289.92,2.37,216.0,91476.0 +2006-03-28 07:00:00+00:00,15.58,57.64,0.0,0.0,0.0,290.08,2.15,207.0,91482.0 +2006-03-28 08:00:00+00:00,14.75,60.48,0.0,0.0,0.0,290.25,1.93,198.0,91488.0 +2006-03-28 09:00:00+00:00,14.45,60.78,0.0,0.0,0.0,294.25,2.0,184.0,91485.0 +2006-03-28 10:00:00+00:00,14.14,61.08,0.0,0.0,0.0,298.25,2.07,169.0,91482.0 +2006-03-28 11:00:00+00:00,13.83,61.38,0.0,0.0,0.0,302.25,2.14,155.0,91479.0 +2006-03-28 12:00:00+00:00,14.73,56.13,0.0,0.0,0.0,305.85,2.32,165.0,91503.0 +2006-03-28 13:00:00+00:00,15.63,50.89,0.0,0.0,0.0,309.45,2.5,176.0,91527.0 +2006-03-28 14:00:00+00:00,16.53,45.64,6.0,0.0,6.0,313.05,2.68,186.0,91551.0 +2006-03-28 15:00:00+00:00,17.39,45.01,52.0,0.0,52.0,317.98,3.14,194.0,91587.0 +2006-03-28 16:00:00+00:00,18.26,44.39,34.0,0.0,34.0,322.92,3.6,202.0,91623.0 +2006-03-28 17:00:00+00:00,19.12,43.76,122.0,0.0,122.0,327.85,4.06,210.0,91659.0 +2006-03-28 18:00:00+00:00,19.77,44.13,189.0,8.64,182.0,327.78,4.39,209.0,91620.0 +2006-03-28 19:00:00+00:00,20.42,44.49,427.0,43.8,389.0,327.72,4.73,208.0,91581.0 +2006-03-28 20:00:00+00:00,21.06,44.86,401.0,35.75,370.0,327.65,5.06,208.0,91542.0 +2006-03-28 21:00:00+00:00,21.54,40.91,862.0,937.37,103.0,321.02,5.01,211.0,91452.0 +2006-03-28 22:00:00+00:00,22.02,36.95,607.0,487.9,266.0,314.38,4.96,215.0,91361.0 +2006-03-28 23:00:00+00:00,22.5,33.0,417.0,355.84,224.0,307.75,4.91,219.0,91271.0 +2006-03-29 00:00:00+00:00,21.51,37.39,270.0,453.04,110.0,298.7,4.34,204.0,91211.0 +2006-03-29 01:00:00+00:00,20.51,41.78,100.0,429.95,40.0,289.65,3.78,190.0,91151.0 +2006-03-29 02:00:00+00:00,19.52,46.17,0.0,0.0,0.0,280.6,3.21,176.0,91091.0 +2006-03-29 03:00:00+00:00,18.72,48.99,0.0,0.0,0.0,280.1,3.53,184.0,91142.0 +2006-03-29 04:00:00+00:00,17.92,51.82,0.0,0.0,0.0,279.6,3.85,192.0,91193.0 +2006-03-29 05:00:00+00:00,17.12,54.64,0.0,0.0,0.0,279.1,4.17,200.0,91244.0 +2006-03-29 06:00:00+00:00,16.29,57.53,0.0,0.0,0.0,276.72,3.93,199.0,91253.0 +2006-03-29 07:00:00+00:00,15.46,60.42,0.0,0.0,0.0,274.33,3.69,198.0,91262.0 +2006-03-29 08:00:00+00:00,14.63,63.31,0.0,0.0,0.0,271.95,3.45,197.0,91271.0 +2006-03-29 09:00:00+00:00,13.98,66.7,0.0,0.0,0.0,269.5,3.37,196.0,91277.0 +2006-03-29 10:00:00+00:00,13.33,70.08,0.0,0.0,0.0,267.05,3.29,194.0,91283.0 +2006-03-29 11:00:00+00:00,12.68,73.47,0.0,0.0,0.0,264.6,3.21,193.0,91289.0 +2006-03-29 12:00:00+00:00,13.91,69.09,0.0,0.0,0.0,267.38,3.32,192.0,91298.0 +2006-03-29 13:00:00+00:00,15.14,64.71,0.0,0.0,0.0,270.17,3.43,190.0,91307.0 +2006-03-29 14:00:00+00:00,16.38,60.33,47.0,0.0,47.0,272.95,3.54,189.0,91316.0 +2006-03-29 15:00:00+00:00,17.98,52.76,246.0,304.99,137.0,277.03,4.87,195.0,91283.0 +2006-03-29 16:00:00+00:00,19.59,45.19,431.0,377.4,224.0,281.12,6.19,201.0,91250.0 +2006-03-29 17:00:00+00:00,21.19,37.62,654.0,589.21,239.0,285.2,7.52,207.0,91217.0 +2006-03-29 18:00:00+00:00,21.95,34.68,762.0,531.74,329.0,286.82,7.97,212.0,91157.0 +2006-03-29 19:00:00+00:00,22.71,31.74,824.0,512.09,378.0,288.43,8.43,218.0,91097.0 +2006-03-29 20:00:00+00:00,23.47,28.8,957.0,975.48,108.0,290.05,8.88,223.0,91037.0 +2006-03-29 21:00:00+00:00,22.79,30.33,884.0,958.69,105.0,289.32,8.72,226.0,91007.0 +2006-03-29 22:00:00+00:00,22.11,31.85,746.0,923.67,98.0,288.58,8.56,228.0,90977.0 +2006-03-29 23:00:00+00:00,21.42,33.38,556.0,860.77,87.0,287.85,8.4,231.0,90947.0 +2006-03-30 00:00:00+00:00,20.05,38.83,330.0,731.27,70.0,285.3,7.56,236.0,91034.0 +2006-03-30 01:00:00+00:00,18.68,44.28,103.0,436.82,41.0,282.75,6.73,242.0,91121.0 +2006-03-30 02:00:00+00:00,17.31,49.73,0.0,0.0,0.0,280.2,5.89,248.0,91208.0 +2006-03-30 03:00:00+00:00,16.07,54.27,0.0,0.0,0.0,276.67,5.06,248.0,91280.0 +2006-03-30 04:00:00+00:00,14.83,58.82,0.0,0.0,0.0,273.13,4.23,249.0,91352.0 +2006-03-30 05:00:00+00:00,13.59,63.36,0.0,0.0,0.0,269.6,3.39,250.0,91425.0 +2006-03-30 06:00:00+00:00,12.88,67.44,0.0,0.0,0.0,265.57,2.93,248.0,91422.0 +2006-03-30 07:00:00+00:00,12.17,71.51,0.0,0.0,0.0,261.53,2.46,245.0,91419.0 +2006-03-30 08:00:00+00:00,11.45,75.59,0.0,0.0,0.0,257.5,2.0,243.0,91416.0 +2006-03-30 09:00:00+00:00,10.83,78.61,0.0,0.0,0.0,256.05,1.77,237.0,91419.0 +2006-03-30 10:00:00+00:00,10.21,81.62,0.0,0.0,0.0,254.6,1.53,230.0,91422.0 +2006-03-30 11:00:00+00:00,9.59,84.64,0.0,0.0,0.0,253.15,1.3,224.0,91425.0 +2006-03-30 12:00:00+00:00,10.87,75.52,0.0,0.0,0.0,254.48,1.08,225.0,91470.0 +2006-03-30 13:00:00+00:00,12.15,66.4,0.0,0.0,0.0,255.82,0.86,227.0,91515.0 +2006-03-30 14:00:00+00:00,13.43,57.28,109.0,477.19,38.0,257.15,0.65,228.0,91560.0 +2006-03-30 15:00:00+00:00,15.26,48.88,256.0,331.56,136.0,262.45,1.63,230.0,91548.0 +2006-03-30 16:00:00+00:00,17.09,40.47,515.0,694.66,131.0,267.75,2.61,233.0,91536.0 +2006-03-30 17:00:00+00:00,18.91,32.07,618.0,489.87,271.0,273.05,3.59,235.0,91524.0 +2006-03-30 18:00:00+00:00,20.26,28.28,601.0,222.49,419.0,274.32,4.1,236.0,91449.0 +2006-03-30 19:00:00+00:00,21.6,24.48,802.0,473.51,388.0,275.58,4.61,238.0,91373.0 +2006-03-30 20:00:00+00:00,22.94,20.69,858.0,593.07,340.0,276.85,5.12,239.0,91298.0 +2006-03-30 21:00:00+00:00,22.78,19.93,734.0,484.44,339.0,277.18,5.08,239.0,91250.0 +2006-03-30 22:00:00+00:00,22.62,19.17,487.0,198.82,347.0,277.52,5.03,240.0,91202.0 +2006-03-30 23:00:00+00:00,22.46,18.41,362.0,202.81,251.0,277.85,4.99,240.0,91154.0 +2006-03-31 00:00:00+00:00,21.27,20.82,303.0,623.09,80.0,277.95,4.3,239.0,91187.0 +2006-03-31 01:00:00+00:00,20.09,23.23,82.0,249.47,46.0,278.05,3.6,238.0,91220.0 +2006-03-31 02:00:00+00:00,18.9,25.64,0.0,0.0,0.0,278.15,2.91,236.0,91253.0 +2006-03-31 03:00:00+00:00,17.95,28.24,0.0,0.0,0.0,279.95,2.61,231.0,91310.0 +2006-03-31 04:00:00+00:00,16.99,30.85,0.0,0.0,0.0,281.75,2.3,227.0,91367.0 +2006-03-31 05:00:00+00:00,16.04,33.45,0.0,0.0,0.0,283.55,2.0,222.0,91425.0 +2006-03-31 06:00:00+00:00,15.0,36.01,0.0,0.0,0.0,282.3,1.94,211.0,91416.0 +2006-03-31 07:00:00+00:00,13.95,38.56,0.0,0.0,0.0,281.05,1.88,199.0,91406.0 +2006-03-31 08:00:00+00:00,12.9,41.12,0.0,0.0,0.0,279.8,1.82,188.0,91397.0 +2006-03-31 09:00:00+00:00,12.44,42.66,0.0,0.0,0.0,279.83,1.94,179.0,91379.0 +2006-03-31 10:00:00+00:00,11.98,44.2,0.0,0.0,0.0,279.87,2.05,171.0,91361.0 +2006-03-31 11:00:00+00:00,11.52,45.74,0.0,0.0,0.0,279.9,2.17,162.0,91343.0 +2006-03-31 12:00:00+00:00,13.09,42.48,0.0,0.0,0.0,279.7,2.35,163.0,91373.0 +2006-03-31 13:00:00+00:00,14.66,39.23,0.0,0.0,0.0,279.5,2.53,164.0,91403.0 +2006-03-31 14:00:00+00:00,16.23,35.97,118.0,482.17,44.0,279.3,2.72,165.0,91434.0 +2006-03-31 15:00:00+00:00,18.21,30.66,37.0,0.0,37.0,282.45,3.69,174.0,91422.0 +2006-03-31 16:00:00+00:00,25.57,13.02,309.0,98.73,254.0,294.16,7.09,183.0,91410.0 +2006-03-31 17:00:00+00:00,24.93,14.73,389.0,75.81,335.0,292.41,6.84,191.0,91397.0 +2006-03-31 18:00:00+00:00,24.29,16.43,776.0,544.01,329.0,290.66,6.58,196.0,91337.0 +2006-03-31 19:00:00+00:00,23.65,18.13,967.0,977.61,109.0,288.91,6.33,200.0,91277.0 +2006-03-31 20:00:00+00:00,23.01,19.83,963.0,974.39,109.0,287.16,6.08,205.0,91217.0 +2006-03-31 21:00:00+00:00,22.36,21.53,726.0,468.14,343.0,285.4,5.82,209.0,91190.0 +2006-03-31 22:00:00+00:00,21.72,23.24,600.0,445.74,285.0,283.65,5.57,213.0,91163.0 +2006-03-31 23:00:00+00:00,21.08,24.94,227.0,27.29,212.0,281.9,5.32,216.0,91136.0 +2008-04-01 00:00:00+00:00,20.44,26.64,334.0,730.11,71.0,280.15,5.07,244.0,91085.0 +2008-04-01 01:00:00+00:00,19.8,28.34,106.0,443.19,41.0,278.4,4.81,248.0,91160.0 +2008-04-01 02:00:00+00:00,19.16,30.04,0.0,0.0,0.0,276.65,4.56,251.0,91235.0 +2008-04-01 03:00:00+00:00,18.52,31.75,0.0,0.0,0.0,274.9,4.31,249.0,91289.0 +2008-04-01 04:00:00+00:00,17.88,33.45,0.0,0.0,0.0,273.15,4.06,248.0,91343.0 +2008-04-01 05:00:00+00:00,17.24,35.15,0.0,0.0,0.0,271.4,3.8,246.0,91397.0 +2008-04-01 06:00:00+00:00,16.59,36.85,0.0,0.0,0.0,269.65,3.55,241.0,91400.0 +2008-04-01 07:00:00+00:00,15.95,38.56,0.0,0.0,0.0,267.9,3.3,237.0,91403.0 +2008-04-01 08:00:00+00:00,12.73,47.57,0.0,0.0,0.0,259.3,2.1,233.0,91406.0 +2008-04-01 09:00:00+00:00,12.18,51.53,0.0,0.0,0.0,257.35,1.98,232.0,91419.0 +2008-04-01 10:00:00+00:00,11.63,55.49,0.0,0.0,0.0,255.4,1.86,231.0,91431.0 +2008-04-01 11:00:00+00:00,11.08,59.45,0.0,0.0,0.0,253.45,1.74,230.0,91443.0 +2008-04-01 12:00:00+00:00,12.41,53.11,0.0,0.0,0.0,254.53,1.56,233.0,91503.0 +2008-04-01 13:00:00+00:00,13.74,46.77,0.0,0.0,0.0,255.62,1.39,236.0,91563.0 +2008-04-01 14:00:00+00:00,15.08,40.43,125.0,505.9,45.0,256.7,1.21,239.0,91623.0 +2008-04-01 15:00:00+00:00,16.7,34.6,362.0,779.17,73.0,259.28,2.19,245.0,91635.0 +2008-04-01 16:00:00+00:00,18.32,28.77,593.0,896.19,90.0,261.87,3.16,251.0,91647.0 +2008-04-01 17:00:00+00:00,19.94,22.94,787.0,957.77,101.0,264.45,4.14,257.0,91659.0 +2008-04-01 18:00:00+00:00,21.15,20.15,926.0,992.39,107.0,263.77,4.29,258.0,91590.0 +2008-04-01 19:00:00+00:00,22.35,17.37,999.0,1008.02,111.0,263.08,4.45,260.0,91521.0 +2008-04-01 20:00:00+00:00,23.55,14.58,998.0,1009.75,110.0,262.4,4.61,261.0,91452.0 +2008-04-01 21:00:00+00:00,23.5,13.8,924.0,995.31,107.0,262.55,4.57,263.0,91403.0 +2008-04-01 22:00:00+00:00,23.44,13.01,782.0,961.64,100.0,262.7,4.54,265.0,91355.0 +2008-04-01 23:00:00+00:00,23.38,12.23,585.0,898.41,89.0,262.85,4.51,266.0,91307.0 +2008-04-02 00:00:00+00:00,21.85,14.66,354.0,783.4,70.0,263.75,3.73,267.0,91328.0 +2008-04-02 01:00:00+00:00,20.32,17.1,116.0,496.61,42.0,264.65,2.95,267.0,91349.0 +2008-04-02 02:00:00+00:00,18.79,19.53,0.0,0.0,0.0,265.55,2.17,267.0,91370.0 +2008-04-02 03:00:00+00:00,18.62,22.0,0.0,0.0,0.0,264.37,1.59,264.0,91400.0 +2008-04-02 04:00:00+00:00,18.46,24.48,0.0,0.0,0.0,263.18,1.01,260.0,91431.0 +2008-04-02 05:00:00+00:00,18.29,26.95,0.0,0.0,0.0,262.0,0.43,257.0,91461.0 +2008-04-02 06:00:00+00:00,17.44,27.45,0.0,0.0,0.0,260.33,0.48,222.0,91458.0 +2008-04-02 07:00:00+00:00,16.58,27.96,0.0,0.0,0.0,258.67,0.54,187.0,91455.0 +2008-04-02 08:00:00+00:00,15.73,28.46,0.0,0.0,0.0,257.0,0.59,152.0,91452.0 +2008-04-02 09:00:00+00:00,13.91,33.01,0.0,0.0,0.0,256.1,0.92,140.0,91440.0 +2008-04-02 10:00:00+00:00,12.1,37.55,0.0,0.0,0.0,255.2,1.26,129.0,91428.0 +2008-04-02 11:00:00+00:00,10.28,42.1,0.0,0.0,0.0,254.3,1.59,118.0,91416.0 +2008-04-02 12:00:00+00:00,12.11,37.8,0.0,0.0,0.0,256.28,1.57,121.0,91455.0 +2008-04-02 13:00:00+00:00,13.93,33.51,0.0,0.0,0.0,258.27,1.55,124.0,91494.0 +2008-04-02 14:00:00+00:00,15.75,29.21,76.0,104.44,59.0,260.25,1.53,128.0,91533.0 +2008-04-02 15:00:00+00:00,18.5,24.13,371.0,796.61,72.0,264.7,2.12,148.0,91503.0 +2008-04-02 16:00:00+00:00,21.25,19.05,602.0,910.79,87.0,269.15,2.71,169.0,91473.0 +2008-04-02 17:00:00+00:00,24.0,13.97,640.0,519.36,266.0,273.6,3.3,190.0,91443.0 +2008-04-02 18:00:00+00:00,25.17,12.53,931.0,997.8,104.0,275.03,3.77,199.0,91361.0 +2008-04-02 19:00:00+00:00,26.35,11.08,1000.0,1010.0,107.0,276.47,4.23,208.0,91280.0 +2008-04-02 20:00:00+00:00,27.52,9.64,996.0,1007.54,107.0,277.9,4.7,217.0,91199.0 +2008-04-02 21:00:00+00:00,27.16,9.41,787.0,573.15,315.0,281.05,4.97,222.0,91160.0 +2008-04-02 22:00:00+00:00,26.81,9.18,653.0,573.3,245.0,284.2,5.25,227.0,91121.0 +2008-04-02 23:00:00+00:00,26.45,8.95,585.0,900.02,86.0,287.35,5.52,232.0,91082.0 +2008-04-03 00:00:00+00:00,24.83,10.58,353.0,775.76,70.0,287.85,4.91,234.0,91133.0 +2008-04-03 01:00:00+00:00,23.21,12.22,117.0,495.56,42.0,288.35,4.3,235.0,91184.0 +2008-04-03 02:00:00+00:00,21.59,13.85,0.0,0.0,0.0,288.85,3.7,237.0,91235.0 +2008-04-03 03:00:00+00:00,20.67,16.76,0.0,0.0,0.0,285.77,3.15,232.0,91295.0 +2008-04-03 04:00:00+00:00,19.75,19.66,0.0,0.0,0.0,282.68,2.6,227.0,91355.0 +2008-04-03 05:00:00+00:00,18.82,22.57,0.0,0.0,0.0,279.6,2.06,222.0,91416.0 +2008-04-03 06:00:00+00:00,17.5,24.02,0.0,0.0,0.0,277.53,2.0,214.0,91410.0 +2008-04-03 07:00:00+00:00,16.18,25.46,0.0,0.0,0.0,275.47,1.94,206.0,91403.0 +2008-04-03 08:00:00+00:00,14.86,26.91,0.0,0.0,0.0,273.4,1.89,198.0,91397.0 +2008-04-03 09:00:00+00:00,14.29,28.22,0.0,0.0,0.0,270.8,1.82,196.0,91388.0 +2008-04-03 10:00:00+00:00,13.72,29.54,0.0,0.0,0.0,268.2,1.75,194.0,91379.0 +2008-04-03 11:00:00+00:00,13.15,30.85,0.0,0.0,0.0,265.6,1.68,192.0,91370.0 +2008-04-03 12:00:00+00:00,14.26,29.41,0.0,0.0,0.0,270.83,1.59,190.0,91416.0 +2008-04-03 13:00:00+00:00,15.37,27.98,0.0,0.0,0.0,276.07,1.49,189.0,91461.0 +2008-04-03 14:00:00+00:00,16.48,26.54,72.0,65.72,61.0,281.3,1.39,188.0,91506.0 +2008-04-03 15:00:00+00:00,18.72,22.26,107.0,0.0,107.0,292.87,2.43,197.0,91482.0 +2008-04-03 16:00:00+00:00,20.95,17.98,485.0,514.42,192.0,304.43,3.47,206.0,91458.0 +2008-04-03 17:00:00+00:00,23.19,13.7,512.0,214.11,357.0,316.0,4.51,215.0,91434.0 +2008-04-03 18:00:00+00:00,24.16,12.67,757.0,490.19,349.0,320.7,5.2,221.0,91373.0 +2008-04-03 19:00:00+00:00,25.12,11.65,843.0,516.15,385.0,325.4,5.88,227.0,91313.0 +2008-04-03 20:00:00+00:00,26.09,10.62,846.0,561.44,349.0,330.1,6.57,233.0,91253.0 +2008-04-03 21:00:00+00:00,25.76,11.11,745.0,504.76,328.0,326.88,6.44,236.0,91217.0 +2008-04-03 22:00:00+00:00,25.44,11.59,631.0,519.54,260.0,323.67,6.31,239.0,91181.0 +2008-04-03 23:00:00+00:00,25.11,12.08,578.0,883.71,86.0,320.45,6.18,242.0,91145.0 +2008-04-04 00:00:00+00:00,23.65,14.2,348.0,757.37,70.0,313.23,5.58,243.0,91187.0 +2008-04-04 01:00:00+00:00,22.19,16.33,115.0,475.05,42.0,306.02,4.97,243.0,91229.0 +2008-04-04 02:00:00+00:00,20.73,18.45,0.0,0.0,0.0,298.8,4.37,244.0,91271.0 +2008-04-04 03:00:00+00:00,19.62,21.79,0.0,0.0,0.0,290.12,3.67,244.0,91328.0 +2008-04-04 04:00:00+00:00,18.51,25.13,0.0,0.0,0.0,281.43,2.97,245.0,91385.0 +2008-04-04 05:00:00+00:00,17.4,28.47,0.0,0.0,0.0,272.75,2.26,246.0,91443.0 +2008-04-04 06:00:00+00:00,16.5,31.05,0.0,0.0,0.0,268.0,2.05,241.0,91425.0 +2008-04-04 07:00:00+00:00,15.59,33.62,0.0,0.0,0.0,263.25,1.84,237.0,91406.0 +2008-04-04 08:00:00+00:00,14.69,36.2,0.0,0.0,0.0,258.5,1.63,233.0,91388.0 +2008-04-04 09:00:00+00:00,14.11,38.09,0.0,0.0,0.0,255.8,1.54,230.0,91382.0 +2008-04-04 10:00:00+00:00,13.54,39.97,0.0,0.0,0.0,253.1,1.45,227.0,91376.0 +2008-04-04 11:00:00+00:00,12.96,41.86,0.0,0.0,0.0,250.4,1.37,224.0,91370.0 +2008-04-04 12:00:00+00:00,13.86,38.63,0.0,0.0,0.0,249.95,1.31,228.0,91422.0 +2008-04-04 13:00:00+00:00,14.75,35.39,0.0,0.0,0.0,249.5,1.26,231.0,91473.0 +2008-04-04 14:00:00+00:00,15.64,32.16,138.0,535.05,46.0,249.05,1.2,235.0,91524.0 +2008-04-04 15:00:00+00:00,17.49,28.51,374.0,786.27,72.0,252.22,2.34,244.0,91515.0 +2008-04-04 16:00:00+00:00,19.33,24.86,602.0,896.01,88.0,255.38,3.49,253.0,91506.0 +2008-04-04 17:00:00+00:00,21.18,21.21,792.0,953.67,98.0,258.55,4.63,263.0,91497.0 +2008-04-04 18:00:00+00:00,21.86,19.86,926.0,983.53,104.0,258.68,5.47,263.0,91440.0 +2008-04-04 19:00:00+00:00,22.55,18.51,993.0,995.0,107.0,258.82,6.31,264.0,91382.0 +2008-04-04 20:00:00+00:00,23.23,17.16,988.0,992.07,107.0,258.95,7.14,264.0,91325.0 +2008-04-04 21:00:00+00:00,22.72,18.06,763.0,530.95,323.0,260.47,6.98,270.0,91304.0 +2008-04-04 22:00:00+00:00,22.22,18.95,645.0,541.53,257.0,261.98,6.82,276.0,91283.0 +2008-04-04 23:00:00+00:00,21.71,19.85,484.0,558.11,172.0,263.5,6.66,282.0,91262.0 +2008-04-05 00:00:00+00:00,20.63,22.68,350.0,758.19,70.0,262.42,5.76,292.0,91343.0 +2008-04-05 01:00:00+00:00,19.54,25.51,117.0,480.83,42.0,261.33,4.85,302.0,91425.0 +2008-04-05 02:00:00+00:00,18.45,28.34,0.0,0.0,0.0,260.25,3.94,311.0,91506.0 +2008-04-05 03:00:00+00:00,17.61,32.24,0.0,0.0,0.0,259.32,3.72,317.0,91563.0 +2008-04-05 04:00:00+00:00,16.77,36.13,0.0,0.0,0.0,258.38,3.5,323.0,91620.0 +2008-04-05 05:00:00+00:00,15.93,40.03,0.0,0.0,0.0,257.45,3.28,329.0,91677.0 +2008-04-05 06:00:00+00:00,15.27,40.9,0.0,0.0,0.0,255.97,3.05,333.0,91677.0 +2008-04-05 07:00:00+00:00,14.62,41.77,0.0,0.0,0.0,254.48,2.81,337.0,91677.0 +2008-04-05 08:00:00+00:00,13.96,42.64,0.0,0.0,0.0,253.0,2.58,341.0,91677.0 +2008-04-05 09:00:00+00:00,13.67,41.58,0.0,0.0,0.0,251.95,2.42,349.0,91665.0 +2008-04-05 10:00:00+00:00,13.39,40.51,0.0,0.0,0.0,250.9,2.27,356.0,91653.0 +2008-04-05 11:00:00+00:00,13.1,39.45,0.0,0.0,0.0,249.85,2.11,3.0,91641.0 +2008-04-05 12:00:00+00:00,14.16,39.28,0.0,0.0,0.0,251.52,1.84,14.0,91686.0 +2008-04-05 13:00:00+00:00,15.22,39.1,0.0,0.0,0.0,253.18,1.57,25.0,91731.0 +2008-04-05 14:00:00+00:00,16.28,38.93,142.0,538.29,47.0,254.85,1.3,36.0,91776.0 +2008-04-05 15:00:00+00:00,18.39,31.6,381.0,792.98,73.0,258.02,1.97,36.0,91746.0 +2008-04-05 16:00:00+00:00,20.49,24.26,613.0,907.06,89.0,261.18,2.64,37.0,91716.0 +2008-04-05 17:00:00+00:00,22.59,16.93,807.0,967.97,99.0,264.35,3.31,37.0,91686.0 +2008-04-05 18:00:00+00:00,23.51,14.1,947.0,1003.4,105.0,263.72,2.86,32.0,91602.0 +2008-04-05 19:00:00+00:00,24.42,11.26,1018.0,1018.45,108.0,263.08,2.41,28.0,91518.0 +2008-04-05 20:00:00+00:00,25.34,8.43,1015.0,1018.17,108.0,262.45,1.96,23.0,91434.0 +2008-04-05 21:00:00+00:00,25.33,7.88,940.0,1004.53,105.0,261.95,1.81,11.0,91343.0 +2008-04-05 22:00:00+00:00,25.32,7.34,798.0,973.79,98.0,261.45,1.66,358.0,91253.0 +2008-04-05 23:00:00+00:00,25.31,6.79,602.0,915.76,88.0,260.95,1.52,345.0,91163.0 +2008-04-06 00:00:00+00:00,23.33,8.59,368.0,796.73,72.0,258.9,1.55,345.0,91175.0 +2008-04-06 01:00:00+00:00,21.34,10.39,127.0,524.38,44.0,256.85,1.58,345.0,91187.0 +2008-04-06 02:00:00+00:00,19.36,12.19,0.0,0.0,0.0,254.8,1.61,344.0,91199.0 +2008-04-06 03:00:00+00:00,18.38,12.13,0.0,0.0,0.0,254.85,1.51,357.0,91211.0 +2008-04-06 04:00:00+00:00,17.41,12.08,0.0,0.0,0.0,254.9,1.41,9.0,91223.0 +2008-04-06 05:00:00+00:00,16.43,12.02,0.0,0.0,0.0,254.95,1.31,22.0,91235.0 +2008-04-06 06:00:00+00:00,15.95,11.63,0.0,0.0,0.0,252.87,1.24,21.0,91199.0 +2008-04-06 07:00:00+00:00,15.46,11.23,0.0,0.0,0.0,250.78,1.17,20.0,91163.0 +2008-04-06 08:00:00+00:00,14.98,10.84,0.0,0.0,0.0,248.7,1.1,18.0,91127.0 +2008-04-06 09:00:00+00:00,14.77,12.27,0.0,0.0,0.0,247.42,1.04,22.0,91094.0 +2008-04-06 10:00:00+00:00,14.56,13.71,0.0,0.0,0.0,246.13,0.98,26.0,91061.0 +2008-04-06 11:00:00+00:00,14.35,15.14,0.0,0.0,0.0,244.85,0.92,29.0,91028.0 +2008-04-06 12:00:00+00:00,15.18,15.3,0.0,0.0,0.0,245.9,0.72,80.0,91055.0 +2008-04-06 13:00:00+00:00,16.01,15.46,0.0,0.0,0.0,246.95,0.52,130.0,91082.0 +2008-04-06 14:00:00+00:00,16.83,15.62,156.0,591.2,49.0,248.0,0.32,180.0,91109.0 +2008-04-06 15:00:00+00:00,19.17,14.82,399.0,827.65,74.0,251.68,1.48,205.0,91076.0 +2008-04-06 16:00:00+00:00,21.51,14.02,630.0,928.36,90.0,255.37,2.63,230.0,91043.0 +2008-04-06 17:00:00+00:00,23.85,13.22,820.0,979.47,100.0,259.05,3.79,255.0,91010.0 +2008-04-06 18:00:00+00:00,24.81,12.32,954.0,1006.55,106.0,258.72,4.58,254.0,90932.0 +2008-04-06 19:00:00+00:00,25.77,11.41,1021.0,1018.38,108.0,258.38,5.37,254.0,90854.0 +2008-04-06 20:00:00+00:00,26.73,10.51,1013.0,1012.83,108.0,258.05,6.15,254.0,90776.0 +2008-04-06 21:00:00+00:00,26.32,10.87,933.0,994.34,104.0,259.37,6.42,256.0,90746.0 +2008-04-06 22:00:00+00:00,25.91,11.24,788.0,956.81,98.0,260.68,6.69,258.0,90716.0 +2008-04-06 23:00:00+00:00,25.5,11.6,591.0,894.41,87.0,262.0,6.95,260.0,90686.0 +2008-04-07 00:00:00+00:00,23.86,12.7,359.0,770.64,71.0,262.28,6.15,262.0,90758.0 +2008-04-07 01:00:00+00:00,22.22,13.8,124.0,498.21,44.0,262.57,5.34,263.0,90830.0 +2008-04-07 02:00:00+00:00,20.58,14.9,0.0,0.0,0.0,262.85,4.54,264.0,90902.0 +2008-04-07 03:00:00+00:00,19.38,18.37,0.0,0.0,0.0,262.77,3.89,262.0,90962.0 +2008-04-07 04:00:00+00:00,18.18,21.85,0.0,0.0,0.0,262.68,3.25,259.0,91022.0 +2008-04-07 05:00:00+00:00,16.98,25.32,0.0,0.0,0.0,262.6,2.61,256.0,91082.0 +2008-04-07 06:00:00+00:00,15.83,27.0,0.0,0.0,0.0,260.3,2.4,246.0,91082.0 +2008-04-07 07:00:00+00:00,14.68,28.68,0.0,0.0,0.0,258.0,2.18,236.0,91082.0 +2008-04-07 08:00:00+00:00,13.53,30.36,0.0,0.0,0.0,255.7,1.97,227.0,91082.0 +2008-04-07 09:00:00+00:00,12.9,32.09,0.0,0.0,0.0,254.1,1.99,216.0,91094.0 +2008-04-07 10:00:00+00:00,12.27,33.83,0.0,0.0,0.0,252.5,2.01,206.0,91106.0 +2008-04-07 11:00:00+00:00,11.64,35.56,0.0,0.0,0.0,250.9,2.03,196.0,91118.0 +2008-04-07 12:00:00+00:00,13.53,33.25,0.0,0.0,0.0,253.0,1.83,197.0,91172.0 +2008-04-07 13:00:00+00:00,15.42,30.95,0.0,0.0,0.0,255.1,1.63,199.0,91226.0 +2008-04-07 14:00:00+00:00,17.31,28.64,152.0,560.8,48.0,257.2,1.43,201.0,91280.0 +2008-04-07 15:00:00+00:00,19.26,25.28,391.0,798.69,74.0,261.08,2.29,213.0,91295.0 +2008-04-07 16:00:00+00:00,21.2,21.91,619.0,905.05,89.0,264.97,3.15,226.0,91310.0 +2008-04-07 17:00:00+00:00,23.15,18.55,808.0,959.8,99.0,268.85,4.01,238.0,91325.0 +2008-04-07 18:00:00+00:00,24.15,17.17,941.0,988.47,105.0,269.43,4.38,240.0,91259.0 +2008-04-07 19:00:00+00:00,25.16,15.8,1007.0,999.48,108.0,270.02,4.74,241.0,91193.0 +2008-04-07 20:00:00+00:00,26.16,14.42,1001.0,996.43,108.0,270.6,5.1,243.0,91127.0 +2008-04-07 21:00:00+00:00,25.95,15.13,924.0,980.69,104.0,271.6,5.27,244.0,91088.0 +2008-04-07 22:00:00+00:00,25.74,15.85,783.0,946.89,98.0,272.6,5.43,245.0,91049.0 +2008-04-07 23:00:00+00:00,25.53,16.56,589.0,887.41,87.0,273.6,5.6,246.0,91010.0 +2008-04-08 00:00:00+00:00,24.19,18.63,359.0,766.17,71.0,273.83,5.07,245.0,91040.0 +2008-04-08 01:00:00+00:00,22.85,20.7,125.0,497.37,44.0,274.07,4.53,244.0,91070.0 +2008-04-08 02:00:00+00:00,21.51,22.77,0.0,0.0,0.0,274.3,4.0,242.0,91100.0 +2008-04-08 03:00:00+00:00,20.09,26.0,0.0,0.0,0.0,273.62,3.59,241.0,91166.0 +2008-04-08 04:00:00+00:00,18.67,29.24,0.0,0.0,0.0,272.93,3.18,240.0,91232.0 +2008-04-08 05:00:00+00:00,17.25,32.47,0.0,0.0,0.0,272.25,2.77,239.0,91298.0 +2008-04-08 06:00:00+00:00,16.18,36.76,0.0,0.0,0.0,269.6,2.53,234.0,91316.0 +2008-04-08 07:00:00+00:00,15.1,41.06,0.0,0.0,0.0,266.95,2.29,230.0,91334.0 +2008-04-08 08:00:00+00:00,14.03,45.35,0.0,0.0,0.0,264.3,2.04,225.0,91352.0 +2008-04-08 09:00:00+00:00,13.38,48.85,0.0,0.0,0.0,262.08,2.0,223.0,91340.0 +2008-04-08 10:00:00+00:00,12.74,52.34,0.0,0.0,0.0,259.87,1.95,220.0,91328.0 +2008-04-08 11:00:00+00:00,12.09,55.84,0.0,0.0,0.0,257.65,1.9,217.0,91316.0 +2008-04-08 12:00:00+00:00,13.77,50.42,0.0,0.0,0.0,258.85,1.85,218.0,91334.0 +2008-04-08 13:00:00+00:00,15.44,45.01,0.0,0.0,0.0,260.05,1.79,218.0,91352.0 +2008-04-08 14:00:00+00:00,17.11,39.59,152.0,547.73,48.0,261.25,1.74,219.0,91370.0 +2008-04-08 15:00:00+00:00,19.14,33.73,386.0,780.41,73.0,266.08,2.67,231.0,91340.0 +2008-04-08 16:00:00+00:00,21.16,27.86,609.0,883.84,88.0,270.92,3.6,244.0,91310.0 +2008-04-08 17:00:00+00:00,23.18,22.0,795.0,939.05,98.0,275.75,4.52,256.0,91280.0 +2008-04-08 18:00:00+00:00,24.22,19.98,926.0,967.06,105.0,277.48,5.12,259.0,91214.0 +2008-04-08 19:00:00+00:00,25.25,17.96,992.0,980.76,107.0,279.22,5.72,262.0,91148.0 +2008-04-08 20:00:00+00:00,26.29,15.94,987.0,979.07,107.0,280.95,6.32,265.0,91082.0 +2008-04-08 21:00:00+00:00,25.99,15.49,912.0,963.58,104.0,282.02,6.42,266.0,91040.0 +2008-04-08 22:00:00+00:00,25.7,15.03,773.0,931.57,97.0,283.08,6.52,268.0,90998.0 +2008-04-08 23:00:00+00:00,25.4,14.58,582.0,871.7,87.0,284.15,6.62,270.0,90956.0 +2008-04-09 00:00:00+00:00,24.03,15.23,357.0,756.5,71.0,284.13,5.7,272.0,90998.0 +2008-04-09 01:00:00+00:00,22.65,15.87,126.0,496.58,44.0,284.12,4.78,275.0,91040.0 +2008-04-09 02:00:00+00:00,21.28,16.52,0.0,0.0,0.0,284.1,3.86,278.0,91082.0 +2008-04-09 03:00:00+00:00,19.87,19.58,0.0,0.0,0.0,282.15,3.36,281.0,91127.0 +2008-04-09 04:00:00+00:00,18.46,22.65,0.0,0.0,0.0,280.2,2.85,285.0,91172.0 +2008-04-09 05:00:00+00:00,17.05,25.71,0.0,0.0,0.0,278.25,2.34,288.0,91217.0 +2008-04-09 06:00:00+00:00,16.82,24.12,0.0,0.0,0.0,275.43,1.94,298.0,91208.0 +2008-04-09 07:00:00+00:00,16.59,22.53,0.0,0.0,0.0,272.62,1.54,307.0,91199.0 +2008-04-09 08:00:00+00:00,16.36,20.94,0.0,0.0,0.0,269.8,1.13,317.0,91190.0 +2008-04-09 09:00:00+00:00,14.97,25.47,0.0,0.0,0.0,267.73,1.09,353.0,91157.0 +2008-04-09 10:00:00+00:00,13.58,30.01,0.0,0.0,0.0,265.67,1.04,28.0,91124.0 +2008-04-09 11:00:00+00:00,12.19,34.54,0.0,0.0,0.0,263.6,0.99,64.0,91091.0 +2008-04-09 12:00:00+00:00,13.93,30.69,0.0,0.0,0.0,265.07,1.08,92.0,91094.0 +2008-04-09 13:00:00+00:00,15.66,26.83,0.0,0.0,0.0,266.53,1.17,121.0,91097.0 +2008-04-09 14:00:00+00:00,17.39,22.98,160.0,571.42,49.0,268.0,1.26,150.0,91100.0 +2008-04-09 15:00:00+00:00,19.42,19.58,395.0,792.21,74.0,271.62,2.17,169.0,91055.0 +2008-04-09 16:00:00+00:00,21.44,16.19,619.0,893.32,89.0,275.23,3.09,188.0,91010.0 +2008-04-09 17:00:00+00:00,23.46,12.79,805.0,946.72,99.0,278.85,4.01,206.0,90965.0 +2008-04-09 18:00:00+00:00,24.43,11.5,937.0,976.39,105.0,279.32,4.64,214.0,90884.0 +2008-04-09 19:00:00+00:00,25.4,10.22,1003.0,988.73,108.0,279.78,5.27,222.0,90803.0 +2008-04-09 20:00:00+00:00,26.37,8.93,998.0,987.39,108.0,280.25,5.9,230.0,90722.0 +2008-04-09 21:00:00+00:00,25.82,9.06,923.0,973.98,104.0,280.07,6.16,235.0,90686.0 +2008-04-09 22:00:00+00:00,25.27,9.18,783.0,941.13,98.0,279.88,6.42,240.0,90650.0 +2008-04-09 23:00:00+00:00,24.72,9.31,590.0,882.47,87.0,279.7,6.68,245.0,90613.0 +2008-04-10 00:00:00+00:00,23.37,10.35,362.0,765.38,71.0,279.42,6.11,246.0,90631.0 +2008-04-10 01:00:00+00:00,22.02,11.39,129.0,507.78,44.0,279.13,5.55,247.0,90650.0 +2008-04-10 02:00:00+00:00,20.67,12.43,0.0,0.0,0.0,278.85,4.99,249.0,90668.0 +2008-04-10 03:00:00+00:00,19.08,14.2,0.0,0.0,0.0,274.88,4.18,243.0,90719.0 +2008-04-10 04:00:00+00:00,17.49,15.97,0.0,0.0,0.0,270.92,3.37,238.0,90770.0 +2008-04-10 05:00:00+00:00,15.9,17.74,0.0,0.0,0.0,266.95,2.57,233.0,90821.0 +2008-04-10 06:00:00+00:00,14.99,20.34,0.0,0.0,0.0,263.28,2.58,230.0,90830.0 +2008-04-10 07:00:00+00:00,14.07,22.93,0.0,0.0,0.0,259.62,2.6,227.0,90839.0 +2008-04-10 08:00:00+00:00,13.16,25.53,0.0,0.0,0.0,255.95,2.62,223.0,90848.0 +2008-04-10 09:00:00+00:00,12.7,29.99,0.0,0.0,0.0,253.57,2.65,222.0,90833.0 +2008-04-10 10:00:00+00:00,12.23,34.44,0.0,0.0,0.0,251.18,2.68,221.0,90818.0 +2008-04-10 11:00:00+00:00,11.77,38.9,0.0,0.0,0.0,248.8,2.7,220.0,90803.0 +2008-04-10 12:00:00+00:00,12.9,37.71,0.0,0.0,0.0,250.22,3.03,219.0,90797.0 +2008-04-10 13:00:00+00:00,14.02,36.51,0.0,0.0,0.0,251.63,3.37,217.0,90791.0 +2008-04-10 14:00:00+00:00,15.14,35.32,160.0,558.95,49.0,253.05,3.7,216.0,90785.0 +2008-04-10 15:00:00+00:00,16.15,33.79,182.0,46.42,163.0,257.9,4.91,221.0,90788.0 +2008-04-10 16:00:00+00:00,17.15,32.26,121.0,0.0,121.0,262.75,6.11,226.0,90791.0 +2008-04-10 17:00:00+00:00,18.15,30.73,168.0,5.34,164.0,267.6,7.32,231.0,90794.0 +2008-04-10 18:00:00+00:00,18.54,28.03,305.0,18.71,289.0,271.48,8.08,237.0,90770.0 +2008-04-10 19:00:00+00:00,18.93,25.33,561.0,111.24,460.0,275.37,8.84,242.0,90746.0 +2008-04-10 20:00:00+00:00,19.32,22.63,838.0,469.09,414.0,279.25,9.6,247.0,90722.0 +2008-04-10 21:00:00+00:00,19.05,22.18,326.0,22.53,307.0,276.23,9.15,252.0,90716.0 +2008-04-10 22:00:00+00:00,18.78,21.72,790.0,947.93,98.0,273.22,8.71,257.0,90710.0 +2008-04-10 23:00:00+00:00,18.5,21.27,595.0,886.21,88.0,270.2,8.26,262.0,90704.0 +2008-04-11 00:00:00+00:00,17.59,23.45,366.0,768.97,72.0,264.85,7.09,266.0,90785.0 +2008-04-11 01:00:00+00:00,16.68,25.63,132.0,512.81,45.0,259.5,5.93,269.0,90866.0 +2008-04-11 02:00:00+00:00,15.77,27.81,0.0,0.0,0.0,254.15,4.76,273.0,90947.0 +2008-04-11 03:00:00+00:00,14.95,29.8,0.0,0.0,0.0,251.9,4.43,271.0,91022.0 +2008-04-11 04:00:00+00:00,14.14,31.79,0.0,0.0,0.0,249.65,4.1,268.0,91097.0 +2008-04-11 05:00:00+00:00,13.32,33.78,0.0,0.0,0.0,247.4,3.77,265.0,91172.0 +2008-04-11 06:00:00+00:00,12.64,36.34,0.0,0.0,0.0,245.3,3.43,260.0,91202.0 +2008-04-11 07:00:00+00:00,11.96,38.9,0.0,0.0,0.0,243.2,3.1,256.0,91232.0 +2008-04-11 08:00:00+00:00,11.28,41.46,0.0,0.0,0.0,241.1,2.77,251.0,91262.0 +2008-04-11 09:00:00+00:00,10.98,44.69,0.0,0.0,0.0,240.07,2.64,251.0,91274.0 +2008-04-11 10:00:00+00:00,10.67,47.92,0.0,0.0,0.0,239.03,2.51,250.0,91286.0 +2008-04-11 11:00:00+00:00,10.37,51.15,0.0,0.0,0.0,238.0,2.39,250.0,91298.0 +2008-04-11 12:00:00+00:00,11.38,46.47,0.0,0.0,0.0,239.43,2.62,256.0,91331.0 +2008-04-11 13:00:00+00:00,12.38,41.78,0.0,0.0,0.0,240.87,2.85,261.0,91364.0 +2008-04-11 14:00:00+00:00,13.38,37.1,171.0,591.5,51.0,242.3,3.08,267.0,91397.0 +2008-04-11 15:00:00+00:00,15.21,29.97,410.0,808.16,76.0,245.68,4.1,274.0,91394.0 +2008-04-11 16:00:00+00:00,17.04,22.84,638.0,910.51,91.0,249.07,5.13,282.0,91391.0 +2008-04-11 17:00:00+00:00,18.87,15.71,827.0,964.74,101.0,252.45,6.15,289.0,91388.0 +2008-04-11 18:00:00+00:00,20.04,13.62,963.0,997.38,107.0,253.1,6.62,290.0,91343.0 +2008-04-11 19:00:00+00:00,21.22,11.52,1033.0,1013.5,110.0,253.75,7.08,291.0,91298.0 +2008-04-11 20:00:00+00:00,22.39,9.43,1031.0,1016.18,110.0,254.4,7.54,293.0,91253.0 +2008-04-11 21:00:00+00:00,22.24,9.28,956.0,1004.23,107.0,253.53,7.37,295.0,91235.0 +2008-04-11 22:00:00+00:00,22.09,9.13,814.0,975.23,100.0,252.67,7.2,296.0,91217.0 +2008-04-11 23:00:00+00:00,21.93,8.98,617.0,919.57,89.0,251.8,7.03,298.0,91199.0 +2008-04-12 00:00:00+00:00,20.5,11.16,383.0,803.77,74.0,251.38,5.91,300.0,91253.0 +2008-04-12 01:00:00+00:00,19.06,13.35,141.0,546.82,47.0,250.97,4.78,302.0,91307.0 +2008-04-12 02:00:00+00:00,17.62,15.53,0.0,0.0,0.0,250.55,3.66,304.0,91361.0 +2008-04-12 03:00:00+00:00,16.55,17.46,0.0,0.0,0.0,248.95,3.34,308.0,91428.0 +2008-04-12 04:00:00+00:00,15.48,19.4,0.0,0.0,0.0,247.35,3.03,312.0,91494.0 +2008-04-12 05:00:00+00:00,14.41,21.33,0.0,0.0,0.0,245.75,2.72,316.0,91560.0 +2008-04-12 06:00:00+00:00,13.62,22.61,0.0,0.0,0.0,243.73,2.64,324.0,91590.0 +2008-04-12 07:00:00+00:00,12.83,23.88,0.0,0.0,0.0,241.72,2.57,331.0,91620.0 +2008-04-12 08:00:00+00:00,12.04,25.16,0.0,0.0,0.0,239.7,2.5,339.0,91650.0 +2008-04-12 09:00:00+00:00,11.69,26.19,0.0,0.0,0.0,238.5,2.59,348.0,91677.0 +2008-04-12 10:00:00+00:00,11.35,27.21,0.0,0.0,0.0,237.3,2.68,357.0,91704.0 +2008-04-12 11:00:00+00:00,11.0,28.24,0.0,0.0,0.0,236.1,2.77,6.0,91731.0 +2008-04-12 12:00:00+00:00,12.72,25.73,0.0,0.0,0.0,236.77,2.45,17.0,91788.0 +2008-04-12 13:00:00+00:00,14.43,23.21,0.0,0.0,0.0,237.43,2.13,28.0,91845.0 +2008-04-12 14:00:00+00:00,16.14,20.7,178.0,608.37,52.0,238.1,1.81,39.0,91902.0 +2008-04-12 15:00:00+00:00,18.2,17.48,420.0,822.06,77.0,241.18,2.4,36.0,91878.0 +2008-04-12 16:00:00+00:00,20.25,14.26,649.0,921.56,92.0,244.27,2.99,34.0,91854.0 +2008-04-12 17:00:00+00:00,22.3,11.04,841.0,977.72,102.0,247.35,3.59,31.0,91830.0 +2008-04-12 18:00:00+00:00,23.46,9.82,977.0,1009.03,108.0,248.78,3.66,24.0,91758.0 +2008-04-12 19:00:00+00:00,24.62,8.61,1046.0,1023.68,111.0,250.22,3.72,17.0,91686.0 +2008-04-12 20:00:00+00:00,25.78,7.39,1042.0,1024.5,111.0,251.65,3.79,10.0,91614.0 +2008-04-12 21:00:00+00:00,25.71,7.28,965.0,1012.23,107.0,252.03,3.84,7.0,91551.0 +2008-04-12 22:00:00+00:00,25.64,7.16,821.0,980.63,101.0,252.42,3.89,4.0,91488.0 +2008-04-12 23:00:00+00:00,25.57,7.05,622.0,923.23,90.0,252.8,3.93,2.0,91425.0 +2008-04-13 00:00:00+00:00,23.76,8.63,386.0,807.18,74.0,251.27,3.77,6.0,91464.0 +2008-04-13 01:00:00+00:00,21.94,10.2,143.0,551.26,47.0,249.73,3.62,10.0,91503.0 +2008-04-13 02:00:00+00:00,20.13,11.78,0.0,0.0,0.0,248.2,3.46,14.0,91542.0 +2008-04-13 03:00:00+00:00,19.45,12.63,0.0,0.0,0.0,247.82,3.62,22.0,91617.0 +2008-04-13 04:00:00+00:00,18.78,13.48,0.0,0.0,0.0,247.43,3.78,31.0,91692.0 +2008-04-13 05:00:00+00:00,18.1,14.33,0.0,0.0,0.0,247.05,3.94,40.0,91767.0 +2008-04-13 06:00:00+00:00,17.54,14.82,0.0,0.0,0.0,245.82,4.03,45.0,91815.0 +2008-04-13 07:00:00+00:00,16.97,15.3,0.0,0.0,0.0,244.58,4.12,50.0,91863.0 +2008-04-13 08:00:00+00:00,16.41,15.79,0.0,0.0,0.0,243.35,4.21,56.0,91911.0 +2008-04-13 09:00:00+00:00,15.74,16.63,0.0,0.0,0.0,241.92,4.1,60.0,91920.0 +2008-04-13 10:00:00+00:00,15.08,17.48,0.0,0.0,0.0,240.48,3.99,64.0,91929.0 +2008-04-13 11:00:00+00:00,14.41,18.32,0.0,0.0,0.0,239.05,3.88,68.0,91938.0 +2008-04-13 12:00:00+00:00,15.73,17.12,0.0,0.0,0.0,239.83,3.92,72.0,91986.0 +2008-04-13 13:00:00+00:00,17.04,15.91,0.0,0.0,0.0,240.62,3.97,75.0,92034.0 +2008-04-13 14:00:00+00:00,18.35,14.71,184.0,619.99,53.0,241.4,4.01,78.0,92082.0 +2008-04-13 15:00:00+00:00,20.24,12.52,427.0,831.06,77.0,242.63,5.14,79.0,92055.0 +2008-04-13 16:00:00+00:00,22.12,10.33,658.0,930.93,92.0,243.87,6.28,80.0,92028.0 +2008-04-13 17:00:00+00:00,24.0,8.14,850.0,985.4,102.0,245.1,7.41,81.0,92001.0 +2008-04-13 18:00:00+00:00,25.36,7.11,986.0,1016.05,108.0,246.17,7.09,82.0,91905.0 +2008-04-13 19:00:00+00:00,26.71,6.07,1053.0,1028.41,111.0,247.23,6.78,82.0,91809.0 +2008-04-13 20:00:00+00:00,28.07,5.04,1048.0,1028.44,111.0,248.3,6.47,82.0,91713.0 +2008-04-13 21:00:00+00:00,28.02,4.86,969.0,1013.19,108.0,248.88,6.07,81.0,91641.0 +2008-04-13 22:00:00+00:00,27.98,4.67,825.0,983.33,101.0,249.47,5.67,80.0,91569.0 +2008-04-13 23:00:00+00:00,27.93,4.49,626.0,926.91,90.0,250.05,5.27,80.0,91497.0 +2008-04-14 00:00:00+00:00,25.89,5.66,391.0,815.73,74.0,248.37,4.86,79.0,91524.0 +2008-04-14 01:00:00+00:00,23.85,6.83,147.0,561.28,48.0,246.68,4.46,78.0,91551.0 +2008-04-14 02:00:00+00:00,21.81,8.0,0.0,0.0,0.0,245.0,4.06,77.0,91578.0 +2008-04-14 03:00:00+00:00,20.72,8.96,0.0,0.0,0.0,243.98,3.78,78.0,91617.0 +2008-04-14 04:00:00+00:00,19.63,9.91,0.0,0.0,0.0,242.97,3.51,78.0,91656.0 +2008-04-14 05:00:00+00:00,18.54,10.87,0.0,0.0,0.0,241.95,3.24,78.0,91695.0 +2008-04-14 06:00:00+00:00,17.16,11.75,0.0,0.0,0.0,239.5,3.17,76.0,91686.0 +2008-04-14 07:00:00+00:00,15.79,12.62,0.0,0.0,0.0,237.05,3.1,74.0,91677.0 +2008-04-14 08:00:00+00:00,14.41,13.5,0.0,0.0,0.0,234.6,3.03,72.0,91668.0 +2008-04-14 09:00:00+00:00,13.53,13.83,0.0,0.0,0.0,233.72,3.1,72.0,91659.0 +2008-04-14 10:00:00+00:00,12.66,14.17,0.0,0.0,0.0,232.83,3.16,71.0,91650.0 +2008-04-14 11:00:00+00:00,11.78,14.5,0.0,0.0,0.0,231.95,3.23,71.0,91641.0 +2008-04-14 12:00:00+00:00,13.8,13.42,0.0,0.0,0.0,233.55,3.19,73.0,91695.0 +2008-04-14 13:00:00+00:00,15.81,12.33,0.0,0.0,0.0,235.15,3.14,74.0,91749.0 +2008-04-14 14:00:00+00:00,17.82,11.25,193.0,645.23,54.0,236.75,3.1,76.0,91803.0 +2008-04-14 15:00:00+00:00,20.93,9.26,441.0,854.13,78.0,241.37,4.35,83.0,91761.0 +2008-04-14 16:00:00+00:00,24.03,7.26,672.0,946.83,93.0,245.98,5.6,90.0,91719.0 +2008-04-14 17:00:00+00:00,27.14,5.27,863.0,997.03,103.0,250.6,6.84,97.0,91677.0 +2008-04-14 18:00:00+00:00,28.62,4.81,995.0,1021.93,109.0,253.58,6.82,101.0,91587.0 +2008-04-14 19:00:00+00:00,30.09,4.35,1059.0,1032.08,111.0,256.57,6.8,105.0,91497.0 +2008-04-14 20:00:00+00:00,31.57,3.89,1049.0,1026.95,111.0,259.55,6.79,110.0,91406.0 +2008-04-14 21:00:00+00:00,31.52,3.84,967.0,1009.49,107.0,262.97,6.11,113.0,91352.0 +2008-04-14 22:00:00+00:00,31.48,3.8,821.0,976.58,100.0,266.38,5.43,116.0,91298.0 +2008-04-14 23:00:00+00:00,31.43,3.75,621.0,915.09,90.0,269.8,4.74,119.0,91244.0 +2008-04-15 00:00:00+00:00,28.95,5.0,387.0,801.18,74.0,269.15,4.51,111.0,91265.0 +2008-04-15 01:00:00+00:00,26.46,6.26,73.0,50.39,64.0,268.5,4.29,103.0,91286.0 +2008-04-15 02:00:00+00:00,23.98,7.51,0.0,0.0,0.0,267.85,4.06,95.0,91307.0 +2008-04-15 03:00:00+00:00,22.33,8.54,0.0,0.0,0.0,268.32,3.73,91.0,91364.0 +2008-04-15 04:00:00+00:00,20.68,9.56,0.0,0.0,0.0,268.78,3.4,87.0,91422.0 +2008-04-15 05:00:00+00:00,19.03,10.59,0.0,0.0,0.0,269.25,3.08,82.0,91479.0 +2008-04-15 06:00:00+00:00,17.64,12.02,0.0,0.0,0.0,267.22,2.91,80.0,91476.0 +2008-04-15 07:00:00+00:00,16.24,13.45,0.0,0.0,0.0,265.18,2.74,77.0,91473.0 +2008-04-15 08:00:00+00:00,14.85,14.88,0.0,0.0,0.0,263.15,2.58,74.0,91470.0 +2008-04-15 09:00:00+00:00,14.02,16.19,0.0,0.0,0.0,261.85,2.58,75.0,91464.0 +2008-04-15 10:00:00+00:00,13.18,17.51,0.0,0.0,0.0,260.55,2.58,76.0,91458.0 +2008-04-15 11:00:00+00:00,12.35,18.82,0.0,0.0,0.0,259.25,2.58,77.0,91452.0 +2008-04-15 12:00:00+00:00,14.54,17.31,0.0,0.0,0.0,259.8,2.42,81.0,91488.0 +2008-04-15 13:00:00+00:00,16.73,15.79,0.0,0.0,0.0,260.35,2.26,84.0,91524.0 +2008-04-15 14:00:00+00:00,18.91,14.28,190.0,619.58,54.0,260.9,2.1,87.0,91560.0 +2008-04-15 15:00:00+00:00,22.64,11.61,431.0,825.6,77.0,266.62,2.22,97.0,91527.0 +2008-04-15 16:00:00+00:00,26.36,8.95,658.0,920.37,92.0,272.33,2.34,107.0,91494.0 +2008-04-15 17:00:00+00:00,30.08,6.28,844.0,969.45,102.0,278.05,2.47,117.0,91461.0 +2008-04-15 18:00:00+00:00,31.08,5.48,975.0,996.81,108.0,280.47,2.62,151.0,91379.0 +2008-04-15 19:00:00+00:00,32.08,4.68,1039.0,1008.66,110.0,282.88,2.77,185.0,91298.0 +2008-04-15 20:00:00+00:00,33.08,3.88,1033.0,1008.04,110.0,285.3,2.92,218.0,91217.0 +2008-04-15 21:00:00+00:00,32.72,3.85,956.0,994.16,107.0,285.22,3.4,228.0,91151.0 +2008-04-15 22:00:00+00:00,32.37,3.81,813.0,963.15,100.0,285.13,3.88,238.0,91085.0 +2008-04-15 23:00:00+00:00,32.01,3.78,617.0,905.11,90.0,285.05,4.36,247.0,91019.0 +2008-04-16 00:00:00+00:00,30.0,4.69,386.0,794.45,74.0,284.98,4.09,246.0,91040.0 +2008-04-16 01:00:00+00:00,27.98,5.61,148.0,553.0,48.0,284.92,3.82,245.0,91061.0 +2008-04-16 02:00:00+00:00,25.97,6.52,0.0,0.0,0.0,284.85,3.54,244.0,91082.0 +2008-04-16 03:00:00+00:00,24.98,7.91,0.0,0.0,0.0,284.1,3.23,244.0,91151.0 +2008-04-16 04:00:00+00:00,23.99,9.31,0.0,0.0,0.0,283.35,2.91,244.0,91220.0 +2008-04-16 05:00:00+00:00,23.0,10.7,0.0,0.0,0.0,282.6,2.59,243.0,91289.0 +2008-04-16 06:00:00+00:00,21.85,11.53,0.0,0.0,0.0,279.87,2.28,236.0,91271.0 +2008-04-16 07:00:00+00:00,20.69,12.37,0.0,0.0,0.0,277.13,1.97,228.0,91253.0 +2008-04-16 08:00:00+00:00,19.54,13.2,0.0,0.0,0.0,274.4,1.66,220.0,91235.0 +2008-04-16 09:00:00+00:00,18.25,13.68,0.0,0.0,0.0,272.72,1.85,205.0,91214.0 +2008-04-16 10:00:00+00:00,16.97,14.15,0.0,0.0,0.0,271.03,2.04,190.0,91193.0 +2008-04-16 11:00:00+00:00,15.68,14.63,0.0,0.0,0.0,269.35,2.23,175.0,91172.0 +2008-04-16 12:00:00+00:00,17.78,13.54,0.0,0.0,0.0,268.82,2.19,182.0,91211.0 +2008-04-16 13:00:00+00:00,19.88,12.46,0.0,0.0,0.0,268.28,2.14,188.0,91250.0 +2008-04-16 14:00:00+00:00,21.98,11.37,200.0,648.7,55.0,267.75,2.1,195.0,91289.0 +2008-04-16 15:00:00+00:00,24.35,9.95,447.0,850.86,79.0,271.7,3.37,206.0,91262.0 +2008-04-16 16:00:00+00:00,26.71,8.54,678.0,946.05,93.0,275.65,4.64,217.0,91235.0 +2008-04-16 17:00:00+00:00,29.08,7.12,869.0,996.83,103.0,279.6,5.92,228.0,91208.0 +2008-04-16 18:00:00+00:00,29.96,6.48,1003.0,1024.64,109.0,280.32,6.49,231.0,91127.0 +2008-04-16 19:00:00+00:00,30.83,5.83,1068.0,1035.24,112.0,281.03,7.07,235.0,91046.0 +2008-04-16 20:00:00+00:00,31.71,5.19,1060.0,1033.95,111.0,281.75,7.64,238.0,90965.0 +2008-04-16 21:00:00+00:00,31.19,5.37,977.0,1015.16,108.0,281.58,7.66,240.0,90914.0 +2008-04-16 22:00:00+00:00,30.67,5.54,829.0,980.83,101.0,281.42,7.67,241.0,90863.0 +2008-04-16 23:00:00+00:00,30.14,5.72,504.0,546.04,185.0,281.25,7.68,243.0,90812.0 +2008-04-17 00:00:00+00:00,28.33,7.13,392.0,805.56,74.0,279.38,6.74,241.0,90848.0 +2008-04-17 01:00:00+00:00,26.51,8.53,100.0,202.13,63.0,277.52,5.8,239.0,90884.0 +2008-04-17 02:00:00+00:00,24.7,9.94,0.0,0.0,0.0,275.65,4.86,237.0,90920.0 +2008-04-17 03:00:00+00:00,23.26,11.38,0.0,0.0,0.0,274.42,4.44,234.0,90968.0 +2008-04-17 04:00:00+00:00,21.82,12.82,0.0,0.0,0.0,273.18,4.02,231.0,91016.0 +2008-04-17 05:00:00+00:00,20.37,14.26,0.0,0.0,0.0,271.95,3.6,228.0,91064.0 +2008-04-17 06:00:00+00:00,19.34,15.35,0.0,0.0,0.0,268.57,3.41,224.0,91049.0 +2008-04-17 07:00:00+00:00,18.32,16.43,0.0,0.0,0.0,265.18,3.21,220.0,91034.0 +2008-04-17 08:00:00+00:00,17.29,17.52,0.0,0.0,0.0,261.8,3.02,216.0,91019.0 +2008-04-17 09:00:00+00:00,16.64,20.13,0.0,0.0,0.0,259.88,3.05,216.0,91013.0 +2008-04-17 10:00:00+00:00,15.99,22.73,0.0,0.0,0.0,257.97,3.08,215.0,91007.0 +2008-04-17 11:00:00+00:00,15.34,25.34,0.0,0.0,0.0,256.05,3.1,215.0,91001.0 +2008-04-17 12:00:00+00:00,16.93,25.94,0.0,0.0,0.0,255.77,3.24,218.0,91031.0 +2008-04-17 13:00:00+00:00,18.51,26.55,0.0,0.0,0.0,255.48,3.38,222.0,91061.0 +2008-04-17 14:00:00+00:00,20.09,27.15,198.0,628.62,55.0,255.2,3.52,226.0,91091.0 +2008-04-17 15:00:00+00:00,21.65,23.45,439.0,827.67,78.0,256.83,4.72,230.0,91085.0 +2008-04-17 16:00:00+00:00,23.21,19.75,667.0,924.9,92.0,258.47,5.93,234.0,91079.0 +2008-04-17 17:00:00+00:00,24.77,16.05,854.0,974.82,102.0,260.1,7.13,237.0,91073.0 +2008-04-17 18:00:00+00:00,25.56,13.88,986.0,1003.24,108.0,260.1,7.57,242.0,91031.0 +2008-04-17 19:00:00+00:00,26.36,11.71,1052.0,1016.38,111.0,260.1,8.01,246.0,90989.0 +2008-04-17 20:00:00+00:00,27.15,9.54,1046.0,1016.32,111.0,260.1,8.46,250.0,90947.0 +2008-04-17 21:00:00+00:00,26.64,9.09,968.0,1003.48,107.0,260.93,8.25,254.0,90917.0 +2008-04-17 22:00:00+00:00,26.14,8.64,823.0,971.59,100.0,261.77,8.05,257.0,90887.0 +2008-04-17 23:00:00+00:00,25.63,8.19,625.0,912.76,90.0,262.6,7.85,260.0,90857.0 +2008-04-18 00:00:00+00:00,24.31,8.8,393.0,803.98,74.0,262.63,6.89,265.0,90926.0 +2008-04-18 01:00:00+00:00,22.98,9.4,153.0,561.37,49.0,262.67,5.93,270.0,90995.0 +2008-04-18 02:00:00+00:00,21.65,10.01,0.0,0.0,0.0,262.7,4.97,275.0,91064.0 +2008-04-18 03:00:00+00:00,20.58,9.95,0.0,0.0,0.0,262.2,4.78,279.0,91136.0 +2008-04-18 04:00:00+00:00,19.52,9.88,0.0,0.0,0.0,261.7,4.59,283.0,91208.0 +2008-04-18 05:00:00+00:00,18.45,9.82,0.0,0.0,0.0,261.2,4.4,287.0,91280.0 +2008-04-18 06:00:00+00:00,17.22,10.75,0.0,0.0,0.0,256.87,4.07,289.0,91319.0 +2008-04-18 07:00:00+00:00,15.98,11.69,0.0,0.0,0.0,252.53,3.74,292.0,91358.0 +2008-04-18 08:00:00+00:00,14.75,12.62,0.0,0.0,0.0,248.2,3.41,294.0,91397.0 +2008-04-18 09:00:00+00:00,13.65,14.49,0.0,0.0,0.0,242.32,3.14,297.0,91437.0 +2008-04-18 10:00:00+00:00,12.56,16.36,0.0,0.0,0.0,236.43,2.88,300.0,91476.0 +2008-04-18 11:00:00+00:00,11.46,18.23,0.0,0.0,0.0,230.55,2.62,303.0,91515.0 +2008-04-18 12:00:00+00:00,12.72,17.15,0.0,0.0,0.0,229.82,3.09,317.0,91590.0 +2008-04-18 13:00:00+00:00,13.98,16.08,0.0,0.0,0.0,229.08,3.55,331.0,91665.0 +2008-04-18 14:00:00+00:00,15.23,15.0,206.0,648.27,56.0,228.35,4.01,345.0,91740.0 +2008-04-18 15:00:00+00:00,17.1,12.94,450.0,843.65,79.0,230.4,4.32,344.0,91737.0 +2008-04-18 16:00:00+00:00,18.96,10.89,679.0,937.67,93.0,232.45,4.62,343.0,91734.0 +2008-04-18 17:00:00+00:00,20.83,8.83,869.0,989.22,103.0,234.5,4.92,343.0,91731.0 +2008-04-18 18:00:00+00:00,21.94,8.02,1001.0,1016.22,109.0,235.97,5.01,340.0,91674.0 +2008-04-18 19:00:00+00:00,23.05,7.21,1066.0,1027.85,112.0,237.43,5.09,336.0,91617.0 +2008-04-18 20:00:00+00:00,24.16,6.4,1058.0,1027.02,111.0,238.9,5.17,333.0,91560.0 +2008-04-18 21:00:00+00:00,23.97,6.42,978.0,1011.67,108.0,239.35,5.1,336.0,91521.0 +2008-04-18 22:00:00+00:00,23.79,6.45,834.0,982.54,101.0,239.8,5.03,340.0,91482.0 +2008-04-18 23:00:00+00:00,23.6,6.47,636.0,926.8,91.0,240.25,4.97,344.0,91443.0 +2008-04-19 00:00:00+00:00,21.84,8.26,401.0,817.48,75.0,237.93,4.19,355.0,91482.0 +2008-04-19 01:00:00+00:00,20.07,10.05,159.0,586.77,49.0,235.62,3.41,6.0,91521.0 +2008-04-19 02:00:00+00:00,18.3,11.84,0.0,0.0,0.0,233.3,2.63,17.0,91560.0 +2008-04-19 03:00:00+00:00,17.21,12.95,0.0,0.0,0.0,233.7,2.49,23.0,91599.0 +2008-04-19 04:00:00+00:00,16.12,14.05,0.0,0.0,0.0,234.1,2.35,28.0,91638.0 +2008-04-19 05:00:00+00:00,15.02,15.16,0.0,0.0,0.0,234.5,2.21,34.0,91677.0 +2008-04-19 06:00:00+00:00,13.98,16.74,0.0,0.0,0.0,233.22,2.2,40.0,91659.0 +2008-04-19 07:00:00+00:00,12.95,18.31,0.0,0.0,0.0,231.93,2.19,46.0,91641.0 +2008-04-19 08:00:00+00:00,11.91,19.89,0.0,0.0,0.0,230.65,2.18,52.0,91623.0 +2008-04-19 09:00:00+00:00,11.22,20.79,0.0,0.0,0.0,229.65,2.19,57.0,91611.0 +2008-04-19 10:00:00+00:00,10.54,21.7,0.0,0.0,0.0,228.65,2.2,61.0,91599.0 +2008-04-19 11:00:00+00:00,9.85,22.6,0.0,0.0,0.0,227.65,2.21,66.0,91587.0 +2008-04-19 12:00:00+00:00,12.07,19.97,0.0,0.0,0.0,228.28,2.03,70.0,91632.0 +2008-04-19 13:00:00+00:00,14.29,17.35,0.0,0.0,0.0,228.92,1.86,73.0,91677.0 +2008-04-19 14:00:00+00:00,16.5,14.72,213.0,663.2,57.0,229.55,1.68,77.0,91722.0 +2008-04-19 15:00:00+00:00,19.44,11.89,459.0,857.23,79.0,233.4,2.03,82.0,91680.0 +2008-04-19 16:00:00+00:00,22.37,9.07,688.0,945.64,94.0,237.25,2.37,88.0,91638.0 +2008-04-19 17:00:00+00:00,25.3,6.24,877.0,995.88,103.0,241.1,2.72,93.0,91596.0 +2008-04-19 18:00:00+00:00,26.67,5.39,1009.0,1022.37,109.0,242.28,2.47,110.0,91494.0 +2008-04-19 19:00:00+00:00,28.05,4.54,1073.0,1032.87,112.0,243.47,2.22,126.0,91391.0 +2008-04-19 20:00:00+00:00,29.42,3.69,1066.0,1033.4,111.0,244.65,1.97,143.0,91289.0 +2008-04-19 21:00:00+00:00,29.52,3.52,986.0,1018.71,108.0,245.9,1.98,168.0,91193.0 +2008-04-19 22:00:00+00:00,29.62,3.35,840.0,988.12,101.0,247.15,1.99,193.0,91097.0 +2008-04-19 23:00:00+00:00,29.72,3.18,641.0,932.31,91.0,248.4,2.0,218.0,91001.0 +2008-04-20 00:00:00+00:00,27.84,4.24,406.0,825.89,75.0,250.65,1.96,220.0,90983.0 +2008-04-20 01:00:00+00:00,25.95,5.31,162.0,590.51,50.0,252.9,1.93,221.0,90965.0 +2008-04-20 02:00:00+00:00,24.06,6.37,0.0,0.0,0.0,255.15,1.89,222.0,90947.0 +2008-04-20 03:00:00+00:00,23.08,7.34,0.0,0.0,0.0,257.62,1.99,212.0,90968.0 +2008-04-20 04:00:00+00:00,22.1,8.31,0.0,0.0,0.0,260.08,2.09,202.0,90989.0 +2008-04-20 05:00:00+00:00,21.11,9.28,0.0,0.0,0.0,262.55,2.19,191.0,91010.0 +2008-04-20 06:00:00+00:00,19.47,10.86,0.0,0.0,0.0,263.4,2.27,191.0,90995.0 +2008-04-20 07:00:00+00:00,17.83,12.44,0.0,0.0,0.0,264.25,2.35,192.0,90980.0 +2008-04-20 08:00:00+00:00,16.19,14.02,0.0,0.0,0.0,265.1,2.43,192.0,90965.0 +2008-04-20 09:00:00+00:00,15.96,13.83,0.0,0.0,0.0,267.77,2.34,190.0,90968.0 +2008-04-20 10:00:00+00:00,15.73,13.65,0.0,0.0,0.0,270.43,2.26,189.0,90971.0 +2008-04-20 11:00:00+00:00,15.5,13.46,0.0,0.0,0.0,273.1,2.18,188.0,90974.0 +2008-04-20 12:00:00+00:00,17.18,12.23,0.0,0.0,0.0,274.62,2.11,184.0,91019.0 +2008-04-20 13:00:00+00:00,18.86,11.01,12.0,0.0,12.0,276.13,2.04,181.0,91064.0 +2008-04-20 14:00:00+00:00,20.53,9.78,18.0,0.0,18.0,277.65,1.97,178.0,91109.0 +2008-04-20 15:00:00+00:00,22.93,8.13,308.0,284.28,181.0,282.88,3.14,189.0,91088.0 +2008-04-20 16:00:00+00:00,25.33,6.47,674.0,920.36,93.0,288.12,4.31,200.0,91067.0 +2008-04-20 17:00:00+00:00,27.73,4.82,689.0,500.0,299.0,293.35,5.48,210.0,91046.0 +2008-04-20 18:00:00+00:00,28.37,4.79,824.0,499.56,383.0,296.88,6.09,214.0,90977.0 +2008-04-20 19:00:00+00:00,29.0,4.75,869.0,463.21,437.0,300.42,6.7,218.0,90908.0 +2008-04-20 20:00:00+00:00,29.64,4.72,828.0,458.9,403.0,303.95,7.31,222.0,90839.0 +2008-04-20 21:00:00+00:00,28.78,5.77,821.0,544.14,351.0,306.92,7.3,222.0,90809.0 +2008-04-20 22:00:00+00:00,27.92,6.83,705.0,613.57,245.0,309.88,7.28,223.0,90779.0 +2008-04-20 23:00:00+00:00,27.05,7.88,511.0,532.28,196.0,312.85,7.27,224.0,90749.0 +2008-04-21 00:00:00+00:00,25.73,9.84,395.0,797.0,74.0,315.45,6.52,224.0,90800.0 +2008-04-21 01:00:00+00:00,24.41,11.79,114.0,265.82,63.0,318.05,5.77,224.0,90851.0 +2008-04-21 02:00:00+00:00,23.09,13.75,0.0,0.0,0.0,320.65,5.02,224.0,90902.0 +2008-04-21 03:00:00+00:00,21.69,16.25,0.0,0.0,0.0,316.85,4.61,224.0,90962.0 +2008-04-21 04:00:00+00:00,20.29,18.74,0.0,0.0,0.0,313.05,4.19,224.0,91022.0 +2008-04-21 05:00:00+00:00,18.88,21.24,0.0,0.0,0.0,309.25,3.78,224.0,91082.0 +2008-04-21 06:00:00+00:00,17.57,25.03,0.0,0.0,0.0,293.5,3.49,223.0,91100.0 +2008-04-21 07:00:00+00:00,16.25,28.83,0.0,0.0,0.0,277.75,3.2,222.0,91118.0 +2008-04-21 08:00:00+00:00,14.94,32.62,0.0,0.0,0.0,262.0,2.91,222.0,91136.0 +2008-04-21 09:00:00+00:00,14.16,37.27,0.0,0.0,0.0,257.23,2.74,220.0,91139.0 +2008-04-21 10:00:00+00:00,13.37,41.93,0.0,0.0,0.0,252.47,2.58,219.0,91142.0 +2008-04-21 11:00:00+00:00,12.59,46.58,0.0,0.0,0.0,247.7,2.41,218.0,91145.0 +2008-04-21 12:00:00+00:00,14.22,43.34,0.0,0.0,0.0,248.08,2.47,222.0,91202.0 +2008-04-21 13:00:00+00:00,15.85,40.09,13.0,0.0,13.0,248.47,2.53,226.0,91259.0 +2008-04-21 14:00:00+00:00,17.48,36.85,214.0,646.87,57.0,248.85,2.59,230.0,91316.0 +2008-04-21 15:00:00+00:00,19.23,31.59,455.0,835.29,79.0,251.63,3.61,234.0,91313.0 +2008-04-21 16:00:00+00:00,20.97,26.33,678.0,922.23,93.0,254.42,4.63,238.0,91310.0 +2008-04-21 17:00:00+00:00,22.71,21.07,862.0,970.97,102.0,257.2,5.66,242.0,91307.0 +2008-04-21 18:00:00+00:00,23.75,18.47,989.0,995.26,108.0,257.83,5.9,244.0,91253.0 +2008-04-21 19:00:00+00:00,24.8,15.88,1049.0,1004.52,110.0,258.47,6.15,247.0,91199.0 +2008-04-21 20:00:00+00:00,25.84,13.28,1039.0,1000.99,110.0,259.1,6.4,249.0,91145.0 +2008-04-21 21:00:00+00:00,25.65,12.59,959.0,985.48,106.0,259.9,6.21,252.0,91100.0 +2008-04-21 22:00:00+00:00,25.47,11.9,815.0,951.43,100.0,260.7,6.01,254.0,91055.0 +2008-04-21 23:00:00+00:00,25.28,11.21,621.0,896.16,89.0,261.5,5.82,256.0,91010.0 +2008-04-22 00:00:00+00:00,23.99,12.25,392.0,785.7,74.0,262.95,5.03,256.0,91025.0 +2008-04-22 01:00:00+00:00,22.69,13.29,157.0,556.55,49.0,264.4,4.25,255.0,91040.0 +2008-04-22 02:00:00+00:00,21.39,14.33,0.0,0.0,0.0,265.85,3.46,255.0,91055.0 +2008-04-22 03:00:00+00:00,20.16,16.4,0.0,0.0,0.0,265.02,3.01,252.0,91106.0 +2008-04-22 04:00:00+00:00,18.94,18.47,0.0,0.0,0.0,264.18,2.56,250.0,91157.0 +2008-04-22 05:00:00+00:00,17.71,20.54,0.0,0.0,0.0,263.35,2.11,248.0,91208.0 +2008-04-22 06:00:00+00:00,16.92,22.34,0.0,0.0,0.0,261.23,1.97,243.0,91220.0 +2008-04-22 07:00:00+00:00,16.14,24.15,0.0,0.0,0.0,259.12,1.83,238.0,91232.0 +2008-04-22 08:00:00+00:00,15.35,25.95,0.0,0.0,0.0,257.0,1.7,233.0,91244.0 +2008-04-22 09:00:00+00:00,14.71,28.87,0.0,0.0,0.0,255.22,1.54,230.0,91250.0 +2008-04-22 10:00:00+00:00,14.07,31.79,0.0,0.0,0.0,253.43,1.39,226.0,91256.0 +2008-04-22 11:00:00+00:00,13.43,34.71,0.0,0.0,0.0,251.65,1.24,223.0,91262.0 +2008-04-22 12:00:00+00:00,14.92,30.25,0.0,0.0,0.0,253.58,1.12,224.0,91337.0 +2008-04-22 13:00:00+00:00,16.4,25.78,14.0,0.0,14.0,255.52,1.0,225.0,91413.0 +2008-04-22 14:00:00+00:00,17.88,21.32,223.0,669.78,58.0,257.45,0.88,226.0,91488.0 +2008-04-22 15:00:00+00:00,19.76,17.3,467.0,853.42,80.0,260.45,1.68,233.0,91476.0 +2008-04-22 16:00:00+00:00,21.64,13.29,694.0,941.45,94.0,263.45,2.47,241.0,91464.0 +2008-04-22 17:00:00+00:00,23.52,9.27,881.0,990.61,103.0,266.45,3.27,248.0,91452.0 +2008-04-22 18:00:00+00:00,24.78,7.9,1012.0,1017.41,109.0,266.02,3.74,252.0,91394.0 +2008-04-22 19:00:00+00:00,26.04,6.52,1074.0,1027.89,111.0,265.58,4.22,257.0,91337.0 +2008-04-22 20:00:00+00:00,27.3,5.15,1064.0,1024.75,111.0,265.15,4.69,261.0,91280.0 +2008-04-22 21:00:00+00:00,27.16,4.94,983.0,1009.96,107.0,265.82,4.72,266.0,91238.0 +2008-04-22 22:00:00+00:00,27.03,4.73,838.0,978.41,101.0,266.48,4.74,270.0,91196.0 +2008-04-22 23:00:00+00:00,26.89,4.52,641.0,923.64,91.0,267.15,4.77,274.0,91154.0 +2008-04-23 00:00:00+00:00,25.16,5.3,408.0,818.8,75.0,267.48,4.11,280.0,91178.0 +2008-04-23 01:00:00+00:00,23.43,6.09,167.0,596.22,50.0,267.82,3.46,286.0,91202.0 +2008-04-23 02:00:00+00:00,21.7,6.87,0.0,0.0,0.0,268.15,2.8,292.0,91226.0 +2008-04-23 03:00:00+00:00,20.48,8.26,0.0,0.0,0.0,267.03,2.35,311.0,91253.0 +2008-04-23 04:00:00+00:00,19.26,9.66,0.0,0.0,0.0,265.92,1.9,330.0,91280.0 +2008-04-23 05:00:00+00:00,18.04,11.05,0.0,0.0,0.0,264.8,1.45,350.0,91307.0 +2008-04-23 06:00:00+00:00,16.96,12.11,0.0,0.0,0.0,262.58,1.42,14.0,91280.0 +2008-04-23 07:00:00+00:00,15.88,13.18,0.0,0.0,0.0,260.37,1.39,38.0,91253.0 +2008-04-23 08:00:00+00:00,14.8,14.24,0.0,0.0,0.0,258.15,1.37,63.0,91226.0 +2008-04-23 09:00:00+00:00,13.8,16.18,0.0,0.0,0.0,256.58,1.39,69.0,91208.0 +2008-04-23 10:00:00+00:00,12.79,18.12,0.0,0.0,0.0,255.02,1.42,75.0,91190.0 +2008-04-23 11:00:00+00:00,11.79,20.06,0.0,0.0,0.0,253.45,1.45,81.0,91172.0 +2008-04-23 12:00:00+00:00,14.54,17.32,0.0,0.0,0.0,254.4,1.27,87.0,91214.0 +2008-04-23 13:00:00+00:00,17.29,14.58,15.0,0.0,15.0,255.35,1.1,93.0,91256.0 +2008-04-23 14:00:00+00:00,20.03,11.84,227.0,676.2,58.0,256.3,0.92,99.0,91298.0 +2008-04-23 15:00:00+00:00,22.46,9.7,472.0,858.29,80.0,261.35,1.34,125.0,91256.0 +2008-04-23 16:00:00+00:00,24.88,7.55,699.0,944.96,94.0,266.4,1.76,151.0,91214.0 +2008-04-23 17:00:00+00:00,27.31,5.41,886.0,993.7,103.0,271.45,2.18,177.0,91172.0 +2008-04-23 18:00:00+00:00,28.44,4.95,1014.0,1017.04,109.0,272.1,2.91,192.0,91094.0 +2008-04-23 19:00:00+00:00,29.58,4.5,1076.0,1027.79,111.0,272.75,3.65,206.0,91016.0 +2008-04-23 20:00:00+00:00,30.71,4.04,1067.0,1025.93,111.0,273.4,4.39,221.0,90938.0 +2008-04-23 21:00:00+00:00,30.36,4.16,988.0,1013.68,107.0,275.0,4.74,228.0,90878.0 +2008-04-23 22:00:00+00:00,30.02,4.27,843.0,982.79,101.0,276.6,5.09,234.0,90818.0 +2008-04-23 23:00:00+00:00,29.67,4.39,645.0,927.55,91.0,278.2,5.45,241.0,90758.0 +2008-04-24 00:00:00+00:00,27.65,5.28,411.0,822.25,75.0,279.72,4.74,247.0,90818.0 +2008-04-24 01:00:00+00:00,25.62,6.17,169.0,594.72,51.0,281.23,4.04,253.0,90878.0 +2008-04-24 02:00:00+00:00,23.6,7.06,0.0,0.0,0.0,282.75,3.34,260.0,90938.0 +2008-04-24 03:00:00+00:00,22.95,8.68,0.0,0.0,0.0,279.88,2.88,257.0,90983.0 +2008-04-24 04:00:00+00:00,22.31,10.3,0.0,0.0,0.0,277.02,2.43,254.0,91028.0 +2008-04-24 05:00:00+00:00,21.66,11.92,0.0,0.0,0.0,274.15,1.97,252.0,91073.0 +2008-04-24 06:00:00+00:00,20.4,13.59,0.0,0.0,0.0,271.88,1.81,245.0,91076.0 +2008-04-24 07:00:00+00:00,19.14,15.25,0.0,0.0,0.0,269.62,1.65,238.0,91079.0 +2008-04-24 08:00:00+00:00,17.88,16.92,0.0,0.0,0.0,267.35,1.49,231.0,91082.0 +2008-04-24 09:00:00+00:00,17.4,18.07,0.0,0.0,0.0,262.97,1.28,232.0,91079.0 +2008-04-24 10:00:00+00:00,16.91,19.23,0.0,0.0,0.0,258.58,1.07,232.0,91076.0 +2008-04-24 11:00:00+00:00,16.43,20.38,0.0,0.0,0.0,254.2,0.86,233.0,91073.0 +2008-04-24 12:00:00+00:00,17.6,18.49,0.0,0.0,0.0,254.32,0.91,247.0,91160.0 +2008-04-24 13:00:00+00:00,18.77,16.59,16.0,0.0,16.0,254.43,0.96,261.0,91247.0 +2008-04-24 14:00:00+00:00,19.94,14.7,225.0,658.96,58.0,254.55,1.01,275.0,91334.0 +2008-04-24 15:00:00+00:00,21.95,12.78,464.0,837.13,79.0,257.43,1.61,273.0,91307.0 +2008-04-24 16:00:00+00:00,23.96,10.86,686.0,922.12,93.0,260.32,2.21,271.0,91280.0 +2008-04-24 17:00:00+00:00,25.97,8.94,867.0,967.76,102.0,263.2,2.81,269.0,91253.0 +2008-04-24 18:00:00+00:00,27.1,8.51,993.0,993.21,107.0,263.3,3.5,266.0,91193.0 +2008-04-24 19:00:00+00:00,28.24,8.09,1052.0,1001.18,110.0,263.4,4.19,262.0,91133.0 +2008-04-24 20:00:00+00:00,29.37,7.66,1041.0,998.24,109.0,263.5,4.88,259.0,91073.0 +2008-04-24 21:00:00+00:00,29.09,8.01,960.0,980.68,106.0,265.32,5.19,262.0,91040.0 +2008-04-24 22:00:00+00:00,28.82,8.35,818.0,950.18,99.0,267.13,5.5,264.0,91007.0 +2008-04-24 23:00:00+00:00,28.54,8.7,625.0,894.74,89.0,268.95,5.81,266.0,90974.0 +2008-04-25 00:00:00+00:00,26.96,10.04,398.0,789.14,74.0,269.53,5.18,268.0,91019.0 +2008-04-25 01:00:00+00:00,25.37,11.39,164.0,568.33,50.0,270.12,4.55,270.0,91064.0 +2008-04-25 02:00:00+00:00,23.79,12.73,0.0,0.0,0.0,270.7,3.92,272.0,91109.0 +2008-04-25 03:00:00+00:00,22.33,15.18,0.0,0.0,0.0,270.13,3.44,275.0,91175.0 +2008-04-25 04:00:00+00:00,20.88,17.63,0.0,0.0,0.0,269.57,2.96,278.0,91241.0 +2008-04-25 05:00:00+00:00,19.42,20.08,0.0,0.0,0.0,269.0,2.48,280.0,91307.0 +2008-04-25 06:00:00+00:00,19.4,20.17,0.0,0.0,0.0,267.4,2.13,278.0,91298.0 +2008-04-25 07:00:00+00:00,19.39,20.27,0.0,0.0,0.0,265.8,1.77,276.0,91289.0 +2008-04-25 08:00:00+00:00,19.37,20.36,0.0,0.0,0.0,264.2,1.42,274.0,91280.0 +2008-04-25 09:00:00+00:00,18.83,21.44,0.0,0.0,0.0,262.7,1.1,276.0,91274.0 +2008-04-25 10:00:00+00:00,18.3,22.53,0.0,0.0,0.0,261.2,0.78,277.0,91268.0 +2008-04-25 11:00:00+00:00,17.76,23.61,0.0,0.0,0.0,259.7,0.46,278.0,91262.0 +2008-04-25 12:00:00+00:00,18.67,23.95,0.0,0.0,0.0,261.52,0.64,272.0,91313.0 +2008-04-25 13:00:00+00:00,19.58,24.28,24.0,168.83,17.0,263.33,0.82,266.0,91364.0 +2008-04-25 14:00:00+00:00,20.48,24.62,224.0,646.25,58.0,265.15,1.01,259.0,91416.0 +2008-04-25 15:00:00+00:00,22.2,20.91,460.0,822.86,79.0,269.33,1.97,259.0,91403.0 +2008-04-25 16:00:00+00:00,23.91,17.2,681.0,911.96,92.0,273.52,2.93,260.0,91391.0 +2008-04-25 17:00:00+00:00,25.62,13.49,863.0,960.99,101.0,277.7,3.89,260.0,91379.0 +2008-04-25 18:00:00+00:00,26.7,11.97,990.0,987.45,107.0,278.02,4.42,261.0,91313.0 +2008-04-25 19:00:00+00:00,27.78,10.44,1052.0,999.13,110.0,278.33,4.96,262.0,91247.0 +2008-04-25 20:00:00+00:00,28.86,8.92,1045.0,1000.63,109.0,278.65,5.49,264.0,91181.0 +2008-04-25 21:00:00+00:00,28.62,8.79,969.0,989.11,106.0,279.32,5.66,268.0,91160.0 +2008-04-25 22:00:00+00:00,28.39,8.65,830.0,962.58,100.0,279.98,5.82,272.0,91139.0 +2008-04-25 23:00:00+00:00,28.15,8.52,638.0,912.08,90.0,280.65,5.99,276.0,91118.0 +2008-04-26 00:00:00+00:00,26.51,9.87,411.0,814.55,75.0,280.23,5.37,283.0,91169.0 +2008-04-26 01:00:00+00:00,24.86,11.21,173.0,601.71,51.0,279.82,4.74,289.0,91220.0 +2008-04-26 02:00:00+00:00,23.21,12.56,0.0,0.0,0.0,279.4,4.12,296.0,91271.0 +2008-04-26 03:00:00+00:00,21.81,15.0,0.0,0.0,0.0,276.53,3.73,303.0,91331.0 +2008-04-26 04:00:00+00:00,20.41,17.45,0.0,0.0,0.0,273.67,3.34,310.0,91391.0 +2008-04-26 05:00:00+00:00,19.01,19.89,0.0,0.0,0.0,270.8,2.95,317.0,91452.0 +2008-04-26 06:00:00+00:00,18.41,19.66,0.0,0.0,0.0,267.12,2.67,323.0,91455.0 +2008-04-26 07:00:00+00:00,17.8,19.42,0.0,0.0,0.0,263.43,2.39,328.0,91458.0 +2008-04-26 08:00:00+00:00,17.2,19.19,0.0,0.0,0.0,259.75,2.11,334.0,91461.0 +2008-04-26 09:00:00+00:00,16.12,20.98,0.0,0.0,0.0,256.97,2.08,347.0,91467.0 +2008-04-26 10:00:00+00:00,15.03,22.76,0.0,0.0,0.0,254.18,2.05,0.0,91473.0 +2008-04-26 11:00:00+00:00,13.95,24.55,0.0,0.0,0.0,251.4,2.01,13.0,91479.0 +2008-04-26 12:00:00+00:00,16.28,21.98,0.0,0.0,0.0,253.72,1.83,25.0,91536.0 +2008-04-26 13:00:00+00:00,18.6,19.41,28.0,199.47,19.0,256.03,1.66,38.0,91593.0 +2008-04-26 14:00:00+00:00,20.92,16.84,242.0,699.38,60.0,258.35,1.48,50.0,91650.0 +2008-04-26 15:00:00+00:00,22.99,13.81,488.0,873.29,81.0,260.58,1.64,51.0,91626.0 +2008-04-26 16:00:00+00:00,25.05,10.77,715.0,957.5,94.0,262.82,1.8,52.0,91602.0 +2008-04-26 17:00:00+00:00,27.11,7.74,902.0,1004.63,103.0,265.05,1.96,52.0,91578.0 +2008-04-26 18:00:00+00:00,28.16,6.58,1031.0,1028.65,109.0,265.22,1.91,33.0,91509.0 +2008-04-26 19:00:00+00:00,29.21,5.43,1093.0,1038.44,112.0,265.38,1.87,14.0,91440.0 +2008-04-26 20:00:00+00:00,30.26,4.27,1084.0,1038.28,111.0,265.55,1.82,355.0,91370.0 +2008-04-26 21:00:00+00:00,30.17,3.98,1004.0,1025.01,108.0,265.92,2.11,348.0,91322.0 +2008-04-26 22:00:00+00:00,30.09,3.68,859.0,997.33,101.0,266.28,2.4,342.0,91274.0 +2008-04-26 23:00:00+00:00,30.0,3.39,660.0,944.29,91.0,266.65,2.69,335.0,91226.0 +2008-04-27 00:00:00+00:00,27.82,4.27,426.0,844.58,76.0,265.3,2.77,340.0,91244.0 +2008-04-27 01:00:00+00:00,25.63,5.14,181.0,629.52,52.0,263.95,2.86,345.0,91262.0 +2008-04-27 02:00:00+00:00,23.44,6.02,0.0,0.0,0.0,262.6,2.94,350.0,91280.0 +2008-04-27 03:00:00+00:00,22.23,7.07,0.0,0.0,0.0,262.32,2.86,356.0,91313.0 +2008-04-27 04:00:00+00:00,21.02,8.11,0.0,0.0,0.0,262.03,2.78,2.0,91346.0 +2008-04-27 05:00:00+00:00,19.81,9.16,0.0,0.0,0.0,261.75,2.7,8.0,91379.0 +2008-04-27 06:00:00+00:00,18.57,10.24,0.0,0.0,0.0,259.4,2.55,14.0,91358.0 +2008-04-27 07:00:00+00:00,17.34,11.33,0.0,0.0,0.0,257.05,2.4,20.0,91337.0 +2008-04-27 08:00:00+00:00,16.1,12.41,0.0,0.0,0.0,254.7,2.25,26.0,91316.0 +2008-04-27 09:00:00+00:00,15.36,13.62,0.0,0.0,0.0,253.58,2.16,32.0,91295.0 +2008-04-27 10:00:00+00:00,14.63,14.84,0.0,0.0,0.0,252.47,2.07,37.0,91274.0 +2008-04-27 11:00:00+00:00,13.89,16.05,0.0,0.0,0.0,251.35,1.99,42.0,91253.0 +2008-04-27 12:00:00+00:00,16.42,14.02,0.0,0.0,0.0,251.48,1.68,48.0,91319.0 +2008-04-27 13:00:00+00:00,18.94,11.99,31.0,225.82,20.0,251.62,1.37,54.0,91385.0 +2008-04-27 14:00:00+00:00,21.46,9.96,246.0,705.82,60.0,251.75,1.06,60.0,91452.0 +2008-04-27 15:00:00+00:00,23.92,8.24,490.0,872.03,81.0,255.63,1.08,56.0,91406.0 +2008-04-27 16:00:00+00:00,26.38,6.53,715.0,953.63,94.0,259.52,1.09,53.0,91361.0 +2008-04-27 17:00:00+00:00,28.84,4.81,898.0,996.69,103.0,263.4,1.1,49.0,91316.0 +2008-04-27 18:00:00+00:00,29.85,4.53,1023.0,1018.52,108.0,264.35,1.42,10.0,91232.0 +2008-04-27 19:00:00+00:00,30.85,4.26,1081.0,1024.82,111.0,265.3,1.73,332.0,91148.0 +2008-04-27 20:00:00+00:00,31.86,3.98,1067.0,1019.39,110.0,266.25,2.04,293.0,91064.0 +2008-04-27 21:00:00+00:00,31.74,4.19,983.0,1000.29,107.0,266.42,2.75,297.0,91010.0 +2008-04-27 22:00:00+00:00,31.62,4.41,838.0,968.94,100.0,266.58,3.46,301.0,90956.0 +2008-04-27 23:00:00+00:00,31.49,4.62,641.0,911.8,90.0,266.75,4.17,304.0,90902.0 +2008-04-28 00:00:00+00:00,29.46,6.0,411.0,807.09,75.0,264.77,4.01,311.0,90944.0 +2008-04-28 01:00:00+00:00,27.42,7.39,174.0,593.99,51.0,262.78,3.85,317.0,90986.0 +2008-04-28 02:00:00+00:00,25.39,8.77,0.0,0.0,0.0,260.8,3.7,324.0,91028.0 +2008-04-28 03:00:00+00:00,24.38,9.86,0.0,0.0,0.0,262.7,3.61,334.0,91076.0 +2008-04-28 04:00:00+00:00,23.37,10.95,0.0,0.0,0.0,264.6,3.52,343.0,91124.0 +2008-04-28 05:00:00+00:00,22.35,12.04,0.0,0.0,0.0,266.5,3.43,353.0,91172.0 +2008-04-28 06:00:00+00:00,21.3,12.43,0.0,0.0,0.0,267.22,3.18,6.0,91190.0 +2008-04-28 07:00:00+00:00,20.24,12.81,0.0,0.0,0.0,267.93,2.93,19.0,91208.0 +2008-04-28 08:00:00+00:00,19.19,13.2,0.0,0.0,0.0,268.65,2.68,31.0,91226.0 +2008-04-28 09:00:00+00:00,18.23,13.25,0.0,0.0,0.0,267.58,2.74,42.0,91259.0 +2008-04-28 10:00:00+00:00,17.26,13.29,0.0,0.0,0.0,266.52,2.8,53.0,91292.0 +2008-04-28 11:00:00+00:00,16.3,13.34,0.0,0.0,0.0,265.45,2.87,63.0,91325.0 +2008-04-28 12:00:00+00:00,18.5,11.81,0.0,0.0,0.0,265.35,3.4,68.0,91428.0 +2008-04-28 13:00:00+00:00,20.7,10.29,32.0,229.75,20.0,265.25,3.93,73.0,91530.0 +2008-04-28 14:00:00+00:00,22.9,8.76,245.0,693.55,60.0,265.15,4.46,79.0,91632.0 +2008-04-28 15:00:00+00:00,24.47,7.52,488.0,862.45,81.0,264.2,5.71,82.0,91629.0 +2008-04-28 16:00:00+00:00,26.03,6.28,712.0,945.3,94.0,263.25,6.97,85.0,91626.0 +2008-04-28 17:00:00+00:00,27.6,5.04,893.0,987.64,103.0,262.3,8.23,88.0,91623.0 +2008-04-28 18:00:00+00:00,28.32,5.01,1018.0,1010.73,108.0,263.17,7.98,90.0,91584.0 +2008-04-28 19:00:00+00:00,29.04,4.99,1078.0,1019.75,111.0,264.03,7.72,91.0,91545.0 +2008-04-28 20:00:00+00:00,29.76,4.96,1068.0,1018.7,110.0,264.9,7.46,93.0,91506.0 +2008-04-28 21:00:00+00:00,29.48,5.39,988.0,1004.21,107.0,267.2,7.02,92.0,91479.0 +2008-04-28 22:00:00+00:00,29.21,5.82,845.0,976.09,100.0,269.5,6.58,92.0,91452.0 +2008-04-28 23:00:00+00:00,28.93,6.25,650.0,924.07,90.0,271.8,6.14,92.0,91425.0 +2008-04-29 00:00:00+00:00,27.5,7.02,420.0,824.96,75.0,271.78,5.69,89.0,91461.0 +2008-04-29 01:00:00+00:00,26.07,7.78,180.0,611.78,52.0,271.77,5.24,87.0,91497.0 +2008-04-29 02:00:00+00:00,24.64,8.55,0.0,0.0,0.0,271.75,4.79,84.0,91533.0 +2008-04-29 03:00:00+00:00,23.8,10.48,0.0,0.0,0.0,271.45,4.65,85.0,91596.0 +2008-04-29 04:00:00+00:00,22.96,12.4,0.0,0.0,0.0,271.15,4.52,87.0,91659.0 +2008-04-29 05:00:00+00:00,22.11,14.33,0.0,0.0,0.0,270.85,4.39,88.0,91722.0 +2008-04-29 06:00:00+00:00,21.03,16.34,0.0,0.0,0.0,266.93,4.23,87.0,91731.0 +2008-04-29 07:00:00+00:00,19.95,18.35,0.0,0.0,0.0,263.02,4.08,86.0,91740.0 +2008-04-29 08:00:00+00:00,18.87,20.36,0.0,0.0,0.0,259.1,3.93,85.0,91749.0 +2008-04-29 09:00:00+00:00,17.71,21.91,0.0,0.0,0.0,256.28,3.83,85.0,91752.0 +2008-04-29 10:00:00+00:00,16.55,23.47,0.0,0.0,0.0,253.47,3.74,85.0,91755.0 +2008-04-29 11:00:00+00:00,15.39,25.02,0.0,0.0,0.0,250.65,3.64,85.0,91758.0 +2008-04-29 12:00:00+00:00,17.07,23.38,0.0,0.0,0.0,248.9,3.43,85.0,91794.0 +2008-04-29 13:00:00+00:00,18.75,21.75,35.0,251.45,21.0,247.15,3.22,84.0,91830.0 +2008-04-29 14:00:00+00:00,20.43,20.11,249.0,700.29,60.0,245.4,3.01,84.0,91866.0 +2008-04-29 15:00:00+00:00,22.9,16.35,493.0,867.86,81.0,250.02,3.6,90.0,91806.0 +2008-04-29 16:00:00+00:00,25.37,12.58,719.0,952.38,94.0,254.63,4.2,96.0,91746.0 +2008-04-29 17:00:00+00:00,27.84,8.82,903.0,997.42,103.0,259.25,4.8,102.0,91686.0 +2008-04-29 18:00:00+00:00,29.22,7.23,1030.0,1021.88,108.0,262.07,4.44,110.0,91593.0 +2008-04-29 19:00:00+00:00,30.61,5.63,1090.0,1030.54,111.0,264.88,4.07,118.0,91500.0 +2008-04-29 20:00:00+00:00,31.99,4.04,1078.0,1027.6,110.0,267.7,3.71,126.0,91406.0 +2008-04-29 21:00:00+00:00,32.02,3.81,997.0,1012.69,107.0,269.37,3.02,143.0,91331.0 +2008-04-29 22:00:00+00:00,32.05,3.57,852.0,983.23,100.0,271.03,2.33,160.0,91256.0 +2008-04-29 23:00:00+00:00,32.08,3.34,655.0,929.73,90.0,272.7,1.64,177.0,91181.0 +2008-04-30 00:00:00+00:00,31.36,4.22,318.0,414.2,144.0,270.82,1.78,151.0,91166.0 +2008-04-30 01:00:00+00:00,30.64,5.1,131.0,298.06,68.0,268.93,1.92,125.0,91151.0 +2008-04-30 02:00:00+00:00,29.92,5.98,0.0,0.0,0.0,267.05,2.06,99.0,91136.0 +2008-04-30 03:00:00+00:00,28.01,7.38,0.0,0.0,0.0,269.0,2.13,101.0,91157.0 +2008-04-30 04:00:00+00:00,26.11,8.78,0.0,0.0,0.0,270.95,2.21,102.0,91178.0 +2008-04-30 05:00:00+00:00,24.2,10.18,0.0,0.0,0.0,272.9,2.29,104.0,91199.0 +2008-04-30 06:00:00+00:00,22.34,12.05,0.0,0.0,0.0,271.82,2.2,107.0,91184.0 +2008-04-30 07:00:00+00:00,20.49,13.91,0.0,0.0,0.0,270.73,2.11,110.0,91169.0 +2008-04-30 08:00:00+00:00,18.63,15.78,0.0,0.0,0.0,269.65,2.01,113.0,91154.0 +2008-04-30 09:00:00+00:00,17.8,16.11,0.0,0.0,0.0,268.48,2.06,115.0,91142.0 +2008-04-30 10:00:00+00:00,16.96,16.44,0.0,0.0,0.0,267.32,2.11,116.0,91130.0 +2008-04-30 11:00:00+00:00,16.13,16.77,0.0,0.0,0.0,266.15,2.17,117.0,91118.0 +2008-04-30 12:00:00+00:00,18.73,14.37,0.0,0.0,0.0,266.98,1.99,126.0,91157.0 +2008-04-30 13:00:00+00:00,21.32,11.98,37.0,254.01,22.0,267.82,1.81,134.0,91196.0 +2008-04-30 14:00:00+00:00,23.91,9.58,248.0,688.76,60.0,268.65,1.63,143.0,91235.0 +2008-04-30 15:00:00+00:00,26.47,7.85,488.0,854.5,80.0,273.88,2.4,170.0,91196.0 +2008-04-30 16:00:00+00:00,34.37,0.5,710.0,936.74,93.0,279.06,5.59,196.0,91157.0 +2008-04-30 17:00:00+00:00,33.67,0.14,892.0,982.36,102.0,283.01,5.38,223.0,91118.0 +2008-04-30 18:00:00+00:00,32.97,2.36,1016.0,1005.4,107.0,286.96,5.16,230.0,91049.0 +2008-04-30 19:00:00+00:00,32.27,4.57,576.0,94.57,486.0,290.91,4.95,236.0,90980.0 +2008-04-30 20:00:00+00:00,31.57,6.79,894.0,488.59,433.0,294.85,4.73,243.0,90911.0 +2008-04-30 21:00:00+00:00,30.87,9.01,869.0,638.39,307.0,298.8,4.52,243.0,90854.0 +2008-04-30 22:00:00+00:00,30.17,11.23,837.0,962.98,99.0,302.75,4.31,244.0,90797.0 +2008-04-30 23:00:00+00:00,29.47,13.44,643.0,909.12,89.0,306.7,4.09,245.0,90740.0 +2007-05-01 00:00:00+00:00,28.77,15.66,390.0,727.57,83.0,310.65,3.88,278.0,90950.0 +2007-05-01 01:00:00+00:00,28.06,17.88,165.0,510.52,56.0,314.6,3.66,282.0,90953.0 +2007-05-01 02:00:00+00:00,27.36,20.09,0.0,0.0,0.0,318.55,3.45,285.0,90956.0 +2007-05-01 03:00:00+00:00,26.66,22.31,0.0,0.0,0.0,322.5,3.23,279.0,91016.0 +2007-05-01 04:00:00+00:00,25.96,24.53,0.0,0.0,0.0,326.45,3.02,273.0,91076.0 +2007-05-01 05:00:00+00:00,25.26,26.75,0.0,0.0,0.0,330.4,2.8,267.0,91136.0 +2007-05-01 06:00:00+00:00,24.56,28.96,0.0,0.0,0.0,334.35,2.59,259.0,91127.0 +2007-05-01 07:00:00+00:00,23.86,31.18,0.0,0.0,0.0,338.3,2.37,251.0,91118.0 +2007-05-01 08:00:00+00:00,21.51,34.95,0.0,0.0,0.0,302.45,1.61,242.0,91109.0 +2007-05-01 09:00:00+00:00,20.34,35.92,0.0,0.0,0.0,300.72,1.47,228.0,91100.0 +2007-05-01 10:00:00+00:00,19.16,36.88,0.0,0.0,0.0,298.98,1.32,214.0,91091.0 +2007-05-01 11:00:00+00:00,17.98,37.85,0.0,0.0,0.0,297.25,1.17,200.0,91082.0 +2007-05-01 12:00:00+00:00,19.9,33.99,0.0,0.0,0.0,298.13,1.33,199.0,91097.0 +2007-05-01 13:00:00+00:00,21.83,30.13,34.0,192.45,22.0,299.02,1.49,197.0,91112.0 +2007-05-01 14:00:00+00:00,23.75,26.27,229.0,594.31,65.0,299.9,1.66,196.0,91127.0 +2007-05-01 15:00:00+00:00,25.58,22.82,456.0,766.44,88.0,303.42,2.37,201.0,91094.0 +2007-05-01 16:00:00+00:00,27.41,19.37,669.0,856.27,103.0,306.93,3.08,207.0,91061.0 +2007-05-01 17:00:00+00:00,29.24,15.92,844.0,905.45,114.0,310.45,3.79,212.0,91028.0 +2007-05-01 18:00:00+00:00,29.93,15.31,699.0,262.72,461.0,311.28,4.49,211.0,90959.0 +2007-05-01 19:00:00+00:00,30.62,14.7,1027.0,948.33,123.0,312.12,5.18,210.0,90890.0 +2007-05-01 20:00:00+00:00,31.32,14.09,878.0,455.01,448.0,312.95,5.88,209.0,90821.0 +2007-05-01 21:00:00+00:00,30.61,15.93,492.0,79.38,422.0,313.62,5.99,216.0,90797.0 +2007-05-01 22:00:00+00:00,29.9,17.78,702.0,569.09,265.0,314.28,6.11,222.0,90773.0 +2007-05-01 23:00:00+00:00,29.2,19.62,555.0,633.34,168.0,314.95,6.22,228.0,90749.0 +2007-05-02 00:00:00+00:00,27.9,23.06,389.0,722.02,83.0,316.62,5.4,237.0,90782.0 +2007-05-02 01:00:00+00:00,26.59,26.49,165.0,505.47,56.0,318.28,4.58,245.0,90815.0 +2007-05-02 02:00:00+00:00,25.29,29.93,0.0,0.0,0.0,319.95,3.77,253.0,90848.0 +2007-05-02 03:00:00+00:00,23.99,35.08,0.0,0.0,0.0,318.37,3.14,257.0,90923.0 +2007-05-02 04:00:00+00:00,22.7,40.23,0.0,0.0,0.0,316.78,2.51,261.0,90998.0 +2007-05-02 05:00:00+00:00,21.4,45.38,0.0,0.0,0.0,315.2,1.88,265.0,91073.0 +2007-05-02 06:00:00+00:00,20.39,46.64,0.0,0.0,0.0,314.03,1.83,252.0,91067.0 +2007-05-02 07:00:00+00:00,19.39,47.9,0.0,0.0,0.0,312.87,1.79,239.0,91061.0 +2007-05-02 08:00:00+00:00,18.38,49.16,0.0,0.0,0.0,311.7,1.75,226.0,91055.0 +2007-05-02 09:00:00+00:00,17.8,50.32,0.0,0.0,0.0,307.62,1.73,221.0,91067.0 +2007-05-02 10:00:00+00:00,17.21,51.49,0.0,0.0,0.0,303.53,1.71,216.0,91079.0 +2007-05-02 11:00:00+00:00,16.62,52.65,0.0,0.0,0.0,299.45,1.7,211.0,91091.0 +2007-05-02 12:00:00+00:00,17.98,48.47,0.0,0.0,0.0,296.53,1.6,211.0,91127.0 +2007-05-02 13:00:00+00:00,19.35,44.28,36.0,198.24,23.0,293.62,1.51,210.0,91163.0 +2007-05-02 14:00:00+00:00,20.71,40.1,234.0,602.44,66.0,290.7,1.42,210.0,91199.0 +2007-05-02 15:00:00+00:00,22.67,33.75,462.0,772.69,89.0,294.38,1.94,225.0,91184.0 +2007-05-02 16:00:00+00:00,24.64,27.39,675.0,860.87,104.0,298.07,2.46,241.0,91169.0 +2007-05-02 17:00:00+00:00,26.6,21.04,851.0,911.89,114.0,301.75,2.98,256.0,91154.0 +2007-05-02 18:00:00+00:00,27.61,19.33,974.0,940.9,120.0,301.97,3.43,261.0,91100.0 +2007-05-02 19:00:00+00:00,28.63,17.61,1032.0,952.02,123.0,302.18,3.88,266.0,91046.0 +2007-05-02 20:00:00+00:00,29.65,15.9,1023.0,950.89,123.0,302.4,4.33,272.0,90992.0 +2007-05-02 21:00:00+00:00,29.65,15.51,946.0,936.32,119.0,302.6,4.49,273.0,90944.0 +2007-05-02 22:00:00+00:00,29.66,15.11,808.0,904.61,112.0,302.8,4.65,275.0,90896.0 +2007-05-02 23:00:00+00:00,29.67,14.72,620.0,847.09,101.0,303.0,4.81,276.0,90848.0 +2007-05-03 00:00:00+00:00,28.28,16.28,399.0,740.02,84.0,302.92,4.27,275.0,90857.0 +2007-05-03 01:00:00+00:00,26.9,17.84,172.0,528.1,57.0,302.83,3.72,274.0,90866.0 +2007-05-03 02:00:00+00:00,25.51,19.4,0.0,0.0,0.0,302.75,3.17,273.0,90875.0 +2007-05-03 03:00:00+00:00,24.25,20.69,0.0,0.0,0.0,301.5,3.04,270.0,90944.0 +2007-05-03 04:00:00+00:00,22.99,21.98,0.0,0.0,0.0,300.25,2.91,266.0,91013.0 +2007-05-03 05:00:00+00:00,21.73,23.27,0.0,0.0,0.0,299.0,2.79,263.0,91082.0 +2007-05-03 06:00:00+00:00,21.27,25.3,0.0,0.0,0.0,295.78,2.52,259.0,91088.0 +2007-05-03 07:00:00+00:00,20.81,27.33,0.0,0.0,0.0,292.57,2.26,255.0,91094.0 +2007-05-03 08:00:00+00:00,20.35,29.36,0.0,0.0,0.0,289.35,2.0,251.0,91100.0 +2007-05-03 09:00:00+00:00,19.63,31.84,0.0,0.0,0.0,287.22,1.78,241.0,91094.0 +2007-05-03 10:00:00+00:00,18.9,34.32,0.0,0.0,0.0,285.08,1.56,230.0,91088.0 +2007-05-03 11:00:00+00:00,18.17,36.8,0.0,0.0,0.0,282.95,1.34,220.0,91082.0 +2007-05-03 12:00:00+00:00,19.54,32.26,0.0,0.0,0.0,284.28,1.37,228.0,91115.0 +2007-05-03 13:00:00+00:00,20.91,27.71,40.0,218.25,25.0,285.62,1.4,236.0,91148.0 +2007-05-03 14:00:00+00:00,22.28,23.17,243.0,624.77,67.0,286.95,1.43,243.0,91181.0 +2007-05-03 15:00:00+00:00,24.04,20.85,475.0,793.41,90.0,289.95,2.34,244.0,91133.0 +2007-05-03 16:00:00+00:00,25.79,18.52,691.0,880.57,105.0,292.95,3.24,244.0,91085.0 +2007-05-03 17:00:00+00:00,27.55,16.2,868.0,928.25,116.0,295.95,4.14,244.0,91037.0 +2007-05-03 18:00:00+00:00,28.62,14.89,991.0,955.66,122.0,295.22,4.85,247.0,90980.0 +2007-05-03 19:00:00+00:00,29.69,13.59,1051.0,968.3,125.0,294.48,5.56,249.0,90923.0 +2007-05-03 20:00:00+00:00,30.76,12.28,1042.0,968.46,124.0,293.75,6.28,251.0,90866.0 +2007-05-03 21:00:00+00:00,30.39,12.09,964.0,954.06,120.0,293.9,6.42,252.0,90818.0 +2007-05-03 22:00:00+00:00,30.03,11.91,823.0,921.04,113.0,294.05,6.57,253.0,90770.0 +2007-05-03 23:00:00+00:00,29.67,11.72,632.0,862.75,102.0,294.2,6.72,254.0,90722.0 +2007-05-04 00:00:00+00:00,28.18,12.55,408.0,755.56,85.0,294.98,6.05,254.0,90731.0 +2007-05-04 01:00:00+00:00,26.69,13.38,177.0,541.21,58.0,295.77,5.37,253.0,90740.0 +2007-05-04 02:00:00+00:00,25.2,14.21,0.0,0.0,0.0,296.55,4.7,253.0,90749.0 +2007-05-04 03:00:00+00:00,23.66,15.6,0.0,0.0,0.0,293.58,4.09,253.0,90818.0 +2007-05-04 04:00:00+00:00,22.12,16.98,0.0,0.0,0.0,290.62,3.47,253.0,90887.0 +2007-05-04 05:00:00+00:00,20.58,18.37,0.0,0.0,0.0,287.65,2.86,253.0,90956.0 +2007-05-04 06:00:00+00:00,19.5,20.03,0.0,0.0,0.0,284.05,2.63,243.0,90947.0 +2007-05-04 07:00:00+00:00,18.43,21.69,0.0,0.0,0.0,280.45,2.4,233.0,90938.0 +2007-05-04 08:00:00+00:00,17.35,23.35,0.0,0.0,0.0,276.85,2.18,223.0,90929.0 +2007-05-04 09:00:00+00:00,16.62,24.84,0.0,0.0,0.0,274.43,2.25,218.0,90923.0 +2007-05-04 10:00:00+00:00,15.88,26.32,0.0,0.0,0.0,272.02,2.32,214.0,90917.0 +2007-05-04 11:00:00+00:00,15.15,27.81,0.0,0.0,0.0,269.6,2.39,209.0,90911.0 +2007-05-04 12:00:00+00:00,17.11,26.11,0.0,0.0,0.0,270.65,2.82,217.0,90923.0 +2007-05-04 13:00:00+00:00,19.07,24.4,42.0,222.84,26.0,271.7,3.25,224.0,90935.0 +2007-05-04 14:00:00+00:00,21.03,22.7,244.0,618.7,68.0,272.75,3.68,232.0,90947.0 +2007-05-04 15:00:00+00:00,22.69,19.85,473.0,785.34,90.0,275.9,4.58,234.0,90923.0 +2007-05-04 16:00:00+00:00,24.34,17.01,687.0,871.77,105.0,279.05,5.48,235.0,90899.0 +2007-05-04 17:00:00+00:00,26.0,14.16,862.0,919.98,115.0,282.2,6.37,237.0,90875.0 +2007-05-04 18:00:00+00:00,27.0,13.55,854.0,492.9,405.0,283.97,6.91,238.0,90803.0 +2007-05-04 19:00:00+00:00,28.0,12.95,1044.0,960.56,124.0,285.73,7.46,240.0,90731.0 +2007-05-04 20:00:00+00:00,29.01,12.34,1034.0,958.63,124.0,287.5,8.0,241.0,90659.0 +2007-05-04 21:00:00+00:00,28.66,13.0,847.0,549.65,360.0,289.02,8.16,240.0,90598.0 +2007-05-04 22:00:00+00:00,28.31,13.67,671.0,475.19,304.0,290.53,8.32,238.0,90538.0 +2007-05-04 23:00:00+00:00,27.96,14.33,549.0,594.23,183.0,292.05,8.48,237.0,90478.0 +2007-05-05 00:00:00+00:00,26.23,16.32,407.0,750.01,85.0,290.7,7.83,236.0,90511.0 +2007-05-05 01:00:00+00:00,24.5,18.3,178.0,540.57,58.0,289.35,7.17,236.0,90544.0 +2007-05-05 02:00:00+00:00,22.77,20.29,0.0,0.0,0.0,288.0,6.51,235.0,90577.0 +2007-05-05 03:00:00+00:00,21.67,22.37,0.0,0.0,0.0,285.33,6.14,234.0,90653.0 +2007-05-05 04:00:00+00:00,20.58,24.45,0.0,0.0,0.0,282.67,5.77,233.0,90728.0 +2007-05-05 05:00:00+00:00,19.48,26.53,0.0,0.0,0.0,280.0,5.41,232.0,90803.0 +2007-05-05 06:00:00+00:00,18.56,29.03,0.0,0.0,0.0,276.15,4.97,231.0,90809.0 +2007-05-05 07:00:00+00:00,17.64,31.53,0.0,0.0,0.0,272.3,4.53,230.0,90815.0 +2007-05-05 08:00:00+00:00,16.72,34.03,0.0,0.0,0.0,268.45,4.1,228.0,90821.0 +2007-05-05 09:00:00+00:00,16.08,38.63,0.0,0.0,0.0,266.72,4.0,229.0,90821.0 +2007-05-05 10:00:00+00:00,15.43,43.22,0.0,0.0,0.0,264.98,3.9,230.0,90821.0 +2007-05-05 11:00:00+00:00,14.79,47.82,0.0,0.0,0.0,263.25,3.81,231.0,90821.0 +2007-05-05 12:00:00+00:00,15.7,44.25,0.0,0.0,0.0,267.08,4.51,232.0,90809.0 +2007-05-05 13:00:00+00:00,16.61,40.69,32.0,80.22,26.0,270.92,5.22,233.0,90797.0 +2007-05-05 14:00:00+00:00,17.52,37.12,192.0,330.84,97.0,274.75,5.93,235.0,90785.0 +2007-05-05 15:00:00+00:00,19.15,31.28,476.0,785.64,91.0,277.77,6.64,237.0,90758.0 +2007-05-05 16:00:00+00:00,20.78,25.43,692.0,875.07,106.0,280.78,7.35,240.0,90731.0 +2007-05-05 17:00:00+00:00,22.41,19.59,869.0,925.34,116.0,283.8,8.06,242.0,90704.0 +2007-05-05 18:00:00+00:00,23.42,17.52,991.0,952.33,122.0,285.2,8.46,244.0,90640.0 +2007-05-05 19:00:00+00:00,24.44,15.44,1050.0,964.37,125.0,286.6,8.86,246.0,90577.0 +2007-05-05 20:00:00+00:00,25.46,13.37,1040.0,963.6,124.0,288.0,9.26,248.0,90514.0 +2007-05-05 21:00:00+00:00,25.09,13.37,963.0,950.02,120.0,288.47,9.08,250.0,90484.0 +2007-05-05 22:00:00+00:00,24.73,13.36,823.0,917.62,113.0,288.93,8.9,252.0,90454.0 +2007-05-05 23:00:00+00:00,24.37,13.36,633.0,859.89,102.0,289.4,8.72,254.0,90424.0 +2007-05-06 00:00:00+00:00,23.2,14.29,410.0,753.81,85.0,292.97,7.47,255.0,90472.0 +2007-05-06 01:00:00+00:00,22.04,15.22,180.0,539.97,59.0,296.53,6.23,257.0,90520.0 +2007-05-06 02:00:00+00:00,20.87,16.15,0.0,0.0,0.0,300.1,4.98,258.0,90568.0 +2007-05-06 03:00:00+00:00,19.88,16.98,0.0,0.0,0.0,298.37,4.46,259.0,90640.0 +2007-05-06 04:00:00+00:00,18.9,17.81,0.0,0.0,0.0,296.63,3.94,260.0,90713.0 +2007-05-06 05:00:00+00:00,17.91,18.64,0.0,0.0,0.0,294.9,3.42,260.0,90785.0 +2007-05-06 06:00:00+00:00,16.77,20.36,0.0,0.0,0.0,289.2,3.01,256.0,90806.0 +2007-05-06 07:00:00+00:00,15.64,22.07,0.0,0.0,0.0,283.5,2.6,252.0,90827.0 +2007-05-06 08:00:00+00:00,14.5,23.79,0.0,0.0,0.0,277.8,2.19,248.0,90848.0 +2007-05-06 09:00:00+00:00,14.0,23.83,0.0,0.0,0.0,274.88,2.04,241.0,90866.0 +2007-05-06 10:00:00+00:00,13.49,23.88,0.0,0.0,0.0,271.97,1.89,234.0,90884.0 +2007-05-06 11:00:00+00:00,12.99,23.92,0.0,0.0,0.0,269.05,1.74,227.0,90902.0 +2007-05-06 12:00:00+00:00,14.36,22.56,0.0,0.0,0.0,266.38,1.63,253.0,91001.0 +2007-05-06 13:00:00+00:00,15.72,21.21,48.0,257.37,28.0,263.72,1.53,279.0,91100.0 +2007-05-06 14:00:00+00:00,17.09,19.85,259.0,652.28,70.0,261.05,1.42,304.0,91199.0 +2007-05-06 15:00:00+00:00,18.56,17.72,493.0,812.46,93.0,261.82,1.64,305.0,91199.0 +2007-05-06 16:00:00+00:00,20.04,15.58,710.0,897.8,107.0,262.58,1.85,306.0,91199.0 +2007-05-06 17:00:00+00:00,21.51,13.45,888.0,945.47,117.0,263.35,2.07,307.0,91199.0 +2007-05-06 18:00:00+00:00,22.55,12.33,1012.0,971.55,124.0,261.5,2.06,302.0,91157.0 +2007-05-06 19:00:00+00:00,23.59,11.22,1072.0,984.87,126.0,259.65,2.04,297.0,91115.0 +2007-05-06 20:00:00+00:00,24.63,10.1,1062.0,983.31,126.0,257.8,2.03,292.0,91073.0 +2007-05-06 21:00:00+00:00,24.76,9.83,983.0,968.87,122.0,257.22,2.07,290.0,91040.0 +2007-05-06 22:00:00+00:00,24.89,9.57,841.0,936.59,115.0,256.63,2.12,288.0,91007.0 +2007-05-06 23:00:00+00:00,25.02,9.3,649.0,881.92,103.0,256.05,2.17,285.0,90974.0 +2007-05-07 00:00:00+00:00,23.92,10.37,423.0,776.07,87.0,260.13,1.83,292.0,91016.0 +2007-05-07 01:00:00+00:00,22.82,11.45,189.0,570.34,60.0,264.22,1.5,299.0,91058.0 +2007-05-07 02:00:00+00:00,21.72,12.52,0.0,0.0,0.0,268.3,1.17,306.0,91100.0 +2007-05-07 03:00:00+00:00,20.44,13.8,0.0,0.0,0.0,269.83,1.32,338.0,91157.0 +2007-05-07 04:00:00+00:00,19.15,15.09,0.0,0.0,0.0,271.37,1.48,10.0,91214.0 +2007-05-07 05:00:00+00:00,17.87,16.37,0.0,0.0,0.0,272.9,1.63,42.0,91271.0 +2007-05-07 06:00:00+00:00,16.86,17.93,0.0,0.0,0.0,273.63,1.67,53.0,91277.0 +2007-05-07 07:00:00+00:00,15.85,19.48,0.0,0.0,0.0,274.37,1.72,64.0,91283.0 +2007-05-07 08:00:00+00:00,14.83,21.04,0.0,0.0,0.0,275.1,1.77,75.0,91289.0 +2007-05-07 09:00:00+00:00,14.12,22.48,0.0,0.0,0.0,276.07,1.84,76.0,91283.0 +2007-05-07 10:00:00+00:00,13.4,23.93,0.0,0.0,0.0,277.03,1.91,77.0,91277.0 +2007-05-07 11:00:00+00:00,12.68,25.37,0.0,0.0,0.0,278.0,1.99,78.0,91271.0 +2007-05-07 12:00:00+00:00,15.31,22.22,0.0,0.0,0.0,283.58,2.07,79.0,91295.0 +2007-05-07 13:00:00+00:00,17.94,19.08,48.0,248.31,28.0,289.17,2.15,79.0,91319.0 +2007-05-07 14:00:00+00:00,20.57,15.93,251.0,622.7,69.0,294.75,2.23,80.0,91343.0 +2007-05-07 15:00:00+00:00,22.71,13.38,477.0,780.52,91.0,298.32,3.11,91.0,91307.0 +2007-05-07 16:00:00+00:00,24.85,10.82,685.0,859.62,106.0,301.88,3.99,102.0,91271.0 +2007-05-07 17:00:00+00:00,26.99,8.27,855.0,905.62,115.0,305.45,4.87,114.0,91235.0 +2007-05-07 18:00:00+00:00,27.21,9.02,972.0,929.6,121.0,305.23,4.55,125.0,91181.0 +2007-05-07 19:00:00+00:00,27.43,9.76,1027.0,938.82,124.0,305.02,4.23,136.0,91127.0 +2007-05-07 20:00:00+00:00,27.66,10.51,722.0,237.11,496.0,304.8,3.9,147.0,91073.0 +2007-05-07 21:00:00+00:00,27.14,11.29,665.0,237.1,454.0,307.35,3.23,157.0,91031.0 +2007-05-07 22:00:00+00:00,26.63,12.06,418.0,72.12,362.0,309.9,2.56,168.0,90989.0 +2007-05-07 23:00:00+00:00,26.12,12.84,245.0,22.56,231.0,312.45,1.89,178.0,90947.0 +2007-05-08 00:00:00+00:00,25.95,15.23,125.0,0.0,125.0,316.15,1.65,195.0,90968.0 +2007-05-08 01:00:00+00:00,25.78,17.61,62.0,0.0,62.0,319.85,1.4,211.0,90989.0 +2007-05-08 02:00:00+00:00,25.61,20.0,0.0,0.0,0.0,323.55,1.16,228.0,91010.0 +2007-05-08 03:00:00+00:00,24.6,22.79,0.0,0.0,0.0,321.47,1.22,220.0,91061.0 +2007-05-08 04:00:00+00:00,23.58,25.57,0.0,0.0,0.0,319.38,1.29,212.0,91112.0 +2007-05-08 05:00:00+00:00,22.57,28.36,0.0,0.0,0.0,317.3,1.35,203.0,91163.0 +2007-05-08 06:00:00+00:00,21.07,31.65,0.0,0.0,0.0,311.03,1.14,170.0,91169.0 +2007-05-08 07:00:00+00:00,19.57,34.93,0.0,0.0,0.0,304.77,0.92,137.0,91175.0 +2007-05-08 08:00:00+00:00,18.07,38.22,0.0,0.0,0.0,298.5,0.7,103.0,91181.0 +2007-05-08 09:00:00+00:00,17.12,40.67,0.0,0.0,0.0,295.47,1.1,83.0,91184.0 +2007-05-08 10:00:00+00:00,16.16,43.12,0.0,0.0,0.0,292.43,1.5,63.0,91187.0 +2007-05-08 11:00:00+00:00,15.21,45.57,0.0,0.0,0.0,289.4,1.9,43.0,91190.0 +2007-05-08 12:00:00+00:00,16.98,42.01,0.0,0.0,0.0,286.95,1.93,53.0,91256.0 +2007-05-08 13:00:00+00:00,18.75,38.44,48.0,240.1,28.0,284.5,1.95,63.0,91322.0 +2007-05-08 14:00:00+00:00,20.52,34.88,248.0,607.36,69.0,282.05,1.97,73.0,91388.0 +2007-05-08 15:00:00+00:00,22.53,30.08,474.0,771.13,91.0,286.7,2.2,77.0,91358.0 +2007-05-08 16:00:00+00:00,24.53,25.28,683.0,854.31,106.0,291.35,2.43,80.0,91328.0 +2007-05-08 17:00:00+00:00,26.54,20.48,855.0,903.86,115.0,296.0,2.66,83.0,91298.0 +2007-05-08 18:00:00+00:00,27.24,18.53,973.0,928.19,122.0,297.42,2.29,71.0,91226.0 +2007-05-08 19:00:00+00:00,27.94,16.59,1029.0,939.66,124.0,298.83,1.93,59.0,91154.0 +2007-05-08 20:00:00+00:00,28.64,14.64,859.0,423.32,455.0,300.25,1.56,46.0,91082.0 +2007-05-08 21:00:00+00:00,28.45,14.41,801.0,454.45,396.0,304.7,1.69,34.0,91046.0 +2007-05-08 22:00:00+00:00,28.26,14.17,673.0,470.5,307.0,309.15,1.82,22.0,91010.0 +2007-05-08 23:00:00+00:00,28.08,13.94,386.0,152.68,291.0,313.6,1.94,10.0,90974.0 +2007-05-09 00:00:00+00:00,26.61,16.27,300.0,293.22,172.0,312.82,2.21,14.0,91007.0 +2007-05-09 01:00:00+00:00,25.15,18.59,134.0,208.4,86.0,312.03,2.47,18.0,91040.0 +2007-05-09 02:00:00+00:00,23.68,20.92,8.0,0.0,8.0,311.25,2.73,23.0,91073.0 +2007-05-09 03:00:00+00:00,22.68,23.36,0.0,0.0,0.0,307.42,2.66,36.0,91115.0 +2007-05-09 04:00:00+00:00,21.68,25.8,0.0,0.0,0.0,303.58,2.58,50.0,91157.0 +2007-05-09 05:00:00+00:00,20.68,28.24,0.0,0.0,0.0,299.75,2.51,64.0,91199.0 +2007-05-09 06:00:00+00:00,19.52,30.74,0.0,0.0,0.0,296.9,2.34,65.0,91208.0 +2007-05-09 07:00:00+00:00,18.37,33.25,0.0,0.0,0.0,294.05,2.18,67.0,91217.0 +2007-05-09 08:00:00+00:00,17.21,35.75,0.0,0.0,0.0,291.2,2.01,69.0,91226.0 +2007-05-09 09:00:00+00:00,16.39,38.09,0.0,0.0,0.0,290.23,1.94,67.0,91235.0 +2007-05-09 10:00:00+00:00,15.56,40.43,0.0,0.0,0.0,289.27,1.88,64.0,91244.0 +2007-05-09 11:00:00+00:00,14.74,42.77,0.0,0.0,0.0,288.3,1.81,62.0,91253.0 +2007-05-09 12:00:00+00:00,17.23,38.72,0.0,0.0,0.0,288.57,1.71,69.0,91319.0 +2007-05-09 13:00:00+00:00,19.72,34.68,50.0,244.27,29.0,288.83,1.61,75.0,91385.0 +2007-05-09 14:00:00+00:00,22.21,30.63,249.0,605.89,69.0,289.1,1.52,82.0,91452.0 +2007-05-09 15:00:00+00:00,24.5,25.85,473.0,765.95,91.0,295.48,1.57,54.0,91431.0 +2007-05-09 16:00:00+00:00,26.78,21.06,682.0,850.61,106.0,301.87,1.63,25.0,91410.0 +2007-05-09 17:00:00+00:00,29.07,16.28,854.0,899.75,116.0,308.25,1.68,357.0,91388.0 +2007-05-09 18:00:00+00:00,30.09,14.27,975.0,929.02,122.0,308.72,2.47,350.0,91325.0 +2007-05-09 19:00:00+00:00,31.11,12.26,1034.0,942.63,125.0,309.18,3.26,343.0,91262.0 +2007-05-09 20:00:00+00:00,32.14,10.25,1025.0,942.92,124.0,309.65,4.04,336.0,91199.0 +2007-05-09 21:00:00+00:00,32.14,9.96,951.0,930.07,121.0,309.4,4.07,337.0,91154.0 +2007-05-09 22:00:00+00:00,32.14,9.66,815.0,899.59,114.0,309.15,4.11,337.0,91109.0 +2007-05-09 23:00:00+00:00,32.15,9.37,630.0,846.49,102.0,308.9,4.14,338.0,91064.0 +2007-05-10 00:00:00+00:00,30.07,10.72,412.0,743.79,86.0,304.27,3.57,338.0,91091.0 +2007-05-10 01:00:00+00:00,27.98,12.08,187.0,546.49,60.0,299.63,3.01,338.0,91118.0 +2007-05-10 02:00:00+00:00,25.9,13.43,10.0,0.0,10.0,295.0,2.44,337.0,91145.0 +2007-05-10 03:00:00+00:00,24.93,13.74,0.0,0.0,0.0,294.13,2.3,350.0,91190.0 +2007-05-10 04:00:00+00:00,23.95,14.04,0.0,0.0,0.0,293.27,2.16,3.0,91235.0 +2007-05-10 05:00:00+00:00,22.98,14.35,0.0,0.0,0.0,292.4,2.01,15.0,91280.0 +2007-05-10 06:00:00+00:00,22.64,14.16,0.0,0.0,0.0,290.48,1.85,28.0,91280.0 +2007-05-10 07:00:00+00:00,22.3,13.96,0.0,0.0,0.0,288.57,1.68,42.0,91280.0 +2007-05-10 08:00:00+00:00,21.96,13.77,0.0,0.0,0.0,286.65,1.52,55.0,91280.0 +2007-05-10 09:00:00+00:00,21.11,14.74,0.0,0.0,0.0,285.25,1.43,63.0,91289.0 +2007-05-10 10:00:00+00:00,20.25,15.71,0.0,0.0,0.0,283.85,1.34,70.0,91298.0 +2007-05-10 11:00:00+00:00,19.4,16.68,0.0,0.0,0.0,282.45,1.26,78.0,91307.0 +2007-05-10 12:00:00+00:00,21.24,15.72,0.0,0.0,0.0,284.12,1.14,45.0,91379.0 +2007-05-10 13:00:00+00:00,23.08,14.76,55.0,270.99,31.0,285.78,1.02,13.0,91452.0 +2007-05-10 14:00:00+00:00,24.92,13.8,262.0,638.01,71.0,287.45,0.9,340.0,91524.0 +2007-05-10 15:00:00+00:00,27.37,11.8,493.0,798.87,93.0,291.85,1.43,343.0,91500.0 +2007-05-10 16:00:00+00:00,29.81,9.79,706.0,880.88,108.0,296.25,1.96,347.0,91476.0 +2007-05-10 17:00:00+00:00,32.26,7.79,881.0,928.57,118.0,300.65,2.5,350.0,91452.0 +2007-05-10 18:00:00+00:00,33.12,7.52,1002.0,954.91,124.0,300.67,2.23,346.0,91370.0 +2007-05-10 19:00:00+00:00,33.98,7.25,1060.0,966.34,127.0,300.68,1.95,341.0,91289.0 +2007-05-10 20:00:00+00:00,34.85,6.98,1049.0,964.79,126.0,300.7,1.68,336.0,91208.0 +2007-05-10 21:00:00+00:00,34.87,6.91,971.0,950.09,122.0,300.5,1.9,330.0,91151.0 +2007-05-10 22:00:00+00:00,34.89,6.84,832.0,918.57,115.0,300.3,2.12,323.0,91094.0 +2007-05-10 23:00:00+00:00,34.91,6.77,643.0,862.03,104.0,300.1,2.34,316.0,91037.0 +2007-05-11 00:00:00+00:00,32.78,8.1,421.0,759.0,87.0,298.73,2.05,314.0,91043.0 +2007-05-11 01:00:00+00:00,30.65,9.42,192.0,558.78,61.0,297.37,1.76,312.0,91049.0 +2007-05-11 02:00:00+00:00,28.52,10.75,11.0,0.0,11.0,296.0,1.46,310.0,91055.0 +2007-05-11 03:00:00+00:00,27.65,11.64,0.0,0.0,0.0,297.02,1.28,312.0,91094.0 +2007-05-11 04:00:00+00:00,26.78,12.52,0.0,0.0,0.0,298.03,1.1,315.0,91133.0 +2007-05-11 05:00:00+00:00,25.91,13.41,0.0,0.0,0.0,299.05,0.92,317.0,91172.0 +2007-05-11 06:00:00+00:00,25.85,13.34,0.0,0.0,0.0,297.1,0.81,293.0,91175.0 +2007-05-11 07:00:00+00:00,25.79,13.26,0.0,0.0,0.0,295.15,0.69,269.0,91178.0 +2007-05-11 08:00:00+00:00,25.73,13.19,0.0,0.0,0.0,293.2,0.58,245.0,91181.0 +2007-05-11 09:00:00+00:00,25.06,15.0,0.0,0.0,0.0,291.35,0.71,197.0,91181.0 +2007-05-11 10:00:00+00:00,24.38,16.82,0.0,0.0,0.0,289.5,0.85,149.0,91181.0 +2007-05-11 11:00:00+00:00,23.71,18.63,0.0,0.0,0.0,287.65,0.98,101.0,91181.0 +2007-05-11 12:00:00+00:00,24.62,16.79,0.0,0.0,0.0,289.28,1.0,90.0,91259.0 +2007-05-11 13:00:00+00:00,25.54,14.95,56.0,274.5,31.0,290.92,1.02,78.0,91337.0 +2007-05-11 14:00:00+00:00,26.45,13.11,262.0,633.34,71.0,292.55,1.03,67.0,91416.0 +2007-05-11 15:00:00+00:00,28.84,11.36,489.0,787.88,93.0,297.73,1.3,87.0,91379.0 +2007-05-11 16:00:00+00:00,31.23,9.61,700.0,871.43,107.0,302.92,1.57,108.0,91343.0 +2007-05-11 17:00:00+00:00,33.62,7.86,872.0,917.28,117.0,308.1,1.83,129.0,91307.0 +2007-05-11 18:00:00+00:00,34.66,7.38,992.0,943.87,123.0,309.77,2.24,150.0,91226.0 +2007-05-11 19:00:00+00:00,35.7,6.91,1048.0,953.83,126.0,311.43,2.64,171.0,91145.0 +2007-05-11 20:00:00+00:00,36.74,6.43,1037.0,952.19,125.0,313.1,3.05,191.0,91064.0 +2007-05-11 21:00:00+00:00,36.54,6.59,958.0,934.32,122.0,316.4,2.99,200.0,90998.0 +2007-05-11 22:00:00+00:00,36.34,6.75,746.0,652.29,236.0,319.7,2.94,209.0,90932.0 +2007-05-11 23:00:00+00:00,36.15,6.91,591.0,711.58,145.0,323.0,2.88,217.0,90866.0 +2007-05-12 00:00:00+00:00,34.37,7.93,353.0,454.96,152.0,326.07,2.41,196.0,90866.0 +2007-05-12 01:00:00+00:00,32.59,8.95,177.0,511.68,56.0,329.13,1.94,175.0,90866.0 +2007-05-12 02:00:00+00:00,30.81,9.97,13.0,0.0,13.0,332.2,1.46,154.0,90866.0 +2007-05-12 03:00:00+00:00,29.33,11.3,0.0,0.0,0.0,332.08,1.37,160.0,90935.0 +2007-05-12 04:00:00+00:00,27.85,12.64,0.0,0.0,0.0,331.97,1.27,165.0,91004.0 +2007-05-12 05:00:00+00:00,26.37,13.97,0.0,0.0,0.0,331.85,1.17,171.0,91073.0 +2007-05-12 06:00:00+00:00,26.35,14.47,0.0,0.0,0.0,323.88,1.27,151.0,91088.0 +2007-05-12 07:00:00+00:00,26.34,14.97,0.0,0.0,0.0,315.92,1.37,131.0,91103.0 +2007-05-12 08:00:00+00:00,26.32,15.47,0.0,0.0,0.0,307.95,1.46,112.0,91118.0 +2007-05-12 09:00:00+00:00,24.28,17.17,0.0,0.0,0.0,304.72,1.84,105.0,91115.0 +2007-05-12 10:00:00+00:00,22.24,18.86,0.0,0.0,0.0,301.48,2.22,97.0,91112.0 +2007-05-12 11:00:00+00:00,20.2,20.56,0.0,0.0,0.0,298.25,2.59,90.0,91109.0 +2007-05-12 12:00:00+00:00,22.47,18.22,0.0,0.0,0.0,299.53,2.38,92.0,91160.0 +2007-05-12 13:00:00+00:00,24.75,15.88,56.0,267.37,31.0,300.82,2.17,94.0,91211.0 +2007-05-12 14:00:00+00:00,27.02,13.54,258.0,619.04,70.0,302.1,1.96,96.0,91262.0 +2007-05-12 15:00:00+00:00,29.47,11.98,484.0,777.1,92.0,307.42,2.55,114.0,91223.0 +2007-05-12 16:00:00+00:00,31.93,10.41,694.0,860.64,107.0,312.73,3.14,132.0,91184.0 +2007-05-12 17:00:00+00:00,34.38,8.85,867.0,909.73,117.0,318.05,3.74,151.0,91145.0 +2007-05-12 18:00:00+00:00,35.28,8.32,989.0,939.41,123.0,318.67,3.69,161.0,91061.0 +2007-05-12 19:00:00+00:00,36.18,7.8,1047.0,951.73,126.0,319.28,3.64,172.0,90977.0 +2007-05-12 20:00:00+00:00,37.08,7.27,1037.0,950.09,126.0,319.9,3.59,183.0,90893.0 +2007-05-12 21:00:00+00:00,36.75,7.36,958.0,933.13,122.0,322.03,3.46,192.0,90857.0 +2007-05-12 22:00:00+00:00,36.43,7.44,687.0,500.54,295.0,324.17,3.33,200.0,90821.0 +2007-05-12 23:00:00+00:00,36.11,7.53,532.0,504.57,215.0,326.3,3.2,209.0,90785.0 +2007-05-13 00:00:00+00:00,34.65,8.19,21.0,0.0,21.0,330.15,2.63,203.0,90824.0 +2007-05-13 01:00:00+00:00,33.2,8.84,88.0,20.96,83.0,334.0,2.07,197.0,90863.0 +2007-05-13 02:00:00+00:00,31.74,9.5,6.0,0.0,6.0,337.85,1.5,191.0,90902.0 +2007-05-13 03:00:00+00:00,30.03,10.61,0.0,0.0,0.0,332.58,1.42,203.0,90995.0 +2007-05-13 04:00:00+00:00,28.32,11.71,0.0,0.0,0.0,327.32,1.34,215.0,91088.0 +2007-05-13 05:00:00+00:00,26.61,12.82,0.0,0.0,0.0,322.05,1.26,227.0,91181.0 +2007-05-13 06:00:00+00:00,26.33,13.23,0.0,0.0,0.0,317.38,1.07,191.0,91187.0 +2007-05-13 07:00:00+00:00,26.05,13.64,0.0,0.0,0.0,312.72,0.89,156.0,91193.0 +2007-05-13 08:00:00+00:00,25.76,14.05,0.0,0.0,0.0,308.05,0.7,120.0,91199.0 +2007-05-13 09:00:00+00:00,24.37,15.72,0.0,0.0,0.0,305.95,1.17,111.0,91190.0 +2007-05-13 10:00:00+00:00,22.97,17.38,0.0,0.0,0.0,303.85,1.63,103.0,91181.0 +2007-05-13 11:00:00+00:00,21.58,19.05,0.0,0.0,0.0,301.75,2.1,95.0,91172.0 +2007-05-13 12:00:00+00:00,23.44,16.95,0.0,0.0,0.0,303.98,2.07,103.0,91214.0 +2007-05-13 13:00:00+00:00,25.29,14.84,58.0,271.26,32.0,306.22,2.04,112.0,91256.0 +2007-05-13 14:00:00+00:00,27.15,12.74,263.0,627.98,71.0,308.45,2.01,121.0,91298.0 +2007-05-13 15:00:00+00:00,29.28,11.13,490.0,784.29,93.0,311.93,2.59,140.0,91250.0 +2007-05-13 16:00:00+00:00,31.4,9.53,701.0,867.54,108.0,315.42,3.16,160.0,91202.0 +2007-05-13 17:00:00+00:00,33.53,7.92,874.0,915.59,118.0,318.9,3.74,179.0,91154.0 +2007-05-13 18:00:00+00:00,34.43,7.69,994.0,942.6,124.0,318.5,3.88,188.0,91076.0 +2007-05-13 19:00:00+00:00,35.33,7.45,1052.0,954.84,127.0,318.1,4.01,197.0,90998.0 +2007-05-13 20:00:00+00:00,36.24,7.22,1041.0,953.23,126.0,317.7,4.15,206.0,90920.0 +2007-05-13 21:00:00+00:00,35.88,7.55,965.0,939.78,122.0,317.77,4.33,214.0,90878.0 +2007-05-13 22:00:00+00:00,35.52,7.87,827.0,907.69,115.0,317.83,4.51,221.0,90836.0 +2007-05-13 23:00:00+00:00,35.17,8.2,641.0,852.74,104.0,317.9,4.69,229.0,90794.0 +2007-05-14 00:00:00+00:00,33.8,9.03,336.0,402.02,157.0,324.88,4.31,232.0,90833.0 +2007-05-14 01:00:00+00:00,32.43,9.87,170.0,428.25,67.0,331.87,3.94,236.0,90872.0 +2007-05-14 02:00:00+00:00,31.06,10.7,14.0,0.0,14.0,338.85,3.56,239.0,90911.0 +2007-05-14 03:00:00+00:00,29.68,11.91,0.0,0.0,0.0,332.53,3.34,244.0,91001.0 +2007-05-14 04:00:00+00:00,28.3,13.11,0.0,0.0,0.0,326.22,3.13,249.0,91091.0 +2007-05-14 05:00:00+00:00,26.92,14.32,0.0,0.0,0.0,319.9,2.91,254.0,91181.0 +2007-05-14 06:00:00+00:00,25.72,16.04,0.0,0.0,0.0,315.93,2.47,248.0,91169.0 +2007-05-14 07:00:00+00:00,24.53,17.77,0.0,0.0,0.0,311.97,2.03,241.0,91157.0 +2007-05-14 08:00:00+00:00,23.33,19.49,0.0,0.0,0.0,308.0,1.59,235.0,91145.0 +2007-05-14 09:00:00+00:00,22.24,21.08,0.0,0.0,0.0,306.03,1.47,228.0,91151.0 +2007-05-14 10:00:00+00:00,21.14,22.68,0.0,0.0,0.0,304.07,1.35,220.0,91157.0 +2007-05-14 11:00:00+00:00,20.05,24.27,0.0,0.0,0.0,302.1,1.23,213.0,91163.0 +2007-05-14 12:00:00+00:00,22.27,22.02,0.0,0.0,0.0,303.35,1.39,213.0,91202.0 +2007-05-14 13:00:00+00:00,24.5,19.77,60.0,275.2,33.0,304.6,1.55,213.0,91241.0 +2007-05-14 14:00:00+00:00,26.72,17.52,264.0,627.23,71.0,305.85,1.71,213.0,91280.0 +2007-05-14 15:00:00+00:00,28.35,15.57,489.0,779.73,93.0,308.85,2.4,213.0,91259.0 +2007-05-14 16:00:00+00:00,29.98,13.61,697.0,859.91,108.0,311.85,3.08,214.0,91238.0 +2007-05-14 17:00:00+00:00,31.61,11.66,867.0,906.99,117.0,314.85,3.77,215.0,91217.0 +2007-05-14 18:00:00+00:00,32.44,10.88,984.0,930.69,124.0,315.4,4.21,215.0,91154.0 +2007-05-14 19:00:00+00:00,33.27,10.09,1039.0,941.48,126.0,315.95,4.66,214.0,91091.0 +2007-05-14 20:00:00+00:00,34.11,9.31,1028.0,938.7,126.0,316.5,5.1,213.0,91028.0 +2007-05-14 21:00:00+00:00,33.83,9.48,951.0,923.05,122.0,316.4,5.13,218.0,90989.0 +2007-05-14 22:00:00+00:00,33.56,9.64,816.0,892.25,115.0,316.3,5.15,222.0,90950.0 +2007-05-14 23:00:00+00:00,33.29,9.81,632.0,838.1,103.0,316.2,5.17,226.0,90911.0 +2007-05-15 00:00:00+00:00,32.03,11.35,417.0,738.32,87.0,318.2,4.99,234.0,90938.0 +2007-05-15 01:00:00+00:00,30.78,12.88,100.0,45.36,89.0,320.2,4.8,241.0,90965.0 +2007-05-15 02:00:00+00:00,29.52,14.42,8.0,0.0,8.0,322.2,4.62,248.0,90992.0 +2007-05-15 03:00:00+00:00,27.97,16.55,0.0,0.0,0.0,320.77,4.05,250.0,91091.0 +2007-05-15 04:00:00+00:00,26.41,18.68,0.0,0.0,0.0,319.33,3.47,252.0,91190.0 +2007-05-15 05:00:00+00:00,24.86,20.81,0.0,0.0,0.0,317.9,2.9,254.0,91289.0 +2007-05-15 06:00:00+00:00,24.05,23.54,0.0,0.0,0.0,315.15,2.51,245.0,91304.0 +2007-05-15 07:00:00+00:00,23.24,26.28,0.0,0.0,0.0,312.4,2.13,237.0,91319.0 +2007-05-15 08:00:00+00:00,22.42,29.01,0.0,0.0,0.0,309.65,1.75,229.0,91334.0 +2007-05-15 09:00:00+00:00,21.3,31.06,0.0,0.0,0.0,309.05,1.67,218.0,91334.0 +2007-05-15 10:00:00+00:00,20.17,33.12,0.0,0.0,0.0,308.45,1.59,207.0,91334.0 +2007-05-15 11:00:00+00:00,19.04,35.17,0.0,0.0,0.0,307.85,1.5,196.0,91334.0 +2007-05-15 12:00:00+00:00,21.11,32.19,0.0,0.0,0.0,308.5,1.4,202.0,91370.0 +2007-05-15 13:00:00+00:00,23.19,29.2,63.0,289.17,34.0,309.15,1.3,208.0,91406.0 +2007-05-15 14:00:00+00:00,25.26,26.22,268.0,633.1,72.0,309.8,1.2,215.0,91443.0 +2007-05-15 15:00:00+00:00,27.0,22.44,496.0,789.06,94.0,313.88,1.22,209.0,91406.0 +2007-05-15 16:00:00+00:00,28.73,18.66,706.0,869.87,109.0,317.97,1.25,203.0,91370.0 +2007-05-15 17:00:00+00:00,30.47,14.88,878.0,916.6,119.0,322.05,1.27,197.0,91334.0 +2007-05-15 18:00:00+00:00,31.66,14.22,997.0,942.64,125.0,323.73,1.83,194.0,91259.0 +2007-05-15 19:00:00+00:00,32.85,13.55,1053.0,953.95,127.0,325.42,2.4,191.0,91184.0 +2007-05-15 20:00:00+00:00,34.04,12.89,1041.0,950.23,127.0,327.1,2.97,188.0,91109.0 +2007-05-15 21:00:00+00:00,33.97,13.19,963.0,934.19,123.0,328.7,3.13,196.0,91043.0 +2007-05-15 22:00:00+00:00,33.91,13.48,825.0,902.3,115.0,330.3,3.3,204.0,90977.0 +2007-05-15 23:00:00+00:00,33.85,13.78,640.0,847.25,104.0,331.9,3.46,211.0,90911.0 +2007-05-16 00:00:00+00:00,32.61,14.95,422.0,744.45,88.0,329.08,3.39,221.0,90911.0 +2007-05-16 01:00:00+00:00,31.38,16.13,198.0,552.17,63.0,326.27,3.31,230.0,90911.0 +2007-05-16 02:00:00+00:00,30.14,17.3,15.0,0.0,15.0,323.45,3.24,239.0,90911.0 +2007-05-16 03:00:00+00:00,28.68,19.07,0.0,0.0,0.0,322.95,2.7,242.0,91013.0 +2007-05-16 04:00:00+00:00,27.22,20.83,0.0,0.0,0.0,322.45,2.17,245.0,91115.0 +2007-05-16 05:00:00+00:00,25.76,22.6,0.0,0.0,0.0,321.95,1.63,248.0,91217.0 +2007-05-16 06:00:00+00:00,25.01,25.06,0.0,0.0,0.0,319.28,1.49,201.0,91232.0 +2007-05-16 07:00:00+00:00,24.26,27.52,0.0,0.0,0.0,316.62,1.36,154.0,91247.0 +2007-05-16 08:00:00+00:00,23.51,29.98,0.0,0.0,0.0,313.95,1.23,106.0,91262.0 +2007-05-16 09:00:00+00:00,22.23,31.38,0.0,0.0,0.0,311.77,1.72,99.0,91259.0 +2007-05-16 10:00:00+00:00,20.94,32.78,0.0,0.0,0.0,309.58,2.21,92.0,91256.0 +2007-05-16 11:00:00+00:00,19.65,34.18,0.0,0.0,0.0,307.4,2.7,85.0,91253.0 +2007-05-16 12:00:00+00:00,21.95,31.11,0.0,0.0,0.0,310.12,2.86,90.0,91286.0 +2007-05-16 13:00:00+00:00,24.25,28.04,62.0,283.25,33.0,312.83,3.01,95.0,91319.0 +2007-05-16 14:00:00+00:00,26.55,24.97,262.0,613.38,71.0,315.55,3.16,100.0,91352.0 +2007-05-16 15:00:00+00:00,28.63,23.0,380.0,352.25,200.0,323.63,4.17,110.0,91313.0 +2007-05-16 16:00:00+00:00,30.7,21.02,580.0,477.02,252.0,331.72,5.18,120.0,91274.0 +2007-05-16 17:00:00+00:00,32.78,19.05,756.0,513.77,330.0,339.8,6.19,129.0,91235.0 +2007-05-16 18:00:00+00:00,33.42,17.9,779.0,388.75,419.0,345.42,5.69,137.0,91163.0 +2007-05-16 19:00:00+00:00,34.06,16.74,899.0,441.53,470.0,351.03,5.18,146.0,91091.0 +2007-05-16 20:00:00+00:00,34.71,15.59,866.0,419.6,462.0,356.65,4.68,154.0,91019.0 +2007-05-16 21:00:00+00:00,34.04,16.17,941.0,909.79,122.0,357.08,3.96,155.0,90995.0 +2007-05-16 22:00:00+00:00,33.37,16.75,646.0,383.21,344.0,357.52,3.25,156.0,90971.0 +2007-05-16 23:00:00+00:00,32.71,17.33,303.0,52.05,270.0,357.95,2.54,157.0,90947.0 +2007-05-17 00:00:00+00:00,31.1,19.72,410.0,717.25,87.0,360.05,2.38,128.0,90989.0 +2007-05-17 01:00:00+00:00,29.5,22.11,119.0,105.5,93.0,362.15,2.22,100.0,91031.0 +2007-05-17 02:00:00+00:00,27.89,24.5,11.0,0.0,11.0,364.25,2.06,72.0,91073.0 +2007-05-17 03:00:00+00:00,27.1,26.59,0.0,0.0,0.0,356.32,2.12,73.0,91151.0 +2007-05-17 04:00:00+00:00,26.31,28.68,0.0,0.0,0.0,348.38,2.18,74.0,91229.0 +2007-05-17 05:00:00+00:00,25.52,30.77,0.0,0.0,0.0,340.45,2.25,75.0,91307.0 +2007-05-17 06:00:00+00:00,24.18,36.13,0.0,0.0,0.0,333.93,1.99,75.0,91304.0 +2007-05-17 07:00:00+00:00,22.84,41.48,0.0,0.0,0.0,327.42,1.72,75.0,91301.0 +2007-05-17 08:00:00+00:00,21.5,46.84,0.0,0.0,0.0,320.9,1.46,75.0,91298.0 +2007-05-17 09:00:00+00:00,20.67,52.22,0.0,0.0,0.0,317.73,1.43,75.0,91295.0 +2007-05-17 10:00:00+00:00,19.84,57.61,0.0,0.0,0.0,314.57,1.4,75.0,91292.0 +2007-05-17 11:00:00+00:00,19.01,62.99,0.0,0.0,0.0,311.4,1.37,75.0,91289.0 +2007-05-17 12:00:00+00:00,20.86,60.54,0.0,0.0,0.0,312.47,1.66,84.0,91304.0 +2007-05-17 13:00:00+00:00,22.72,58.09,63.0,277.8,34.0,313.53,1.95,93.0,91319.0 +2007-05-17 14:00:00+00:00,24.57,55.64,265.0,616.39,72.0,314.6,2.25,101.0,91334.0 +2007-05-17 15:00:00+00:00,26.59,48.49,490.0,772.76,94.0,320.28,2.57,114.0,91310.0 +2007-05-17 16:00:00+00:00,28.6,41.34,699.0,856.54,109.0,325.97,2.9,127.0,91286.0 +2007-05-17 17:00:00+00:00,30.62,34.19,871.0,907.02,118.0,331.65,3.23,140.0,91262.0 +2007-05-17 18:00:00+00:00,31.55,30.26,991.0,934.24,125.0,333.13,2.88,151.0,91202.0 +2007-05-17 19:00:00+00:00,32.49,26.34,1048.0,946.02,128.0,334.62,2.54,162.0,91142.0 +2007-05-17 20:00:00+00:00,33.43,22.41,1038.0,945.29,127.0,336.1,2.19,173.0,91082.0 +2007-05-17 21:00:00+00:00,33.38,21.11,962.0,930.95,123.0,334.97,1.87,195.0,91046.0 +2007-05-17 22:00:00+00:00,33.33,19.82,825.0,898.3,116.0,333.83,1.54,217.0,91010.0 +2007-05-17 23:00:00+00:00,33.29,18.52,640.0,841.89,105.0,332.7,1.21,239.0,90974.0 +2007-05-18 00:00:00+00:00,31.88,19.71,424.0,743.37,88.0,328.9,1.24,286.0,91022.0 +2007-05-18 01:00:00+00:00,30.48,20.89,162.0,330.11,80.0,325.1,1.27,334.0,91070.0 +2007-05-18 02:00:00+00:00,29.07,22.08,16.0,0.0,16.0,321.3,1.3,22.0,91118.0 +2007-05-18 03:00:00+00:00,28.09,23.89,0.0,0.0,0.0,319.17,1.57,28.0,91205.0 +2007-05-18 04:00:00+00:00,27.1,25.7,0.0,0.0,0.0,317.03,1.84,35.0,91292.0 +2007-05-18 05:00:00+00:00,26.12,27.51,0.0,0.0,0.0,314.9,2.11,42.0,91379.0 +2007-05-18 06:00:00+00:00,24.51,31.22,0.0,0.0,0.0,309.58,2.07,46.0,91403.0 +2007-05-18 07:00:00+00:00,22.9,34.93,0.0,0.0,0.0,304.27,2.04,50.0,91428.0 +2007-05-18 08:00:00+00:00,21.28,38.64,0.0,0.0,0.0,298.95,2.0,54.0,91452.0 +2007-05-18 09:00:00+00:00,20.31,44.43,0.0,0.0,0.0,296.6,1.89,60.0,91431.0 +2007-05-18 10:00:00+00:00,19.34,50.22,0.0,0.0,0.0,294.25,1.78,67.0,91410.0 +2007-05-18 11:00:00+00:00,18.37,56.01,0.0,0.0,0.0,291.9,1.67,73.0,91388.0 +2007-05-18 12:00:00+00:00,20.74,44.1,0.0,0.0,0.0,296.87,1.63,88.0,91385.0 +2007-05-18 13:00:00+00:00,23.11,32.2,66.0,291.57,35.0,301.83,1.6,104.0,91382.0 +2007-05-18 14:00:00+00:00,25.48,20.29,269.0,622.71,73.0,306.8,1.56,119.0,91379.0 +2007-05-18 15:00:00+00:00,27.15,19.48,492.0,774.58,94.0,310.12,1.74,130.0,91364.0 +2007-05-18 16:00:00+00:00,28.82,18.66,700.0,856.56,109.0,313.43,1.93,141.0,91349.0 +2007-05-18 17:00:00+00:00,30.49,17.85,870.0,903.54,119.0,316.75,2.11,152.0,91334.0 +2007-05-18 18:00:00+00:00,31.49,18.28,989.0,931.21,125.0,315.42,1.79,157.0,91295.0 +2007-05-18 19:00:00+00:00,32.5,18.71,1046.0,943.15,128.0,314.08,1.47,162.0,91256.0 +2007-05-18 20:00:00+00:00,33.51,19.14,1036.0,942.36,127.0,312.75,1.14,167.0,91217.0 +2007-05-18 21:00:00+00:00,33.44,18.76,960.0,927.72,123.0,310.72,0.93,219.0,91169.0 +2007-05-18 22:00:00+00:00,33.37,18.37,824.0,895.71,116.0,308.68,0.72,270.0,91121.0 +2007-05-18 23:00:00+00:00,33.31,17.99,640.0,840.04,105.0,306.65,0.51,322.0,91073.0 +2007-05-19 00:00:00+00:00,31.78,18.03,424.0,738.47,89.0,301.22,0.97,324.0,91061.0 +2007-05-19 01:00:00+00:00,30.26,18.08,201.0,547.27,64.0,295.78,1.43,327.0,91049.0 +2007-05-19 02:00:00+00:00,28.73,18.12,21.0,94.83,17.0,290.35,1.89,329.0,91037.0 +2007-05-19 03:00:00+00:00,27.62,19.29,0.0,0.0,0.0,291.17,1.37,17.0,91082.0 +2007-05-19 04:00:00+00:00,26.5,20.46,0.0,0.0,0.0,291.98,0.84,64.0,91127.0 +2007-05-19 05:00:00+00:00,25.39,21.63,0.0,0.0,0.0,292.8,0.32,112.0,91172.0 +2007-05-19 06:00:00+00:00,24.29,23.7,0.0,0.0,0.0,290.5,0.69,121.0,91166.0 +2007-05-19 07:00:00+00:00,23.2,25.77,0.0,0.0,0.0,288.2,1.06,130.0,91160.0 +2007-05-19 08:00:00+00:00,22.1,27.84,0.0,0.0,0.0,285.9,1.43,139.0,91154.0 +2007-05-19 09:00:00+00:00,20.99,29.15,0.0,0.0,0.0,283.35,1.66,131.0,91169.0 +2007-05-19 10:00:00+00:00,19.87,30.46,0.0,0.0,0.0,280.8,1.89,122.0,91184.0 +2007-05-19 11:00:00+00:00,18.75,31.77,0.0,0.0,0.0,278.25,2.12,114.0,91199.0 +2007-05-19 12:00:00+00:00,20.92,28.0,0.0,0.0,0.0,280.28,1.94,122.0,91235.0 +2007-05-19 13:00:00+00:00,23.08,24.22,68.0,295.85,36.0,282.32,1.75,130.0,91271.0 +2007-05-19 14:00:00+00:00,25.25,20.45,272.0,629.11,73.0,284.35,1.56,138.0,91307.0 +2007-05-19 15:00:00+00:00,27.22,17.79,496.0,778.44,95.0,287.25,1.94,151.0,91268.0 +2007-05-19 16:00:00+00:00,29.2,15.13,704.0,861.0,109.0,290.15,2.33,164.0,91229.0 +2007-05-19 17:00:00+00:00,31.17,12.47,876.0,909.75,119.0,293.05,2.72,178.0,91190.0 +2007-05-19 18:00:00+00:00,32.27,11.73,996.0,937.92,125.0,292.37,2.95,189.0,91118.0 +2007-05-19 19:00:00+00:00,33.37,11.0,1054.0,950.59,128.0,291.68,3.19,201.0,91046.0 +2007-05-19 20:00:00+00:00,34.48,10.26,1045.0,949.82,128.0,291.0,3.42,213.0,90974.0 +2007-05-19 21:00:00+00:00,34.3,9.96,970.0,936.69,124.0,291.73,3.74,221.0,90917.0 +2007-05-19 22:00:00+00:00,34.13,9.67,836.0,908.31,117.0,292.47,4.06,229.0,90860.0 +2007-05-19 23:00:00+00:00,33.96,9.37,652.0,855.46,106.0,293.2,4.37,238.0,90803.0 +2007-05-20 00:00:00+00:00,32.13,12.47,435.0,757.78,90.0,292.85,4.32,243.0,90848.0 +2007-05-20 01:00:00+00:00,30.3,15.56,208.0,566.91,65.0,292.5,4.26,249.0,90893.0 +2007-05-20 02:00:00+00:00,28.47,18.66,24.0,135.24,18.0,292.15,4.21,254.0,90938.0 +2007-05-20 03:00:00+00:00,27.49,21.04,0.0,0.0,0.0,290.98,3.55,254.0,91019.0 +2007-05-20 04:00:00+00:00,26.51,23.42,0.0,0.0,0.0,289.82,2.9,254.0,91100.0 +2007-05-20 05:00:00+00:00,25.53,25.8,0.0,0.0,0.0,288.65,2.25,253.0,91181.0 +2007-05-20 06:00:00+00:00,24.27,27.51,0.0,0.0,0.0,286.57,1.97,243.0,91178.0 +2007-05-20 07:00:00+00:00,23.01,29.23,0.0,0.0,0.0,284.48,1.69,233.0,91175.0 +2007-05-20 08:00:00+00:00,21.74,30.94,0.0,0.0,0.0,282.4,1.41,223.0,91172.0 +2007-05-20 09:00:00+00:00,20.67,32.57,0.0,0.0,0.0,281.4,1.37,206.0,91169.0 +2007-05-20 10:00:00+00:00,19.6,34.19,0.0,0.0,0.0,280.4,1.32,189.0,91166.0 +2007-05-20 11:00:00+00:00,18.53,35.82,0.0,0.0,0.0,279.4,1.28,172.0,91163.0 +2007-05-20 12:00:00+00:00,20.9,31.46,0.0,0.0,0.0,282.83,1.43,169.0,91175.0 +2007-05-20 13:00:00+00:00,23.28,27.09,72.0,318.41,37.0,286.27,1.58,166.0,91187.0 +2007-05-20 14:00:00+00:00,25.65,22.73,280.0,648.2,74.0,289.7,1.72,163.0,91199.0 +2007-05-20 15:00:00+00:00,27.44,19.17,507.0,795.95,96.0,294.9,2.4,174.0,91160.0 +2007-05-20 16:00:00+00:00,29.22,15.61,716.0,875.63,110.0,300.1,3.09,186.0,91121.0 +2007-05-20 17:00:00+00:00,31.01,12.05,887.0,920.81,120.0,305.3,3.77,197.0,91082.0 +2007-05-20 18:00:00+00:00,31.77,11.07,1005.0,945.74,126.0,306.98,4.16,205.0,91007.0 +2007-05-20 19:00:00+00:00,32.53,10.09,1060.0,954.97,129.0,308.67,4.55,213.0,90932.0 +2007-05-20 20:00:00+00:00,33.29,9.11,1049.0,953.15,128.0,310.35,4.94,221.0,90857.0 +2007-05-20 21:00:00+00:00,32.87,9.8,972.0,937.92,124.0,311.25,5.11,226.0,90800.0 +2007-05-20 22:00:00+00:00,32.45,10.48,836.0,907.01,117.0,312.15,5.28,231.0,90743.0 +2007-05-20 23:00:00+00:00,32.03,11.17,651.0,852.07,106.0,313.05,5.45,236.0,90686.0 +2007-05-21 00:00:00+00:00,30.52,13.46,433.0,750.73,90.0,314.47,5.22,237.0,90704.0 +2007-05-21 01:00:00+00:00,29.02,15.75,208.0,562.69,65.0,315.88,5.0,238.0,90722.0 +2007-05-21 02:00:00+00:00,27.51,18.04,24.0,128.95,18.0,317.3,4.77,239.0,90740.0 +2007-05-21 03:00:00+00:00,26.1,20.93,0.0,0.0,0.0,315.4,4.15,237.0,90845.0 +2007-05-21 04:00:00+00:00,24.68,23.81,0.0,0.0,0.0,313.5,3.52,236.0,90950.0 +2007-05-21 05:00:00+00:00,23.27,26.7,0.0,0.0,0.0,311.6,2.9,234.0,91055.0 +2007-05-21 06:00:00+00:00,22.32,28.99,0.0,0.0,0.0,308.42,2.62,224.0,91064.0 +2007-05-21 07:00:00+00:00,21.37,31.27,0.0,0.0,0.0,305.23,2.34,213.0,91073.0 +2007-05-21 08:00:00+00:00,20.42,33.56,0.0,0.0,0.0,302.05,2.06,203.0,91082.0 +2007-05-21 09:00:00+00:00,19.91,35.47,0.0,0.0,0.0,299.68,2.13,196.0,91097.0 +2007-05-21 10:00:00+00:00,19.39,37.38,0.0,0.0,0.0,297.32,2.21,189.0,91112.0 +2007-05-21 11:00:00+00:00,18.87,39.29,0.0,0.0,0.0,294.95,2.29,182.0,91127.0 +2007-05-21 12:00:00+00:00,20.1,38.09,0.0,0.0,0.0,296.48,3.0,184.0,91127.0 +2007-05-21 13:00:00+00:00,21.34,36.89,74.0,331.55,37.0,298.02,3.71,186.0,91127.0 +2007-05-21 14:00:00+00:00,22.57,35.69,285.0,657.88,75.0,299.55,4.43,187.0,91127.0 +2007-05-21 15:00:00+00:00,24.26,31.77,516.0,809.62,97.0,302.2,4.94,192.0,91088.0 +2007-05-21 16:00:00+00:00,25.95,27.86,729.0,891.73,111.0,304.85,5.46,198.0,91049.0 +2007-05-21 17:00:00+00:00,27.64,23.94,902.0,936.7,121.0,307.5,5.97,203.0,91010.0 +2007-05-21 18:00:00+00:00,28.57,21.95,1020.0,960.04,127.0,307.88,6.24,208.0,90938.0 +2007-05-21 19:00:00+00:00,29.51,19.97,1074.0,967.59,130.0,308.27,6.51,214.0,90866.0 +2007-05-21 20:00:00+00:00,30.45,17.98,1060.0,962.71,129.0,308.65,6.77,220.0,90794.0 +2007-05-21 21:00:00+00:00,30.06,18.03,979.0,943.59,125.0,309.25,6.86,223.0,90752.0 +2007-05-21 22:00:00+00:00,29.67,18.09,840.0,909.52,118.0,309.85,6.94,226.0,90710.0 +2007-05-21 23:00:00+00:00,29.29,18.14,653.0,853.4,106.0,310.45,7.02,229.0,90668.0 +2007-05-22 00:00:00+00:00,27.9,21.93,435.0,752.48,90.0,310.65,6.48,229.0,90686.0 +2007-05-22 01:00:00+00:00,26.52,25.71,210.0,566.39,65.0,310.85,5.94,230.0,90704.0 +2007-05-22 02:00:00+00:00,25.13,29.5,26.0,143.84,19.0,311.05,5.39,230.0,90722.0 +2007-05-22 03:00:00+00:00,23.92,32.05,0.0,0.0,0.0,309.03,5.03,227.0,90818.0 +2007-05-22 04:00:00+00:00,22.71,34.6,0.0,0.0,0.0,307.02,4.66,224.0,90914.0 +2007-05-22 05:00:00+00:00,21.5,37.15,0.0,0.0,0.0,305.0,4.29,221.0,91010.0 +2007-05-22 06:00:00+00:00,20.57,39.11,0.0,0.0,0.0,298.57,3.82,213.0,91025.0 +2007-05-22 07:00:00+00:00,19.64,41.07,0.0,0.0,0.0,292.13,3.35,205.0,91040.0 +2007-05-22 08:00:00+00:00,18.71,43.03,0.0,0.0,0.0,285.7,2.88,196.0,91055.0 +2007-05-22 09:00:00+00:00,18.1,45.01,0.0,0.0,0.0,282.23,2.92,191.0,91055.0 +2007-05-22 10:00:00+00:00,17.48,47.0,0.0,0.0,0.0,278.77,2.97,186.0,91055.0 +2007-05-22 11:00:00+00:00,16.87,48.98,0.0,0.0,0.0,275.3,3.01,181.0,91055.0 +2007-05-22 12:00:00+00:00,18.32,42.47,0.0,0.0,0.0,279.13,3.61,187.0,91070.0 +2007-05-22 13:00:00+00:00,19.78,35.96,74.0,318.05,38.0,282.97,4.22,193.0,91085.0 +2007-05-22 14:00:00+00:00,21.23,29.45,282.0,645.8,75.0,286.8,4.83,199.0,91100.0 +2007-05-22 15:00:00+00:00,22.85,26.32,507.0,792.5,96.0,292.97,5.3,203.0,91079.0 +2007-05-22 16:00:00+00:00,24.47,23.19,716.0,871.84,111.0,299.13,5.77,206.0,91058.0 +2007-05-22 17:00:00+00:00,26.09,20.06,886.0,917.87,120.0,305.3,6.25,209.0,91037.0 +2007-05-22 18:00:00+00:00,27.14,19.21,1004.0,943.22,126.0,307.02,6.44,213.0,90971.0 +2007-05-22 19:00:00+00:00,28.19,18.35,1059.0,952.56,129.0,308.73,6.63,217.0,90905.0 +2007-05-22 20:00:00+00:00,29.25,17.5,1047.0,949.56,128.0,310.45,6.83,220.0,90839.0 +2007-05-22 21:00:00+00:00,28.94,18.37,968.0,930.52,125.0,311.15,6.84,222.0,90803.0 +2007-05-22 22:00:00+00:00,28.63,19.23,831.0,898.2,117.0,311.85,6.86,225.0,90767.0 +2007-05-22 23:00:00+00:00,28.33,20.1,647.0,842.29,106.0,312.55,6.87,227.0,90731.0 +2007-05-23 00:00:00+00:00,27.08,23.33,432.0,743.37,90.0,311.88,6.16,228.0,90761.0 +2007-05-23 01:00:00+00:00,25.83,26.56,209.0,558.44,65.0,311.22,5.45,228.0,90791.0 +2007-05-23 02:00:00+00:00,24.58,29.79,27.0,137.87,20.0,310.55,4.74,229.0,90821.0 +2007-05-23 03:00:00+00:00,23.38,33.46,0.0,0.0,0.0,307.4,4.28,228.0,90911.0 +2007-05-23 04:00:00+00:00,22.17,37.12,0.0,0.0,0.0,304.25,3.81,227.0,91001.0 +2007-05-23 05:00:00+00:00,20.97,40.79,0.0,0.0,0.0,301.1,3.34,226.0,91091.0 +2007-05-23 06:00:00+00:00,20.04,43.5,0.0,0.0,0.0,296.3,2.95,218.0,91106.0 +2007-05-23 07:00:00+00:00,19.12,46.2,0.0,0.0,0.0,291.5,2.57,209.0,91121.0 +2007-05-23 08:00:00+00:00,18.19,48.91,0.0,0.0,0.0,286.7,2.18,201.0,91136.0 +2007-05-23 09:00:00+00:00,17.66,50.63,0.0,0.0,0.0,283.68,2.3,193.0,91151.0 +2007-05-23 10:00:00+00:00,17.12,52.35,0.0,0.0,0.0,280.67,2.42,185.0,91166.0 +2007-05-23 11:00:00+00:00,16.58,54.07,0.0,0.0,0.0,277.65,2.54,177.0,91181.0 +2007-05-23 12:00:00+00:00,17.98,48.72,0.0,0.0,0.0,280.48,2.86,186.0,91214.0 +2007-05-23 13:00:00+00:00,19.38,43.38,74.0,313.87,38.0,283.32,3.19,196.0,91247.0 +2007-05-23 14:00:00+00:00,20.78,38.03,280.0,637.08,75.0,286.15,3.52,205.0,91280.0 +2007-05-23 15:00:00+00:00,22.48,34.15,504.0,785.17,96.0,289.5,4.09,210.0,91250.0 +2007-05-23 16:00:00+00:00,24.18,30.27,711.0,865.04,110.0,292.85,4.67,215.0,91220.0 +2007-05-23 17:00:00+00:00,25.88,26.39,881.0,911.11,120.0,296.2,5.24,220.0,91190.0 +2007-05-23 18:00:00+00:00,27.14,23.98,999.0,937.2,126.0,298.77,5.46,224.0,91130.0 +2007-05-23 19:00:00+00:00,28.4,21.56,1055.0,947.83,129.0,301.33,5.67,228.0,91070.0 +2007-05-23 20:00:00+00:00,29.66,19.15,1045.0,945.74,129.0,303.9,5.89,232.0,91010.0 +2007-05-23 21:00:00+00:00,29.55,19.23,970.0,931.82,125.0,305.5,5.81,237.0,90983.0 +2007-05-23 22:00:00+00:00,29.45,19.3,835.0,900.76,118.0,307.1,5.73,241.0,90956.0 +2007-05-23 23:00:00+00:00,29.35,19.38,652.0,846.78,107.0,308.7,5.66,245.0,90929.0 +2007-05-24 00:00:00+00:00,28.03,21.15,438.0,751.69,91.0,308.07,4.78,255.0,90962.0 +2007-05-24 01:00:00+00:00,26.71,22.91,214.0,569.92,66.0,307.43,3.91,265.0,90995.0 +2007-05-24 02:00:00+00:00,25.39,24.68,29.0,151.36,21.0,306.8,3.03,275.0,91028.0 +2007-05-24 03:00:00+00:00,24.67,27.45,0.0,0.0,0.0,305.6,2.53,276.0,91073.0 +2007-05-24 04:00:00+00:00,23.94,30.21,0.0,0.0,0.0,304.4,2.02,278.0,91118.0 +2007-05-24 05:00:00+00:00,23.22,32.98,0.0,0.0,0.0,303.2,1.52,279.0,91163.0 +2007-05-24 06:00:00+00:00,22.59,33.95,0.0,0.0,0.0,300.92,1.16,257.0,91169.0 +2007-05-24 07:00:00+00:00,21.96,34.92,0.0,0.0,0.0,298.63,0.8,234.0,91175.0 +2007-05-24 08:00:00+00:00,21.32,35.89,0.0,0.0,0.0,296.35,0.44,212.0,91181.0 +2007-05-24 09:00:00+00:00,19.85,40.24,0.0,0.0,0.0,294.93,0.81,185.0,91193.0 +2007-05-24 10:00:00+00:00,18.37,44.58,0.0,0.0,0.0,293.52,1.18,157.0,91205.0 +2007-05-24 11:00:00+00:00,16.89,48.93,0.0,0.0,0.0,292.1,1.54,130.0,91217.0 +2007-05-24 12:00:00+00:00,19.47,42.64,0.0,0.0,0.0,295.18,1.68,125.0,91247.0 +2007-05-24 13:00:00+00:00,22.04,36.36,75.0,318.63,38.0,298.27,1.81,121.0,91277.0 +2007-05-24 14:00:00+00:00,24.62,30.07,281.0,637.86,75.0,301.35,1.94,116.0,91307.0 +2007-05-24 15:00:00+00:00,26.41,26.28,504.0,783.74,96.0,305.75,2.57,129.0,91265.0 +2007-05-24 16:00:00+00:00,28.2,22.5,711.0,862.64,111.0,310.15,3.2,142.0,91223.0 +2007-05-24 17:00:00+00:00,29.99,18.71,880.0,909.2,120.0,314.55,3.83,155.0,91181.0 +2007-05-24 18:00:00+00:00,31.06,17.61,998.0,934.44,127.0,315.42,3.89,168.0,91112.0 +2007-05-24 19:00:00+00:00,32.13,16.52,1055.0,947.23,129.0,316.28,3.94,181.0,91043.0 +2007-05-24 20:00:00+00:00,33.21,15.42,1045.0,945.05,129.0,317.15,4.0,194.0,90974.0 +2007-05-24 21:00:00+00:00,33.08,15.71,970.0,930.94,125.0,317.25,4.27,204.0,90932.0 +2007-05-24 22:00:00+00:00,32.95,16.01,836.0,900.82,118.0,317.35,4.53,214.0,90890.0 +2007-05-24 23:00:00+00:00,32.82,16.3,654.0,848.18,107.0,317.45,4.8,224.0,90848.0 +2007-05-25 00:00:00+00:00,31.46,17.9,440.0,753.5,91.0,318.02,4.49,233.0,90866.0 +2007-05-25 01:00:00+00:00,30.11,19.49,217.0,577.46,66.0,318.58,4.18,242.0,90884.0 +2007-05-25 02:00:00+00:00,28.75,21.09,30.0,163.92,21.0,319.15,3.88,251.0,90902.0 +2007-05-25 03:00:00+00:00,27.71,24.39,0.0,0.0,0.0,316.08,3.23,250.0,90977.0 +2007-05-25 04:00:00+00:00,26.66,27.7,0.0,0.0,0.0,313.02,2.59,249.0,91052.0 +2007-05-25 05:00:00+00:00,25.62,31.0,0.0,0.0,0.0,309.95,1.94,248.0,91127.0 +2007-05-25 06:00:00+00:00,24.44,33.48,0.0,0.0,0.0,306.27,1.7,237.0,91142.0 +2007-05-25 07:00:00+00:00,23.26,35.95,0.0,0.0,0.0,302.58,1.46,226.0,91157.0 +2007-05-25 08:00:00+00:00,22.08,38.43,0.0,0.0,0.0,298.9,1.21,214.0,91172.0 +2007-05-25 09:00:00+00:00,20.93,41.17,0.0,0.0,0.0,297.2,1.21,191.0,91184.0 +2007-05-25 10:00:00+00:00,19.78,43.9,0.0,0.0,0.0,295.5,1.21,168.0,91196.0 +2007-05-25 11:00:00+00:00,18.63,46.64,0.0,0.0,0.0,293.8,1.21,144.0,91208.0 +2007-05-25 12:00:00+00:00,20.88,41.72,0.0,0.0,0.0,295.9,1.09,142.0,91247.0 +2007-05-25 13:00:00+00:00,23.12,36.8,77.0,323.51,39.0,298.0,0.97,140.0,91286.0 +2007-05-25 14:00:00+00:00,25.37,31.88,284.0,644.97,75.0,300.1,0.84,138.0,91325.0 +2007-05-25 15:00:00+00:00,27.25,27.99,509.0,790.08,97.0,305.13,1.39,150.0,91286.0 +2007-05-25 16:00:00+00:00,29.14,24.1,717.0,870.37,111.0,310.17,1.94,161.0,91247.0 +2007-05-25 17:00:00+00:00,31.02,20.21,886.0,914.52,121.0,315.2,2.48,173.0,91208.0 +2007-05-25 18:00:00+00:00,32.17,18.49,1004.0,940.31,127.0,314.72,3.09,188.0,91124.0 +2007-05-25 19:00:00+00:00,33.32,16.77,1060.0,950.74,130.0,314.23,3.71,203.0,91040.0 +2007-05-25 20:00:00+00:00,34.48,15.05,1049.0,948.51,129.0,313.75,4.32,218.0,90956.0 +2007-05-25 21:00:00+00:00,34.25,14.79,973.0,933.38,125.0,313.05,4.42,226.0,90914.0 +2007-05-25 22:00:00+00:00,34.02,14.54,837.0,900.89,118.0,312.35,4.53,235.0,90872.0 +2007-05-25 23:00:00+00:00,33.79,14.28,654.0,846.49,107.0,311.65,4.63,243.0,90830.0 +2007-05-26 00:00:00+00:00,32.47,15.77,439.0,748.89,91.0,319.87,3.69,246.0,90863.0 +2007-05-26 01:00:00+00:00,31.15,17.25,216.0,569.75,66.0,328.08,2.74,248.0,90896.0 +2007-05-26 02:00:00+00:00,29.83,18.74,31.0,158.1,22.0,336.3,1.79,250.0,90929.0 +2007-05-26 03:00:00+00:00,28.43,20.88,0.0,0.0,0.0,337.1,1.52,251.0,91022.0 +2007-05-26 04:00:00+00:00,27.04,23.01,0.0,0.0,0.0,337.9,1.24,252.0,91115.0 +2007-05-26 05:00:00+00:00,25.64,25.15,0.0,0.0,0.0,338.7,0.97,254.0,91208.0 +2007-05-26 06:00:00+00:00,24.93,27.2,0.0,0.0,0.0,329.6,0.82,236.0,91208.0 +2007-05-26 07:00:00+00:00,24.23,29.26,0.0,0.0,0.0,320.5,0.68,218.0,91208.0 +2007-05-26 08:00:00+00:00,23.52,31.31,0.0,0.0,0.0,311.4,0.54,200.0,91208.0 +2007-05-26 09:00:00+00:00,22.39,33.0,0.0,0.0,0.0,308.23,0.75,189.0,91223.0 +2007-05-26 10:00:00+00:00,21.25,34.7,0.0,0.0,0.0,305.07,0.97,179.0,91238.0 +2007-05-26 11:00:00+00:00,20.11,36.39,0.0,0.0,0.0,301.9,1.19,169.0,91253.0 +2007-05-26 12:00:00+00:00,22.05,32.6,0.0,0.0,0.0,301.4,1.39,175.0,91319.0 +2007-05-26 13:00:00+00:00,24.0,28.82,77.0,320.08,39.0,300.9,1.59,181.0,91385.0 +2007-05-26 14:00:00+00:00,25.94,25.03,283.0,639.87,75.0,300.4,1.79,187.0,91452.0 +2007-05-26 15:00:00+00:00,27.68,21.87,506.0,783.11,97.0,303.55,2.33,198.0,91431.0 +2007-05-26 16:00:00+00:00,29.42,18.7,714.0,865.25,111.0,306.7,2.87,208.0,91410.0 +2007-05-26 17:00:00+00:00,31.16,15.54,885.0,912.72,121.0,309.85,3.41,218.0,91388.0 +2007-05-26 18:00:00+00:00,32.08,13.98,1003.0,938.72,127.0,308.27,3.65,225.0,91307.0 +2007-05-26 19:00:00+00:00,33.0,12.42,1060.0,950.2,130.0,306.68,3.89,231.0,91226.0 +2007-05-26 20:00:00+00:00,33.93,10.86,1050.0,947.87,130.0,305.1,4.14,237.0,91145.0 +2007-05-26 21:00:00+00:00,33.73,10.54,975.0,933.65,126.0,303.73,4.2,244.0,91085.0 +2007-05-26 22:00:00+00:00,33.53,10.23,840.0,902.24,119.0,302.37,4.26,250.0,91025.0 +2007-05-26 23:00:00+00:00,33.33,9.91,658.0,851.02,107.0,301.0,4.32,256.0,90965.0 +2007-05-27 00:00:00+00:00,32.05,11.29,443.0,755.05,91.0,302.22,3.96,260.0,90956.0 +2007-05-27 01:00:00+00:00,30.78,12.67,220.0,577.3,67.0,303.43,3.61,265.0,90947.0 +2007-05-27 02:00:00+00:00,29.5,14.05,33.0,186.71,22.0,304.65,3.26,269.0,90938.0 +2007-05-27 03:00:00+00:00,28.06,15.88,0.0,0.0,0.0,305.17,3.09,269.0,91019.0 +2007-05-27 04:00:00+00:00,26.61,17.72,0.0,0.0,0.0,305.68,2.93,270.0,91100.0 +2007-05-27 05:00:00+00:00,25.17,19.55,0.0,0.0,0.0,306.2,2.77,270.0,91181.0 +2007-05-27 06:00:00+00:00,24.49,21.29,0.0,0.0,0.0,302.68,2.48,264.0,91181.0 +2007-05-27 07:00:00+00:00,23.82,23.03,0.0,0.0,0.0,299.17,2.18,257.0,91181.0 +2007-05-27 08:00:00+00:00,23.14,24.77,0.0,0.0,0.0,295.65,1.89,251.0,91181.0 +2007-05-27 09:00:00+00:00,22.2,25.71,0.0,0.0,0.0,294.2,1.71,241.0,91184.0 +2007-05-27 10:00:00+00:00,21.25,26.65,0.0,0.0,0.0,292.75,1.53,231.0,91187.0 +2007-05-27 11:00:00+00:00,20.31,27.59,0.0,0.0,0.0,291.3,1.35,220.0,91190.0 +2007-05-27 12:00:00+00:00,22.27,24.65,0.0,0.0,0.0,293.77,1.27,220.0,91238.0 +2007-05-27 13:00:00+00:00,24.23,21.71,79.0,333.62,39.0,296.23,1.2,219.0,91286.0 +2007-05-27 14:00:00+00:00,26.19,18.77,285.0,641.09,76.0,298.7,1.12,218.0,91334.0 +2007-05-27 15:00:00+00:00,28.05,16.41,508.0,785.82,97.0,302.63,1.37,223.0,91313.0 +2007-05-27 16:00:00+00:00,29.91,14.04,714.0,864.51,111.0,306.57,1.61,227.0,91292.0 +2007-05-27 17:00:00+00:00,31.77,11.68,884.0,910.97,121.0,310.5,1.86,232.0,91271.0 +2007-05-27 18:00:00+00:00,32.7,10.8,1001.0,936.09,127.0,309.57,2.5,233.0,91190.0 +2007-05-27 19:00:00+00:00,33.63,9.91,1056.0,945.61,130.0,308.63,3.14,233.0,91109.0 +2007-05-27 20:00:00+00:00,34.56,9.03,1045.0,943.13,129.0,307.7,3.78,234.0,91028.0 +2007-05-27 21:00:00+00:00,34.29,8.98,970.0,927.34,126.0,306.37,4.1,240.0,90971.0 +2007-05-27 22:00:00+00:00,34.03,8.92,837.0,898.61,118.0,305.03,4.41,245.0,90914.0 +2007-05-27 23:00:00+00:00,33.77,8.87,656.0,846.3,107.0,303.7,4.73,251.0,90857.0 +2007-05-28 00:00:00+00:00,32.3,10.3,443.0,750.53,92.0,301.9,4.41,248.0,90869.0 +2007-05-28 01:00:00+00:00,30.84,11.73,221.0,577.31,67.0,300.1,4.09,245.0,90881.0 +2007-05-28 02:00:00+00:00,29.37,13.16,34.0,180.72,23.0,298.3,3.77,242.0,90893.0 +2007-05-28 03:00:00+00:00,27.88,15.4,0.0,0.0,0.0,296.6,3.41,242.0,90971.0 +2007-05-28 04:00:00+00:00,26.38,17.64,0.0,0.0,0.0,294.9,3.05,242.0,91049.0 +2007-05-28 05:00:00+00:00,24.89,19.88,0.0,0.0,0.0,293.2,2.69,243.0,91127.0 +2007-05-28 06:00:00+00:00,24.02,21.62,0.0,0.0,0.0,290.35,2.35,236.0,91139.0 +2007-05-28 07:00:00+00:00,23.15,23.37,0.0,0.0,0.0,287.5,2.02,230.0,91151.0 +2007-05-28 08:00:00+00:00,22.28,25.11,0.0,0.0,0.0,284.65,1.68,223.0,91163.0 +2007-05-28 09:00:00+00:00,21.08,25.98,0.0,0.0,0.0,282.97,1.61,210.0,91172.0 +2007-05-28 10:00:00+00:00,19.88,26.86,0.0,0.0,0.0,281.28,1.54,198.0,91181.0 +2007-05-28 11:00:00+00:00,18.68,27.73,0.0,0.0,0.0,279.6,1.46,185.0,91190.0 +2007-05-28 12:00:00+00:00,21.09,24.93,0.0,0.0,0.0,282.65,1.7,185.0,91214.0 +2007-05-28 13:00:00+00:00,23.5,22.13,82.0,347.13,40.0,285.7,1.93,185.0,91238.0 +2007-05-28 14:00:00+00:00,25.91,19.33,292.0,657.74,77.0,288.75,2.17,185.0,91262.0 +2007-05-28 15:00:00+00:00,27.58,16.54,518.0,801.99,98.0,292.77,2.9,194.0,91235.0 +2007-05-28 16:00:00+00:00,29.24,13.76,726.0,879.6,112.0,296.78,3.64,203.0,91208.0 +2007-05-28 17:00:00+00:00,30.91,10.97,896.0,923.6,122.0,300.8,4.37,212.0,91181.0 +2007-05-28 18:00:00+00:00,31.75,10.04,1014.0,948.49,128.0,300.98,4.74,220.0,91109.0 +2007-05-28 19:00:00+00:00,32.59,9.1,1070.0,958.4,131.0,301.17,5.11,228.0,91037.0 +2007-05-28 20:00:00+00:00,33.43,8.17,1060.0,956.95,130.0,301.35,5.48,236.0,90965.0 +2007-05-28 21:00:00+00:00,33.09,8.57,985.0,941.92,127.0,300.4,5.56,241.0,90920.0 +2007-05-28 22:00:00+00:00,32.75,8.98,850.0,911.24,120.0,299.45,5.64,246.0,90875.0 +2007-05-28 23:00:00+00:00,32.41,9.38,667.0,860.09,108.0,298.5,5.72,252.0,90830.0 +2007-05-29 00:00:00+00:00,31.12,11.12,449.0,750.33,97.0,298.82,5.23,253.0,90869.0 +2007-05-29 01:00:00+00:00,29.82,12.86,225.0,573.66,71.0,299.13,4.74,255.0,90908.0 +2007-05-29 02:00:00+00:00,28.53,14.6,35.0,175.19,24.0,299.45,4.25,257.0,90947.0 +2007-05-29 03:00:00+00:00,27.25,16.37,0.0,0.0,0.0,297.75,3.61,254.0,91025.0 +2007-05-29 04:00:00+00:00,25.96,18.13,0.0,0.0,0.0,296.05,2.97,252.0,91103.0 +2007-05-29 05:00:00+00:00,24.68,19.9,0.0,0.0,0.0,294.35,2.33,249.0,91181.0 +2007-05-29 06:00:00+00:00,23.27,21.11,0.0,0.0,0.0,291.47,2.11,236.0,91190.0 +2007-05-29 07:00:00+00:00,21.86,22.31,0.0,0.0,0.0,288.58,1.9,222.0,91199.0 +2007-05-29 08:00:00+00:00,20.44,23.52,0.0,0.0,0.0,285.7,1.68,209.0,91208.0 +2007-05-29 09:00:00+00:00,19.66,24.17,0.0,0.0,0.0,284.32,1.74,200.0,91217.0 +2007-05-29 10:00:00+00:00,18.88,24.81,0.0,0.0,0.0,282.93,1.79,190.0,91226.0 +2007-05-29 11:00:00+00:00,18.1,25.46,0.0,0.0,0.0,281.55,1.85,181.0,91235.0 +2007-05-29 12:00:00+00:00,20.36,22.77,0.0,0.0,0.0,284.32,2.0,190.0,91283.0 +2007-05-29 13:00:00+00:00,22.63,20.07,80.0,319.66,41.0,287.08,2.15,198.0,91331.0 +2007-05-29 14:00:00+00:00,24.89,17.38,284.0,622.58,80.0,289.85,2.3,207.0,91379.0 +2007-05-29 15:00:00+00:00,26.53,15.09,505.0,768.63,102.0,293.62,3.02,214.0,91367.0 +2007-05-29 16:00:00+00:00,28.16,12.8,710.0,847.5,118.0,297.38,3.74,221.0,91355.0 +2007-05-29 17:00:00+00:00,29.8,10.51,878.0,894.52,128.0,301.15,4.46,227.0,91343.0 +2007-05-29 18:00:00+00:00,30.71,9.97,996.0,921.33,135.0,303.22,4.67,232.0,91283.0 +2007-05-29 19:00:00+00:00,31.63,9.42,1052.0,932.44,138.0,305.28,4.89,237.0,91223.0 +2007-05-29 20:00:00+00:00,32.55,8.88,1042.0,930.66,137.0,307.35,5.1,242.0,91163.0 +2007-05-29 21:00:00+00:00,32.31,9.33,968.0,915.91,133.0,308.55,5.2,246.0,91124.0 +2007-05-29 22:00:00+00:00,32.07,9.77,835.0,883.95,126.0,309.75,5.3,250.0,91085.0 +2007-05-29 23:00:00+00:00,31.84,10.22,655.0,830.85,114.0,310.95,5.39,255.0,91046.0 +2007-05-30 00:00:00+00:00,30.6,11.78,443.0,735.29,97.0,311.05,4.92,255.0,91073.0 +2007-05-30 01:00:00+00:00,29.37,13.35,223.0,562.7,71.0,311.15,4.45,255.0,91100.0 +2007-05-30 02:00:00+00:00,28.13,14.91,36.0,170.09,25.0,311.25,3.97,256.0,91127.0 +2007-05-30 03:00:00+00:00,27.08,17.84,0.0,0.0,0.0,309.4,3.34,255.0,91208.0 +2007-05-30 04:00:00+00:00,26.04,20.77,0.0,0.0,0.0,307.55,2.7,253.0,91289.0 +2007-05-30 05:00:00+00:00,24.99,23.7,0.0,0.0,0.0,305.7,2.07,252.0,91370.0 +2007-05-30 06:00:00+00:00,23.77,25.8,0.0,0.0,0.0,302.55,1.78,240.0,91370.0 +2007-05-30 07:00:00+00:00,22.56,27.9,0.0,0.0,0.0,299.4,1.5,227.0,91370.0 +2007-05-30 08:00:00+00:00,21.34,30.0,0.0,0.0,0.0,296.25,1.21,214.0,91370.0 +2007-05-30 09:00:00+00:00,20.26,31.53,0.0,0.0,0.0,295.28,1.15,202.0,91382.0 +2007-05-30 10:00:00+00:00,19.17,33.06,0.0,0.0,0.0,294.32,1.09,189.0,91394.0 +2007-05-30 11:00:00+00:00,18.08,34.59,0.0,0.0,0.0,293.35,1.03,176.0,91406.0 +2007-05-30 12:00:00+00:00,20.65,30.45,0.0,0.0,0.0,297.68,1.05,178.0,91440.0 +2007-05-30 13:00:00+00:00,23.23,26.3,83.0,333.51,42.0,302.02,1.07,179.0,91473.0 +2007-05-30 14:00:00+00:00,25.8,22.16,292.0,642.53,81.0,306.35,1.09,181.0,91506.0 +2007-05-30 15:00:00+00:00,27.56,19.61,518.0,788.79,104.0,310.92,1.48,191.0,91479.0 +2007-05-30 16:00:00+00:00,29.32,17.06,727.0,869.88,119.0,315.48,1.86,201.0,91452.0 +2007-05-30 17:00:00+00:00,31.08,14.51,899.0,916.78,130.0,320.05,2.25,211.0,91425.0 +2007-05-30 18:00:00+00:00,32.15,13.51,1019.0,943.43,137.0,320.97,2.5,220.0,91349.0 +2007-05-30 19:00:00+00:00,33.23,12.5,1077.0,955.49,140.0,321.88,2.74,228.0,91274.0 +2007-05-30 20:00:00+00:00,34.31,11.5,1068.0,954.8,139.0,322.8,2.99,237.0,91199.0 +2007-05-30 21:00:00+00:00,34.25,11.03,994.0,941.47,135.0,322.15,3.2,243.0,91133.0 +2007-05-30 22:00:00+00:00,34.2,10.55,860.0,911.55,128.0,321.5,3.42,249.0,91067.0 +2007-05-30 23:00:00+00:00,34.15,10.08,676.0,858.47,116.0,320.85,3.63,255.0,91001.0 +2007-05-31 00:00:00+00:00,32.89,11.1,460.0,764.87,99.0,320.78,3.53,258.0,90989.0 +2007-05-31 01:00:00+00:00,31.64,12.12,233.0,588.74,73.0,320.72,3.43,260.0,90977.0 +2007-05-31 02:00:00+00:00,30.38,13.14,39.0,195.44,26.0,320.65,3.32,262.0,90965.0 +2007-05-31 03:00:00+00:00,28.84,14.71,0.0,0.0,0.0,318.12,3.09,263.0,91031.0 +2007-05-31 04:00:00+00:00,27.29,16.28,0.0,0.0,0.0,315.58,2.85,263.0,91097.0 +2007-05-31 05:00:00+00:00,25.75,17.85,0.0,0.0,0.0,313.05,2.61,263.0,91163.0 +2007-05-31 06:00:00+00:00,25.07,19.5,0.0,0.0,0.0,309.12,2.21,259.0,91160.0 +2007-05-31 07:00:00+00:00,24.4,21.16,0.0,0.0,0.0,305.18,1.82,255.0,91157.0 +2007-05-31 08:00:00+00:00,23.72,22.81,0.0,0.0,0.0,301.25,1.42,251.0,91154.0 +2007-05-31 09:00:00+00:00,22.89,24.3,0.0,0.0,0.0,299.88,1.09,237.0,91142.0 +2007-05-31 10:00:00+00:00,22.05,25.78,0.0,0.0,0.0,298.52,0.75,223.0,91130.0 +2007-05-31 11:00:00+00:00,21.22,27.27,0.0,0.0,0.0,297.15,0.41,209.0,91118.0 +2007-05-31 12:00:00+00:00,22.87,24.39,0.0,0.0,0.0,298.92,0.36,240.0,91148.0 +2007-05-31 13:00:00+00:00,24.51,21.5,83.0,331.22,42.0,300.68,0.31,272.0,91178.0 +2007-05-31 14:00:00+00:00,26.16,18.62,291.0,638.23,81.0,302.45,0.26,303.0,91208.0 +2007-05-31 15:00:00+00:00,28.06,16.05,515.0,782.35,104.0,307.52,0.65,282.0,91163.0 +2007-05-31 16:00:00+00:00,34.92,10.16,722.0,862.26,119.0,326.05,3.18,261.0,91118.0 +2007-05-31 17:00:00+00:00,34.35,10.06,892.0,909.28,129.0,322.96,3.15,241.0,91073.0 +2007-05-31 18:00:00+00:00,33.78,9.97,1011.0,935.61,136.0,319.87,3.12,244.0,90986.0 +2007-05-31 19:00:00+00:00,33.2,9.87,1068.0,946.94,139.0,316.78,3.09,246.0,90899.0 +2007-05-31 20:00:00+00:00,32.63,9.78,1058.0,945.02,138.0,313.69,3.05,249.0,90812.0 +2007-05-31 21:00:00+00:00,32.06,9.68,983.0,929.78,134.0,310.59,3.02,254.0,90761.0 +2007-05-31 22:00:00+00:00,31.49,9.58,848.0,896.81,127.0,307.5,2.99,258.0,90710.0 +2007-05-31 23:00:00+00:00,30.92,9.49,580.0,578.43,202.0,304.41,2.96,262.0,90659.0 +2008-06-01 00:00:00+00:00,30.35,9.39,476.0,817.56,89.0,301.32,2.93,271.0,91055.0 +2008-06-01 01:00:00+00:00,29.78,9.3,182.0,303.61,99.0,298.23,2.9,275.0,91091.0 +2008-06-01 02:00:00+00:00,29.21,9.2,40.0,204.91,26.0,295.14,2.87,280.0,91127.0 +2008-06-01 03:00:00+00:00,28.63,9.11,0.0,0.0,0.0,292.05,2.84,283.0,91187.0 +2008-06-01 04:00:00+00:00,28.06,9.01,0.0,0.0,0.0,288.96,2.81,286.0,91247.0 +2008-06-01 05:00:00+00:00,27.49,8.91,0.0,0.0,0.0,285.87,2.78,289.0,91307.0 +2008-06-01 06:00:00+00:00,26.92,8.82,0.0,0.0,0.0,282.78,2.75,299.0,91298.0 +2008-06-01 07:00:00+00:00,26.35,8.72,0.0,0.0,0.0,279.69,2.72,308.0,91289.0 +2008-06-01 08:00:00+00:00,23.81,10.92,0.0,0.0,0.0,277.4,1.24,318.0,91280.0 +2008-06-01 09:00:00+00:00,22.67,11.68,0.0,0.0,0.0,276.45,1.23,334.0,91292.0 +2008-06-01 10:00:00+00:00,21.52,12.45,0.0,0.0,0.0,275.5,1.21,349.0,91304.0 +2008-06-01 11:00:00+00:00,20.38,13.21,0.0,0.0,0.0,274.55,1.2,5.0,91316.0 +2008-06-01 12:00:00+00:00,22.24,12.45,0.0,0.0,0.0,276.37,0.96,352.0,91364.0 +2008-06-01 13:00:00+00:00,24.1,11.7,91.0,409.46,40.0,278.18,0.71,339.0,91413.0 +2008-06-01 14:00:00+00:00,25.96,10.94,309.0,712.97,74.0,280.0,0.47,326.0,91461.0 +2008-06-01 15:00:00+00:00,28.15,9.34,541.0,852.1,93.0,283.78,0.97,308.0,91431.0 +2008-06-01 16:00:00+00:00,30.34,7.73,754.0,924.76,107.0,287.57,1.48,290.0,91400.0 +2008-06-01 17:00:00+00:00,32.53,6.13,929.0,968.55,116.0,291.35,1.99,271.0,91370.0 +2008-06-01 18:00:00+00:00,33.79,5.51,1051.0,993.03,122.0,291.07,2.72,273.0,91301.0 +2008-06-01 19:00:00+00:00,35.06,4.89,1110.0,1003.63,125.0,290.78,3.46,274.0,91232.0 +2008-06-01 20:00:00+00:00,36.33,4.27,1101.0,1003.04,124.0,290.5,4.19,276.0,91163.0 +2008-06-01 21:00:00+00:00,36.2,4.29,1025.0,989.26,121.0,290.13,4.35,280.0,91112.0 +2008-06-01 22:00:00+00:00,36.07,4.32,888.0,961.64,114.0,289.77,4.51,283.0,91061.0 +2008-06-01 23:00:00+00:00,35.95,4.34,701.0,911.95,104.0,289.4,4.68,286.0,91010.0 +2008-06-02 00:00:00+00:00,33.71,5.14,480.0,823.64,89.0,286.87,4.17,289.0,91028.0 +2008-06-02 01:00:00+00:00,31.48,5.95,248.0,658.29,67.0,284.33,3.66,291.0,91046.0 +2008-06-02 02:00:00+00:00,29.25,6.75,45.0,256.82,27.0,281.8,3.14,294.0,91064.0 +2008-06-02 03:00:00+00:00,27.78,8.48,0.0,0.0,0.0,281.77,2.98,300.0,91121.0 +2008-06-02 04:00:00+00:00,26.32,10.2,0.0,0.0,0.0,281.73,2.81,305.0,91178.0 +2008-06-02 05:00:00+00:00,24.86,11.93,0.0,0.0,0.0,281.7,2.65,311.0,91235.0 +2008-06-02 06:00:00+00:00,24.26,11.22,0.0,0.0,0.0,280.03,2.54,319.0,91217.0 +2008-06-02 07:00:00+00:00,23.67,10.52,0.0,0.0,0.0,278.37,2.43,328.0,91199.0 +2008-06-02 08:00:00+00:00,23.07,9.81,0.0,0.0,0.0,276.7,2.32,336.0,91181.0 +2008-06-02 09:00:00+00:00,22.15,10.64,0.0,0.0,0.0,275.72,2.19,348.0,91181.0 +2008-06-02 10:00:00+00:00,21.22,11.48,0.0,0.0,0.0,274.73,2.07,0.0,91181.0 +2008-06-02 11:00:00+00:00,20.3,12.31,0.0,0.0,0.0,273.75,1.94,12.0,91181.0 +2008-06-02 12:00:00+00:00,22.62,11.53,0.0,0.0,0.0,276.92,1.63,26.0,91211.0 +2008-06-02 13:00:00+00:00,24.95,10.75,92.0,407.2,41.0,280.08,1.31,40.0,91241.0 +2008-06-02 14:00:00+00:00,27.28,9.97,311.0,717.94,74.0,283.25,0.99,55.0,91271.0 +2008-06-02 15:00:00+00:00,29.46,8.68,542.0,851.52,94.0,288.43,0.8,11.0,91244.0 +2008-06-02 16:00:00+00:00,31.64,7.4,753.0,922.98,107.0,293.62,0.62,327.0,91217.0 +2008-06-02 17:00:00+00:00,33.82,6.11,924.0,962.32,116.0,298.8,0.43,283.0,91190.0 +2008-06-02 18:00:00+00:00,34.97,5.78,1042.0,983.14,122.0,300.52,1.34,279.0,91118.0 +2008-06-02 19:00:00+00:00,36.13,5.46,1099.0,992.07,125.0,302.23,2.26,275.0,91046.0 +2008-06-02 20:00:00+00:00,37.28,5.13,1088.0,989.2,124.0,303.95,3.17,272.0,90974.0 +2008-06-02 21:00:00+00:00,37.19,5.26,1012.0,974.31,121.0,305.72,3.66,276.0,90932.0 +2008-06-02 22:00:00+00:00,37.09,5.4,879.0,949.41,114.0,307.48,4.15,280.0,90890.0 +2008-06-02 23:00:00+00:00,37.0,5.53,695.0,901.23,104.0,309.25,4.63,284.0,90848.0 +2008-06-03 00:00:00+00:00,34.97,6.58,477.0,812.93,90.0,309.85,4.38,287.0,90884.0 +2008-06-03 01:00:00+00:00,32.93,7.64,247.0,650.99,67.0,310.45,4.12,291.0,90920.0 +2008-06-03 02:00:00+00:00,30.9,8.69,45.0,250.65,27.0,311.05,3.86,295.0,90956.0 +2008-06-03 03:00:00+00:00,29.55,10.59,0.0,0.0,0.0,312.37,3.63,299.0,91010.0 +2008-06-03 04:00:00+00:00,28.21,12.48,0.0,0.0,0.0,313.68,3.39,304.0,91064.0 +2008-06-03 05:00:00+00:00,26.87,14.38,0.0,0.0,0.0,315.0,3.16,309.0,91118.0 +2008-06-03 06:00:00+00:00,26.1,14.44,0.0,0.0,0.0,316.68,2.98,314.0,91103.0 +2008-06-03 07:00:00+00:00,25.34,14.5,0.0,0.0,0.0,318.37,2.8,318.0,91088.0 +2008-06-03 08:00:00+00:00,24.57,14.56,0.0,0.0,0.0,320.05,2.62,323.0,91073.0 +2008-06-03 09:00:00+00:00,23.92,14.66,0.0,0.0,0.0,316.62,2.49,328.0,91073.0 +2008-06-03 10:00:00+00:00,23.26,14.75,0.0,0.0,0.0,313.18,2.36,332.0,91073.0 +2008-06-03 11:00:00+00:00,22.61,14.85,0.0,0.0,0.0,309.75,2.23,336.0,91073.0 +2008-06-03 12:00:00+00:00,24.53,14.59,0.0,0.0,0.0,309.48,2.2,327.0,91121.0 +2008-06-03 13:00:00+00:00,26.46,14.33,86.0,373.44,39.0,309.22,2.17,318.0,91169.0 +2008-06-03 14:00:00+00:00,28.39,14.07,38.0,0.0,38.0,308.95,2.14,309.0,91217.0 +2008-06-03 15:00:00+00:00,30.19,12.22,519.0,809.25,93.0,311.95,2.78,304.0,91199.0 +2008-06-03 16:00:00+00:00,32.0,10.38,725.0,884.13,106.0,314.95,3.43,299.0,91181.0 +2008-06-03 17:00:00+00:00,33.81,8.53,894.0,927.57,115.0,317.95,4.07,294.0,91163.0 +2008-06-03 18:00:00+00:00,34.76,8.12,1011.0,950.85,121.0,318.67,4.58,293.0,91103.0 +2008-06-03 19:00:00+00:00,35.72,7.71,1066.0,960.17,123.0,319.38,5.1,293.0,91043.0 +2008-06-03 20:00:00+00:00,36.68,7.3,1056.0,956.93,123.0,320.1,5.61,292.0,90983.0 +2008-06-03 21:00:00+00:00,36.47,7.71,981.0,941.92,119.0,320.53,5.74,292.0,90947.0 +2008-06-03 22:00:00+00:00,36.25,8.13,849.0,912.42,113.0,320.97,5.87,293.0,90911.0 +2008-06-03 23:00:00+00:00,36.04,8.54,670.0,863.18,103.0,321.4,6.0,293.0,90875.0 +2008-06-04 00:00:00+00:00,34.28,9.54,458.0,775.09,88.0,319.08,5.27,294.0,90908.0 +2008-06-04 01:00:00+00:00,32.52,10.55,236.0,611.49,66.0,316.77,4.54,295.0,90941.0 +2008-06-04 02:00:00+00:00,30.77,11.55,44.0,244.92,26.0,314.45,3.81,296.0,90974.0 +2008-06-04 03:00:00+00:00,29.38,13.89,0.0,0.0,0.0,314.27,3.55,297.0,91016.0 +2008-06-04 04:00:00+00:00,28.0,16.24,0.0,0.0,0.0,314.08,3.3,299.0,91058.0 +2008-06-04 05:00:00+00:00,26.62,18.58,0.0,0.0,0.0,313.9,3.05,301.0,91100.0 +2008-06-04 06:00:00+00:00,26.07,17.74,0.0,0.0,0.0,312.22,2.78,303.0,91067.0 +2008-06-04 07:00:00+00:00,25.53,16.9,0.0,0.0,0.0,310.53,2.51,305.0,91034.0 +2008-06-04 08:00:00+00:00,24.98,16.06,0.0,0.0,0.0,308.85,2.23,307.0,91001.0 +2008-06-04 09:00:00+00:00,24.68,16.58,0.0,0.0,0.0,307.6,1.99,314.0,90986.0 +2008-06-04 10:00:00+00:00,24.39,17.11,0.0,0.0,0.0,306.35,1.75,321.0,90971.0 +2008-06-04 11:00:00+00:00,24.09,17.63,0.0,0.0,0.0,305.1,1.5,328.0,90956.0 +2008-06-04 12:00:00+00:00,25.43,16.6,0.0,0.0,0.0,306.73,1.32,306.0,90977.0 +2008-06-04 13:00:00+00:00,26.78,15.56,86.0,371.87,39.0,308.37,1.14,284.0,90998.0 +2008-06-04 14:00:00+00:00,28.13,14.53,293.0,664.84,73.0,310.0,0.95,262.0,91019.0 +2008-06-04 15:00:00+00:00,29.73,12.31,517.0,805.09,93.0,313.38,1.8,259.0,90983.0 +2008-06-04 16:00:00+00:00,31.34,10.1,724.0,882.5,106.0,316.77,2.64,256.0,90947.0 +2008-06-04 17:00:00+00:00,32.95,7.88,894.0,926.22,116.0,320.15,3.49,253.0,90911.0 +2008-06-04 18:00:00+00:00,33.99,7.25,1012.0,950.65,122.0,321.0,4.22,252.0,90827.0 +2008-06-04 19:00:00+00:00,35.03,6.61,1070.0,962.94,124.0,321.85,4.94,252.0,90743.0 +2008-06-04 20:00:00+00:00,36.07,5.98,1062.0,961.61,124.0,322.7,5.67,251.0,90659.0 +2008-06-04 21:00:00+00:00,35.91,5.82,991.0,951.09,120.0,323.38,5.92,252.0,90592.0 +2008-06-04 22:00:00+00:00,35.74,5.67,861.0,925.08,114.0,324.07,6.17,252.0,90526.0 +2008-06-04 23:00:00+00:00,35.58,5.51,682.0,878.47,104.0,324.75,6.41,253.0,90460.0 +2008-06-05 00:00:00+00:00,33.78,5.94,469.0,791.83,90.0,321.78,5.75,254.0,90469.0 +2008-06-05 01:00:00+00:00,31.98,6.37,244.0,633.3,67.0,318.82,5.09,255.0,90478.0 +2008-06-05 02:00:00+00:00,30.18,6.8,47.0,266.2,27.0,315.85,4.43,256.0,90487.0 +2008-06-05 03:00:00+00:00,28.61,8.02,0.0,0.0,0.0,313.03,3.83,256.0,90529.0 +2008-06-05 04:00:00+00:00,27.05,9.25,0.0,0.0,0.0,310.22,3.22,256.0,90571.0 +2008-06-05 05:00:00+00:00,25.49,10.47,0.0,0.0,0.0,307.4,2.62,257.0,90613.0 +2008-06-05 06:00:00+00:00,24.63,11.48,0.0,0.0,0.0,303.4,2.41,248.0,90580.0 +2008-06-05 07:00:00+00:00,23.76,12.5,0.0,0.0,0.0,299.4,2.2,240.0,90547.0 +2008-06-05 08:00:00+00:00,22.9,13.51,0.0,0.0,0.0,295.4,1.99,232.0,90514.0 +2008-06-05 09:00:00+00:00,21.73,14.24,0.0,0.0,0.0,292.22,1.98,226.0,90499.0 +2008-06-05 10:00:00+00:00,20.55,14.97,0.0,0.0,0.0,289.03,1.98,220.0,90484.0 +2008-06-05 11:00:00+00:00,19.38,15.7,0.0,0.0,0.0,285.85,1.97,214.0,90469.0 +2008-06-05 12:00:00+00:00,21.49,14.71,0.0,0.0,0.0,285.88,2.36,221.0,90472.0 +2008-06-05 13:00:00+00:00,23.6,13.72,90.0,386.3,41.0,285.92,2.74,227.0,90475.0 +2008-06-05 14:00:00+00:00,25.71,12.73,302.0,688.41,74.0,285.95,3.13,233.0,90478.0 +2008-06-05 15:00:00+00:00,27.34,11.67,528.0,823.8,94.0,287.78,4.45,230.0,90424.0 +2008-06-05 16:00:00+00:00,28.98,10.61,735.0,895.2,108.0,289.62,5.77,227.0,90370.0 +2008-06-05 17:00:00+00:00,30.62,9.55,903.0,935.62,117.0,291.45,7.09,224.0,90316.0 +2008-06-05 18:00:00+00:00,31.49,9.74,1018.0,956.89,122.0,291.95,7.8,225.0,90238.0 +2008-06-05 19:00:00+00:00,32.37,9.93,917.0,487.44,438.0,292.45,8.51,227.0,90160.0 +2008-06-05 20:00:00+00:00,33.25,10.12,945.0,533.88,424.0,292.95,9.21,229.0,90082.0 +2008-06-05 21:00:00+00:00,32.68,11.24,874.0,540.15,379.0,294.53,9.31,229.0,90037.0 +2008-06-05 22:00:00+00:00,32.11,12.37,848.0,909.28,113.0,296.12,9.41,230.0,89992.0 +2008-06-05 23:00:00+00:00,31.54,13.49,667.0,855.81,103.0,297.7,9.5,231.0,89947.0 +2008-06-06 00:00:00+00:00,29.55,15.08,457.0,766.84,89.0,296.25,8.77,231.0,89995.0 +2008-06-06 01:00:00+00:00,27.56,16.68,237.0,605.14,67.0,294.8,8.04,232.0,90043.0 +2008-06-06 02:00:00+00:00,25.57,18.27,45.0,234.61,27.0,293.35,7.31,232.0,90091.0 +2008-06-06 03:00:00+00:00,24.51,22.67,0.0,0.0,0.0,291.58,6.86,232.0,90175.0 +2008-06-06 04:00:00+00:00,23.45,27.07,0.0,0.0,0.0,289.82,6.41,232.0,90259.0 +2008-06-06 05:00:00+00:00,22.39,31.47,0.0,0.0,0.0,288.05,5.96,232.0,90343.0 +2008-06-06 06:00:00+00:00,21.36,36.3,0.0,0.0,0.0,285.8,5.42,232.0,90370.0 +2008-06-06 07:00:00+00:00,20.32,41.13,0.0,0.0,0.0,283.55,4.88,232.0,90397.0 +2008-06-06 08:00:00+00:00,19.29,45.96,0.0,0.0,0.0,281.3,4.34,232.0,90424.0 +2008-06-06 09:00:00+00:00,18.4,47.18,0.0,0.0,0.0,280.38,4.09,233.0,90469.0 +2008-06-06 10:00:00+00:00,17.5,48.41,0.0,0.0,0.0,279.47,3.83,234.0,90514.0 +2008-06-06 11:00:00+00:00,16.61,49.63,0.0,0.0,0.0,278.55,3.57,234.0,90559.0 +2008-06-06 12:00:00+00:00,17.97,42.25,0.0,0.0,0.0,281.9,3.82,239.0,90610.0 +2008-06-06 13:00:00+00:00,19.34,34.86,88.0,377.29,40.0,285.25,4.07,243.0,90662.0 +2008-06-06 14:00:00+00:00,20.71,27.48,298.0,675.87,74.0,288.6,4.32,247.0,90713.0 +2008-06-06 15:00:00+00:00,22.53,23.26,522.0,812.22,94.0,291.4,4.82,252.0,90725.0 +2008-06-06 16:00:00+00:00,24.35,19.05,732.0,890.83,108.0,294.2,5.33,256.0,90737.0 +2008-06-06 17:00:00+00:00,26.17,14.83,904.0,935.54,118.0,297.0,5.83,261.0,90749.0 +2008-06-06 18:00:00+00:00,27.45,13.06,1026.0,963.16,124.0,298.67,5.96,264.0,90716.0 +2008-06-06 19:00:00+00:00,28.73,11.29,1086.0,976.67,126.0,300.33,6.09,267.0,90683.0 +2008-06-06 20:00:00+00:00,30.01,9.52,1080.0,977.17,126.0,302.0,6.22,270.0,90650.0 +2008-06-06 21:00:00+00:00,30.22,9.28,1008.0,965.09,123.0,302.9,6.03,273.0,90625.0 +2008-06-06 22:00:00+00:00,30.43,9.03,874.0,936.78,116.0,303.8,5.84,275.0,90601.0 +2008-06-06 23:00:00+00:00,30.64,8.79,691.0,886.28,106.0,304.7,5.66,277.0,90577.0 +2008-06-07 00:00:00+00:00,29.06,10.23,475.0,798.15,91.0,302.88,4.78,283.0,90622.0 +2008-06-07 01:00:00+00:00,27.48,11.68,248.0,637.56,68.0,301.07,3.91,289.0,90668.0 +2008-06-07 02:00:00+00:00,25.9,13.12,49.0,268.3,28.0,299.25,3.03,295.0,90713.0 +2008-06-07 03:00:00+00:00,24.74,14.97,0.0,0.0,0.0,297.47,2.8,306.0,90782.0 +2008-06-07 04:00:00+00:00,23.58,16.83,0.0,0.0,0.0,295.68,2.56,318.0,90851.0 +2008-06-07 05:00:00+00:00,22.43,18.68,0.0,0.0,0.0,293.9,2.32,329.0,90920.0 +2008-06-07 06:00:00+00:00,21.91,18.22,0.0,0.0,0.0,291.1,2.05,346.0,90914.0 +2008-06-07 07:00:00+00:00,21.38,17.75,0.0,0.0,0.0,288.3,1.77,4.0,90908.0 +2008-06-07 08:00:00+00:00,20.86,17.29,0.0,0.0,0.0,285.5,1.5,21.0,90902.0 +2008-06-07 09:00:00+00:00,19.44,21.16,0.0,0.0,0.0,283.27,1.53,43.0,90914.0 +2008-06-07 10:00:00+00:00,18.02,25.04,0.0,0.0,0.0,281.03,1.55,65.0,90926.0 +2008-06-07 11:00:00+00:00,16.6,28.91,0.0,0.0,0.0,278.8,1.57,87.0,90938.0 +2008-06-07 12:00:00+00:00,19.43,24.4,0.0,0.0,0.0,282.63,1.39,97.0,90983.0 +2008-06-07 13:00:00+00:00,22.27,19.88,89.0,376.4,41.0,286.47,1.21,107.0,91028.0 +2008-06-07 14:00:00+00:00,25.11,15.37,298.0,675.55,74.0,290.3,1.03,116.0,91073.0 +2008-06-07 15:00:00+00:00,26.99,13.74,521.0,808.33,95.0,295.3,1.2,137.0,91055.0 +2008-06-07 16:00:00+00:00,28.87,12.1,727.0,883.67,108.0,300.3,1.37,157.0,91037.0 +2008-06-07 17:00:00+00:00,30.76,10.47,897.0,927.17,118.0,305.3,1.53,177.0,91019.0 +2008-06-07 18:00:00+00:00,31.99,9.49,1016.0,952.37,124.0,307.35,1.93,195.0,90935.0 +2008-06-07 19:00:00+00:00,33.22,8.52,1075.0,965.26,126.0,309.4,2.32,212.0,90851.0 +2008-06-07 20:00:00+00:00,34.45,7.54,1067.0,963.48,126.0,311.45,2.72,229.0,90767.0 +2008-06-07 21:00:00+00:00,34.65,7.35,995.0,950.31,123.0,313.48,3.06,236.0,90707.0 +2008-06-07 22:00:00+00:00,34.84,7.16,864.0,923.51,116.0,315.52,3.4,242.0,90647.0 +2008-06-07 23:00:00+00:00,35.04,6.97,685.0,875.85,106.0,317.55,3.74,249.0,90586.0 +2008-06-08 00:00:00+00:00,33.36,7.92,472.0,789.96,91.0,319.15,3.49,252.0,90604.0 +2008-06-08 01:00:00+00:00,31.68,8.87,247.0,627.44,69.0,320.75,3.23,255.0,90622.0 +2008-06-08 02:00:00+00:00,30.01,9.82,50.0,263.27,29.0,322.35,2.98,257.0,90640.0 +2008-06-08 03:00:00+00:00,28.72,11.73,0.0,0.0,0.0,321.38,2.71,255.0,90695.0 +2008-06-08 04:00:00+00:00,27.43,13.64,0.0,0.0,0.0,320.42,2.45,252.0,90749.0 +2008-06-08 05:00:00+00:00,26.14,15.55,0.0,0.0,0.0,319.45,2.18,249.0,90803.0 +2008-06-08 06:00:00+00:00,25.48,16.9,0.0,0.0,0.0,316.6,1.92,244.0,90797.0 +2008-06-08 07:00:00+00:00,24.83,18.26,0.0,0.0,0.0,313.75,1.66,239.0,90791.0 +2008-06-08 08:00:00+00:00,24.17,19.61,0.0,0.0,0.0,310.9,1.39,234.0,90785.0 +2008-06-08 09:00:00+00:00,23.12,21.31,0.0,0.0,0.0,309.0,1.2,218.0,90788.0 +2008-06-08 10:00:00+00:00,22.08,23.01,0.0,0.0,0.0,307.1,1.01,203.0,90791.0 +2008-06-08 11:00:00+00:00,21.03,24.71,0.0,0.0,0.0,305.2,0.81,188.0,90794.0 +2008-06-08 12:00:00+00:00,22.97,22.62,0.0,0.0,0.0,307.02,1.01,195.0,90836.0 +2008-06-08 13:00:00+00:00,24.91,20.52,87.0,367.9,40.0,308.83,1.2,203.0,90878.0 +2008-06-08 14:00:00+00:00,26.86,18.43,292.0,657.27,74.0,310.65,1.39,211.0,90920.0 +2008-06-08 15:00:00+00:00,28.61,18.35,513.0,795.04,94.0,316.15,2.28,215.0,90884.0 +2008-06-08 16:00:00+00:00,30.36,18.27,717.0,869.43,108.0,321.65,3.16,218.0,90848.0 +2008-06-08 17:00:00+00:00,32.12,18.19,886.0,914.08,118.0,327.15,4.04,222.0,90812.0 +2008-06-08 18:00:00+00:00,33.15,17.2,1004.0,939.49,124.0,330.03,4.6,226.0,90761.0 +2008-06-08 19:00:00+00:00,34.19,16.21,1062.0,951.84,126.0,332.92,5.16,231.0,90710.0 +2008-06-08 20:00:00+00:00,35.22,15.22,1055.0,950.83,126.0,335.8,5.72,235.0,90659.0 +2008-06-08 21:00:00+00:00,35.0,15.06,984.0,937.75,123.0,335.88,5.78,238.0,90622.0 +2008-06-08 22:00:00+00:00,34.77,14.91,855.0,911.53,116.0,335.97,5.83,242.0,90586.0 +2008-06-08 23:00:00+00:00,34.55,14.75,678.0,863.97,106.0,336.05,5.89,245.0,90550.0 +2008-06-09 00:00:00+00:00,33.17,16.43,467.0,777.73,91.0,333.97,5.32,248.0,90565.0 +2008-06-09 01:00:00+00:00,31.79,18.1,245.0,617.52,69.0,331.88,4.76,251.0,90580.0 +2008-06-09 02:00:00+00:00,30.42,19.78,50.0,258.58,29.0,329.8,4.19,254.0,90595.0 +2008-06-09 03:00:00+00:00,28.87,22.23,0.0,0.0,0.0,326.83,3.57,253.0,90686.0 +2008-06-09 04:00:00+00:00,27.33,24.68,0.0,0.0,0.0,323.87,2.95,252.0,90776.0 +2008-06-09 05:00:00+00:00,25.79,27.13,0.0,0.0,0.0,320.9,2.33,251.0,90866.0 +2008-06-09 06:00:00+00:00,24.9,29.65,0.0,0.0,0.0,317.5,2.11,246.0,90890.0 +2008-06-09 07:00:00+00:00,24.0,32.18,0.0,0.0,0.0,314.1,1.89,240.0,90914.0 +2008-06-09 08:00:00+00:00,23.11,34.7,0.0,0.0,0.0,310.7,1.67,234.0,90938.0 +2008-06-09 09:00:00+00:00,22.33,36.62,0.0,0.0,0.0,309.35,1.38,238.0,90956.0 +2008-06-09 10:00:00+00:00,21.55,38.53,0.0,0.0,0.0,308.0,1.09,242.0,90974.0 +2008-06-09 11:00:00+00:00,20.77,40.45,0.0,0.0,0.0,306.65,0.8,246.0,90992.0 +2008-06-09 12:00:00+00:00,22.59,35.89,0.0,0.0,0.0,308.38,0.9,252.0,91031.0 +2008-06-09 13:00:00+00:00,24.41,31.34,88.0,367.46,41.0,310.12,1.0,257.0,91070.0 +2008-06-09 14:00:00+00:00,26.24,26.78,295.0,663.24,75.0,311.85,1.1,263.0,91109.0 +2008-06-09 15:00:00+00:00,28.04,22.84,516.0,798.91,95.0,316.52,1.7,258.0,91082.0 +2008-06-09 16:00:00+00:00,29.84,18.89,720.0,872.37,109.0,321.18,2.3,253.0,91055.0 +2008-06-09 17:00:00+00:00,31.65,14.95,888.0,916.5,118.0,325.85,2.9,248.0,91028.0 +2008-06-09 18:00:00+00:00,32.87,13.55,1005.0,940.51,124.0,327.63,3.49,253.0,90971.0 +2008-06-09 19:00:00+00:00,34.09,12.15,1063.0,951.67,127.0,329.42,4.07,258.0,90914.0 +2008-06-09 20:00:00+00:00,35.31,10.75,1056.0,950.49,127.0,331.2,4.66,263.0,90857.0 +2008-06-09 21:00:00+00:00,35.26,10.73,984.0,937.19,123.0,331.15,4.86,267.0,90812.0 +2008-06-09 22:00:00+00:00,35.22,10.7,855.0,909.45,117.0,331.1,5.06,272.0,90767.0 +2008-06-09 23:00:00+00:00,35.17,10.68,678.0,862.71,106.0,331.05,5.26,276.0,90722.0 +2008-06-10 00:00:00+00:00,33.67,11.83,467.0,773.86,92.0,327.2,4.74,283.0,90731.0 +2008-06-10 01:00:00+00:00,32.16,12.97,245.0,614.75,69.0,323.35,4.23,291.0,90740.0 +2008-06-10 02:00:00+00:00,30.66,14.12,51.0,266.31,29.0,319.5,3.71,298.0,90749.0 +2008-06-10 03:00:00+00:00,29.28,16.71,0.0,0.0,0.0,316.52,3.54,305.0,90815.0 +2008-06-10 04:00:00+00:00,27.9,19.31,0.0,0.0,0.0,313.53,3.37,312.0,90881.0 +2008-06-10 05:00:00+00:00,26.53,21.9,0.0,0.0,0.0,310.55,3.2,318.0,90947.0 +2008-06-10 06:00:00+00:00,26.01,21.69,0.0,0.0,0.0,307.18,2.87,325.0,90926.0 +2008-06-10 07:00:00+00:00,25.48,21.49,0.0,0.0,0.0,303.82,2.54,332.0,90905.0 +2008-06-10 08:00:00+00:00,24.96,21.28,0.0,0.0,0.0,300.45,2.21,338.0,90884.0 +2008-06-10 09:00:00+00:00,24.12,22.18,0.0,0.0,0.0,297.9,2.06,346.0,90896.0 +2008-06-10 10:00:00+00:00,23.28,23.08,0.0,0.0,0.0,295.35,1.91,354.0,90908.0 +2008-06-10 11:00:00+00:00,22.44,23.98,0.0,0.0,0.0,292.8,1.77,2.0,90920.0 +2008-06-10 12:00:00+00:00,24.37,22.28,0.0,0.0,0.0,293.92,1.53,12.0,90962.0 +2008-06-10 13:00:00+00:00,26.31,20.59,89.0,375.05,41.0,295.03,1.29,23.0,91004.0 +2008-06-10 14:00:00+00:00,28.25,18.89,297.0,669.35,75.0,296.15,1.05,33.0,91046.0 +2008-06-10 15:00:00+00:00,30.24,16.07,521.0,806.66,96.0,300.65,1.05,45.0,91019.0 +2008-06-10 16:00:00+00:00,32.23,13.24,728.0,882.51,110.0,305.15,1.06,57.0,90992.0 +2008-06-10 17:00:00+00:00,34.22,10.42,898.0,926.11,120.0,309.65,1.06,69.0,90965.0 +2008-06-10 18:00:00+00:00,35.3,9.41,1017.0,951.17,126.0,310.55,0.97,27.0,90902.0 +2008-06-10 19:00:00+00:00,36.39,8.41,1076.0,963.72,128.0,311.45,0.89,345.0,90839.0 +2008-06-10 20:00:00+00:00,37.47,7.4,1070.0,963.47,128.0,312.35,0.8,303.0,90776.0 +2008-06-10 21:00:00+00:00,37.62,7.14,998.0,949.71,125.0,312.58,1.21,304.0,90716.0 +2008-06-10 22:00:00+00:00,37.77,6.88,867.0,922.17,118.0,312.82,1.63,306.0,90656.0 +2008-06-10 23:00:00+00:00,37.92,6.62,687.0,873.54,107.0,313.05,2.04,307.0,90595.0 +2008-06-11 00:00:00+00:00,36.02,7.44,474.0,784.47,93.0,312.48,2.17,310.0,90595.0 +2008-06-11 01:00:00+00:00,34.12,8.27,250.0,626.01,70.0,311.92,2.29,314.0,90595.0 +2008-06-11 02:00:00+00:00,32.22,9.09,53.0,273.95,30.0,311.35,2.41,317.0,90595.0 +2008-06-11 03:00:00+00:00,30.96,10.1,0.0,0.0,0.0,311.33,2.51,322.0,90647.0 +2008-06-11 04:00:00+00:00,29.7,11.11,0.0,0.0,0.0,311.32,2.6,327.0,90698.0 +2008-06-11 05:00:00+00:00,28.44,12.12,0.0,0.0,0.0,311.3,2.69,333.0,90749.0 +2008-06-11 06:00:00+00:00,27.49,11.78,0.0,0.0,0.0,309.48,2.62,339.0,90740.0 +2008-06-11 07:00:00+00:00,26.55,11.43,0.0,0.0,0.0,307.67,2.54,345.0,90731.0 +2008-06-11 08:00:00+00:00,25.6,11.09,0.0,0.0,0.0,305.85,2.47,350.0,90722.0 +2008-06-11 09:00:00+00:00,24.9,11.96,0.0,0.0,0.0,304.48,2.27,0.0,90731.0 +2008-06-11 10:00:00+00:00,24.19,12.82,0.0,0.0,0.0,303.12,2.06,10.0,90740.0 +2008-06-11 11:00:00+00:00,23.49,13.69,0.0,0.0,0.0,301.75,1.86,20.0,90749.0 +2008-06-11 12:00:00+00:00,25.7,12.31,0.0,0.0,0.0,303.53,1.34,42.0,90791.0 +2008-06-11 13:00:00+00:00,27.92,10.93,89.0,375.04,41.0,305.32,0.81,63.0,90833.0 +2008-06-11 14:00:00+00:00,30.14,9.55,298.0,669.55,76.0,307.1,0.29,85.0,90875.0 +2008-06-11 15:00:00+00:00,32.34,7.97,523.0,808.8,97.0,311.07,1.18,134.0,90848.0 +2008-06-11 16:00:00+00:00,34.55,6.39,730.0,884.14,111.0,315.03,2.07,182.0,90821.0 +2008-06-11 17:00:00+00:00,36.76,4.81,901.0,929.8,120.0,319.0,2.97,231.0,90794.0 +2008-06-11 18:00:00+00:00,37.62,4.79,1022.0,956.52,126.0,321.22,3.89,235.0,90737.0 +2008-06-11 19:00:00+00:00,38.49,4.76,1081.0,967.65,129.0,323.43,4.82,240.0,90680.0 +2008-06-11 20:00:00+00:00,39.35,4.74,1075.0,967.25,129.0,325.65,5.75,245.0,90622.0 +2008-06-11 21:00:00+00:00,38.94,5.22,1003.0,954.62,125.0,326.77,6.0,249.0,90583.0 +2008-06-11 22:00:00+00:00,38.53,5.71,867.0,921.36,118.0,327.88,6.24,253.0,90544.0 +2008-06-11 23:00:00+00:00,38.12,6.19,684.0,866.32,108.0,329.0,6.48,257.0,90505.0 +2008-06-12 00:00:00+00:00,36.22,7.45,470.0,774.55,93.0,328.7,5.9,258.0,90538.0 +2008-06-12 01:00:00+00:00,34.31,8.71,247.0,613.03,70.0,328.4,5.31,260.0,90571.0 +2008-06-12 02:00:00+00:00,32.41,9.97,52.0,258.07,30.0,328.1,4.73,262.0,90604.0 +2008-06-12 03:00:00+00:00,30.79,11.68,0.0,0.0,0.0,325.15,4.02,259.0,90674.0 +2008-06-12 04:00:00+00:00,29.18,13.4,0.0,0.0,0.0,322.2,3.31,257.0,90743.0 +2008-06-12 05:00:00+00:00,27.57,15.11,0.0,0.0,0.0,319.25,2.61,254.0,90812.0 +2008-06-12 06:00:00+00:00,26.19,16.43,0.0,0.0,0.0,315.6,2.49,244.0,90821.0 +2008-06-12 07:00:00+00:00,24.81,17.75,0.0,0.0,0.0,311.95,2.38,234.0,90830.0 +2008-06-12 08:00:00+00:00,23.43,19.07,0.0,0.0,0.0,308.3,2.26,224.0,90839.0 +2008-06-12 09:00:00+00:00,22.55,20.21,0.0,0.0,0.0,304.78,2.32,220.0,90866.0 +2008-06-12 10:00:00+00:00,21.68,21.34,0.0,0.0,0.0,301.27,2.37,216.0,90893.0 +2008-06-12 11:00:00+00:00,20.8,22.48,0.0,0.0,0.0,297.75,2.43,211.0,90920.0 +2008-06-12 12:00:00+00:00,23.0,21.09,0.0,0.0,0.0,297.73,2.87,214.0,90953.0 +2008-06-12 13:00:00+00:00,25.21,19.69,90.0,383.05,41.0,297.72,3.31,216.0,90986.0 +2008-06-12 14:00:00+00:00,27.42,18.3,300.0,675.91,76.0,297.7,3.75,218.0,91019.0 +2008-06-12 15:00:00+00:00,29.24,15.16,526.0,814.82,97.0,300.55,4.59,222.0,90992.0 +2008-06-12 16:00:00+00:00,31.06,12.02,733.0,888.68,111.0,303.4,5.43,226.0,90965.0 +2008-06-12 17:00:00+00:00,32.89,8.88,903.0,931.15,121.0,306.25,6.28,230.0,90938.0 +2008-06-12 18:00:00+00:00,33.82,8.34,1022.0,955.48,127.0,308.45,6.52,235.0,90872.0 +2008-06-12 19:00:00+00:00,34.76,7.81,1081.0,966.53,130.0,310.65,6.76,240.0,90806.0 +2008-06-12 20:00:00+00:00,35.7,7.27,1074.0,965.94,129.0,312.85,7.01,244.0,90740.0 +2008-06-12 21:00:00+00:00,35.39,7.71,1002.0,951.94,126.0,314.07,6.97,247.0,90713.0 +2008-06-12 22:00:00+00:00,35.09,8.15,869.0,921.81,119.0,315.28,6.92,250.0,90686.0 +2008-06-12 23:00:00+00:00,34.78,8.59,688.0,871.18,108.0,316.5,6.88,253.0,90659.0 +2008-06-13 00:00:00+00:00,33.05,10.94,471.0,764.73,98.0,317.15,6.13,254.0,90710.0 +2008-06-13 01:00:00+00:00,31.32,13.29,247.0,596.79,74.0,317.8,5.37,256.0,90761.0 +2008-06-13 02:00:00+00:00,29.6,15.64,52.0,242.82,31.0,318.45,4.62,257.0,90812.0 +2008-06-13 03:00:00+00:00,28.29,17.47,0.0,0.0,0.0,315.07,3.92,255.0,90893.0 +2008-06-13 04:00:00+00:00,26.98,19.31,0.0,0.0,0.0,311.68,3.21,254.0,90974.0 +2008-06-13 05:00:00+00:00,25.67,21.14,0.0,0.0,0.0,308.3,2.51,252.0,91055.0 +2008-06-13 06:00:00+00:00,24.33,22.26,0.0,0.0,0.0,303.68,2.28,242.0,91064.0 +2008-06-13 07:00:00+00:00,23.0,23.37,0.0,0.0,0.0,299.07,2.04,232.0,91073.0 +2008-06-13 08:00:00+00:00,21.66,24.49,0.0,0.0,0.0,294.45,1.81,222.0,91082.0 +2008-06-13 09:00:00+00:00,20.67,24.68,0.0,0.0,0.0,291.7,1.71,214.0,91100.0 +2008-06-13 10:00:00+00:00,19.69,24.86,0.0,0.0,0.0,288.95,1.61,205.0,91118.0 +2008-06-13 11:00:00+00:00,18.7,25.05,0.0,0.0,0.0,286.2,1.52,197.0,91136.0 +2008-06-13 12:00:00+00:00,21.23,22.76,0.0,0.0,0.0,287.82,1.56,205.0,91172.0 +2008-06-13 13:00:00+00:00,23.77,20.47,88.0,352.16,43.0,289.43,1.6,213.0,91208.0 +2008-06-13 14:00:00+00:00,26.31,18.18,296.0,652.21,80.0,291.05,1.64,221.0,91244.0 +2008-06-13 15:00:00+00:00,28.17,15.54,519.0,790.51,103.0,295.17,1.92,234.0,91226.0 +2008-06-13 16:00:00+00:00,30.04,12.9,726.0,868.98,118.0,299.28,2.2,247.0,91208.0 +2008-06-13 17:00:00+00:00,31.91,10.26,897.0,915.86,128.0,303.4,2.48,260.0,91190.0 +2008-06-13 18:00:00+00:00,33.12,9.24,1018.0,942.74,135.0,304.7,2.87,263.0,91121.0 +2008-06-13 19:00:00+00:00,34.34,8.22,1077.0,954.24,138.0,306.0,3.26,267.0,91052.0 +2008-06-13 20:00:00+00:00,35.55,7.2,1072.0,955.46,137.0,307.3,3.66,270.0,90983.0 +2008-06-13 21:00:00+00:00,35.63,7.29,1001.0,941.68,134.0,308.67,3.89,274.0,90941.0 +2008-06-13 22:00:00+00:00,35.72,7.39,871.0,913.68,127.0,310.03,4.13,277.0,90899.0 +2008-06-13 23:00:00+00:00,35.8,7.48,692.0,865.56,115.0,311.4,4.37,281.0,90857.0 +2008-06-14 00:00:00+00:00,34.11,9.16,479.0,775.46,100.0,311.62,3.87,284.0,90887.0 +2008-06-14 01:00:00+00:00,32.42,10.84,254.0,615.15,75.0,311.83,3.36,287.0,90917.0 +2008-06-14 02:00:00+00:00,30.73,12.52,56.0,273.76,32.0,312.05,2.86,291.0,90947.0 +2008-06-14 03:00:00+00:00,29.62,15.6,0.0,0.0,0.0,311.48,2.66,295.0,91025.0 +2008-06-14 04:00:00+00:00,28.51,18.68,0.0,0.0,0.0,310.92,2.46,299.0,91103.0 +2008-06-14 05:00:00+00:00,27.41,21.76,0.0,0.0,0.0,310.35,2.26,303.0,91181.0 +2008-06-14 06:00:00+00:00,27.0,21.75,0.0,0.0,0.0,308.73,2.27,313.0,91175.0 +2008-06-14 07:00:00+00:00,26.58,21.73,0.0,0.0,0.0,307.12,2.28,323.0,91169.0 +2008-06-14 08:00:00+00:00,26.17,21.72,0.0,0.0,0.0,305.5,2.29,333.0,91163.0 +2008-06-14 09:00:00+00:00,24.93,22.2,0.0,0.0,0.0,305.25,2.34,346.0,91181.0 +2008-06-14 10:00:00+00:00,23.7,22.67,0.0,0.0,0.0,305.0,2.39,358.0,91199.0 +2008-06-14 11:00:00+00:00,22.46,23.15,0.0,0.0,0.0,304.75,2.44,11.0,91217.0 +2008-06-14 12:00:00+00:00,24.52,21.88,0.0,0.0,0.0,308.57,2.25,14.0,91280.0 +2008-06-14 13:00:00+00:00,26.58,20.6,88.0,352.73,43.0,312.38,2.06,17.0,91343.0 +2008-06-14 14:00:00+00:00,28.65,19.33,295.0,646.73,81.0,316.2,1.88,20.0,91406.0 +2008-06-14 15:00:00+00:00,30.89,16.55,517.0,787.18,103.0,321.72,1.86,18.0,91370.0 +2008-06-14 16:00:00+00:00,33.13,13.78,722.0,863.62,118.0,327.23,1.84,17.0,91334.0 +2008-06-14 17:00:00+00:00,35.38,11.0,890.0,907.75,128.0,332.75,1.82,15.0,91298.0 +2008-06-14 18:00:00+00:00,36.41,9.77,1009.0,933.21,135.0,334.45,1.89,352.0,91229.0 +2008-06-14 19:00:00+00:00,37.45,8.53,1067.0,944.01,138.0,336.15,1.96,328.0,91160.0 +2008-06-14 20:00:00+00:00,38.49,7.3,1060.0,942.95,137.0,337.85,2.03,304.0,91091.0 +2008-06-14 21:00:00+00:00,38.54,7.24,989.0,928.19,134.0,341.32,2.48,304.0,91052.0 +2008-06-14 22:00:00+00:00,38.6,7.18,859.0,899.46,126.0,344.78,2.94,304.0,91013.0 +2008-06-14 23:00:00+00:00,38.65,7.12,681.0,848.01,115.0,348.25,3.39,303.0,90974.0 +2008-06-15 00:00:00+00:00,36.75,7.85,470.0,757.62,99.0,343.78,3.29,307.0,91004.0 +2008-06-15 01:00:00+00:00,34.85,8.58,249.0,595.8,75.0,339.32,3.18,311.0,91034.0 +2008-06-15 02:00:00+00:00,32.96,9.31,54.0,247.77,32.0,334.85,3.08,314.0,91064.0 +2008-06-15 03:00:00+00:00,31.64,11.3,0.0,0.0,0.0,334.05,3.12,320.0,91118.0 +2008-06-15 04:00:00+00:00,30.33,13.28,0.0,0.0,0.0,333.25,3.16,327.0,91172.0 +2008-06-15 05:00:00+00:00,29.02,15.27,0.0,0.0,0.0,332.45,3.2,333.0,91226.0 +2008-06-15 06:00:00+00:00,28.1,15.43,0.0,0.0,0.0,330.4,3.12,340.0,91211.0 +2008-06-15 07:00:00+00:00,27.19,15.59,0.0,0.0,0.0,328.35,3.03,348.0,91196.0 +2008-06-15 08:00:00+00:00,26.27,15.75,0.0,0.0,0.0,326.3,2.95,356.0,91181.0 +2008-06-15 09:00:00+00:00,25.51,16.8,0.0,0.0,0.0,325.83,2.78,3.0,91187.0 +2008-06-15 10:00:00+00:00,24.76,17.86,0.0,0.0,0.0,325.37,2.6,11.0,91193.0 +2008-06-15 11:00:00+00:00,24.0,18.91,0.0,0.0,0.0,324.9,2.43,19.0,91199.0 +2008-06-15 12:00:00+00:00,26.39,16.97,0.0,0.0,0.0,325.98,2.08,24.0,91241.0 +2008-06-15 13:00:00+00:00,28.79,15.04,83.0,322.07,42.0,327.07,1.74,30.0,91283.0 +2008-06-15 14:00:00+00:00,31.19,13.1,282.0,614.12,79.0,328.15,1.39,36.0,91325.0 +2008-06-15 15:00:00+00:00,33.46,11.09,499.0,755.37,102.0,337.15,1.45,33.0,91289.0 +2008-06-15 16:00:00+00:00,35.73,9.07,700.0,833.98,117.0,346.15,1.51,31.0,91253.0 +2008-06-15 17:00:00+00:00,38.01,7.06,865.0,879.41,127.0,355.15,1.57,28.0,91217.0 +2008-06-15 18:00:00+00:00,38.92,7.0,980.0,904.49,133.0,353.88,1.81,5.0,91154.0 +2008-06-15 19:00:00+00:00,39.83,6.94,1037.0,915.51,136.0,352.62,2.04,341.0,91091.0 +2008-06-15 20:00:00+00:00,40.74,6.88,1031.0,914.13,136.0,351.35,2.28,317.0,91028.0 +2008-06-15 21:00:00+00:00,40.6,7.71,962.0,900.63,132.0,350.72,2.86,316.0,90977.0 +2008-06-15 22:00:00+00:00,40.46,8.53,836.0,871.8,125.0,350.08,3.44,314.0,90926.0 +2008-06-15 23:00:00+00:00,40.32,9.36,662.0,820.06,114.0,349.45,4.03,313.0,90875.0 +2008-06-16 00:00:00+00:00,38.66,9.84,457.0,731.76,98.0,346.87,3.94,317.0,90881.0 +2008-06-16 01:00:00+00:00,36.99,10.31,242.0,573.27,74.0,344.28,3.84,321.0,90887.0 +2008-06-16 02:00:00+00:00,35.33,10.79,53.0,233.7,32.0,341.7,3.75,325.0,90893.0 +2008-06-16 03:00:00+00:00,34.25,11.72,0.0,0.0,0.0,340.55,3.8,329.0,90944.0 +2008-06-16 04:00:00+00:00,33.17,12.64,0.0,0.0,0.0,339.4,3.84,332.0,90995.0 +2008-06-16 05:00:00+00:00,32.1,13.57,0.0,0.0,0.0,338.25,3.89,336.0,91046.0 +2008-06-16 06:00:00+00:00,30.94,14.62,0.0,0.0,0.0,335.78,3.58,340.0,91028.0 +2008-06-16 07:00:00+00:00,29.77,15.67,0.0,0.0,0.0,333.32,3.27,344.0,91010.0 +2008-06-16 08:00:00+00:00,28.61,16.72,0.0,0.0,0.0,330.85,2.97,347.0,90992.0 +2008-06-16 09:00:00+00:00,27.75,16.76,0.0,0.0,0.0,331.75,2.7,353.0,90986.0 +2008-06-16 10:00:00+00:00,26.89,16.81,0.0,0.0,0.0,332.65,2.44,360.0,90980.0 +2008-06-16 11:00:00+00:00,26.03,16.85,0.0,0.0,0.0,333.55,2.18,6.0,90974.0 +2008-06-16 12:00:00+00:00,28.12,15.58,0.0,0.0,0.0,336.02,1.82,354.0,91025.0 +2008-06-16 13:00:00+00:00,30.22,14.31,82.0,322.95,41.0,338.48,1.45,341.0,91076.0 +2008-06-16 14:00:00+00:00,32.32,13.04,281.0,611.83,79.0,340.95,1.09,329.0,91127.0 +2008-06-16 15:00:00+00:00,34.29,11.36,497.0,752.14,102.0,342.6,1.5,324.0,91100.0 +2008-06-16 16:00:00+00:00,36.26,9.67,696.0,828.68,117.0,344.25,1.92,319.0,91073.0 +2008-06-16 17:00:00+00:00,38.24,7.99,767.0,522.09,329.0,345.9,2.33,314.0,91046.0 +2008-06-16 18:00:00+00:00,39.07,8.2,974.0,898.22,133.0,349.57,2.74,308.0,90986.0 +2008-06-16 19:00:00+00:00,39.9,8.41,952.0,538.52,422.0,353.23,3.14,302.0,90926.0 +2008-06-16 20:00:00+00:00,40.73,8.62,940.0,520.78,430.0,356.9,3.54,296.0,90866.0 +2008-06-16 21:00:00+00:00,40.56,8.97,184.0,9.76,175.0,359.37,3.96,297.0,90830.0 +2008-06-16 22:00:00+00:00,40.39,9.32,159.0,6.13,154.0,361.83,4.38,298.0,90794.0 +2008-06-16 23:00:00+00:00,40.22,9.67,146.0,1.49,145.0,364.3,4.8,299.0,90758.0 +2008-06-17 00:00:00+00:00,38.68,10.52,119.0,0.0,119.0,359.53,4.57,302.0,90794.0 +2008-06-17 01:00:00+00:00,37.14,11.37,218.0,469.36,80.0,354.77,4.33,306.0,90830.0 +2008-06-17 02:00:00+00:00,35.61,12.22,53.0,231.11,32.0,350.0,4.1,309.0,90866.0 +2008-06-17 03:00:00+00:00,34.4,14.13,0.0,0.0,0.0,347.97,4.0,313.0,90926.0 +2008-06-17 04:00:00+00:00,33.19,16.03,0.0,0.0,0.0,345.93,3.91,317.0,90986.0 +2008-06-17 05:00:00+00:00,31.98,17.94,0.0,0.0,0.0,343.9,3.82,320.0,91046.0 +2008-06-17 06:00:00+00:00,30.88,18.61,0.0,0.0,0.0,342.53,3.62,324.0,91013.0 +2008-06-17 07:00:00+00:00,29.79,19.27,0.0,0.0,0.0,341.17,3.42,328.0,90980.0 +2008-06-17 08:00:00+00:00,28.69,19.94,0.0,0.0,0.0,339.8,3.21,331.0,90947.0 +2008-06-17 09:00:00+00:00,28.22,19.88,0.0,0.0,0.0,341.0,3.05,335.0,90947.0 +2008-06-17 10:00:00+00:00,27.75,19.82,0.0,0.0,0.0,342.2,2.89,339.0,90947.0 +2008-06-17 11:00:00+00:00,27.28,19.76,0.0,0.0,0.0,343.4,2.73,344.0,90947.0 +2008-06-17 12:00:00+00:00,29.02,19.42,0.0,0.0,0.0,339.55,2.57,346.0,91013.0 +2008-06-17 13:00:00+00:00,30.77,19.08,80.0,308.2,41.0,335.7,2.42,349.0,91079.0 +2008-06-17 14:00:00+00:00,32.52,18.74,276.0,597.52,79.0,331.85,2.26,351.0,91145.0 +2008-06-17 15:00:00+00:00,34.41,16.29,490.0,741.36,101.0,336.98,2.37,346.0,91115.0 +2008-06-17 16:00:00+00:00,36.3,13.85,689.0,820.56,116.0,342.12,2.48,341.0,91085.0 +2008-06-17 17:00:00+00:00,38.2,11.4,853.0,865.69,127.0,347.25,2.59,336.0,91055.0 +2008-06-17 18:00:00+00:00,39.15,10.59,968.0,891.96,133.0,349.7,2.98,322.0,91001.0 +2008-06-17 19:00:00+00:00,40.11,9.78,1025.0,903.29,136.0,352.15,3.37,308.0,90947.0 +2008-06-17 20:00:00+00:00,41.06,8.97,1019.0,901.49,136.0,354.6,3.75,295.0,90893.0 +2008-06-17 21:00:00+00:00,40.93,9.13,950.0,886.84,132.0,361.08,4.13,295.0,90863.0 +2008-06-17 22:00:00+00:00,40.8,9.29,480.0,110.2,390.0,367.57,4.51,296.0,90833.0 +2008-06-17 23:00:00+00:00,40.67,9.45,381.0,106.01,310.0,374.05,4.9,297.0,90803.0 +2008-06-18 00:00:00+00:00,39.2,10.53,216.0,44.69,194.0,366.77,4.74,300.0,90854.0 +2008-06-18 01:00:00+00:00,37.72,11.6,240.0,562.84,74.0,359.48,4.58,303.0,90905.0 +2008-06-18 02:00:00+00:00,36.25,12.68,54.0,239.62,32.0,352.2,4.43,306.0,90956.0 +2008-06-18 03:00:00+00:00,34.89,14.43,0.0,0.0,0.0,349.63,4.23,308.0,91025.0 +2008-06-18 04:00:00+00:00,33.54,16.19,0.0,0.0,0.0,347.07,4.03,310.0,91094.0 +2008-06-18 05:00:00+00:00,32.19,17.94,0.0,0.0,0.0,344.5,3.83,311.0,91163.0 +2008-06-18 06:00:00+00:00,31.09,19.07,0.0,0.0,0.0,341.47,3.58,314.0,91157.0 +2008-06-18 07:00:00+00:00,29.99,20.2,0.0,0.0,0.0,338.43,3.33,318.0,91151.0 +2008-06-18 08:00:00+00:00,28.89,21.33,0.0,0.0,0.0,335.4,3.08,321.0,91145.0 +2008-06-18 09:00:00+00:00,28.75,21.39,0.0,0.0,0.0,333.0,2.97,326.0,91157.0 +2008-06-18 10:00:00+00:00,28.62,21.46,0.0,0.0,0.0,330.6,2.86,331.0,91169.0 +2008-06-18 11:00:00+00:00,28.48,21.52,0.0,0.0,0.0,328.2,2.74,337.0,91181.0 +2008-06-18 12:00:00+00:00,29.91,20.58,0.0,0.0,0.0,330.42,2.8,339.0,91253.0 +2008-06-18 13:00:00+00:00,31.35,19.63,80.0,309.36,41.0,332.63,2.85,342.0,91325.0 +2008-06-18 14:00:00+00:00,32.79,18.69,276.0,598.45,79.0,334.85,2.9,345.0,91397.0 +2008-06-18 15:00:00+00:00,34.9,15.94,489.0,740.15,101.0,340.3,3.31,347.0,91367.0 +2008-06-18 16:00:00+00:00,37.01,13.2,688.0,818.21,117.0,345.75,3.71,350.0,91337.0 +2008-06-18 17:00:00+00:00,39.12,10.45,853.0,866.03,127.0,351.2,4.12,352.0,91307.0 +2008-06-18 18:00:00+00:00,39.96,10.02,970.0,893.2,134.0,355.85,4.16,341.0,91250.0 +2008-06-18 19:00:00+00:00,40.81,9.58,1028.0,905.33,137.0,360.5,4.19,330.0,91193.0 +2008-06-18 20:00:00+00:00,41.66,9.15,1024.0,905.41,137.0,365.15,4.22,320.0,91136.0 +2008-06-18 21:00:00+00:00,41.55,9.31,956.0,891.91,133.0,368.05,4.57,319.0,91085.0 +2008-06-18 22:00:00+00:00,41.45,9.46,832.0,863.85,126.0,370.95,4.92,318.0,91034.0 +2008-06-18 23:00:00+00:00,41.34,9.62,661.0,814.37,115.0,373.85,5.27,317.0,90983.0 +2008-06-19 00:00:00+00:00,39.81,10.6,458.0,728.07,99.0,370.47,4.91,318.0,90998.0 +2008-06-19 01:00:00+00:00,38.28,11.59,244.0,571.35,75.0,367.08,4.56,320.0,91013.0 +2008-06-19 02:00:00+00:00,36.75,12.57,55.0,237.33,33.0,363.7,4.21,321.0,91028.0 +2008-06-19 03:00:00+00:00,35.72,13.58,0.0,0.0,0.0,359.07,4.29,324.0,91088.0 +2008-06-19 04:00:00+00:00,34.69,14.59,0.0,0.0,0.0,354.43,4.36,328.0,91148.0 +2008-06-19 05:00:00+00:00,33.67,15.6,0.0,0.0,0.0,349.8,4.44,331.0,91208.0 +2008-06-19 06:00:00+00:00,32.73,16.72,0.0,0.0,0.0,346.9,4.27,334.0,91193.0 +2008-06-19 07:00:00+00:00,31.8,17.84,0.0,0.0,0.0,344.0,4.1,338.0,91178.0 +2008-06-19 08:00:00+00:00,30.86,18.96,0.0,0.0,0.0,341.1,3.93,341.0,91163.0 +2008-06-19 09:00:00+00:00,30.08,19.67,0.0,0.0,0.0,341.15,3.77,345.0,91157.0 +2008-06-19 10:00:00+00:00,29.3,20.39,0.0,0.0,0.0,341.2,3.6,349.0,91151.0 +2008-06-19 11:00:00+00:00,28.52,21.1,0.0,0.0,0.0,341.25,3.43,353.0,91145.0 +2008-06-19 12:00:00+00:00,30.17,19.57,0.0,0.0,0.0,341.5,3.16,348.0,91205.0 +2008-06-19 13:00:00+00:00,31.83,18.04,80.0,310.7,41.0,341.75,2.89,343.0,91265.0 +2008-06-19 14:00:00+00:00,33.49,16.51,276.0,599.48,79.0,342.0,2.62,338.0,91325.0 +2008-06-19 15:00:00+00:00,35.21,14.68,490.0,740.92,102.0,345.92,3.12,336.0,91292.0 +2008-06-19 16:00:00+00:00,36.94,12.84,691.0,823.06,117.0,349.83,3.62,333.0,91259.0 +2008-06-19 17:00:00+00:00,38.67,11.01,857.0,869.98,128.0,353.75,4.12,330.0,91226.0 +2008-06-19 18:00:00+00:00,39.4,10.36,974.0,897.67,134.0,354.78,4.37,319.0,91151.0 +2008-06-19 19:00:00+00:00,40.14,9.72,1033.0,909.42,138.0,355.82,4.61,308.0,91076.0 +2008-06-19 20:00:00+00:00,40.87,9.07,1029.0,910.37,137.0,356.85,4.86,297.0,91001.0 +2008-06-19 21:00:00+00:00,40.7,8.78,963.0,898.07,134.0,359.75,5.13,297.0,90938.0 +2008-06-19 22:00:00+00:00,40.54,8.48,839.0,870.63,127.0,362.65,5.4,298.0,90875.0 +2008-06-19 23:00:00+00:00,40.37,8.19,668.0,822.49,116.0,365.55,5.67,298.0,90812.0 +2008-06-20 00:00:00+00:00,38.77,8.55,464.0,737.09,100.0,360.32,5.0,300.0,90845.0 +2008-06-20 01:00:00+00:00,37.17,8.92,249.0,586.65,75.0,355.08,4.34,302.0,90878.0 +2008-06-20 02:00:00+00:00,35.58,9.28,57.0,256.63,33.0,349.85,3.67,305.0,90911.0 +2008-06-20 03:00:00+00:00,34.24,10.82,0.0,0.0,0.0,347.6,3.45,307.0,90959.0 +2008-06-20 04:00:00+00:00,32.9,12.35,0.0,0.0,0.0,345.35,3.23,309.0,91007.0 +2008-06-20 05:00:00+00:00,31.57,13.89,0.0,0.0,0.0,343.1,3.01,311.0,91055.0 +2008-06-20 06:00:00+00:00,30.72,14.48,0.0,0.0,0.0,339.97,2.8,311.0,91040.0 +2008-06-20 07:00:00+00:00,29.88,15.07,0.0,0.0,0.0,336.83,2.59,312.0,91025.0 +2008-06-20 08:00:00+00:00,29.03,15.66,0.0,0.0,0.0,333.7,2.39,312.0,91010.0 +2008-06-20 09:00:00+00:00,28.71,16.57,0.0,0.0,0.0,330.78,2.23,316.0,91007.0 +2008-06-20 10:00:00+00:00,28.38,17.48,0.0,0.0,0.0,327.87,2.07,320.0,91004.0 +2008-06-20 11:00:00+00:00,28.06,18.39,0.0,0.0,0.0,324.95,1.92,324.0,91001.0 +2008-06-20 12:00:00+00:00,29.46,17.25,0.0,0.0,0.0,325.33,1.78,319.0,91046.0 +2008-06-20 13:00:00+00:00,30.86,16.1,84.0,336.23,42.0,325.72,1.64,313.0,91091.0 +2008-06-20 14:00:00+00:00,32.26,14.96,287.0,628.06,81.0,326.1,1.5,307.0,91136.0 +2008-06-20 15:00:00+00:00,34.18,12.12,508.0,772.34,104.0,328.92,2.18,305.0,91118.0 +2008-06-20 16:00:00+00:00,36.11,9.28,714.0,853.79,119.0,331.73,2.86,304.0,91100.0 +2008-06-20 17:00:00+00:00,38.04,6.44,884.0,900.22,130.0,334.55,3.54,303.0,91082.0 +2008-06-20 18:00:00+00:00,38.84,5.71,1004.0,926.75,137.0,333.83,4.02,298.0,91019.0 +2008-06-20 19:00:00+00:00,39.64,4.99,1065.0,939.95,140.0,333.12,4.5,294.0,90956.0 +2008-06-20 20:00:00+00:00,40.44,4.26,1061.0,939.83,140.0,332.4,4.98,290.0,90893.0 +2008-06-20 21:00:00+00:00,40.33,4.13,993.0,928.08,136.0,332.05,5.07,292.0,90848.0 +2008-06-20 22:00:00+00:00,40.21,3.99,867.0,901.88,129.0,331.7,5.15,294.0,90803.0 +2008-06-20 23:00:00+00:00,40.1,3.86,692.0,854.46,118.0,331.35,5.24,297.0,90758.0 +2008-06-21 00:00:00+00:00,38.15,4.68,483.0,770.42,102.0,329.08,4.54,300.0,90767.0 +2008-06-21 01:00:00+00:00,36.2,5.49,260.0,615.43,77.0,326.82,3.84,304.0,90776.0 +2008-06-21 02:00:00+00:00,34.25,6.31,61.0,275.78,35.0,324.55,3.14,308.0,90785.0 +2008-06-21 03:00:00+00:00,32.88,7.53,0.0,0.0,0.0,322.95,3.04,308.0,90833.0 +2008-06-21 04:00:00+00:00,31.51,8.76,0.0,0.0,0.0,321.35,2.94,309.0,90881.0 +2008-06-21 05:00:00+00:00,30.14,9.98,0.0,0.0,0.0,319.75,2.84,310.0,90929.0 +2008-06-21 06:00:00+00:00,29.9,9.75,0.0,0.0,0.0,316.67,2.67,308.0,90917.0 +2008-06-21 07:00:00+00:00,29.65,9.51,0.0,0.0,0.0,313.58,2.5,306.0,90905.0 +2008-06-21 08:00:00+00:00,29.41,9.28,0.0,0.0,0.0,310.5,2.33,304.0,90893.0 +2008-06-21 09:00:00+00:00,29.48,9.49,0.0,0.0,0.0,308.32,2.06,304.0,90899.0 +2008-06-21 10:00:00+00:00,29.55,9.69,0.0,0.0,0.0,306.13,1.78,305.0,90905.0 +2008-06-21 11:00:00+00:00,29.62,9.9,0.0,0.0,0.0,303.95,1.5,305.0,90911.0 +2008-06-21 12:00:00+00:00,30.47,9.45,0.0,0.0,0.0,305.22,1.25,294.0,90974.0 +2008-06-21 13:00:00+00:00,31.33,9.01,84.0,329.99,43.0,306.48,0.99,282.0,91037.0 +2008-06-21 14:00:00+00:00,32.19,8.56,290.0,638.51,81.0,307.75,0.73,271.0,91100.0 +2008-06-21 15:00:00+00:00,34.36,7.12,513.0,780.92,105.0,311.65,0.85,292.0,91085.0 +2008-06-21 16:00:00+00:00,36.54,5.69,719.0,860.19,120.0,315.55,0.96,314.0,91070.0 +2008-06-21 17:00:00+00:00,38.72,4.25,887.0,903.05,131.0,319.45,1.08,335.0,91055.0 +2008-06-21 18:00:00+00:00,39.58,3.93,1006.0,929.13,137.0,320.12,1.08,318.0,91007.0 +2008-06-21 19:00:00+00:00,40.45,3.6,1064.0,938.99,140.0,320.78,1.09,302.0,90959.0 +2008-06-21 20:00:00+00:00,41.32,3.28,1058.0,936.65,140.0,321.45,1.09,285.0,90911.0 +2008-06-21 21:00:00+00:00,41.34,3.31,988.0,922.36,136.0,322.22,1.45,285.0,90863.0 +2008-06-21 22:00:00+00:00,41.35,3.33,861.0,894.03,129.0,322.98,1.81,284.0,90815.0 +2008-06-21 23:00:00+00:00,41.37,3.36,685.0,843.28,118.0,323.75,2.17,284.0,90767.0 +2008-06-22 00:00:00+00:00,39.42,3.98,481.0,783.54,93.0,324.07,1.56,249.0,90782.0 +2008-06-22 01:00:00+00:00,37.47,4.59,259.0,630.76,71.0,324.38,0.95,215.0,90797.0 +2008-06-22 02:00:00+00:00,35.52,5.21,61.0,294.82,33.0,324.7,0.34,181.0,90812.0 +2008-06-22 03:00:00+00:00,34.08,6.08,0.0,0.0,0.0,325.52,0.53,183.0,90884.0 +2008-06-22 04:00:00+00:00,32.65,6.94,0.0,0.0,0.0,326.33,0.72,184.0,90956.0 +2008-06-22 05:00:00+00:00,31.22,7.81,0.0,0.0,0.0,327.15,0.91,186.0,91028.0 +2008-06-22 06:00:00+00:00,30.91,9.01,0.0,0.0,0.0,324.42,0.9,172.0,91043.0 +2008-06-22 07:00:00+00:00,30.6,10.21,0.0,0.0,0.0,321.68,0.89,158.0,91058.0 +2008-06-22 08:00:00+00:00,30.29,11.41,0.0,0.0,0.0,318.95,0.88,144.0,91073.0 +2008-06-22 09:00:00+00:00,29.56,12.58,0.0,0.0,0.0,317.12,1.16,127.0,91100.0 +2008-06-22 10:00:00+00:00,28.82,13.74,0.0,0.0,0.0,315.28,1.43,111.0,91127.0 +2008-06-22 11:00:00+00:00,28.09,14.91,0.0,0.0,0.0,313.45,1.71,94.0,91154.0 +2008-06-22 12:00:00+00:00,29.58,12.69,0.0,0.0,0.0,315.47,1.57,89.0,91211.0 +2008-06-22 13:00:00+00:00,31.08,10.48,85.0,364.33,40.0,317.48,1.43,84.0,91268.0 +2008-06-22 14:00:00+00:00,32.58,8.26,290.0,658.3,75.0,319.5,1.3,80.0,91325.0 +2008-06-22 15:00:00+00:00,34.75,7.02,510.0,795.34,95.0,325.37,1.69,93.0,91304.0 +2008-06-22 16:00:00+00:00,36.92,5.78,713.0,868.09,109.0,331.23,2.08,107.0,91283.0 +2008-06-22 17:00:00+00:00,39.09,4.54,879.0,909.49,118.0,337.1,2.47,120.0,91262.0 +2008-06-22 18:00:00+00:00,39.9,4.37,996.0,932.61,124.0,342.38,2.07,127.0,91214.0 +2008-06-22 19:00:00+00:00,40.71,4.19,1054.0,942.12,127.0,347.67,1.68,134.0,91166.0 +2008-06-22 20:00:00+00:00,41.52,4.02,1048.0,939.61,127.0,352.95,1.28,140.0,91118.0 +2008-06-22 21:00:00+00:00,41.52,4.11,979.0,926.41,123.0,355.95,1.17,106.0,91073.0 +2008-06-22 22:00:00+00:00,41.52,4.19,783.0,637.2,261.0,358.95,1.06,73.0,91028.0 +2008-06-22 23:00:00+00:00,41.52,4.28,577.0,520.1,227.0,361.95,0.95,39.0,90983.0 +2008-06-23 00:00:00+00:00,39.81,4.92,409.0,504.23,159.0,369.68,1.28,56.0,91004.0 +2008-06-23 01:00:00+00:00,38.09,5.57,253.0,612.66,70.0,377.42,1.61,73.0,91025.0 +2008-06-23 02:00:00+00:00,36.38,6.21,59.0,282.43,32.0,385.15,1.94,90.0,91046.0 +2008-06-23 03:00:00+00:00,36.16,7.59,0.0,0.0,0.0,377.73,1.91,97.0,91100.0 +2008-06-23 04:00:00+00:00,35.94,8.97,0.0,0.0,0.0,370.32,1.88,104.0,91154.0 +2008-06-23 05:00:00+00:00,35.73,10.35,0.0,0.0,0.0,362.9,1.85,110.0,91208.0 +2008-06-23 06:00:00+00:00,33.62,11.92,0.0,0.0,0.0,355.82,1.88,113.0,91220.0 +2008-06-23 07:00:00+00:00,31.5,13.49,0.0,0.0,0.0,348.73,1.9,116.0,91232.0 +2008-06-23 08:00:00+00:00,29.39,15.06,0.0,0.0,0.0,341.65,1.93,119.0,91244.0 +2008-06-23 09:00:00+00:00,28.0,16.29,0.0,0.0,0.0,338.05,1.93,118.0,91259.0 +2008-06-23 10:00:00+00:00,26.62,17.51,0.0,0.0,0.0,334.45,1.93,116.0,91274.0 +2008-06-23 11:00:00+00:00,25.23,18.74,0.0,0.0,0.0,330.85,1.93,114.0,91289.0 +2008-06-23 12:00:00+00:00,27.28,17.71,0.0,0.0,0.0,332.67,1.74,104.0,91382.0 +2008-06-23 13:00:00+00:00,29.33,16.67,79.0,334.09,38.0,334.48,1.54,94.0,91476.0 +2008-06-23 14:00:00+00:00,31.39,15.64,276.0,623.04,73.0,336.3,1.35,84.0,91569.0 +2008-06-23 15:00:00+00:00,33.22,13.45,491.0,761.88,94.0,342.03,1.53,88.0,91521.0 +2008-06-23 16:00:00+00:00,35.05,11.27,691.0,838.63,108.0,347.77,1.7,93.0,91473.0 +2008-06-23 17:00:00+00:00,36.88,9.08,857.0,884.88,117.0,353.5,1.88,98.0,91425.0 +2008-06-23 18:00:00+00:00,37.83,8.4,975.0,911.5,123.0,353.95,1.68,82.0,91337.0 +2008-06-23 19:00:00+00:00,38.78,7.73,1034.0,922.91,126.0,354.4,1.49,66.0,91250.0 +2008-06-23 20:00:00+00:00,39.73,7.05,1030.0,922.19,126.0,354.85,1.3,50.0,91163.0 +2008-06-23 21:00:00+00:00,39.87,7.07,964.0,909.92,123.0,359.3,1.38,29.0,91088.0 +2008-06-23 22:00:00+00:00,40.0,7.09,841.0,884.56,116.0,363.75,1.47,7.0,91013.0 +2008-06-23 23:00:00+00:00,40.14,7.11,603.0,590.96,205.0,368.2,1.56,346.0,90938.0 +2008-06-24 00:00:00+00:00,38.57,8.68,423.0,602.38,124.0,365.1,1.74,332.0,90944.0 +2008-06-24 01:00:00+00:00,37.0,10.24,31.0,0.0,31.0,362.0,1.92,318.0,90950.0 +2008-06-24 02:00:00+00:00,35.43,11.81,7.0,0.0,7.0,358.9,2.1,305.0,90956.0 +2008-06-24 03:00:00+00:00,34.57,13.35,0.0,0.0,0.0,359.15,2.38,310.0,91004.0 +2008-06-24 04:00:00+00:00,33.71,14.88,0.0,0.0,0.0,359.4,2.67,316.0,91052.0 +2008-06-24 05:00:00+00:00,32.86,16.42,0.0,0.0,0.0,359.65,2.95,322.0,91100.0 +2008-06-24 06:00:00+00:00,31.89,16.73,0.0,0.0,0.0,356.73,3.01,326.0,91094.0 +2008-06-24 07:00:00+00:00,30.92,17.05,0.0,0.0,0.0,353.82,3.07,330.0,91088.0 +2008-06-24 08:00:00+00:00,29.95,17.36,0.0,0.0,0.0,350.9,3.13,334.0,91082.0 +2008-06-24 09:00:00+00:00,29.46,17.45,0.0,0.0,0.0,345.33,2.82,341.0,91085.0 +2008-06-24 10:00:00+00:00,28.96,17.55,0.0,0.0,0.0,339.77,2.51,348.0,91088.0 +2008-06-24 11:00:00+00:00,28.47,17.64,0.0,0.0,0.0,334.2,2.21,355.0,91091.0 +2008-06-24 12:00:00+00:00,29.94,17.27,0.0,0.0,0.0,336.47,1.85,318.0,91130.0 +2008-06-24 13:00:00+00:00,31.41,16.91,79.0,336.42,38.0,338.73,1.5,282.0,91169.0 +2008-06-24 14:00:00+00:00,32.89,16.54,276.0,624.62,73.0,341.0,1.14,246.0,91208.0 +2008-06-24 15:00:00+00:00,34.62,14.67,491.0,762.98,94.0,342.53,1.39,261.0,91184.0 +2008-06-24 16:00:00+00:00,36.35,12.81,693.0,842.27,108.0,344.07,1.64,276.0,91160.0 +2008-06-24 17:00:00+00:00,38.08,10.94,861.0,888.98,118.0,345.6,1.89,292.0,91136.0 +2008-06-24 18:00:00+00:00,38.95,10.13,980.0,916.08,124.0,346.78,2.45,283.0,91067.0 +2008-06-24 19:00:00+00:00,39.83,9.31,1041.0,929.12,127.0,347.97,3.01,274.0,90998.0 +2008-06-24 20:00:00+00:00,40.71,8.5,321.0,20.4,301.0,349.15,3.57,264.0,90929.0 +2008-06-24 21:00:00+00:00,40.56,8.52,974.0,919.42,124.0,352.52,3.92,266.0,90878.0 +2008-06-24 22:00:00+00:00,40.4,8.55,195.0,9.76,187.0,355.88,4.27,268.0,90827.0 +2008-06-24 23:00:00+00:00,40.25,8.57,649.0,755.22,140.0,359.25,4.62,270.0,90776.0 +2008-06-25 00:00:00+00:00,38.7,9.72,455.0,704.39,105.0,355.37,4.17,272.0,90812.0 +2008-06-25 01:00:00+00:00,37.14,10.86,252.0,607.04,70.0,351.48,3.73,273.0,90848.0 +2008-06-25 02:00:00+00:00,35.59,12.01,60.0,279.35,33.0,347.6,3.28,275.0,90884.0 +2008-06-25 03:00:00+00:00,34.19,13.85,0.0,0.0,0.0,343.93,3.06,276.0,90950.0 +2008-06-25 04:00:00+00:00,32.8,15.7,0.0,0.0,0.0,340.27,2.83,277.0,91016.0 +2008-06-25 05:00:00+00:00,31.41,17.54,0.0,0.0,0.0,336.6,2.61,277.0,91082.0 +2008-06-25 06:00:00+00:00,31.06,18.3,0.0,0.0,0.0,333.48,2.32,271.0,91085.0 +2008-06-25 07:00:00+00:00,30.7,19.05,0.0,0.0,0.0,330.37,2.03,265.0,91088.0 +2008-06-25 08:00:00+00:00,30.35,19.81,0.0,0.0,0.0,327.25,1.74,259.0,91091.0 +2008-06-25 09:00:00+00:00,29.01,21.28,0.0,0.0,0.0,325.3,1.54,249.0,91109.0 +2008-06-25 10:00:00+00:00,27.66,22.75,0.0,0.0,0.0,323.35,1.35,239.0,91127.0 +2008-06-25 11:00:00+00:00,26.32,24.22,0.0,0.0,0.0,321.4,1.16,229.0,91145.0 +2008-06-25 12:00:00+00:00,28.27,21.49,0.0,0.0,0.0,326.45,0.89,220.0,91202.0 +2008-06-25 13:00:00+00:00,30.22,18.75,78.0,330.68,38.0,331.5,0.63,210.0,91259.0 +2008-06-25 14:00:00+00:00,32.18,16.02,275.0,623.21,73.0,336.55,0.36,201.0,91316.0 +2008-06-25 15:00:00+00:00,33.82,13.91,490.0,762.21,94.0,346.18,0.56,200.0,91283.0 +2008-06-25 16:00:00+00:00,35.46,11.81,690.0,838.76,108.0,355.82,0.75,200.0,91250.0 +2008-06-25 17:00:00+00:00,37.11,9.7,856.0,883.54,118.0,365.45,0.95,200.0,91217.0 +2008-06-25 18:00:00+00:00,37.98,9.39,974.0,909.98,124.0,367.47,1.94,212.0,91154.0 +2008-06-25 19:00:00+00:00,38.86,9.08,1033.0,921.12,127.0,369.48,2.94,224.0,91091.0 +2008-06-25 20:00:00+00:00,39.73,8.77,1028.0,920.05,126.0,371.5,3.93,236.0,91028.0 +2008-06-25 21:00:00+00:00,39.61,9.12,960.0,905.15,123.0,370.55,4.0,242.0,90986.0 +2008-06-25 22:00:00+00:00,39.48,9.46,835.0,876.45,116.0,369.6,4.06,248.0,90944.0 +2008-06-25 23:00:00+00:00,39.36,9.81,663.0,825.88,106.0,368.65,4.12,254.0,90902.0 +2008-06-26 00:00:00+00:00,38.02,11.32,364.0,345.83,192.0,370.17,4.05,252.0,90920.0 +2008-06-26 01:00:00+00:00,36.68,12.84,247.0,589.44,70.0,371.68,3.98,250.0,90938.0 +2008-06-26 02:00:00+00:00,35.35,14.35,58.0,267.83,32.0,373.2,3.9,248.0,90956.0 +2008-06-26 03:00:00+00:00,34.04,15.56,0.0,0.0,0.0,368.38,3.69,248.0,91043.0 +2008-06-26 04:00:00+00:00,32.73,16.77,0.0,0.0,0.0,363.57,3.47,248.0,91130.0 +2008-06-26 05:00:00+00:00,31.42,17.98,0.0,0.0,0.0,358.75,3.26,248.0,91217.0 +2008-06-26 06:00:00+00:00,30.39,19.33,0.0,0.0,0.0,353.67,2.76,243.0,91235.0 +2008-06-26 07:00:00+00:00,29.35,20.68,0.0,0.0,0.0,348.58,2.26,238.0,91253.0 +2008-06-26 08:00:00+00:00,28.32,22.03,0.0,0.0,0.0,343.5,1.77,233.0,91271.0 +2008-06-26 09:00:00+00:00,27.26,23.43,0.0,0.0,0.0,342.95,1.49,220.0,91289.0 +2008-06-26 10:00:00+00:00,26.21,24.82,0.0,0.0,0.0,342.4,1.21,208.0,91307.0 +2008-06-26 11:00:00+00:00,25.15,26.22,0.0,0.0,0.0,341.85,0.94,195.0,91325.0 +2008-06-26 12:00:00+00:00,26.92,25.1,0.0,0.0,0.0,343.0,0.88,197.0,91358.0 +2008-06-26 13:00:00+00:00,28.69,23.97,1.0,0.0,1.0,344.15,0.82,198.0,91391.0 +2008-06-26 14:00:00+00:00,30.46,22.85,196.0,232.05,121.0,345.3,0.76,200.0,91425.0 +2008-06-26 15:00:00+00:00,31.94,19.66,469.0,713.3,99.0,350.77,1.07,213.0,91410.0 +2008-06-26 16:00:00+00:00,33.42,16.47,674.0,817.96,107.0,356.23,1.37,226.0,91394.0 +2008-06-26 17:00:00+00:00,34.91,13.28,838.0,863.73,117.0,361.7,1.68,238.0,91379.0 +2008-06-26 18:00:00+00:00,35.72,12.49,883.0,525.84,392.0,365.65,2.23,237.0,91313.0 +2008-06-26 19:00:00+00:00,36.53,11.7,652.0,171.85,483.0,369.6,2.77,236.0,91247.0 +2008-06-26 20:00:00+00:00,37.34,10.91,1012.0,903.71,126.0,373.55,3.31,235.0,91181.0 +2008-06-26 21:00:00+00:00,37.06,11.28,775.0,391.4,413.0,375.97,3.42,236.0,91145.0 +2008-06-26 22:00:00+00:00,36.79,11.66,25.0,0.0,25.0,378.38,3.53,238.0,91109.0 +2008-06-26 23:00:00+00:00,36.51,12.03,67.0,0.0,67.0,380.8,3.64,239.0,91073.0 +2008-06-27 00:00:00+00:00,35.53,13.67,10.0,0.0,10.0,375.35,3.36,239.0,91067.0 +2008-06-27 01:00:00+00:00,34.55,15.31,10.0,0.0,10.0,369.9,3.08,240.0,91061.0 +2008-06-27 02:00:00+00:00,33.58,16.95,2.0,0.0,2.0,364.45,2.8,240.0,91055.0 +2008-06-27 03:00:00+00:00,32.48,17.09,0.0,0.0,0.0,360.43,2.71,242.0,91112.0 +2008-06-27 04:00:00+00:00,31.38,17.22,0.0,0.0,0.0,356.42,2.63,244.0,91169.0 +2008-06-27 05:00:00+00:00,30.29,17.36,0.0,0.0,0.0,352.4,2.54,246.0,91226.0 +2008-06-27 06:00:00+00:00,29.72,17.64,0.0,0.0,0.0,350.18,2.23,244.0,91223.0 +2008-06-27 07:00:00+00:00,29.14,17.92,0.0,0.0,0.0,347.97,1.93,242.0,91220.0 +2008-06-27 08:00:00+00:00,28.57,18.2,0.0,0.0,0.0,345.75,1.63,240.0,91217.0 +2008-06-27 09:00:00+00:00,27.41,18.72,0.0,0.0,0.0,342.85,1.32,230.0,91232.0 +2008-06-27 10:00:00+00:00,26.26,19.24,0.0,0.0,0.0,339.95,1.02,221.0,91247.0 +2008-06-27 11:00:00+00:00,25.1,19.76,0.0,0.0,0.0,337.05,0.72,211.0,91262.0 +2008-06-27 12:00:00+00:00,26.71,19.14,0.0,0.0,0.0,340.27,0.69,213.0,91292.0 +2008-06-27 13:00:00+00:00,28.33,18.52,70.0,268.97,38.0,343.48,0.66,215.0,91322.0 +2008-06-27 14:00:00+00:00,29.95,17.9,255.0,527.55,85.0,346.7,0.63,217.0,91352.0 +2008-06-27 15:00:00+00:00,31.55,17.22,394.0,390.07,192.0,352.23,0.99,222.0,91316.0 +2008-06-27 16:00:00+00:00,33.15,16.53,586.0,514.1,230.0,357.77,1.35,227.0,91280.0 +2008-06-27 17:00:00+00:00,34.75,15.85,844.0,871.5,117.0,363.3,1.71,232.0,91244.0 +2008-06-27 18:00:00+00:00,35.57,15.61,961.0,896.74,124.0,365.17,2.37,237.0,91157.0 +2008-06-27 19:00:00+00:00,36.4,15.36,881.0,409.87,478.0,367.03,3.03,241.0,91070.0 +2008-06-27 20:00:00+00:00,37.22,15.12,497.0,48.96,449.0,368.9,3.7,246.0,90983.0 +2008-06-27 21:00:00+00:00,36.95,14.53,144.0,4.32,140.0,371.93,3.75,247.0,90941.0 +2008-06-27 22:00:00+00:00,36.67,13.95,102.0,0.0,102.0,374.97,3.81,248.0,90899.0 +2008-06-27 23:00:00+00:00,36.4,13.36,19.0,0.0,19.0,378.0,3.86,249.0,90857.0 +2008-06-28 00:00:00+00:00,35.05,14.05,22.0,0.0,22.0,370.65,3.31,247.0,90863.0 +2008-06-28 01:00:00+00:00,33.69,14.73,73.0,0.0,73.0,363.3,2.76,245.0,90869.0 +2008-06-28 02:00:00+00:00,32.34,15.42,17.0,0.0,17.0,355.95,2.21,242.0,90875.0 +2008-06-28 03:00:00+00:00,31.39,15.78,0.0,0.0,0.0,352.45,2.17,237.0,90920.0 +2008-06-28 04:00:00+00:00,30.45,16.13,0.0,0.0,0.0,348.95,2.14,232.0,90965.0 +2008-06-28 05:00:00+00:00,29.51,16.49,0.0,0.0,0.0,345.45,2.11,226.0,91010.0 +2008-06-28 06:00:00+00:00,29.01,17.82,0.0,0.0,0.0,343.95,1.99,225.0,91016.0 +2008-06-28 07:00:00+00:00,28.5,19.15,0.0,0.0,0.0,342.45,1.86,225.0,91022.0 +2008-06-28 08:00:00+00:00,28.0,20.48,0.0,0.0,0.0,340.95,1.74,224.0,91028.0 +2008-06-28 09:00:00+00:00,27.25,20.84,0.0,0.0,0.0,339.08,1.51,225.0,91049.0 +2008-06-28 10:00:00+00:00,26.5,21.21,0.0,0.0,0.0,337.22,1.29,226.0,91070.0 +2008-06-28 11:00:00+00:00,25.75,21.57,0.0,0.0,0.0,335.35,1.06,227.0,91091.0 +2008-06-28 12:00:00+00:00,26.53,22.52,0.0,0.0,0.0,335.37,1.07,215.0,91169.0 +2008-06-28 13:00:00+00:00,27.31,23.48,74.0,313.83,37.0,335.38,1.08,203.0,91247.0 +2008-06-28 14:00:00+00:00,28.1,24.43,267.0,603.92,73.0,335.4,1.09,191.0,91325.0 +2008-06-28 15:00:00+00:00,30.03,21.34,479.0,744.74,94.0,341.67,1.3,220.0,91301.0 +2008-06-28 16:00:00+00:00,31.96,18.26,677.0,822.58,108.0,347.93,1.5,248.0,91277.0 +2008-06-28 17:00:00+00:00,33.9,15.17,842.0,868.5,118.0,354.2,1.71,276.0,91253.0 +2008-06-28 18:00:00+00:00,34.91,14.31,959.0,894.97,124.0,358.52,2.13,280.0,91187.0 +2008-06-28 19:00:00+00:00,35.92,13.46,1019.0,907.38,127.0,362.83,2.56,284.0,91121.0 +2008-06-28 20:00:00+00:00,36.93,12.6,921.0,473.28,457.0,367.15,2.98,288.0,91055.0 +2008-06-28 21:00:00+00:00,36.96,12.41,132.0,2.16,130.0,369.83,3.23,288.0,91016.0 +2008-06-28 22:00:00+00:00,36.98,12.21,76.0,0.0,76.0,372.52,3.48,287.0,90977.0 +2008-06-28 23:00:00+00:00,37.01,12.02,52.0,0.0,52.0,375.2,3.72,287.0,90938.0 +2008-06-29 00:00:00+00:00,35.94,13.02,89.0,0.0,89.0,371.92,3.48,284.0,90947.0 +2008-06-29 01:00:00+00:00,34.87,14.01,26.0,0.0,26.0,368.63,3.24,281.0,90956.0 +2008-06-29 02:00:00+00:00,33.8,15.01,6.0,0.0,6.0,365.35,2.99,278.0,90965.0 +2008-06-29 03:00:00+00:00,32.41,16.75,0.0,0.0,0.0,359.65,2.97,280.0,91037.0 +2008-06-29 04:00:00+00:00,31.03,18.5,0.0,0.0,0.0,353.95,2.94,282.0,91109.0 +2008-06-29 05:00:00+00:00,29.65,20.24,0.0,0.0,0.0,348.25,2.91,284.0,91181.0 +2008-06-29 06:00:00+00:00,29.17,22.45,0.0,0.0,0.0,343.1,2.69,284.0,91181.0 +2008-06-29 07:00:00+00:00,28.68,24.67,0.0,0.0,0.0,337.95,2.46,284.0,91181.0 +2008-06-29 08:00:00+00:00,28.2,26.88,0.0,0.0,0.0,332.8,2.23,284.0,91181.0 +2008-06-29 09:00:00+00:00,27.6,27.57,0.0,0.0,0.0,331.63,2.12,286.0,91199.0 +2008-06-29 10:00:00+00:00,26.99,28.26,0.0,0.0,0.0,330.47,2.0,287.0,91217.0 +2008-06-29 11:00:00+00:00,26.39,28.95,0.0,0.0,0.0,329.3,1.89,289.0,91235.0 +2008-06-29 12:00:00+00:00,27.24,25.51,0.0,0.0,0.0,332.97,1.83,289.0,91307.0 +2008-06-29 13:00:00+00:00,28.09,22.07,73.0,308.3,37.0,336.63,1.77,290.0,91379.0 +2008-06-29 14:00:00+00:00,28.95,18.63,163.0,118.68,125.0,340.3,1.71,291.0,91452.0 +2008-06-29 15:00:00+00:00,31.19,16.61,479.0,746.09,94.0,342.23,2.62,301.0,91425.0 +2008-06-29 16:00:00+00:00,33.43,14.58,678.0,824.95,108.0,344.17,3.52,312.0,91397.0 +2008-06-29 17:00:00+00:00,35.68,12.56,843.0,870.32,118.0,346.1,4.43,322.0,91370.0 +2008-06-29 18:00:00+00:00,36.43,12.34,960.0,896.43,124.0,349.52,4.14,324.0,91304.0 +2008-06-29 19:00:00+00:00,37.18,12.11,1019.0,907.58,127.0,352.93,3.86,326.0,91238.0 +2008-06-29 20:00:00+00:00,37.93,11.89,1016.0,906.81,127.0,356.35,3.57,328.0,91172.0 +2008-06-29 21:00:00+00:00,37.9,11.96,950.0,892.67,124.0,359.88,3.68,328.0,91127.0 +2008-06-29 22:00:00+00:00,37.86,12.02,831.0,869.19,117.0,363.42,3.78,327.0,91082.0 +2008-06-29 23:00:00+00:00,37.83,12.09,664.0,824.13,107.0,366.95,3.89,327.0,91037.0 +2008-06-30 00:00:00+00:00,36.47,13.13,464.0,743.9,93.0,360.52,3.62,325.0,91025.0 +2008-06-30 01:00:00+00:00,35.11,14.17,252.0,600.22,71.0,354.08,3.35,323.0,91013.0 +2008-06-30 02:00:00+00:00,33.76,15.21,49.0,152.98,34.0,347.65,3.08,321.0,91001.0 +2008-06-30 03:00:00+00:00,32.9,16.78,0.0,0.0,0.0,344.43,3.12,319.0,91049.0 +2008-06-30 04:00:00+00:00,32.05,18.35,0.0,0.0,0.0,341.22,3.17,318.0,91097.0 +2008-06-30 05:00:00+00:00,31.2,19.92,0.0,0.0,0.0,338.0,3.21,316.0,91145.0 +2008-06-30 06:00:00+00:00,30.29,21.66,0.0,0.0,0.0,337.08,3.07,324.0,91148.0 +2008-06-30 07:00:00+00:00,29.37,23.39,0.0,0.0,0.0,336.17,2.92,332.0,91151.0 +2008-06-30 08:00:00+00:00,28.46,25.13,0.0,0.0,0.0,335.25,2.77,339.0,91154.0 +2008-06-30 09:00:00+00:00,27.86,25.48,0.0,0.0,0.0,335.07,2.69,357.0,91181.0 +2008-06-30 10:00:00+00:00,27.26,25.82,0.0,0.0,0.0,334.88,2.62,14.0,91208.0 +2008-06-30 11:00:00+00:00,26.66,26.17,0.0,0.0,0.0,334.7,2.54,31.0,91235.0 +2008-06-30 12:00:00+00:00,28.43,24.91,0.0,0.0,0.0,337.25,2.41,40.0,91298.0 +2008-06-30 13:00:00+00:00,30.2,23.64,71.0,294.15,37.0,339.8,2.29,49.0,91361.0 +2008-06-30 14:00:00+00:00,31.98,22.38,264.0,598.58,73.0,342.35,2.17,58.0,91425.0 +2008-06-30 15:00:00+00:00,33.66,19.73,366.0,308.7,207.0,347.57,2.84,68.0,91403.0 +2008-06-30 16:00:00+00:00,39.35,10.61,675.0,821.57,108.0,365.06,4.02,78.0,91382.0 +2008-06-30 17:00:00+00:00,38.8,11.38,841.0,868.56,118.0,364.58,3.92,88.0,91361.0 +2008-06-30 18:00:00+00:00,38.25,12.14,959.0,895.76,124.0,364.09,3.83,83.0,91304.0 +2008-06-30 19:00:00+00:00,37.7,12.91,762.0,266.64,500.0,363.61,3.74,78.0,91247.0 +2008-06-30 20:00:00+00:00,37.16,13.67,1016.0,906.87,127.0,363.12,3.65,73.0,91190.0 +2008-06-30 21:00:00+00:00,36.61,14.44,950.0,892.59,124.0,362.63,3.56,73.0,91151.0 +2008-06-30 22:00:00+00:00,36.06,15.2,828.0,865.34,117.0,362.15,3.47,72.0,91112.0 +2008-06-30 23:00:00+00:00,35.51,15.97,659.0,816.43,107.0,361.66,3.37,71.0,91073.0 +2014-07-01 00:00:00+00:00,34.97,16.73,476.0,773.65,90.0,361.17,3.28,271.0,90725.0 +2014-07-01 01:00:00+00:00,34.42,17.5,258.0,626.41,69.0,360.69,3.19,270.0,90719.0 +2014-07-01 02:00:00+00:00,33.87,18.27,62.0,295.57,33.0,360.2,3.1,269.0,90713.0 +2014-07-01 03:00:00+00:00,33.32,19.03,0.0,0.0,0.0,359.72,3.01,266.0,90773.0 +2014-07-01 04:00:00+00:00,32.77,19.8,0.0,0.0,0.0,359.23,2.92,263.0,90833.0 +2014-07-01 05:00:00+00:00,32.23,20.56,0.0,0.0,0.0,358.74,2.82,260.0,90893.0 +2014-07-01 06:00:00+00:00,31.68,21.33,0.0,0.0,0.0,358.26,2.73,250.0,90917.0 +2014-07-01 07:00:00+00:00,31.13,22.09,0.0,0.0,0.0,357.77,2.64,241.0,90941.0 +2014-07-01 08:00:00+00:00,27.54,27.54,0.0,0.0,0.0,344.55,2.73,231.0,90965.0 +2014-07-01 09:00:00+00:00,26.69,28.33,0.0,0.0,0.0,341.43,2.68,229.0,90992.0 +2014-07-01 10:00:00+00:00,25.83,29.12,0.0,0.0,0.0,338.32,2.62,228.0,91019.0 +2014-07-01 11:00:00+00:00,24.98,29.91,0.0,0.0,0.0,335.2,2.57,226.0,91046.0 +2014-07-01 12:00:00+00:00,27.04,27.53,0.0,0.0,0.0,339.67,2.73,227.0,91064.0 +2014-07-01 13:00:00+00:00,29.1,25.14,74.0,332.3,36.0,344.13,2.9,228.0,91082.0 +2014-07-01 14:00:00+00:00,31.15,22.76,272.0,632.16,71.0,348.6,3.06,229.0,91100.0 +2014-07-01 15:00:00+00:00,32.9,20.12,487.0,770.33,91.0,354.07,3.09,244.0,91073.0 +2014-07-01 16:00:00+00:00,34.65,17.47,688.0,847.21,104.0,359.53,3.13,258.0,91046.0 +2014-07-01 17:00:00+00:00,36.39,14.83,854.0,890.87,113.0,365.0,3.16,273.0,91019.0 +2014-07-01 18:00:00+00:00,37.43,14.06,973.0,916.58,119.0,368.6,3.26,277.0,90947.0 +2014-07-01 19:00:00+00:00,38.46,13.28,1034.0,928.38,122.0,372.2,3.37,281.0,90875.0 +2014-07-01 20:00:00+00:00,39.49,12.51,1032.0,928.37,122.0,375.8,3.48,284.0,90803.0 +2014-07-01 21:00:00+00:00,39.35,12.64,967.0,916.3,119.0,378.5,3.55,286.0,90761.0 +2014-07-01 22:00:00+00:00,39.21,12.76,845.0,890.72,113.0,381.2,3.62,288.0,90719.0 +2014-07-01 23:00:00+00:00,39.08,12.89,674.0,844.27,103.0,383.9,3.7,290.0,90677.0 +2014-07-02 00:00:00+00:00,37.82,13.22,471.0,763.39,90.0,388.73,3.3,284.0,90698.0 +2014-07-02 01:00:00+00:00,36.56,13.55,255.0,616.28,69.0,393.57,2.91,277.0,90719.0 +2014-07-02 02:00:00+00:00,35.3,13.88,61.0,285.41,33.0,398.4,2.51,270.0,90740.0 +2014-07-02 03:00:00+00:00,34.0,15.64,0.0,0.0,0.0,393.52,2.24,261.0,90806.0 +2014-07-02 04:00:00+00:00,32.71,17.39,0.0,0.0,0.0,388.63,1.98,251.0,90872.0 +2014-07-02 05:00:00+00:00,31.41,19.15,0.0,0.0,0.0,383.75,1.71,242.0,90938.0 +2014-07-02 06:00:00+00:00,30.44,20.44,0.0,0.0,0.0,375.23,1.49,242.0,90968.0 +2014-07-02 07:00:00+00:00,29.48,21.72,0.0,0.0,0.0,366.72,1.28,242.0,90998.0 +2014-07-02 08:00:00+00:00,28.51,23.01,0.0,0.0,0.0,358.2,1.06,242.0,91028.0 +2014-07-02 09:00:00+00:00,27.84,24.02,0.0,0.0,0.0,353.87,1.63,245.0,91061.0 +2014-07-02 10:00:00+00:00,27.17,25.02,0.0,0.0,0.0,349.53,2.19,249.0,91094.0 +2014-07-02 11:00:00+00:00,26.5,26.03,0.0,0.0,0.0,345.2,2.76,252.0,91127.0 +2014-07-02 12:00:00+00:00,27.59,26.43,0.0,0.0,0.0,346.7,2.83,255.0,91184.0 +2014-07-02 13:00:00+00:00,28.69,26.84,70.0,309.53,35.0,348.2,2.91,259.0,91241.0 +2014-07-02 14:00:00+00:00,29.78,27.24,265.0,615.57,70.0,349.7,2.98,262.0,91298.0 +2014-07-02 15:00:00+00:00,31.82,23.74,479.0,758.23,90.0,355.63,3.05,296.0,91265.0 +2014-07-02 16:00:00+00:00,33.85,20.25,678.0,833.73,104.0,361.57,3.12,330.0,91232.0 +2014-07-02 17:00:00+00:00,35.88,16.75,844.0,879.54,113.0,367.5,3.19,4.0,91199.0 +2014-07-02 18:00:00+00:00,36.95,15.58,962.0,905.22,119.0,370.85,3.17,18.0,91127.0 +2014-07-02 19:00:00+00:00,38.01,14.4,1022.0,916.42,122.0,374.2,3.15,33.0,91055.0 +2014-07-02 20:00:00+00:00,39.07,13.23,1019.0,915.2,122.0,377.55,3.13,48.0,90983.0 +2014-07-02 21:00:00+00:00,39.02,13.19,953.0,901.15,119.0,378.92,3.6,43.0,90938.0 +2014-07-02 22:00:00+00:00,38.97,13.16,832.0,874.77,113.0,380.28,4.06,38.0,90893.0 +2014-07-02 23:00:00+00:00,38.92,13.12,663.0,827.8,103.0,381.65,4.52,33.0,90848.0 +2014-07-03 00:00:00+00:00,37.75,14.08,462.0,747.21,89.0,382.48,4.08,75.0,90848.0 +2014-07-03 01:00:00+00:00,36.59,15.04,249.0,599.65,68.0,383.32,3.64,117.0,90848.0 +2014-07-03 02:00:00+00:00,35.42,16.0,59.0,275.46,32.0,384.15,3.2,159.0,90848.0 +2014-07-03 03:00:00+00:00,34.36,18.15,0.0,0.0,0.0,386.85,3.02,167.0,90935.0 +2014-07-03 04:00:00+00:00,33.3,20.3,0.0,0.0,0.0,389.55,2.84,176.0,91022.0 +2014-07-03 05:00:00+00:00,32.24,22.45,0.0,0.0,0.0,392.25,2.66,184.0,91109.0 +2014-07-03 06:00:00+00:00,31.57,24.31,0.0,0.0,0.0,391.92,3.04,181.0,91148.0 +2014-07-03 07:00:00+00:00,30.9,26.17,0.0,0.0,0.0,391.58,3.43,177.0,91187.0 +2014-07-03 08:00:00+00:00,30.23,28.03,0.0,0.0,0.0,391.25,3.81,173.0,91226.0 +2014-07-03 09:00:00+00:00,29.26,32.04,0.0,0.0,0.0,381.88,3.0,115.0,91262.0 +2014-07-03 10:00:00+00:00,28.3,36.05,0.0,0.0,0.0,372.52,2.2,57.0,91298.0 +2014-07-03 11:00:00+00:00,27.33,40.06,0.0,0.0,0.0,363.15,1.39,358.0,91334.0 +2014-07-03 12:00:00+00:00,28.25,40.44,0.0,0.0,0.0,363.5,1.36,16.0,91376.0 +2014-07-03 13:00:00+00:00,29.17,40.81,66.0,286.37,34.0,363.85,1.32,34.0,91419.0 +2014-07-03 14:00:00+00:00,30.09,41.19,255.0,589.41,69.0,364.2,1.28,51.0,91461.0 +2014-07-03 15:00:00+00:00,31.65,37.28,376.0,349.62,197.0,370.12,1.98,64.0,91437.0 +2014-07-03 16:00:00+00:00,33.21,33.38,549.0,386.86,283.0,376.03,2.67,78.0,91413.0 +2014-07-03 17:00:00+00:00,34.77,29.47,684.0,400.99,351.0,381.95,3.37,91.0,91388.0 +2014-07-03 18:00:00+00:00,35.35,26.81,807.0,417.92,418.0,386.0,3.02,95.0,91319.0 +2014-07-03 19:00:00+00:00,35.92,24.16,1010.0,904.46,122.0,390.05,2.68,99.0,91250.0 +2014-07-03 20:00:00+00:00,36.49,21.5,1008.0,904.09,122.0,394.1,2.33,103.0,91181.0 +2014-07-03 21:00:00+00:00,35.67,21.84,943.0,890.34,119.0,394.22,2.22,122.0,91145.0 +2014-07-03 22:00:00+00:00,34.85,22.17,426.0,60.83,376.0,394.33,2.1,142.0,91109.0 +2014-07-03 23:00:00+00:00,34.04,22.51,212.0,10.35,205.0,394.45,1.99,162.0,91073.0 +2014-07-04 00:00:00+00:00,33.16,24.18,140.0,0.0,140.0,394.98,1.49,178.0,91085.0 +2014-07-04 01:00:00+00:00,32.29,25.85,77.0,0.0,77.0,395.52,1.0,195.0,91097.0 +2014-07-04 02:00:00+00:00,31.42,27.52,30.0,0.0,30.0,396.05,0.51,211.0,91109.0 +2014-07-04 03:00:00+00:00,30.84,33.87,0.0,0.0,0.0,393.67,0.55,225.0,91226.0 +2014-07-04 04:00:00+00:00,30.27,40.21,0.0,0.0,0.0,391.28,0.58,238.0,91343.0 +2014-07-04 05:00:00+00:00,29.69,46.56,0.0,0.0,0.0,388.9,0.62,251.0,91461.0 +2014-07-04 06:00:00+00:00,29.29,50.9,0.0,0.0,0.0,388.37,0.89,253.0,91476.0 +2014-07-04 07:00:00+00:00,28.88,55.25,0.0,0.0,0.0,387.83,1.16,255.0,91491.0 +2014-07-04 08:00:00+00:00,28.48,59.59,0.0,0.0,0.0,387.3,1.43,257.0,91506.0 +2014-07-04 09:00:00+00:00,27.96,61.61,0.0,0.0,0.0,387.28,1.33,265.0,91515.0 +2014-07-04 10:00:00+00:00,27.45,63.64,0.0,0.0,0.0,387.27,1.22,273.0,91524.0 +2014-07-04 11:00:00+00:00,26.93,65.66,0.0,0.0,0.0,387.25,1.12,282.0,91533.0 +2014-07-04 12:00:00+00:00,26.35,63.0,0.0,0.0,0.0,386.47,1.07,335.0,91587.0 +2014-07-04 13:00:00+00:00,25.77,60.34,46.0,81.55,37.0,385.68,1.02,29.0,91641.0 +2014-07-04 14:00:00+00:00,25.18,57.68,193.0,251.34,114.0,384.9,0.97,82.0,91695.0 +2014-07-04 15:00:00+00:00,26.84,51.94,202.0,27.4,188.0,385.1,1.47,88.0,91659.0 +2014-07-04 16:00:00+00:00,28.5,46.21,521.0,323.29,299.0,385.3,1.98,93.0,91623.0 +2014-07-04 17:00:00+00:00,30.16,40.47,530.0,143.42,411.0,385.5,2.48,99.0,91587.0 +2014-07-04 18:00:00+00:00,30.69,39.0,745.0,318.18,449.0,388.23,2.72,115.0,91569.0 +2014-07-04 19:00:00+00:00,31.22,37.53,805.0,350.49,461.0,390.97,2.95,130.0,91551.0 +2014-07-04 20:00:00+00:00,31.75,36.06,991.0,887.9,121.0,393.7,3.19,146.0,91533.0 +2014-07-04 21:00:00+00:00,31.87,36.42,927.0,874.16,118.0,393.22,2.92,160.0,91500.0 +2014-07-04 22:00:00+00:00,31.99,36.77,676.0,397.78,349.0,392.73,2.66,174.0,91467.0 +2014-07-04 23:00:00+00:00,32.11,37.13,49.0,0.0,49.0,392.25,2.4,188.0,91434.0 +2014-07-05 00:00:00+00:00,31.58,36.54,166.0,8.01,162.0,389.58,2.43,220.0,91437.0 +2014-07-05 01:00:00+00:00,31.06,35.94,122.0,36.46,111.0,386.92,2.46,252.0,91440.0 +2014-07-05 02:00:00+00:00,30.54,35.35,9.0,0.0,9.0,384.25,2.48,284.0,91443.0 +2014-07-05 03:00:00+00:00,30.18,39.18,0.0,0.0,0.0,387.8,2.31,298.0,91494.0 +2014-07-05 04:00:00+00:00,29.81,43.01,0.0,0.0,0.0,391.35,2.13,312.0,91545.0 +2014-07-05 05:00:00+00:00,29.45,46.84,0.0,0.0,0.0,394.9,1.96,327.0,91596.0 +2014-07-05 06:00:00+00:00,29.08,49.51,0.0,0.0,0.0,392.5,1.67,333.0,91587.0 +2014-07-05 07:00:00+00:00,28.71,52.19,0.0,0.0,0.0,390.1,1.38,339.0,91578.0 +2014-07-05 08:00:00+00:00,28.34,54.86,0.0,0.0,0.0,387.7,1.09,346.0,91569.0 +2014-07-05 09:00:00+00:00,27.74,56.46,0.0,0.0,0.0,386.83,1.24,348.0,91566.0 +2014-07-05 10:00:00+00:00,27.13,58.06,0.0,0.0,0.0,385.97,1.38,350.0,91563.0 +2014-07-05 11:00:00+00:00,26.53,59.66,0.0,0.0,0.0,385.1,1.53,352.0,91560.0 +2014-07-05 12:00:00+00:00,26.82,63.27,0.0,0.0,0.0,383.37,1.14,346.0,91650.0 +2014-07-05 13:00:00+00:00,27.12,66.87,28.0,0.0,28.0,381.63,0.75,340.0,91740.0 +2014-07-05 14:00:00+00:00,27.41,70.48,10.0,0.0,10.0,379.9,0.36,333.0,91830.0 +2014-07-05 15:00:00+00:00,28.58,63.39,300.0,154.97,221.0,382.95,1.21,348.0,91776.0 +2014-07-05 16:00:00+00:00,29.75,56.29,445.0,179.36,322.0,386.0,2.07,3.0,91722.0 +2014-07-05 17:00:00+00:00,30.92,49.2,145.0,4.82,141.0,389.05,2.92,17.0,91668.0 +2014-07-05 18:00:00+00:00,30.85,48.43,932.0,874.4,119.0,389.78,3.09,354.0,91629.0 +2014-07-05 19:00:00+00:00,30.78,47.67,993.0,887.72,122.0,390.52,3.26,331.0,91590.0 +2014-07-05 20:00:00+00:00,30.71,46.9,992.0,888.05,122.0,391.25,3.42,308.0,91551.0 +2014-07-05 21:00:00+00:00,30.67,46.92,476.0,68.08,413.0,391.77,2.52,308.0,91521.0 +2014-07-05 22:00:00+00:00,30.63,46.94,624.0,281.0,393.0,392.28,1.62,308.0,91491.0 +2014-07-05 23:00:00+00:00,30.59,46.96,432.0,166.99,319.0,392.8,0.72,309.0,91461.0 +2014-07-06 00:00:00+00:00,30.16,48.38,109.0,0.0,109.0,389.02,0.91,296.0,91440.0 +2014-07-06 01:00:00+00:00,29.74,49.79,4.0,0.0,4.0,385.23,1.09,284.0,91419.0 +2014-07-06 02:00:00+00:00,29.32,51.21,2.0,0.0,2.0,381.45,1.28,272.0,91397.0 +2014-07-06 03:00:00+00:00,28.86,55.38,0.0,0.0,0.0,381.0,1.53,279.0,91431.0 +2014-07-06 04:00:00+00:00,28.41,59.56,0.0,0.0,0.0,380.55,1.78,286.0,91464.0 +2014-07-06 05:00:00+00:00,27.95,63.73,0.0,0.0,0.0,380.1,2.03,293.0,91497.0 +2014-07-06 06:00:00+00:00,27.58,67.25,0.0,0.0,0.0,379.12,1.65,298.0,91479.0 +2014-07-06 07:00:00+00:00,27.21,70.78,0.0,0.0,0.0,378.13,1.26,303.0,91461.0 +2014-07-06 08:00:00+00:00,26.84,74.3,0.0,0.0,0.0,377.15,0.88,308.0,91443.0 +2014-07-06 09:00:00+00:00,26.31,76.26,0.0,0.0,0.0,376.22,0.83,316.0,91437.0 +2014-07-06 10:00:00+00:00,25.79,78.22,0.0,0.0,0.0,375.28,0.77,323.0,91431.0 +2014-07-06 11:00:00+00:00,25.26,80.18,0.0,0.0,0.0,374.35,0.72,331.0,91425.0 +2014-07-06 12:00:00+00:00,26.09,73.94,0.0,0.0,0.0,371.17,0.62,8.0,91470.0 +2014-07-06 13:00:00+00:00,26.92,67.71,61.0,260.51,33.0,367.98,0.52,45.0,91515.0 +2014-07-06 14:00:00+00:00,27.74,61.47,247.0,571.04,69.0,364.8,0.43,82.0,91560.0 +2014-07-06 15:00:00+00:00,29.24,53.87,454.0,715.64,90.0,372.3,1.1,129.0,91503.0 +2014-07-06 16:00:00+00:00,30.73,46.28,650.0,798.73,103.0,379.8,1.78,176.0,91446.0 +2014-07-06 17:00:00+00:00,32.22,38.68,814.0,846.31,113.0,387.3,2.46,224.0,91388.0 +2014-07-06 18:00:00+00:00,32.47,36.78,930.0,872.74,119.0,387.75,2.72,231.0,91331.0 +2014-07-06 19:00:00+00:00,32.72,34.88,675.0,166.19,512.0,388.2,2.98,238.0,91274.0 +2014-07-06 20:00:00+00:00,32.96,32.98,885.0,545.19,351.0,388.65,3.24,246.0,91217.0 +2014-07-06 21:00:00+00:00,32.96,33.44,652.0,241.0,429.0,387.4,2.48,252.0,91193.0 +2014-07-06 22:00:00+00:00,32.96,33.89,24.0,0.0,24.0,386.15,1.72,259.0,91169.0 +2014-07-06 23:00:00+00:00,32.96,34.35,516.0,328.07,294.0,384.9,0.97,266.0,91145.0 +2014-07-07 00:00:00+00:00,32.31,38.06,446.0,715.42,89.0,384.63,1.17,251.0,91133.0 +2014-07-07 01:00:00+00:00,31.67,41.76,238.0,564.27,68.0,384.37,1.38,237.0,91121.0 +2014-07-07 02:00:00+00:00,31.02,45.47,55.0,247.7,31.0,384.1,1.59,222.0,91109.0 +2014-07-07 03:00:00+00:00,30.5,48.35,0.0,0.0,0.0,384.37,1.62,229.0,91142.0 +2014-07-07 04:00:00+00:00,29.99,51.22,0.0,0.0,0.0,384.63,1.65,236.0,91175.0 +2014-07-07 05:00:00+00:00,29.47,54.1,0.0,0.0,0.0,384.9,1.68,244.0,91208.0 +2014-07-07 06:00:00+00:00,29.18,56.5,0.0,0.0,0.0,381.68,1.55,238.0,91187.0 +2014-07-07 07:00:00+00:00,28.88,58.91,0.0,0.0,0.0,378.47,1.42,233.0,91166.0 +2014-07-07 08:00:00+00:00,28.59,61.31,0.0,0.0,0.0,375.25,1.28,227.0,91145.0 +2014-07-07 09:00:00+00:00,28.15,62.71,0.0,0.0,0.0,372.58,1.56,246.0,91148.0 +2014-07-07 10:00:00+00:00,27.71,64.11,0.0,0.0,0.0,369.92,1.83,264.0,91151.0 +2014-07-07 11:00:00+00:00,27.27,65.51,0.0,0.0,0.0,367.25,2.11,283.0,91154.0 +2014-07-07 12:00:00+00:00,27.81,63.65,0.0,0.0,0.0,369.3,1.6,265.0,91202.0 +2014-07-07 13:00:00+00:00,28.36,61.78,40.0,47.18,35.0,371.35,1.1,246.0,91250.0 +2014-07-07 14:00:00+00:00,28.9,59.92,245.0,567.09,69.0,373.4,0.59,228.0,91298.0 +2014-07-07 15:00:00+00:00,28.69,58.14,414.0,516.29,152.0,376.47,0.97,252.0,91313.0 +2014-07-07 16:00:00+00:00,28.47,56.37,276.0,26.32,258.0,379.53,1.34,276.0,91328.0 +2014-07-07 17:00:00+00:00,28.25,54.59,728.0,478.52,332.0,382.6,1.71,301.0,91343.0 +2014-07-07 18:00:00+00:00,28.22,53.87,748.0,330.57,441.0,383.35,2.0,303.0,91313.0 +2014-07-07 19:00:00+00:00,28.19,53.16,650.0,142.79,510.0,384.1,2.3,306.0,91283.0 +2014-07-07 20:00:00+00:00,28.15,52.44,880.0,414.6,474.0,384.85,2.59,308.0,91253.0 +2014-07-07 21:00:00+00:00,28.05,53.48,143.0,4.32,139.0,386.22,2.73,310.0,91247.0 +2014-07-07 22:00:00+00:00,27.95,54.53,115.0,0.0,115.0,387.58,2.86,312.0,91241.0 +2014-07-07 23:00:00+00:00,27.86,55.57,171.0,5.91,167.0,388.95,2.99,313.0,91235.0 +2014-07-08 00:00:00+00:00,27.46,57.35,174.0,14.03,167.0,388.18,2.4,269.0,91229.0 +2014-07-08 01:00:00+00:00,27.07,59.13,87.0,0.0,87.0,387.42,1.81,225.0,91223.0 +2014-07-08 02:00:00+00:00,26.68,60.91,16.0,0.0,16.0,386.65,1.21,181.0,91217.0 +2014-07-08 03:00:00+00:00,26.54,65.14,0.0,0.0,0.0,386.8,1.5,175.0,91250.0 +2014-07-08 04:00:00+00:00,26.39,69.37,0.0,0.0,0.0,386.95,1.79,170.0,91283.0 +2014-07-08 05:00:00+00:00,26.25,73.6,0.0,0.0,0.0,387.1,2.08,164.0,91316.0 +2014-07-08 06:00:00+00:00,25.91,75.97,0.0,0.0,0.0,386.47,2.11,163.0,91295.0 +2014-07-08 07:00:00+00:00,25.56,78.34,0.0,0.0,0.0,385.83,2.13,163.0,91274.0 +2014-07-08 08:00:00+00:00,25.22,80.71,0.0,0.0,0.0,385.2,2.15,162.0,91253.0 +2014-07-08 09:00:00+00:00,24.82,82.28,0.0,0.0,0.0,386.97,1.84,157.0,91265.0 +2014-07-08 10:00:00+00:00,24.42,83.86,0.0,0.0,0.0,388.73,1.54,153.0,91277.0 +2014-07-08 11:00:00+00:00,24.02,85.43,0.0,0.0,0.0,390.5,1.23,149.0,91289.0 +2014-07-08 12:00:00+00:00,24.85,81.37,0.0,0.0,0.0,388.08,1.22,91.0,91355.0 +2014-07-08 13:00:00+00:00,25.69,77.3,42.0,67.04,35.0,385.67,1.22,33.0,91422.0 +2014-07-08 14:00:00+00:00,26.52,73.24,200.0,304.24,106.0,383.25,1.21,335.0,91488.0 +2014-07-08 15:00:00+00:00,27.06,66.17,421.0,557.01,139.0,381.2,1.53,345.0,91464.0 +2014-07-08 16:00:00+00:00,27.6,59.1,587.0,525.71,228.0,379.15,1.85,356.0,91440.0 +2014-07-08 17:00:00+00:00,28.13,52.03,816.0,849.08,114.0,377.1,2.17,6.0,91416.0 +2014-07-08 18:00:00+00:00,28.82,50.36,935.0,878.1,120.0,378.02,2.38,357.0,91394.0 +2014-07-08 19:00:00+00:00,29.5,48.68,896.0,432.62,472.0,378.93,2.6,349.0,91373.0 +2014-07-08 20:00:00+00:00,30.18,47.01,997.0,892.74,123.0,379.85,2.81,340.0,91352.0 +2014-07-08 21:00:00+00:00,29.63,49.81,936.0,882.11,120.0,383.77,2.55,329.0,91352.0 +2014-07-08 22:00:00+00:00,29.08,52.61,817.0,855.37,114.0,387.68,2.28,318.0,91352.0 +2014-07-08 23:00:00+00:00,28.54,55.41,38.0,0.0,38.0,391.6,2.01,307.0,91352.0 +2014-07-09 00:00:00+00:00,28.33,54.93,99.0,0.0,99.0,387.27,1.8,288.0,91298.0 +2014-07-09 01:00:00+00:00,28.13,54.46,40.0,0.0,40.0,382.93,1.58,268.0,91244.0 +2014-07-09 02:00:00+00:00,27.92,53.98,6.0,0.0,6.0,378.6,1.37,249.0,91190.0 +2014-07-09 03:00:00+00:00,27.48,59.59,0.0,0.0,0.0,377.13,1.47,258.0,91241.0 +2014-07-09 04:00:00+00:00,27.05,65.21,0.0,0.0,0.0,375.67,1.58,267.0,91292.0 +2014-07-09 05:00:00+00:00,26.61,70.82,0.0,0.0,0.0,374.2,1.68,276.0,91343.0 +2014-07-09 06:00:00+00:00,26.22,73.85,0.0,0.0,0.0,372.6,1.44,278.0,91325.0 +2014-07-09 07:00:00+00:00,25.83,76.87,0.0,0.0,0.0,371.0,1.2,280.0,91307.0 +2014-07-09 08:00:00+00:00,25.44,79.9,0.0,0.0,0.0,369.4,0.95,282.0,91289.0 +2014-07-09 09:00:00+00:00,24.81,82.9,0.0,0.0,0.0,366.37,1.3,295.0,91286.0 +2014-07-09 10:00:00+00:00,24.19,85.91,0.0,0.0,0.0,363.33,1.65,308.0,91283.0 +2014-07-09 11:00:00+00:00,23.56,88.91,0.0,0.0,0.0,360.3,2.0,320.0,91280.0 +2014-07-09 12:00:00+00:00,24.28,84.48,0.0,0.0,0.0,358.7,1.55,332.0,91349.0 +2014-07-09 13:00:00+00:00,25.01,80.04,24.0,0.0,24.0,357.1,1.1,344.0,91419.0 +2014-07-09 14:00:00+00:00,25.73,75.61,68.0,0.0,68.0,355.5,0.65,356.0,91488.0 +2014-07-09 15:00:00+00:00,27.58,67.42,154.0,3.96,152.0,360.52,1.19,8.0,91455.0 +2014-07-09 16:00:00+00:00,29.43,59.23,309.0,41.06,281.0,365.53,1.73,20.0,91422.0 +2014-07-09 17:00:00+00:00,31.28,51.04,710.0,456.42,333.0,370.55,2.28,32.0,91388.0 +2014-07-09 18:00:00+00:00,31.71,50.56,831.0,443.1,420.0,375.1,2.37,77.0,91331.0 +2014-07-09 19:00:00+00:00,32.13,50.07,913.0,462.41,460.0,379.65,2.46,121.0,91274.0 +2014-07-09 20:00:00+00:00,32.55,49.59,988.0,883.79,123.0,384.2,2.55,166.0,91217.0 +2014-07-09 21:00:00+00:00,32.04,50.31,926.0,871.48,120.0,388.0,2.74,201.0,91190.0 +2014-07-09 22:00:00+00:00,31.53,51.03,476.0,96.14,397.0,391.8,2.94,235.0,91163.0 +2014-07-09 23:00:00+00:00,31.03,51.75,643.0,796.98,104.0,395.6,3.13,270.0,91136.0 +2014-07-10 00:00:00+00:00,30.12,53.73,446.0,714.52,90.0,389.28,2.55,268.0,91139.0 +2014-07-10 01:00:00+00:00,29.22,55.7,222.0,459.83,84.0,382.97,1.97,265.0,91142.0 +2014-07-10 02:00:00+00:00,28.31,57.68,3.0,0.0,3.0,376.65,1.39,263.0,91145.0 +2014-07-10 03:00:00+00:00,27.61,62.76,0.0,0.0,0.0,374.2,1.34,262.0,91187.0 +2014-07-10 04:00:00+00:00,26.92,67.84,0.0,0.0,0.0,371.75,1.28,261.0,91229.0 +2014-07-10 05:00:00+00:00,26.22,72.92,0.0,0.0,0.0,369.3,1.23,260.0,91271.0 +2014-07-10 06:00:00+00:00,25.73,76.74,0.0,0.0,0.0,365.62,1.26,263.0,91262.0 +2014-07-10 07:00:00+00:00,25.25,80.55,0.0,0.0,0.0,361.93,1.3,267.0,91253.0 +2014-07-10 08:00:00+00:00,24.76,84.37,0.0,0.0,0.0,358.25,1.34,270.0,91244.0 +2014-07-10 09:00:00+00:00,24.48,86.82,0.0,0.0,0.0,361.42,1.24,276.0,91256.0 +2014-07-10 10:00:00+00:00,24.21,89.28,0.0,0.0,0.0,364.58,1.14,282.0,91268.0 +2014-07-10 11:00:00+00:00,23.93,91.73,0.0,0.0,0.0,367.75,1.03,288.0,91280.0 +2014-07-10 12:00:00+00:00,24.6,85.69,0.0,0.0,0.0,376.38,0.85,282.0,91310.0 +2014-07-10 13:00:00+00:00,25.28,79.64,56.0,237.15,32.0,385.02,0.66,276.0,91340.0 +2014-07-10 14:00:00+00:00,25.95,73.6,199.0,310.36,104.0,393.65,0.47,269.0,91370.0 +2014-07-10 15:00:00+00:00,26.66,70.24,449.0,712.57,90.0,390.05,0.87,279.0,91364.0 +2014-07-10 16:00:00+00:00,27.37,66.88,332.0,55.81,294.0,386.45,1.27,289.0,91358.0 +2014-07-10 17:00:00+00:00,28.08,63.52,809.0,842.23,114.0,382.85,1.67,298.0,91352.0 +2014-07-10 18:00:00+00:00,27.93,65.68,927.0,870.59,120.0,382.32,2.16,299.0,91331.0 +2014-07-10 19:00:00+00:00,27.78,67.85,988.0,883.35,123.0,381.78,2.64,299.0,91310.0 +2014-07-10 20:00:00+00:00,27.62,70.01,987.0,883.04,123.0,381.25,3.13,299.0,91289.0 +2014-07-10 21:00:00+00:00,27.99,68.78,925.0,870.6,120.0,383.25,3.14,299.0,91259.0 +2014-07-10 22:00:00+00:00,28.35,67.54,806.0,842.34,114.0,385.25,3.14,299.0,91229.0 +2014-07-10 23:00:00+00:00,28.72,66.31,642.0,795.77,104.0,387.25,3.14,299.0,91199.0 +2014-07-11 00:00:00+00:00,28.19,69.94,429.0,638.75,111.0,385.88,2.41,297.0,91187.0 +2014-07-11 01:00:00+00:00,27.67,73.57,156.0,130.18,117.0,384.52,1.68,295.0,91175.0 +2014-07-11 02:00:00+00:00,27.15,77.2,26.0,0.0,26.0,383.15,0.95,293.0,91163.0 +2014-07-11 03:00:00+00:00,26.93,79.67,0.0,0.0,0.0,382.52,0.88,296.0,91202.0 +2014-07-11 04:00:00+00:00,26.7,82.13,0.0,0.0,0.0,381.88,0.8,298.0,91241.0 +2014-07-11 05:00:00+00:00,26.48,84.6,0.0,0.0,0.0,381.25,0.73,301.0,91280.0 +2014-07-11 06:00:00+00:00,26.22,86.62,0.0,0.0,0.0,378.38,0.85,304.0,91265.0 +2014-07-11 07:00:00+00:00,25.97,88.63,0.0,0.0,0.0,375.52,0.96,308.0,91250.0 +2014-07-11 08:00:00+00:00,25.71,90.65,0.0,0.0,0.0,372.65,1.08,311.0,91235.0 +2014-07-11 09:00:00+00:00,25.17,91.79,0.0,0.0,0.0,370.2,1.19,314.0,91238.0 +2014-07-11 10:00:00+00:00,24.63,92.94,0.0,0.0,0.0,367.75,1.31,318.0,91241.0 +2014-07-11 11:00:00+00:00,24.09,94.08,0.0,0.0,0.0,365.3,1.42,322.0,91244.0 +2014-07-11 12:00:00+00:00,25.33,84.23,0.0,0.0,0.0,366.68,1.31,319.0,91283.0 +2014-07-11 13:00:00+00:00,26.57,74.38,44.0,110.51,33.0,368.07,1.21,316.0,91322.0 +2014-07-11 14:00:00+00:00,27.8,64.53,166.0,160.86,117.0,369.45,1.1,313.0,91361.0 +2014-07-11 15:00:00+00:00,28.98,53.82,272.0,111.43,216.0,374.33,1.35,324.0,91340.0 +2014-07-11 16:00:00+00:00,30.15,43.1,645.0,794.32,105.0,379.22,1.59,336.0,91319.0 +2014-07-11 17:00:00+00:00,31.32,32.39,810.0,844.28,114.0,384.1,1.83,347.0,91298.0 +2014-07-11 18:00:00+00:00,31.27,31.45,929.0,872.25,121.0,382.77,2.46,334.0,91280.0 +2014-07-11 19:00:00+00:00,31.21,30.51,990.0,884.77,124.0,381.43,3.09,322.0,91262.0 +2014-07-11 20:00:00+00:00,31.15,29.57,989.0,884.35,124.0,380.1,3.72,309.0,91244.0 +2014-07-11 21:00:00+00:00,31.3,28.14,926.0,870.84,121.0,377.47,3.89,308.0,91214.0 +2014-07-11 22:00:00+00:00,31.45,26.71,808.0,845.02,114.0,374.83,4.05,307.0,91184.0 +2014-07-11 23:00:00+00:00,31.6,25.28,642.0,796.1,104.0,372.2,4.21,306.0,91154.0 +2014-07-12 00:00:00+00:00,31.02,27.63,103.0,0.0,103.0,377.87,3.67,305.0,91136.0 +2014-07-12 01:00:00+00:00,30.44,29.99,68.0,0.0,68.0,383.53,3.13,304.0,91118.0 +2014-07-12 02:00:00+00:00,29.86,32.34,16.0,0.0,16.0,389.2,2.59,304.0,91100.0 +2014-07-12 03:00:00+00:00,29.68,32.98,0.0,0.0,0.0,392.12,2.02,307.0,91139.0 +2014-07-12 04:00:00+00:00,29.5,33.61,0.0,0.0,0.0,395.03,1.45,311.0,91178.0 +2014-07-12 05:00:00+00:00,29.32,34.25,0.0,0.0,0.0,397.95,0.88,314.0,91217.0 +2014-07-12 06:00:00+00:00,29.25,33.49,0.0,0.0,0.0,390.27,0.94,323.0,91199.0 +2014-07-12 07:00:00+00:00,29.17,32.74,0.0,0.0,0.0,382.58,0.99,332.0,91181.0 +2014-07-12 08:00:00+00:00,29.1,31.98,0.0,0.0,0.0,374.9,1.05,341.0,91163.0 +2014-07-12 09:00:00+00:00,28.58,31.08,0.0,0.0,0.0,372.83,1.09,358.0,91169.0 +2014-07-12 10:00:00+00:00,28.05,30.18,0.0,0.0,0.0,370.77,1.14,16.0,91175.0 +2014-07-12 11:00:00+00:00,27.53,29.28,0.0,0.0,0.0,368.7,1.19,33.0,91181.0 +2014-07-12 12:00:00+00:00,27.59,30.9,0.0,0.0,0.0,363.48,0.97,41.0,91265.0 +2014-07-12 13:00:00+00:00,27.65,32.51,55.0,245.32,31.0,358.27,0.74,49.0,91349.0 +2014-07-12 14:00:00+00:00,27.7,34.13,239.0,560.84,69.0,353.05,0.52,57.0,91434.0 +2014-07-12 15:00:00+00:00,29.63,29.36,449.0,716.19,90.0,356.77,1.1,68.0,91397.0 +2014-07-12 16:00:00+00:00,31.56,24.59,647.0,798.51,105.0,360.48,1.68,79.0,91361.0 +2014-07-12 17:00:00+00:00,33.48,19.82,812.0,846.35,115.0,364.2,2.26,90.0,91325.0 +2014-07-12 18:00:00+00:00,33.32,19.73,931.0,875.01,121.0,367.32,2.71,94.0,91286.0 +2014-07-12 19:00:00+00:00,33.16,19.63,809.0,362.87,454.0,370.43,3.16,98.0,91247.0 +2014-07-12 20:00:00+00:00,32.99,19.54,991.0,886.71,124.0,373.55,3.61,102.0,91208.0 +2014-07-12 21:00:00+00:00,32.85,20.6,928.0,873.27,121.0,372.88,3.25,80.0,91205.0 +2014-07-12 22:00:00+00:00,32.71,21.67,808.0,844.1,115.0,372.22,2.89,57.0,91202.0 +2014-07-12 23:00:00+00:00,32.58,22.73,241.0,16.29,230.0,371.55,2.52,35.0,91199.0 +2014-07-13 00:00:00+00:00,32.02,23.86,414.0,555.46,138.0,370.65,2.04,20.0,91184.0 +2014-07-13 01:00:00+00:00,31.47,24.99,177.0,221.26,111.0,369.75,1.55,5.0,91169.0 +2014-07-13 02:00:00+00:00,30.91,26.12,32.0,21.55,30.0,368.85,1.06,351.0,91154.0 +2014-07-13 03:00:00+00:00,30.71,28.92,0.0,0.0,0.0,369.15,1.29,11.0,91184.0 +2014-07-13 04:00:00+00:00,30.51,31.71,0.0,0.0,0.0,369.45,1.52,31.0,91214.0 +2014-07-13 05:00:00+00:00,30.31,34.51,0.0,0.0,0.0,369.75,1.75,51.0,91244.0 +2014-07-13 06:00:00+00:00,29.42,37.36,0.0,0.0,0.0,368.25,1.7,58.0,91247.0 +2014-07-13 07:00:00+00:00,28.54,40.2,0.0,0.0,0.0,366.75,1.65,65.0,91250.0 +2014-07-13 08:00:00+00:00,27.65,43.05,0.0,0.0,0.0,365.25,1.6,72.0,91253.0 +2014-07-13 09:00:00+00:00,26.63,45.07,0.0,0.0,0.0,362.32,1.42,69.0,91259.0 +2014-07-13 10:00:00+00:00,25.62,47.08,0.0,0.0,0.0,359.38,1.24,67.0,91265.0 +2014-07-13 11:00:00+00:00,24.6,49.1,0.0,0.0,0.0,356.45,1.06,65.0,91271.0 +2014-07-13 12:00:00+00:00,25.64,45.82,0.0,0.0,0.0,357.25,1.37,70.0,91319.0 +2014-07-13 13:00:00+00:00,26.68,42.54,44.0,124.87,32.0,358.05,1.68,76.0,91367.0 +2014-07-13 14:00:00+00:00,27.71,39.26,170.0,185.69,114.0,358.85,1.99,81.0,91416.0 +2014-07-13 15:00:00+00:00,28.67,36.52,445.0,710.07,90.0,363.3,2.7,89.0,91406.0 +2014-07-13 16:00:00+00:00,29.62,33.77,642.0,792.39,105.0,367.75,3.42,97.0,91397.0 +2014-07-13 17:00:00+00:00,30.57,31.03,807.0,841.15,115.0,372.2,4.14,104.0,91388.0 +2014-07-13 18:00:00+00:00,30.81,33.79,926.0,870.22,121.0,374.97,3.96,104.0,91385.0 +2014-07-13 19:00:00+00:00,31.05,36.56,987.0,882.58,124.0,377.73,3.79,104.0,91382.0 +2014-07-13 20:00:00+00:00,31.29,39.32,986.0,881.94,124.0,380.5,3.61,104.0,91379.0 +2014-07-13 21:00:00+00:00,30.9,40.7,559.0,103.92,463.0,382.93,3.32,110.0,91346.0 +2014-07-13 22:00:00+00:00,30.51,42.07,805.0,842.0,114.0,385.37,3.03,116.0,91313.0 +2014-07-13 23:00:00+00:00,30.12,43.45,501.0,297.75,300.0,387.8,2.73,122.0,91280.0 +2014-07-14 00:00:00+00:00,28.89,44.3,379.0,400.96,180.0,389.8,3.55,140.0,91286.0 +2014-07-14 01:00:00+00:00,27.67,45.15,46.0,0.0,46.0,391.8,4.37,158.0,91292.0 +2014-07-14 02:00:00+00:00,26.45,46.0,2.0,0.0,2.0,393.8,5.19,177.0,91298.0 +2014-07-14 03:00:00+00:00,26.24,50.13,0.0,0.0,0.0,393.15,3.92,169.0,91355.0 +2014-07-14 04:00:00+00:00,26.02,54.25,0.0,0.0,0.0,392.5,2.65,161.0,91413.0 +2014-07-14 05:00:00+00:00,25.81,58.38,0.0,0.0,0.0,391.85,1.38,152.0,91470.0 +2014-07-14 06:00:00+00:00,25.52,63.28,0.0,0.0,0.0,391.95,1.28,141.0,91476.0 +2014-07-14 07:00:00+00:00,25.24,68.18,0.0,0.0,0.0,392.05,1.18,130.0,91482.0 +2014-07-14 08:00:00+00:00,24.95,73.08,0.0,0.0,0.0,392.15,1.08,118.0,91488.0 +2014-07-14 09:00:00+00:00,24.44,76.67,0.0,0.0,0.0,391.6,1.12,113.0,91500.0 +2014-07-14 10:00:00+00:00,23.92,80.25,0.0,0.0,0.0,391.05,1.17,107.0,91512.0 +2014-07-14 11:00:00+00:00,23.41,83.84,0.0,0.0,0.0,390.5,1.21,102.0,91524.0 +2014-07-14 12:00:00+00:00,23.56,77.3,0.0,0.0,0.0,388.4,1.35,102.0,91569.0 +2014-07-14 13:00:00+00:00,23.71,70.76,8.0,0.0,8.0,386.3,1.48,102.0,91614.0 +2014-07-14 14:00:00+00:00,23.86,64.22,70.0,0.0,70.0,384.2,1.61,102.0,91659.0 +2014-07-14 15:00:00+00:00,25.14,59.82,445.0,711.96,90.0,381.27,1.47,116.0,91629.0 +2014-07-14 16:00:00+00:00,26.42,55.43,643.0,795.15,105.0,378.33,1.33,131.0,91599.0 +2014-07-14 17:00:00+00:00,27.69,51.03,809.0,844.47,115.0,375.4,1.19,145.0,91569.0 +2014-07-14 18:00:00+00:00,27.68,50.37,928.0,873.01,121.0,376.3,1.33,152.0,91542.0 +2014-07-14 19:00:00+00:00,27.67,49.7,989.0,885.09,124.0,377.2,1.47,158.0,91515.0 +2014-07-14 20:00:00+00:00,27.66,49.04,849.0,400.21,458.0,378.1,1.61,165.0,91488.0 +2014-07-14 21:00:00+00:00,27.5,56.15,632.0,171.1,474.0,376.9,1.95,173.0,91509.0 +2014-07-14 22:00:00+00:00,27.34,63.27,209.0,10.97,200.0,375.7,2.29,181.0,91530.0 +2014-07-14 23:00:00+00:00,27.19,70.38,627.0,672.98,173.0,374.5,2.63,189.0,91551.0 +2014-07-15 00:00:00+00:00,27.63,69.34,398.0,476.14,162.0,377.73,2.23,149.0,91503.0 +2014-07-15 01:00:00+00:00,28.08,68.29,150.0,117.96,115.0,380.97,1.82,110.0,91455.0 +2014-07-15 02:00:00+00:00,28.52,67.25,34.0,44.06,30.0,384.2,1.41,70.0,91406.0 +2014-07-15 03:00:00+00:00,28.39,67.58,0.0,0.0,0.0,380.07,1.35,84.0,91425.0 +2014-07-15 04:00:00+00:00,28.26,67.91,0.0,0.0,0.0,375.93,1.3,98.0,91443.0 +2014-07-15 05:00:00+00:00,28.13,68.24,0.0,0.0,0.0,371.8,1.24,111.0,91461.0 +2014-07-15 06:00:00+00:00,27.51,72.65,0.0,0.0,0.0,365.88,1.19,132.0,91464.0 +2014-07-15 07:00:00+00:00,26.89,77.05,0.0,0.0,0.0,359.97,1.13,153.0,91467.0 +2014-07-15 08:00:00+00:00,26.27,81.46,0.0,0.0,0.0,354.05,1.08,174.0,91470.0 +2014-07-15 09:00:00+00:00,25.25,83.75,0.0,0.0,0.0,354.77,1.18,170.0,91473.0 +2014-07-15 10:00:00+00:00,24.23,86.03,0.0,0.0,0.0,355.48,1.29,167.0,91476.0 +2014-07-15 11:00:00+00:00,23.21,88.32,0.0,0.0,0.0,356.2,1.39,163.0,91479.0 +2014-07-15 12:00:00+00:00,23.88,83.88,0.0,0.0,0.0,356.2,1.25,146.0,91557.0 +2014-07-15 13:00:00+00:00,24.55,79.45,50.0,216.16,30.0,356.2,1.11,129.0,91635.0 +2014-07-15 14:00:00+00:00,25.22,75.01,233.0,552.88,68.0,356.2,0.97,112.0,91713.0 +2014-07-15 15:00:00+00:00,26.02,74.18,297.0,166.91,214.0,361.47,1.47,96.0,91719.0 +2014-07-15 16:00:00+00:00,26.82,73.35,480.0,256.11,307.0,366.73,1.97,81.0,91725.0 +2014-07-15 17:00:00+00:00,27.62,72.52,200.0,9.75,192.0,372.0,2.47,65.0,91731.0 +2014-07-15 18:00:00+00:00,27.59,71.47,109.0,0.0,109.0,374.47,2.39,48.0,91698.0 +2014-07-15 19:00:00+00:00,27.55,70.42,138.0,4.1,134.0,376.93,2.31,30.0,91665.0 +2014-07-15 20:00:00+00:00,27.51,69.37,450.0,35.84,415.0,379.4,2.23,13.0,91632.0 +2014-07-15 21:00:00+00:00,28.27,66.51,567.0,110.51,465.0,381.23,2.45,1.0,91563.0 +2014-07-15 22:00:00+00:00,29.03,63.64,483.0,120.75,384.0,383.07,2.66,349.0,91494.0 +2014-07-15 23:00:00+00:00,29.79,60.78,384.0,117.19,305.0,384.9,2.87,337.0,91425.0 +2014-07-16 00:00:00+00:00,29.67,59.21,265.0,107.08,212.0,384.38,2.35,326.0,91403.0 +2014-07-16 01:00:00+00:00,29.56,57.65,140.0,84.52,115.0,383.87,1.83,314.0,91382.0 +2014-07-16 02:00:00+00:00,29.44,56.08,30.0,11.15,29.0,383.35,1.31,303.0,91361.0 +2014-07-16 03:00:00+00:00,28.92,57.55,0.0,0.0,0.0,381.85,1.21,309.0,91391.0 +2014-07-16 04:00:00+00:00,28.39,59.01,0.0,0.0,0.0,380.35,1.11,316.0,91422.0 +2014-07-16 05:00:00+00:00,27.87,60.48,0.0,0.0,0.0,378.85,1.01,323.0,91452.0 +2014-07-16 06:00:00+00:00,27.72,64.1,0.0,0.0,0.0,374.6,1.07,321.0,91434.0 +2014-07-16 07:00:00+00:00,27.58,67.71,0.0,0.0,0.0,370.35,1.13,319.0,91416.0 +2014-07-16 08:00:00+00:00,27.43,71.33,0.0,0.0,0.0,366.1,1.19,317.0,91397.0 +2014-07-16 09:00:00+00:00,26.9,72.9,0.0,0.0,0.0,364.35,1.09,320.0,91394.0 +2014-07-16 10:00:00+00:00,26.36,74.46,0.0,0.0,0.0,362.6,0.98,323.0,91391.0 +2014-07-16 11:00:00+00:00,25.83,76.03,0.0,0.0,0.0,360.85,0.88,326.0,91388.0 +2014-07-16 12:00:00+00:00,26.31,72.07,0.0,0.0,0.0,363.78,0.78,338.0,91422.0 +2014-07-16 13:00:00+00:00,26.79,68.1,49.0,220.53,29.0,366.72,0.67,351.0,91455.0 +2014-07-16 14:00:00+00:00,27.26,64.14,231.0,549.13,68.0,369.65,0.57,3.0,91488.0 +2014-07-16 15:00:00+00:00,27.76,59.59,439.0,703.75,90.0,372.52,1.41,351.0,91479.0 +2014-07-16 16:00:00+00:00,28.26,55.03,637.0,788.89,105.0,375.38,2.25,340.0,91470.0 +2014-07-16 17:00:00+00:00,28.75,50.48,804.0,840.21,115.0,378.25,3.09,328.0,91461.0 +2014-07-16 18:00:00+00:00,28.54,51.1,923.0,868.92,121.0,380.4,3.6,321.0,91440.0 +2014-07-16 19:00:00+00:00,28.33,51.72,986.0,883.01,124.0,382.55,4.12,315.0,91419.0 +2014-07-16 20:00:00+00:00,28.11,52.34,987.0,884.16,124.0,384.7,4.63,308.0,91397.0 +2014-07-16 21:00:00+00:00,28.05,49.6,926.0,872.55,121.0,385.37,4.47,309.0,91349.0 +2014-07-16 22:00:00+00:00,27.99,46.86,809.0,846.97,115.0,386.03,4.31,310.0,91301.0 +2014-07-16 23:00:00+00:00,27.93,44.12,382.0,103.93,312.0,386.7,4.15,311.0,91253.0 +2014-07-17 00:00:00+00:00,28.01,44.74,281.0,133.56,215.0,382.57,3.14,295.0,91187.0 +2014-07-17 01:00:00+00:00,28.09,45.35,118.0,33.92,108.0,378.43,2.14,279.0,91121.0 +2014-07-17 02:00:00+00:00,28.17,45.97,31.0,22.62,29.0,374.3,1.13,263.0,91055.0 +2014-07-17 03:00:00+00:00,27.24,44.92,0.0,0.0,0.0,371.92,2.23,247.0,91100.0 +2014-07-17 04:00:00+00:00,26.31,43.88,0.0,0.0,0.0,369.53,3.34,231.0,91145.0 +2014-07-17 05:00:00+00:00,25.38,42.83,0.0,0.0,0.0,367.15,4.44,216.0,91190.0 +2014-07-17 06:00:00+00:00,24.9,42.1,0.0,0.0,0.0,365.15,4.46,218.0,91196.0 +2014-07-17 07:00:00+00:00,24.43,41.36,0.0,0.0,0.0,363.15,4.48,221.0,91202.0 +2014-07-17 08:00:00+00:00,23.95,40.63,0.0,0.0,0.0,361.15,4.5,223.0,91208.0 +2014-07-17 09:00:00+00:00,23.31,42.13,0.0,0.0,0.0,359.28,3.89,225.0,91220.0 +2014-07-17 10:00:00+00:00,22.67,43.63,0.0,0.0,0.0,357.42,3.28,227.0,91232.0 +2014-07-17 11:00:00+00:00,22.03,45.13,0.0,0.0,0.0,355.55,2.68,229.0,91244.0 +2014-07-17 12:00:00+00:00,23.78,38.28,0.0,0.0,0.0,356.92,2.11,230.0,91280.0 +2014-07-17 13:00:00+00:00,25.54,31.42,49.0,225.16,29.0,358.28,1.54,231.0,91316.0 +2014-07-17 14:00:00+00:00,27.29,24.57,172.0,213.41,109.0,359.65,0.98,232.0,91352.0 +2014-07-17 15:00:00+00:00,28.57,20.96,292.0,159.75,213.0,361.6,1.18,250.0,91355.0 +2014-07-17 16:00:00+00:00,29.85,17.34,157.0,4.46,154.0,363.55,1.37,268.0,91358.0 +2014-07-17 17:00:00+00:00,31.12,13.73,381.0,40.29,348.0,365.5,1.57,285.0,91361.0 +2014-07-17 18:00:00+00:00,31.87,13.47,200.0,11.93,189.0,364.0,2.24,286.0,91307.0 +2014-07-17 19:00:00+00:00,32.62,13.22,297.0,17.42,280.0,362.5,2.91,288.0,91253.0 +2014-07-17 20:00:00+00:00,33.37,12.96,427.0,36.9,391.0,361.0,3.59,289.0,91199.0 +2014-07-17 21:00:00+00:00,33.38,12.92,800.0,493.44,345.0,364.18,3.81,286.0,91148.0 +2014-07-17 22:00:00+00:00,33.38,12.89,821.0,860.94,116.0,367.37,4.04,284.0,91097.0 +2014-07-17 23:00:00+00:00,33.39,12.85,653.0,812.89,106.0,370.55,4.26,281.0,91046.0 +2014-07-18 00:00:00+00:00,31.33,14.27,452.0,731.81,91.0,369.68,3.94,275.0,91043.0 +2014-07-18 01:00:00+00:00,29.28,15.68,239.0,578.75,69.0,368.82,3.62,268.0,91040.0 +2014-07-18 02:00:00+00:00,27.22,17.1,51.0,241.04,30.0,367.95,3.3,261.0,91037.0 +2014-07-18 03:00:00+00:00,26.28,18.69,0.0,0.0,0.0,362.27,3.41,259.0,91100.0 +2014-07-18 04:00:00+00:00,25.33,20.27,0.0,0.0,0.0,356.58,3.52,257.0,91163.0 +2014-07-18 05:00:00+00:00,24.39,21.86,0.0,0.0,0.0,350.9,3.63,255.0,91226.0 +2014-07-18 06:00:00+00:00,24.11,24.22,0.0,0.0,0.0,347.3,3.0,250.0,91232.0 +2014-07-18 07:00:00+00:00,23.83,26.57,0.0,0.0,0.0,343.7,2.37,246.0,91238.0 +2014-07-18 08:00:00+00:00,23.55,28.93,0.0,0.0,0.0,340.1,1.74,241.0,91244.0 +2014-07-18 09:00:00+00:00,22.71,30.6,0.0,0.0,0.0,341.32,2.0,237.0,91277.0 +2014-07-18 10:00:00+00:00,21.87,32.27,0.0,0.0,0.0,342.53,2.26,232.0,91310.0 +2014-07-18 11:00:00+00:00,21.03,33.94,0.0,0.0,0.0,343.75,2.52,228.0,91343.0 +2014-07-18 12:00:00+00:00,22.14,31.32,0.0,0.0,0.0,346.25,2.31,228.0,91388.0 +2014-07-18 13:00:00+00:00,23.25,28.71,49.0,230.05,29.0,348.75,2.1,228.0,91434.0 +2014-07-18 14:00:00+00:00,24.36,26.09,236.0,568.9,69.0,351.25,1.89,227.0,91479.0 +2014-07-18 15:00:00+00:00,26.06,24.56,450.0,728.01,91.0,354.12,1.83,235.0,91479.0 +2014-07-18 16:00:00+00:00,27.76,23.03,565.0,495.48,232.0,356.98,1.77,242.0,91479.0 +2014-07-18 17:00:00+00:00,29.46,21.5,823.0,864.11,116.0,359.85,1.71,249.0,91479.0 +2014-07-18 18:00:00+00:00,30.1,21.86,946.0,893.1,123.0,362.75,2.28,253.0,91428.0 +2014-07-18 19:00:00+00:00,30.74,22.22,1010.0,906.66,126.0,365.65,2.85,256.0,91376.0 +2014-07-18 20:00:00+00:00,31.37,22.58,1010.0,906.64,126.0,368.55,3.42,260.0,91325.0 +2014-07-18 21:00:00+00:00,31.6,22.22,946.0,893.03,123.0,370.22,3.79,262.0,91280.0 +2014-07-18 22:00:00+00:00,31.83,21.87,617.0,274.96,392.0,371.88,4.17,264.0,91235.0 +2014-07-18 23:00:00+00:00,32.06,21.51,635.0,712.57,156.0,373.55,4.54,266.0,91190.0 +2014-07-19 00:00:00+00:00,30.63,24.6,392.0,463.06,164.0,373.55,4.1,261.0,91166.0 +2014-07-19 01:00:00+00:00,29.21,27.69,170.0,205.07,110.0,373.55,3.66,255.0,91142.0 +2014-07-19 02:00:00+00:00,27.78,30.78,31.0,34.99,28.0,373.55,3.21,250.0,91118.0 +2014-07-19 03:00:00+00:00,27.1,33.64,0.0,0.0,0.0,369.6,3.21,245.0,91160.0 +2014-07-19 04:00:00+00:00,26.43,36.49,0.0,0.0,0.0,365.65,3.2,240.0,91202.0 +2014-07-19 05:00:00+00:00,25.75,39.35,0.0,0.0,0.0,361.7,3.2,235.0,91244.0 +2014-07-19 06:00:00+00:00,25.72,43.56,0.0,0.0,0.0,358.75,2.54,237.0,91247.0 +2014-07-19 07:00:00+00:00,25.69,47.77,0.0,0.0,0.0,355.8,1.89,239.0,91250.0 +2014-07-19 08:00:00+00:00,25.66,51.98,0.0,0.0,0.0,352.85,1.23,241.0,91253.0 +2014-07-19 09:00:00+00:00,25.07,55.17,0.0,0.0,0.0,350.62,1.2,242.0,91277.0 +2014-07-19 10:00:00+00:00,24.49,58.37,0.0,0.0,0.0,348.38,1.17,243.0,91301.0 +2014-07-19 11:00:00+00:00,23.9,61.56,0.0,0.0,0.0,346.15,1.14,244.0,91325.0 +2014-07-19 12:00:00+00:00,25.24,56.71,0.0,0.0,0.0,348.88,1.14,249.0,91364.0 +2014-07-19 13:00:00+00:00,26.59,51.86,47.0,223.48,28.0,351.62,1.13,255.0,91403.0 +2014-07-19 14:00:00+00:00,27.93,47.01,233.0,565.31,68.0,354.35,1.12,260.0,91443.0 +2014-07-19 15:00:00+00:00,29.48,40.75,446.0,721.97,91.0,358.12,1.33,258.0,91410.0 +2014-07-19 16:00:00+00:00,31.02,34.49,648.0,807.87,106.0,361.88,1.54,256.0,91376.0 +2014-07-19 17:00:00+00:00,32.56,28.23,816.0,856.55,116.0,365.65,1.75,253.0,91343.0 +2014-07-19 18:00:00+00:00,33.52,26.41,938.0,886.24,122.0,366.25,1.91,249.0,91280.0 +2014-07-19 19:00:00+00:00,34.48,24.58,1001.0,899.04,125.0,366.85,2.06,245.0,91217.0 +2014-07-19 20:00:00+00:00,35.43,22.76,1001.0,898.95,125.0,367.45,2.22,240.0,91154.0 +2014-07-19 21:00:00+00:00,35.53,22.64,937.0,884.89,122.0,367.97,2.06,244.0,91109.0 +2014-07-19 22:00:00+00:00,35.63,22.51,816.0,857.31,115.0,368.48,1.89,247.0,91064.0 +2014-07-19 23:00:00+00:00,35.74,22.39,648.0,808.67,105.0,369.0,1.72,250.0,91019.0 +2014-07-20 00:00:00+00:00,34.11,24.13,446.0,724.5,90.0,368.07,2.25,242.0,91025.0 +2014-07-20 01:00:00+00:00,32.49,25.87,173.0,216.22,110.0,367.13,2.78,233.0,91031.0 +2014-07-20 02:00:00+00:00,30.86,27.61,35.0,71.21,29.0,366.2,3.31,225.0,91037.0 +2014-07-20 03:00:00+00:00,29.74,30.44,0.0,0.0,0.0,364.2,3.05,226.0,91091.0 +2014-07-20 04:00:00+00:00,28.62,33.28,0.0,0.0,0.0,362.2,2.8,228.0,91145.0 +2014-07-20 05:00:00+00:00,27.5,36.11,0.0,0.0,0.0,360.2,2.54,230.0,91199.0 +2014-07-20 06:00:00+00:00,26.98,38.93,0.0,0.0,0.0,357.43,2.54,231.0,91229.0 +2014-07-20 07:00:00+00:00,26.46,41.76,0.0,0.0,0.0,354.67,2.55,233.0,91259.0 +2014-07-20 08:00:00+00:00,25.94,44.58,0.0,0.0,0.0,351.9,2.55,234.0,91289.0 +2014-07-20 09:00:00+00:00,25.43,47.15,0.0,0.0,0.0,350.12,2.29,236.0,91313.0 +2014-07-20 10:00:00+00:00,24.91,49.71,0.0,0.0,0.0,348.33,2.02,239.0,91337.0 +2014-07-20 11:00:00+00:00,24.4,52.28,0.0,0.0,0.0,346.55,1.75,241.0,91361.0 +2014-07-20 12:00:00+00:00,25.6,46.97,0.0,0.0,0.0,349.45,1.44,248.0,91406.0 +2014-07-20 13:00:00+00:00,26.81,41.66,46.0,216.67,28.0,352.35,1.14,254.0,91452.0 +2014-07-20 14:00:00+00:00,28.01,36.35,231.0,561.71,68.0,355.25,0.83,261.0,91497.0 +2014-07-20 15:00:00+00:00,29.68,32.01,444.0,722.04,90.0,359.35,1.26,275.0,91464.0 +2014-07-20 16:00:00+00:00,31.35,27.67,615.0,652.52,178.0,363.45,1.7,289.0,91431.0 +2014-07-20 17:00:00+00:00,33.02,23.33,764.0,592.94,280.0,367.55,2.14,304.0,91397.0 +2014-07-20 18:00:00+00:00,34.13,22.53,684.0,238.05,465.0,370.57,2.1,292.0,91328.0 +2014-07-20 19:00:00+00:00,35.24,21.74,997.0,895.54,125.0,373.58,2.06,280.0,91259.0 +2014-07-20 20:00:00+00:00,36.35,20.94,997.0,895.4,125.0,376.6,2.03,268.0,91190.0 +2014-07-20 21:00:00+00:00,36.4,20.66,934.0,882.21,122.0,380.1,2.32,267.0,91139.0 +2014-07-20 22:00:00+00:00,36.45,20.38,814.0,855.57,115.0,383.6,2.62,265.0,91088.0 +2014-07-20 23:00:00+00:00,36.51,20.1,558.0,472.67,241.0,387.1,2.91,264.0,91037.0 +2014-07-21 00:00:00+00:00,34.9,21.16,446.0,726.08,90.0,384.4,2.9,252.0,91055.0 +2014-07-21 01:00:00+00:00,33.29,22.23,234.0,572.29,68.0,381.7,2.89,241.0,91073.0 +2014-07-21 02:00:00+00:00,31.68,23.29,47.0,229.76,28.0,379.0,2.88,230.0,91091.0 +2014-07-21 03:00:00+00:00,30.87,25.99,0.0,0.0,0.0,377.32,2.86,233.0,91151.0 +2014-07-21 04:00:00+00:00,30.07,28.68,0.0,0.0,0.0,375.63,2.83,236.0,91211.0 +2014-07-21 05:00:00+00:00,29.26,31.38,0.0,0.0,0.0,373.95,2.8,238.0,91271.0 +2014-07-21 06:00:00+00:00,28.52,34.86,0.0,0.0,0.0,372.12,2.74,243.0,91298.0 +2014-07-21 07:00:00+00:00,27.77,38.33,0.0,0.0,0.0,370.28,2.69,247.0,91325.0 +2014-07-21 08:00:00+00:00,27.03,41.81,0.0,0.0,0.0,368.45,2.63,252.0,91352.0 +2014-07-21 09:00:00+00:00,26.47,45.36,0.0,0.0,0.0,366.15,2.39,255.0,91370.0 +2014-07-21 10:00:00+00:00,25.92,48.9,0.0,0.0,0.0,363.85,2.15,259.0,91388.0 +2014-07-21 11:00:00+00:00,25.36,52.45,0.0,0.0,0.0,361.55,1.9,263.0,91406.0 +2014-07-21 12:00:00+00:00,26.38,47.31,0.0,0.0,0.0,364.42,1.4,285.0,91473.0 +2014-07-21 13:00:00+00:00,27.41,42.17,44.0,209.59,27.0,367.28,0.9,308.0,91539.0 +2014-07-21 14:00:00+00:00,28.43,37.03,230.0,561.57,68.0,370.15,0.4,330.0,91605.0 +2014-07-21 15:00:00+00:00,30.21,32.79,345.0,312.99,192.0,372.4,1.28,338.0,91572.0 +2014-07-21 16:00:00+00:00,31.99,28.55,525.0,372.47,276.0,374.65,2.16,346.0,91539.0 +2014-07-21 17:00:00+00:00,33.76,24.31,613.0,274.75,389.0,376.9,3.03,354.0,91506.0 +2014-07-21 18:00:00+00:00,35.0,22.57,936.0,885.6,122.0,379.52,3.04,349.0,91431.0 +2014-07-21 19:00:00+00:00,36.24,20.83,999.0,898.23,125.0,382.13,3.04,344.0,91355.0 +2014-07-21 20:00:00+00:00,37.47,19.09,998.0,897.01,125.0,384.75,3.05,338.0,91280.0 +2014-07-21 21:00:00+00:00,37.73,19.06,934.0,882.83,122.0,387.83,3.33,331.0,91223.0 +2014-07-21 22:00:00+00:00,37.99,19.04,814.0,856.34,115.0,390.92,3.61,324.0,91166.0 +2014-07-21 23:00:00+00:00,38.26,19.01,645.0,806.23,105.0,394.0,3.89,317.0,91109.0 +2014-07-22 00:00:00+00:00,37.41,19.84,444.0,723.69,90.0,389.18,3.46,283.0,91124.0 +2014-07-22 01:00:00+00:00,36.57,20.68,231.0,564.65,68.0,384.37,3.03,250.0,91139.0 +2014-07-22 02:00:00+00:00,35.72,21.51,45.0,209.75,28.0,379.55,2.61,217.0,91154.0 +2014-07-22 03:00:00+00:00,33.92,23.42,0.0,0.0,0.0,378.17,2.34,220.0,91196.0 +2014-07-22 04:00:00+00:00,32.11,25.34,0.0,0.0,0.0,376.78,2.06,223.0,91238.0 +2014-07-22 05:00:00+00:00,30.31,27.25,0.0,0.0,0.0,375.4,1.79,227.0,91280.0 +2014-07-22 06:00:00+00:00,30.13,29.11,0.0,0.0,0.0,373.08,1.77,234.0,91274.0 +2014-07-22 07:00:00+00:00,29.96,30.96,0.0,0.0,0.0,370.77,1.75,241.0,91268.0 +2014-07-22 08:00:00+00:00,29.78,32.82,0.0,0.0,0.0,368.45,1.72,248.0,91262.0 +2014-07-22 09:00:00+00:00,29.43,32.12,0.0,0.0,0.0,365.07,1.44,261.0,91280.0 +2014-07-22 10:00:00+00:00,29.09,31.43,0.0,0.0,0.0,361.68,1.15,275.0,91298.0 +2014-07-22 11:00:00+00:00,28.74,30.73,0.0,0.0,0.0,358.3,0.87,288.0,91316.0 +2014-07-22 12:00:00+00:00,29.43,29.44,0.0,0.0,0.0,361.95,0.79,309.0,91373.0 +2014-07-22 13:00:00+00:00,30.13,28.15,15.0,0.0,15.0,365.6,0.7,331.0,91431.0 +2014-07-22 14:00:00+00:00,30.82,26.86,111.0,27.9,103.0,369.25,0.62,352.0,91488.0 +2014-07-22 15:00:00+00:00,32.9,22.99,371.0,408.32,172.0,375.57,0.92,7.0,91452.0 +2014-07-22 16:00:00+00:00,34.98,19.13,640.0,801.74,105.0,381.88,1.22,21.0,91416.0 +2014-07-22 17:00:00+00:00,37.05,15.26,808.0,851.04,115.0,388.2,1.52,36.0,91379.0 +2014-07-22 18:00:00+00:00,37.79,14.39,718.0,290.75,451.0,391.23,1.22,68.0,91313.0 +2014-07-22 19:00:00+00:00,38.52,13.53,204.0,12.34,192.0,394.27,0.92,99.0,91247.0 +2014-07-22 20:00:00+00:00,39.25,12.66,857.0,408.2,460.0,397.3,0.62,131.0,91181.0 +2014-07-22 21:00:00+00:00,39.21,12.78,462.0,60.93,406.0,397.3,1.04,141.0,91154.0 +2014-07-22 22:00:00+00:00,39.16,12.9,806.0,848.58,114.0,397.3,1.46,152.0,91127.0 +2014-07-22 23:00:00+00:00,39.12,13.02,638.0,798.39,104.0,397.3,1.88,162.0,91100.0 +2014-07-23 00:00:00+00:00,38.45,14.28,438.0,715.24,89.0,391.83,1.61,149.0,91106.0 +2014-07-23 01:00:00+00:00,37.78,15.53,227.0,557.08,67.0,386.37,1.35,136.0,91112.0 +2014-07-23 02:00:00+00:00,37.11,16.79,44.0,214.33,27.0,380.9,1.09,123.0,91118.0 +2014-07-23 03:00:00+00:00,34.81,18.56,0.0,0.0,0.0,380.35,1.31,126.0,91148.0 +2014-07-23 04:00:00+00:00,32.5,20.33,0.0,0.0,0.0,379.8,1.52,128.0,91178.0 +2014-07-23 05:00:00+00:00,30.2,22.1,0.0,0.0,0.0,379.25,1.74,131.0,91208.0 +2014-07-23 06:00:00+00:00,29.14,23.22,0.0,0.0,0.0,379.72,1.96,139.0,91211.0 +2014-07-23 07:00:00+00:00,28.09,24.35,0.0,0.0,0.0,380.18,2.19,147.0,91214.0 +2014-07-23 08:00:00+00:00,27.03,25.47,0.0,0.0,0.0,380.65,2.41,155.0,91217.0 +2014-07-23 09:00:00+00:00,26.31,27.73,0.0,0.0,0.0,376.37,2.17,152.0,91223.0 +2014-07-23 10:00:00+00:00,25.6,29.98,0.0,0.0,0.0,372.08,1.92,148.0,91229.0 +2014-07-23 11:00:00+00:00,24.88,32.24,0.0,0.0,0.0,367.8,1.67,144.0,91235.0 +2014-07-23 12:00:00+00:00,27.06,31.77,0.0,0.0,0.0,366.8,1.94,121.0,91316.0 +2014-07-23 13:00:00+00:00,29.25,31.31,37.0,142.65,26.0,365.8,2.2,98.0,91397.0 +2014-07-23 14:00:00+00:00,31.43,30.84,204.0,435.08,80.0,364.8,2.47,75.0,91479.0 +2014-07-23 15:00:00+00:00,33.18,27.48,432.0,705.92,89.0,369.82,2.57,81.0,91443.0 +2014-07-23 16:00:00+00:00,34.93,24.12,631.0,791.2,104.0,374.83,2.67,86.0,91406.0 +2014-07-23 17:00:00+00:00,36.68,20.76,798.0,841.03,114.0,379.85,2.77,92.0,91370.0 +2014-07-23 18:00:00+00:00,37.35,20.08,918.0,869.77,120.0,382.95,2.4,91.0,91310.0 +2014-07-23 19:00:00+00:00,38.01,19.4,981.0,883.11,123.0,386.05,2.03,89.0,91250.0 +2014-07-23 20:00:00+00:00,38.67,18.72,980.0,881.81,123.0,389.15,1.66,88.0,91190.0 +2014-07-23 21:00:00+00:00,38.1,19.52,917.0,867.88,120.0,393.38,2.62,90.0,91184.0 +2014-07-23 22:00:00+00:00,37.53,20.31,798.0,839.64,114.0,397.62,3.58,92.0,91178.0 +2014-07-23 23:00:00+00:00,36.96,21.11,631.0,789.11,104.0,401.85,4.54,94.0,91172.0 +2014-07-24 00:00:00+00:00,35.18,24.18,432.0,704.81,89.0,394.37,3.57,92.0,91193.0 +2014-07-24 01:00:00+00:00,33.4,27.25,136.0,91.02,110.0,386.88,2.6,91.0,91214.0 +2014-07-24 02:00:00+00:00,31.62,30.32,1.0,0.0,1.0,379.4,1.63,89.0,91235.0 +2014-07-24 03:00:00+00:00,31.18,34.39,0.0,0.0,0.0,376.18,1.41,71.0,91253.0 +2014-07-24 04:00:00+00:00,30.73,38.46,0.0,0.0,0.0,372.97,1.2,53.0,91271.0 +2014-07-24 05:00:00+00:00,30.29,42.53,0.0,0.0,0.0,369.75,0.98,35.0,91289.0 +2014-07-24 06:00:00+00:00,29.31,47.11,0.0,0.0,0.0,365.67,1.08,44.0,91253.0 +2014-07-24 07:00:00+00:00,28.33,51.7,0.0,0.0,0.0,361.58,1.17,54.0,91217.0 +2014-07-24 08:00:00+00:00,27.35,56.28,0.0,0.0,0.0,357.5,1.27,63.0,91181.0 +2014-07-24 09:00:00+00:00,26.45,58.8,0.0,0.0,0.0,354.22,1.49,71.0,91178.0 +2014-07-24 10:00:00+00:00,25.56,61.31,0.0,0.0,0.0,350.93,1.71,80.0,91175.0 +2014-07-24 11:00:00+00:00,24.66,63.83,0.0,0.0,0.0,347.65,1.93,88.0,91172.0 +2014-07-24 12:00:00+00:00,26.88,56.17,0.0,0.0,0.0,348.57,1.89,91.0,91208.0 +2014-07-24 13:00:00+00:00,29.1,48.51,40.0,186.47,26.0,349.48,1.85,94.0,91244.0 +2014-07-24 14:00:00+00:00,31.32,40.85,226.0,561.35,67.0,350.4,1.81,96.0,91280.0 +2014-07-24 15:00:00+00:00,33.53,34.43,442.0,726.67,90.0,356.08,2.28,103.0,91250.0 +2014-07-24 16:00:00+00:00,35.73,28.01,646.0,813.74,105.0,361.77,2.75,110.0,91220.0 +2014-07-24 17:00:00+00:00,37.93,21.59,818.0,865.49,115.0,367.45,3.23,118.0,91190.0 +2014-07-24 18:00:00+00:00,38.71,19.66,940.0,893.5,121.0,368.63,2.98,119.0,91103.0 +2014-07-24 19:00:00+00:00,39.49,17.74,1004.0,905.44,125.0,369.82,2.74,120.0,91016.0 +2014-07-24 20:00:00+00:00,40.26,15.81,1004.0,906.17,124.0,371.0,2.5,121.0,90929.0 +2014-07-24 21:00:00+00:00,40.34,15.37,938.0,890.41,121.0,376.05,2.03,125.0,90863.0 +2014-07-24 22:00:00+00:00,40.42,14.93,814.0,858.99,115.0,381.1,1.56,128.0,90797.0 +2014-07-24 23:00:00+00:00,40.51,14.49,642.0,806.87,104.0,386.15,1.09,132.0,90731.0 +2014-07-25 00:00:00+00:00,38.51,16.97,438.0,719.16,89.0,388.23,3.24,156.0,90788.0 +2014-07-25 01:00:00+00:00,36.52,19.44,224.0,556.26,66.0,390.32,5.38,181.0,90845.0 +2014-07-25 02:00:00+00:00,34.53,21.92,36.0,132.28,26.0,392.4,7.53,206.0,90902.0 +2014-07-25 03:00:00+00:00,33.36,27.37,0.0,0.0,0.0,386.37,6.28,210.0,90998.0 +2014-07-25 04:00:00+00:00,32.18,32.83,0.0,0.0,0.0,380.33,5.03,215.0,91094.0 +2014-07-25 05:00:00+00:00,31.01,38.28,0.0,0.0,0.0,374.3,3.78,220.0,91190.0 +2014-07-25 06:00:00+00:00,30.14,43.51,0.0,0.0,0.0,370.33,2.74,223.0,91226.0 +2014-07-25 07:00:00+00:00,29.27,48.73,0.0,0.0,0.0,366.37,1.71,227.0,91262.0 +2014-07-25 08:00:00+00:00,28.4,53.96,0.0,0.0,0.0,362.4,0.68,230.0,91298.0 +2014-07-25 09:00:00+00:00,27.64,58.13,0.0,0.0,0.0,360.83,1.2,229.0,91310.0 +2014-07-25 10:00:00+00:00,26.87,62.3,0.0,0.0,0.0,359.27,1.71,229.0,91322.0 +2014-07-25 11:00:00+00:00,26.11,66.47,0.0,0.0,0.0,357.7,2.23,228.0,91334.0 +2014-07-25 12:00:00+00:00,27.53,62.92,0.0,0.0,0.0,363.45,1.88,225.0,91355.0 +2014-07-25 13:00:00+00:00,28.95,59.38,38.0,178.01,25.0,369.2,1.52,222.0,91376.0 +2014-07-25 14:00:00+00:00,30.36,55.83,219.0,543.57,66.0,374.95,1.16,219.0,91397.0 +2014-07-25 15:00:00+00:00,31.24,52.19,431.0,708.22,89.0,380.93,1.44,179.0,91364.0 +2014-07-25 16:00:00+00:00,32.12,48.56,632.0,797.19,103.0,386.92,1.72,140.0,91331.0 +2014-07-25 17:00:00+00:00,32.99,44.92,801.0,846.88,114.0,392.9,2.0,100.0,91298.0 +2014-07-25 18:00:00+00:00,32.33,46.52,922.0,875.81,120.0,394.6,3.12,144.0,91274.0 +2014-07-25 19:00:00+00:00,31.67,48.13,984.0,887.63,123.0,396.3,4.23,187.0,91250.0 +2014-07-25 20:00:00+00:00,31.01,49.73,653.0,152.52,505.0,398.0,5.35,231.0,91226.0 +2014-07-25 21:00:00+00:00,29.94,54.8,156.0,6.55,150.0,394.02,5.63,240.0,91253.0 +2014-07-25 22:00:00+00:00,28.86,59.86,68.0,0.0,68.0,390.03,5.9,249.0,91280.0 +2014-07-25 23:00:00+00:00,27.79,64.93,44.0,0.0,44.0,386.05,6.18,258.0,91307.0 +2014-07-26 00:00:00+00:00,27.42,68.29,84.0,0.0,84.0,386.68,4.91,257.0,91304.0 +2014-07-26 01:00:00+00:00,27.06,71.64,99.0,10.63,96.0,387.32,3.63,255.0,91301.0 +2014-07-26 02:00:00+00:00,26.7,75.0,16.0,0.0,16.0,387.95,2.36,253.0,91298.0 +2014-07-26 03:00:00+00:00,26.57,79.79,0.0,0.0,0.0,388.78,1.89,254.0,91358.0 +2014-07-26 04:00:00+00:00,26.45,84.58,0.0,0.0,0.0,389.62,1.43,255.0,91419.0 +2014-07-26 05:00:00+00:00,26.32,89.37,0.0,0.0,0.0,390.45,0.97,255.0,91479.0 +2014-07-26 06:00:00+00:00,26.29,91.59,0.0,0.0,0.0,395.37,1.13,251.0,91464.0 +2014-07-26 07:00:00+00:00,26.25,93.82,0.0,0.0,0.0,400.28,1.29,246.0,91449.0 +2014-07-26 08:00:00+00:00,26.22,96.04,0.0,0.0,0.0,405.2,1.45,242.0,91434.0 +2014-07-26 09:00:00+00:00,25.98,96.96,0.0,0.0,0.0,409.55,1.76,244.0,91446.0 +2014-07-26 10:00:00+00:00,25.74,97.87,0.0,0.0,0.0,413.9,2.06,246.0,91458.0 +2014-07-26 11:00:00+00:00,25.5,98.79,0.0,0.0,0.0,418.25,2.37,248.0,91470.0 +2014-07-26 12:00:00+00:00,25.71,93.49,0.0,0.0,0.0,411.45,2.18,250.0,91503.0 +2014-07-26 13:00:00+00:00,25.92,88.18,37.0,183.2,24.0,404.65,1.99,252.0,91536.0 +2014-07-26 14:00:00+00:00,26.12,82.88,220.0,550.62,66.0,397.85,1.79,254.0,91569.0 +2014-07-26 15:00:00+00:00,27.8,72.97,433.0,714.61,89.0,394.37,2.12,268.0,91533.0 +2014-07-26 16:00:00+00:00,29.48,63.06,636.0,803.24,104.0,390.88,2.45,282.0,91497.0 +2014-07-26 17:00:00+00:00,31.16,53.15,806.0,854.16,114.0,387.4,2.77,296.0,91461.0 +2014-07-26 18:00:00+00:00,32.01,48.06,928.0,883.24,120.0,388.7,3.06,302.0,91373.0 +2014-07-26 19:00:00+00:00,32.86,42.97,991.0,895.61,123.0,390.0,3.35,308.0,91286.0 +2014-07-26 20:00:00+00:00,33.7,37.88,991.0,895.29,123.0,391.3,3.64,314.0,91199.0 +2014-07-26 21:00:00+00:00,32.85,37.21,926.0,880.07,120.0,388.7,3.75,306.0,91172.0 +2014-07-26 22:00:00+00:00,31.99,36.54,805.0,851.22,114.0,386.1,3.86,298.0,91145.0 +2014-07-26 23:00:00+00:00,31.14,35.87,636.0,800.68,104.0,383.5,3.97,290.0,91118.0 +2014-07-27 00:00:00+00:00,30.87,37.99,435.0,719.42,88.0,384.77,3.55,287.0,91094.0 +2014-07-27 01:00:00+00:00,30.61,40.1,222.0,556.08,66.0,386.03,3.13,284.0,91070.0 +2014-07-27 02:00:00+00:00,30.34,42.22,33.0,111.84,25.0,387.3,2.7,280.0,91046.0 +2014-07-27 03:00:00+00:00,29.59,45.0,0.0,0.0,0.0,389.87,3.06,275.0,91115.0 +2014-07-27 04:00:00+00:00,28.84,47.79,0.0,0.0,0.0,392.43,3.42,271.0,91184.0 +2014-07-27 05:00:00+00:00,28.09,50.57,0.0,0.0,0.0,395.0,3.78,266.0,91253.0 +2014-07-27 06:00:00+00:00,27.47,53.17,0.0,0.0,0.0,390.88,4.32,260.0,91265.0 +2014-07-27 07:00:00+00:00,26.86,55.78,0.0,0.0,0.0,386.77,4.86,254.0,91277.0 +2014-07-27 08:00:00+00:00,26.24,58.38,0.0,0.0,0.0,382.65,5.41,248.0,91289.0 +2014-07-27 09:00:00+00:00,25.61,59.98,0.0,0.0,0.0,379.62,5.03,247.0,91310.0 +2014-07-27 10:00:00+00:00,24.98,61.58,0.0,0.0,0.0,376.58,4.64,246.0,91331.0 +2014-07-27 11:00:00+00:00,24.35,63.18,0.0,0.0,0.0,373.55,4.26,245.0,91352.0 +2014-07-27 12:00:00+00:00,24.49,63.15,0.0,0.0,0.0,374.58,4.05,262.0,91500.0 +2014-07-27 13:00:00+00:00,24.63,63.11,8.0,0.0,8.0,375.62,3.83,279.0,91647.0 +2014-07-27 14:00:00+00:00,24.77,63.08,67.0,0.0,67.0,376.65,3.61,297.0,91794.0 +2014-07-27 15:00:00+00:00,26.79,55.33,203.0,37.51,185.0,379.68,3.19,304.0,91734.0 +2014-07-27 16:00:00+00:00,28.8,47.57,384.0,118.0,306.0,382.72,2.76,312.0,91674.0 +2014-07-27 17:00:00+00:00,30.81,39.82,724.0,510.46,311.0,385.75,2.33,320.0,91614.0 +2014-07-27 18:00:00+00:00,32.04,36.46,922.0,877.57,120.0,385.2,2.56,315.0,91524.0 +2014-07-27 19:00:00+00:00,33.27,33.11,869.0,421.35,461.0,384.65,2.79,310.0,91434.0 +2014-07-27 20:00:00+00:00,34.5,29.75,987.0,891.95,123.0,384.1,3.02,305.0,91343.0 +2014-07-27 21:00:00+00:00,34.1,29.29,924.0,878.78,120.0,381.17,3.92,295.0,91310.0 +2014-07-27 22:00:00+00:00,33.7,28.82,803.0,851.11,113.0,378.23,4.81,284.0,91277.0 +2014-07-27 23:00:00+00:00,33.3,28.36,634.0,800.71,103.0,375.3,5.71,274.0,91244.0 +2014-07-28 00:00:00+00:00,32.48,31.13,358.0,374.42,178.0,375.3,4.04,278.0,91247.0 +2014-07-28 01:00:00+00:00,31.67,33.89,187.0,337.32,93.0,375.3,2.36,282.0,91250.0 +2014-07-28 02:00:00+00:00,30.86,36.66,37.0,187.4,24.0,375.3,0.69,285.0,91253.0 +2014-07-28 03:00:00+00:00,30.04,38.76,0.0,0.0,0.0,373.35,0.85,281.0,91307.0 +2014-07-28 04:00:00+00:00,29.22,40.86,0.0,0.0,0.0,371.4,1.0,277.0,91361.0 +2014-07-28 05:00:00+00:00,28.4,42.96,0.0,0.0,0.0,369.45,1.16,273.0,91416.0 +2014-07-28 06:00:00+00:00,28.14,46.53,0.0,0.0,0.0,369.57,1.23,274.0,91437.0 +2014-07-28 07:00:00+00:00,27.88,50.09,0.0,0.0,0.0,369.68,1.3,275.0,91458.0 +2014-07-28 08:00:00+00:00,27.62,53.66,0.0,0.0,0.0,369.8,1.37,276.0,91479.0 +2014-07-28 09:00:00+00:00,27.38,55.38,0.0,0.0,0.0,371.32,1.27,279.0,91491.0 +2014-07-28 10:00:00+00:00,27.13,57.1,0.0,0.0,0.0,372.83,1.17,282.0,91503.0 +2014-07-28 11:00:00+00:00,26.89,58.82,0.0,0.0,0.0,374.35,1.08,284.0,91515.0 +2014-07-28 12:00:00+00:00,26.93,58.0,0.0,0.0,0.0,371.8,0.9,233.0,91623.0 +2014-07-28 13:00:00+00:00,26.98,57.17,14.0,0.0,14.0,369.25,0.73,182.0,91731.0 +2014-07-28 14:00:00+00:00,27.02,56.35,146.0,152.14,104.0,366.7,0.55,131.0,91839.0 +2014-07-28 15:00:00+00:00,28.67,49.8,359.0,390.95,172.0,371.18,1.07,178.0,91812.0 +2014-07-28 16:00:00+00:00,30.32,43.25,509.0,351.65,277.0,375.67,1.58,224.0,91785.0 +2014-07-28 17:00:00+00:00,31.97,36.7,684.0,446.79,323.0,380.15,2.1,271.0,91758.0 +2014-07-28 18:00:00+00:00,32.63,33.99,711.0,286.99,449.0,378.27,2.46,279.0,91686.0 +2014-07-28 19:00:00+00:00,33.28,31.29,705.0,210.87,501.0,376.38,2.83,286.0,91614.0 +2014-07-28 20:00:00+00:00,33.93,28.58,702.0,206.66,502.0,374.5,3.2,294.0,91542.0 +2014-07-28 21:00:00+00:00,33.83,28.89,806.0,436.58,407.0,373.98,2.54,294.0,91497.0 +2014-07-28 22:00:00+00:00,33.73,29.2,234.0,12.35,224.0,373.47,1.89,293.0,91452.0 +2014-07-28 23:00:00+00:00,33.64,29.51,499.0,320.33,287.0,372.95,1.23,293.0,91406.0 +2014-07-29 00:00:00+00:00,32.89,35.21,388.0,500.97,148.0,372.85,0.86,295.0,91397.0 +2014-07-29 01:00:00+00:00,32.15,40.9,218.0,552.93,65.0,372.75,0.49,296.0,91388.0 +2014-07-29 02:00:00+00:00,31.41,46.6,32.0,134.08,23.0,372.65,0.12,298.0,91379.0 +2014-07-29 03:00:00+00:00,30.54,48.79,0.0,0.0,0.0,372.8,0.52,300.0,91422.0 +2014-07-29 04:00:00+00:00,29.67,50.98,0.0,0.0,0.0,372.95,0.92,302.0,91464.0 +2014-07-29 05:00:00+00:00,28.8,53.17,0.0,0.0,0.0,373.1,1.32,304.0,91506.0 +2014-07-29 06:00:00+00:00,28.66,53.84,0.0,0.0,0.0,371.92,1.37,309.0,91497.0 +2014-07-29 07:00:00+00:00,28.52,54.5,0.0,0.0,0.0,370.73,1.42,314.0,91488.0 +2014-07-29 08:00:00+00:00,28.38,55.17,0.0,0.0,0.0,369.55,1.46,319.0,91479.0 +2014-07-29 09:00:00+00:00,27.99,55.04,0.0,0.0,0.0,366.7,1.48,342.0,91470.0 +2014-07-29 10:00:00+00:00,27.59,54.92,0.0,0.0,0.0,363.85,1.49,5.0,91461.0 +2014-07-29 11:00:00+00:00,27.2,54.79,0.0,0.0,0.0,361.0,1.5,27.0,91452.0 +2014-07-29 12:00:00+00:00,27.96,52.09,0.0,0.0,0.0,360.78,1.16,26.0,91506.0 +2014-07-29 13:00:00+00:00,28.72,49.39,28.0,92.79,22.0,360.57,0.82,24.0,91560.0 +2014-07-29 14:00:00+00:00,29.47,46.69,203.0,488.61,69.0,360.35,0.48,22.0,91614.0 +2014-07-29 15:00:00+00:00,31.08,41.9,426.0,711.03,87.0,363.25,1.26,3.0,91581.0 +2014-07-29 16:00:00+00:00,32.68,37.1,629.0,800.37,102.0,366.15,2.04,344.0,91548.0 +2014-07-29 17:00:00+00:00,34.28,32.31,799.0,850.19,113.0,369.05,2.81,325.0,91515.0 +2014-07-29 18:00:00+00:00,35.13,30.41,849.0,506.61,387.0,368.3,2.8,320.0,91452.0 +2014-07-29 19:00:00+00:00,35.97,28.51,799.0,363.16,448.0,367.55,2.8,315.0,91388.0 +2014-07-29 20:00:00+00:00,36.81,26.61,846.0,406.48,453.0,366.8,2.79,310.0,91325.0 +2014-07-29 21:00:00+00:00,36.82,25.56,923.0,880.71,119.0,371.73,2.89,310.0,91259.0 +2014-07-29 22:00:00+00:00,36.83,24.5,802.0,852.32,113.0,376.67,3.0,310.0,91193.0 +2014-07-29 23:00:00+00:00,36.84,23.45,633.0,802.53,103.0,381.6,3.1,310.0,91127.0 +2014-07-30 00:00:00+00:00,35.32,24.93,416.0,651.55,105.0,384.83,2.7,304.0,91130.0 +2014-07-30 01:00:00+00:00,33.81,26.4,131.0,94.66,105.0,388.07,2.29,299.0,91133.0 +2014-07-30 02:00:00+00:00,32.29,27.88,29.0,92.61,23.0,391.3,1.89,294.0,91136.0 +2014-07-30 03:00:00+00:00,31.4,30.39,0.0,0.0,0.0,385.78,1.82,295.0,91178.0 +2014-07-30 04:00:00+00:00,30.5,32.91,0.0,0.0,0.0,380.27,1.74,295.0,91220.0 +2014-07-30 05:00:00+00:00,29.61,35.42,0.0,0.0,0.0,374.75,1.67,295.0,91262.0 +2014-07-30 06:00:00+00:00,29.28,37.16,0.0,0.0,0.0,371.15,1.67,300.0,91253.0 +2014-07-30 07:00:00+00:00,28.94,38.9,0.0,0.0,0.0,367.55,1.67,305.0,91244.0 +2014-07-30 08:00:00+00:00,28.61,40.64,0.0,0.0,0.0,363.95,1.67,309.0,91235.0 +2014-07-30 09:00:00+00:00,28.89,40.3,0.0,0.0,0.0,364.13,1.54,311.0,91232.0 +2014-07-30 10:00:00+00:00,29.18,39.97,0.0,0.0,0.0,364.32,1.41,313.0,91229.0 +2014-07-30 11:00:00+00:00,29.46,39.63,0.0,0.0,0.0,364.5,1.28,315.0,91226.0 +2014-07-30 12:00:00+00:00,29.86,37.68,0.0,0.0,0.0,365.22,0.95,302.0,91271.0 +2014-07-30 13:00:00+00:00,30.26,35.73,32.0,159.92,22.0,365.93,0.62,290.0,91316.0 +2014-07-30 14:00:00+00:00,30.66,33.78,212.0,543.29,64.0,366.65,0.29,277.0,91361.0 +2014-07-30 15:00:00+00:00,32.3,30.1,426.0,713.36,87.0,370.83,0.69,284.0,91340.0 +2014-07-30 16:00:00+00:00,33.94,26.41,610.0,683.27,161.0,375.02,1.09,290.0,91319.0 +2014-07-30 17:00:00+00:00,35.58,22.73,700.0,475.33,317.0,379.2,1.49,296.0,91298.0 +2014-07-30 18:00:00+00:00,35.72,21.25,761.0,393.0,403.0,380.3,2.04,284.0,91241.0 +2014-07-30 19:00:00+00:00,35.86,19.76,751.0,272.38,488.0,381.4,2.59,272.0,91184.0 +2014-07-30 20:00:00+00:00,35.99,18.28,814.0,385.15,442.0,382.5,3.14,260.0,91127.0 +2014-07-30 21:00:00+00:00,35.88,17.91,924.0,882.85,119.0,380.13,3.61,257.0,91091.0 +2014-07-30 22:00:00+00:00,35.76,17.53,803.0,856.12,112.0,377.77,4.08,254.0,91055.0 +2014-07-30 23:00:00+00:00,35.65,17.16,526.0,390.02,269.0,375.4,4.55,251.0,91019.0 +2014-07-31 00:00:00+00:00,34.48,18.68,95.0,0.0,95.0,379.93,4.42,246.0,91025.0 +2014-07-31 01:00:00+00:00,33.32,20.21,56.0,0.0,56.0,384.47,4.29,240.0,91031.0 +2014-07-31 02:00:00+00:00,32.16,21.73,12.0,0.0,12.0,389.0,4.17,234.0,91037.0 +2014-07-31 03:00:00+00:00,31.52,23.48,0.0,0.0,0.0,387.82,4.11,227.0,91106.0 +2014-07-31 04:00:00+00:00,30.89,25.24,0.0,0.0,0.0,386.63,4.06,221.0,91175.0 +2014-07-31 05:00:00+00:00,30.25,26.99,0.0,0.0,0.0,385.45,4.0,215.0,91244.0 +2014-07-31 06:00:00+00:00,29.97,29.32,0.0,0.0,0.0,382.23,3.44,215.0,91256.0 +2014-07-31 07:00:00+00:00,29.7,31.65,0.0,0.0,0.0,379.02,2.88,215.0,91268.0 +2014-07-31 08:00:00+00:00,29.42,33.98,0.0,0.0,0.0,375.8,2.32,215.0,91280.0 +2014-07-31 09:00:00+00:00,28.83,36.4,0.0,0.0,0.0,373.9,2.18,219.0,91295.0 +2014-07-31 10:00:00+00:00,28.24,38.83,0.0,0.0,0.0,372.0,2.05,224.0,91310.0 +2014-07-31 11:00:00+00:00,27.65,41.25,0.0,0.0,0.0,370.1,1.92,228.0,91325.0 +2014-07-31 12:00:00+00:00,28.24,40.51,0.0,0.0,0.0,376.35,1.78,260.0,91373.0 +2014-07-31 13:00:00+00:00,28.83,39.77,5.0,0.0,5.0,382.6,1.65,292.0,91422.0 +2014-07-31 14:00:00+00:00,29.41,39.03,44.0,0.0,44.0,388.85,1.52,324.0,91470.0 +2014-07-31 15:00:00+00:00,31.11,34.23,109.0,0.0,109.0,386.02,1.83,354.0,91446.0 +2014-07-31 16:00:00+00:00,36.88,11.75,156.0,3.05,154.0,385.27,2.76,23.0,91422.0 +2014-07-31 17:00:00+00:00,36.04,16.31,522.0,154.11,398.0,383.62,2.64,53.0,91397.0 +2014-07-31 18:00:00+00:00,35.19,20.87,694.0,263.76,454.0,381.97,2.52,59.0,91340.0 +2014-07-31 19:00:00+00:00,34.35,25.43,475.0,44.58,432.0,380.32,2.4,65.0,91283.0 +2014-07-31 20:00:00+00:00,33.5,29.98,227.0,16.58,211.0,378.67,2.28,70.0,91226.0 +2014-07-31 21:00:00+00:00,32.66,34.54,710.0,355.78,386.0,377.02,2.16,58.0,91202.0 +2014-07-31 22:00:00+00:00,31.81,39.1,384.0,44.68,348.0,375.37,2.04,45.0,91178.0 +2014-07-31 23:00:00+00:00,30.97,43.66,262.0,25.86,245.0,373.72,1.92,32.0,91154.0 +2015-08-01 00:00:00+00:00,30.12,48.22,132.0,0.0,132.0,372.07,1.8,102.0,91458.0 +2015-08-01 01:00:00+00:00,29.27,52.77,72.0,0.0,72.0,370.42,1.68,82.0,91455.0 +2015-08-01 02:00:00+00:00,28.43,57.33,12.0,0.0,12.0,368.77,1.56,62.0,91452.0 +2015-08-01 03:00:00+00:00,27.58,61.89,0.0,0.0,0.0,367.12,1.44,64.0,91485.0 +2015-08-01 04:00:00+00:00,26.74,66.45,0.0,0.0,0.0,365.47,1.31,67.0,91518.0 +2015-08-01 05:00:00+00:00,25.89,71.0,0.0,0.0,0.0,363.82,1.19,70.0,91551.0 +2015-08-01 06:00:00+00:00,25.05,75.56,0.0,0.0,0.0,362.17,1.07,73.0,91509.0 +2015-08-01 07:00:00+00:00,24.2,80.12,0.0,0.0,0.0,360.52,0.95,76.0,91467.0 +2015-08-01 08:00:00+00:00,24.25,86.5,0.0,0.0,0.0,358.2,0.36,79.0,91425.0 +2015-08-01 09:00:00+00:00,23.75,89.06,0.0,0.0,0.0,357.27,0.9,78.0,91410.0 +2015-08-01 10:00:00+00:00,23.25,91.63,0.0,0.0,0.0,356.33,1.44,78.0,91394.0 +2015-08-01 11:00:00+00:00,22.76,94.19,0.0,0.0,0.0,355.4,1.99,78.0,91379.0 +2015-08-01 12:00:00+00:00,23.84,87.29,0.0,0.0,0.0,357.82,1.46,87.0,91410.0 +2015-08-01 13:00:00+00:00,24.93,80.38,29.0,154.53,20.0,360.23,0.94,97.0,91440.0 +2015-08-01 14:00:00+00:00,26.02,73.48,207.0,543.32,61.0,362.65,0.41,106.0,91470.0 +2015-08-01 15:00:00+00:00,27.08,66.65,419.0,711.75,83.0,367.95,0.67,133.0,91452.0 +2015-08-01 16:00:00+00:00,28.13,59.83,621.0,799.13,98.0,373.25,0.93,159.0,91434.0 +2015-08-01 17:00:00+00:00,29.19,53.0,791.0,851.34,107.0,378.55,1.19,186.0,91416.0 +2015-08-01 18:00:00+00:00,29.37,53.89,613.0,161.74,466.0,375.15,1.24,200.0,91391.0 +2015-08-01 19:00:00+00:00,29.56,54.78,897.0,467.02,447.0,371.75,1.29,214.0,91367.0 +2015-08-01 20:00:00+00:00,29.75,55.67,978.0,893.37,117.0,368.35,1.34,227.0,91343.0 +2015-08-01 21:00:00+00:00,29.63,54.59,916.0,881.81,114.0,371.03,1.19,234.0,91301.0 +2015-08-01 22:00:00+00:00,29.5,53.52,649.0,362.98,357.0,373.72,1.04,242.0,91259.0 +2015-08-01 23:00:00+00:00,29.38,52.44,27.0,0.0,27.0,376.4,0.9,249.0,91217.0 +2015-08-02 00:00:00+00:00,29.35,55.51,272.0,146.31,203.0,371.93,1.11,225.0,91181.0 +2015-08-02 01:00:00+00:00,29.33,58.58,143.0,152.95,102.0,367.47,1.32,201.0,91145.0 +2015-08-02 02:00:00+00:00,29.31,61.65,25.0,87.28,20.0,363.0,1.53,177.0,91109.0 +2015-08-02 03:00:00+00:00,28.18,66.53,0.0,0.0,0.0,361.48,1.49,172.0,91139.0 +2015-08-02 04:00:00+00:00,27.05,71.42,0.0,0.0,0.0,359.97,1.45,167.0,91169.0 +2015-08-02 05:00:00+00:00,25.92,76.3,0.0,0.0,0.0,358.45,1.41,162.0,91199.0 +2015-08-02 06:00:00+00:00,25.41,79.74,0.0,0.0,0.0,357.47,1.68,160.0,91169.0 +2015-08-02 07:00:00+00:00,24.91,83.17,0.0,0.0,0.0,356.48,1.96,159.0,91139.0 +2015-08-02 08:00:00+00:00,24.41,86.61,0.0,0.0,0.0,355.5,2.23,157.0,91109.0 +2015-08-02 09:00:00+00:00,23.83,87.06,0.0,0.0,0.0,353.9,2.32,158.0,91094.0 +2015-08-02 10:00:00+00:00,23.25,87.52,0.0,0.0,0.0,352.3,2.4,158.0,91079.0 +2015-08-02 11:00:00+00:00,22.67,87.97,0.0,0.0,0.0,350.7,2.48,158.0,91064.0 +2015-08-02 12:00:00+00:00,24.17,77.46,0.0,0.0,0.0,352.83,2.3,168.0,91127.0 +2015-08-02 13:00:00+00:00,25.67,66.94,29.0,160.48,20.0,354.97,2.11,177.0,91190.0 +2015-08-02 14:00:00+00:00,27.17,56.43,209.0,554.6,61.0,357.1,1.93,186.0,91253.0 +2015-08-02 15:00:00+00:00,28.72,49.15,424.0,722.65,84.0,361.83,1.93,226.0,91259.0 +2015-08-02 16:00:00+00:00,30.27,41.88,630.0,814.56,98.0,366.57,1.93,265.0,91265.0 +2015-08-02 17:00:00+00:00,31.82,34.6,803.0,866.3,108.0,371.3,1.93,305.0,91271.0 +2015-08-02 18:00:00+00:00,32.62,31.71,929.0,897.79,114.0,371.53,2.32,314.0,91214.0 +2015-08-02 19:00:00+00:00,33.42,28.82,703.0,211.95,499.0,371.77,2.71,324.0,91157.0 +2015-08-02 20:00:00+00:00,34.23,25.93,798.0,365.66,446.0,372.0,3.1,333.0,91100.0 +2015-08-02 21:00:00+00:00,34.19,24.37,139.0,4.4,135.0,373.1,2.99,348.0,91046.0 +2015-08-02 22:00:00+00:00,34.15,22.8,807.0,870.48,108.0,374.2,2.87,4.0,90992.0 +2015-08-02 23:00:00+00:00,34.11,21.24,635.0,821.01,98.0,375.3,2.76,19.0,90938.0 +2015-08-03 00:00:00+00:00,33.32,22.44,429.0,734.74,84.0,373.8,2.33,50.0,90929.0 +2015-08-03 01:00:00+00:00,32.54,23.65,213.0,568.33,62.0,372.3,1.9,81.0,90920.0 +2015-08-03 02:00:00+00:00,31.76,24.85,30.0,183.1,20.0,370.8,1.48,112.0,90911.0 +2015-08-03 03:00:00+00:00,29.98,29.02,0.0,0.0,0.0,367.7,1.97,118.0,90956.0 +2015-08-03 04:00:00+00:00,28.21,33.2,0.0,0.0,0.0,364.6,2.46,123.0,91001.0 +2015-08-03 05:00:00+00:00,26.44,37.37,0.0,0.0,0.0,361.5,2.95,129.0,91046.0 +2015-08-03 06:00:00+00:00,25.77,38.93,0.0,0.0,0.0,359.02,2.64,134.0,91049.0 +2015-08-03 07:00:00+00:00,25.1,40.48,0.0,0.0,0.0,356.53,2.34,139.0,91052.0 +2015-08-03 08:00:00+00:00,24.43,42.04,0.0,0.0,0.0,354.05,2.03,144.0,91055.0 +2015-08-03 09:00:00+00:00,24.05,43.73,0.0,0.0,0.0,351.87,1.86,146.0,91070.0 +2015-08-03 10:00:00+00:00,23.67,45.42,0.0,0.0,0.0,349.68,1.7,148.0,91085.0 +2015-08-03 11:00:00+00:00,23.3,47.11,0.0,0.0,0.0,347.5,1.53,149.0,91100.0 +2015-08-03 12:00:00+00:00,24.96,43.3,0.0,0.0,0.0,351.58,1.55,166.0,91154.0 +2015-08-03 13:00:00+00:00,26.63,39.49,28.0,166.94,19.0,355.67,1.58,182.0,91208.0 +2015-08-03 14:00:00+00:00,28.3,35.68,210.0,562.29,61.0,359.75,1.6,199.0,91262.0 +2015-08-03 15:00:00+00:00,29.98,30.57,426.0,729.37,84.0,364.32,1.93,248.0,91259.0 +2015-08-03 16:00:00+00:00,31.67,25.46,633.0,820.87,98.0,368.88,2.26,298.0,91256.0 +2015-08-03 17:00:00+00:00,33.35,20.35,806.0,871.34,108.0,373.45,2.59,347.0,91253.0 +2015-08-03 18:00:00+00:00,34.17,19.19,932.0,901.08,115.0,374.83,2.5,356.0,91187.0 +2015-08-03 19:00:00+00:00,34.99,18.04,998.0,915.32,118.0,376.22,2.4,4.0,91121.0 +2015-08-03 20:00:00+00:00,35.81,16.88,998.0,915.24,118.0,377.6,2.3,13.0,91055.0 +2015-08-03 21:00:00+00:00,35.84,16.64,934.0,903.02,115.0,378.03,2.56,20.0,90995.0 +2015-08-03 22:00:00+00:00,35.86,16.39,811.0,877.11,108.0,378.47,2.81,27.0,90935.0 +2015-08-03 23:00:00+00:00,35.89,16.15,638.0,826.3,99.0,378.9,3.06,34.0,90875.0 +2015-08-04 00:00:00+00:00,35.23,17.16,432.0,744.52,84.0,372.78,2.69,70.0,90881.0 +2015-08-04 01:00:00+00:00,34.58,18.17,214.0,577.41,62.0,366.67,2.32,107.0,90887.0 +2015-08-04 02:00:00+00:00,33.93,19.18,29.0,173.54,20.0,360.55,1.94,144.0,90893.0 +2015-08-04 03:00:00+00:00,31.93,22.15,0.0,0.0,0.0,357.6,1.82,154.0,90938.0 +2015-08-04 04:00:00+00:00,29.93,25.12,0.0,0.0,0.0,354.65,1.7,164.0,90983.0 +2015-08-04 05:00:00+00:00,27.93,28.09,0.0,0.0,0.0,351.7,1.57,175.0,91028.0 +2015-08-04 06:00:00+00:00,27.89,32.11,0.0,0.0,0.0,349.77,1.57,191.0,91043.0 +2015-08-04 07:00:00+00:00,27.85,36.13,0.0,0.0,0.0,347.83,1.56,207.0,91058.0 +2015-08-04 08:00:00+00:00,27.81,40.15,0.0,0.0,0.0,345.9,1.56,222.0,91073.0 +2015-08-04 09:00:00+00:00,27.13,43.41,0.0,0.0,0.0,344.92,1.53,241.0,91094.0 +2015-08-04 10:00:00+00:00,26.46,46.66,0.0,0.0,0.0,343.93,1.49,259.0,91115.0 +2015-08-04 11:00:00+00:00,25.79,49.92,0.0,0.0,0.0,342.95,1.46,278.0,91136.0 +2015-08-04 12:00:00+00:00,26.76,46.99,0.0,0.0,0.0,343.95,1.1,284.0,91199.0 +2015-08-04 13:00:00+00:00,27.74,44.05,27.0,154.64,19.0,344.95,0.74,289.0,91262.0 +2015-08-04 14:00:00+00:00,28.71,41.12,211.0,570.09,61.0,345.95,0.37,295.0,91325.0 +2015-08-04 15:00:00+00:00,30.7,34.92,428.0,736.15,84.0,351.2,1.05,310.0,91304.0 +2015-08-04 16:00:00+00:00,32.7,28.72,634.0,824.15,98.0,356.45,1.72,326.0,91283.0 +2015-08-04 17:00:00+00:00,34.69,22.52,805.0,871.41,108.0,361.7,2.4,341.0,91262.0 +2015-08-04 18:00:00+00:00,35.87,20.57,928.0,898.89,114.0,366.58,2.57,342.0,91202.0 +2015-08-04 19:00:00+00:00,37.06,18.61,991.0,910.15,117.0,371.47,2.73,343.0,91142.0 +2015-08-04 20:00:00+00:00,38.25,16.66,990.0,909.09,117.0,376.35,2.9,344.0,91082.0 +2015-08-04 21:00:00+00:00,38.18,16.5,925.0,895.53,114.0,383.25,3.3,342.0,91040.0 +2015-08-04 22:00:00+00:00,38.1,16.33,801.0,866.33,108.0,390.15,3.71,340.0,90998.0 +2015-08-04 23:00:00+00:00,38.03,16.17,629.0,816.33,98.0,397.05,4.11,337.0,90956.0 +2015-08-05 00:00:00+00:00,36.83,17.64,424.0,730.87,84.0,390.82,3.54,328.0,90965.0 +2015-08-05 01:00:00+00:00,35.63,19.12,208.0,563.84,61.0,384.58,2.98,319.0,90974.0 +2015-08-05 02:00:00+00:00,34.43,20.59,27.0,163.18,19.0,378.35,2.41,310.0,90983.0 +2015-08-05 03:00:00+00:00,32.89,23.6,0.0,0.0,0.0,373.9,1.99,305.0,91025.0 +2015-08-05 04:00:00+00:00,31.35,26.61,0.0,0.0,0.0,369.45,1.57,300.0,91067.0 +2015-08-05 05:00:00+00:00,29.81,29.62,0.0,0.0,0.0,365.0,1.14,296.0,91109.0 +2015-08-05 06:00:00+00:00,29.8,32.24,0.0,0.0,0.0,361.8,1.47,287.0,91127.0 +2015-08-05 07:00:00+00:00,29.8,34.87,0.0,0.0,0.0,358.6,1.8,279.0,91145.0 +2015-08-05 08:00:00+00:00,29.8,37.49,0.0,0.0,0.0,355.4,2.12,271.0,91163.0 +2015-08-05 09:00:00+00:00,29.26,39.13,0.0,0.0,0.0,353.22,1.83,273.0,91178.0 +2015-08-05 10:00:00+00:00,28.72,40.77,0.0,0.0,0.0,351.03,1.53,275.0,91193.0 +2015-08-05 11:00:00+00:00,28.18,42.41,0.0,0.0,0.0,348.85,1.23,277.0,91208.0 +2015-08-05 12:00:00+00:00,28.68,42.58,0.0,0.0,0.0,350.57,0.94,283.0,91277.0 +2015-08-05 13:00:00+00:00,29.18,42.74,21.0,0.0,21.0,352.28,0.65,289.0,91346.0 +2015-08-05 14:00:00+00:00,29.68,42.91,171.0,336.86,83.0,354.0,0.36,294.0,91416.0 +2015-08-05 15:00:00+00:00,31.55,36.75,357.0,423.03,160.0,358.63,1.22,310.0,91394.0 +2015-08-05 16:00:00+00:00,33.41,30.59,537.0,469.97,232.0,363.27,2.09,325.0,91373.0 +2015-08-05 17:00:00+00:00,35.28,24.43,798.0,863.99,108.0,367.9,2.95,341.0,91352.0 +2015-08-05 18:00:00+00:00,36.41,22.32,842.0,508.62,382.0,369.5,3.01,339.0,91277.0 +2015-08-05 19:00:00+00:00,37.55,20.2,917.0,643.3,300.0,371.1,3.06,338.0,91202.0 +2015-08-05 20:00:00+00:00,38.69,18.09,981.0,900.89,117.0,372.7,3.12,337.0,91127.0 +2015-08-05 21:00:00+00:00,38.6,17.84,584.0,163.68,436.0,380.05,3.54,333.0,91076.0 +2015-08-05 22:00:00+00:00,38.51,17.59,791.0,856.83,107.0,387.4,3.96,330.0,91025.0 +2015-08-05 23:00:00+00:00,38.42,17.34,619.0,804.86,97.0,394.75,4.39,326.0,90974.0 +2015-08-06 00:00:00+00:00,36.99,18.86,415.0,717.21,83.0,390.0,3.67,314.0,90962.0 +2015-08-06 01:00:00+00:00,35.56,20.38,201.0,546.31,60.0,385.25,2.96,303.0,90950.0 +2015-08-06 02:00:00+00:00,34.14,21.9,14.0,0.0,14.0,380.5,2.25,291.0,90938.0 +2015-08-06 03:00:00+00:00,33.12,25.59,0.0,0.0,0.0,376.85,2.05,288.0,90974.0 +2015-08-06 04:00:00+00:00,32.11,29.28,0.0,0.0,0.0,373.2,1.84,286.0,91010.0 +2015-08-06 05:00:00+00:00,31.1,32.97,0.0,0.0,0.0,369.55,1.64,283.0,91046.0 +2015-08-06 06:00:00+00:00,30.71,37.41,0.0,0.0,0.0,365.7,1.75,281.0,91049.0 +2015-08-06 07:00:00+00:00,30.32,41.84,0.0,0.0,0.0,361.85,1.85,280.0,91052.0 +2015-08-06 08:00:00+00:00,29.93,46.28,0.0,0.0,0.0,358.0,1.96,278.0,91055.0 +2015-08-06 09:00:00+00:00,29.53,49.25,0.0,0.0,0.0,355.82,2.0,278.0,91064.0 +2015-08-06 10:00:00+00:00,29.13,52.21,0.0,0.0,0.0,353.63,2.03,277.0,91073.0 +2015-08-06 11:00:00+00:00,28.74,55.18,0.0,0.0,0.0,351.45,2.07,277.0,91082.0 +2015-08-06 12:00:00+00:00,29.17,54.48,0.0,0.0,0.0,358.82,2.01,286.0,91187.0 +2015-08-06 13:00:00+00:00,29.6,53.79,8.0,0.0,8.0,366.18,1.95,295.0,91292.0 +2015-08-06 14:00:00+00:00,30.03,53.09,71.0,0.0,71.0,373.55,1.89,303.0,91397.0 +2015-08-06 15:00:00+00:00,31.49,48.23,7.0,0.0,7.0,376.8,1.96,315.0,91367.0 +2015-08-06 16:00:00+00:00,32.95,43.38,81.0,0.0,81.0,380.05,2.04,327.0,91337.0 +2015-08-06 17:00:00+00:00,34.41,38.52,241.0,13.8,230.0,383.3,2.11,339.0,91307.0 +2015-08-06 18:00:00+00:00,34.9,36.6,204.0,11.07,194.0,384.18,2.43,331.0,91250.0 +2015-08-06 19:00:00+00:00,35.4,34.69,176.0,9.4,167.0,385.07,2.75,324.0,91193.0 +2015-08-06 20:00:00+00:00,35.9,32.77,346.0,25.06,322.0,385.95,3.08,316.0,91136.0 +2015-08-06 21:00:00+00:00,35.09,35.0,368.0,25.48,345.0,386.18,2.82,304.0,91142.0 +2015-08-06 22:00:00+00:00,34.28,37.24,611.0,296.26,375.0,386.42,2.56,291.0,91148.0 +2015-08-06 23:00:00+00:00,33.47,39.47,617.0,804.23,97.0,386.65,2.3,278.0,91154.0 +2015-08-07 00:00:00+00:00,33.06,37.71,412.0,716.56,82.0,382.87,2.36,261.0,91070.0 +2015-08-07 01:00:00+00:00,32.66,35.94,198.0,540.32,60.0,379.08,2.42,245.0,90986.0 +2015-08-07 02:00:00+00:00,32.26,34.18,22.0,115.99,17.0,375.3,2.48,228.0,90902.0 +2015-08-07 03:00:00+00:00,31.84,37.61,0.0,0.0,0.0,375.3,2.57,234.0,90956.0 +2015-08-07 04:00:00+00:00,31.42,41.03,0.0,0.0,0.0,375.3,2.65,240.0,91010.0 +2015-08-07 05:00:00+00:00,31.0,44.46,0.0,0.0,0.0,375.3,2.73,247.0,91064.0 +2015-08-07 06:00:00+00:00,30.19,49.58,0.0,0.0,0.0,372.82,2.51,252.0,91088.0 +2015-08-07 07:00:00+00:00,29.38,54.7,0.0,0.0,0.0,370.33,2.29,258.0,91112.0 +2015-08-07 08:00:00+00:00,28.58,59.82,0.0,0.0,0.0,367.85,2.07,264.0,91136.0 +2015-08-07 09:00:00+00:00,28.11,62.45,0.0,0.0,0.0,369.93,2.17,263.0,91142.0 +2015-08-07 10:00:00+00:00,27.64,65.07,0.0,0.0,0.0,372.02,2.28,262.0,91148.0 +2015-08-07 11:00:00+00:00,27.18,67.7,0.0,0.0,0.0,374.1,2.39,261.0,91154.0 +2015-08-07 12:00:00+00:00,26.72,68.47,0.0,0.0,0.0,374.35,2.07,258.0,91217.0 +2015-08-07 13:00:00+00:00,26.27,69.23,12.0,0.0,12.0,374.6,1.76,255.0,91280.0 +2015-08-07 14:00:00+00:00,25.82,70.0,30.0,0.0,30.0,374.85,1.45,252.0,91343.0 +2015-08-07 15:00:00+00:00,27.67,63.74,349.0,402.21,163.0,376.2,1.87,249.0,91316.0 +2015-08-07 16:00:00+00:00,29.53,57.48,412.0,171.78,301.0,377.55,2.29,246.0,91289.0 +2015-08-07 17:00:00+00:00,31.38,51.22,783.0,849.15,107.0,378.9,2.72,242.0,91262.0 +2015-08-07 18:00:00+00:00,30.48,54.58,904.0,876.94,113.0,380.88,2.76,243.0,91247.0 +2015-08-07 19:00:00+00:00,29.58,57.94,967.0,889.53,116.0,382.87,2.8,244.0,91232.0 +2015-08-07 20:00:00+00:00,28.68,61.3,966.0,888.73,116.0,384.85,2.84,245.0,91217.0 +2015-08-07 21:00:00+00:00,28.4,65.33,902.0,875.49,113.0,382.55,2.89,246.0,91202.0 +2015-08-07 22:00:00+00:00,28.11,69.36,779.0,845.46,107.0,380.25,2.94,248.0,91187.0 +2015-08-07 23:00:00+00:00,27.83,73.39,608.0,792.83,97.0,377.95,2.99,249.0,91172.0 +2015-08-08 00:00:00+00:00,27.62,73.25,8.0,0.0,8.0,379.7,2.57,245.0,91178.0 +2015-08-08 01:00:00+00:00,27.41,73.12,133.0,146.46,96.0,381.45,2.16,241.0,91184.0 +2015-08-08 02:00:00+00:00,27.2,72.98,9.0,0.0,9.0,383.2,1.74,237.0,91190.0 +2015-08-08 03:00:00+00:00,26.82,75.4,0.0,0.0,0.0,384.83,1.28,228.0,91214.0 +2015-08-08 04:00:00+00:00,26.44,77.81,0.0,0.0,0.0,386.47,0.82,219.0,91238.0 +2015-08-08 05:00:00+00:00,26.06,80.23,0.0,0.0,0.0,388.1,0.36,209.0,91262.0 +2015-08-08 06:00:00+00:00,25.74,82.98,0.0,0.0,0.0,391.28,0.56,211.0,91244.0 +2015-08-08 07:00:00+00:00,25.42,85.72,0.0,0.0,0.0,394.47,0.75,213.0,91226.0 +2015-08-08 08:00:00+00:00,25.11,88.47,0.0,0.0,0.0,397.65,0.95,215.0,91208.0 +2015-08-08 09:00:00+00:00,24.54,90.41,0.0,0.0,0.0,392.65,1.21,214.0,91208.0 +2015-08-08 10:00:00+00:00,23.98,92.35,0.0,0.0,0.0,387.65,1.47,214.0,91208.0 +2015-08-08 11:00:00+00:00,23.42,94.29,0.0,0.0,0.0,382.65,1.72,213.0,91208.0 +2015-08-08 12:00:00+00:00,23.78,93.24,0.0,0.0,0.0,388.65,1.59,237.0,91277.0 +2015-08-08 13:00:00+00:00,24.15,92.2,21.0,0.0,21.0,394.65,1.45,262.0,91346.0 +2015-08-08 14:00:00+00:00,24.52,91.15,195.0,532.17,59.0,400.65,1.31,286.0,91416.0 +2015-08-08 15:00:00+00:00,25.01,83.88,409.0,709.61,82.0,393.73,1.26,268.0,91406.0 +2015-08-08 16:00:00+00:00,25.51,76.62,614.0,801.88,97.0,386.82,1.2,250.0,91397.0 +2015-08-08 17:00:00+00:00,26.0,69.35,786.0,854.31,107.0,379.9,1.14,232.0,91388.0 +2015-08-08 18:00:00+00:00,26.57,65.18,910.0,884.81,113.0,380.0,1.5,238.0,91352.0 +2015-08-08 19:00:00+00:00,27.15,61.01,975.0,899.09,116.0,380.1,1.86,244.0,91316.0 +2015-08-08 20:00:00+00:00,27.73,56.84,742.0,271.2,483.0,380.2,2.22,250.0,91280.0 +2015-08-08 21:00:00+00:00,27.8,54.94,912.0,888.14,113.0,380.75,2.68,254.0,91265.0 +2015-08-08 22:00:00+00:00,27.87,53.05,91.0,0.0,91.0,381.3,3.14,257.0,91250.0 +2015-08-08 23:00:00+00:00,27.94,51.15,97.0,0.0,97.0,381.85,3.6,260.0,91235.0 +2015-08-09 00:00:00+00:00,26.57,58.84,404.0,691.47,89.0,376.75,2.94,216.0,91235.0 +2015-08-09 01:00:00+00:00,25.21,66.52,117.0,88.08,95.0,371.65,2.28,171.0,91235.0 +2015-08-09 02:00:00+00:00,23.85,74.21,0.0,0.0,0.0,366.55,1.61,127.0,91235.0 +2015-08-09 03:00:00+00:00,23.57,78.88,0.0,0.0,0.0,366.13,1.75,131.0,91265.0 +2015-08-09 04:00:00+00:00,23.29,83.56,0.0,0.0,0.0,365.72,1.89,135.0,91295.0 +2015-08-09 05:00:00+00:00,23.02,88.23,0.0,0.0,0.0,365.3,2.03,140.0,91325.0 +2015-08-09 06:00:00+00:00,22.8,90.41,0.0,0.0,0.0,361.37,2.02,137.0,91316.0 +2015-08-09 07:00:00+00:00,22.58,92.58,0.0,0.0,0.0,357.43,2.02,134.0,91307.0 +2015-08-09 08:00:00+00:00,22.37,94.76,0.0,0.0,0.0,353.5,2.01,131.0,91298.0 +2015-08-09 09:00:00+00:00,21.89,95.8,0.0,0.0,0.0,352.37,1.85,122.0,91304.0 +2015-08-09 10:00:00+00:00,21.41,96.83,0.0,0.0,0.0,351.23,1.69,114.0,91310.0 +2015-08-09 11:00:00+00:00,20.94,97.87,0.0,0.0,0.0,350.1,1.53,105.0,91316.0 +2015-08-09 12:00:00+00:00,22.64,87.08,0.0,0.0,0.0,353.98,1.43,98.0,91361.0 +2015-08-09 13:00:00+00:00,24.35,76.29,20.0,122.69,15.0,357.87,1.32,91.0,91406.0 +2015-08-09 14:00:00+00:00,26.06,65.5,195.0,536.16,59.0,361.75,1.21,84.0,91452.0 +2015-08-09 15:00:00+00:00,27.07,55.39,409.0,712.15,82.0,365.95,1.49,82.0,91425.0 +2015-08-09 16:00:00+00:00,28.08,45.27,614.0,803.67,97.0,370.15,1.76,80.0,91397.0 +2015-08-09 17:00:00+00:00,29.09,35.16,787.0,856.98,107.0,374.35,2.03,78.0,91370.0 +2015-08-09 18:00:00+00:00,29.66,34.64,910.0,886.06,113.0,376.97,1.89,36.0,91343.0 +2015-08-09 19:00:00+00:00,30.24,34.11,974.0,898.23,117.0,379.58,1.75,355.0,91316.0 +2015-08-09 20:00:00+00:00,30.82,33.59,872.0,445.68,447.0,382.2,1.61,314.0,91289.0 +2015-08-09 21:00:00+00:00,30.36,34.04,909.0,886.42,113.0,382.73,2.19,315.0,91271.0 +2015-08-09 22:00:00+00:00,29.9,34.5,28.0,0.0,28.0,383.27,2.76,317.0,91253.0 +2015-08-09 23:00:00+00:00,29.44,34.95,156.0,3.12,154.0,383.8,3.34,319.0,91235.0 +2015-08-10 00:00:00+00:00,29.12,35.14,91.0,0.0,91.0,380.38,3.08,265.0,91202.0 +2015-08-10 01:00:00+00:00,28.8,35.33,39.0,0.0,39.0,376.97,2.82,212.0,91169.0 +2015-08-10 02:00:00+00:00,28.49,35.52,1.0,0.0,1.0,373.55,2.57,159.0,91136.0 +2015-08-10 03:00:00+00:00,27.77,40.46,0.0,0.0,0.0,372.47,2.51,160.0,91187.0 +2015-08-10 04:00:00+00:00,27.06,45.39,0.0,0.0,0.0,371.38,2.45,162.0,91238.0 +2015-08-10 05:00:00+00:00,26.35,50.33,0.0,0.0,0.0,370.3,2.39,163.0,91289.0 +2015-08-10 06:00:00+00:00,25.8,53.21,0.0,0.0,0.0,368.4,2.02,164.0,91292.0 +2015-08-10 07:00:00+00:00,25.26,56.08,0.0,0.0,0.0,366.5,1.65,164.0,91295.0 +2015-08-10 08:00:00+00:00,24.72,58.96,0.0,0.0,0.0,364.6,1.28,165.0,91298.0 +2015-08-10 09:00:00+00:00,24.08,60.65,0.0,0.0,0.0,363.35,1.21,140.0,91301.0 +2015-08-10 10:00:00+00:00,23.44,62.34,0.0,0.0,0.0,362.1,1.14,114.0,91304.0 +2015-08-10 11:00:00+00:00,22.8,64.03,0.0,0.0,0.0,360.85,1.06,89.0,91307.0 +2015-08-10 12:00:00+00:00,23.61,65.01,0.0,0.0,0.0,363.55,0.8,77.0,91367.0 +2015-08-10 13:00:00+00:00,24.43,66.0,5.0,0.0,5.0,366.25,0.53,66.0,91428.0 +2015-08-10 14:00:00+00:00,25.25,66.98,53.0,0.0,53.0,368.95,0.26,55.0,91488.0 +2015-08-10 15:00:00+00:00,26.91,58.82,262.0,146.44,195.0,369.73,0.92,61.0,91443.0 +2015-08-10 16:00:00+00:00,28.57,50.67,605.0,791.47,97.0,370.52,1.58,67.0,91397.0 +2015-08-10 17:00:00+00:00,30.23,42.51,661.0,427.95,322.0,371.3,2.23,73.0,91352.0 +2015-08-10 18:00:00+00:00,30.32,40.7,720.0,313.96,438.0,374.18,2.0,94.0,91292.0 +2015-08-10 19:00:00+00:00,30.42,38.88,865.0,567.83,324.0,377.07,1.76,115.0,91232.0 +2015-08-10 20:00:00+00:00,30.52,37.07,959.0,885.41,116.0,379.95,1.52,136.0,91172.0 +2015-08-10 21:00:00+00:00,29.82,39.99,894.0,872.48,112.0,378.43,1.23,147.0,91175.0 +2015-08-10 22:00:00+00:00,29.13,42.9,139.0,3.8,136.0,376.92,0.95,158.0,91178.0 +2015-08-10 23:00:00+00:00,28.43,45.82,249.0,23.51,234.0,375.4,0.66,169.0,91181.0 +2015-08-11 00:00:00+00:00,28.2,44.09,146.0,4.44,144.0,372.55,1.29,143.0,91169.0 +2015-08-11 01:00:00+00:00,27.97,42.36,101.0,45.12,90.0,369.7,1.92,117.0,91157.0 +2015-08-11 02:00:00+00:00,27.75,40.63,7.0,0.0,7.0,366.85,2.55,91.0,91145.0 +2015-08-11 03:00:00+00:00,27.13,45.47,0.0,0.0,0.0,364.8,2.24,86.0,91181.0 +2015-08-11 04:00:00+00:00,26.52,50.3,0.0,0.0,0.0,362.75,1.93,80.0,91217.0 +2015-08-11 05:00:00+00:00,25.91,55.14,0.0,0.0,0.0,360.7,1.61,75.0,91253.0 +2015-08-11 06:00:00+00:00,25.35,59.06,0.0,0.0,0.0,359.52,1.65,74.0,91235.0 +2015-08-11 07:00:00+00:00,24.8,62.98,0.0,0.0,0.0,358.33,1.69,73.0,91217.0 +2015-08-11 08:00:00+00:00,24.25,66.9,0.0,0.0,0.0,357.15,1.72,72.0,91199.0 +2015-08-11 09:00:00+00:00,23.62,70.33,0.0,0.0,0.0,356.47,1.86,72.0,91205.0 +2015-08-11 10:00:00+00:00,22.99,73.76,0.0,0.0,0.0,355.78,1.99,73.0,91211.0 +2015-08-11 11:00:00+00:00,22.37,77.19,0.0,0.0,0.0,355.1,2.12,74.0,91217.0 +2015-08-11 12:00:00+00:00,23.91,67.5,0.0,0.0,0.0,354.57,1.87,71.0,91271.0 +2015-08-11 13:00:00+00:00,25.46,57.81,13.0,0.0,13.0,354.03,1.61,68.0,91325.0 +2015-08-11 14:00:00+00:00,27.0,48.12,30.0,0.0,30.0,353.5,1.35,64.0,91379.0 +2015-08-11 15:00:00+00:00,28.7,42.62,88.0,0.0,88.0,356.47,1.78,75.0,91355.0 +2015-08-11 16:00:00+00:00,30.4,37.11,136.0,0.0,136.0,359.43,2.21,86.0,91331.0 +2015-08-11 17:00:00+00:00,32.1,31.61,419.0,68.29,365.0,362.4,2.63,97.0,91307.0 +2015-08-11 18:00:00+00:00,32.36,30.45,644.0,208.51,457.0,364.52,2.63,111.0,91262.0 +2015-08-11 19:00:00+00:00,32.62,29.28,963.0,890.31,116.0,366.63,2.62,126.0,91217.0 +2015-08-11 20:00:00+00:00,32.89,28.12,517.0,65.22,455.0,368.75,2.61,140.0,91172.0 +2015-08-11 21:00:00+00:00,32.56,29.52,422.0,49.19,378.0,372.17,2.32,163.0,91166.0 +2015-08-11 22:00:00+00:00,32.22,30.92,535.0,215.98,365.0,375.58,2.03,185.0,91160.0 +2015-08-11 23:00:00+00:00,31.89,32.32,603.0,797.72,96.0,379.0,1.74,208.0,91154.0 +2015-08-12 00:00:00+00:00,31.44,40.08,399.0,710.62,81.0,377.28,1.43,225.0,91154.0 +2015-08-12 01:00:00+00:00,30.99,47.83,185.0,527.57,58.0,375.57,1.12,243.0,91154.0 +2015-08-12 02:00:00+00:00,30.54,55.59,15.0,0.0,15.0,373.85,0.81,260.0,91154.0 +2015-08-12 03:00:00+00:00,30.3,59.68,0.0,0.0,0.0,372.18,0.93,290.0,91199.0 +2015-08-12 04:00:00+00:00,30.07,63.77,0.0,0.0,0.0,370.52,1.05,320.0,91244.0 +2015-08-12 05:00:00+00:00,29.84,67.86,0.0,0.0,0.0,368.85,1.17,350.0,91289.0 +2015-08-12 06:00:00+00:00,28.55,70.56,0.0,0.0,0.0,367.57,1.19,19.0,91295.0 +2015-08-12 07:00:00+00:00,27.26,73.26,0.0,0.0,0.0,366.28,1.21,49.0,91301.0 +2015-08-12 08:00:00+00:00,25.97,75.96,0.0,0.0,0.0,365.0,1.23,79.0,91307.0 +2015-08-12 09:00:00+00:00,25.13,79.02,0.0,0.0,0.0,362.6,1.57,77.0,91304.0 +2015-08-12 10:00:00+00:00,24.3,82.07,0.0,0.0,0.0,360.2,1.92,76.0,91301.0 +2015-08-12 11:00:00+00:00,23.47,85.13,0.0,0.0,0.0,357.8,2.26,75.0,91298.0 +2015-08-12 12:00:00+00:00,24.72,75.78,0.0,0.0,0.0,355.38,2.24,77.0,91379.0 +2015-08-12 13:00:00+00:00,25.97,66.42,17.0,0.0,17.0,352.97,2.23,79.0,91461.0 +2015-08-12 14:00:00+00:00,27.22,57.07,172.0,411.41,70.0,350.55,2.21,81.0,91542.0 +2015-08-12 15:00:00+00:00,29.61,47.89,402.0,704.52,82.0,354.13,2.13,93.0,91518.0 +2015-08-12 16:00:00+00:00,31.99,38.72,607.0,798.25,97.0,357.72,2.06,104.0,91494.0 +2015-08-12 17:00:00+00:00,34.38,29.54,778.0,850.0,107.0,361.3,1.99,115.0,91470.0 +2015-08-12 18:00:00+00:00,35.19,27.61,901.0,879.96,113.0,364.05,2.09,122.0,91406.0 +2015-08-12 19:00:00+00:00,36.0,25.69,879.0,464.25,438.0,366.8,2.2,129.0,91343.0 +2015-08-12 20:00:00+00:00,36.82,23.76,817.0,405.7,432.0,369.55,2.3,136.0,91280.0 +2015-08-12 21:00:00+00:00,36.56,24.2,242.0,13.44,230.0,374.62,2.21,136.0,91250.0 +2015-08-12 22:00:00+00:00,36.29,24.64,77.0,0.0,77.0,379.68,2.12,137.0,91220.0 +2015-08-12 23:00:00+00:00,36.03,25.08,489.0,356.96,263.0,384.75,2.03,137.0,91190.0 +2015-08-13 00:00:00+00:00,34.31,29.6,15.0,0.0,15.0,380.1,1.56,182.0,91211.0 +2015-08-13 01:00:00+00:00,32.59,34.12,3.0,0.0,3.0,375.45,1.09,227.0,91232.0 +2015-08-13 02:00:00+00:00,30.87,38.64,0.0,0.0,0.0,370.8,0.62,271.0,91253.0 +2015-08-13 03:00:00+00:00,31.28,39.65,0.0,0.0,0.0,366.28,0.64,307.0,91289.0 +2015-08-13 04:00:00+00:00,31.69,40.65,0.0,0.0,0.0,361.77,0.67,342.0,91325.0 +2015-08-13 05:00:00+00:00,32.1,41.66,0.0,0.0,0.0,357.25,0.69,17.0,91361.0 +2015-08-13 06:00:00+00:00,30.3,45.47,0.0,0.0,0.0,353.25,0.91,33.0,91352.0 +2015-08-13 07:00:00+00:00,28.5,49.27,0.0,0.0,0.0,349.25,1.14,49.0,91343.0 +2015-08-13 08:00:00+00:00,26.71,53.08,0.0,0.0,0.0,345.25,1.37,64.0,91334.0 +2015-08-13 09:00:00+00:00,25.61,56.09,0.0,0.0,0.0,342.17,1.66,69.0,91325.0 +2015-08-13 10:00:00+00:00,24.52,59.1,0.0,0.0,0.0,339.08,1.95,74.0,91316.0 +2015-08-13 11:00:00+00:00,23.43,62.11,0.0,0.0,0.0,336.0,2.25,79.0,91307.0 +2015-08-13 12:00:00+00:00,25.14,57.24,0.0,0.0,0.0,335.2,2.35,80.0,91358.0 +2015-08-13 13:00:00+00:00,26.85,52.38,13.0,0.0,13.0,334.4,2.45,81.0,91410.0 +2015-08-13 14:00:00+00:00,28.56,47.51,195.0,552.81,59.0,333.6,2.55,82.0,91461.0 +2015-08-13 15:00:00+00:00,31.23,38.99,416.0,735.85,83.0,339.03,2.07,89.0,91431.0 +2015-08-13 16:00:00+00:00,33.89,30.48,625.0,826.79,98.0,344.47,1.6,96.0,91400.0 +2015-08-13 17:00:00+00:00,36.56,21.96,799.0,876.89,108.0,349.9,1.12,103.0,91370.0 +2015-08-13 18:00:00+00:00,37.45,19.28,921.0,902.58,114.0,354.47,1.41,113.0,91298.0 +2015-08-13 19:00:00+00:00,38.34,16.59,982.0,912.02,117.0,359.03,1.71,124.0,91226.0 +2015-08-13 20:00:00+00:00,39.24,13.91,977.0,907.82,117.0,363.6,2.0,134.0,91154.0 +2015-08-13 21:00:00+00:00,38.89,13.85,906.0,890.18,113.0,369.72,2.12,132.0,91106.0 +2015-08-13 22:00:00+00:00,38.55,13.78,778.0,857.16,107.0,375.83,2.25,129.0,91058.0 +2015-08-13 23:00:00+00:00,38.2,13.72,601.0,800.78,96.0,381.95,2.37,127.0,91010.0 +2015-08-14 00:00:00+00:00,36.37,16.46,393.0,706.31,81.0,380.43,1.96,128.0,91043.0 +2015-08-14 01:00:00+00:00,34.54,19.21,178.0,516.42,57.0,378.92,1.55,130.0,91076.0 +2015-08-14 02:00:00+00:00,32.72,21.95,12.0,0.0,12.0,377.4,1.14,131.0,91109.0 +2015-08-14 03:00:00+00:00,32.65,24.43,0.0,0.0,0.0,373.65,1.43,123.0,91175.0 +2015-08-14 04:00:00+00:00,32.59,26.91,0.0,0.0,0.0,369.9,1.71,115.0,91241.0 +2015-08-14 05:00:00+00:00,32.53,29.39,0.0,0.0,0.0,366.15,1.99,107.0,91307.0 +2015-08-14 06:00:00+00:00,31.9,33.41,0.0,0.0,0.0,363.05,1.89,93.0,91313.0 +2015-08-14 07:00:00+00:00,31.28,37.44,0.0,0.0,0.0,359.95,1.78,80.0,91319.0 +2015-08-14 08:00:00+00:00,30.66,41.46,0.0,0.0,0.0,356.85,1.68,66.0,91325.0 +2015-08-14 09:00:00+00:00,29.4,44.31,0.0,0.0,0.0,355.07,1.28,64.0,91337.0 +2015-08-14 10:00:00+00:00,28.14,47.17,0.0,0.0,0.0,353.28,0.88,61.0,91349.0 +2015-08-14 11:00:00+00:00,26.89,50.02,0.0,0.0,0.0,351.5,0.48,59.0,91361.0 +2015-08-14 12:00:00+00:00,28.01,48.6,0.0,0.0,0.0,355.0,0.56,62.0,91385.0 +2015-08-14 13:00:00+00:00,29.14,47.19,12.0,0.0,12.0,358.5,0.64,66.0,91410.0 +2015-08-14 14:00:00+00:00,30.27,45.77,185.0,520.28,58.0,362.0,0.72,69.0,91434.0 +2015-08-14 15:00:00+00:00,32.52,38.22,401.0,707.54,82.0,366.83,1.0,78.0,91410.0 +2015-08-14 16:00:00+00:00,34.78,30.68,607.0,802.02,97.0,371.67,1.28,86.0,91385.0 +2015-08-14 17:00:00+00:00,37.03,23.13,780.0,855.59,107.0,376.5,1.56,94.0,91361.0 +2015-08-14 18:00:00+00:00,37.39,22.01,659.0,233.01,451.0,378.12,1.5,104.0,91319.0 +2015-08-14 19:00:00+00:00,37.75,20.89,968.0,899.76,116.0,379.73,1.45,115.0,91277.0 +2015-08-14 20:00:00+00:00,38.11,19.77,966.0,898.87,116.0,381.35,1.39,125.0,91235.0 +2015-08-14 21:00:00+00:00,37.57,20.99,899.0,884.25,113.0,382.0,1.47,152.0,91214.0 +2015-08-14 22:00:00+00:00,37.03,22.2,491.0,138.36,383.0,382.65,1.54,179.0,91193.0 +2015-08-14 23:00:00+00:00,36.49,23.42,427.0,237.24,278.0,383.3,1.61,206.0,91172.0 +2015-08-15 00:00:00+00:00,35.36,26.11,243.0,127.64,187.0,378.47,1.84,230.0,91163.0 +2015-08-15 01:00:00+00:00,34.23,28.79,176.0,519.53,56.0,373.63,2.06,255.0,91154.0 +2015-08-15 02:00:00+00:00,33.1,31.48,10.0,0.0,10.0,368.8,2.29,280.0,91145.0 +2015-08-15 03:00:00+00:00,32.57,35.29,0.0,0.0,0.0,367.3,1.62,290.0,91187.0 +2015-08-15 04:00:00+00:00,32.05,39.1,0.0,0.0,0.0,365.8,0.96,300.0,91229.0 +2015-08-15 05:00:00+00:00,31.53,42.91,0.0,0.0,0.0,364.3,0.29,310.0,91271.0 +2015-08-15 06:00:00+00:00,31.01,41.6,0.0,0.0,0.0,363.23,0.56,318.0,91259.0 +2015-08-15 07:00:00+00:00,30.49,40.29,0.0,0.0,0.0,362.17,0.83,326.0,91247.0 +2015-08-15 08:00:00+00:00,29.98,38.98,0.0,0.0,0.0,361.1,1.1,333.0,91235.0 +2015-08-15 09:00:00+00:00,29.13,40.01,0.0,0.0,0.0,360.47,1.07,344.0,91232.0 +2015-08-15 10:00:00+00:00,28.28,41.04,0.0,0.0,0.0,359.83,1.04,354.0,91229.0 +2015-08-15 11:00:00+00:00,27.43,42.07,0.0,0.0,0.0,359.2,1.01,5.0,91226.0 +2015-08-15 12:00:00+00:00,28.9,41.69,0.0,0.0,0.0,359.98,1.09,24.0,91253.0 +2015-08-15 13:00:00+00:00,30.38,41.3,12.0,0.0,12.0,360.77,1.17,44.0,91280.0 +2015-08-15 14:00:00+00:00,31.85,40.92,185.0,524.41,58.0,361.55,1.26,63.0,91307.0 +2015-08-15 15:00:00+00:00,33.96,34.65,401.0,710.19,82.0,366.28,1.17,65.0,91274.0 +2015-08-15 16:00:00+00:00,36.07,28.39,608.0,805.52,97.0,371.02,1.08,67.0,91241.0 +2015-08-15 17:00:00+00:00,38.18,22.12,781.0,858.44,107.0,375.75,0.99,69.0,91208.0 +2015-08-15 18:00:00+00:00,39.03,20.06,905.0,888.68,113.0,378.22,0.98,80.0,91130.0 +2015-08-15 19:00:00+00:00,39.89,18.0,968.0,901.25,116.0,380.68,0.97,91.0,91052.0 +2015-08-15 20:00:00+00:00,40.75,15.94,966.0,900.54,116.0,383.15,0.97,102.0,90974.0 +2015-08-15 21:00:00+00:00,40.25,16.19,898.0,885.11,113.0,384.85,1.36,115.0,90938.0 +2015-08-15 22:00:00+00:00,39.75,16.44,772.0,855.75,106.0,386.55,1.76,127.0,90902.0 +2015-08-15 23:00:00+00:00,39.25,16.69,439.0,251.04,282.0,388.25,2.15,140.0,90866.0 +2015-08-16 00:00:00+00:00,37.58,17.31,389.0,706.95,81.0,386.72,1.77,160.0,90863.0 +2015-08-16 01:00:00+00:00,35.92,17.93,26.0,0.0,26.0,385.18,1.39,180.0,90860.0 +2015-08-16 02:00:00+00:00,34.26,18.55,0.0,0.0,0.0,383.65,1.01,200.0,90857.0 +2015-08-16 03:00:00+00:00,33.28,20.47,0.0,0.0,0.0,383.98,1.26,202.0,90920.0 +2015-08-16 04:00:00+00:00,32.3,22.38,0.0,0.0,0.0,384.32,1.5,205.0,90983.0 +2015-08-16 05:00:00+00:00,31.33,24.3,0.0,0.0,0.0,384.65,1.75,207.0,91046.0 +2015-08-16 06:00:00+00:00,30.75,27.45,0.0,0.0,0.0,386.22,2.66,214.0,91076.0 +2015-08-16 07:00:00+00:00,30.17,30.59,0.0,0.0,0.0,387.78,3.56,220.0,91106.0 +2015-08-16 08:00:00+00:00,29.59,33.74,0.0,0.0,0.0,389.35,4.47,226.0,91136.0 +2015-08-16 09:00:00+00:00,28.7,38.16,0.0,0.0,0.0,382.45,3.69,232.0,91163.0 +2015-08-16 10:00:00+00:00,27.82,42.59,0.0,0.0,0.0,375.55,2.91,239.0,91190.0 +2015-08-16 11:00:00+00:00,26.94,47.01,0.0,0.0,0.0,368.65,2.14,245.0,91217.0 +2015-08-16 12:00:00+00:00,27.39,48.97,0.0,0.0,0.0,369.92,1.66,268.0,91286.0 +2015-08-16 13:00:00+00:00,27.85,50.92,1.0,0.0,1.0,371.18,1.18,292.0,91355.0 +2015-08-16 14:00:00+00:00,28.3,52.88,22.0,0.0,22.0,372.45,0.7,315.0,91425.0 +2015-08-16 15:00:00+00:00,30.45,46.03,290.0,239.12,183.0,374.58,1.35,325.0,91394.0 +2015-08-16 16:00:00+00:00,32.6,39.17,602.0,799.58,96.0,376.72,1.99,335.0,91364.0 +2015-08-16 17:00:00+00:00,34.75,32.32,776.0,853.68,107.0,378.85,2.63,345.0,91334.0 +2015-08-16 18:00:00+00:00,35.81,28.96,900.0,884.55,113.0,381.47,2.96,350.0,91241.0 +2015-08-16 19:00:00+00:00,36.87,25.61,964.0,898.54,116.0,384.08,3.29,356.0,91148.0 +2015-08-16 20:00:00+00:00,37.93,22.25,963.0,899.07,116.0,386.7,3.61,1.0,91055.0 +2015-08-16 21:00:00+00:00,37.72,21.78,896.0,884.92,113.0,387.78,3.63,3.0,91001.0 +2015-08-16 22:00:00+00:00,37.51,21.32,769.0,854.51,106.0,388.87,3.64,6.0,90947.0 +2015-08-16 23:00:00+00:00,37.3,20.85,593.0,798.15,96.0,389.95,3.66,8.0,90893.0 +2015-08-17 00:00:00+00:00,36.3,22.24,385.0,705.16,80.0,388.33,3.25,327.0,90872.0 +2015-08-17 01:00:00+00:00,35.3,23.64,169.0,508.69,55.0,386.72,2.85,285.0,90851.0 +2015-08-17 02:00:00+00:00,34.31,25.03,0.0,0.0,0.0,385.1,2.44,244.0,90830.0 +2015-08-17 03:00:00+00:00,33.52,31.34,0.0,0.0,0.0,390.55,2.81,234.0,90911.0 +2015-08-17 04:00:00+00:00,32.73,37.65,0.0,0.0,0.0,396.0,3.18,223.0,90992.0 +2015-08-17 05:00:00+00:00,31.95,43.96,0.0,0.0,0.0,401.45,3.54,212.0,91073.0 +2015-08-17 06:00:00+00:00,31.25,48.77,0.0,0.0,0.0,404.47,3.77,216.0,91127.0 +2015-08-17 07:00:00+00:00,30.55,53.58,0.0,0.0,0.0,407.48,4.0,219.0,91181.0 +2015-08-17 08:00:00+00:00,29.85,58.39,0.0,0.0,0.0,410.5,4.22,222.0,91235.0 +2015-08-17 09:00:00+00:00,29.0,60.37,0.0,0.0,0.0,400.27,4.12,231.0,91259.0 +2015-08-17 10:00:00+00:00,28.15,62.34,0.0,0.0,0.0,390.03,4.03,239.0,91283.0 +2015-08-17 11:00:00+00:00,27.31,64.32,0.0,0.0,0.0,379.8,3.93,248.0,91307.0 +2015-08-17 12:00:00+00:00,27.76,64.18,0.0,0.0,0.0,378.62,3.14,254.0,91319.0 +2015-08-17 13:00:00+00:00,28.22,64.04,12.0,0.0,12.0,377.43,2.35,259.0,91331.0 +2015-08-17 14:00:00+00:00,28.67,63.9,178.0,507.7,57.0,376.25,1.56,265.0,91343.0 +2015-08-17 15:00:00+00:00,30.37,55.36,391.0,695.41,81.0,381.53,1.88,281.0,91295.0 +2015-08-17 16:00:00+00:00,32.07,46.81,513.0,434.04,239.0,386.82,2.19,297.0,91247.0 +2015-08-17 17:00:00+00:00,33.77,38.27,768.0,846.36,106.0,392.1,2.51,313.0,91199.0 +2015-08-17 18:00:00+00:00,34.39,34.8,891.0,877.07,112.0,392.93,3.03,314.0,91133.0 +2015-08-17 19:00:00+00:00,35.02,31.34,954.0,890.57,115.0,393.77,3.54,316.0,91067.0 +2015-08-17 20:00:00+00:00,35.65,27.87,952.0,890.21,115.0,394.6,4.06,317.0,91001.0 +2015-08-17 21:00:00+00:00,35.03,27.4,885.0,875.72,112.0,392.78,4.13,309.0,90956.0 +2015-08-17 22:00:00+00:00,34.42,26.92,759.0,844.28,106.0,390.97,4.21,300.0,90911.0 +2015-08-17 23:00:00+00:00,33.8,26.45,585.0,790.46,95.0,389.15,4.29,292.0,90866.0 +2015-08-18 00:00:00+00:00,33.48,28.11,379.0,696.47,80.0,388.75,3.95,279.0,90866.0 +2015-08-18 01:00:00+00:00,33.17,29.77,166.0,503.27,55.0,388.35,3.62,265.0,90866.0 +2015-08-18 02:00:00+00:00,32.86,31.43,0.0,0.0,0.0,387.95,3.28,252.0,90866.0 +2015-08-18 03:00:00+00:00,31.76,33.99,0.0,0.0,0.0,384.15,3.87,252.0,90953.0 +2015-08-18 04:00:00+00:00,30.66,36.56,0.0,0.0,0.0,380.35,4.45,252.0,91040.0 +2015-08-18 05:00:00+00:00,29.57,39.12,0.0,0.0,0.0,376.55,5.03,252.0,91127.0 +2015-08-18 06:00:00+00:00,28.73,41.34,0.0,0.0,0.0,373.22,4.91,250.0,91142.0 +2015-08-18 07:00:00+00:00,27.89,43.55,0.0,0.0,0.0,369.88,4.78,247.0,91157.0 +2015-08-18 08:00:00+00:00,27.06,45.77,0.0,0.0,0.0,366.55,4.65,245.0,91172.0 +2015-08-18 09:00:00+00:00,26.24,48.14,0.0,0.0,0.0,367.85,3.82,243.0,91184.0 +2015-08-18 10:00:00+00:00,25.43,50.5,0.0,0.0,0.0,369.15,2.99,242.0,91196.0 +2015-08-18 11:00:00+00:00,24.62,52.87,0.0,0.0,0.0,370.45,2.17,240.0,91208.0 +2015-08-18 12:00:00+00:00,25.44,52.45,0.0,0.0,0.0,371.95,2.17,250.0,91220.0 +2015-08-18 13:00:00+00:00,26.27,52.04,10.0,0.0,10.0,373.45,2.17,261.0,91232.0 +2015-08-18 14:00:00+00:00,27.09,51.62,180.0,520.3,57.0,374.95,2.17,271.0,91244.0 +2015-08-18 15:00:00+00:00,28.96,44.8,396.0,709.35,81.0,376.22,2.43,277.0,91199.0 +2015-08-18 16:00:00+00:00,30.82,37.99,603.0,805.14,96.0,377.48,2.7,283.0,91154.0 +2015-08-18 17:00:00+00:00,32.69,31.17,776.0,856.98,107.0,378.75,2.97,289.0,91109.0 +2015-08-18 18:00:00+00:00,34.06,28.04,901.0,888.77,113.0,376.85,3.52,290.0,91022.0 +2015-08-18 19:00:00+00:00,35.43,24.92,965.0,902.81,116.0,374.95,4.07,291.0,90935.0 +2015-08-18 20:00:00+00:00,36.81,21.79,962.0,901.62,116.0,373.05,4.62,291.0,90848.0 +2015-08-18 21:00:00+00:00,36.76,21.33,894.0,888.12,112.0,374.75,4.86,291.0,90794.0 +2015-08-18 22:00:00+00:00,36.7,20.87,766.0,856.12,106.0,376.45,5.09,291.0,90740.0 +2015-08-18 23:00:00+00:00,36.65,20.41,590.0,802.23,95.0,378.15,5.32,291.0,90686.0 +2015-08-19 00:00:00+00:00,35.46,23.26,381.0,706.55,80.0,379.42,4.86,288.0,90722.0 +2015-08-19 01:00:00+00:00,34.27,26.12,165.0,511.67,54.0,380.68,4.4,284.0,90758.0 +2015-08-19 02:00:00+00:00,33.09,28.97,0.0,0.0,0.0,381.95,3.93,281.0,90794.0 +2015-08-19 03:00:00+00:00,32.02,30.84,0.0,0.0,0.0,379.02,4.0,276.0,90854.0 +2015-08-19 04:00:00+00:00,30.95,32.71,0.0,0.0,0.0,376.08,4.08,272.0,90914.0 +2015-08-19 05:00:00+00:00,29.88,34.58,0.0,0.0,0.0,373.15,4.15,267.0,90974.0 +2015-08-19 06:00:00+00:00,28.94,37.51,0.0,0.0,0.0,368.65,4.1,261.0,90989.0 +2015-08-19 07:00:00+00:00,28.01,40.44,0.0,0.0,0.0,364.15,4.05,256.0,91004.0 +2015-08-19 08:00:00+00:00,27.08,43.37,0.0,0.0,0.0,359.65,4.0,250.0,91019.0 +2015-08-19 09:00:00+00:00,26.25,47.0,0.0,0.0,0.0,356.45,3.7,246.0,91022.0 +2015-08-19 10:00:00+00:00,25.42,50.62,0.0,0.0,0.0,353.25,3.4,242.0,91025.0 +2015-08-19 11:00:00+00:00,24.6,54.25,0.0,0.0,0.0,350.05,3.1,238.0,91028.0 +2015-08-19 12:00:00+00:00,25.69,53.17,0.0,0.0,0.0,350.12,3.33,236.0,91079.0 +2015-08-19 13:00:00+00:00,26.79,52.09,0.0,0.0,0.0,350.18,3.56,234.0,91130.0 +2015-08-19 14:00:00+00:00,27.88,51.01,180.0,524.59,57.0,350.25,3.79,232.0,91181.0 +2015-08-19 15:00:00+00:00,29.56,42.58,398.0,716.62,81.0,354.32,3.26,249.0,91160.0 +2015-08-19 16:00:00+00:00,31.24,34.14,606.0,811.95,96.0,358.38,2.72,266.0,91139.0 +2015-08-19 17:00:00+00:00,32.92,25.71,781.0,865.1,107.0,362.45,2.18,283.0,91118.0 +2015-08-19 18:00:00+00:00,34.14,23.96,905.0,894.89,113.0,364.63,2.37,286.0,91043.0 +2015-08-19 19:00:00+00:00,35.36,22.22,968.0,907.68,116.0,366.82,2.57,290.0,90968.0 +2015-08-19 20:00:00+00:00,36.59,20.47,965.0,906.72,116.0,369.0,2.76,294.0,90893.0 +2015-08-19 21:00:00+00:00,36.65,20.24,896.0,892.68,112.0,370.57,2.85,293.0,90830.0 +2015-08-19 22:00:00+00:00,36.7,20.0,768.0,861.6,106.0,372.13,2.94,292.0,90767.0 +2015-08-19 23:00:00+00:00,36.76,19.77,591.0,807.7,95.0,373.7,3.03,291.0,90704.0 +2015-08-20 00:00:00+00:00,35.59,21.82,380.0,712.18,79.0,373.18,2.32,284.0,90743.0 +2015-08-20 01:00:00+00:00,34.43,23.86,163.0,511.15,54.0,372.67,1.61,278.0,90782.0 +2015-08-20 02:00:00+00:00,33.27,25.91,0.0,0.0,0.0,372.15,0.9,272.0,90821.0 +2015-08-20 03:00:00+00:00,32.21,28.11,0.0,0.0,0.0,370.38,1.71,268.0,90875.0 +2015-08-20 04:00:00+00:00,31.16,30.32,0.0,0.0,0.0,368.62,2.52,264.0,90929.0 +2015-08-20 05:00:00+00:00,30.11,32.52,0.0,0.0,0.0,366.85,3.34,261.0,90983.0 +2015-08-20 06:00:00+00:00,29.23,34.97,0.0,0.0,0.0,364.27,3.3,257.0,91004.0 +2015-08-20 07:00:00+00:00,28.35,37.43,0.0,0.0,0.0,361.68,3.26,253.0,91025.0 +2015-08-20 08:00:00+00:00,27.47,39.88,0.0,0.0,0.0,359.1,3.21,249.0,91046.0 +2015-08-20 09:00:00+00:00,26.99,41.77,0.0,0.0,0.0,356.63,2.67,248.0,91049.0 +2015-08-20 10:00:00+00:00,26.51,43.67,0.0,0.0,0.0,354.17,2.13,248.0,91052.0 +2015-08-20 11:00:00+00:00,26.03,45.56,0.0,0.0,0.0,351.7,1.59,248.0,91055.0 +2015-08-20 12:00:00+00:00,26.92,44.98,0.0,0.0,0.0,354.92,1.69,243.0,91106.0 +2015-08-20 13:00:00+00:00,27.82,44.4,0.0,0.0,0.0,358.13,1.79,238.0,91157.0 +2015-08-20 14:00:00+00:00,28.71,43.82,177.0,520.34,56.0,361.35,1.89,234.0,91208.0 +2015-08-20 15:00:00+00:00,30.28,38.56,395.0,712.62,81.0,366.0,1.85,243.0,91187.0 +2015-08-20 16:00:00+00:00,31.84,33.29,604.0,810.84,96.0,370.65,1.81,252.0,91166.0 +2015-08-20 17:00:00+00:00,33.41,28.03,779.0,865.56,106.0,375.3,1.77,261.0,91145.0 +2015-08-20 18:00:00+00:00,34.38,26.58,904.0,895.42,113.0,375.9,2.29,258.0,91064.0 +2015-08-20 19:00:00+00:00,35.35,25.13,968.0,909.42,116.0,376.5,2.8,254.0,90983.0 +2015-08-20 20:00:00+00:00,36.32,23.68,623.0,175.53,459.0,377.1,3.32,251.0,90902.0 +2015-08-20 21:00:00+00:00,35.99,23.37,132.0,2.28,130.0,376.13,3.11,249.0,90854.0 +2015-08-20 22:00:00+00:00,35.67,23.06,650.0,458.41,299.0,375.17,2.89,248.0,90806.0 +2015-08-20 23:00:00+00:00,35.34,22.75,297.0,58.91,261.0,374.2,2.68,247.0,90758.0 +2015-08-21 00:00:00+00:00,33.95,26.69,49.0,0.0,49.0,374.52,2.97,240.0,90794.0 +2015-08-21 01:00:00+00:00,32.57,30.62,51.0,0.0,51.0,374.83,3.26,233.0,90830.0 +2015-08-21 02:00:00+00:00,31.19,34.56,0.0,0.0,0.0,375.15,3.56,226.0,90866.0 +2015-08-21 03:00:00+00:00,30.34,39.01,0.0,0.0,0.0,374.13,3.41,225.0,90947.0 +2015-08-21 04:00:00+00:00,29.49,43.46,0.0,0.0,0.0,373.12,3.26,224.0,91028.0 +2015-08-21 05:00:00+00:00,28.65,47.91,0.0,0.0,0.0,372.1,3.1,223.0,91109.0 +2015-08-21 06:00:00+00:00,28.17,51.12,0.0,0.0,0.0,370.85,3.05,221.0,91127.0 +2015-08-21 07:00:00+00:00,27.69,54.34,0.0,0.0,0.0,369.6,3.0,219.0,91145.0 +2015-08-21 08:00:00+00:00,27.22,57.55,0.0,0.0,0.0,368.35,2.95,217.0,91163.0 +2015-08-21 09:00:00+00:00,26.67,60.81,0.0,0.0,0.0,369.9,2.74,221.0,91175.0 +2015-08-21 10:00:00+00:00,26.12,64.06,0.0,0.0,0.0,371.45,2.54,224.0,91187.0 +2015-08-21 11:00:00+00:00,25.58,67.32,0.0,0.0,0.0,373.0,2.33,227.0,91199.0 +2015-08-21 12:00:00+00:00,25.33,66.88,0.0,0.0,0.0,385.17,2.76,225.0,91244.0 +2015-08-21 13:00:00+00:00,25.09,66.43,0.0,0.0,0.0,397.33,3.2,224.0,91289.0 +2015-08-21 14:00:00+00:00,24.84,65.99,175.0,516.04,56.0,409.5,3.63,222.0,91334.0 +2015-08-21 15:00:00+00:00,25.64,67.2,392.0,710.88,80.0,406.95,3.31,218.0,91340.0 +2015-08-21 16:00:00+00:00,26.45,68.42,601.0,808.14,96.0,404.4,2.98,214.0,91346.0 +2015-08-21 17:00:00+00:00,27.25,69.63,776.0,863.48,106.0,401.85,2.66,210.0,91352.0 +2015-08-21 18:00:00+00:00,27.5,70.8,900.0,893.72,112.0,398.75,3.29,217.0,91313.0 +2015-08-21 19:00:00+00:00,27.75,71.97,527.0,89.84,443.0,395.65,3.91,225.0,91274.0 +2015-08-21 20:00:00+00:00,28.01,73.14,958.0,904.27,115.0,392.55,4.54,233.0,91235.0 +2015-08-21 21:00:00+00:00,28.22,74.42,446.0,53.8,399.0,392.58,4.35,244.0,91235.0 +2015-08-21 22:00:00+00:00,28.43,75.7,120.0,0.0,120.0,392.62,4.17,255.0,91235.0 +2015-08-21 23:00:00+00:00,28.64,76.98,580.0,799.35,94.0,392.65,3.99,266.0,91235.0 +2015-08-22 00:00:00+00:00,28.94,72.97,371.0,704.83,78.0,385.27,3.67,258.0,91139.0 +2015-08-22 01:00:00+00:00,29.25,68.96,155.0,500.83,52.0,377.88,3.35,250.0,91043.0 +2015-08-22 02:00:00+00:00,29.56,64.95,0.0,0.0,0.0,370.5,3.03,242.0,90947.0 +2015-08-22 03:00:00+00:00,28.76,70.01,0.0,0.0,0.0,372.27,3.43,238.0,91037.0 +2015-08-22 04:00:00+00:00,27.96,75.06,0.0,0.0,0.0,374.03,3.83,234.0,91127.0 +2015-08-22 05:00:00+00:00,27.17,80.12,0.0,0.0,0.0,375.8,4.23,230.0,91217.0 +2015-08-22 06:00:00+00:00,26.76,84.61,0.0,0.0,0.0,378.05,4.0,232.0,91250.0 +2015-08-22 07:00:00+00:00,26.36,89.1,0.0,0.0,0.0,380.3,3.77,234.0,91283.0 +2015-08-22 08:00:00+00:00,25.96,93.59,0.0,0.0,0.0,382.55,3.54,235.0,91316.0 +2015-08-22 09:00:00+00:00,25.5,95.55,0.0,0.0,0.0,388.67,2.79,237.0,91334.0 +2015-08-22 10:00:00+00:00,25.04,97.51,0.0,0.0,0.0,394.78,2.03,239.0,91352.0 +2015-08-22 11:00:00+00:00,24.59,99.47,0.0,0.0,0.0,400.9,1.27,241.0,91370.0 +2015-08-22 12:00:00+00:00,25.32,94.62,0.0,0.0,0.0,401.13,1.68,230.0,91382.0 +2015-08-22 13:00:00+00:00,26.06,89.77,0.0,0.0,0.0,401.37,2.1,219.0,91394.0 +2015-08-22 14:00:00+00:00,26.79,84.92,173.0,516.04,55.0,401.6,2.51,208.0,91406.0 +2015-08-22 15:00:00+00:00,27.56,80.34,389.0,706.86,80.0,398.45,2.41,231.0,91406.0 +2015-08-22 16:00:00+00:00,28.33,75.77,598.0,807.06,95.0,395.3,2.32,253.0,91406.0 +2015-08-22 17:00:00+00:00,29.1,71.19,772.0,861.43,105.0,392.15,2.22,276.0,91406.0 +2015-08-22 18:00:00+00:00,29.06,70.22,347.0,23.86,326.0,390.73,1.94,281.0,91376.0 +2015-08-22 19:00:00+00:00,29.02,69.24,960.0,905.54,115.0,389.32,1.65,287.0,91346.0 +2015-08-22 20:00:00+00:00,28.99,68.27,271.0,15.05,257.0,387.9,1.37,292.0,91316.0 +2015-08-22 21:00:00+00:00,28.61,70.36,248.0,13.78,236.0,385.23,1.67,294.0,91307.0 +2015-08-22 22:00:00+00:00,28.24,72.44,238.0,13.15,228.0,382.57,1.98,297.0,91298.0 +2015-08-22 23:00:00+00:00,27.86,74.53,22.0,0.0,22.0,379.9,2.29,299.0,91289.0 +2015-08-23 00:00:00+00:00,27.25,73.67,93.0,0.0,93.0,380.82,2.59,275.0,91250.0 +2015-08-23 01:00:00+00:00,26.64,72.8,18.0,0.0,18.0,381.73,2.9,251.0,91211.0 +2015-08-23 02:00:00+00:00,26.03,71.94,0.0,0.0,0.0,382.65,3.2,227.0,91172.0 +2015-08-23 03:00:00+00:00,25.61,75.45,0.0,0.0,0.0,379.78,2.86,227.0,91229.0 +2015-08-23 04:00:00+00:00,25.19,78.96,0.0,0.0,0.0,376.92,2.51,228.0,91286.0 +2015-08-23 05:00:00+00:00,24.77,82.47,0.0,0.0,0.0,374.05,2.17,228.0,91343.0 +2015-08-23 06:00:00+00:00,24.38,86.59,0.0,0.0,0.0,367.82,1.98,252.0,91340.0 +2015-08-23 07:00:00+00:00,23.99,90.72,0.0,0.0,0.0,361.58,1.8,275.0,91337.0 +2015-08-23 08:00:00+00:00,23.6,94.84,0.0,0.0,0.0,355.35,1.61,299.0,91334.0 +2015-08-23 09:00:00+00:00,23.11,96.56,0.0,0.0,0.0,354.77,1.56,314.0,91343.0 +2015-08-23 10:00:00+00:00,22.63,98.28,0.0,0.0,0.0,354.18,1.51,329.0,91352.0 +2015-08-23 11:00:00+00:00,22.15,100.0,0.0,0.0,0.0,353.6,1.46,344.0,91361.0 +2015-08-23 12:00:00+00:00,23.05,94.8,0.0,0.0,0.0,365.0,1.08,2.0,91425.0 +2015-08-23 13:00:00+00:00,23.95,89.61,0.0,0.0,0.0,376.4,0.7,21.0,91488.0 +2015-08-23 14:00:00+00:00,24.85,84.41,170.0,507.22,55.0,387.8,0.32,39.0,91551.0 +2015-08-23 15:00:00+00:00,26.75,75.3,385.0,702.82,79.0,386.7,1.09,35.0,91524.0 +2015-08-23 16:00:00+00:00,28.65,66.18,591.0,799.56,94.0,385.6,1.85,30.0,91497.0 +2015-08-23 17:00:00+00:00,30.55,57.07,763.0,851.63,105.0,384.5,2.62,26.0,91470.0 +2015-08-23 18:00:00+00:00,31.16,53.81,886.0,882.44,111.0,380.78,2.69,28.0,91431.0 +2015-08-23 19:00:00+00:00,31.77,50.55,948.0,895.61,114.0,377.07,2.77,31.0,91391.0 +2015-08-23 20:00:00+00:00,32.39,47.29,946.0,896.63,114.0,373.35,2.84,33.0,91352.0 +2015-08-23 21:00:00+00:00,30.95,50.89,878.0,884.17,110.0,375.98,2.82,23.0,91361.0 +2015-08-23 22:00:00+00:00,29.5,54.5,494.0,162.42,371.0,378.62,2.8,12.0,91370.0 +2015-08-23 23:00:00+00:00,28.06,58.1,571.0,794.53,93.0,381.25,2.77,2.0,91379.0 +2015-08-24 00:00:00+00:00,28.55,60.15,345.0,609.58,96.0,375.73,2.71,359.0,91367.0 +2015-08-24 01:00:00+00:00,29.04,62.19,89.0,80.89,73.0,370.22,2.65,356.0,91355.0 +2015-08-24 02:00:00+00:00,29.53,64.24,0.0,0.0,0.0,364.7,2.59,353.0,91343.0 +2015-08-24 03:00:00+00:00,28.57,67.82,0.0,0.0,0.0,364.47,2.25,8.0,91376.0 +2015-08-24 04:00:00+00:00,27.61,71.39,0.0,0.0,0.0,364.23,1.9,23.0,91410.0 +2015-08-24 05:00:00+00:00,26.65,74.97,0.0,0.0,0.0,364.0,1.56,38.0,91443.0 +2015-08-24 06:00:00+00:00,26.07,77.71,0.0,0.0,0.0,362.45,1.54,48.0,91428.0 +2015-08-24 07:00:00+00:00,25.49,80.46,0.0,0.0,0.0,360.9,1.52,57.0,91413.0 +2015-08-24 08:00:00+00:00,24.92,83.2,0.0,0.0,0.0,359.35,1.5,67.0,91397.0 +2015-08-24 09:00:00+00:00,24.21,85.18,0.0,0.0,0.0,358.1,2.11,69.0,91394.0 +2015-08-24 10:00:00+00:00,23.51,87.15,0.0,0.0,0.0,356.85,2.73,71.0,91391.0 +2015-08-24 11:00:00+00:00,22.81,89.13,0.0,0.0,0.0,355.6,3.34,74.0,91388.0 +2015-08-24 12:00:00+00:00,24.05,82.2,0.0,0.0,0.0,358.38,3.09,73.0,91446.0 +2015-08-24 13:00:00+00:00,25.3,75.26,0.0,0.0,0.0,361.17,2.83,72.0,91503.0 +2015-08-24 14:00:00+00:00,26.54,68.33,146.0,338.1,70.0,363.95,2.58,70.0,91560.0 +2015-08-24 15:00:00+00:00,28.19,60.23,381.0,698.77,78.0,368.28,2.38,75.0,91527.0 +2015-08-24 16:00:00+00:00,29.83,52.13,587.0,795.28,94.0,372.62,2.17,79.0,91494.0 +2015-08-24 17:00:00+00:00,31.48,44.03,682.0,509.76,289.0,376.95,1.97,83.0,91461.0 +2015-08-24 18:00:00+00:00,31.93,42.05,882.0,880.82,110.0,378.15,1.46,85.0,91422.0 +2015-08-24 19:00:00+00:00,32.39,40.06,944.0,894.29,113.0,379.35,0.95,86.0,91382.0 +2015-08-24 20:00:00+00:00,32.85,38.08,940.0,893.4,113.0,380.55,0.44,88.0,91343.0 +2015-08-24 21:00:00+00:00,31.82,39.34,660.0,266.73,429.0,380.12,1.53,71.0,91337.0 +2015-08-24 22:00:00+00:00,30.78,40.59,741.0,845.72,103.0,379.68,2.61,54.0,91331.0 +2015-08-24 23:00:00+00:00,29.75,41.85,564.0,788.88,92.0,379.25,3.7,37.0,91325.0 +2015-08-25 00:00:00+00:00,29.32,44.93,355.0,689.29,76.0,378.07,2.88,46.0,91319.0 +2015-08-25 01:00:00+00:00,28.89,48.0,141.0,474.77,49.0,376.88,2.06,56.0,91313.0 +2015-08-25 02:00:00+00:00,28.46,51.08,0.0,0.0,0.0,375.7,1.24,65.0,91307.0 +2015-08-25 03:00:00+00:00,27.76,55.29,0.0,0.0,0.0,374.77,1.71,65.0,91334.0 +2015-08-25 04:00:00+00:00,27.06,59.49,0.0,0.0,0.0,373.83,2.17,65.0,91361.0 +2015-08-25 05:00:00+00:00,26.36,63.7,0.0,0.0,0.0,372.9,2.63,65.0,91388.0 +2015-08-25 06:00:00+00:00,25.78,66.99,0.0,0.0,0.0,370.03,2.52,69.0,91370.0 +2015-08-25 07:00:00+00:00,25.21,70.28,0.0,0.0,0.0,367.17,2.4,73.0,91352.0 +2015-08-25 08:00:00+00:00,24.64,73.57,0.0,0.0,0.0,364.3,2.29,77.0,91334.0 +2015-08-25 09:00:00+00:00,24.01,75.89,0.0,0.0,0.0,363.15,1.97,78.0,91337.0 +2015-08-25 10:00:00+00:00,23.39,78.22,0.0,0.0,0.0,362.0,1.65,78.0,91340.0 +2015-08-25 11:00:00+00:00,22.77,80.54,0.0,0.0,0.0,360.85,1.32,79.0,91343.0 +2015-08-25 12:00:00+00:00,24.02,74.29,0.0,0.0,0.0,356.88,1.39,79.0,91413.0 +2015-08-25 13:00:00+00:00,25.28,68.05,0.0,0.0,0.0,352.92,1.45,79.0,91482.0 +2015-08-25 14:00:00+00:00,26.53,61.8,41.0,0.0,41.0,348.95,1.52,79.0,91551.0 +2015-08-25 15:00:00+00:00,28.36,54.79,279.0,238.51,176.0,355.07,1.38,97.0,91521.0 +2015-08-25 16:00:00+00:00,30.19,47.79,370.0,135.88,286.0,361.18,1.24,114.0,91491.0 +2015-08-25 17:00:00+00:00,32.02,40.78,570.0,263.9,367.0,367.3,1.1,132.0,91461.0 +2015-08-25 18:00:00+00:00,32.93,38.7,880.0,881.52,109.0,368.6,1.04,138.0,91397.0 +2015-08-25 19:00:00+00:00,33.84,36.62,774.0,378.56,423.0,369.9,0.98,144.0,91334.0 +2015-08-25 20:00:00+00:00,34.76,34.54,937.0,893.47,112.0,371.2,0.92,150.0,91271.0 +2015-08-25 21:00:00+00:00,33.49,35.24,78.0,0.0,78.0,370.23,1.13,154.0,91289.0 +2015-08-25 22:00:00+00:00,32.21,35.94,56.0,0.0,56.0,369.27,1.33,157.0,91307.0 +2015-08-25 23:00:00+00:00,30.94,36.64,81.0,0.0,81.0,368.3,1.53,161.0,91325.0 +2015-08-26 00:00:00+00:00,30.4,40.77,172.0,39.9,156.0,368.22,1.26,221.0,91352.0 +2015-08-26 01:00:00+00:00,29.86,44.89,62.0,0.0,62.0,368.13,1.0,280.0,91379.0 +2015-08-26 02:00:00+00:00,29.33,49.02,0.0,0.0,0.0,368.05,0.73,340.0,91406.0 +2015-08-26 03:00:00+00:00,28.74,53.18,0.0,0.0,0.0,367.13,0.95,351.0,91437.0 +2015-08-26 04:00:00+00:00,28.16,57.34,0.0,0.0,0.0,366.22,1.17,2.0,91467.0 +2015-08-26 05:00:00+00:00,27.58,61.5,0.0,0.0,0.0,365.3,1.39,13.0,91497.0 +2015-08-26 06:00:00+00:00,26.96,66.68,0.0,0.0,0.0,363.47,1.54,22.0,91476.0 +2015-08-26 07:00:00+00:00,26.34,71.87,0.0,0.0,0.0,361.63,1.7,32.0,91455.0 +2015-08-26 08:00:00+00:00,25.72,77.05,0.0,0.0,0.0,359.8,1.85,42.0,91434.0 +2015-08-26 09:00:00+00:00,24.89,81.49,0.0,0.0,0.0,356.78,1.78,48.0,91428.0 +2015-08-26 10:00:00+00:00,24.06,85.93,0.0,0.0,0.0,353.77,1.72,54.0,91422.0 +2015-08-26 11:00:00+00:00,23.24,90.37,0.0,0.0,0.0,350.75,1.66,59.0,91416.0 +2015-08-26 12:00:00+00:00,24.38,83.09,0.0,0.0,0.0,348.0,1.29,65.0,91482.0 +2015-08-26 13:00:00+00:00,25.52,75.81,0.0,0.0,0.0,345.25,0.92,70.0,91548.0 +2015-08-26 14:00:00+00:00,26.66,68.53,164.0,502.52,53.0,342.5,0.55,75.0,91614.0 +2015-08-26 15:00:00+00:00,28.95,58.73,325.0,416.23,146.0,348.0,0.84,91.0,91578.0 +2015-08-26 16:00:00+00:00,31.25,48.92,587.0,801.31,93.0,353.5,1.12,108.0,91542.0 +2015-08-26 17:00:00+00:00,33.54,39.12,760.0,856.04,103.0,359.0,1.41,124.0,91506.0 +2015-08-26 18:00:00+00:00,34.22,36.64,883.0,886.85,109.0,362.97,1.76,149.0,91443.0 +2015-08-26 19:00:00+00:00,34.91,34.17,944.0,899.35,112.0,366.93,2.11,174.0,91379.0 +2015-08-26 20:00:00+00:00,35.6,31.69,752.0,416.93,368.0,370.9,2.46,198.0,91316.0 +2015-08-26 21:00:00+00:00,35.21,33.15,679.0,305.56,416.0,373.72,2.79,210.0,91316.0 +2015-08-26 22:00:00+00:00,34.83,34.61,141.0,2.67,139.0,376.53,3.13,221.0,91316.0 +2015-08-26 23:00:00+00:00,34.44,36.07,79.0,0.0,79.0,379.35,3.46,233.0,91316.0 +2015-08-27 00:00:00+00:00,33.97,36.6,203.0,95.68,165.0,373.75,2.68,220.0,91295.0 +2015-08-27 01:00:00+00:00,33.51,37.14,99.0,177.86,66.0,368.15,1.89,206.0,91274.0 +2015-08-27 02:00:00+00:00,33.05,37.67,0.0,0.0,0.0,362.55,1.1,193.0,91253.0 +2015-08-27 03:00:00+00:00,32.63,40.36,0.0,0.0,0.0,361.65,1.09,180.0,91298.0 +2015-08-27 04:00:00+00:00,32.21,43.05,0.0,0.0,0.0,360.75,1.07,167.0,91343.0 +2015-08-27 05:00:00+00:00,31.8,45.74,0.0,0.0,0.0,359.85,1.05,154.0,91388.0 +2015-08-27 06:00:00+00:00,31.19,46.6,0.0,0.0,0.0,360.18,1.15,159.0,91379.0 +2015-08-27 07:00:00+00:00,30.59,47.46,0.0,0.0,0.0,360.52,1.26,164.0,91370.0 +2015-08-27 08:00:00+00:00,29.99,48.32,0.0,0.0,0.0,360.85,1.37,169.0,91361.0 +2015-08-27 09:00:00+00:00,28.65,52.74,0.0,0.0,0.0,358.45,1.52,172.0,91367.0 +2015-08-27 10:00:00+00:00,27.32,57.17,0.0,0.0,0.0,356.05,1.68,174.0,91373.0 +2015-08-27 11:00:00+00:00,25.99,61.59,0.0,0.0,0.0,353.65,1.83,176.0,91379.0 +2015-08-27 12:00:00+00:00,26.52,59.74,0.0,0.0,0.0,352.52,1.75,147.0,91473.0 +2015-08-27 13:00:00+00:00,27.06,57.89,0.0,0.0,0.0,351.38,1.66,119.0,91566.0 +2015-08-27 14:00:00+00:00,27.6,56.04,162.0,502.43,52.0,350.25,1.57,90.0,91659.0 +2015-08-27 15:00:00+00:00,29.46,49.44,378.0,702.85,77.0,355.47,1.39,87.0,91626.0 +2015-08-27 16:00:00+00:00,31.31,42.84,584.0,800.33,92.0,360.68,1.21,84.0,91593.0 +2015-08-27 17:00:00+00:00,33.17,36.24,757.0,855.42,102.0,365.9,1.03,81.0,91560.0 +2015-08-27 18:00:00+00:00,34.35,33.53,880.0,886.5,108.0,366.67,1.52,83.0,91467.0 +2015-08-27 19:00:00+00:00,35.53,30.82,808.0,524.38,324.0,367.43,2.01,85.0,91373.0 +2015-08-27 20:00:00+00:00,36.71,28.11,934.0,895.94,111.0,368.2,2.5,86.0,91280.0 +2015-08-27 21:00:00+00:00,36.48,29.48,862.0,878.84,108.0,370.65,2.1,48.0,91250.0 +2015-08-27 22:00:00+00:00,36.24,30.86,655.0,512.61,273.0,373.1,1.7,9.0,91220.0 +2015-08-27 23:00:00+00:00,36.01,32.23,413.0,278.9,249.0,375.55,1.3,330.0,91190.0 +2015-08-28 00:00:00+00:00,34.65,34.68,137.0,7.63,134.0,374.05,1.55,334.0,91208.0 +2015-08-28 01:00:00+00:00,33.29,37.12,3.0,0.0,3.0,372.55,1.81,338.0,91226.0 +2015-08-28 02:00:00+00:00,31.93,39.57,0.0,0.0,0.0,371.05,2.07,342.0,91244.0 +2015-08-28 03:00:00+00:00,31.11,42.8,0.0,0.0,0.0,368.98,1.7,351.0,91271.0 +2015-08-28 04:00:00+00:00,30.29,46.03,0.0,0.0,0.0,366.92,1.32,360.0,91298.0 +2015-08-28 05:00:00+00:00,29.47,49.26,0.0,0.0,0.0,364.85,0.95,9.0,91325.0 +2015-08-28 06:00:00+00:00,28.65,52.11,0.0,0.0,0.0,360.58,1.03,14.0,91310.0 +2015-08-28 07:00:00+00:00,27.83,54.96,0.0,0.0,0.0,356.32,1.11,19.0,91295.0 +2015-08-28 08:00:00+00:00,27.02,57.81,0.0,0.0,0.0,352.05,1.19,24.0,91280.0 +2015-08-28 09:00:00+00:00,26.17,60.62,0.0,0.0,0.0,349.55,1.08,27.0,91271.0 +2015-08-28 10:00:00+00:00,25.32,63.42,0.0,0.0,0.0,347.05,0.97,30.0,91262.0 +2015-08-28 11:00:00+00:00,24.48,66.23,0.0,0.0,0.0,344.55,0.86,33.0,91253.0 +2015-08-28 12:00:00+00:00,25.85,60.02,0.0,0.0,0.0,344.42,0.81,33.0,91310.0 +2015-08-28 13:00:00+00:00,27.23,53.82,0.0,0.0,0.0,344.28,0.76,34.0,91367.0 +2015-08-28 14:00:00+00:00,28.6,47.61,162.0,506.97,52.0,344.15,0.72,34.0,91425.0 +2015-08-28 15:00:00+00:00,30.65,43.06,379.0,708.19,77.0,349.28,1.39,27.0,91385.0 +2015-08-28 16:00:00+00:00,32.69,38.52,588.0,809.15,92.0,354.42,2.06,20.0,91346.0 +2015-08-28 17:00:00+00:00,34.74,33.97,763.0,865.3,102.0,359.55,2.73,13.0,91307.0 +2015-08-28 18:00:00+00:00,35.62,30.57,886.0,895.4,108.0,363.37,2.5,359.0,91220.0 +2015-08-28 19:00:00+00:00,36.5,27.16,948.0,908.99,111.0,367.18,2.26,344.0,91133.0 +2015-08-28 20:00:00+00:00,37.38,23.76,943.0,908.18,111.0,371.0,2.03,329.0,91046.0 +2015-08-28 21:00:00+00:00,37.05,23.76,870.0,892.26,107.0,376.92,1.59,326.0,91016.0 +2015-08-28 22:00:00+00:00,36.71,23.75,738.0,858.48,101.0,382.83,1.15,323.0,90986.0 +2015-08-28 23:00:00+00:00,36.38,23.75,556.0,797.31,90.0,388.75,0.72,320.0,90956.0 +2015-08-29 00:00:00+00:00,35.4,26.24,344.0,696.19,73.0,385.3,0.95,298.0,90959.0 +2015-08-29 01:00:00+00:00,34.42,28.72,129.0,468.73,46.0,381.85,1.18,275.0,90962.0 +2015-08-29 02:00:00+00:00,33.45,31.21,0.0,0.0,0.0,378.4,1.41,253.0,90965.0 +2015-08-29 03:00:00+00:00,33.3,33.25,0.0,0.0,0.0,375.1,1.64,218.0,91001.0 +2015-08-29 04:00:00+00:00,33.16,35.28,0.0,0.0,0.0,371.8,1.87,183.0,91037.0 +2015-08-29 05:00:00+00:00,33.02,37.32,0.0,0.0,0.0,368.5,2.1,148.0,91073.0 +2015-08-29 06:00:00+00:00,32.34,39.53,0.0,0.0,0.0,363.17,2.01,146.0,91070.0 +2015-08-29 07:00:00+00:00,31.66,41.75,0.0,0.0,0.0,357.83,1.93,145.0,91067.0 +2015-08-29 08:00:00+00:00,30.98,43.96,0.0,0.0,0.0,352.5,1.85,144.0,91064.0 +2015-08-29 09:00:00+00:00,30.18,45.36,0.0,0.0,0.0,350.9,1.75,138.0,91079.0 +2015-08-29 10:00:00+00:00,29.39,46.75,0.0,0.0,0.0,349.3,1.65,132.0,91094.0 +2015-08-29 11:00:00+00:00,28.6,48.15,0.0,0.0,0.0,347.7,1.54,126.0,91109.0 +2015-08-29 12:00:00+00:00,28.92,47.68,0.0,0.0,0.0,348.27,1.31,123.0,91178.0 +2015-08-29 13:00:00+00:00,29.25,47.22,0.0,0.0,0.0,348.83,1.09,120.0,91247.0 +2015-08-29 14:00:00+00:00,29.58,46.75,160.0,502.29,52.0,349.4,0.86,118.0,91316.0 +2015-08-29 15:00:00+00:00,31.19,41.96,378.0,711.23,76.0,355.27,1.15,109.0,91316.0 +2015-08-29 16:00:00+00:00,32.8,37.18,586.0,809.88,91.0,361.13,1.45,101.0,91316.0 +2015-08-29 17:00:00+00:00,34.41,32.39,760.0,864.77,101.0,367.0,1.75,92.0,91316.0 +2015-08-29 18:00:00+00:00,34.85,31.26,882.0,894.0,107.0,370.7,2.1,126.0,91280.0 +2015-08-29 19:00:00+00:00,35.29,30.13,943.0,906.84,110.0,374.4,2.44,160.0,91244.0 +2015-08-29 20:00:00+00:00,35.73,29.0,936.0,904.14,110.0,378.1,2.79,195.0,91208.0 +2015-08-29 21:00:00+00:00,35.43,29.66,863.0,888.24,106.0,380.18,3.11,249.0,91190.0 +2015-08-29 22:00:00+00:00,35.12,30.31,730.0,852.79,100.0,382.27,3.43,303.0,91172.0 +2015-08-29 23:00:00+00:00,34.82,30.97,10.0,0.0,10.0,384.35,3.75,358.0,91154.0 +2015-08-30 00:00:00+00:00,34.68,34.85,6.0,0.0,6.0,379.95,3.83,311.0,91130.0 +2015-08-30 01:00:00+00:00,34.54,38.72,23.0,0.0,23.0,375.55,3.91,264.0,91106.0 +2015-08-30 02:00:00+00:00,34.4,42.6,0.0,0.0,0.0,371.15,3.99,218.0,91082.0 +2015-08-30 03:00:00+00:00,33.36,46.05,0.0,0.0,0.0,368.45,3.32,277.0,91139.0 +2015-08-30 04:00:00+00:00,32.32,49.5,0.0,0.0,0.0,365.75,2.65,336.0,91196.0 +2015-08-30 05:00:00+00:00,31.28,52.95,0.0,0.0,0.0,363.05,1.99,36.0,91253.0 +2015-08-30 06:00:00+00:00,30.08,57.17,0.0,0.0,0.0,360.8,1.83,41.0,91244.0 +2015-08-30 07:00:00+00:00,28.88,61.4,0.0,0.0,0.0,358.55,1.68,46.0,91235.0 +2015-08-30 08:00:00+00:00,27.69,65.62,0.0,0.0,0.0,356.3,1.53,52.0,91226.0 +2015-08-30 09:00:00+00:00,26.7,68.67,0.0,0.0,0.0,353.83,1.7,56.0,91208.0 +2015-08-30 10:00:00+00:00,25.71,71.72,0.0,0.0,0.0,351.37,1.86,59.0,91190.0 +2015-08-30 11:00:00+00:00,24.73,74.77,0.0,0.0,0.0,348.9,2.03,63.0,91172.0 +2015-08-30 12:00:00+00:00,26.0,68.67,0.0,0.0,0.0,348.92,1.76,66.0,91223.0 +2015-08-30 13:00:00+00:00,27.28,62.56,0.0,0.0,0.0,348.93,1.49,68.0,91274.0 +2015-08-30 14:00:00+00:00,28.56,56.46,158.0,502.23,51.0,348.95,1.21,71.0,91325.0 +2015-08-30 15:00:00+00:00,30.41,49.04,374.0,704.87,76.0,354.63,1.16,81.0,91310.0 +2015-08-30 16:00:00+00:00,32.26,41.63,581.0,805.72,90.0,360.32,1.11,90.0,91295.0 +2015-08-30 17:00:00+00:00,34.11,34.21,754.0,860.33,100.0,366.0,1.06,100.0,91280.0 +2015-08-30 18:00:00+00:00,34.31,33.37,877.0,891.48,106.0,368.95,1.53,146.0,91241.0 +2015-08-30 19:00:00+00:00,34.52,32.54,115.0,0.0,115.0,371.9,1.99,191.0,91202.0 +2015-08-30 20:00:00+00:00,34.73,31.7,631.0,174.54,472.0,374.85,2.46,236.0,91163.0 +2015-08-30 21:00:00+00:00,34.25,31.79,159.0,5.89,154.0,375.75,2.74,255.0,91127.0 +2015-08-30 22:00:00+00:00,33.78,31.87,130.0,0.0,130.0,376.65,3.03,274.0,91091.0 +2015-08-30 23:00:00+00:00,33.3,31.96,272.0,51.98,242.0,377.55,3.32,293.0,91055.0 +2015-08-31 00:00:00+00:00,32.2,32.68,78.0,0.0,78.0,373.78,3.09,270.0,91043.0 +2015-08-31 01:00:00+00:00,31.1,33.41,61.0,17.82,58.0,370.02,2.86,246.0,91031.0 +2015-08-31 02:00:00+00:00,30.0,34.13,0.0,0.0,0.0,366.25,2.63,222.0,91019.0 +2015-08-31 03:00:00+00:00,29.45,37.84,0.0,0.0,0.0,363.3,2.36,228.0,91046.0 +2015-08-31 04:00:00+00:00,28.9,41.55,0.0,0.0,0.0,360.35,2.09,235.0,91073.0 +2015-08-31 05:00:00+00:00,28.35,45.26,0.0,0.0,0.0,357.4,1.82,241.0,91100.0 +2015-08-31 06:00:00+00:00,28.16,48.56,0.0,0.0,0.0,357.17,1.83,239.0,91112.0 +2015-08-31 07:00:00+00:00,27.97,51.87,0.0,0.0,0.0,356.93,1.84,238.0,91124.0 +2015-08-31 08:00:00+00:00,27.78,55.17,0.0,0.0,0.0,356.7,1.85,237.0,91136.0 +2015-08-31 09:00:00+00:00,26.86,57.75,0.0,0.0,0.0,358.8,1.63,228.0,91139.0 +2015-08-31 10:00:00+00:00,25.94,60.33,0.0,0.0,0.0,360.9,1.42,220.0,91142.0 +2015-08-31 11:00:00+00:00,25.03,62.91,0.0,0.0,0.0,363.0,1.2,211.0,91145.0 +2015-08-31 12:00:00+00:00,25.83,61.36,0.0,0.0,0.0,362.92,1.26,195.0,91220.0 +2015-08-31 13:00:00+00:00,26.64,59.8,0.0,0.0,0.0,362.83,1.32,179.0,91295.0 +2015-08-31 14:00:00+00:00,27.45,58.25,157.0,502.19,51.0,362.75,1.38,164.0,91370.0 +2015-08-31 15:00:00+00:00,28.66,52.83,374.0,710.35,75.0,364.97,1.72,172.0,91349.0 +2015-08-31 16:00:00+00:00,32.1,27.69,583.0,811.45,90.0,367.37,2.65,181.0,91328.0 +2015-08-31 17:00:00+00:00,31.76,32.38,319.0,29.01,297.0,368.05,2.59,189.0,91307.0 +2015-08-31 18:00:00+00:00,31.42,37.06,710.0,369.74,391.0,368.74,2.53,208.0,91289.0 +2015-08-31 19:00:00+00:00,31.08,41.74,872.0,537.22,381.0,369.42,2.48,226.0,91271.0 +2015-08-31 20:00:00+00:00,30.74,46.43,936.0,910.45,109.0,370.1,2.42,244.0,91253.0 +2015-08-31 21:00:00+00:00,30.4,51.11,241.0,13.0,230.0,370.78,2.37,248.0,91229.0 +2015-08-31 22:00:00+00:00,30.06,55.8,727.0,859.23,98.0,371.46,2.31,251.0,91205.0 +2015-08-31 23:00:00+00:00,29.72,60.48,544.0,797.01,87.0,372.15,2.25,255.0,91181.0 +2013-09-01 00:00:00+00:00,29.38,65.16,329.0,700.13,68.0,372.83,2.2,266.0,91019.0 +2013-09-01 01:00:00+00:00,29.04,69.85,113.0,451.44,41.0,373.51,2.14,271.0,91037.0 +2013-09-01 02:00:00+00:00,28.71,74.53,0.0,0.0,0.0,374.19,2.09,275.0,91055.0 +2013-09-01 03:00:00+00:00,28.37,79.21,0.0,0.0,0.0,374.87,2.03,281.0,91103.0 +2013-09-01 04:00:00+00:00,28.03,83.9,0.0,0.0,0.0,375.55,1.97,286.0,91151.0 +2013-09-01 05:00:00+00:00,27.69,88.58,0.0,0.0,0.0,376.24,1.92,292.0,91199.0 +2013-09-01 06:00:00+00:00,27.35,93.26,0.0,0.0,0.0,376.92,1.86,298.0,91202.0 +2013-09-01 07:00:00+00:00,27.01,97.95,0.0,0.0,0.0,377.6,1.81,303.0,91205.0 +2013-09-01 08:00:00+00:00,25.42,100.0,0.0,0.0,0.0,373.4,0.58,309.0,91208.0 +2013-09-01 09:00:00+00:00,25.05,100.0,0.0,0.0,0.0,369.15,0.8,322.0,91208.0 +2013-09-01 10:00:00+00:00,24.68,100.0,0.0,0.0,0.0,364.9,1.02,335.0,91208.0 +2013-09-01 11:00:00+00:00,24.31,100.0,0.0,0.0,0.0,360.65,1.24,348.0,91208.0 +2013-09-01 12:00:00+00:00,25.59,92.64,0.0,0.0,0.0,362.97,1.26,10.0,91226.0 +2013-09-01 13:00:00+00:00,26.86,85.29,0.0,0.0,0.0,365.28,1.27,32.0,91244.0 +2013-09-01 14:00:00+00:00,28.13,77.93,3.0,0.0,3.0,367.6,1.28,54.0,91262.0 +2013-09-01 15:00:00+00:00,29.52,69.98,7.0,0.0,7.0,370.15,1.67,67.0,91244.0 +2013-09-01 16:00:00+00:00,30.91,62.02,137.0,0.0,137.0,372.7,2.06,80.0,91226.0 +2013-09-01 17:00:00+00:00,32.29,54.07,385.0,60.98,339.0,375.25,2.46,93.0,91208.0 +2013-09-01 18:00:00+00:00,32.49,51.27,603.0,194.53,436.0,376.5,1.83,115.0,91157.0 +2013-09-01 19:00:00+00:00,32.7,48.47,195.0,9.9,186.0,377.75,1.2,137.0,91106.0 +2013-09-01 20:00:00+00:00,32.9,45.67,572.0,122.94,461.0,379.0,0.58,158.0,91055.0 +2013-09-01 21:00:00+00:00,32.82,45.45,849.0,891.56,100.0,377.77,1.09,184.0,91016.0 +2013-09-01 22:00:00+00:00,32.75,45.24,717.0,860.58,93.0,376.53,1.59,209.0,90977.0 +2013-09-01 23:00:00+00:00,32.67,45.02,536.0,800.77,83.0,375.3,2.1,234.0,90938.0 +2013-09-02 00:00:00+00:00,31.94,50.97,324.0,697.36,67.0,370.77,2.15,246.0,90935.0 +2013-09-02 01:00:00+00:00,31.21,56.92,109.0,445.24,40.0,366.23,2.2,259.0,90932.0 +2013-09-02 02:00:00+00:00,30.48,62.87,0.0,0.0,0.0,361.7,2.25,271.0,90929.0 +2013-09-02 03:00:00+00:00,29.99,65.95,0.0,0.0,0.0,359.57,1.56,285.0,90983.0 +2013-09-02 04:00:00+00:00,29.5,69.03,0.0,0.0,0.0,357.43,0.88,299.0,91037.0 +2013-09-02 05:00:00+00:00,29.01,72.11,0.0,0.0,0.0,355.3,0.19,313.0,91091.0 +2013-09-02 06:00:00+00:00,28.35,70.01,0.0,0.0,0.0,357.87,0.39,326.0,91103.0 +2013-09-02 07:00:00+00:00,27.7,67.9,0.0,0.0,0.0,360.43,0.59,340.0,91115.0 +2013-09-02 08:00:00+00:00,27.04,65.8,0.0,0.0,0.0,363.0,0.79,353.0,91127.0 +2013-09-02 09:00:00+00:00,26.34,70.51,0.0,0.0,0.0,358.58,1.03,20.0,91121.0 +2013-09-02 10:00:00+00:00,25.64,75.23,0.0,0.0,0.0,354.17,1.26,47.0,91115.0 +2013-09-02 11:00:00+00:00,24.93,79.94,0.0,0.0,0.0,349.75,1.5,74.0,91109.0 +2013-09-02 12:00:00+00:00,25.87,76.63,0.0,0.0,0.0,350.97,1.64,76.0,91148.0 +2013-09-02 13:00:00+00:00,26.81,73.31,0.0,0.0,0.0,352.18,1.77,79.0,91187.0 +2013-09-02 14:00:00+00:00,27.75,70.0,151.0,507.01,47.0,353.4,1.9,82.0,91226.0 +2013-09-02 15:00:00+00:00,29.87,59.66,368.0,717.61,70.0,359.27,1.86,88.0,91226.0 +2013-09-02 16:00:00+00:00,32.0,49.31,577.0,819.07,84.0,365.13,1.82,94.0,91226.0 +2013-09-02 17:00:00+00:00,34.12,38.97,751.0,873.3,94.0,371.0,1.78,101.0,91226.0 +2013-09-02 18:00:00+00:00,34.73,35.65,873.0,903.92,99.0,375.73,1.85,102.0,91148.0 +2013-09-02 19:00:00+00:00,35.33,32.32,931.0,914.35,102.0,380.47,1.93,103.0,91070.0 +2013-09-02 20:00:00+00:00,35.94,29.0,753.0,387.76,404.0,385.2,2.0,104.0,90992.0 +2013-09-02 21:00:00+00:00,35.3,29.73,56.0,0.0,56.0,386.95,1.83,104.0,90992.0 +2013-09-02 22:00:00+00:00,34.66,30.45,26.0,0.0,26.0,388.7,1.65,104.0,90992.0 +2013-09-02 23:00:00+00:00,34.02,31.18,195.0,12.46,188.0,390.45,1.48,105.0,90992.0 +2013-09-03 00:00:00+00:00,33.62,32.73,256.0,345.94,130.0,383.4,1.54,85.0,91016.0 +2013-09-03 01:00:00+00:00,33.22,34.27,70.0,113.03,53.0,376.35,1.61,65.0,91040.0 +2013-09-03 02:00:00+00:00,32.82,35.82,0.0,0.0,0.0,369.3,1.68,45.0,91064.0 +2013-09-03 03:00:00+00:00,31.48,40.78,0.0,0.0,0.0,365.55,1.52,50.0,91103.0 +2013-09-03 04:00:00+00:00,30.15,45.73,0.0,0.0,0.0,361.8,1.35,56.0,91142.0 +2013-09-03 05:00:00+00:00,28.81,50.69,0.0,0.0,0.0,358.05,1.19,61.0,91181.0 +2013-09-03 06:00:00+00:00,27.74,55.47,0.0,0.0,0.0,354.35,1.37,60.0,91184.0 +2013-09-03 07:00:00+00:00,26.67,60.24,0.0,0.0,0.0,350.65,1.56,60.0,91187.0 +2013-09-03 08:00:00+00:00,25.6,65.02,0.0,0.0,0.0,346.95,1.75,59.0,91190.0 +2013-09-03 09:00:00+00:00,24.89,69.65,0.0,0.0,0.0,344.52,1.62,63.0,91187.0 +2013-09-03 10:00:00+00:00,24.18,74.28,0.0,0.0,0.0,342.08,1.49,66.0,91184.0 +2013-09-03 11:00:00+00:00,23.47,78.91,0.0,0.0,0.0,339.65,1.37,70.0,91181.0 +2013-09-03 12:00:00+00:00,24.7,74.07,0.0,0.0,0.0,337.03,1.61,71.0,91247.0 +2013-09-03 13:00:00+00:00,25.92,69.23,0.0,0.0,0.0,334.42,1.85,71.0,91313.0 +2013-09-03 14:00:00+00:00,27.14,64.39,152.0,516.92,47.0,331.8,2.1,72.0,91379.0 +2013-09-03 15:00:00+00:00,29.71,53.12,371.0,728.2,70.0,338.55,3.14,81.0,91361.0 +2013-09-03 16:00:00+00:00,32.28,41.85,580.0,826.71,84.0,345.3,4.18,91.0,91343.0 +2013-09-03 17:00:00+00:00,34.84,30.58,755.0,882.35,93.0,352.05,5.23,100.0,91325.0 +2013-09-03 18:00:00+00:00,35.8,26.15,879.0,914.51,98.0,357.12,4.83,102.0,91238.0 +2013-09-03 19:00:00+00:00,36.75,21.71,941.0,929.09,101.0,362.18,4.44,104.0,91151.0 +2013-09-03 20:00:00+00:00,37.71,17.28,511.0,80.25,439.0,367.25,4.04,106.0,91064.0 +2013-09-03 21:00:00+00:00,37.41,16.54,861.0,916.44,97.0,371.27,3.55,106.0,91019.0 +2013-09-03 22:00:00+00:00,37.11,15.8,725.0,883.13,91.0,375.28,3.06,107.0,90974.0 +2013-09-03 23:00:00+00:00,36.81,15.06,538.0,819.31,81.0,379.3,2.57,107.0,90929.0 +2013-09-04 00:00:00+00:00,35.07,19.76,321.0,711.38,65.0,382.42,2.03,105.0,90956.0 +2013-09-04 01:00:00+00:00,33.32,24.47,103.0,445.81,38.0,385.53,1.5,104.0,90983.0 +2013-09-04 02:00:00+00:00,31.58,29.17,0.0,0.0,0.0,388.65,0.97,102.0,91010.0 +2013-09-04 03:00:00+00:00,31.26,36.06,0.0,0.0,0.0,380.68,1.15,95.0,91073.0 +2013-09-04 04:00:00+00:00,30.94,42.96,0.0,0.0,0.0,372.72,1.34,89.0,91136.0 +2013-09-04 05:00:00+00:00,30.62,49.85,0.0,0.0,0.0,364.75,1.53,82.0,91199.0 +2013-09-04 06:00:00+00:00,29.72,56.79,0.0,0.0,0.0,359.58,1.7,83.0,91199.0 +2013-09-04 07:00:00+00:00,28.83,63.74,0.0,0.0,0.0,354.42,1.87,84.0,91199.0 +2013-09-04 08:00:00+00:00,27.93,70.68,0.0,0.0,0.0,349.25,2.04,86.0,91199.0 +2013-09-04 09:00:00+00:00,26.34,78.55,0.0,0.0,0.0,345.82,1.98,86.0,91190.0 +2013-09-04 10:00:00+00:00,24.75,86.43,0.0,0.0,0.0,342.38,1.92,87.0,91181.0 +2013-09-04 11:00:00+00:00,23.15,94.3,0.0,0.0,0.0,338.95,1.86,88.0,91172.0 +2013-09-04 12:00:00+00:00,24.8,85.6,0.0,0.0,0.0,339.27,2.01,86.0,91232.0 +2013-09-04 13:00:00+00:00,26.44,76.91,0.0,0.0,0.0,339.58,2.17,83.0,91292.0 +2013-09-04 14:00:00+00:00,28.08,68.21,151.0,522.08,46.0,339.9,2.32,81.0,91352.0 +2013-09-04 15:00:00+00:00,30.62,57.4,370.0,731.63,69.0,346.83,2.97,92.0,91328.0 +2013-09-04 16:00:00+00:00,33.16,46.59,580.0,832.77,82.0,353.77,3.62,104.0,91304.0 +2013-09-04 17:00:00+00:00,35.69,35.78,753.0,884.81,91.0,360.7,4.28,115.0,91280.0 +2013-09-04 18:00:00+00:00,36.18,31.98,874.0,912.29,97.0,370.62,3.89,117.0,91208.0 +2013-09-04 19:00:00+00:00,36.68,28.17,506.0,75.43,438.0,380.53,3.5,118.0,91136.0 +2013-09-04 20:00:00+00:00,37.17,24.37,580.0,161.03,436.0,390.45,3.12,119.0,91064.0 +2013-09-04 21:00:00+00:00,36.89,23.98,340.0,25.29,319.0,390.87,3.21,117.0,91034.0 +2013-09-04 22:00:00+00:00,36.61,23.58,708.0,866.69,89.0,391.28,3.31,116.0,91004.0 +2013-09-04 23:00:00+00:00,36.33,23.19,524.0,803.63,79.0,391.7,3.41,114.0,90974.0 +2013-09-05 00:00:00+00:00,35.45,28.77,104.0,0.0,104.0,388.38,2.9,114.0,91004.0 +2013-09-05 01:00:00+00:00,34.56,34.36,23.0,0.0,23.0,385.07,2.4,115.0,91034.0 +2013-09-05 02:00:00+00:00,33.68,39.94,0.0,0.0,0.0,381.75,1.89,115.0,91064.0 +2013-09-05 03:00:00+00:00,32.1,44.08,0.0,0.0,0.0,375.15,1.87,110.0,91112.0 +2013-09-05 04:00:00+00:00,30.53,48.21,0.0,0.0,0.0,368.55,1.84,104.0,91160.0 +2013-09-05 05:00:00+00:00,28.95,52.35,0.0,0.0,0.0,361.95,1.82,98.0,91208.0 +2013-09-05 06:00:00+00:00,27.71,56.61,0.0,0.0,0.0,356.98,1.86,97.0,91217.0 +2013-09-05 07:00:00+00:00,26.46,60.86,0.0,0.0,0.0,352.02,1.9,96.0,91226.0 +2013-09-05 08:00:00+00:00,25.22,65.12,0.0,0.0,0.0,347.05,1.94,95.0,91235.0 +2013-09-05 09:00:00+00:00,24.53,68.06,0.0,0.0,0.0,345.68,1.89,95.0,91229.0 +2013-09-05 10:00:00+00:00,23.84,71.01,0.0,0.0,0.0,344.32,1.84,95.0,91223.0 +2013-09-05 11:00:00+00:00,23.15,73.95,0.0,0.0,0.0,342.95,1.79,95.0,91217.0 +2013-09-05 12:00:00+00:00,24.68,68.41,0.0,0.0,0.0,352.42,1.77,105.0,91271.0 +2013-09-05 13:00:00+00:00,26.21,62.88,0.0,0.0,0.0,361.88,1.76,115.0,91325.0 +2013-09-05 14:00:00+00:00,27.73,57.34,146.0,507.27,45.0,371.35,1.74,125.0,91379.0 +2013-09-05 15:00:00+00:00,28.71,52.12,364.0,725.35,67.0,371.05,1.66,124.0,91376.0 +2013-09-05 16:00:00+00:00,29.69,46.91,572.0,823.81,81.0,370.75,1.57,123.0,91373.0 +2013-09-05 17:00:00+00:00,30.66,41.69,745.0,877.95,90.0,370.45,1.49,122.0,91370.0 +2013-09-05 18:00:00+00:00,31.03,40.1,866.0,907.75,95.0,370.23,1.24,120.0,91322.0 +2013-09-05 19:00:00+00:00,31.39,38.52,532.0,93.45,448.0,370.02,0.98,118.0,91274.0 +2013-09-05 20:00:00+00:00,31.76,36.93,554.0,114.45,452.0,369.8,0.73,116.0,91226.0 +2013-09-05 21:00:00+00:00,32.25,36.54,400.0,53.21,356.0,372.47,1.17,105.0,91178.0 +2013-09-05 22:00:00+00:00,32.74,36.14,255.0,16.89,243.0,375.13,1.61,94.0,91130.0 +2013-09-05 23:00:00+00:00,33.23,35.75,518.0,800.52,78.0,377.8,2.06,84.0,91082.0 +2013-09-06 00:00:00+00:00,32.37,39.36,226.0,259.25,135.0,379.15,2.0,96.0,91055.0 +2013-09-06 01:00:00+00:00,31.52,42.97,34.0,0.0,34.0,380.5,1.94,109.0,91028.0 +2013-09-06 02:00:00+00:00,30.66,46.58,0.0,0.0,0.0,381.85,1.88,122.0,91001.0 +2013-09-06 03:00:00+00:00,29.58,50.69,0.0,0.0,0.0,376.98,1.97,130.0,91055.0 +2013-09-06 04:00:00+00:00,28.49,54.79,0.0,0.0,0.0,372.12,2.06,139.0,91109.0 +2013-09-06 05:00:00+00:00,27.41,58.9,0.0,0.0,0.0,367.25,2.15,148.0,91163.0 +2013-09-06 06:00:00+00:00,26.58,65.24,0.0,0.0,0.0,369.08,2.34,155.0,91190.0 +2013-09-06 07:00:00+00:00,25.75,71.58,0.0,0.0,0.0,370.92,2.53,162.0,91217.0 +2013-09-06 08:00:00+00:00,24.92,77.92,0.0,0.0,0.0,372.75,2.72,170.0,91244.0 +2013-09-06 09:00:00+00:00,24.55,83.53,0.0,0.0,0.0,375.52,2.1,140.0,91244.0 +2013-09-06 10:00:00+00:00,24.18,89.14,0.0,0.0,0.0,378.28,1.48,111.0,91244.0 +2013-09-06 11:00:00+00:00,23.81,94.75,0.0,0.0,0.0,381.05,0.86,82.0,91244.0 +2013-09-06 12:00:00+00:00,24.38,89.75,0.0,0.0,0.0,380.15,0.89,54.0,91313.0 +2013-09-06 13:00:00+00:00,24.95,84.74,0.0,0.0,0.0,379.25,0.93,26.0,91382.0 +2013-09-06 14:00:00+00:00,25.52,79.74,46.0,0.0,46.0,378.35,0.97,359.0,91452.0 +2013-09-06 15:00:00+00:00,26.34,73.88,297.0,377.93,143.0,377.58,0.74,34.0,91425.0 +2013-09-06 16:00:00+00:00,27.16,68.02,310.0,79.13,263.0,376.82,0.52,70.0,91397.0 +2013-09-06 17:00:00+00:00,27.98,62.16,460.0,131.74,362.0,376.05,0.3,106.0,91370.0 +2013-09-06 18:00:00+00:00,28.52,60.93,530.0,122.79,426.0,377.83,0.9,120.0,91304.0 +2013-09-06 19:00:00+00:00,29.06,59.69,566.0,121.63,457.0,379.62,1.49,133.0,91238.0 +2013-09-06 20:00:00+00:00,29.6,58.46,268.0,14.64,255.0,381.4,2.08,147.0,91172.0 +2013-09-06 21:00:00+00:00,29.74,57.98,149.0,4.86,145.0,383.45,1.86,160.0,91139.0 +2013-09-06 22:00:00+00:00,29.87,57.49,474.0,189.62,340.0,385.5,1.63,174.0,91106.0 +2013-09-06 23:00:00+00:00,30.01,57.01,510.0,790.11,79.0,387.55,1.41,188.0,91073.0 +2013-09-07 00:00:00+00:00,28.9,61.28,297.0,678.19,62.0,384.05,1.26,199.0,91094.0 +2013-09-07 01:00:00+00:00,27.8,65.55,71.0,212.52,43.0,380.55,1.12,210.0,91115.0 +2013-09-07 02:00:00+00:00,26.69,69.82,0.0,0.0,0.0,377.05,0.98,222.0,91136.0 +2013-09-07 03:00:00+00:00,26.75,73.68,0.0,0.0,0.0,377.33,1.05,174.0,91163.0 +2013-09-07 04:00:00+00:00,26.8,77.54,0.0,0.0,0.0,377.62,1.13,126.0,91190.0 +2013-09-07 05:00:00+00:00,26.86,81.4,0.0,0.0,0.0,377.9,1.2,78.0,91217.0 +2013-09-07 06:00:00+00:00,25.94,83.58,0.0,0.0,0.0,374.08,1.33,69.0,91193.0 +2013-09-07 07:00:00+00:00,25.03,85.75,0.0,0.0,0.0,370.27,1.46,60.0,91169.0 +2013-09-07 08:00:00+00:00,24.11,87.93,0.0,0.0,0.0,366.45,1.59,51.0,91145.0 +2013-09-07 09:00:00+00:00,23.58,90.15,0.0,0.0,0.0,365.1,1.45,55.0,91124.0 +2013-09-07 10:00:00+00:00,23.06,92.36,0.0,0.0,0.0,363.75,1.32,58.0,91103.0 +2013-09-07 11:00:00+00:00,22.53,94.58,0.0,0.0,0.0,362.4,1.19,62.0,91082.0 +2013-09-07 12:00:00+00:00,23.25,91.24,0.0,0.0,0.0,363.15,1.3,72.0,91133.0 +2013-09-07 13:00:00+00:00,23.97,87.9,0.0,0.0,0.0,363.9,1.41,81.0,91184.0 +2013-09-07 14:00:00+00:00,24.68,84.56,6.0,0.0,6.0,364.65,1.52,91.0,91235.0 +2013-09-07 15:00:00+00:00,25.45,79.19,14.0,0.0,14.0,372.65,1.14,98.0,91208.0 +2013-09-07 16:00:00+00:00,26.22,73.82,143.0,0.0,143.0,380.65,0.75,106.0,91181.0 +2013-09-07 17:00:00+00:00,26.99,68.45,454.0,126.74,360.0,388.65,0.37,113.0,91154.0 +2013-09-07 18:00:00+00:00,27.16,68.33,541.0,134.99,427.0,390.67,0.6,122.0,91091.0 +2013-09-07 19:00:00+00:00,27.34,68.2,737.0,361.53,414.0,392.68,0.83,130.0,91028.0 +2013-09-07 20:00:00+00:00,27.51,68.08,49.0,0.0,49.0,394.7,1.06,139.0,90965.0 +2013-09-07 21:00:00+00:00,26.94,72.47,51.0,0.0,51.0,390.5,1.29,143.0,90962.0 +2013-09-07 22:00:00+00:00,26.37,76.86,197.0,8.54,191.0,386.3,1.52,146.0,90959.0 +2013-09-07 23:00:00+00:00,25.8,81.25,195.0,14.78,187.0,382.1,1.75,150.0,90956.0 +2013-09-08 00:00:00+00:00,26.14,79.44,137.0,29.24,127.0,377.73,1.55,118.0,90926.0 +2013-09-08 01:00:00+00:00,26.49,77.64,2.0,0.0,2.0,373.37,1.35,86.0,90896.0 +2013-09-08 02:00:00+00:00,26.83,75.83,0.0,0.0,0.0,369.0,1.14,55.0,90866.0 +2013-09-08 03:00:00+00:00,26.54,77.4,0.0,0.0,0.0,369.4,1.0,66.0,90875.0 +2013-09-08 04:00:00+00:00,26.25,78.97,0.0,0.0,0.0,369.8,0.85,78.0,90884.0 +2013-09-08 05:00:00+00:00,25.96,80.54,0.0,0.0,0.0,370.2,0.7,89.0,90893.0 +2013-09-08 06:00:00+00:00,25.0,82.07,0.0,0.0,0.0,368.05,0.65,111.0,90890.0 +2013-09-08 07:00:00+00:00,24.04,83.59,0.0,0.0,0.0,365.9,0.59,134.0,90887.0 +2013-09-08 08:00:00+00:00,23.08,85.12,0.0,0.0,0.0,363.75,0.54,156.0,90884.0 +2013-09-08 09:00:00+00:00,22.61,88.83,0.0,0.0,0.0,365.05,0.56,166.0,90893.0 +2013-09-08 10:00:00+00:00,22.15,92.53,0.0,0.0,0.0,366.35,0.57,177.0,90902.0 +2013-09-08 11:00:00+00:00,21.68,96.24,0.0,0.0,0.0,367.65,0.59,187.0,90911.0 +2013-09-08 12:00:00+00:00,22.04,94.14,0.0,0.0,0.0,370.45,0.54,198.0,90965.0 +2013-09-08 13:00:00+00:00,22.39,92.03,0.0,0.0,0.0,373.25,0.49,210.0,91019.0 +2013-09-08 14:00:00+00:00,22.74,89.93,61.0,0.0,61.0,376.05,0.44,221.0,91073.0 +2013-09-08 15:00:00+00:00,23.08,86.7,46.0,0.0,46.0,378.85,0.35,196.0,91073.0 +2013-09-08 16:00:00+00:00,23.42,83.47,41.0,0.0,41.0,381.65,0.27,170.0,91073.0 +2013-09-08 17:00:00+00:00,23.75,80.24,93.0,0.0,93.0,384.45,0.18,145.0,91073.0 +2013-09-08 18:00:00+00:00,24.04,81.37,851.0,899.02,94.0,385.35,0.77,156.0,91019.0 +2013-09-08 19:00:00+00:00,24.34,82.5,543.0,104.42,450.0,386.25,1.36,167.0,90965.0 +2013-09-08 20:00:00+00:00,24.63,83.63,91.0,0.0,91.0,387.15,1.94,177.0,90911.0 +2013-09-08 21:00:00+00:00,24.16,85.67,821.0,892.78,92.0,387.93,2.05,187.0,90902.0 +2013-09-08 22:00:00+00:00,23.69,87.72,306.0,34.34,282.0,388.72,2.15,197.0,90893.0 +2013-09-08 23:00:00+00:00,23.22,89.76,248.0,54.0,219.0,389.5,2.25,207.0,90884.0 +2013-09-09 00:00:00+00:00,23.6,85.78,207.0,225.26,131.0,380.4,1.71,206.0,90881.0 +2013-09-09 01:00:00+00:00,23.99,81.81,57.0,122.74,42.0,371.3,1.17,205.0,90878.0 +2013-09-09 02:00:00+00:00,24.37,77.83,0.0,0.0,0.0,362.2,0.63,204.0,90875.0 +2013-09-09 03:00:00+00:00,24.05,82.14,0.0,0.0,0.0,367.2,0.97,204.0,90908.0 +2013-09-09 04:00:00+00:00,23.72,86.45,0.0,0.0,0.0,372.2,1.31,205.0,90941.0 +2013-09-09 05:00:00+00:00,23.4,90.76,0.0,0.0,0.0,377.2,1.64,205.0,90974.0 +2013-09-09 06:00:00+00:00,23.02,92.09,0.0,0.0,0.0,381.6,1.58,204.0,90992.0 +2013-09-09 07:00:00+00:00,22.64,93.41,0.0,0.0,0.0,386.0,1.51,203.0,91010.0 +2013-09-09 08:00:00+00:00,22.26,94.74,0.0,0.0,0.0,390.4,1.45,202.0,91028.0 +2013-09-09 09:00:00+00:00,21.95,96.19,0.0,0.0,0.0,392.27,1.71,201.0,91040.0 +2013-09-09 10:00:00+00:00,21.64,97.65,0.0,0.0,0.0,394.13,1.97,201.0,91052.0 +2013-09-09 11:00:00+00:00,21.33,99.1,0.0,0.0,0.0,396.0,2.23,200.0,91064.0 +2013-09-09 12:00:00+00:00,21.54,96.99,0.0,0.0,0.0,394.3,2.07,209.0,91118.0 +2013-09-09 13:00:00+00:00,21.75,94.89,0.0,0.0,0.0,392.6,1.91,218.0,91172.0 +2013-09-09 14:00:00+00:00,21.95,92.78,141.0,513.24,43.0,390.9,1.75,227.0,91226.0 +2013-09-09 15:00:00+00:00,22.72,89.65,361.0,734.85,66.0,391.17,2.22,223.0,91235.0 +2013-09-09 16:00:00+00:00,23.5,86.53,572.0,838.8,79.0,391.43,2.69,219.0,91244.0 +2013-09-09 17:00:00+00:00,24.27,83.4,748.0,895.33,88.0,391.7,3.16,216.0,91253.0 +2013-09-09 18:00:00+00:00,24.96,82.17,870.0,924.36,94.0,391.88,3.18,217.0,91208.0 +2013-09-09 19:00:00+00:00,25.65,80.95,929.0,938.29,96.0,392.07,3.2,219.0,91163.0 +2013-09-09 20:00:00+00:00,26.34,79.72,681.0,276.53,438.0,392.25,3.23,221.0,91118.0 +2013-09-09 21:00:00+00:00,26.25,80.08,541.0,180.82,394.0,387.0,3.23,230.0,91118.0 +2013-09-09 22:00:00+00:00,26.16,80.43,252.0,17.27,240.0,381.75,3.24,239.0,91118.0 +2013-09-09 23:00:00+00:00,26.07,80.79,508.0,810.89,76.0,376.5,3.24,247.0,91118.0 +2013-09-10 00:00:00+00:00,24.9,82.21,203.0,216.36,131.0,366.5,2.71,204.0,91160.0 +2013-09-10 01:00:00+00:00,23.72,83.62,79.0,400.34,32.0,356.5,2.18,161.0,91202.0 +2013-09-10 02:00:00+00:00,22.55,85.04,0.0,0.0,0.0,346.5,1.66,118.0,91244.0 +2013-09-10 03:00:00+00:00,21.99,90.03,0.0,0.0,0.0,341.3,1.34,117.0,91283.0 +2013-09-10 04:00:00+00:00,21.44,95.01,0.0,0.0,0.0,336.1,1.03,115.0,91322.0 +2013-09-10 05:00:00+00:00,20.88,100.0,0.0,0.0,0.0,330.9,0.72,114.0,91361.0 +2013-09-10 06:00:00+00:00,20.27,100.0,0.0,0.0,0.0,328.33,0.72,112.0,91361.0 +2013-09-10 07:00:00+00:00,19.67,100.0,0.0,0.0,0.0,325.77,0.72,111.0,91361.0 +2013-09-10 08:00:00+00:00,19.06,100.0,0.0,0.0,0.0,323.2,0.72,109.0,91361.0 +2013-09-10 09:00:00+00:00,18.47,100.0,0.0,0.0,0.0,322.27,0.93,103.0,91361.0 +2013-09-10 10:00:00+00:00,17.88,100.0,0.0,0.0,0.0,321.33,1.15,96.0,91361.0 +2013-09-10 11:00:00+00:00,17.28,100.0,0.0,0.0,0.0,320.4,1.37,89.0,91361.0 +2013-09-10 12:00:00+00:00,19.26,96.71,0.0,0.0,0.0,323.17,1.1,65.0,91413.0 +2013-09-10 13:00:00+00:00,21.23,93.41,0.0,0.0,0.0,325.93,0.83,40.0,91464.0 +2013-09-10 14:00:00+00:00,23.2,90.12,142.0,524.15,43.0,328.7,0.57,16.0,91515.0 +2013-09-10 15:00:00+00:00,24.97,78.82,363.0,743.64,66.0,333.87,1.33,10.0,91500.0 +2013-09-10 16:00:00+00:00,26.74,67.52,574.0,845.28,79.0,339.03,2.1,5.0,91485.0 +2013-09-10 17:00:00+00:00,28.51,56.22,749.0,899.52,88.0,344.2,2.87,359.0,91470.0 +2013-09-10 18:00:00+00:00,29.3,52.68,871.0,929.6,93.0,350.0,3.06,353.0,91400.0 +2013-09-10 19:00:00+00:00,30.09,49.15,929.0,942.5,95.0,355.8,3.25,347.0,91331.0 +2013-09-10 20:00:00+00:00,30.88,45.61,919.0,941.2,95.0,361.6,3.43,341.0,91262.0 +2013-09-10 21:00:00+00:00,30.7,45.82,840.0,924.23,92.0,362.78,3.65,342.0,91229.0 +2013-09-10 22:00:00+00:00,30.51,46.02,701.0,891.53,85.0,363.97,3.86,343.0,91196.0 +2013-09-10 23:00:00+00:00,30.33,46.23,512.0,827.01,75.0,365.15,4.07,344.0,91163.0 +2013-09-11 00:00:00+00:00,29.0,52.76,293.0,713.13,59.0,363.58,3.47,359.0,91178.0 +2013-09-11 01:00:00+00:00,27.67,59.28,78.0,417.55,31.0,362.02,2.87,13.0,91193.0 +2013-09-11 02:00:00+00:00,26.34,65.81,0.0,0.0,0.0,360.45,2.28,28.0,91208.0 +2013-09-11 03:00:00+00:00,25.72,69.45,0.0,0.0,0.0,359.38,1.79,30.0,91238.0 +2013-09-11 04:00:00+00:00,25.1,73.1,0.0,0.0,0.0,358.32,1.31,33.0,91268.0 +2013-09-11 05:00:00+00:00,24.48,76.74,0.0,0.0,0.0,357.25,0.83,35.0,91298.0 +2013-09-11 06:00:00+00:00,23.65,79.98,0.0,0.0,0.0,353.25,0.81,41.0,91271.0 +2013-09-11 07:00:00+00:00,22.83,83.23,0.0,0.0,0.0,349.25,0.8,47.0,91244.0 +2013-09-11 08:00:00+00:00,22.0,86.47,0.0,0.0,0.0,345.25,0.79,53.0,91217.0 +2013-09-11 09:00:00+00:00,21.49,87.58,0.0,0.0,0.0,344.88,1.0,58.0,91193.0 +2013-09-11 10:00:00+00:00,20.98,88.68,0.0,0.0,0.0,344.52,1.22,63.0,91169.0 +2013-09-11 11:00:00+00:00,20.46,89.79,0.0,0.0,0.0,344.15,1.43,68.0,91145.0 +2013-09-11 12:00:00+00:00,21.88,83.83,0.0,0.0,0.0,346.02,1.65,70.0,91184.0 +2013-09-11 13:00:00+00:00,23.29,77.88,0.0,0.0,0.0,347.88,1.87,72.0,91223.0 +2013-09-11 14:00:00+00:00,24.7,71.92,140.0,524.64,42.0,349.75,2.08,74.0,91262.0 +2013-09-11 15:00:00+00:00,26.51,63.79,361.0,745.02,65.0,356.25,2.23,72.0,91238.0 +2013-09-11 16:00:00+00:00,28.32,55.67,573.0,848.44,78.0,362.75,2.39,70.0,91214.0 +2013-09-11 17:00:00+00:00,30.13,47.54,747.0,901.06,87.0,369.25,2.54,68.0,91190.0 +2013-09-11 18:00:00+00:00,30.92,43.34,868.0,930.14,92.0,370.98,2.38,54.0,91112.0 +2013-09-11 19:00:00+00:00,31.72,39.13,925.0,942.25,94.0,372.72,2.23,39.0,91034.0 +2013-09-11 20:00:00+00:00,32.51,34.93,913.0,939.05,94.0,374.45,2.07,24.0,90956.0 +2013-09-11 21:00:00+00:00,32.48,33.65,832.0,921.01,90.0,372.95,2.27,30.0,90911.0 +2013-09-11 22:00:00+00:00,32.46,32.37,692.0,885.15,84.0,371.45,2.46,36.0,90866.0 +2013-09-11 23:00:00+00:00,32.43,31.09,503.0,818.66,74.0,369.95,2.66,41.0,90821.0 +2013-09-12 00:00:00+00:00,30.61,37.01,285.0,701.81,58.0,368.78,2.28,53.0,90833.0 +2013-09-12 01:00:00+00:00,28.78,42.92,72.0,389.98,30.0,367.62,1.9,65.0,90845.0 +2013-09-12 02:00:00+00:00,26.96,48.84,0.0,0.0,0.0,366.45,1.52,76.0,90857.0 +2013-09-12 03:00:00+00:00,26.2,53.91,0.0,0.0,0.0,364.1,1.51,76.0,90899.0 +2013-09-12 04:00:00+00:00,25.45,58.99,0.0,0.0,0.0,361.75,1.51,76.0,90941.0 +2013-09-12 05:00:00+00:00,24.69,64.06,0.0,0.0,0.0,359.4,1.5,76.0,90983.0 +2013-09-12 06:00:00+00:00,24.15,67.38,0.0,0.0,0.0,357.08,1.96,76.0,90986.0 +2013-09-12 07:00:00+00:00,23.62,70.69,0.0,0.0,0.0,354.77,2.42,76.0,90989.0 +2013-09-12 08:00:00+00:00,23.08,74.01,0.0,0.0,0.0,352.45,2.88,77.0,90992.0 +2013-09-12 09:00:00+00:00,22.63,78.01,0.0,0.0,0.0,348.93,2.47,76.0,90983.0 +2013-09-12 10:00:00+00:00,22.18,82.02,0.0,0.0,0.0,345.42,2.06,76.0,90974.0 +2013-09-12 11:00:00+00:00,21.73,86.02,0.0,0.0,0.0,341.9,1.66,75.0,90965.0 +2013-09-12 12:00:00+00:00,23.01,84.32,0.0,0.0,0.0,344.67,1.88,78.0,90956.0 +2013-09-12 13:00:00+00:00,24.29,82.61,0.0,0.0,0.0,347.43,2.1,80.0,90947.0 +2013-09-12 14:00:00+00:00,25.57,80.91,136.0,508.93,42.0,350.2,2.32,83.0,90938.0 +2013-09-12 15:00:00+00:00,27.29,75.52,354.0,733.8,64.0,354.55,1.83,97.0,90920.0 +2013-09-12 16:00:00+00:00,29.01,70.12,565.0,839.62,77.0,358.9,1.34,110.0,90902.0 +2013-09-12 17:00:00+00:00,30.73,64.73,739.0,894.44,86.0,363.25,0.86,124.0,90884.0 +2013-09-12 18:00:00+00:00,31.55,61.19,861.0,925.91,91.0,368.17,1.31,132.0,90815.0 +2013-09-12 19:00:00+00:00,32.36,57.65,919.0,939.78,93.0,373.08,1.76,139.0,90746.0 +2013-09-12 20:00:00+00:00,33.18,54.11,908.0,938.09,93.0,378.0,2.21,146.0,90677.0 +2013-09-12 21:00:00+00:00,33.21,52.75,829.0,922.82,89.0,376.97,2.31,124.0,90637.0 +2013-09-12 22:00:00+00:00,33.24,51.38,688.0,886.07,83.0,375.93,2.42,102.0,90598.0 +2013-09-12 23:00:00+00:00,33.27,50.02,499.0,819.86,73.0,374.9,2.52,79.0,90559.0 +2013-09-13 00:00:00+00:00,31.54,58.15,95.0,0.0,95.0,376.05,2.29,81.0,90589.0 +2013-09-13 01:00:00+00:00,29.82,66.29,69.0,389.05,29.0,377.2,2.05,82.0,90619.0 +2013-09-13 02:00:00+00:00,28.09,74.42,0.0,0.0,0.0,378.35,1.81,84.0,90650.0 +2013-09-13 03:00:00+00:00,27.35,79.06,0.0,0.0,0.0,376.3,1.98,84.0,90701.0 +2013-09-13 04:00:00+00:00,26.62,83.71,0.0,0.0,0.0,374.25,2.16,85.0,90752.0 +2013-09-13 05:00:00+00:00,25.88,88.35,0.0,0.0,0.0,372.2,2.33,85.0,90803.0 +2013-09-13 06:00:00+00:00,25.16,91.08,0.0,0.0,0.0,366.72,2.72,86.0,90791.0 +2013-09-13 07:00:00+00:00,24.45,93.81,0.0,0.0,0.0,361.23,3.11,87.0,90779.0 +2013-09-13 08:00:00+00:00,23.73,96.54,0.0,0.0,0.0,355.75,3.5,88.0,90767.0 +2013-09-13 09:00:00+00:00,23.24,97.69,0.0,0.0,0.0,354.12,3.29,88.0,90767.0 +2013-09-13 10:00:00+00:00,22.75,98.85,0.0,0.0,0.0,352.48,3.07,89.0,90767.0 +2013-09-13 11:00:00+00:00,22.25,100.0,0.0,0.0,0.0,350.85,2.86,89.0,90767.0 +2013-09-13 12:00:00+00:00,23.8,94.18,0.0,0.0,0.0,353.33,2.98,90.0,90776.0 +2013-09-13 13:00:00+00:00,25.35,88.37,0.0,0.0,0.0,355.82,3.1,92.0,90785.0 +2013-09-13 14:00:00+00:00,26.9,82.55,134.0,509.33,41.0,358.3,3.23,93.0,90794.0 +2013-09-13 15:00:00+00:00,28.42,73.29,353.0,737.77,63.0,363.13,2.6,102.0,90785.0 +2013-09-13 16:00:00+00:00,29.95,64.04,563.0,839.41,77.0,367.97,1.97,111.0,90776.0 +2013-09-13 17:00:00+00:00,31.47,54.78,736.0,894.69,85.0,372.8,1.34,120.0,90767.0 +2013-09-13 18:00:00+00:00,32.16,51.33,856.0,924.13,90.0,375.75,1.41,115.0,90722.0 +2013-09-13 19:00:00+00:00,32.84,47.88,912.0,936.21,92.0,378.7,1.48,109.0,90677.0 +2013-09-13 20:00:00+00:00,33.53,44.43,900.0,933.71,92.0,381.65,1.54,104.0,90631.0 +2013-09-13 21:00:00+00:00,33.25,43.55,820.0,915.93,89.0,381.13,1.6,89.0,90613.0 +2013-09-13 22:00:00+00:00,32.97,42.68,680.0,881.18,82.0,380.62,1.66,74.0,90595.0 +2013-09-13 23:00:00+00:00,32.69,41.8,491.0,813.37,72.0,380.1,1.72,59.0,90577.0 +2013-09-14 00:00:00+00:00,31.28,45.33,91.0,0.0,91.0,378.72,1.95,63.0,90598.0 +2013-09-14 01:00:00+00:00,29.86,48.85,64.0,367.67,28.0,377.33,2.18,66.0,90619.0 +2013-09-14 02:00:00+00:00,28.45,52.38,0.0,0.0,0.0,375.95,2.41,70.0,90640.0 +2013-09-14 03:00:00+00:00,27.52,58.49,0.0,0.0,0.0,374.77,2.37,65.0,90698.0 +2013-09-14 04:00:00+00:00,26.58,64.61,0.0,0.0,0.0,373.58,2.33,61.0,90755.0 +2013-09-14 05:00:00+00:00,25.65,70.72,0.0,0.0,0.0,372.4,2.29,57.0,90812.0 +2013-09-14 06:00:00+00:00,24.9,76.13,0.0,0.0,0.0,369.03,2.71,61.0,90815.0 +2013-09-14 07:00:00+00:00,24.16,81.54,0.0,0.0,0.0,365.67,3.14,66.0,90818.0 +2013-09-14 08:00:00+00:00,23.41,86.95,0.0,0.0,0.0,362.3,3.56,70.0,90821.0 +2013-09-14 09:00:00+00:00,22.93,90.12,0.0,0.0,0.0,358.72,3.32,73.0,90815.0 +2013-09-14 10:00:00+00:00,22.45,93.28,0.0,0.0,0.0,355.13,3.08,76.0,90809.0 +2013-09-14 11:00:00+00:00,21.96,96.45,0.0,0.0,0.0,351.55,2.84,78.0,90803.0 +2013-09-14 12:00:00+00:00,23.33,90.93,0.0,0.0,0.0,352.35,2.93,79.0,90839.0 +2013-09-14 13:00:00+00:00,24.69,85.4,0.0,0.0,0.0,353.15,3.02,79.0,90875.0 +2013-09-14 14:00:00+00:00,26.05,79.88,134.0,515.33,41.0,353.95,3.1,80.0,90911.0 +2013-09-14 15:00:00+00:00,28.19,68.1,355.0,746.95,63.0,356.38,2.92,84.0,90899.0 +2013-09-14 16:00:00+00:00,30.33,56.31,566.0,847.93,77.0,358.82,2.74,88.0,90887.0 +2013-09-14 17:00:00+00:00,32.46,44.53,740.0,903.28,85.0,361.25,2.57,93.0,90875.0 +2013-09-14 18:00:00+00:00,33.28,39.69,860.0,932.07,90.0,365.77,2.18,93.0,90842.0 +2013-09-14 19:00:00+00:00,34.1,34.84,916.0,944.13,92.0,370.28,1.79,92.0,90809.0 +2013-09-14 20:00:00+00:00,34.92,30.0,903.0,940.95,92.0,374.8,1.41,92.0,90776.0 +2013-09-14 21:00:00+00:00,34.77,29.18,822.0,924.14,88.0,376.15,1.54,86.0,90758.0 +2013-09-14 22:00:00+00:00,34.62,28.36,680.0,886.65,82.0,377.5,1.67,80.0,90740.0 +2013-09-14 23:00:00+00:00,34.47,27.54,489.0,816.62,72.0,378.85,1.81,74.0,90722.0 +2013-09-15 00:00:00+00:00,32.47,31.92,271.0,695.28,56.0,372.63,2.0,75.0,90752.0 +2013-09-15 01:00:00+00:00,30.46,36.29,61.0,365.6,27.0,366.42,2.18,75.0,90782.0 +2013-09-15 02:00:00+00:00,28.46,40.67,0.0,0.0,0.0,360.2,2.37,76.0,90812.0 +2013-09-15 03:00:00+00:00,27.91,45.74,0.0,0.0,0.0,359.18,2.84,79.0,90863.0 +2013-09-15 04:00:00+00:00,27.36,50.82,0.0,0.0,0.0,358.17,3.3,83.0,90914.0 +2013-09-15 05:00:00+00:00,26.81,55.89,0.0,0.0,0.0,357.15,3.77,86.0,90965.0 +2013-09-15 06:00:00+00:00,26.3,60.53,0.0,0.0,0.0,354.9,3.63,85.0,90986.0 +2013-09-15 07:00:00+00:00,25.8,65.16,0.0,0.0,0.0,352.65,3.5,83.0,91007.0 +2013-09-15 08:00:00+00:00,25.29,69.8,0.0,0.0,0.0,350.4,3.37,81.0,91028.0 +2013-09-15 09:00:00+00:00,24.7,72.3,0.0,0.0,0.0,348.6,3.14,79.0,91034.0 +2013-09-15 10:00:00+00:00,24.11,74.8,0.0,0.0,0.0,346.8,2.91,77.0,91040.0 +2013-09-15 11:00:00+00:00,23.51,77.3,0.0,0.0,0.0,345.0,2.69,74.0,91046.0 +2013-09-15 12:00:00+00:00,24.92,71.7,0.0,0.0,0.0,347.3,3.06,75.0,91064.0 +2013-09-15 13:00:00+00:00,26.33,66.1,0.0,0.0,0.0,349.6,3.43,75.0,91082.0 +2013-09-15 14:00:00+00:00,27.73,60.5,131.0,504.69,41.0,351.9,3.81,75.0,91100.0 +2013-09-15 15:00:00+00:00,29.61,53.31,350.0,738.28,63.0,357.3,4.02,82.0,91097.0 +2013-09-15 16:00:00+00:00,31.49,46.13,559.0,840.9,76.0,362.7,4.23,90.0,91094.0 +2013-09-15 17:00:00+00:00,33.36,38.94,731.0,893.99,85.0,368.1,4.44,97.0,91091.0 +2013-09-15 18:00:00+00:00,34.01,36.91,850.0,923.11,90.0,369.7,3.26,98.0,91037.0 +2013-09-15 19:00:00+00:00,34.66,34.89,904.0,933.75,92.0,371.3,2.08,100.0,90983.0 +2013-09-15 20:00:00+00:00,35.31,32.86,890.0,930.83,91.0,372.9,0.9,102.0,90929.0 +2013-09-15 21:00:00+00:00,34.77,34.27,808.0,910.97,88.0,376.45,1.79,98.0,90920.0 +2013-09-15 22:00:00+00:00,34.24,35.67,667.0,872.86,82.0,380.0,2.68,94.0,90911.0 +2013-09-15 23:00:00+00:00,33.7,37.08,478.0,804.18,71.0,383.55,3.57,91.0,90902.0 +2013-09-16 00:00:00+00:00,31.96,39.94,262.0,676.65,56.0,377.87,4.22,84.0,90917.0 +2013-09-16 01:00:00+00:00,30.23,42.8,56.0,340.64,26.0,372.18,4.87,78.0,90932.0 +2013-09-16 02:00:00+00:00,28.49,45.66,0.0,0.0,0.0,366.5,5.52,72.0,90947.0 +2013-09-16 03:00:00+00:00,27.74,50.22,0.0,0.0,0.0,366.33,5.69,75.0,90986.0 +2013-09-16 04:00:00+00:00,26.98,54.79,0.0,0.0,0.0,366.17,5.87,79.0,91025.0 +2013-09-16 05:00:00+00:00,26.23,59.35,0.0,0.0,0.0,366.0,6.04,83.0,91064.0 +2013-09-16 06:00:00+00:00,25.6,62.98,0.0,0.0,0.0,361.95,5.65,83.0,91058.0 +2013-09-16 07:00:00+00:00,24.96,66.61,0.0,0.0,0.0,357.9,5.26,83.0,91052.0 +2013-09-16 08:00:00+00:00,24.33,70.24,0.0,0.0,0.0,353.85,4.87,84.0,91046.0 +2013-09-16 09:00:00+00:00,23.84,72.85,0.0,0.0,0.0,351.92,4.67,82.0,91031.0 +2013-09-16 10:00:00+00:00,23.35,75.47,0.0,0.0,0.0,349.98,4.46,80.0,91016.0 +2013-09-16 11:00:00+00:00,22.85,78.08,0.0,0.0,0.0,348.05,4.26,79.0,91001.0 +2013-09-16 12:00:00+00:00,24.66,72.94,0.0,0.0,0.0,353.78,4.04,82.0,91004.0 +2013-09-16 13:00:00+00:00,26.47,67.79,0.0,0.0,0.0,359.52,3.82,86.0,91007.0 +2013-09-16 14:00:00+00:00,28.28,62.65,128.0,499.51,40.0,365.25,3.6,90.0,91010.0 +2013-09-16 15:00:00+00:00,29.65,55.88,346.0,732.14,63.0,367.42,3.11,99.0,90998.0 +2013-09-16 16:00:00+00:00,31.02,49.11,555.0,837.35,76.0,369.58,2.63,109.0,90986.0 +2013-09-16 17:00:00+00:00,32.39,42.34,728.0,894.4,84.0,371.75,2.14,118.0,90974.0 +2013-09-16 18:00:00+00:00,33.24,37.89,847.0,923.9,89.0,372.55,1.62,120.0,90890.0 +2013-09-16 19:00:00+00:00,34.1,33.45,902.0,934.9,92.0,373.35,1.1,122.0,90806.0 +2013-09-16 20:00:00+00:00,34.95,29.0,888.0,932.37,91.0,374.15,0.58,124.0,90722.0 +2013-09-16 21:00:00+00:00,35.02,27.96,807.0,914.26,88.0,374.6,0.58,115.0,90671.0 +2013-09-16 22:00:00+00:00,35.08,26.92,665.0,876.96,81.0,375.05,0.58,106.0,90619.0 +2013-09-16 23:00:00+00:00,35.15,25.88,476.0,807.51,71.0,375.5,0.58,97.0,90568.0 +2013-09-17 00:00:00+00:00,33.88,28.31,258.0,677.5,55.0,375.75,0.65,101.0,90571.0 +2013-09-17 01:00:00+00:00,32.61,30.75,52.0,324.79,25.0,376.0,0.73,104.0,90574.0 +2013-09-17 02:00:00+00:00,31.34,33.18,0.0,0.0,0.0,376.25,0.8,108.0,90577.0 +2013-09-17 03:00:00+00:00,30.45,35.86,0.0,0.0,0.0,375.0,1.46,113.0,90616.0 +2013-09-17 04:00:00+00:00,29.56,38.54,0.0,0.0,0.0,373.75,2.11,117.0,90656.0 +2013-09-17 05:00:00+00:00,28.67,41.22,0.0,0.0,0.0,372.5,2.77,122.0,90695.0 +2013-09-17 06:00:00+00:00,27.91,43.28,0.0,0.0,0.0,370.08,2.41,124.0,90716.0 +2013-09-17 07:00:00+00:00,27.14,45.34,0.0,0.0,0.0,367.67,2.06,126.0,90737.0 +2013-09-17 08:00:00+00:00,26.38,47.4,0.0,0.0,0.0,365.25,1.7,127.0,90758.0 +2013-09-17 09:00:00+00:00,25.81,48.34,0.0,0.0,0.0,365.22,1.66,123.0,90758.0 +2013-09-17 10:00:00+00:00,25.25,49.29,0.0,0.0,0.0,365.18,1.62,118.0,90758.0 +2013-09-17 11:00:00+00:00,24.68,50.23,0.0,0.0,0.0,365.15,1.59,113.0,90758.0 +2013-09-17 12:00:00+00:00,25.95,45.71,0.0,0.0,0.0,365.92,1.72,125.0,90794.0 +2013-09-17 13:00:00+00:00,27.22,41.2,0.0,0.0,0.0,366.68,1.85,136.0,90830.0 +2013-09-17 14:00:00+00:00,28.49,36.68,126.0,494.26,40.0,367.45,1.99,147.0,90866.0 +2013-09-17 15:00:00+00:00,30.21,30.91,345.0,733.79,63.0,368.45,2.02,170.0,90845.0 +2013-09-17 16:00:00+00:00,31.94,25.15,554.0,839.1,76.0,369.45,2.06,192.0,90824.0 +2013-09-17 17:00:00+00:00,33.66,19.38,727.0,896.27,84.0,370.45,2.1,215.0,90803.0 +2013-09-17 18:00:00+00:00,34.52,19.12,845.0,924.74,89.0,372.9,2.37,241.0,90734.0 +2013-09-17 19:00:00+00:00,35.37,18.86,900.0,936.1,92.0,375.35,2.64,267.0,90665.0 +2013-09-17 20:00:00+00:00,36.23,18.6,885.0,932.81,91.0,377.8,2.91,293.0,90595.0 +2013-09-17 21:00:00+00:00,35.97,18.68,802.0,913.79,87.0,379.55,3.2,307.0,90556.0 +2013-09-17 22:00:00+00:00,35.72,18.75,660.0,875.12,81.0,381.3,3.49,320.0,90517.0 +2013-09-17 23:00:00+00:00,35.46,18.83,470.0,802.91,71.0,383.05,3.78,334.0,90478.0 +2013-09-18 00:00:00+00:00,34.03,20.24,254.0,675.03,55.0,379.6,3.42,277.0,90514.0 +2013-09-18 01:00:00+00:00,32.61,21.65,49.0,319.76,24.0,376.15,3.06,221.0,90550.0 +2013-09-18 02:00:00+00:00,31.18,23.06,0.0,0.0,0.0,372.7,2.7,164.0,90586.0 +2013-09-18 03:00:00+00:00,30.21,24.57,0.0,0.0,0.0,371.98,2.33,176.0,90637.0 +2013-09-18 04:00:00+00:00,29.24,26.08,0.0,0.0,0.0,371.27,1.96,187.0,90689.0 +2013-09-18 05:00:00+00:00,28.27,27.59,0.0,0.0,0.0,370.55,1.59,199.0,90740.0 +2013-09-18 06:00:00+00:00,27.73,31.29,0.0,0.0,0.0,369.4,1.44,228.0,90749.0 +2013-09-18 07:00:00+00:00,27.2,34.98,0.0,0.0,0.0,368.25,1.29,256.0,90758.0 +2013-09-18 08:00:00+00:00,26.66,38.68,0.0,0.0,0.0,367.1,1.14,285.0,90767.0 +2013-09-18 09:00:00+00:00,26.28,40.15,0.0,0.0,0.0,362.48,0.97,319.0,90761.0 +2013-09-18 10:00:00+00:00,25.9,41.63,0.0,0.0,0.0,357.87,0.8,352.0,90755.0 +2013-09-18 11:00:00+00:00,25.51,43.1,0.0,0.0,0.0,353.25,0.62,25.0,90749.0 +2013-09-18 12:00:00+00:00,26.03,41.04,0.0,0.0,0.0,354.45,0.49,28.0,90803.0 +2013-09-18 13:00:00+00:00,26.55,38.99,0.0,0.0,0.0,355.65,0.35,31.0,90857.0 +2013-09-18 14:00:00+00:00,27.07,36.93,128.0,512.2,40.0,356.85,0.22,34.0,90911.0 +2013-09-18 15:00:00+00:00,29.13,30.0,351.0,753.83,63.0,358.92,1.03,41.0,90887.0 +2013-09-18 16:00:00+00:00,31.19,23.06,564.0,860.31,76.0,360.98,1.85,47.0,90863.0 +2013-09-18 17:00:00+00:00,33.24,16.13,739.0,914.99,85.0,363.05,2.66,54.0,90839.0 +2013-09-18 18:00:00+00:00,33.94,15.69,858.0,942.83,90.0,369.6,2.73,56.0,90779.0 +2013-09-18 19:00:00+00:00,34.63,15.24,911.0,952.49,92.0,376.15,2.79,58.0,90719.0 +2013-09-18 20:00:00+00:00,35.33,14.8,896.0,949.82,91.0,382.7,2.86,60.0,90659.0 +2013-09-18 21:00:00+00:00,35.26,14.98,812.0,930.08,88.0,382.35,3.2,60.0,90622.0 +2013-09-18 22:00:00+00:00,35.19,15.17,667.0,890.03,82.0,382.0,3.54,61.0,90586.0 +2013-09-18 23:00:00+00:00,35.12,15.35,475.0,820.6,71.0,381.65,3.88,62.0,90550.0 +2013-09-19 00:00:00+00:00,33.72,15.22,254.0,686.3,55.0,381.48,3.62,64.0,90571.0 +2013-09-19 01:00:00+00:00,32.33,15.09,47.0,327.73,23.0,381.32,3.37,67.0,90592.0 +2013-09-19 02:00:00+00:00,30.93,14.96,0.0,0.0,0.0,381.15,3.12,70.0,90613.0 +2013-09-19 03:00:00+00:00,29.85,17.34,0.0,0.0,0.0,379.12,2.6,75.0,90659.0 +2013-09-19 04:00:00+00:00,28.78,19.72,0.0,0.0,0.0,377.08,2.08,81.0,90704.0 +2013-09-19 05:00:00+00:00,27.7,22.1,0.0,0.0,0.0,375.05,1.56,86.0,90749.0 +2013-09-19 06:00:00+00:00,26.78,22.96,0.0,0.0,0.0,369.33,1.45,86.0,90761.0 +2013-09-19 07:00:00+00:00,25.85,23.83,0.0,0.0,0.0,363.62,1.35,85.0,90773.0 +2013-09-19 08:00:00+00:00,24.93,24.69,0.0,0.0,0.0,357.9,1.24,85.0,90785.0 +2013-09-19 09:00:00+00:00,24.17,28.61,0.0,0.0,0.0,351.4,1.33,82.0,90785.0 +2013-09-19 10:00:00+00:00,23.41,32.52,0.0,0.0,0.0,344.9,1.42,79.0,90785.0 +2013-09-19 11:00:00+00:00,22.64,36.44,0.0,0.0,0.0,338.4,1.5,76.0,90785.0 +2013-09-19 12:00:00+00:00,23.95,32.49,0.0,0.0,0.0,338.58,1.52,79.0,90854.0 +2013-09-19 13:00:00+00:00,25.26,28.53,0.0,0.0,0.0,338.77,1.53,83.0,90923.0 +2013-09-19 14:00:00+00:00,26.57,24.58,125.0,501.18,40.0,338.95,1.54,86.0,90992.0 +2013-09-19 15:00:00+00:00,28.69,21.23,345.0,742.58,63.0,343.63,1.37,94.0,90989.0 +2013-09-19 16:00:00+00:00,30.81,17.87,555.0,848.11,76.0,348.32,1.2,101.0,90986.0 +2013-09-19 17:00:00+00:00,32.93,14.52,727.0,903.01,84.0,353.0,1.03,109.0,90983.0 +2013-09-19 18:00:00+00:00,33.57,14.7,844.0,930.3,89.0,357.78,1.15,107.0,90956.0 +2013-09-19 19:00:00+00:00,34.22,14.88,896.0,938.7,92.0,362.57,1.26,105.0,90929.0 +2013-09-19 20:00:00+00:00,34.86,15.06,880.0,935.04,91.0,367.35,1.38,103.0,90902.0 +2013-09-19 21:00:00+00:00,34.28,15.83,796.0,915.58,87.0,370.57,1.01,93.0,90899.0 +2013-09-19 22:00:00+00:00,33.7,16.6,653.0,876.1,81.0,373.78,0.63,82.0,90896.0 +2013-09-19 23:00:00+00:00,33.12,17.37,17.0,0.0,17.0,377.0,0.26,72.0,90893.0 +2013-09-20 00:00:00+00:00,32.13,19.96,8.0,0.0,8.0,378.65,0.85,77.0,90890.0 +2013-09-20 01:00:00+00:00,31.15,22.56,1.0,0.0,1.0,380.3,1.43,82.0,90887.0 +2013-09-20 02:00:00+00:00,30.16,25.15,0.0,0.0,0.0,381.95,2.01,86.0,90884.0 +2013-09-20 03:00:00+00:00,28.86,28.35,0.0,0.0,0.0,379.03,2.16,84.0,90950.0 +2013-09-20 04:00:00+00:00,27.57,31.54,0.0,0.0,0.0,376.12,2.3,82.0,91016.0 +2013-09-20 05:00:00+00:00,26.27,34.74,0.0,0.0,0.0,373.2,2.44,79.0,91082.0 +2013-09-20 06:00:00+00:00,25.4,38.24,0.0,0.0,0.0,365.4,2.15,76.0,91091.0 +2013-09-20 07:00:00+00:00,24.54,41.73,0.0,0.0,0.0,357.6,1.86,74.0,91100.0 +2013-09-20 08:00:00+00:00,23.67,45.23,0.0,0.0,0.0,349.8,1.57,71.0,91109.0 +2013-09-20 09:00:00+00:00,23.08,50.12,0.0,0.0,0.0,345.17,1.72,73.0,91100.0 +2013-09-20 10:00:00+00:00,22.5,55.0,0.0,0.0,0.0,340.53,1.88,74.0,91091.0 +2013-09-20 11:00:00+00:00,21.91,59.89,0.0,0.0,0.0,335.9,2.03,76.0,91082.0 +2013-09-20 12:00:00+00:00,23.13,57.41,0.0,0.0,0.0,333.55,2.1,79.0,91103.0 +2013-09-20 13:00:00+00:00,24.34,54.93,0.0,0.0,0.0,331.2,2.17,81.0,91124.0 +2013-09-20 14:00:00+00:00,25.55,52.45,122.0,495.91,39.0,328.85,2.23,84.0,91145.0 +2013-09-20 15:00:00+00:00,27.71,44.09,341.0,739.19,62.0,334.38,1.69,92.0,91124.0 +2013-09-20 16:00:00+00:00,29.87,35.72,552.0,846.53,76.0,339.92,1.14,100.0,91103.0 +2013-09-20 17:00:00+00:00,32.02,27.36,726.0,905.09,84.0,345.45,0.59,109.0,91082.0 +2013-09-20 18:00:00+00:00,33.02,25.65,845.0,933.81,90.0,347.45,1.16,113.0,90983.0 +2013-09-20 19:00:00+00:00,34.03,23.94,899.0,945.95,92.0,349.45,1.72,117.0,90884.0 +2013-09-20 20:00:00+00:00,35.03,22.23,882.0,941.6,91.0,351.45,2.29,121.0,90785.0 +2013-09-20 21:00:00+00:00,34.83,22.58,798.0,923.06,87.0,356.82,2.74,119.0,90725.0 +2013-09-20 22:00:00+00:00,34.62,22.93,456.0,248.27,295.0,362.18,3.2,117.0,90665.0 +2013-09-20 23:00:00+00:00,34.42,23.28,373.0,405.8,177.0,367.55,3.66,115.0,90604.0 +2013-09-21 00:00:00+00:00,33.43,25.23,187.0,317.59,98.0,373.87,3.25,124.0,90568.0 +2013-09-21 01:00:00+00:00,32.43,27.17,8.0,0.0,8.0,380.18,2.84,133.0,90532.0 +2013-09-21 02:00:00+00:00,31.44,29.12,0.0,0.0,0.0,386.5,2.43,142.0,90496.0 +2013-09-21 03:00:00+00:00,30.41,32.74,0.0,0.0,0.0,382.27,2.37,155.0,90550.0 +2013-09-21 04:00:00+00:00,29.37,36.35,0.0,0.0,0.0,378.03,2.31,168.0,90604.0 +2013-09-21 05:00:00+00:00,28.34,39.97,0.0,0.0,0.0,373.8,2.25,182.0,90659.0 +2013-09-21 06:00:00+00:00,27.42,42.35,0.0,0.0,0.0,367.97,2.48,185.0,90674.0 +2013-09-21 07:00:00+00:00,26.5,44.72,0.0,0.0,0.0,362.13,2.71,189.0,90689.0 +2013-09-21 08:00:00+00:00,25.58,47.1,0.0,0.0,0.0,356.3,2.94,193.0,90704.0 +2013-09-21 09:00:00+00:00,24.95,49.69,0.0,0.0,0.0,353.6,2.51,196.0,90707.0 +2013-09-21 10:00:00+00:00,24.32,52.29,0.0,0.0,0.0,350.9,2.08,199.0,90710.0 +2013-09-21 11:00:00+00:00,23.68,54.88,0.0,0.0,0.0,348.2,1.66,202.0,90713.0 +2013-09-21 12:00:00+00:00,24.52,55.74,0.0,0.0,0.0,351.97,2.66,197.0,90713.0 +2013-09-21 13:00:00+00:00,25.36,56.6,0.0,0.0,0.0,355.73,3.66,192.0,90713.0 +2013-09-21 14:00:00+00:00,26.19,57.46,118.0,478.44,39.0,359.5,4.66,186.0,90713.0 +2013-09-21 15:00:00+00:00,27.53,51.21,336.0,730.48,62.0,360.13,5.59,197.0,90701.0 +2013-09-21 16:00:00+00:00,28.87,44.95,547.0,843.21,75.0,360.77,6.52,208.0,90689.0 +2013-09-21 17:00:00+00:00,30.21,38.7,721.0,901.58,84.0,361.4,7.45,219.0,90677.0 +2013-09-21 18:00:00+00:00,30.86,35.63,841.0,933.67,89.0,365.33,7.89,225.0,90619.0 +2013-09-21 19:00:00+00:00,31.52,32.57,898.0,948.61,92.0,369.27,8.32,230.0,90562.0 +2013-09-21 20:00:00+00:00,32.17,29.5,887.0,951.85,91.0,373.2,8.76,236.0,90505.0 +2013-09-21 21:00:00+00:00,31.6,27.45,806.0,937.18,88.0,372.03,8.34,240.0,90505.0 +2013-09-21 22:00:00+00:00,31.04,25.4,663.0,903.68,81.0,370.87,7.91,244.0,90505.0 +2013-09-21 23:00:00+00:00,30.47,23.35,470.0,834.19,71.0,369.7,7.49,248.0,90505.0 +2013-09-22 00:00:00+00:00,29.38,20.84,247.0,700.89,54.0,371.68,6.39,253.0,90571.0 +2013-09-22 01:00:00+00:00,28.28,18.33,38.0,291.22,21.0,373.67,5.29,258.0,90637.0 +2013-09-22 02:00:00+00:00,27.19,15.82,0.0,0.0,0.0,375.65,4.19,264.0,90704.0 +2013-09-22 03:00:00+00:00,26.13,18.24,0.0,0.0,0.0,369.57,3.44,269.0,90773.0 +2013-09-22 04:00:00+00:00,25.08,20.67,0.0,0.0,0.0,363.48,2.69,274.0,90842.0 +2013-09-22 05:00:00+00:00,24.02,23.09,0.0,0.0,0.0,357.4,1.94,278.0,90911.0 +2013-09-22 06:00:00+00:00,23.51,24.41,0.0,0.0,0.0,351.38,1.68,280.0,90917.0 +2013-09-22 07:00:00+00:00,22.99,25.73,0.0,0.0,0.0,345.37,1.41,282.0,90923.0 +2013-09-22 08:00:00+00:00,22.48,27.05,0.0,0.0,0.0,339.35,1.14,283.0,90929.0 +2013-09-22 09:00:00+00:00,21.42,30.37,0.0,0.0,0.0,336.95,1.11,230.0,90938.0 +2013-09-22 10:00:00+00:00,20.36,33.68,0.0,0.0,0.0,334.55,1.08,177.0,90947.0 +2013-09-22 11:00:00+00:00,19.29,37.0,0.0,0.0,0.0,332.15,1.05,124.0,90956.0 +2013-09-22 12:00:00+00:00,20.59,33.99,0.0,0.0,0.0,331.92,1.05,131.0,91007.0 +2013-09-22 13:00:00+00:00,21.89,30.98,0.0,0.0,0.0,331.68,1.05,139.0,91058.0 +2013-09-22 14:00:00+00:00,23.18,27.97,127.0,534.23,40.0,331.45,1.05,146.0,91109.0 +2013-09-22 15:00:00+00:00,25.06,23.57,358.0,788.8,64.0,333.32,1.19,173.0,91115.0 +2013-09-22 16:00:00+00:00,26.94,19.16,577.0,897.35,77.0,335.18,1.33,200.0,91121.0 +2013-09-22 17:00:00+00:00,28.81,14.76,757.0,953.52,86.0,337.05,1.48,226.0,91127.0 +2013-09-22 18:00:00+00:00,30.0,13.39,879.0,982.2,91.0,336.43,1.82,238.0,91082.0 +2013-09-22 19:00:00+00:00,31.19,12.01,935.0,995.06,93.0,335.82,2.16,249.0,91037.0 +2013-09-22 20:00:00+00:00,32.38,10.64,918.0,991.08,93.0,335.2,2.5,260.0,90992.0 +2013-09-22 21:00:00+00:00,32.29,10.41,831.0,973.81,89.0,335.33,2.57,267.0,90974.0 +2013-09-22 22:00:00+00:00,32.19,10.17,680.0,935.01,82.0,335.47,2.65,274.0,90956.0 +2013-09-22 23:00:00+00:00,32.1,9.94,479.0,859.38,72.0,335.6,2.73,281.0,90938.0 +2013-09-23 00:00:00+00:00,30.33,12.33,249.0,717.23,55.0,333.25,2.64,294.0,90980.0 +2013-09-23 01:00:00+00:00,28.57,14.72,36.0,299.44,20.0,330.9,2.55,308.0,91022.0 +2013-09-23 02:00:00+00:00,26.8,17.11,0.0,0.0,0.0,328.55,2.46,322.0,91064.0 +2013-09-23 03:00:00+00:00,26.76,17.33,0.0,0.0,0.0,326.78,1.84,352.0,91100.0 +2013-09-23 04:00:00+00:00,26.71,17.56,0.0,0.0,0.0,325.02,1.23,23.0,91136.0 +2013-09-23 05:00:00+00:00,26.67,17.78,0.0,0.0,0.0,323.25,0.62,54.0,91172.0 +2013-09-23 06:00:00+00:00,25.46,21.93,0.0,0.0,0.0,320.32,0.78,69.0,91193.0 +2013-09-23 07:00:00+00:00,24.26,26.08,0.0,0.0,0.0,317.38,0.94,84.0,91214.0 +2013-09-23 08:00:00+00:00,23.05,30.23,0.0,0.0,0.0,314.45,1.1,99.0,91235.0 +2013-09-23 09:00:00+00:00,21.72,32.38,0.0,0.0,0.0,312.8,1.21,97.0,91241.0 +2013-09-23 10:00:00+00:00,20.39,34.52,0.0,0.0,0.0,311.15,1.32,94.0,91247.0 +2013-09-23 11:00:00+00:00,19.06,36.67,0.0,0.0,0.0,309.5,1.43,92.0,91253.0 +2013-09-23 12:00:00+00:00,20.56,33.45,0.0,0.0,0.0,310.55,1.51,95.0,91304.0 +2013-09-23 13:00:00+00:00,22.06,30.23,0.0,0.0,0.0,311.6,1.58,97.0,91355.0 +2013-09-23 14:00:00+00:00,23.56,27.01,123.0,523.17,39.0,312.65,1.66,99.0,91406.0 +2013-09-23 15:00:00+00:00,26.29,21.69,351.0,777.72,63.0,320.08,1.57,113.0,91385.0 +2013-09-23 16:00:00+00:00,29.02,16.37,568.0,885.34,77.0,327.52,1.49,128.0,91364.0 +2013-09-23 17:00:00+00:00,31.74,11.05,745.0,940.3,86.0,334.95,1.41,142.0,91343.0 +2013-09-23 18:00:00+00:00,32.79,11.37,866.0,969.85,91.0,338.38,1.92,163.0,91250.0 +2013-09-23 19:00:00+00:00,33.85,11.7,919.0,980.24,93.0,341.82,2.43,185.0,91157.0 +2013-09-23 20:00:00+00:00,34.9,12.02,900.0,975.2,92.0,345.25,2.94,206.0,91064.0 +2013-09-23 21:00:00+00:00,34.55,12.49,812.0,955.47,88.0,345.87,3.07,219.0,91022.0 +2013-09-23 22:00:00+00:00,34.2,12.95,661.0,911.72,82.0,346.48,3.2,231.0,90980.0 +2013-09-23 23:00:00+00:00,33.85,13.42,462.0,833.92,71.0,347.1,3.34,244.0,90938.0 +2013-09-24 00:00:00+00:00,32.36,15.06,236.0,688.99,53.0,347.17,3.32,240.0,90920.0 +2013-09-24 01:00:00+00:00,30.88,16.71,31.0,268.05,18.0,347.23,3.31,236.0,90902.0 +2013-09-24 02:00:00+00:00,29.39,18.35,0.0,0.0,0.0,347.3,3.3,233.0,90884.0 +2013-09-24 03:00:00+00:00,28.22,21.85,0.0,0.0,0.0,346.62,2.72,233.0,90926.0 +2013-09-24 04:00:00+00:00,27.04,25.36,0.0,0.0,0.0,345.93,2.15,234.0,90968.0 +2013-09-24 05:00:00+00:00,25.87,28.86,0.0,0.0,0.0,345.25,1.57,234.0,91010.0 +2013-09-24 06:00:00+00:00,25.28,31.84,0.0,0.0,0.0,341.48,1.63,233.0,91004.0 +2013-09-24 07:00:00+00:00,24.7,34.81,0.0,0.0,0.0,337.72,1.68,232.0,90998.0 +2013-09-24 08:00:00+00:00,24.11,37.79,0.0,0.0,0.0,333.95,1.74,231.0,90992.0 +2013-09-24 09:00:00+00:00,23.16,41.1,0.0,0.0,0.0,331.98,1.78,219.0,90974.0 +2013-09-24 10:00:00+00:00,22.21,44.41,0.0,0.0,0.0,330.02,1.83,207.0,90956.0 +2013-09-24 11:00:00+00:00,21.25,47.72,0.0,0.0,0.0,328.05,1.88,196.0,90938.0 +2013-09-24 12:00:00+00:00,22.21,46.12,0.0,0.0,0.0,326.15,1.93,198.0,90965.0 +2013-09-24 13:00:00+00:00,23.16,44.52,0.0,0.0,0.0,324.25,1.99,201.0,90992.0 +2013-09-24 14:00:00+00:00,24.11,42.92,120.0,511.86,39.0,322.35,2.04,203.0,91019.0 +2013-09-24 15:00:00+00:00,26.34,36.2,347.0,772.0,63.0,327.03,2.92,212.0,90980.0 +2013-09-24 16:00:00+00:00,28.57,29.48,563.0,880.52,77.0,331.72,3.8,221.0,90941.0 +2013-09-24 17:00:00+00:00,30.79,22.76,740.0,938.49,85.0,336.4,4.68,229.0,90902.0 +2013-09-24 18:00:00+00:00,31.87,19.81,859.0,966.25,90.0,335.55,5.24,233.0,90809.0 +2013-09-24 19:00:00+00:00,32.95,16.86,911.0,976.07,92.0,334.7,5.8,236.0,90716.0 +2013-09-24 20:00:00+00:00,34.03,13.91,892.0,970.14,92.0,333.85,6.36,239.0,90622.0 +2013-09-24 21:00:00+00:00,33.39,14.39,803.0,948.91,88.0,331.15,6.37,241.0,90598.0 +2013-09-24 22:00:00+00:00,32.74,14.87,654.0,908.74,81.0,328.45,6.38,242.0,90574.0 +2013-09-24 23:00:00+00:00,32.1,15.35,456.0,831.67,70.0,325.75,6.39,244.0,90550.0 +2013-09-25 00:00:00+00:00,30.6,19.18,231.0,682.71,53.0,326.3,5.52,240.0,90550.0 +2013-09-25 01:00:00+00:00,29.09,23.01,28.0,252.43,17.0,326.85,4.65,236.0,90550.0 +2013-09-25 02:00:00+00:00,27.59,26.84,0.0,0.0,0.0,327.4,3.78,232.0,90550.0 +2013-09-25 03:00:00+00:00,26.36,31.45,0.0,0.0,0.0,324.27,3.62,228.0,90595.0 +2013-09-25 04:00:00+00:00,25.12,36.07,0.0,0.0,0.0,321.13,3.46,224.0,90640.0 +2013-09-25 05:00:00+00:00,23.89,40.68,0.0,0.0,0.0,318.0,3.3,220.0,90686.0 +2013-09-25 06:00:00+00:00,23.12,42.61,0.0,0.0,0.0,315.18,3.11,214.0,90695.0 +2013-09-25 07:00:00+00:00,22.35,44.54,0.0,0.0,0.0,312.37,2.93,207.0,90704.0 +2013-09-25 08:00:00+00:00,21.58,46.47,0.0,0.0,0.0,309.55,2.74,201.0,90713.0 +2013-09-25 09:00:00+00:00,21.15,46.61,0.0,0.0,0.0,307.82,2.73,197.0,90716.0 +2013-09-25 10:00:00+00:00,20.73,46.76,0.0,0.0,0.0,306.08,2.72,193.0,90719.0 +2013-09-25 11:00:00+00:00,20.3,46.9,0.0,0.0,0.0,304.35,2.7,189.0,90722.0 +2013-09-25 12:00:00+00:00,21.47,44.87,0.0,0.0,0.0,307.38,2.93,188.0,90755.0 +2013-09-25 13:00:00+00:00,22.64,42.83,0.0,0.0,0.0,310.42,3.16,187.0,90788.0 +2013-09-25 14:00:00+00:00,23.8,40.8,116.0,500.28,38.0,313.45,3.39,186.0,90821.0 +2013-09-25 15:00:00+00:00,25.72,34.98,340.0,760.8,62.0,318.75,4.07,193.0,90788.0 +2013-09-25 16:00:00+00:00,27.64,29.15,555.0,872.07,76.0,324.05,4.75,201.0,90755.0 +2013-09-25 17:00:00+00:00,29.56,23.33,729.0,926.66,85.0,329.35,5.43,208.0,90722.0 +2013-09-25 18:00:00+00:00,30.44,22.69,847.0,955.1,90.0,330.2,6.2,209.0,90656.0 +2013-09-25 19:00:00+00:00,31.32,22.06,898.0,964.74,92.0,331.05,6.96,210.0,90589.0 +2013-09-25 20:00:00+00:00,32.2,21.42,878.0,958.97,91.0,331.9,7.72,210.0,90523.0 +2013-09-25 21:00:00+00:00,31.46,23.06,790.0,938.3,87.0,332.88,7.58,212.0,90514.0 +2013-09-25 22:00:00+00:00,30.73,24.69,640.0,894.57,80.0,333.87,7.44,213.0,90505.0 +2013-09-25 23:00:00+00:00,29.99,26.33,444.0,814.15,70.0,334.85,7.3,214.0,90496.0 +2013-09-26 00:00:00+00:00,28.9,28.16,222.0,664.46,52.0,337.32,6.48,216.0,90538.0 +2013-09-26 01:00:00+00:00,27.8,29.98,16.0,0.0,16.0,339.78,5.66,218.0,90580.0 +2013-09-26 02:00:00+00:00,26.71,31.81,0.0,0.0,0.0,342.25,4.84,220.0,90622.0 +2013-09-26 03:00:00+00:00,25.67,34.57,0.0,0.0,0.0,339.63,4.3,221.0,90698.0 +2013-09-26 04:00:00+00:00,24.63,37.33,0.0,0.0,0.0,337.02,3.76,222.0,90773.0 +2013-09-26 05:00:00+00:00,23.59,40.09,0.0,0.0,0.0,334.4,3.21,222.0,90848.0 +2013-09-26 06:00:00+00:00,22.72,43.25,0.0,0.0,0.0,330.53,2.95,220.0,90872.0 +2013-09-26 07:00:00+00:00,21.84,46.4,0.0,0.0,0.0,326.67,2.68,218.0,90896.0 +2013-09-26 08:00:00+00:00,20.97,49.56,0.0,0.0,0.0,322.8,2.41,216.0,90920.0 +2013-09-26 09:00:00+00:00,20.31,52.74,0.0,0.0,0.0,319.15,2.58,215.0,90947.0 +2013-09-26 10:00:00+00:00,19.66,55.91,0.0,0.0,0.0,315.5,2.75,214.0,90974.0 +2013-09-26 11:00:00+00:00,19.0,59.09,0.0,0.0,0.0,311.85,2.92,213.0,91001.0 +2013-09-26 12:00:00+00:00,19.41,52.97,0.0,0.0,0.0,317.05,3.18,217.0,91046.0 +2013-09-26 13:00:00+00:00,19.82,46.85,0.0,0.0,0.0,322.25,3.44,222.0,91091.0 +2013-09-26 14:00:00+00:00,20.22,40.73,61.0,52.1,53.0,327.45,3.7,226.0,91136.0 +2013-09-26 15:00:00+00:00,21.26,36.01,332.0,744.0,62.0,327.1,3.83,230.0,91154.0 +2013-09-26 16:00:00+00:00,22.31,31.28,545.0,858.11,76.0,326.75,3.97,233.0,91172.0 +2013-09-26 17:00:00+00:00,23.35,26.56,719.0,917.67,84.0,326.4,4.11,237.0,91190.0 +2013-09-26 18:00:00+00:00,24.42,23.76,371.0,40.54,339.0,323.6,4.35,243.0,91142.0 +2013-09-26 19:00:00+00:00,25.49,20.95,340.0,25.25,319.0,320.8,4.59,250.0,91094.0 +2013-09-26 20:00:00+00:00,26.56,18.15,168.0,6.12,163.0,318.0,4.83,256.0,91046.0 +2013-09-26 21:00:00+00:00,26.48,15.74,433.0,103.37,356.0,316.25,4.65,263.0,91031.0 +2013-09-26 22:00:00+00:00,26.41,13.34,270.0,33.79,249.0,314.5,4.47,270.0,91016.0 +2013-09-26 23:00:00+00:00,26.33,10.93,450.0,835.87,70.0,312.75,4.29,277.0,91001.0 +2013-09-27 00:00:00+00:00,25.11,12.98,226.0,693.29,52.0,313.97,3.81,292.0,91070.0 +2013-09-27 01:00:00+00:00,23.89,15.03,15.0,0.0,15.0,315.18,3.33,308.0,91139.0 +2013-09-27 02:00:00+00:00,22.67,17.08,0.0,0.0,0.0,316.4,2.86,323.0,91208.0 +2013-09-27 03:00:00+00:00,22.06,17.6,0.0,0.0,0.0,316.12,2.58,340.0,91241.0 +2013-09-27 04:00:00+00:00,21.46,18.12,0.0,0.0,0.0,315.83,2.31,356.0,91274.0 +2013-09-27 05:00:00+00:00,20.85,18.64,0.0,0.0,0.0,315.55,2.04,13.0,91307.0 +2013-09-27 06:00:00+00:00,20.07,19.97,0.0,0.0,0.0,312.12,1.77,29.0,91316.0 +2013-09-27 07:00:00+00:00,19.29,21.31,0.0,0.0,0.0,308.68,1.51,45.0,91325.0 +2013-09-27 08:00:00+00:00,18.51,22.64,0.0,0.0,0.0,305.25,1.24,61.0,91334.0 +2013-09-27 09:00:00+00:00,17.87,24.32,0.0,0.0,0.0,302.6,1.2,66.0,91361.0 +2013-09-27 10:00:00+00:00,17.24,25.99,0.0,0.0,0.0,299.95,1.17,71.0,91388.0 +2013-09-27 11:00:00+00:00,16.6,27.67,0.0,0.0,0.0,297.3,1.13,76.0,91416.0 +2013-09-27 12:00:00+00:00,18.07,26.28,0.0,0.0,0.0,300.82,1.27,80.0,91488.0 +2013-09-27 13:00:00+00:00,19.53,24.89,0.0,0.0,0.0,304.33,1.42,83.0,91560.0 +2013-09-27 14:00:00+00:00,20.99,23.5,115.0,509.35,38.0,307.85,1.56,86.0,91632.0 +2013-09-27 15:00:00+00:00,23.16,20.9,341.0,771.43,63.0,314.48,1.46,99.0,91623.0 +2013-09-27 16:00:00+00:00,25.33,18.3,556.0,880.85,77.0,321.12,1.36,111.0,91614.0 +2013-09-27 17:00:00+00:00,27.5,15.7,731.0,937.68,85.0,327.75,1.26,123.0,91605.0 +2013-09-27 18:00:00+00:00,28.41,16.76,849.0,965.76,90.0,327.18,1.83,129.0,91527.0 +2013-09-27 19:00:00+00:00,29.33,17.83,900.0,975.72,92.0,326.62,2.4,134.0,91449.0 +2013-09-27 20:00:00+00:00,30.24,18.89,880.0,969.67,92.0,326.05,2.97,140.0,91370.0 +2013-09-27 21:00:00+00:00,30.17,18.86,791.0,949.24,88.0,326.98,2.96,130.0,91340.0 +2013-09-27 22:00:00+00:00,30.11,18.84,640.0,906.22,81.0,327.92,2.95,121.0,91310.0 +2013-09-27 23:00:00+00:00,30.04,18.81,441.0,824.72,70.0,328.85,2.94,112.0,91280.0 +2013-09-28 00:00:00+00:00,28.85,20.1,217.0,670.43,52.0,327.03,2.67,101.0,91322.0 +2013-09-28 01:00:00+00:00,27.67,21.39,14.0,0.0,14.0,325.22,2.4,90.0,91364.0 +2013-09-28 02:00:00+00:00,26.48,22.68,0.0,0.0,0.0,323.4,2.12,79.0,91406.0 +2013-09-28 03:00:00+00:00,25.83,23.99,0.0,0.0,0.0,322.53,1.55,82.0,91437.0 +2013-09-28 04:00:00+00:00,25.18,25.29,0.0,0.0,0.0,321.67,0.97,84.0,91467.0 +2013-09-28 05:00:00+00:00,24.53,26.6,0.0,0.0,0.0,320.8,0.4,87.0,91497.0 +2013-09-28 06:00:00+00:00,23.56,27.99,0.0,0.0,0.0,318.37,0.73,87.0,91509.0 +2013-09-28 07:00:00+00:00,22.6,29.37,0.0,0.0,0.0,315.93,1.05,86.0,91521.0 +2013-09-28 08:00:00+00:00,21.63,30.76,0.0,0.0,0.0,313.5,1.38,86.0,91533.0 +2013-09-28 09:00:00+00:00,20.34,34.65,0.0,0.0,0.0,311.03,1.4,85.0,91539.0 +2013-09-28 10:00:00+00:00,19.05,38.54,0.0,0.0,0.0,308.57,1.42,84.0,91545.0 +2013-09-28 11:00:00+00:00,17.75,42.43,0.0,0.0,0.0,306.1,1.43,83.0,91551.0 +2013-09-28 12:00:00+00:00,19.15,39.24,0.0,0.0,0.0,305.6,1.3,84.0,91617.0 +2013-09-28 13:00:00+00:00,20.55,36.04,0.0,0.0,0.0,305.1,1.17,85.0,91683.0 +2013-09-28 14:00:00+00:00,21.94,32.85,110.0,490.7,37.0,304.6,1.03,85.0,91749.0 +2013-09-28 15:00:00+00:00,24.49,26.35,334.0,760.19,62.0,310.43,1.38,95.0,91713.0 +2013-09-28 16:00:00+00:00,27.04,19.86,550.0,876.17,76.0,316.27,1.72,104.0,91677.0 +2013-09-28 17:00:00+00:00,29.59,13.36,727.0,936.06,85.0,322.1,2.07,113.0,91641.0 +2013-09-28 18:00:00+00:00,30.58,13.77,847.0,967.41,90.0,322.5,2.26,166.0,91557.0 +2013-09-28 19:00:00+00:00,31.58,14.18,899.0,978.93,92.0,322.9,2.46,218.0,91473.0 +2013-09-28 20:00:00+00:00,32.57,14.59,881.0,975.77,92.0,323.3,2.65,270.0,91388.0 +2013-09-28 21:00:00+00:00,32.44,14.28,792.0,956.21,88.0,322.2,2.86,279.0,91343.0 +2013-09-28 22:00:00+00:00,32.31,13.96,641.0,914.65,81.0,321.1,3.07,288.0,91298.0 +2013-09-28 23:00:00+00:00,32.18,13.65,441.0,833.55,70.0,320.0,3.28,297.0,91253.0 +2013-09-29 00:00:00+00:00,30.1,15.9,215.0,679.76,51.0,319.6,2.97,302.0,91274.0 +2013-09-29 01:00:00+00:00,28.03,18.14,13.0,0.0,13.0,319.2,2.67,306.0,91295.0 +2013-09-29 02:00:00+00:00,25.95,20.39,0.0,0.0,0.0,318.8,2.36,310.0,91316.0 +2013-09-29 03:00:00+00:00,24.97,22.78,0.0,0.0,0.0,317.82,1.74,316.0,91349.0 +2013-09-29 04:00:00+00:00,24.0,25.16,0.0,0.0,0.0,316.83,1.13,321.0,91382.0 +2013-09-29 05:00:00+00:00,23.02,27.55,0.0,0.0,0.0,315.85,0.51,326.0,91416.0 +2013-09-29 06:00:00+00:00,22.57,26.69,0.0,0.0,0.0,313.02,0.69,330.0,91410.0 +2013-09-29 07:00:00+00:00,22.12,25.82,0.0,0.0,0.0,310.18,0.87,334.0,91403.0 +2013-09-29 08:00:00+00:00,21.67,24.96,0.0,0.0,0.0,307.35,1.05,338.0,91397.0 +2013-09-29 09:00:00+00:00,20.78,27.66,0.0,0.0,0.0,304.92,1.07,347.0,91379.0 +2013-09-29 10:00:00+00:00,19.89,30.37,0.0,0.0,0.0,302.48,1.09,355.0,91361.0 +2013-09-29 11:00:00+00:00,19.0,33.07,0.0,0.0,0.0,300.05,1.1,4.0,91343.0 +2013-09-29 12:00:00+00:00,20.17,32.44,0.0,0.0,0.0,299.52,1.0,12.0,91382.0 +2013-09-29 13:00:00+00:00,21.33,31.82,0.0,0.0,0.0,298.98,0.9,19.0,91422.0 +2013-09-29 14:00:00+00:00,22.49,31.19,110.0,498.85,37.0,298.45,0.8,27.0,91461.0 +2013-09-29 15:00:00+00:00,25.12,25.72,337.0,774.2,62.0,303.83,1.33,0.0,91431.0 +2013-09-29 16:00:00+00:00,27.75,20.24,554.0,886.36,77.0,309.22,1.86,334.0,91400.0 +2013-09-29 17:00:00+00:00,30.37,14.77,732.0,947.67,85.0,314.6,2.39,307.0,91370.0 +2013-09-29 18:00:00+00:00,31.41,13.55,852.0,976.82,91.0,315.0,2.51,302.0,91295.0 +2013-09-29 19:00:00+00:00,32.44,12.33,904.0,988.31,93.0,315.4,2.64,298.0,91220.0 +2013-09-29 20:00:00+00:00,33.48,11.11,884.0,984.47,92.0,315.8,2.77,293.0,91145.0 +2013-09-29 21:00:00+00:00,33.12,10.94,794.0,964.66,88.0,314.83,2.88,296.0,91097.0 +2013-09-29 22:00:00+00:00,32.75,10.76,643.0,924.88,81.0,313.87,2.99,300.0,91049.0 +2013-09-29 23:00:00+00:00,32.39,10.59,442.0,844.86,70.0,312.9,3.1,303.0,91001.0 +2013-09-30 00:00:00+00:00,30.23,14.0,214.0,689.44,51.0,311.08,2.82,306.0,91025.0 +2013-09-30 01:00:00+00:00,28.06,17.4,12.0,0.0,12.0,309.27,2.54,309.0,91049.0 +2013-09-30 02:00:00+00:00,25.9,20.81,0.0,0.0,0.0,307.45,2.26,312.0,91073.0 +2013-09-30 03:00:00+00:00,25.75,19.75,0.0,0.0,0.0,305.65,1.83,314.0,91103.0 +2013-09-30 04:00:00+00:00,25.61,18.7,0.0,0.0,0.0,303.85,1.4,315.0,91133.0 +2013-09-30 05:00:00+00:00,25.46,17.64,0.0,0.0,0.0,302.05,0.97,317.0,91163.0 +2013-09-30 06:00:00+00:00,24.93,18.84,0.0,0.0,0.0,299.62,1.26,316.0,91166.0 +2013-09-30 07:00:00+00:00,24.39,20.03,0.0,0.0,0.0,297.18,1.55,315.0,91169.0 +2013-09-30 08:00:00+00:00,23.86,21.23,0.0,0.0,0.0,294.75,1.85,315.0,91172.0 +2013-09-30 09:00:00+00:00,22.93,24.0,0.0,0.0,0.0,293.45,1.64,327.0,91184.0 +2013-09-30 10:00:00+00:00,22.01,26.76,0.0,0.0,0.0,292.15,1.43,340.0,91196.0 +2013-09-30 11:00:00+00:00,21.08,29.53,0.0,0.0,0.0,290.85,1.21,352.0,91208.0 +2013-09-30 12:00:00+00:00,21.47,29.16,0.0,0.0,0.0,291.75,1.36,298.0,91274.0 +2013-09-30 13:00:00+00:00,21.86,28.79,0.0,0.0,0.0,292.65,1.5,244.0,91340.0 +2013-09-30 14:00:00+00:00,22.25,28.42,108.0,493.46,37.0,293.55,1.64,190.0,91406.0 +2013-09-30 15:00:00+00:00,24.69,23.84,332.0,765.8,62.0,299.07,1.72,216.0,91397.0 +2013-09-30 16:00:00+00:00,31.59,11.38,547.0,879.91,76.0,303.35,1.95,241.0,91388.0 +2013-09-30 17:00:00+00:00,31.29,12.57,722.0,937.37,85.0,306.84,2.1,267.0,91379.0 +2013-09-30 18:00:00+00:00,31.0,13.76,840.0,967.02,90.0,310.33,2.26,267.0,91304.0 +2013-09-30 19:00:00+00:00,30.7,14.95,890.0,977.0,92.0,313.83,2.41,267.0,91229.0 +2013-09-30 20:00:00+00:00,30.41,16.14,869.0,972.05,91.0,317.32,2.57,267.0,91154.0 +2013-09-30 21:00:00+00:00,30.11,17.33,778.0,949.87,87.0,320.81,2.72,269.0,91121.0 +2013-09-30 22:00:00+00:00,29.82,18.52,626.0,905.43,80.0,324.3,2.88,271.0,91088.0 +2013-09-30 23:00:00+00:00,29.52,19.72,427.0,821.96,69.0,327.79,3.03,272.0,91055.0 +2011-10-01 00:00:00+00:00,29.23,20.91,200.0,621.77,53.0,331.28,3.19,112.0,91193.0 +2011-10-01 01:00:00+00:00,28.93,22.1,12.0,0.0,12.0,334.77,3.34,109.0,91205.0 +2011-10-01 02:00:00+00:00,28.64,23.29,0.0,0.0,0.0,338.26,3.5,106.0,91217.0 +2011-10-01 03:00:00+00:00,28.34,24.48,0.0,0.0,0.0,341.75,3.65,109.0,91277.0 +2011-10-01 04:00:00+00:00,28.05,25.67,0.0,0.0,0.0,345.24,3.81,111.0,91337.0 +2011-10-01 05:00:00+00:00,27.75,26.86,0.0,0.0,0.0,348.73,3.96,113.0,91397.0 +2011-10-01 06:00:00+00:00,27.46,28.06,0.0,0.0,0.0,352.22,4.12,111.0,91410.0 +2011-10-01 07:00:00+00:00,27.16,29.25,0.0,0.0,0.0,355.71,4.27,110.0,91422.0 +2011-10-01 08:00:00+00:00,25.03,33.6,0.0,0.0,0.0,342.5,3.71,108.0,91434.0 +2011-10-01 09:00:00+00:00,24.26,35.9,0.0,0.0,0.0,340.5,3.56,101.0,91434.0 +2011-10-01 10:00:00+00:00,23.49,38.21,0.0,0.0,0.0,338.5,3.42,93.0,91434.0 +2011-10-01 11:00:00+00:00,22.72,40.51,0.0,0.0,0.0,336.5,3.27,86.0,91434.0 +2011-10-01 12:00:00+00:00,23.64,40.25,0.0,0.0,0.0,334.43,3.13,86.0,91458.0 +2011-10-01 13:00:00+00:00,24.56,39.98,0.0,0.0,0.0,332.37,2.99,87.0,91482.0 +2011-10-01 14:00:00+00:00,25.49,39.72,37.0,0.0,37.0,330.3,2.86,87.0,91506.0 +2011-10-01 15:00:00+00:00,27.34,34.82,275.0,493.51,101.0,335.93,2.56,97.0,91491.0 +2011-10-01 16:00:00+00:00,29.19,29.91,242.0,42.97,219.0,341.57,2.27,106.0,91476.0 +2011-10-01 17:00:00+00:00,31.03,25.01,348.0,63.28,305.0,347.2,1.97,115.0,91461.0 +2011-10-01 18:00:00+00:00,31.13,24.88,634.0,350.71,362.0,352.75,1.73,119.0,91434.0 +2011-10-01 19:00:00+00:00,31.23,24.74,851.0,924.36,96.0,358.3,1.49,123.0,91406.0 +2011-10-01 20:00:00+00:00,31.32,24.61,682.0,428.55,339.0,363.85,1.24,128.0,91379.0 +2011-10-01 21:00:00+00:00,31.23,25.16,554.0,287.3,345.0,364.13,1.51,124.0,91361.0 +2011-10-01 22:00:00+00:00,31.14,25.7,61.0,0.0,61.0,364.42,1.78,120.0,91343.0 +2011-10-01 23:00:00+00:00,31.04,26.25,25.0,0.0,25.0,364.7,2.06,117.0,91325.0 +2011-10-02 00:00:00+00:00,30.11,30.83,21.0,0.0,21.0,362.3,1.98,88.0,91334.0 +2011-10-02 01:00:00+00:00,29.18,35.4,1.0,0.0,1.0,359.9,1.91,60.0,91343.0 +2011-10-02 02:00:00+00:00,28.25,39.98,0.0,0.0,0.0,357.5,1.83,31.0,91352.0 +2011-10-02 03:00:00+00:00,27.21,44.4,0.0,0.0,0.0,356.97,1.98,41.0,91379.0 +2011-10-02 04:00:00+00:00,26.18,48.81,0.0,0.0,0.0,356.43,2.13,50.0,91406.0 +2011-10-02 05:00:00+00:00,25.14,53.23,0.0,0.0,0.0,355.9,2.28,59.0,91434.0 +2011-10-02 06:00:00+00:00,24.36,55.46,0.0,0.0,0.0,351.83,2.43,66.0,91431.0 +2011-10-02 07:00:00+00:00,23.57,57.69,0.0,0.0,0.0,347.77,2.58,73.0,91428.0 +2011-10-02 08:00:00+00:00,22.79,59.92,0.0,0.0,0.0,343.7,2.73,80.0,91425.0 +2011-10-02 09:00:00+00:00,22.03,62.67,0.0,0.0,0.0,338.68,2.79,84.0,91425.0 +2011-10-02 10:00:00+00:00,21.28,65.43,0.0,0.0,0.0,333.67,2.84,89.0,91425.0 +2011-10-02 11:00:00+00:00,20.52,68.18,0.0,0.0,0.0,328.65,2.9,94.0,91425.0 +2011-10-02 12:00:00+00:00,21.77,64.83,0.0,0.0,0.0,328.13,2.62,97.0,91470.0 +2011-10-02 13:00:00+00:00,23.02,61.47,0.0,0.0,0.0,327.62,2.34,100.0,91515.0 +2011-10-02 14:00:00+00:00,24.28,58.12,97.0,424.33,37.0,327.1,2.06,104.0,91560.0 +2011-10-02 15:00:00+00:00,26.41,48.71,310.0,703.04,64.0,332.53,1.77,134.0,91560.0 +2011-10-02 16:00:00+00:00,28.54,39.3,516.0,820.85,79.0,337.97,1.49,164.0,91560.0 +2011-10-02 17:00:00+00:00,30.67,29.89,685.0,882.67,88.0,343.4,1.21,194.0,91560.0 +2011-10-02 18:00:00+00:00,31.28,28.04,800.0,914.44,94.0,347.8,1.67,223.0,91500.0 +2011-10-02 19:00:00+00:00,31.88,26.18,850.0,927.5,96.0,352.2,2.13,252.0,91440.0 +2011-10-02 20:00:00+00:00,32.48,24.33,830.0,923.11,95.0,356.6,2.59,282.0,91379.0 +2011-10-02 21:00:00+00:00,32.25,24.77,743.0,901.74,91.0,355.6,2.5,310.0,91358.0 +2011-10-02 22:00:00+00:00,32.01,25.22,205.0,11.7,198.0,354.6,2.4,339.0,91337.0 +2011-10-02 23:00:00+00:00,31.77,25.66,164.0,18.57,156.0,353.6,2.3,7.0,91316.0 +2011-10-03 00:00:00+00:00,31.13,28.51,98.0,48.5,87.0,352.05,2.55,37.0,91328.0 +2011-10-03 01:00:00+00:00,30.48,31.36,0.0,0.0,0.0,350.5,2.8,67.0,91340.0 +2011-10-03 02:00:00+00:00,29.84,34.21,0.0,0.0,0.0,348.95,3.05,98.0,91352.0 +2011-10-03 03:00:00+00:00,28.13,36.46,0.0,0.0,0.0,345.78,2.57,99.0,91376.0 +2011-10-03 04:00:00+00:00,26.41,38.71,0.0,0.0,0.0,342.62,2.08,100.0,91400.0 +2011-10-03 05:00:00+00:00,24.7,40.96,0.0,0.0,0.0,339.45,1.6,101.0,91425.0 +2011-10-03 06:00:00+00:00,23.75,43.51,0.0,0.0,0.0,335.43,1.95,101.0,91419.0 +2011-10-03 07:00:00+00:00,22.81,46.05,0.0,0.0,0.0,331.42,2.3,102.0,91413.0 +2011-10-03 08:00:00+00:00,21.86,48.6,0.0,0.0,0.0,327.4,2.65,102.0,91406.0 +2011-10-03 09:00:00+00:00,21.26,50.84,0.0,0.0,0.0,324.75,2.8,102.0,91403.0 +2011-10-03 10:00:00+00:00,20.66,53.07,0.0,0.0,0.0,322.1,2.95,103.0,91400.0 +2011-10-03 11:00:00+00:00,20.06,55.31,0.0,0.0,0.0,319.45,3.1,103.0,91397.0 +2011-10-03 12:00:00+00:00,21.32,54.3,0.0,0.0,0.0,319.07,2.89,106.0,91458.0 +2011-10-03 13:00:00+00:00,22.58,53.29,0.0,0.0,0.0,318.68,2.67,108.0,91518.0 +2011-10-03 14:00:00+00:00,23.84,52.28,96.0,424.78,37.0,318.3,2.46,111.0,91578.0 +2011-10-03 15:00:00+00:00,25.82,46.13,310.0,708.51,64.0,325.4,2.42,131.0,91548.0 +2011-10-03 16:00:00+00:00,27.81,39.98,519.0,831.1,79.0,332.5,2.39,151.0,91518.0 +2011-10-03 17:00:00+00:00,29.79,33.83,689.0,892.87,88.0,339.6,2.36,170.0,91488.0 +2011-10-03 18:00:00+00:00,30.63,30.45,805.0,925.19,94.0,342.1,2.69,187.0,91413.0 +2011-10-03 19:00:00+00:00,31.47,27.08,856.0,939.36,96.0,344.6,3.01,204.0,91337.0 +2011-10-03 20:00:00+00:00,32.31,23.7,836.0,935.55,95.0,347.1,3.34,221.0,91262.0 +2011-10-03 21:00:00+00:00,32.16,23.27,612.0,478.7,268.0,347.78,2.91,216.0,91220.0 +2011-10-03 22:00:00+00:00,32.0,22.85,490.0,444.62,226.0,348.47,2.49,211.0,91178.0 +2011-10-03 23:00:00+00:00,31.84,22.42,251.0,152.57,186.0,349.15,2.07,205.0,91136.0 +2011-10-04 00:00:00+00:00,31.02,25.0,115.0,121.61,88.0,347.47,1.7,188.0,91139.0 +2011-10-04 01:00:00+00:00,30.21,27.59,0.0,0.0,0.0,345.78,1.33,172.0,91142.0 +2011-10-04 02:00:00+00:00,29.39,30.17,0.0,0.0,0.0,344.1,0.97,155.0,91145.0 +2011-10-04 03:00:00+00:00,28.3,32.89,0.0,0.0,0.0,347.1,1.4,151.0,91184.0 +2011-10-04 04:00:00+00:00,27.21,35.61,0.0,0.0,0.0,350.1,1.83,148.0,91223.0 +2011-10-04 05:00:00+00:00,26.12,38.33,0.0,0.0,0.0,353.1,2.26,144.0,91262.0 +2011-10-04 06:00:00+00:00,25.2,39.85,0.0,0.0,0.0,345.47,2.4,146.0,91259.0 +2011-10-04 07:00:00+00:00,24.28,41.37,0.0,0.0,0.0,337.83,2.55,147.0,91256.0 +2011-10-04 08:00:00+00:00,23.36,42.89,0.0,0.0,0.0,330.2,2.69,149.0,91253.0 +2011-10-04 09:00:00+00:00,22.64,44.79,0.0,0.0,0.0,326.08,2.72,151.0,91247.0 +2011-10-04 10:00:00+00:00,21.91,46.7,0.0,0.0,0.0,321.97,2.75,153.0,91241.0 +2011-10-04 11:00:00+00:00,21.19,48.6,0.0,0.0,0.0,317.85,2.79,155.0,91235.0 +2011-10-04 12:00:00+00:00,22.47,47.66,0.0,0.0,0.0,326.15,2.66,152.0,91259.0 +2011-10-04 13:00:00+00:00,23.74,46.73,0.0,0.0,0.0,334.45,2.54,148.0,91283.0 +2011-10-04 14:00:00+00:00,25.02,45.79,95.0,432.67,36.0,342.75,2.41,145.0,91307.0 +2011-10-04 15:00:00+00:00,26.52,40.15,309.0,711.22,64.0,341.2,4.09,160.0,91259.0 +2011-10-04 16:00:00+00:00,28.02,34.52,456.0,585.07,148.0,339.65,5.76,175.0,91211.0 +2011-10-04 17:00:00+00:00,29.51,28.88,459.0,206.02,321.0,338.1,7.43,191.0,91163.0 +2011-10-04 18:00:00+00:00,29.7,27.92,491.0,141.2,383.0,342.85,8.11,199.0,91100.0 +2011-10-04 19:00:00+00:00,29.89,26.97,681.0,412.35,349.0,347.6,8.8,208.0,91037.0 +2011-10-04 20:00:00+00:00,30.07,26.01,658.0,423.94,324.0,352.35,9.48,216.0,90974.0 +2011-10-04 21:00:00+00:00,29.58,27.42,742.0,911.55,91.0,352.38,9.13,218.0,90965.0 +2011-10-04 22:00:00+00:00,29.08,28.82,594.0,867.37,83.0,352.42,8.79,220.0,90956.0 +2011-10-04 23:00:00+00:00,28.58,30.23,399.0,778.59,71.0,352.45,8.44,221.0,90947.0 +2011-10-05 00:00:00+00:00,27.6,32.94,182.0,607.57,50.0,346.23,7.43,222.0,90998.0 +2011-10-05 01:00:00+00:00,26.63,35.66,0.0,0.0,0.0,340.02,6.43,223.0,91049.0 +2011-10-05 02:00:00+00:00,25.65,38.37,0.0,0.0,0.0,333.8,5.42,224.0,91100.0 +2011-10-05 03:00:00+00:00,24.63,40.48,0.0,0.0,0.0,330.78,4.67,225.0,91130.0 +2011-10-05 04:00:00+00:00,23.62,42.59,0.0,0.0,0.0,327.77,3.91,225.0,91160.0 +2011-10-05 05:00:00+00:00,22.6,44.7,0.0,0.0,0.0,324.75,3.16,226.0,91190.0 +2011-10-05 06:00:00+00:00,21.76,46.61,0.0,0.0,0.0,319.82,2.97,224.0,91202.0 +2011-10-05 07:00:00+00:00,20.92,48.52,0.0,0.0,0.0,314.88,2.78,222.0,91214.0 +2011-10-05 08:00:00+00:00,20.08,50.43,0.0,0.0,0.0,309.95,2.59,220.0,91226.0 +2011-10-05 09:00:00+00:00,19.3,52.94,0.0,0.0,0.0,305.17,2.8,214.0,91229.0 +2011-10-05 10:00:00+00:00,18.52,55.45,0.0,0.0,0.0,300.38,3.01,208.0,91232.0 +2011-10-05 11:00:00+00:00,17.74,57.96,0.0,0.0,0.0,295.6,3.21,202.0,91235.0 +2011-10-05 12:00:00+00:00,18.32,55.64,0.0,0.0,0.0,292.27,3.33,203.0,91268.0 +2011-10-05 13:00:00+00:00,18.9,53.31,0.0,0.0,0.0,288.93,3.45,204.0,91301.0 +2011-10-05 14:00:00+00:00,19.48,50.99,93.0,426.0,36.0,285.6,3.57,205.0,91334.0 +2011-10-05 15:00:00+00:00,21.15,45.67,309.0,716.98,64.0,288.68,4.02,210.0,91316.0 +2011-10-05 16:00:00+00:00,22.82,40.35,519.0,840.64,79.0,291.77,4.47,216.0,91298.0 +2011-10-05 17:00:00+00:00,24.48,35.03,691.0,904.72,88.0,294.85,4.92,221.0,91280.0 +2011-10-05 18:00:00+00:00,25.75,31.94,807.0,936.61,94.0,295.22,5.39,224.0,91193.0 +2011-10-05 19:00:00+00:00,27.02,28.85,858.0,951.07,96.0,295.58,5.85,227.0,91106.0 +2011-10-05 20:00:00+00:00,28.29,25.76,837.0,946.89,95.0,295.95,6.32,230.0,91019.0 +2011-10-05 21:00:00+00:00,27.98,26.37,748.0,925.73,91.0,296.13,6.12,230.0,90974.0 +2011-10-05 22:00:00+00:00,27.67,26.97,599.0,882.8,83.0,296.32,5.92,230.0,90929.0 +2011-10-05 23:00:00+00:00,27.36,27.58,403.0,797.05,71.0,296.5,5.72,230.0,90884.0 +2011-10-06 00:00:00+00:00,26.27,30.81,114.0,150.57,82.0,296.72,5.4,227.0,90899.0 +2011-10-06 01:00:00+00:00,25.19,34.03,0.0,0.0,0.0,296.93,5.08,224.0,90914.0 +2011-10-06 02:00:00+00:00,24.1,37.26,0.0,0.0,0.0,297.15,4.76,221.0,90929.0 +2011-10-06 03:00:00+00:00,23.02,41.19,0.0,0.0,0.0,295.2,4.75,217.0,90944.0 +2011-10-06 04:00:00+00:00,21.94,45.12,0.0,0.0,0.0,293.25,4.74,213.0,90959.0 +2011-10-06 05:00:00+00:00,20.86,49.05,0.0,0.0,0.0,291.3,4.73,208.0,90974.0 +2011-10-06 06:00:00+00:00,20.16,52.73,0.0,0.0,0.0,288.75,4.56,210.0,90983.0 +2011-10-06 07:00:00+00:00,19.46,56.4,0.0,0.0,0.0,286.2,4.38,213.0,90992.0 +2011-10-06 08:00:00+00:00,18.76,60.08,0.0,0.0,0.0,283.65,4.21,215.0,91001.0 +2011-10-06 09:00:00+00:00,18.11,65.55,0.0,0.0,0.0,282.02,4.1,216.0,91004.0 +2011-10-06 10:00:00+00:00,17.46,71.03,0.0,0.0,0.0,280.38,3.99,217.0,91007.0 +2011-10-06 11:00:00+00:00,16.81,76.5,0.0,0.0,0.0,278.75,3.88,218.0,91010.0 +2011-10-06 12:00:00+00:00,17.24,78.77,0.0,0.0,0.0,279.63,5.41,218.0,91031.0 +2011-10-06 13:00:00+00:00,17.67,81.04,0.0,0.0,0.0,280.52,6.95,218.0,91052.0 +2011-10-06 14:00:00+00:00,18.1,83.31,89.0,403.91,36.0,281.4,8.48,218.0,91073.0 +2011-10-06 15:00:00+00:00,18.67,77.36,77.0,0.0,77.0,287.57,9.3,220.0,91103.0 +2011-10-06 16:00:00+00:00,19.24,71.42,510.0,826.38,80.0,293.73,10.12,223.0,91133.0 +2011-10-06 17:00:00+00:00,19.8,65.47,682.0,892.71,90.0,299.9,10.94,225.0,91163.0 +2011-10-06 18:00:00+00:00,20.37,58.51,799.0,927.95,96.0,304.7,8.89,228.0,91139.0 +2011-10-06 19:00:00+00:00,20.94,51.55,130.0,1.25,129.0,309.5,6.85,231.0,91115.0 +2011-10-06 20:00:00+00:00,21.5,44.59,144.0,3.85,141.0,314.3,4.8,234.0,91091.0 +2011-10-06 21:00:00+00:00,21.4,42.53,343.0,49.63,308.0,317.0,4.96,235.0,91070.0 +2011-10-06 22:00:00+00:00,21.29,40.47,108.0,0.0,108.0,319.7,5.12,236.0,91049.0 +2011-10-06 23:00:00+00:00,21.18,38.41,97.0,0.0,97.0,322.4,5.28,237.0,91028.0 +2011-10-07 00:00:00+00:00,20.42,41.84,40.0,0.0,40.0,317.02,4.25,240.0,91055.0 +2011-10-07 01:00:00+00:00,19.65,45.27,0.0,0.0,0.0,311.63,3.21,244.0,91082.0 +2011-10-07 02:00:00+00:00,18.89,48.7,0.0,0.0,0.0,306.25,2.18,248.0,91109.0 +2011-10-07 03:00:00+00:00,18.09,52.93,0.0,0.0,0.0,303.18,1.79,245.0,91121.0 +2011-10-07 04:00:00+00:00,17.3,57.16,0.0,0.0,0.0,300.12,1.4,242.0,91133.0 +2011-10-07 05:00:00+00:00,16.5,61.39,0.0,0.0,0.0,297.05,1.01,239.0,91145.0 +2011-10-07 06:00:00+00:00,15.86,64.43,0.0,0.0,0.0,294.28,1.09,237.0,91154.0 +2011-10-07 07:00:00+00:00,15.22,67.48,0.0,0.0,0.0,291.52,1.16,235.0,91163.0 +2011-10-07 08:00:00+00:00,14.58,70.52,0.0,0.0,0.0,288.75,1.24,233.0,91172.0 +2011-10-07 09:00:00+00:00,14.0,72.98,0.0,0.0,0.0,286.22,1.62,229.0,91190.0 +2011-10-07 10:00:00+00:00,13.41,75.43,0.0,0.0,0.0,283.68,2.0,226.0,91208.0 +2011-10-07 11:00:00+00:00,12.83,77.89,0.0,0.0,0.0,281.15,2.37,223.0,91226.0 +2011-10-07 12:00:00+00:00,13.66,67.59,0.0,0.0,0.0,286.07,1.84,230.0,91286.0 +2011-10-07 13:00:00+00:00,14.49,57.28,0.0,0.0,0.0,290.98,1.31,236.0,91346.0 +2011-10-07 14:00:00+00:00,15.33,46.98,91.0,427.66,36.0,295.9,0.77,243.0,91406.0 +2011-10-07 15:00:00+00:00,16.54,41.42,172.0,107.12,136.0,299.42,1.55,245.0,91406.0 +2011-10-07 16:00:00+00:00,17.76,35.86,357.0,257.13,224.0,302.93,2.34,247.0,91406.0 +2011-10-07 17:00:00+00:00,18.97,30.3,695.0,915.5,91.0,306.45,3.12,250.0,91406.0 +2011-10-07 18:00:00+00:00,19.83,27.17,812.0,948.43,97.0,301.9,3.94,253.0,91376.0 +2011-10-07 19:00:00+00:00,20.68,24.05,602.0,263.48,393.0,297.35,4.77,256.0,91346.0 +2011-10-07 20:00:00+00:00,21.53,20.92,588.0,276.09,374.0,292.8,5.6,259.0,91316.0 +2011-10-07 21:00:00+00:00,21.22,20.63,754.0,941.84,94.0,287.97,5.28,267.0,91334.0 +2011-10-07 22:00:00+00:00,20.91,20.34,603.0,898.75,86.0,283.13,4.97,275.0,91352.0 +2011-10-07 23:00:00+00:00,20.6,20.05,403.0,810.59,73.0,278.3,4.65,283.0,91370.0 +2011-10-08 00:00:00+00:00,19.58,24.09,178.0,625.12,51.0,274.78,3.8,296.0,91403.0 +2011-10-08 01:00:00+00:00,18.56,28.13,0.0,0.0,0.0,271.27,2.95,309.0,91437.0 +2011-10-08 02:00:00+00:00,17.54,32.17,0.0,0.0,0.0,267.75,2.1,322.0,91470.0 +2011-10-08 03:00:00+00:00,16.64,34.53,0.0,0.0,0.0,265.3,2.02,333.0,91494.0 +2011-10-08 04:00:00+00:00,15.75,36.9,0.0,0.0,0.0,262.85,1.94,343.0,91518.0 +2011-10-08 05:00:00+00:00,14.85,39.26,0.0,0.0,0.0,260.4,1.86,353.0,91542.0 +2011-10-08 06:00:00+00:00,14.23,42.4,0.0,0.0,0.0,258.38,1.76,3.0,91545.0 +2011-10-08 07:00:00+00:00,13.6,45.53,0.0,0.0,0.0,256.37,1.66,14.0,91548.0 +2011-10-08 08:00:00+00:00,12.98,48.67,0.0,0.0,0.0,254.35,1.56,24.0,91551.0 +2011-10-08 09:00:00+00:00,12.33,51.57,0.0,0.0,0.0,252.78,1.69,29.0,91557.0 +2011-10-08 10:00:00+00:00,11.67,54.47,0.0,0.0,0.0,251.22,1.83,34.0,91563.0 +2011-10-08 11:00:00+00:00,11.02,57.37,0.0,0.0,0.0,249.65,1.96,40.0,91569.0 +2011-10-08 12:00:00+00:00,12.21,52.35,0.0,0.0,0.0,253.28,1.87,51.0,91575.0 +2011-10-08 13:00:00+00:00,13.39,47.33,0.0,0.0,0.0,256.92,1.77,62.0,91581.0 +2011-10-08 14:00:00+00:00,14.58,42.31,91.0,428.68,37.0,260.55,1.68,74.0,91587.0 +2011-10-08 15:00:00+00:00,16.65,35.01,314.0,744.26,66.0,265.52,1.94,79.0,91557.0 +2011-10-08 16:00:00+00:00,18.73,27.7,529.0,871.41,81.0,270.48,2.21,84.0,91527.0 +2011-10-08 17:00:00+00:00,20.8,20.4,704.0,934.0,91.0,275.45,2.47,90.0,91497.0 +2011-10-08 18:00:00+00:00,21.85,18.59,822.0,966.48,97.0,276.23,3.03,38.0,91419.0 +2011-10-08 19:00:00+00:00,22.9,16.77,872.0,979.47,99.0,277.02,3.59,346.0,91340.0 +2011-10-08 20:00:00+00:00,23.95,14.96,851.0,976.87,98.0,277.8,4.15,294.0,91262.0 +2011-10-08 21:00:00+00:00,23.9,15.1,759.0,955.09,94.0,276.92,4.17,303.0,91244.0 +2011-10-08 22:00:00+00:00,23.85,15.23,604.0,907.79,86.0,276.03,4.2,311.0,91226.0 +2011-10-08 23:00:00+00:00,23.79,15.37,401.0,815.05,73.0,275.15,4.22,320.0,91208.0 +2011-10-09 00:00:00+00:00,22.24,18.0,174.0,624.6,50.0,272.58,3.49,330.0,91262.0 +2011-10-09 01:00:00+00:00,20.7,20.64,0.0,0.0,0.0,270.02,2.75,340.0,91316.0 +2011-10-09 02:00:00+00:00,19.15,23.27,0.0,0.0,0.0,267.45,2.01,351.0,91370.0 +2011-10-09 03:00:00+00:00,18.27,24.7,0.0,0.0,0.0,266.3,1.77,1.0,91376.0 +2011-10-09 04:00:00+00:00,17.4,26.14,0.0,0.0,0.0,265.15,1.53,11.0,91382.0 +2011-10-09 05:00:00+00:00,16.52,27.57,0.0,0.0,0.0,264.0,1.28,20.0,91388.0 +2011-10-09 06:00:00+00:00,15.73,29.78,0.0,0.0,0.0,262.43,1.49,31.0,91364.0 +2011-10-09 07:00:00+00:00,14.93,32.0,0.0,0.0,0.0,260.87,1.7,42.0,91340.0 +2011-10-09 08:00:00+00:00,14.14,34.21,0.0,0.0,0.0,259.3,1.9,53.0,91316.0 +2011-10-09 09:00:00+00:00,13.42,36.05,0.0,0.0,0.0,258.47,2.09,58.0,91319.0 +2011-10-09 10:00:00+00:00,12.71,37.9,0.0,0.0,0.0,257.63,2.28,62.0,91322.0 +2011-10-09 11:00:00+00:00,11.99,39.74,0.0,0.0,0.0,256.8,2.47,67.0,91325.0 +2011-10-09 12:00:00+00:00,13.29,37.48,0.0,0.0,0.0,256.78,2.26,70.0,91382.0 +2011-10-09 13:00:00+00:00,14.58,35.23,0.0,0.0,0.0,256.77,2.06,72.0,91440.0 +2011-10-09 14:00:00+00:00,15.88,32.97,90.0,437.95,36.0,256.75,1.85,75.0,91497.0 +2011-10-09 15:00:00+00:00,18.45,28.0,312.0,747.76,65.0,261.48,2.08,83.0,91473.0 +2011-10-09 16:00:00+00:00,21.02,23.02,528.0,874.87,81.0,266.22,2.32,91.0,91449.0 +2011-10-09 17:00:00+00:00,23.58,18.05,704.0,938.97,91.0,270.95,2.55,99.0,91425.0 +2011-10-09 18:00:00+00:00,24.63,16.58,823.0,972.7,97.0,271.32,2.17,103.0,91334.0 +2011-10-09 19:00:00+00:00,25.67,15.1,874.0,987.07,99.0,271.68,1.78,108.0,91244.0 +2011-10-09 20:00:00+00:00,26.71,13.63,852.0,983.65,98.0,272.05,1.39,113.0,91154.0 +2011-10-09 21:00:00+00:00,26.7,13.51,759.0,961.28,94.0,272.15,2.15,114.0,91118.0 +2011-10-09 22:00:00+00:00,26.68,13.38,603.0,915.19,85.0,272.25,2.9,116.0,91082.0 +2011-10-09 23:00:00+00:00,26.66,13.26,398.0,819.58,72.0,272.35,3.66,117.0,91046.0 +2011-10-10 00:00:00+00:00,26.0,15.97,171.0,623.93,50.0,272.82,2.84,122.0,91067.0 +2011-10-10 01:00:00+00:00,25.33,18.68,0.0,0.0,0.0,273.28,2.03,126.0,91088.0 +2011-10-10 02:00:00+00:00,24.67,21.39,0.0,0.0,0.0,273.75,1.21,131.0,91109.0 +2011-10-10 03:00:00+00:00,23.3,24.21,0.0,0.0,0.0,274.38,1.37,119.0,91118.0 +2011-10-10 04:00:00+00:00,21.94,27.03,0.0,0.0,0.0,275.02,1.54,107.0,91127.0 +2011-10-10 05:00:00+00:00,20.57,29.85,0.0,0.0,0.0,275.65,1.7,95.0,91136.0 +2011-10-10 06:00:00+00:00,19.03,32.55,0.0,0.0,0.0,274.3,1.84,92.0,91133.0 +2011-10-10 07:00:00+00:00,17.5,35.25,0.0,0.0,0.0,272.95,1.99,89.0,91130.0 +2011-10-10 08:00:00+00:00,15.96,37.95,0.0,0.0,0.0,271.6,2.14,87.0,91127.0 +2011-10-10 09:00:00+00:00,14.94,39.91,0.0,0.0,0.0,270.08,2.39,85.0,91133.0 +2011-10-10 10:00:00+00:00,13.91,41.88,0.0,0.0,0.0,268.57,2.64,82.0,91139.0 +2011-10-10 11:00:00+00:00,12.89,43.84,0.0,0.0,0.0,267.05,2.9,80.0,91145.0 +2011-10-10 12:00:00+00:00,14.23,40.78,0.0,0.0,0.0,266.32,2.73,85.0,91199.0 +2011-10-10 13:00:00+00:00,15.57,37.71,0.0,0.0,0.0,265.58,2.56,89.0,91253.0 +2011-10-10 14:00:00+00:00,16.92,34.65,87.0,431.15,35.0,264.85,2.39,94.0,91307.0 +2011-10-10 15:00:00+00:00,20.01,28.17,308.0,742.24,65.0,270.58,2.0,112.0,91283.0 +2011-10-10 16:00:00+00:00,23.1,21.68,523.0,870.55,81.0,276.32,1.61,131.0,91259.0 +2011-10-10 17:00:00+00:00,26.19,15.2,698.0,936.34,90.0,282.05,1.23,150.0,91235.0 +2011-10-10 18:00:00+00:00,27.22,14.06,816.0,969.6,96.0,282.2,1.63,180.0,91157.0 +2011-10-10 19:00:00+00:00,28.24,12.92,866.0,983.26,98.0,282.35,2.04,210.0,91079.0 +2011-10-10 20:00:00+00:00,29.26,11.78,844.0,980.03,97.0,282.5,2.44,240.0,91001.0 +2011-10-10 21:00:00+00:00,29.12,11.77,751.0,957.38,93.0,282.38,2.7,252.0,90974.0 +2011-10-10 22:00:00+00:00,28.98,11.75,596.0,910.22,85.0,282.27,2.97,264.0,90947.0 +2011-10-10 23:00:00+00:00,28.84,11.74,394.0,819.07,72.0,282.15,3.23,276.0,90920.0 +2011-10-11 00:00:00+00:00,26.76,14.48,167.0,623.1,49.0,280.5,2.76,286.0,90959.0 +2011-10-11 01:00:00+00:00,24.68,17.21,0.0,0.0,0.0,278.85,2.3,295.0,90998.0 +2011-10-11 02:00:00+00:00,22.6,19.95,0.0,0.0,0.0,277.2,1.83,305.0,91037.0 +2011-10-11 03:00:00+00:00,21.81,21.29,0.0,0.0,0.0,276.88,1.68,329.0,91055.0 +2011-10-11 04:00:00+00:00,21.01,22.64,0.0,0.0,0.0,276.57,1.53,353.0,91073.0 +2011-10-11 05:00:00+00:00,20.22,23.98,0.0,0.0,0.0,276.25,1.38,17.0,91091.0 +2011-10-11 06:00:00+00:00,19.42,25.08,0.0,0.0,0.0,274.72,1.35,25.0,91094.0 +2011-10-11 07:00:00+00:00,18.61,26.17,0.0,0.0,0.0,273.18,1.32,33.0,91097.0 +2011-10-11 08:00:00+00:00,17.81,27.27,0.0,0.0,0.0,271.65,1.3,41.0,91100.0 +2011-10-11 09:00:00+00:00,16.9,29.05,0.0,0.0,0.0,270.4,1.35,41.0,91106.0 +2011-10-11 10:00:00+00:00,15.98,30.84,0.0,0.0,0.0,269.15,1.41,40.0,91112.0 +2011-10-11 11:00:00+00:00,15.07,32.62,0.0,0.0,0.0,267.9,1.46,39.0,91118.0 +2011-10-11 12:00:00+00:00,16.29,31.11,0.0,0.0,0.0,268.27,1.44,44.0,91157.0 +2011-10-11 13:00:00+00:00,17.51,29.61,0.0,0.0,0.0,268.63,1.43,48.0,91196.0 +2011-10-11 14:00:00+00:00,18.74,28.1,84.0,415.64,35.0,269.0,1.41,52.0,91235.0 +2011-10-11 15:00:00+00:00,21.73,23.28,304.0,739.77,64.0,274.6,1.6,46.0,91214.0 +2011-10-11 16:00:00+00:00,24.73,18.45,517.0,866.23,80.0,280.2,1.79,39.0,91193.0 +2011-10-11 17:00:00+00:00,27.72,13.63,690.0,929.08,90.0,285.8,1.99,32.0,91172.0 +2011-10-11 18:00:00+00:00,28.98,12.38,807.0,963.8,95.0,287.0,2.63,13.0,91112.0 +2011-10-11 19:00:00+00:00,30.24,11.13,855.0,974.29,98.0,288.2,3.26,354.0,91052.0 +2011-10-11 20:00:00+00:00,31.49,9.88,832.0,969.79,97.0,289.4,3.9,334.0,90992.0 +2011-10-11 21:00:00+00:00,31.23,10.29,739.0,947.56,92.0,289.6,3.73,334.0,90974.0 +2011-10-11 22:00:00+00:00,30.97,10.71,585.0,899.76,84.0,289.8,3.55,334.0,90956.0 +2011-10-11 23:00:00+00:00,30.7,11.12,384.0,805.63,71.0,290.0,3.38,334.0,90938.0 +2011-10-12 00:00:00+00:00,28.3,14.02,160.0,605.86,48.0,287.83,2.86,335.0,90977.0 +2011-10-12 01:00:00+00:00,25.91,16.92,0.0,0.0,0.0,285.67,2.35,337.0,91016.0 +2011-10-12 02:00:00+00:00,23.51,19.82,0.0,0.0,0.0,283.5,1.83,338.0,91055.0 +2011-10-12 03:00:00+00:00,22.56,20.62,0.0,0.0,0.0,283.27,1.48,346.0,91088.0 +2011-10-12 04:00:00+00:00,21.62,21.43,0.0,0.0,0.0,283.03,1.12,354.0,91121.0 +2011-10-12 05:00:00+00:00,20.67,22.23,0.0,0.0,0.0,282.8,0.76,2.0,91154.0 +2011-10-12 06:00:00+00:00,20.0,24.81,0.0,0.0,0.0,281.55,0.95,10.0,91175.0 +2011-10-12 07:00:00+00:00,19.33,27.38,0.0,0.0,0.0,280.3,1.14,19.0,91196.0 +2011-10-12 08:00:00+00:00,18.66,29.96,0.0,0.0,0.0,279.05,1.32,28.0,91217.0 +2011-10-12 09:00:00+00:00,17.95,31.38,0.0,0.0,0.0,278.37,1.73,38.0,91223.0 +2011-10-12 10:00:00+00:00,17.23,32.81,0.0,0.0,0.0,277.68,2.14,49.0,91229.0 +2011-10-12 11:00:00+00:00,16.52,34.23,0.0,0.0,0.0,277.0,2.55,60.0,91235.0 +2011-10-12 12:00:00+00:00,17.65,32.01,0.0,0.0,0.0,277.05,2.47,65.0,91253.0 +2011-10-12 13:00:00+00:00,18.78,29.8,0.0,0.0,0.0,277.1,2.4,71.0,91271.0 +2011-10-12 14:00:00+00:00,19.92,27.58,81.0,408.19,34.0,277.15,2.32,76.0,91289.0 +2011-10-12 15:00:00+00:00,23.36,23.28,300.0,734.22,64.0,282.35,2.87,79.0,91289.0 +2011-10-12 16:00:00+00:00,26.8,18.98,514.0,865.91,80.0,287.55,3.42,82.0,91289.0 +2011-10-12 17:00:00+00:00,30.24,14.68,687.0,931.13,89.0,292.75,3.97,84.0,91289.0 +2011-10-12 18:00:00+00:00,31.32,13.67,804.0,964.77,95.0,294.17,3.87,84.0,91220.0 +2011-10-12 19:00:00+00:00,32.39,12.67,853.0,978.18,97.0,295.58,3.77,84.0,91151.0 +2011-10-12 20:00:00+00:00,33.46,11.66,830.0,974.03,96.0,297.0,3.67,84.0,91082.0 +2011-10-12 21:00:00+00:00,33.2,11.59,736.0,949.4,92.0,296.77,3.56,79.0,91058.0 +2011-10-12 22:00:00+00:00,32.93,11.53,581.0,899.96,84.0,296.53,3.45,74.0,91034.0 +2011-10-12 23:00:00+00:00,32.66,11.46,378.0,802.22,70.0,296.3,3.34,70.0,91010.0 +2011-10-13 00:00:00+00:00,30.11,14.34,155.0,598.71,47.0,295.52,2.87,74.0,91019.0 +2011-10-13 01:00:00+00:00,27.56,17.22,0.0,0.0,0.0,294.73,2.41,78.0,91028.0 +2011-10-13 02:00:00+00:00,25.01,20.1,0.0,0.0,0.0,293.95,1.94,82.0,91037.0 +2011-10-13 03:00:00+00:00,23.62,22.95,0.0,0.0,0.0,292.83,2.08,85.0,91073.0 +2011-10-13 04:00:00+00:00,22.24,25.8,0.0,0.0,0.0,291.72,2.21,88.0,91109.0 +2011-10-13 05:00:00+00:00,20.85,28.65,0.0,0.0,0.0,290.6,2.34,91.0,91145.0 +2011-10-13 06:00:00+00:00,20.01,30.75,0.0,0.0,0.0,287.85,2.56,89.0,91145.0 +2011-10-13 07:00:00+00:00,19.17,32.86,0.0,0.0,0.0,285.1,2.78,88.0,91145.0 +2011-10-13 08:00:00+00:00,18.33,34.96,0.0,0.0,0.0,282.35,2.99,86.0,91145.0 +2011-10-13 09:00:00+00:00,17.58,36.6,0.0,0.0,0.0,280.93,3.2,86.0,91148.0 +2011-10-13 10:00:00+00:00,16.82,38.23,0.0,0.0,0.0,279.52,3.4,85.0,91151.0 +2011-10-13 11:00:00+00:00,16.07,39.87,0.0,0.0,0.0,278.1,3.6,84.0,91154.0 +2011-10-13 12:00:00+00:00,17.56,37.9,0.0,0.0,0.0,278.58,3.5,87.0,91193.0 +2011-10-13 13:00:00+00:00,19.04,35.93,0.0,0.0,0.0,279.07,3.4,90.0,91232.0 +2011-10-13 14:00:00+00:00,20.53,33.96,80.0,409.36,34.0,279.55,3.3,93.0,91271.0 +2011-10-13 15:00:00+00:00,24.38,27.33,301.0,744.34,64.0,286.37,2.41,110.0,91259.0 +2011-10-13 16:00:00+00:00,28.24,20.71,514.0,871.66,80.0,293.18,1.53,127.0,91247.0 +2011-10-13 17:00:00+00:00,32.09,14.08,688.0,937.94,89.0,300.0,0.65,145.0,91235.0 +2011-10-13 18:00:00+00:00,32.99,13.0,804.0,969.89,95.0,302.45,1.26,175.0,91148.0 +2011-10-13 19:00:00+00:00,33.89,11.92,852.0,982.14,97.0,304.9,1.88,205.0,91061.0 +2011-10-13 20:00:00+00:00,34.78,10.84,827.0,975.66,96.0,307.35,2.5,234.0,90974.0 +2011-10-13 21:00:00+00:00,34.33,10.95,733.0,952.75,91.0,307.77,2.86,244.0,90944.0 +2011-10-13 22:00:00+00:00,33.88,11.06,578.0,903.79,83.0,308.18,3.21,254.0,90914.0 +2011-10-13 23:00:00+00:00,33.42,11.17,376.0,806.57,70.0,308.6,3.57,264.0,90884.0 +2011-10-14 00:00:00+00:00,31.19,13.48,152.0,602.39,46.0,307.55,2.94,267.0,90905.0 +2011-10-14 01:00:00+00:00,28.95,15.78,0.0,0.0,0.0,306.5,2.3,270.0,90926.0 +2011-10-14 02:00:00+00:00,26.72,18.09,0.0,0.0,0.0,305.45,1.67,272.0,90947.0 +2011-10-14 03:00:00+00:00,26.63,18.77,0.0,0.0,0.0,304.65,1.88,265.0,90989.0 +2011-10-14 04:00:00+00:00,26.55,19.45,0.0,0.0,0.0,303.85,2.08,257.0,91031.0 +2011-10-14 05:00:00+00:00,26.46,20.13,0.0,0.0,0.0,303.05,2.29,249.0,91073.0 +2011-10-14 06:00:00+00:00,25.55,23.09,0.0,0.0,0.0,300.67,2.38,250.0,91088.0 +2011-10-14 07:00:00+00:00,24.64,26.05,0.0,0.0,0.0,298.28,2.46,251.0,91103.0 +2011-10-14 08:00:00+00:00,23.73,29.01,0.0,0.0,0.0,295.9,2.55,253.0,91118.0 +2011-10-14 09:00:00+00:00,23.19,30.29,0.0,0.0,0.0,294.12,2.57,289.0,91121.0 +2011-10-14 10:00:00+00:00,22.65,31.56,0.0,0.0,0.0,292.33,2.58,326.0,91124.0 +2011-10-14 11:00:00+00:00,22.11,32.84,0.0,0.0,0.0,290.55,2.59,2.0,91127.0 +2011-10-14 12:00:00+00:00,22.15,31.58,0.0,0.0,0.0,290.13,2.38,26.0,91178.0 +2011-10-14 13:00:00+00:00,22.18,30.32,0.0,0.0,0.0,289.72,2.17,49.0,91229.0 +2011-10-14 14:00:00+00:00,22.22,29.06,78.0,410.69,33.0,289.3,1.96,73.0,91280.0 +2011-10-14 15:00:00+00:00,25.39,24.06,296.0,738.88,63.0,294.88,1.85,67.0,91271.0 +2011-10-14 16:00:00+00:00,28.56,19.05,510.0,871.49,79.0,300.47,1.74,61.0,91262.0 +2011-10-14 17:00:00+00:00,31.72,14.05,683.0,935.43,89.0,306.05,1.63,55.0,91253.0 +2011-10-14 18:00:00+00:00,32.69,13.15,799.0,969.6,94.0,307.27,1.79,3.0,91175.0 +2011-10-14 19:00:00+00:00,33.66,12.26,848.0,982.23,97.0,308.48,1.96,312.0,91097.0 +2011-10-14 20:00:00+00:00,34.63,11.36,824.0,977.32,96.0,309.7,2.12,261.0,91019.0 +2011-10-14 21:00:00+00:00,34.39,11.36,731.0,956.12,91.0,308.78,2.43,275.0,90992.0 +2011-10-14 22:00:00+00:00,34.14,11.37,575.0,905.81,83.0,307.87,2.73,289.0,90965.0 +2011-10-14 23:00:00+00:00,33.89,11.37,372.0,808.28,69.0,306.95,3.03,303.0,90938.0 +2011-10-15 00:00:00+00:00,31.62,14.02,148.0,594.44,46.0,304.85,2.69,310.0,90971.0 +2011-10-15 01:00:00+00:00,29.36,16.67,0.0,0.0,0.0,302.75,2.34,317.0,91004.0 +2011-10-15 02:00:00+00:00,27.09,19.32,0.0,0.0,0.0,300.65,1.99,324.0,91037.0 +2011-10-15 03:00:00+00:00,26.92,19.16,0.0,0.0,0.0,300.25,1.94,339.0,91070.0 +2011-10-15 04:00:00+00:00,26.75,19.01,0.0,0.0,0.0,299.85,1.89,354.0,91103.0 +2011-10-15 05:00:00+00:00,26.58,18.85,0.0,0.0,0.0,299.45,1.85,10.0,91136.0 +2011-10-15 06:00:00+00:00,25.04,21.2,0.0,0.0,0.0,297.68,2.0,26.0,91148.0 +2011-10-15 07:00:00+00:00,23.5,23.56,0.0,0.0,0.0,295.92,2.16,42.0,91160.0 +2011-10-15 08:00:00+00:00,21.96,25.91,0.0,0.0,0.0,294.15,2.32,58.0,91172.0 +2011-10-15 09:00:00+00:00,20.73,29.03,0.0,0.0,0.0,293.12,2.5,64.0,91166.0 +2011-10-15 10:00:00+00:00,19.49,32.16,0.0,0.0,0.0,292.08,2.68,70.0,91160.0 +2011-10-15 11:00:00+00:00,18.26,35.28,0.0,0.0,0.0,291.05,2.86,75.0,91154.0 +2011-10-15 12:00:00+00:00,19.37,33.24,0.0,0.0,0.0,291.12,2.88,78.0,91196.0 +2011-10-15 13:00:00+00:00,20.48,31.2,0.0,0.0,0.0,291.18,2.91,80.0,91238.0 +2011-10-15 14:00:00+00:00,21.6,29.16,76.0,402.83,33.0,291.25,2.94,82.0,91280.0 +2011-10-15 15:00:00+00:00,25.47,23.8,295.0,742.98,63.0,297.17,2.22,89.0,91268.0 +2011-10-15 16:00:00+00:00,29.34,18.44,508.0,873.4,79.0,303.08,1.49,95.0,91256.0 +2011-10-15 17:00:00+00:00,33.2,13.08,682.0,939.27,89.0,309.0,0.77,102.0,91244.0 +2011-10-15 18:00:00+00:00,34.2,12.04,797.0,972.11,94.0,311.0,1.39,121.0,91169.0 +2011-10-15 19:00:00+00:00,35.19,10.99,844.0,983.67,96.0,313.0,2.0,141.0,91094.0 +2011-10-15 20:00:00+00:00,36.18,9.95,818.0,976.3,95.0,315.0,2.62,160.0,91019.0 +2011-10-15 21:00:00+00:00,35.78,9.98,723.0,950.51,91.0,314.2,3.01,178.0,90992.0 +2011-10-15 22:00:00+00:00,35.38,10.02,566.0,898.54,82.0,313.4,3.39,195.0,90965.0 +2011-10-15 23:00:00+00:00,34.98,10.05,363.0,793.75,69.0,312.6,3.78,213.0,90938.0 +2011-10-16 00:00:00+00:00,32.48,12.62,141.0,573.94,45.0,311.28,3.3,214.0,90983.0 +2011-10-16 01:00:00+00:00,29.99,15.18,0.0,0.0,0.0,309.97,2.81,216.0,91028.0 +2011-10-16 02:00:00+00:00,27.49,17.75,0.0,0.0,0.0,308.65,2.33,217.0,91073.0 +2011-10-16 03:00:00+00:00,27.03,18.55,0.0,0.0,0.0,307.93,2.25,169.0,91112.0 +2011-10-16 04:00:00+00:00,26.57,19.35,0.0,0.0,0.0,307.22,2.17,120.0,91151.0 +2011-10-16 05:00:00+00:00,26.11,20.15,0.0,0.0,0.0,306.5,2.1,72.0,91190.0 +2011-10-16 06:00:00+00:00,25.4,21.09,0.0,0.0,0.0,304.37,2.08,71.0,91205.0 +2011-10-16 07:00:00+00:00,24.7,22.03,0.0,0.0,0.0,302.23,2.06,71.0,91220.0 +2011-10-16 08:00:00+00:00,23.99,22.97,0.0,0.0,0.0,300.1,2.04,70.0,91235.0 +2011-10-16 09:00:00+00:00,23.04,25.39,0.0,0.0,0.0,298.8,2.15,72.0,91241.0 +2011-10-16 10:00:00+00:00,22.09,27.82,0.0,0.0,0.0,297.5,2.26,74.0,91247.0 +2011-10-16 11:00:00+00:00,21.14,30.24,0.0,0.0,0.0,296.2,2.37,76.0,91253.0 +2011-10-16 12:00:00+00:00,21.81,30.37,0.0,0.0,0.0,296.42,2.18,78.0,91307.0 +2011-10-16 13:00:00+00:00,22.48,30.51,0.0,0.0,0.0,296.63,1.99,80.0,91361.0 +2011-10-16 14:00:00+00:00,23.16,30.64,71.0,375.38,32.0,296.85,1.79,83.0,91416.0 +2011-10-16 15:00:00+00:00,26.27,25.46,285.0,721.36,62.0,302.18,1.76,27.0,91397.0 +2011-10-16 16:00:00+00:00,29.38,20.29,495.0,854.89,78.0,307.52,1.73,331.0,91379.0 +2011-10-16 17:00:00+00:00,32.48,15.11,666.0,922.48,87.0,312.85,1.7,276.0,91361.0 +2011-10-16 18:00:00+00:00,33.38,13.69,780.0,955.2,93.0,313.98,2.3,269.0,91301.0 +2011-10-16 19:00:00+00:00,34.28,12.26,826.0,966.62,95.0,315.12,2.9,262.0,91241.0 +2011-10-16 20:00:00+00:00,35.18,10.84,801.0,960.33,94.0,316.25,3.5,255.0,91181.0 +2011-10-16 21:00:00+00:00,34.61,11.15,706.0,934.2,89.0,315.6,3.81,260.0,91166.0 +2011-10-16 22:00:00+00:00,34.04,11.45,552.0,881.74,81.0,314.95,4.11,265.0,91151.0 +2011-10-16 23:00:00+00:00,33.47,11.76,352.0,776.05,68.0,314.3,4.41,270.0,91136.0 +2011-10-17 00:00:00+00:00,31.29,14.19,134.0,552.16,44.0,311.95,3.43,279.0,91196.0 +2011-10-17 01:00:00+00:00,29.11,16.63,0.0,0.0,0.0,309.6,2.44,289.0,91256.0 +2011-10-17 02:00:00+00:00,26.93,19.06,0.0,0.0,0.0,307.25,1.45,298.0,91316.0 +2011-10-17 03:00:00+00:00,25.85,19.97,0.0,0.0,0.0,305.52,1.4,304.0,91340.0 +2011-10-17 04:00:00+00:00,24.76,20.87,0.0,0.0,0.0,303.78,1.36,310.0,91364.0 +2011-10-17 05:00:00+00:00,23.68,21.78,0.0,0.0,0.0,302.05,1.31,316.0,91388.0 +2011-10-17 06:00:00+00:00,23.18,21.65,0.0,0.0,0.0,299.97,1.26,321.0,91397.0 +2011-10-17 07:00:00+00:00,22.69,21.52,0.0,0.0,0.0,297.88,1.21,327.0,91406.0 +2011-10-17 08:00:00+00:00,22.19,21.39,0.0,0.0,0.0,295.8,1.16,332.0,91416.0 +2011-10-17 09:00:00+00:00,21.55,21.9,0.0,0.0,0.0,294.0,1.25,334.0,91413.0 +2011-10-17 10:00:00+00:00,20.9,22.4,0.0,0.0,0.0,292.2,1.34,337.0,91410.0 +2011-10-17 11:00:00+00:00,20.26,22.91,0.0,0.0,0.0,290.4,1.43,339.0,91406.0 +2011-10-17 12:00:00+00:00,21.3,26.39,0.0,0.0,0.0,290.87,1.31,334.0,91455.0 +2011-10-17 13:00:00+00:00,22.34,29.87,0.0,0.0,0.0,291.33,1.18,329.0,91503.0 +2011-10-17 14:00:00+00:00,23.38,33.35,69.0,376.17,31.0,291.8,1.05,323.0,91551.0 +2011-10-17 15:00:00+00:00,25.81,28.28,281.0,718.98,61.0,295.85,1.89,325.0,91536.0 +2011-10-17 16:00:00+00:00,28.25,23.21,490.0,852.69,77.0,299.9,2.73,326.0,91521.0 +2011-10-17 17:00:00+00:00,30.68,18.14,660.0,918.36,87.0,303.95,3.57,328.0,91506.0 +2011-10-17 18:00:00+00:00,31.57,16.64,773.0,950.71,93.0,304.88,4.11,325.0,91437.0 +2011-10-17 19:00:00+00:00,32.46,15.15,820.0,964.02,95.0,305.82,4.66,323.0,91367.0 +2011-10-17 20:00:00+00:00,33.34,13.65,797.0,960.57,94.0,306.75,5.2,321.0,91298.0 +2011-10-17 21:00:00+00:00,32.89,13.8,704.0,937.47,89.0,306.7,4.79,322.0,91265.0 +2011-10-17 22:00:00+00:00,32.43,13.95,552.0,889.15,81.0,306.65,4.37,322.0,91232.0 +2011-10-17 23:00:00+00:00,31.97,14.1,353.0,791.02,67.0,306.6,3.96,323.0,91199.0 +2011-10-18 00:00:00+00:00,29.89,16.69,133.0,566.82,43.0,302.9,3.44,326.0,91235.0 +2011-10-18 01:00:00+00:00,27.82,19.28,0.0,0.0,0.0,299.2,2.93,328.0,91271.0 +2011-10-18 02:00:00+00:00,25.74,21.87,0.0,0.0,0.0,295.5,2.41,331.0,91307.0 +2011-10-18 03:00:00+00:00,24.94,22.07,0.0,0.0,0.0,294.57,1.91,338.0,91319.0 +2011-10-18 04:00:00+00:00,24.13,22.28,0.0,0.0,0.0,293.63,1.41,344.0,91331.0 +2011-10-18 05:00:00+00:00,23.33,22.48,0.0,0.0,0.0,292.7,0.91,351.0,91343.0 +2011-10-18 06:00:00+00:00,22.49,25.28,0.0,0.0,0.0,291.68,1.23,4.0,91349.0 +2011-10-18 07:00:00+00:00,21.64,28.09,0.0,0.0,0.0,290.67,1.54,17.0,91355.0 +2011-10-18 08:00:00+00:00,20.8,30.89,0.0,0.0,0.0,289.65,1.86,30.0,91361.0 +2011-10-18 09:00:00+00:00,19.81,33.01,0.0,0.0,0.0,288.65,1.86,42.0,91376.0 +2011-10-18 10:00:00+00:00,18.82,35.12,0.0,0.0,0.0,287.65,1.85,54.0,91391.0 +2011-10-18 11:00:00+00:00,17.83,37.24,0.0,0.0,0.0,286.65,1.85,65.0,91406.0 +2011-10-18 12:00:00+00:00,19.0,35.76,0.0,0.0,0.0,286.93,1.98,68.0,91464.0 +2011-10-18 13:00:00+00:00,20.17,34.28,0.0,0.0,0.0,287.22,2.11,70.0,91521.0 +2011-10-18 14:00:00+00:00,21.34,32.8,67.0,377.1,30.0,287.5,2.25,73.0,91578.0 +2011-10-18 15:00:00+00:00,24.64,26.98,281.0,726.52,61.0,291.78,2.91,76.0,91560.0 +2011-10-18 16:00:00+00:00,27.94,21.17,491.0,860.91,77.0,296.07,3.56,78.0,91542.0 +2011-10-18 17:00:00+00:00,31.23,15.35,663.0,928.73,87.0,300.35,4.22,81.0,91524.0 +2011-10-18 18:00:00+00:00,32.06,13.93,777.0,961.66,93.0,300.07,3.77,83.0,91446.0 +2011-10-18 19:00:00+00:00,32.88,12.52,824.0,974.77,95.0,299.78,3.33,85.0,91367.0 +2011-10-18 20:00:00+00:00,33.7,11.1,799.0,969.04,94.0,299.5,2.88,87.0,91289.0 +2011-10-18 21:00:00+00:00,33.32,10.88,706.0,946.89,89.0,298.12,3.06,86.0,91256.0 +2011-10-18 22:00:00+00:00,32.93,10.65,551.0,894.73,81.0,296.73,3.24,85.0,91223.0 +2011-10-18 23:00:00+00:00,32.54,10.43,350.0,792.26,67.0,295.35,3.42,84.0,91190.0 +2011-10-19 00:00:00+00:00,30.23,12.46,129.0,556.19,43.0,294.55,3.13,85.0,91193.0 +2011-10-19 01:00:00+00:00,27.91,14.48,0.0,0.0,0.0,293.75,2.84,87.0,91196.0 +2011-10-19 02:00:00+00:00,25.6,16.51,0.0,0.0,0.0,292.95,2.55,89.0,91199.0 +2011-10-19 03:00:00+00:00,24.31,17.99,0.0,0.0,0.0,291.4,2.7,89.0,91220.0 +2011-10-19 04:00:00+00:00,23.02,19.46,0.0,0.0,0.0,289.85,2.85,89.0,91241.0 +2011-10-19 05:00:00+00:00,21.73,20.94,0.0,0.0,0.0,288.3,2.99,89.0,91262.0 +2011-10-19 06:00:00+00:00,20.84,22.2,0.0,0.0,0.0,285.2,3.29,87.0,91262.0 +2011-10-19 07:00:00+00:00,19.95,23.47,0.0,0.0,0.0,282.1,3.58,85.0,91262.0 +2011-10-19 08:00:00+00:00,19.06,24.73,0.0,0.0,0.0,279.0,3.88,83.0,91262.0 +2011-10-19 09:00:00+00:00,18.22,26.19,0.0,0.0,0.0,276.95,3.87,82.0,91280.0 +2011-10-19 10:00:00+00:00,17.39,27.66,0.0,0.0,0.0,274.9,3.87,81.0,91298.0 +2011-10-19 11:00:00+00:00,16.55,29.12,0.0,0.0,0.0,272.85,3.86,81.0,91316.0 +2011-10-19 12:00:00+00:00,17.64,28.28,0.0,0.0,0.0,273.83,3.85,83.0,91340.0 +2011-10-19 13:00:00+00:00,18.72,27.44,0.0,0.0,0.0,274.82,3.83,85.0,91364.0 +2011-10-19 14:00:00+00:00,19.81,26.6,66.0,378.19,30.0,275.8,3.82,88.0,91388.0 +2011-10-19 15:00:00+00:00,23.32,22.55,281.0,734.29,61.0,281.33,3.35,96.0,91349.0 +2011-10-19 16:00:00+00:00,26.84,18.51,492.0,869.29,77.0,286.87,2.88,104.0,91310.0 +2011-10-19 17:00:00+00:00,30.35,14.46,663.0,934.39,87.0,292.4,2.41,113.0,91271.0 +2011-10-19 18:00:00+00:00,31.74,13.14,776.0,967.11,92.0,296.02,2.46,142.0,91178.0 +2011-10-19 19:00:00+00:00,33.13,11.82,821.0,977.58,94.0,299.63,2.51,171.0,91085.0 +2011-10-19 20:00:00+00:00,34.51,10.5,795.0,970.7,93.0,303.25,2.57,200.0,90992.0 +2011-10-19 21:00:00+00:00,34.09,10.47,700.0,945.6,88.0,304.15,2.82,213.0,90953.0 +2011-10-19 22:00:00+00:00,33.67,10.44,545.0,892.67,80.0,305.05,3.08,226.0,90914.0 +2011-10-19 23:00:00+00:00,33.24,10.41,344.0,787.76,66.0,305.95,3.34,240.0,90875.0 +2011-10-20 00:00:00+00:00,31.01,12.36,124.0,544.75,42.0,306.38,2.73,234.0,90917.0 +2011-10-20 01:00:00+00:00,28.79,14.31,0.0,0.0,0.0,306.82,2.11,228.0,90959.0 +2011-10-20 02:00:00+00:00,26.56,16.26,0.0,0.0,0.0,307.25,1.5,222.0,91001.0 +2011-10-20 03:00:00+00:00,25.71,16.61,0.0,0.0,0.0,307.23,1.93,221.0,91046.0 +2011-10-20 04:00:00+00:00,24.87,16.96,0.0,0.0,0.0,307.22,2.36,220.0,91091.0 +2011-10-20 05:00:00+00:00,24.02,17.31,0.0,0.0,0.0,307.2,2.79,219.0,91136.0 +2011-10-20 06:00:00+00:00,22.77,18.97,0.0,0.0,0.0,303.97,2.86,217.0,91154.0 +2011-10-20 07:00:00+00:00,21.53,20.64,0.0,0.0,0.0,300.73,2.94,214.0,91172.0 +2011-10-20 08:00:00+00:00,20.28,22.3,0.0,0.0,0.0,297.5,3.02,211.0,91190.0 +2011-10-20 09:00:00+00:00,19.61,24.17,0.0,0.0,0.0,295.35,3.06,204.0,91211.0 +2011-10-20 10:00:00+00:00,18.94,26.05,0.0,0.0,0.0,293.2,3.09,198.0,91232.0 +2011-10-20 11:00:00+00:00,18.27,27.92,0.0,0.0,0.0,291.05,3.13,191.0,91253.0 +2011-10-20 12:00:00+00:00,19.35,27.66,0.0,0.0,0.0,290.62,3.13,187.0,91331.0 +2011-10-20 13:00:00+00:00,20.43,27.41,0.0,0.0,0.0,290.18,3.13,183.0,91410.0 +2011-10-20 14:00:00+00:00,21.51,27.15,63.0,368.6,29.0,289.75,3.13,179.0,91488.0 +2011-10-20 15:00:00+00:00,24.05,23.38,276.0,728.79,60.0,295.28,3.63,191.0,91479.0 +2011-10-20 16:00:00+00:00,26.59,19.61,487.0,867.3,76.0,300.82,4.13,203.0,91470.0 +2011-10-20 17:00:00+00:00,29.13,15.84,658.0,933.63,86.0,306.35,4.63,216.0,91461.0 +2011-10-20 18:00:00+00:00,30.05,15.02,771.0,965.52,92.0,307.93,5.04,222.0,91397.0 +2011-10-20 19:00:00+00:00,30.97,14.2,817.0,977.72,94.0,309.52,5.45,228.0,91334.0 +2011-10-20 20:00:00+00:00,31.88,13.38,790.0,969.58,93.0,311.1,5.86,234.0,91271.0 +2011-10-20 21:00:00+00:00,31.37,14.94,695.0,944.26,88.0,311.1,5.5,234.0,91271.0 +2011-10-20 22:00:00+00:00,30.86,16.51,540.0,890.51,80.0,311.1,5.14,234.0,91271.0 +2011-10-20 23:00:00+00:00,30.35,18.07,338.0,780.18,66.0,311.1,4.79,234.0,91271.0 +2011-10-21 00:00:00+00:00,28.95,22.85,120.0,539.28,41.0,312.12,4.07,231.0,91322.0 +2011-10-21 01:00:00+00:00,27.54,27.63,0.0,0.0,0.0,313.13,3.35,228.0,91373.0 +2011-10-21 02:00:00+00:00,26.14,32.41,0.0,0.0,0.0,314.15,2.63,225.0,91425.0 +2011-10-21 03:00:00+00:00,25.0,37.47,0.0,0.0,0.0,314.52,2.54,222.0,91476.0 +2011-10-21 04:00:00+00:00,23.87,42.54,0.0,0.0,0.0,314.88,2.45,220.0,91527.0 +2011-10-21 05:00:00+00:00,22.73,47.6,0.0,0.0,0.0,315.25,2.36,217.0,91578.0 +2011-10-21 06:00:00+00:00,22.04,53.05,0.0,0.0,0.0,314.85,2.31,213.0,91614.0 +2011-10-21 07:00:00+00:00,21.35,58.51,0.0,0.0,0.0,314.45,2.26,209.0,91650.0 +2011-10-21 08:00:00+00:00,20.66,63.96,0.0,0.0,0.0,314.05,2.21,205.0,91686.0 +2011-10-21 09:00:00+00:00,20.11,68.47,0.0,0.0,0.0,315.2,2.19,191.0,91707.0 +2011-10-21 10:00:00+00:00,19.56,72.97,0.0,0.0,0.0,316.35,2.18,177.0,91728.0 +2011-10-21 11:00:00+00:00,19.01,77.48,0.0,0.0,0.0,317.5,2.17,162.0,91749.0 +2011-10-21 12:00:00+00:00,20.11,70.41,0.0,0.0,0.0,320.02,1.91,154.0,91773.0 +2011-10-21 13:00:00+00:00,21.21,63.35,0.0,0.0,0.0,322.53,1.65,146.0,91797.0 +2011-10-21 14:00:00+00:00,22.32,56.28,58.0,336.07,28.0,325.05,1.39,138.0,91821.0 +2011-10-21 15:00:00+00:00,24.21,50.54,263.0,695.95,59.0,330.18,1.0,145.0,91803.0 +2011-10-21 16:00:00+00:00,26.1,44.8,467.0,833.42,75.0,335.32,0.6,152.0,91785.0 +2011-10-21 17:00:00+00:00,27.98,39.06,633.0,900.04,85.0,340.45,0.21,159.0,91767.0 +2011-10-21 18:00:00+00:00,28.98,35.98,743.0,933.9,90.0,339.6,0.88,175.0,91683.0 +2011-10-21 19:00:00+00:00,29.97,32.9,787.0,945.23,92.0,338.75,1.56,190.0,91599.0 +2011-10-21 20:00:00+00:00,30.96,29.82,761.0,937.65,91.0,337.9,2.23,206.0,91515.0 +2011-10-21 21:00:00+00:00,30.73,29.96,667.0,909.97,86.0,335.95,2.29,215.0,91485.0 +2011-10-21 22:00:00+00:00,30.5,30.11,515.0,853.11,78.0,334.0,2.35,224.0,91455.0 +2011-10-21 23:00:00+00:00,30.27,30.25,320.0,743.25,64.0,332.05,2.41,233.0,91425.0 +2011-10-22 00:00:00+00:00,29.05,31.69,85.0,259.61,48.0,327.47,1.8,240.0,91446.0 +2011-10-22 01:00:00+00:00,27.83,33.14,0.0,0.0,0.0,322.88,1.18,246.0,91467.0 +2011-10-22 02:00:00+00:00,26.61,34.58,0.0,0.0,0.0,318.3,0.57,253.0,91488.0 +2011-10-22 03:00:00+00:00,26.34,35.51,0.0,0.0,0.0,317.23,0.88,255.0,91500.0 +2011-10-22 04:00:00+00:00,26.07,36.43,0.0,0.0,0.0,316.17,1.2,257.0,91512.0 +2011-10-22 05:00:00+00:00,25.8,37.36,0.0,0.0,0.0,315.1,1.52,260.0,91524.0 +2011-10-22 06:00:00+00:00,25.17,38.69,0.0,0.0,0.0,314.0,1.64,317.0,91524.0 +2011-10-22 07:00:00+00:00,24.55,40.02,0.0,0.0,0.0,312.9,1.77,15.0,91524.0 +2011-10-22 08:00:00+00:00,23.92,41.35,0.0,0.0,0.0,311.8,1.89,73.0,91524.0 +2011-10-22 09:00:00+00:00,22.26,43.62,0.0,0.0,0.0,310.35,2.08,74.0,91536.0 +2011-10-22 10:00:00+00:00,20.6,45.9,0.0,0.0,0.0,308.9,2.27,75.0,91548.0 +2011-10-22 11:00:00+00:00,18.94,48.17,0.0,0.0,0.0,307.45,2.46,76.0,91560.0 +2011-10-22 12:00:00+00:00,19.92,47.45,0.0,0.0,0.0,307.9,2.4,79.0,91596.0 +2011-10-22 13:00:00+00:00,20.89,46.73,0.0,0.0,0.0,308.35,2.34,81.0,91632.0 +2011-10-22 14:00:00+00:00,21.87,46.01,56.0,336.15,27.0,308.8,2.28,84.0,91668.0 +2011-10-22 15:00:00+00:00,24.55,36.47,262.0,700.37,59.0,313.45,2.58,81.0,91641.0 +2011-10-22 16:00:00+00:00,27.24,26.94,467.0,839.78,75.0,318.1,2.88,78.0,91614.0 +2011-10-22 17:00:00+00:00,29.92,17.4,635.0,909.03,85.0,322.75,3.19,75.0,91587.0 +2011-10-22 18:00:00+00:00,30.74,17.19,747.0,945.08,90.0,322.93,3.19,76.0,91509.0 +2011-10-22 19:00:00+00:00,31.56,16.98,792.0,957.51,92.0,323.12,3.19,78.0,91431.0 +2011-10-22 20:00:00+00:00,32.38,16.77,767.0,951.77,91.0,323.3,3.19,79.0,91352.0 +2011-10-22 21:00:00+00:00,32.2,16.65,674.0,927.22,86.0,321.9,3.46,50.0,91328.0 +2011-10-22 22:00:00+00:00,32.02,16.52,520.0,870.14,78.0,320.5,3.74,22.0,91304.0 +2011-10-22 23:00:00+00:00,31.84,16.4,323.0,761.14,64.0,319.1,4.01,353.0,91280.0 +2011-10-23 00:00:00+00:00,30.18,19.12,110.0,512.21,39.0,316.53,3.45,354.0,91301.0 +2011-10-23 01:00:00+00:00,28.53,21.83,0.0,0.0,0.0,313.97,2.89,355.0,91322.0 +2011-10-23 02:00:00+00:00,26.87,24.55,0.0,0.0,0.0,311.4,2.33,356.0,91343.0 +2011-10-23 03:00:00+00:00,25.76,25.73,0.0,0.0,0.0,310.32,1.72,10.0,91364.0 +2011-10-23 04:00:00+00:00,24.64,26.91,0.0,0.0,0.0,309.23,1.11,24.0,91385.0 +2011-10-23 05:00:00+00:00,23.53,28.09,0.0,0.0,0.0,308.15,0.5,38.0,91406.0 +2011-10-23 06:00:00+00:00,22.43,29.64,0.0,0.0,0.0,305.8,0.87,46.0,91400.0 +2011-10-23 07:00:00+00:00,21.34,31.2,0.0,0.0,0.0,303.45,1.24,55.0,91394.0 +2011-10-23 08:00:00+00:00,20.24,32.75,0.0,0.0,0.0,301.1,1.61,64.0,91388.0 +2011-10-23 09:00:00+00:00,19.39,34.15,0.0,0.0,0.0,299.3,1.95,69.0,91385.0 +2011-10-23 10:00:00+00:00,18.54,35.54,0.0,0.0,0.0,297.5,2.29,74.0,91382.0 +2011-10-23 11:00:00+00:00,17.69,36.94,0.0,0.0,0.0,295.7,2.62,78.0,91379.0 +2011-10-23 12:00:00+00:00,18.79,35.94,0.0,0.0,0.0,295.25,2.51,83.0,91434.0 +2011-10-23 13:00:00+00:00,19.89,34.95,0.0,0.0,0.0,294.8,2.41,88.0,91488.0 +2011-10-23 14:00:00+00:00,20.99,33.95,55.0,336.32,27.0,294.35,2.3,93.0,91542.0 +2011-10-23 15:00:00+00:00,24.19,27.42,261.0,708.45,58.0,299.93,2.18,98.0,91530.0 +2011-10-23 16:00:00+00:00,27.4,20.89,468.0,848.44,75.0,305.52,2.06,103.0,91518.0 +2011-10-23 17:00:00+00:00,30.6,14.36,636.0,918.16,84.0,311.1,1.94,107.0,91506.0 +2011-10-23 18:00:00+00:00,31.4,13.63,748.0,952.06,90.0,312.25,2.11,129.0,91428.0 +2011-10-23 19:00:00+00:00,32.2,12.89,793.0,964.41,92.0,313.4,2.28,151.0,91349.0 +2011-10-23 20:00:00+00:00,33.0,12.16,767.0,957.55,91.0,314.55,2.44,173.0,91271.0 +2011-10-23 21:00:00+00:00,32.7,12.27,673.0,931.95,86.0,314.33,2.75,187.0,91247.0 +2011-10-23 22:00:00+00:00,32.4,12.38,519.0,875.47,78.0,314.12,3.06,202.0,91223.0 +2011-10-23 23:00:00+00:00,32.1,12.49,321.0,764.48,64.0,313.9,3.37,217.0,91199.0 +2011-10-24 00:00:00+00:00,30.25,15.13,107.0,511.96,38.0,313.05,2.82,243.0,91247.0 +2011-10-24 01:00:00+00:00,28.4,17.76,0.0,0.0,0.0,312.2,2.28,269.0,91295.0 +2011-10-24 02:00:00+00:00,26.55,20.4,0.0,0.0,0.0,311.35,1.74,295.0,91343.0 +2011-10-24 03:00:00+00:00,26.46,20.31,0.0,0.0,0.0,312.32,1.61,323.0,91379.0 +2011-10-24 04:00:00+00:00,26.38,20.23,0.0,0.0,0.0,313.28,1.49,350.0,91416.0 +2011-10-24 05:00:00+00:00,26.29,20.14,0.0,0.0,0.0,314.25,1.37,18.0,91452.0 +2011-10-24 06:00:00+00:00,25.2,21.41,0.0,0.0,0.0,314.27,1.47,38.0,91443.0 +2011-10-24 07:00:00+00:00,24.11,22.67,0.0,0.0,0.0,314.28,1.58,57.0,91434.0 +2011-10-24 08:00:00+00:00,23.02,23.94,0.0,0.0,0.0,314.3,1.68,77.0,91425.0 +2011-10-24 09:00:00+00:00,21.77,26.94,0.0,0.0,0.0,313.37,1.99,82.0,91428.0 +2011-10-24 10:00:00+00:00,20.53,29.93,0.0,0.0,0.0,312.43,2.29,87.0,91431.0 +2011-10-24 11:00:00+00:00,19.28,32.93,0.0,0.0,0.0,311.5,2.59,92.0,91434.0 +2011-10-24 12:00:00+00:00,19.84,32.68,0.0,0.0,0.0,311.58,2.38,101.0,91473.0 +2011-10-24 13:00:00+00:00,20.39,32.44,0.0,0.0,0.0,311.67,2.17,109.0,91512.0 +2011-10-24 14:00:00+00:00,20.95,32.19,51.0,311.66,26.0,311.75,1.96,118.0,91551.0 +2011-10-24 15:00:00+00:00,24.22,26.06,120.0,42.37,108.0,317.98,2.14,144.0,91545.0 +2011-10-24 16:00:00+00:00,27.49,19.93,263.0,130.55,203.0,324.22,2.32,170.0,91539.0 +2011-10-24 17:00:00+00:00,30.75,13.8,616.0,892.27,83.0,330.45,2.5,196.0,91533.0 +2011-10-24 18:00:00+00:00,31.4,13.43,725.0,927.11,88.0,332.78,2.74,208.0,91452.0 +2011-10-24 19:00:00+00:00,32.05,13.05,768.0,938.19,90.0,335.12,2.98,219.0,91370.0 +2011-10-24 20:00:00+00:00,32.7,12.68,149.0,1.43,148.0,337.45,3.23,230.0,91289.0 +2011-10-24 21:00:00+00:00,31.99,13.53,355.0,97.51,294.0,338.08,3.51,237.0,91280.0 +2011-10-24 22:00:00+00:00,31.28,14.39,499.0,846.77,76.0,338.72,3.8,243.0,91271.0 +2011-10-24 23:00:00+00:00,30.57,15.24,306.0,734.64,62.0,339.35,4.08,249.0,91262.0 +2011-10-25 00:00:00+00:00,29.03,20.5,99.0,473.25,37.0,338.22,3.11,253.0,91319.0 +2011-10-25 01:00:00+00:00,27.5,25.76,0.0,0.0,0.0,337.08,2.13,258.0,91376.0 +2011-10-25 02:00:00+00:00,25.96,31.02,0.0,0.0,0.0,335.95,1.16,262.0,91434.0 +2011-10-25 03:00:00+00:00,25.6,32.24,0.0,0.0,0.0,334.48,1.45,252.0,91461.0 +2011-10-25 04:00:00+00:00,25.24,33.47,0.0,0.0,0.0,333.02,1.75,241.0,91488.0 +2011-10-25 05:00:00+00:00,24.88,34.69,0.0,0.0,0.0,331.55,2.04,230.0,91515.0 +2011-10-25 06:00:00+00:00,23.75,35.71,0.0,0.0,0.0,330.03,2.17,220.0,91500.0 +2011-10-25 07:00:00+00:00,22.61,36.74,0.0,0.0,0.0,328.52,2.29,210.0,91485.0 +2011-10-25 08:00:00+00:00,21.48,37.76,0.0,0.0,0.0,327.0,2.41,199.0,91470.0 +2011-10-25 09:00:00+00:00,20.98,39.25,0.0,0.0,0.0,324.57,2.54,196.0,91473.0 +2011-10-25 10:00:00+00:00,20.47,40.75,0.0,0.0,0.0,322.13,2.67,192.0,91476.0 +2011-10-25 11:00:00+00:00,19.97,42.24,0.0,0.0,0.0,319.7,2.8,189.0,91479.0 +2011-10-25 12:00:00+00:00,20.64,46.83,0.0,0.0,0.0,320.77,2.88,190.0,91521.0 +2011-10-25 13:00:00+00:00,21.31,51.42,0.0,0.0,0.0,321.83,2.96,191.0,91563.0 +2011-10-25 14:00:00+00:00,21.99,56.01,47.0,285.14,25.0,322.9,3.03,192.0,91605.0 +2011-10-25 15:00:00+00:00,23.85,50.08,244.0,671.75,56.0,326.53,3.75,211.0,91581.0 +2011-10-25 16:00:00+00:00,25.72,44.14,444.0,813.63,73.0,330.17,4.46,229.0,91557.0 +2011-10-25 17:00:00+00:00,27.58,38.21,608.0,886.29,82.0,333.8,5.17,248.0,91533.0 +2011-10-25 18:00:00+00:00,28.61,34.24,717.0,920.91,88.0,335.28,5.6,249.0,91437.0 +2011-10-25 19:00:00+00:00,29.64,30.28,760.0,932.52,90.0,336.77,6.04,251.0,91340.0 +2011-10-25 20:00:00+00:00,30.66,26.31,735.0,926.23,89.0,338.25,6.47,252.0,91244.0 +2011-10-25 21:00:00+00:00,30.16,28.12,643.0,899.63,84.0,334.7,6.06,250.0,91196.0 +2011-10-25 22:00:00+00:00,29.66,29.94,493.0,841.74,76.0,331.15,5.64,248.0,91148.0 +2011-10-25 23:00:00+00:00,29.15,31.75,301.0,728.32,62.0,327.6,5.23,247.0,91100.0 +2011-10-26 00:00:00+00:00,28.21,35.43,95.0,463.43,36.0,330.3,4.97,246.0,91133.0 +2011-10-26 01:00:00+00:00,27.26,39.12,0.0,0.0,0.0,333.0,4.71,246.0,91166.0 +2011-10-26 02:00:00+00:00,26.32,42.8,0.0,0.0,0.0,335.7,4.46,245.0,91199.0 +2011-10-26 03:00:00+00:00,25.12,49.58,0.0,0.0,0.0,335.58,4.38,241.0,91232.0 +2011-10-26 04:00:00+00:00,23.91,56.36,0.0,0.0,0.0,335.47,4.31,237.0,91265.0 +2011-10-26 05:00:00+00:00,22.71,63.14,0.0,0.0,0.0,335.35,4.23,234.0,91298.0 +2011-10-26 06:00:00+00:00,21.96,67.54,0.0,0.0,0.0,332.53,4.13,227.0,91289.0 +2011-10-26 07:00:00+00:00,21.2,71.95,0.0,0.0,0.0,329.72,4.02,220.0,91280.0 +2011-10-26 08:00:00+00:00,20.45,76.35,0.0,0.0,0.0,326.9,3.92,214.0,91271.0 +2011-10-26 09:00:00+00:00,19.88,78.84,0.0,0.0,0.0,325.82,3.73,211.0,91265.0 +2011-10-26 10:00:00+00:00,19.3,81.32,0.0,0.0,0.0,324.73,3.55,208.0,91259.0 +2011-10-26 11:00:00+00:00,18.73,83.81,0.0,0.0,0.0,323.65,3.37,205.0,91253.0 +2011-10-26 12:00:00+00:00,19.07,80.92,0.0,0.0,0.0,320.68,3.73,207.0,91250.0 +2011-10-26 13:00:00+00:00,19.41,78.04,0.0,0.0,0.0,317.72,4.1,210.0,91247.0 +2011-10-26 14:00:00+00:00,19.75,75.15,46.0,296.98,24.0,314.75,4.47,212.0,91244.0 +2011-10-26 15:00:00+00:00,20.91,65.04,245.0,683.54,56.0,317.95,5.63,217.0,91226.0 +2011-10-26 16:00:00+00:00,22.07,54.93,449.0,831.23,73.0,321.15,6.79,222.0,91208.0 +2011-10-26 17:00:00+00:00,23.23,44.82,617.0,905.68,83.0,324.35,7.94,226.0,91190.0 +2011-10-26 18:00:00+00:00,23.89,40.07,730.0,945.56,88.0,319.6,7.81,231.0,91112.0 +2011-10-26 19:00:00+00:00,24.55,35.33,775.0,958.97,90.0,314.85,7.67,236.0,91034.0 +2011-10-26 20:00:00+00:00,25.2,30.58,751.0,954.95,89.0,310.1,7.53,241.0,90956.0 +2011-10-26 21:00:00+00:00,24.41,31.62,657.0,926.81,85.0,304.12,7.34,245.0,90950.0 +2011-10-26 22:00:00+00:00,23.61,32.65,503.0,869.11,76.0,298.13,7.15,250.0,90944.0 +2011-10-26 23:00:00+00:00,22.81,33.69,306.0,752.56,62.0,292.15,6.97,255.0,90938.0 +2011-10-27 00:00:00+00:00,22.09,34.42,95.0,477.01,36.0,290.42,5.88,262.0,90971.0 +2011-10-27 01:00:00+00:00,21.37,35.15,0.0,0.0,0.0,288.68,4.79,268.0,91004.0 +2011-10-27 02:00:00+00:00,20.65,35.88,0.0,0.0,0.0,286.95,3.7,275.0,91037.0 +2011-10-27 03:00:00+00:00,19.72,36.06,0.0,0.0,0.0,283.15,3.34,276.0,91070.0 +2011-10-27 04:00:00+00:00,18.79,36.24,0.0,0.0,0.0,279.35,2.98,276.0,91103.0 +2011-10-27 05:00:00+00:00,17.86,36.42,0.0,0.0,0.0,275.55,2.62,277.0,91136.0 +2011-10-27 06:00:00+00:00,17.09,38.38,0.0,0.0,0.0,272.72,1.94,275.0,91157.0 +2011-10-27 07:00:00+00:00,16.31,40.34,0.0,0.0,0.0,269.88,1.26,272.0,91178.0 +2011-10-27 08:00:00+00:00,15.54,42.3,0.0,0.0,0.0,267.05,0.58,270.0,91199.0 +2011-10-27 09:00:00+00:00,15.35,42.85,0.0,0.0,0.0,264.97,0.83,283.0,91232.0 +2011-10-27 10:00:00+00:00,15.16,43.41,0.0,0.0,0.0,262.88,1.08,296.0,91265.0 +2011-10-27 11:00:00+00:00,14.97,43.96,0.0,0.0,0.0,260.8,1.32,309.0,91298.0 +2011-10-27 12:00:00+00:00,14.88,44.39,0.0,0.0,0.0,259.13,1.18,350.0,91346.0 +2011-10-27 13:00:00+00:00,14.79,44.81,0.0,0.0,0.0,257.47,1.04,32.0,91394.0 +2011-10-27 14:00:00+00:00,14.7,45.24,47.0,324.03,24.0,255.8,0.9,73.0,91443.0 +2011-10-27 15:00:00+00:00,16.85,39.86,252.0,713.99,57.0,259.72,1.55,74.0,91449.0 +2011-10-27 16:00:00+00:00,19.0,34.49,460.0,862.52,73.0,263.63,2.21,75.0,91455.0 +2011-10-27 17:00:00+00:00,21.14,29.11,628.0,930.47,83.0,267.55,2.87,76.0,91461.0 +2011-10-27 18:00:00+00:00,22.38,26.59,740.0,964.58,89.0,268.6,2.68,79.0,91385.0 +2011-10-27 19:00:00+00:00,23.61,24.08,785.0,977.27,91.0,269.65,2.49,81.0,91310.0 +2011-10-27 20:00:00+00:00,24.84,21.56,758.0,970.93,89.0,270.7,2.3,84.0,91235.0 +2011-10-27 21:00:00+00:00,24.87,21.44,663.0,942.89,85.0,271.03,2.64,87.0,91214.0 +2011-10-27 22:00:00+00:00,24.89,21.32,509.0,888.63,76.0,271.37,2.98,90.0,91193.0 +2011-10-27 23:00:00+00:00,24.91,21.2,309.0,770.99,62.0,271.7,3.32,92.0,91172.0 +2011-10-28 00:00:00+00:00,23.8,23.69,96.0,499.43,36.0,269.47,2.75,87.0,91226.0 +2011-10-28 01:00:00+00:00,22.68,26.18,0.0,0.0,0.0,267.23,2.18,82.0,91280.0 +2011-10-28 02:00:00+00:00,21.57,28.67,0.0,0.0,0.0,265.0,1.61,77.0,91334.0 +2011-10-28 03:00:00+00:00,19.77,31.41,0.0,0.0,0.0,264.87,1.29,76.0,91370.0 +2011-10-28 04:00:00+00:00,17.98,34.15,0.0,0.0,0.0,264.73,0.97,74.0,91406.0 +2011-10-28 05:00:00+00:00,16.18,36.89,0.0,0.0,0.0,264.6,0.65,72.0,91443.0 +2011-10-28 06:00:00+00:00,15.31,38.86,0.0,0.0,0.0,263.2,1.17,72.0,91455.0 +2011-10-28 07:00:00+00:00,14.44,40.82,0.0,0.0,0.0,261.8,1.7,71.0,91467.0 +2011-10-28 08:00:00+00:00,13.57,42.79,0.0,0.0,0.0,260.4,2.22,71.0,91479.0 +2011-10-28 09:00:00+00:00,12.96,44.13,0.0,0.0,0.0,259.17,2.51,73.0,91488.0 +2011-10-28 10:00:00+00:00,12.35,45.48,0.0,0.0,0.0,257.93,2.81,74.0,91497.0 +2011-10-28 11:00:00+00:00,11.74,46.82,0.0,0.0,0.0,256.7,3.1,76.0,91506.0 +2011-10-28 12:00:00+00:00,12.73,45.29,0.0,0.0,0.0,256.7,2.97,77.0,91578.0 +2011-10-28 13:00:00+00:00,13.72,43.76,0.0,0.0,0.0,256.7,2.85,78.0,91650.0 +2011-10-28 14:00:00+00:00,14.72,42.23,44.0,309.42,23.0,256.7,2.72,79.0,91722.0 +2011-10-28 15:00:00+00:00,17.79,35.61,248.0,711.87,56.0,261.8,3.41,80.0,91725.0 +2011-10-28 16:00:00+00:00,20.87,29.0,453.0,853.9,73.0,266.9,4.11,80.0,91728.0 +2011-10-28 17:00:00+00:00,23.94,22.38,620.0,924.66,82.0,272.0,4.8,81.0,91731.0 +2011-10-28 18:00:00+00:00,25.3,20.09,731.0,958.49,88.0,274.13,4.35,85.0,91656.0 +2011-10-28 19:00:00+00:00,26.66,17.8,775.0,970.27,90.0,276.27,3.9,89.0,91581.0 +2011-10-28 20:00:00+00:00,28.01,15.51,748.0,962.25,89.0,278.4,3.45,93.0,91506.0 +2011-10-28 21:00:00+00:00,27.72,15.46,654.0,936.13,84.0,278.92,3.27,95.0,91482.0 +2011-10-28 22:00:00+00:00,27.43,15.41,501.0,879.41,76.0,279.43,3.09,96.0,91458.0 +2011-10-28 23:00:00+00:00,27.14,15.36,303.0,764.43,61.0,279.95,2.91,98.0,91434.0 +2011-10-29 00:00:00+00:00,25.62,18.61,91.0,480.01,35.0,277.75,2.64,92.0,91464.0 +2011-10-29 01:00:00+00:00,24.1,21.87,0.0,0.0,0.0,275.55,2.38,87.0,91494.0 +2011-10-29 02:00:00+00:00,22.58,25.12,0.0,0.0,0.0,273.35,2.11,81.0,91524.0 +2011-10-29 03:00:00+00:00,20.74,27.56,0.0,0.0,0.0,272.25,2.39,78.0,91548.0 +2011-10-29 04:00:00+00:00,18.89,30.0,0.0,0.0,0.0,271.15,2.67,76.0,91572.0 +2011-10-29 05:00:00+00:00,17.05,32.44,0.0,0.0,0.0,270.05,2.95,73.0,91596.0 +2011-10-29 06:00:00+00:00,16.09,34.27,0.0,0.0,0.0,268.33,3.04,73.0,91602.0 +2011-10-29 07:00:00+00:00,15.12,36.09,0.0,0.0,0.0,266.62,3.13,73.0,91608.0 +2011-10-29 08:00:00+00:00,14.16,37.92,0.0,0.0,0.0,264.9,3.21,74.0,91614.0 +2011-10-29 09:00:00+00:00,13.54,39.79,0.0,0.0,0.0,263.27,3.22,74.0,91617.0 +2011-10-29 10:00:00+00:00,12.91,41.65,0.0,0.0,0.0,261.63,3.22,74.0,91620.0 +2011-10-29 11:00:00+00:00,12.29,43.52,0.0,0.0,0.0,260.0,3.23,74.0,91623.0 +2011-10-29 12:00:00+00:00,13.3,42.26,0.0,0.0,0.0,262.03,3.16,77.0,91653.0 +2011-10-29 13:00:00+00:00,14.31,40.99,0.0,0.0,0.0,264.07,3.09,79.0,91683.0 +2011-10-29 14:00:00+00:00,15.33,39.73,37.0,216.26,23.0,266.1,3.02,82.0,91713.0 +2011-10-29 15:00:00+00:00,18.61,33.26,213.0,563.29,63.0,274.75,2.4,87.0,91689.0 +2011-10-29 16:00:00+00:00,21.9,26.79,452.0,861.02,72.0,283.4,1.77,93.0,91665.0 +2011-10-29 17:00:00+00:00,25.18,20.32,456.0,370.28,242.0,292.05,1.14,98.0,91641.0 +2011-10-29 18:00:00+00:00,26.48,18.38,585.0,514.4,242.0,293.42,1.52,135.0,91554.0 +2011-10-29 19:00:00+00:00,27.77,16.45,572.0,364.75,316.0,294.78,1.89,171.0,91467.0 +2011-10-29 20:00:00+00:00,29.06,14.51,593.0,493.6,257.0,296.15,2.26,207.0,91379.0 +2011-10-29 21:00:00+00:00,28.65,14.54,460.0,312.49,271.0,291.42,2.5,231.0,91349.0 +2011-10-29 22:00:00+00:00,28.23,14.56,396.0,481.91,165.0,286.68,2.73,255.0,91319.0 +2011-10-29 23:00:00+00:00,27.81,14.59,208.0,274.9,122.0,281.95,2.97,279.0,91289.0 +2011-10-30 00:00:00+00:00,26.13,17.88,89.0,485.58,34.0,279.48,2.62,296.0,91331.0 +2011-10-30 01:00:00+00:00,24.44,21.18,0.0,0.0,0.0,277.02,2.28,313.0,91373.0 +2011-10-30 02:00:00+00:00,22.76,24.47,0.0,0.0,0.0,274.55,1.93,331.0,91416.0 +2011-10-30 03:00:00+00:00,21.49,25.94,0.0,0.0,0.0,274.23,1.68,350.0,91440.0 +2011-10-30 04:00:00+00:00,20.23,27.41,0.0,0.0,0.0,273.92,1.43,9.0,91464.0 +2011-10-30 05:00:00+00:00,18.96,28.88,0.0,0.0,0.0,273.6,1.19,28.0,91488.0 +2011-10-30 06:00:00+00:00,17.95,30.79,0.0,0.0,0.0,272.05,1.26,37.0,91494.0 +2011-10-30 07:00:00+00:00,16.93,32.69,0.0,0.0,0.0,270.5,1.33,46.0,91500.0 +2011-10-30 08:00:00+00:00,15.92,34.6,0.0,0.0,0.0,268.95,1.41,55.0,91506.0 +2011-10-30 09:00:00+00:00,15.14,36.59,0.0,0.0,0.0,267.38,1.88,60.0,91518.0 +2011-10-30 10:00:00+00:00,14.37,38.58,0.0,0.0,0.0,265.82,2.35,66.0,91530.0 +2011-10-30 11:00:00+00:00,13.59,40.57,0.0,0.0,0.0,264.25,2.83,71.0,91542.0 +2011-10-30 12:00:00+00:00,14.21,39.25,0.0,0.0,0.0,263.8,2.65,76.0,91605.0 +2011-10-30 13:00:00+00:00,14.83,37.94,0.0,0.0,0.0,263.35,2.47,80.0,91668.0 +2011-10-30 14:00:00+00:00,15.45,36.62,41.0,308.48,22.0,262.9,2.29,84.0,91731.0 +2011-10-30 15:00:00+00:00,19.24,29.73,247.0,726.63,56.0,268.17,2.34,84.0,91737.0 +2011-10-30 16:00:00+00:00,23.03,22.84,455.0,872.86,73.0,273.43,2.4,83.0,91743.0 +2011-10-30 17:00:00+00:00,26.82,15.95,625.0,945.93,82.0,278.7,2.46,83.0,91749.0 +2011-10-30 18:00:00+00:00,27.91,14.66,736.0,977.74,88.0,279.75,2.39,88.0,91668.0 +2011-10-30 19:00:00+00:00,28.99,13.37,780.0,988.92,90.0,280.8,2.33,93.0,91587.0 +2011-10-30 20:00:00+00:00,30.07,12.08,753.0,981.38,89.0,281.85,2.26,98.0,91506.0 +2011-10-30 21:00:00+00:00,29.91,11.98,656.0,952.08,84.0,281.37,2.56,101.0,91479.0 +2011-10-30 22:00:00+00:00,29.75,11.88,501.0,895.95,75.0,280.88,2.86,105.0,91452.0 +2011-10-30 23:00:00+00:00,29.59,11.78,301.0,776.23,61.0,280.4,3.16,108.0,91425.0 +2011-10-31 00:00:00+00:00,28.16,14.51,87.0,482.04,34.0,279.75,2.75,96.0,91458.0 +2011-10-31 01:00:00+00:00,26.72,17.24,0.0,0.0,0.0,279.1,2.34,84.0,91491.0 +2011-10-31 02:00:00+00:00,25.29,19.97,0.0,0.0,0.0,278.45,1.93,71.0,91524.0 +2011-10-31 03:00:00+00:00,23.21,21.98,0.0,0.0,0.0,278.0,1.75,77.0,91545.0 +2011-10-31 04:00:00+00:00,21.14,23.98,0.0,0.0,0.0,277.55,1.56,82.0,91566.0 +2011-10-31 05:00:00+00:00,19.06,25.99,0.0,0.0,0.0,277.1,1.38,87.0,91587.0 +2011-10-31 06:00:00+00:00,17.99,27.94,0.0,0.0,0.0,274.97,1.66,85.0,91572.0 +2011-10-31 07:00:00+00:00,16.92,29.88,0.0,0.0,0.0,272.83,1.94,83.0,91557.0 +2011-10-31 08:00:00+00:00,15.85,31.83,0.0,0.0,0.0,270.7,2.22,82.0,91542.0 +2011-10-31 09:00:00+00:00,14.93,33.26,0.0,0.0,0.0,269.38,2.59,81.0,91515.0 +2011-10-31 10:00:00+00:00,14.01,34.69,0.0,0.0,0.0,268.07,2.97,81.0,91488.0 +2011-10-31 11:00:00+00:00,13.09,36.12,0.0,0.0,0.0,266.75,3.34,81.0,91461.0 +2011-10-31 12:00:00+00:00,13.94,34.62,0.0,0.0,0.0,266.23,3.22,84.0,91494.0 +2011-10-31 13:00:00+00:00,14.78,33.12,0.0,0.0,0.0,265.72,3.1,88.0,91527.0 +2011-10-31 14:00:00+00:00,15.63,31.62,39.0,308.04,21.0,265.2,2.98,91.0,91560.0 +2011-10-31 15:00:00+00:00,19.78,25.36,241.0,717.01,55.0,270.27,2.35,101.0,91542.0 +2011-10-31 16:00:00+00:00,30.93,9.51,447.0,864.17,72.0,282.28,2.19,112.0,91524.0 +2011-10-31 17:00:00+00:00,30.23,10.4,613.0,933.11,81.0,282.08,2.11,123.0,91506.0 +2011-10-31 18:00:00+00:00,29.52,11.29,723.0,965.52,87.0,281.87,2.02,155.0,91416.0 +2011-10-31 19:00:00+00:00,28.82,12.18,766.0,976.02,89.0,281.67,1.94,187.0,91325.0 +2011-10-31 20:00:00+00:00,28.12,13.07,740.0,969.49,88.0,281.47,1.85,218.0,91235.0 +2011-10-31 21:00:00+00:00,27.42,13.96,646.0,943.36,83.0,281.26,1.77,229.0,91205.0 +2011-10-31 22:00:00+00:00,26.72,14.85,491.0,884.12,74.0,281.06,1.68,240.0,91175.0 +2011-10-31 23:00:00+00:00,26.02,15.74,293.0,762.44,60.0,280.86,1.6,250.0,91145.0 +2009-11-01 00:00:00+00:00,25.32,16.63,79.0,453.85,32.0,280.65,1.51,213.0,91452.0 +2009-11-01 01:00:00+00:00,24.62,17.52,0.0,0.0,0.0,280.45,1.42,170.0,91479.0 +2009-11-01 02:00:00+00:00,23.91,18.42,0.0,0.0,0.0,280.25,1.34,127.0,91506.0 +2009-11-01 03:00:00+00:00,23.21,19.31,0.0,0.0,0.0,280.04,1.25,118.0,91539.0 +2009-11-01 04:00:00+00:00,22.51,20.2,0.0,0.0,0.0,279.84,1.17,108.0,91572.0 +2009-11-01 05:00:00+00:00,21.81,21.09,0.0,0.0,0.0,279.64,1.08,99.0,91605.0 +2009-11-01 06:00:00+00:00,21.11,21.98,0.0,0.0,0.0,279.43,1.0,94.0,91611.0 +2009-11-01 07:00:00+00:00,20.41,22.87,0.0,0.0,0.0,279.23,0.91,89.0,91617.0 +2009-11-01 08:00:00+00:00,14.88,31.1,0.0,0.0,0.0,274.15,1.49,84.0,91623.0 +2009-11-01 09:00:00+00:00,14.02,32.63,0.0,0.0,0.0,272.15,1.62,84.0,91623.0 +2009-11-01 10:00:00+00:00,13.16,34.15,0.0,0.0,0.0,270.15,1.75,83.0,91623.0 +2009-11-01 11:00:00+00:00,12.29,35.68,0.0,0.0,0.0,268.15,1.88,82.0,91623.0 +2009-11-01 12:00:00+00:00,12.97,33.84,0.0,0.0,0.0,267.12,1.72,81.0,91686.0 +2009-11-01 13:00:00+00:00,13.64,32.01,0.0,0.0,0.0,266.08,1.57,80.0,91749.0 +2009-11-01 14:00:00+00:00,14.31,30.17,33.0,249.61,20.0,265.05,1.42,80.0,91812.0 +2009-11-01 15:00:00+00:00,18.66,24.25,232.0,701.03,55.0,269.4,1.57,78.0,91797.0 +2009-11-01 16:00:00+00:00,23.01,18.34,438.0,858.1,72.0,273.75,1.72,76.0,91782.0 +2009-11-01 17:00:00+00:00,27.37,12.42,606.0,931.82,82.0,278.1,1.88,74.0,91767.0 +2009-11-01 18:00:00+00:00,28.63,11.41,717.0,966.69,88.0,280.15,2.04,76.0,91683.0 +2009-11-01 19:00:00+00:00,29.89,10.4,761.0,978.84,90.0,282.2,2.21,79.0,91599.0 +2009-11-01 20:00:00+00:00,31.16,9.39,734.0,972.21,88.0,284.25,2.37,81.0,91515.0 +2009-11-01 21:00:00+00:00,30.58,9.57,639.0,942.3,84.0,284.0,2.27,82.0,91497.0 +2009-11-01 22:00:00+00:00,30.0,9.76,485.0,883.22,75.0,283.75,2.16,83.0,91479.0 +2009-11-01 23:00:00+00:00,29.43,9.94,287.0,760.12,60.0,283.5,2.06,83.0,91461.0 +2009-11-02 00:00:00+00:00,26.77,12.45,77.0,447.82,32.0,281.98,2.16,83.0,91494.0 +2009-11-02 01:00:00+00:00,24.1,14.96,0.0,0.0,0.0,280.47,2.27,82.0,91527.0 +2009-11-02 02:00:00+00:00,21.44,17.47,0.0,0.0,0.0,278.95,2.37,82.0,91560.0 +2009-11-02 03:00:00+00:00,19.92,19.58,0.0,0.0,0.0,276.88,2.4,84.0,91578.0 +2009-11-02 04:00:00+00:00,18.41,21.68,0.0,0.0,0.0,274.82,2.44,86.0,91596.0 +2009-11-02 05:00:00+00:00,16.89,23.79,0.0,0.0,0.0,272.75,2.47,87.0,91614.0 +2009-11-02 06:00:00+00:00,16.0,24.88,0.0,0.0,0.0,269.83,2.48,86.0,91614.0 +2009-11-02 07:00:00+00:00,15.11,25.97,0.0,0.0,0.0,266.92,2.49,84.0,91614.0 +2009-11-02 08:00:00+00:00,14.22,27.06,0.0,0.0,0.0,264.0,2.5,82.0,91614.0 +2009-11-02 09:00:00+00:00,13.75,27.43,0.0,0.0,0.0,262.58,2.54,80.0,91623.0 +2009-11-02 10:00:00+00:00,13.28,27.79,0.0,0.0,0.0,261.17,2.59,79.0,91632.0 +2009-11-02 11:00:00+00:00,12.8,28.16,0.0,0.0,0.0,259.75,2.63,77.0,91641.0 +2009-11-02 12:00:00+00:00,13.69,26.82,0.0,0.0,0.0,260.17,2.46,77.0,91692.0 +2009-11-02 13:00:00+00:00,14.57,25.47,0.0,0.0,0.0,260.58,2.29,76.0,91743.0 +2009-11-02 14:00:00+00:00,15.46,24.13,32.0,265.92,19.0,261.0,2.11,76.0,91794.0 +2009-11-02 15:00:00+00:00,19.92,19.44,233.0,714.83,55.0,265.42,2.46,79.0,91770.0 +2009-11-02 16:00:00+00:00,24.39,14.75,440.0,870.37,72.0,269.83,2.8,82.0,91746.0 +2009-11-02 17:00:00+00:00,28.86,10.06,608.0,941.9,82.0,274.25,3.14,84.0,91722.0 +2009-11-02 18:00:00+00:00,30.07,8.89,719.0,975.76,88.0,276.67,3.63,91.0,91632.0 +2009-11-02 19:00:00+00:00,31.28,7.72,762.0,987.55,89.0,279.08,4.12,98.0,91542.0 +2009-11-02 20:00:00+00:00,32.5,6.55,733.0,976.53,88.0,281.5,4.61,105.0,91452.0 +2009-11-02 21:00:00+00:00,31.66,7.41,637.0,946.75,83.0,281.28,4.12,105.0,91425.0 +2009-11-02 22:00:00+00:00,30.82,8.27,481.0,883.66,74.0,281.07,3.63,104.0,91397.0 +2009-11-02 23:00:00+00:00,29.99,9.13,282.0,751.85,60.0,280.85,3.14,103.0,91370.0 +2009-11-03 00:00:00+00:00,27.4,10.85,73.0,430.78,31.0,279.3,3.04,100.0,91400.0 +2009-11-03 01:00:00+00:00,24.82,12.57,0.0,0.0,0.0,277.75,2.94,96.0,91431.0 +2009-11-03 02:00:00+00:00,22.23,14.29,0.0,0.0,0.0,276.2,2.84,93.0,91461.0 +2009-11-03 03:00:00+00:00,20.81,16.12,0.0,0.0,0.0,275.05,2.66,90.0,91503.0 +2009-11-03 04:00:00+00:00,19.39,17.95,0.0,0.0,0.0,273.9,2.47,88.0,91545.0 +2009-11-03 05:00:00+00:00,17.97,19.78,0.0,0.0,0.0,272.75,2.29,86.0,91587.0 +2009-11-03 06:00:00+00:00,17.12,21.35,0.0,0.0,0.0,271.08,2.29,85.0,91593.0 +2009-11-03 07:00:00+00:00,16.26,22.91,0.0,0.0,0.0,269.42,2.28,83.0,91599.0 +2009-11-03 08:00:00+00:00,15.4,24.48,0.0,0.0,0.0,267.75,2.28,82.0,91605.0 +2009-11-03 09:00:00+00:00,14.68,25.81,0.0,0.0,0.0,266.93,2.25,81.0,91611.0 +2009-11-03 10:00:00+00:00,13.95,27.15,0.0,0.0,0.0,266.12,2.23,80.0,91617.0 +2009-11-03 11:00:00+00:00,13.22,28.48,0.0,0.0,0.0,265.3,2.21,80.0,91623.0 +2009-11-03 12:00:00+00:00,14.26,27.72,0.0,0.0,0.0,266.65,2.11,82.0,91662.0 +2009-11-03 13:00:00+00:00,15.29,26.97,0.0,0.0,0.0,268.0,2.02,84.0,91701.0 +2009-11-03 14:00:00+00:00,16.32,26.21,28.0,218.88,18.0,269.35,1.93,86.0,91740.0 +2009-11-03 15:00:00+00:00,20.54,22.04,219.0,676.1,53.0,276.42,2.2,90.0,91734.0 +2009-11-03 16:00:00+00:00,24.76,17.86,419.0,832.75,70.0,283.48,2.46,94.0,91728.0 +2009-11-03 17:00:00+00:00,28.98,13.69,328.0,128.03,257.0,290.55,2.73,98.0,91722.0 +2009-11-03 18:00:00+00:00,30.04,12.84,525.0,390.54,274.0,295.85,3.08,108.0,91641.0 +2009-11-03 19:00:00+00:00,31.1,11.98,565.0,401.48,293.0,301.15,3.42,119.0,91560.0 +2009-11-03 20:00:00+00:00,32.17,11.13,425.0,159.92,320.0,306.45,3.77,130.0,91479.0 +2009-11-03 21:00:00+00:00,31.42,11.96,402.0,227.04,270.0,309.9,3.39,133.0,91464.0 +2009-11-03 22:00:00+00:00,30.67,12.8,44.0,0.0,44.0,313.35,3.02,136.0,91449.0 +2009-11-03 23:00:00+00:00,29.93,13.63,107.0,10.27,104.0,316.8,2.65,139.0,91434.0 +2009-11-04 00:00:00+00:00,28.29,16.45,27.0,0.0,27.0,322.2,2.62,130.0,91494.0 +2009-11-04 01:00:00+00:00,26.66,19.27,0.0,0.0,0.0,327.6,2.59,122.0,91554.0 +2009-11-04 02:00:00+00:00,25.02,22.09,0.0,0.0,0.0,333.0,2.57,113.0,91614.0 +2009-11-04 03:00:00+00:00,23.63,24.42,0.0,0.0,0.0,330.83,2.46,107.0,91653.0 +2009-11-04 04:00:00+00:00,22.25,26.74,0.0,0.0,0.0,328.67,2.34,100.0,91692.0 +2009-11-04 05:00:00+00:00,20.86,29.07,0.0,0.0,0.0,326.5,2.23,94.0,91731.0 +2009-11-04 06:00:00+00:00,19.81,30.54,0.0,0.0,0.0,319.98,2.19,91.0,91734.0 +2009-11-04 07:00:00+00:00,18.75,32.0,0.0,0.0,0.0,313.47,2.14,87.0,91737.0 +2009-11-04 08:00:00+00:00,17.69,33.47,0.0,0.0,0.0,306.95,2.1,84.0,91740.0 +2009-11-04 09:00:00+00:00,16.63,35.05,0.0,0.0,0.0,298.92,2.12,83.0,91743.0 +2009-11-04 10:00:00+00:00,15.56,36.64,0.0,0.0,0.0,290.88,2.15,83.0,91746.0 +2009-11-04 11:00:00+00:00,14.49,38.22,0.0,0.0,0.0,282.85,2.18,82.0,91749.0 +2009-11-04 12:00:00+00:00,15.15,35.18,0.0,0.0,0.0,279.75,2.03,85.0,91779.0 +2009-11-04 13:00:00+00:00,15.81,32.14,0.0,0.0,0.0,276.65,1.89,88.0,91809.0 +2009-11-04 14:00:00+00:00,16.47,29.1,25.0,0.0,25.0,273.55,1.74,91.0,91839.0 +2009-11-04 15:00:00+00:00,20.55,24.54,214.0,665.18,53.0,278.22,1.9,100.0,91833.0 +2009-11-04 16:00:00+00:00,24.64,19.99,414.0,828.15,70.0,282.88,2.06,110.0,91827.0 +2009-11-04 17:00:00+00:00,28.73,15.43,579.0,906.14,80.0,287.55,2.22,119.0,91821.0 +2009-11-04 18:00:00+00:00,29.69,14.91,690.0,945.61,86.0,290.17,2.31,140.0,91737.0 +2009-11-04 19:00:00+00:00,30.65,14.38,734.0,959.12,88.0,292.78,2.4,160.0,91653.0 +2009-11-04 20:00:00+00:00,31.61,13.86,709.0,952.96,87.0,295.4,2.5,181.0,91569.0 +2009-11-04 21:00:00+00:00,30.99,14.51,615.0,922.68,82.0,294.7,2.29,188.0,91527.0 +2009-11-04 22:00:00+00:00,30.37,15.16,463.0,859.91,73.0,294.0,2.07,196.0,91485.0 +2009-11-04 23:00:00+00:00,29.75,15.81,268.0,727.23,58.0,293.3,1.86,203.0,91443.0 +2009-11-05 00:00:00+00:00,27.89,17.57,66.0,403.13,29.0,291.92,1.94,192.0,91458.0 +2009-11-05 01:00:00+00:00,26.03,19.32,0.0,0.0,0.0,290.53,2.03,180.0,91473.0 +2009-11-05 02:00:00+00:00,24.17,21.08,0.0,0.0,0.0,289.15,2.11,169.0,91488.0 +2009-11-05 03:00:00+00:00,23.3,23.84,0.0,0.0,0.0,288.42,2.01,162.0,91518.0 +2009-11-05 04:00:00+00:00,22.43,26.6,0.0,0.0,0.0,287.68,1.91,155.0,91548.0 +2009-11-05 05:00:00+00:00,21.56,29.36,0.0,0.0,0.0,286.95,1.81,148.0,91578.0 +2009-11-05 06:00:00+00:00,20.41,32.08,0.0,0.0,0.0,285.0,1.71,139.0,91563.0 +2009-11-05 07:00:00+00:00,19.26,34.79,0.0,0.0,0.0,283.05,1.6,130.0,91548.0 +2009-11-05 08:00:00+00:00,18.11,37.51,0.0,0.0,0.0,281.1,1.5,121.0,91533.0 +2009-11-05 09:00:00+00:00,17.03,38.65,0.0,0.0,0.0,279.47,1.57,114.0,91521.0 +2009-11-05 10:00:00+00:00,15.95,39.8,0.0,0.0,0.0,277.83,1.63,107.0,91509.0 +2009-11-05 11:00:00+00:00,14.87,40.94,0.0,0.0,0.0,276.2,1.7,100.0,91497.0 +2009-11-05 12:00:00+00:00,15.66,38.64,0.0,0.0,0.0,275.98,1.65,102.0,91521.0 +2009-11-05 13:00:00+00:00,16.44,36.35,0.0,0.0,0.0,275.77,1.6,104.0,91545.0 +2009-11-05 14:00:00+00:00,17.22,34.05,24.0,0.0,24.0,275.55,1.56,105.0,91569.0 +2009-11-05 15:00:00+00:00,20.49,29.18,210.0,662.33,52.0,282.82,1.58,119.0,91536.0 +2009-11-05 16:00:00+00:00,23.76,24.3,409.0,825.9,69.0,290.08,1.6,133.0,91503.0 +2009-11-05 17:00:00+00:00,27.04,19.43,441.0,413.29,215.0,297.35,1.61,148.0,91470.0 +2009-11-05 18:00:00+00:00,27.98,18.2,438.0,209.51,305.0,304.03,1.91,162.0,91370.0 +2009-11-05 19:00:00+00:00,28.92,16.97,385.0,97.07,320.0,310.72,2.2,176.0,91271.0 +2009-11-05 20:00:00+00:00,29.87,15.74,426.0,169.52,316.0,317.4,2.5,190.0,91172.0 +2009-11-05 21:00:00+00:00,28.95,16.9,433.0,315.33,252.0,319.07,2.27,203.0,91142.0 +2009-11-05 22:00:00+00:00,28.03,18.06,161.0,11.11,156.0,320.73,2.04,217.0,91112.0 +2009-11-05 23:00:00+00:00,27.12,19.22,80.0,0.0,80.0,322.4,1.81,230.0,91082.0 +2009-11-06 00:00:00+00:00,26.15,21.52,26.0,0.0,26.0,319.22,1.52,240.0,91112.0 +2009-11-06 01:00:00+00:00,25.18,23.82,0.0,0.0,0.0,316.03,1.24,249.0,91142.0 +2009-11-06 02:00:00+00:00,24.21,26.12,0.0,0.0,0.0,312.85,0.95,259.0,91172.0 +2009-11-06 03:00:00+00:00,23.56,26.26,0.0,0.0,0.0,312.58,0.76,276.0,91184.0 +2009-11-06 04:00:00+00:00,22.9,26.41,0.0,0.0,0.0,312.32,0.57,293.0,91196.0 +2009-11-06 05:00:00+00:00,22.25,26.55,0.0,0.0,0.0,312.05,0.37,310.0,91208.0 +2009-11-06 06:00:00+00:00,21.41,27.95,0.0,0.0,0.0,312.43,0.53,344.0,91187.0 +2009-11-06 07:00:00+00:00,20.56,29.36,0.0,0.0,0.0,312.82,0.69,18.0,91166.0 +2009-11-06 08:00:00+00:00,19.71,30.76,0.0,0.0,0.0,313.2,0.86,52.0,91145.0 +2009-11-06 09:00:00+00:00,18.99,32.19,0.0,0.0,0.0,311.33,0.94,61.0,91133.0 +2009-11-06 10:00:00+00:00,18.27,33.61,0.0,0.0,0.0,309.47,1.02,70.0,91121.0 +2009-11-06 11:00:00+00:00,17.55,35.04,0.0,0.0,0.0,307.6,1.1,79.0,91109.0 +2009-11-06 12:00:00+00:00,17.52,35.44,0.0,0.0,0.0,304.35,1.09,86.0,91136.0 +2009-11-06 13:00:00+00:00,17.48,35.84,0.0,0.0,0.0,301.1,1.07,93.0,91163.0 +2009-11-06 14:00:00+00:00,17.45,36.24,12.0,0.0,12.0,297.85,1.05,100.0,91190.0 +2009-11-06 15:00:00+00:00,20.31,30.24,205.0,655.15,51.0,298.92,0.82,143.0,91178.0 +2009-11-06 16:00:00+00:00,23.17,24.23,301.0,360.32,154.0,299.98,0.59,186.0,91166.0 +2009-11-06 17:00:00+00:00,26.03,18.23,530.0,795.61,98.0,301.05,0.36,229.0,91154.0 +2009-11-06 18:00:00+00:00,26.95,17.1,558.0,543.67,215.0,300.02,0.88,232.0,91070.0 +2009-11-06 19:00:00+00:00,27.87,15.97,572.0,471.67,258.0,298.98,1.4,234.0,90986.0 +2009-11-06 20:00:00+00:00,28.8,14.84,408.0,145.71,314.0,297.95,1.92,236.0,90902.0 +2009-11-06 21:00:00+00:00,28.42,15.58,472.0,438.28,222.0,298.08,2.11,238.0,90884.0 +2009-11-06 22:00:00+00:00,28.04,16.33,447.0,839.36,72.0,298.22,2.29,239.0,90866.0 +2009-11-06 23:00:00+00:00,27.66,17.07,257.0,707.75,57.0,298.35,2.48,240.0,90848.0 +2009-11-07 00:00:00+00:00,25.21,20.29,60.0,381.88,27.0,294.25,2.34,234.0,90902.0 +2009-11-07 01:00:00+00:00,22.76,23.5,0.0,0.0,0.0,290.15,2.19,228.0,90956.0 +2009-11-07 02:00:00+00:00,20.31,26.72,0.0,0.0,0.0,286.05,2.04,223.0,91010.0 +2009-11-07 03:00:00+00:00,20.05,27.51,0.0,0.0,0.0,286.43,2.02,220.0,91061.0 +2009-11-07 04:00:00+00:00,19.78,28.29,0.0,0.0,0.0,286.82,2.0,218.0,91112.0 +2009-11-07 05:00:00+00:00,19.52,29.08,0.0,0.0,0.0,287.2,1.97,216.0,91163.0 +2009-11-07 06:00:00+00:00,18.16,31.86,0.0,0.0,0.0,286.08,1.87,208.0,91160.0 +2009-11-07 07:00:00+00:00,16.8,34.63,0.0,0.0,0.0,284.97,1.76,200.0,91157.0 +2009-11-07 08:00:00+00:00,15.43,37.41,0.0,0.0,0.0,283.85,1.66,192.0,91154.0 +2009-11-07 09:00:00+00:00,14.75,39.24,0.0,0.0,0.0,282.45,1.58,184.0,91172.0 +2009-11-07 10:00:00+00:00,14.06,41.06,0.0,0.0,0.0,281.05,1.5,175.0,91190.0 +2009-11-07 11:00:00+00:00,13.37,42.89,0.0,0.0,0.0,279.65,1.42,167.0,91208.0 +2009-11-07 12:00:00+00:00,14.05,42.36,0.0,0.0,0.0,279.22,1.34,157.0,91259.0 +2009-11-07 13:00:00+00:00,14.72,41.84,0.0,0.0,0.0,278.78,1.26,148.0,91310.0 +2009-11-07 14:00:00+00:00,15.39,41.31,14.0,0.0,14.0,278.35,1.17,138.0,91361.0 +2009-11-07 15:00:00+00:00,18.45,35.16,201.0,647.75,51.0,283.32,1.23,152.0,91355.0 +2009-11-07 16:00:00+00:00,21.51,29.01,398.0,816.29,68.0,288.28,1.29,167.0,91349.0 +2009-11-07 17:00:00+00:00,24.58,22.86,560.0,894.01,78.0,293.25,1.35,181.0,91343.0 +2009-11-07 18:00:00+00:00,25.48,22.09,668.0,931.4,84.0,294.58,1.69,194.0,91277.0 +2009-11-07 19:00:00+00:00,26.39,21.31,711.0,944.28,86.0,295.92,2.03,207.0,91211.0 +2009-11-07 20:00:00+00:00,27.3,20.54,686.0,937.06,85.0,297.25,2.37,219.0,91145.0 +2009-11-07 21:00:00+00:00,26.93,21.71,594.0,906.71,80.0,296.88,2.33,226.0,91151.0 +2009-11-07 22:00:00+00:00,26.57,22.87,444.0,841.04,71.0,296.52,2.28,234.0,91157.0 +2009-11-07 23:00:00+00:00,26.21,24.04,217.0,507.84,75.0,296.15,2.23,241.0,91163.0 +2009-11-08 00:00:00+00:00,24.46,27.99,34.0,59.62,29.0,295.67,1.97,251.0,91217.0 +2009-11-08 01:00:00+00:00,22.72,31.94,0.0,0.0,0.0,295.18,1.7,261.0,91271.0 +2009-11-08 02:00:00+00:00,20.97,35.89,0.0,0.0,0.0,294.7,1.43,272.0,91325.0 +2009-11-08 03:00:00+00:00,20.14,37.55,0.0,0.0,0.0,293.53,1.37,293.0,91373.0 +2009-11-08 04:00:00+00:00,19.32,39.21,0.0,0.0,0.0,292.37,1.3,315.0,91422.0 +2009-11-08 05:00:00+00:00,18.49,40.87,0.0,0.0,0.0,291.2,1.23,337.0,91470.0 +2009-11-08 06:00:00+00:00,17.54,42.4,0.0,0.0,0.0,289.57,1.39,358.0,91470.0 +2009-11-08 07:00:00+00:00,16.59,43.93,0.0,0.0,0.0,287.93,1.55,19.0,91470.0 +2009-11-08 08:00:00+00:00,15.63,45.46,0.0,0.0,0.0,286.3,1.71,40.0,91470.0 +2009-11-08 09:00:00+00:00,14.92,47.06,0.0,0.0,0.0,284.63,1.71,50.0,91488.0 +2009-11-08 10:00:00+00:00,14.21,48.67,0.0,0.0,0.0,282.97,1.7,60.0,91506.0 +2009-11-08 11:00:00+00:00,13.5,50.27,0.0,0.0,0.0,281.3,1.7,69.0,91524.0 +2009-11-08 12:00:00+00:00,14.09,49.9,0.0,0.0,0.0,280.05,1.53,70.0,91599.0 +2009-11-08 13:00:00+00:00,14.68,49.52,0.0,0.0,0.0,278.8,1.37,71.0,91674.0 +2009-11-08 14:00:00+00:00,15.27,49.15,13.0,0.0,13.0,277.55,1.2,73.0,91749.0 +2009-11-08 15:00:00+00:00,18.69,41.11,199.0,648.88,51.0,282.25,1.4,69.0,91746.0 +2009-11-08 16:00:00+00:00,22.12,33.07,398.0,823.81,68.0,286.95,1.6,65.0,91743.0 +2009-11-08 17:00:00+00:00,25.55,25.03,561.0,902.24,78.0,291.65,1.79,62.0,91740.0 +2009-11-08 18:00:00+00:00,26.52,23.06,670.0,940.37,84.0,293.75,1.98,75.0,91659.0 +2009-11-08 19:00:00+00:00,27.5,21.09,714.0,954.3,86.0,295.85,2.17,88.0,91578.0 +2009-11-08 20:00:00+00:00,28.48,19.12,688.0,945.59,85.0,297.95,2.36,102.0,91497.0 +2009-11-08 21:00:00+00:00,28.07,19.23,596.0,915.84,80.0,297.18,2.33,103.0,91473.0 +2009-11-08 22:00:00+00:00,27.67,19.33,302.0,265.73,185.0,296.42,2.3,105.0,91449.0 +2009-11-08 23:00:00+00:00,27.27,19.44,171.0,227.66,108.0,295.65,2.28,106.0,91425.0 +2009-11-09 00:00:00+00:00,25.2,22.0,56.0,356.24,27.0,294.48,2.45,103.0,91461.0 +2009-11-09 01:00:00+00:00,23.13,24.56,0.0,0.0,0.0,293.32,2.63,99.0,91497.0 +2009-11-09 02:00:00+00:00,21.06,27.12,0.0,0.0,0.0,292.15,2.8,96.0,91533.0 +2009-11-09 03:00:00+00:00,19.82,28.96,0.0,0.0,0.0,290.55,2.82,96.0,91551.0 +2009-11-09 04:00:00+00:00,18.58,30.81,0.0,0.0,0.0,288.95,2.84,96.0,91569.0 +2009-11-09 05:00:00+00:00,17.34,32.65,0.0,0.0,0.0,287.35,2.86,96.0,91587.0 +2009-11-09 06:00:00+00:00,16.74,33.8,0.0,0.0,0.0,285.07,2.81,93.0,91593.0 +2009-11-09 07:00:00+00:00,16.14,34.96,0.0,0.0,0.0,282.78,2.77,90.0,91599.0 +2009-11-09 08:00:00+00:00,15.54,36.11,0.0,0.0,0.0,280.5,2.73,88.0,91605.0 +2009-11-09 09:00:00+00:00,15.09,36.81,0.0,0.0,0.0,279.65,2.71,85.0,91629.0 +2009-11-09 10:00:00+00:00,14.63,37.51,0.0,0.0,0.0,278.8,2.69,82.0,91653.0 +2009-11-09 11:00:00+00:00,14.17,38.21,0.0,0.0,0.0,277.95,2.66,80.0,91677.0 +2009-11-09 12:00:00+00:00,14.7,37.6,0.0,0.0,0.0,277.23,2.54,81.0,91725.0 +2009-11-09 13:00:00+00:00,15.23,37.0,0.0,0.0,0.0,276.52,2.41,82.0,91773.0 +2009-11-09 14:00:00+00:00,15.76,36.39,13.0,0.0,13.0,275.8,2.29,82.0,91821.0 +2009-11-09 15:00:00+00:00,19.7,29.48,195.0,645.58,50.0,280.65,2.8,89.0,91809.0 +2009-11-09 16:00:00+00:00,23.64,22.56,391.0,813.8,68.0,285.5,3.3,96.0,91797.0 +2009-11-09 17:00:00+00:00,27.59,15.65,551.0,889.87,78.0,290.35,3.81,103.0,91785.0 +2009-11-09 18:00:00+00:00,28.54,14.82,657.0,926.8,83.0,292.55,4.02,108.0,91701.0 +2009-11-09 19:00:00+00:00,29.5,13.99,699.0,938.39,85.0,294.75,4.24,112.0,91617.0 +2009-11-09 20:00:00+00:00,30.46,13.16,559.0,536.21,219.0,296.95,4.46,117.0,91533.0 +2009-11-09 21:00:00+00:00,29.83,14.63,483.0,524.98,189.0,296.88,4.06,117.0,91512.0 +2009-11-09 22:00:00+00:00,29.2,16.1,434.0,832.6,70.0,296.82,3.66,116.0,91491.0 +2009-11-09 23:00:00+00:00,28.57,17.57,246.0,697.24,55.0,296.75,3.26,116.0,91470.0 +2009-11-10 00:00:00+00:00,26.59,19.32,53.0,341.61,26.0,296.07,3.28,111.0,91497.0 +2009-11-10 01:00:00+00:00,24.62,21.07,0.0,0.0,0.0,295.38,3.31,107.0,91524.0 +2009-11-10 02:00:00+00:00,22.64,22.82,0.0,0.0,0.0,294.7,3.34,103.0,91551.0 +2009-11-10 03:00:00+00:00,21.65,24.65,0.0,0.0,0.0,293.73,3.09,99.0,91593.0 +2009-11-10 04:00:00+00:00,20.67,26.49,0.0,0.0,0.0,292.77,2.85,94.0,91635.0 +2009-11-10 05:00:00+00:00,19.68,28.32,0.0,0.0,0.0,291.8,2.61,89.0,91677.0 +2009-11-10 06:00:00+00:00,18.82,30.45,0.0,0.0,0.0,289.95,2.55,85.0,91683.0 +2009-11-10 07:00:00+00:00,17.96,32.58,0.0,0.0,0.0,288.1,2.49,81.0,91689.0 +2009-11-10 08:00:00+00:00,17.1,34.71,0.0,0.0,0.0,286.25,2.43,76.0,91695.0 +2009-11-10 09:00:00+00:00,16.38,36.45,0.0,0.0,0.0,284.73,2.41,77.0,91701.0 +2009-11-10 10:00:00+00:00,15.65,38.18,0.0,0.0,0.0,283.22,2.4,78.0,91707.0 +2009-11-10 11:00:00+00:00,14.92,39.92,0.0,0.0,0.0,281.7,2.39,78.0,91713.0 +2009-11-10 12:00:00+00:00,15.35,39.16,0.0,0.0,0.0,280.53,2.3,81.0,91719.0 +2009-11-10 13:00:00+00:00,15.77,38.39,0.0,0.0,0.0,279.37,2.22,83.0,91725.0 +2009-11-10 14:00:00+00:00,16.19,37.63,12.0,0.0,12.0,278.2,2.14,86.0,91731.0 +2009-11-10 15:00:00+00:00,19.77,32.38,189.0,633.11,49.0,283.02,2.33,91.0,91713.0 +2009-11-10 16:00:00+00:00,23.35,27.12,383.0,803.58,67.0,287.83,2.52,96.0,91695.0 +2009-11-10 17:00:00+00:00,26.93,21.87,543.0,882.96,77.0,292.65,2.72,102.0,91677.0 +2009-11-10 18:00:00+00:00,27.99,20.69,650.0,921.13,83.0,295.85,2.76,119.0,91575.0 +2009-11-10 19:00:00+00:00,29.05,19.5,576.0,533.36,229.0,299.05,2.8,136.0,91473.0 +2009-11-10 20:00:00+00:00,30.11,18.32,666.0,924.63,83.0,302.25,2.84,154.0,91370.0 +2009-11-10 21:00:00+00:00,29.45,19.43,424.0,330.52,240.0,303.65,2.58,163.0,91337.0 +2009-11-10 22:00:00+00:00,28.79,20.53,349.0,465.28,147.0,305.05,2.32,172.0,91304.0 +2009-11-10 23:00:00+00:00,28.13,21.64,196.0,412.94,84.0,306.45,2.06,181.0,91271.0 +2009-11-11 00:00:00+00:00,26.23,23.74,33.0,78.16,27.0,307.42,2.2,178.0,91274.0 +2009-11-11 01:00:00+00:00,24.32,25.85,0.0,0.0,0.0,308.38,2.35,176.0,91277.0 +2009-11-11 02:00:00+00:00,22.42,27.95,0.0,0.0,0.0,309.35,2.5,173.0,91280.0 +2009-11-11 03:00:00+00:00,21.61,30.88,0.0,0.0,0.0,307.23,2.45,177.0,91295.0 +2009-11-11 04:00:00+00:00,20.79,33.82,0.0,0.0,0.0,305.12,2.4,181.0,91310.0 +2009-11-11 05:00:00+00:00,19.98,36.75,0.0,0.0,0.0,303.0,2.34,186.0,91325.0 +2009-11-11 06:00:00+00:00,19.36,38.74,0.0,0.0,0.0,300.27,2.12,188.0,91313.0 +2009-11-11 07:00:00+00:00,18.74,40.73,0.0,0.0,0.0,297.53,1.89,191.0,91301.0 +2009-11-11 08:00:00+00:00,18.11,42.72,0.0,0.0,0.0,294.8,1.67,194.0,91289.0 +2009-11-11 09:00:00+00:00,17.46,44.46,0.0,0.0,0.0,293.5,1.71,185.0,91265.0 +2009-11-11 10:00:00+00:00,16.8,46.21,0.0,0.0,0.0,292.2,1.75,177.0,91241.0 +2009-11-11 11:00:00+00:00,16.14,47.95,0.0,0.0,0.0,290.9,1.79,168.0,91217.0 +2009-11-11 12:00:00+00:00,17.04,47.62,0.0,0.0,0.0,293.98,1.93,173.0,91217.0 +2009-11-11 13:00:00+00:00,17.94,47.29,0.0,0.0,0.0,297.07,2.07,178.0,91217.0 +2009-11-11 14:00:00+00:00,18.84,46.96,13.0,0.0,13.0,300.15,2.21,183.0,91217.0 +2009-11-11 15:00:00+00:00,21.11,41.47,186.0,629.41,49.0,304.3,3.07,192.0,91181.0 +2009-11-11 16:00:00+00:00,23.38,35.99,305.0,446.62,131.0,308.45,3.94,201.0,91145.0 +2009-11-11 17:00:00+00:00,25.66,30.5,454.0,549.59,166.0,312.6,4.8,210.0,91109.0 +2009-11-11 18:00:00+00:00,26.27,29.51,519.0,460.93,237.0,313.75,5.53,213.0,91007.0 +2009-11-11 19:00:00+00:00,26.89,28.51,498.0,307.61,299.0,314.9,6.26,216.0,90905.0 +2009-11-11 20:00:00+00:00,27.51,27.52,520.0,413.06,261.0,316.05,6.99,218.0,90803.0 +2009-11-11 21:00:00+00:00,26.76,29.29,454.0,430.04,216.0,319.3,6.61,220.0,90794.0 +2009-11-11 22:00:00+00:00,26.01,31.07,323.0,366.43,165.0,322.55,6.22,221.0,90785.0 +2009-11-11 23:00:00+00:00,25.26,32.84,97.0,7.45,95.0,325.8,5.83,223.0,90776.0 +2009-11-12 00:00:00+00:00,24.16,34.72,21.0,0.0,21.0,322.07,5.31,218.0,90782.0 +2009-11-12 01:00:00+00:00,23.07,36.6,0.0,0.0,0.0,318.33,4.79,213.0,90788.0 +2009-11-12 02:00:00+00:00,21.97,38.48,0.0,0.0,0.0,314.6,4.26,208.0,90794.0 +2009-11-12 03:00:00+00:00,21.16,40.87,0.0,0.0,0.0,314.38,4.22,206.0,90800.0 +2009-11-12 04:00:00+00:00,20.36,43.26,0.0,0.0,0.0,314.17,4.18,204.0,90806.0 +2009-11-12 05:00:00+00:00,19.55,45.65,0.0,0.0,0.0,313.95,4.14,201.0,90812.0 +2009-11-12 06:00:00+00:00,19.0,48.7,0.0,0.0,0.0,313.38,4.25,203.0,90806.0 +2009-11-12 07:00:00+00:00,18.44,51.76,0.0,0.0,0.0,312.82,4.36,205.0,90800.0 +2009-11-12 08:00:00+00:00,17.88,54.81,0.0,0.0,0.0,312.25,4.47,207.0,90794.0 +2009-11-12 09:00:00+00:00,17.2,59.29,0.0,0.0,0.0,310.35,4.4,210.0,90812.0 +2009-11-12 10:00:00+00:00,16.51,63.76,0.0,0.0,0.0,308.45,4.34,213.0,90830.0 +2009-11-12 11:00:00+00:00,15.82,68.24,0.0,0.0,0.0,306.55,4.28,216.0,90848.0 +2009-11-12 12:00:00+00:00,16.0,69.83,0.0,0.0,0.0,321.57,4.35,215.0,90854.0 +2009-11-12 13:00:00+00:00,16.17,71.41,0.0,0.0,0.0,336.58,4.43,214.0,90860.0 +2009-11-12 14:00:00+00:00,16.35,73.0,0.0,0.0,0.0,351.6,4.51,213.0,90866.0 +2009-11-12 15:00:00+00:00,16.91,66.59,62.0,0.0,62.0,352.55,5.19,215.0,90890.0 +2009-11-12 16:00:00+00:00,17.48,60.19,169.0,38.86,154.0,353.5,5.86,217.0,90914.0 +2009-11-12 17:00:00+00:00,18.05,53.78,436.0,472.79,190.0,354.45,6.54,220.0,90938.0 +2009-11-12 18:00:00+00:00,18.82,49.81,636.0,912.69,81.0,346.32,6.64,221.0,90881.0 +2009-11-12 19:00:00+00:00,19.59,45.83,497.0,318.66,292.0,338.18,6.74,223.0,90824.0 +2009-11-12 20:00:00+00:00,20.37,41.86,68.0,0.0,68.0,330.05,6.84,224.0,90767.0 +2009-11-12 21:00:00+00:00,19.96,44.45,59.0,0.0,59.0,324.77,6.37,226.0,90767.0 +2009-11-12 22:00:00+00:00,19.55,47.04,14.0,0.0,14.0,319.48,5.89,228.0,90767.0 +2009-11-12 23:00:00+00:00,19.14,49.63,8.0,0.0,8.0,314.2,5.42,229.0,90767.0 +2009-11-13 00:00:00+00:00,18.47,52.69,47.0,317.29,24.0,314.68,4.9,229.0,90833.0 +2009-11-13 01:00:00+00:00,17.81,55.76,0.0,0.0,0.0,315.17,4.38,229.0,90899.0 +2009-11-13 02:00:00+00:00,17.14,58.82,0.0,0.0,0.0,315.65,3.86,229.0,90965.0 +2009-11-13 03:00:00+00:00,16.41,63.51,0.0,0.0,0.0,312.23,3.42,229.0,91004.0 +2009-11-13 04:00:00+00:00,15.69,68.2,0.0,0.0,0.0,308.82,2.97,229.0,91043.0 +2009-11-13 05:00:00+00:00,14.96,72.89,0.0,0.0,0.0,305.4,2.52,229.0,91082.0 +2009-11-13 06:00:00+00:00,14.46,77.27,0.0,0.0,0.0,301.57,2.32,230.0,91088.0 +2009-11-13 07:00:00+00:00,13.95,81.64,0.0,0.0,0.0,297.73,2.11,232.0,91094.0 +2009-11-13 08:00:00+00:00,13.44,86.02,0.0,0.0,0.0,293.9,1.9,233.0,91100.0 +2009-11-13 09:00:00+00:00,13.05,88.63,0.0,0.0,0.0,294.57,1.8,228.0,91124.0 +2009-11-13 10:00:00+00:00,12.66,91.25,0.0,0.0,0.0,295.23,1.69,224.0,91148.0 +2009-11-13 11:00:00+00:00,12.27,93.86,0.0,0.0,0.0,295.9,1.59,219.0,91172.0 +2009-11-13 12:00:00+00:00,12.38,88.65,0.0,0.0,0.0,292.15,1.56,218.0,91220.0 +2009-11-13 13:00:00+00:00,12.48,83.45,0.0,0.0,0.0,288.4,1.54,216.0,91268.0 +2009-11-13 14:00:00+00:00,12.58,78.24,0.0,0.0,0.0,284.65,1.52,215.0,91316.0 +2009-11-13 15:00:00+00:00,13.66,71.32,28.0,0.0,28.0,292.2,2.74,220.0,91343.0 +2009-11-13 16:00:00+00:00,14.75,64.39,118.0,0.0,118.0,299.75,3.96,224.0,91370.0 +2009-11-13 17:00:00+00:00,15.84,57.47,277.0,87.1,232.0,307.3,5.19,229.0,91397.0 +2009-11-13 18:00:00+00:00,16.63,53.7,252.0,26.47,236.0,312.35,5.39,235.0,91352.0 +2009-11-13 19:00:00+00:00,17.42,49.93,359.0,89.1,302.0,317.4,5.59,240.0,91307.0 +2009-11-13 20:00:00+00:00,18.21,46.16,485.0,335.37,277.0,322.45,5.79,245.0,91262.0 +2009-11-13 21:00:00+00:00,17.98,46.05,443.0,409.4,219.0,320.55,5.37,250.0,91265.0 +2009-11-13 22:00:00+00:00,17.76,45.93,330.0,413.62,154.0,318.65,4.95,255.0,91268.0 +2009-11-13 23:00:00+00:00,17.54,45.82,236.0,690.39,54.0,316.75,4.52,260.0,91271.0 +2009-11-14 00:00:00+00:00,16.83,50.49,46.0,326.28,23.0,317.83,3.66,267.0,91316.0 +2009-11-14 01:00:00+00:00,16.13,55.17,0.0,0.0,0.0,318.92,2.8,274.0,91361.0 +2009-11-14 02:00:00+00:00,15.42,59.84,0.0,0.0,0.0,320.0,1.93,281.0,91406.0 +2009-11-14 03:00:00+00:00,14.45,61.73,0.0,0.0,0.0,312.43,1.78,284.0,91464.0 +2009-11-14 04:00:00+00:00,13.47,63.61,0.0,0.0,0.0,304.87,1.63,287.0,91521.0 +2009-11-14 05:00:00+00:00,12.5,65.5,0.0,0.0,0.0,297.3,1.48,290.0,91578.0 +2009-11-14 06:00:00+00:00,11.82,66.15,0.0,0.0,0.0,288.12,1.56,302.0,91590.0 +2009-11-14 07:00:00+00:00,11.14,66.81,0.0,0.0,0.0,278.93,1.65,314.0,91602.0 +2009-11-14 08:00:00+00:00,10.45,67.46,0.0,0.0,0.0,269.75,1.74,326.0,91614.0 +2009-11-14 09:00:00+00:00,9.95,67.03,0.0,0.0,0.0,265.67,1.7,331.0,91638.0 +2009-11-14 10:00:00+00:00,9.45,66.59,0.0,0.0,0.0,261.58,1.66,337.0,91662.0 +2009-11-14 11:00:00+00:00,8.94,66.16,0.0,0.0,0.0,257.5,1.63,342.0,91686.0 +2009-11-14 12:00:00+00:00,9.32,65.76,0.0,0.0,0.0,257.58,1.33,346.0,91740.0 +2009-11-14 13:00:00+00:00,9.7,65.37,0.0,0.0,0.0,257.67,1.04,349.0,91794.0 +2009-11-14 14:00:00+00:00,10.08,64.97,0.0,0.0,0.0,257.75,0.74,352.0,91848.0 +2009-11-14 15:00:00+00:00,12.31,53.11,184.0,655.93,48.0,259.63,1.14,344.0,91857.0 +2009-11-14 16:00:00+00:00,14.54,41.24,384.0,839.54,66.0,261.52,1.54,336.0,91866.0 +2009-11-14 17:00:00+00:00,16.77,29.38,550.0,922.06,77.0,263.4,1.93,328.0,91875.0 +2009-11-14 18:00:00+00:00,17.87,25.35,661.0,962.05,83.0,263.43,2.49,328.0,91806.0 +2009-11-14 19:00:00+00:00,18.97,21.32,708.0,979.18,85.0,263.47,3.05,328.0,91737.0 +2009-11-14 20:00:00+00:00,20.08,17.29,685.0,974.2,84.0,263.5,3.61,329.0,91668.0 +2009-11-14 21:00:00+00:00,19.69,16.98,594.0,946.49,79.0,261.42,3.38,336.0,91674.0 +2009-11-14 22:00:00+00:00,19.3,16.66,444.0,884.56,70.0,259.33,3.14,343.0,91680.0 +2009-11-14 23:00:00+00:00,18.91,16.35,250.0,746.37,55.0,257.25,2.91,351.0,91686.0 +2009-11-15 00:00:00+00:00,16.97,19.45,49.0,364.48,24.0,253.28,2.71,5.0,91761.0 +2009-11-15 01:00:00+00:00,15.03,22.54,0.0,0.0,0.0,249.32,2.51,20.0,91836.0 +2009-11-15 02:00:00+00:00,13.09,25.64,0.0,0.0,0.0,245.35,2.32,34.0,91911.0 +2009-11-15 03:00:00+00:00,12.06,26.87,0.0,0.0,0.0,243.03,2.34,43.0,91935.0 +2009-11-15 04:00:00+00:00,11.02,28.1,0.0,0.0,0.0,240.72,2.36,53.0,91959.0 +2009-11-15 05:00:00+00:00,9.99,29.33,0.0,0.0,0.0,238.4,2.39,62.0,91983.0 +2009-11-15 06:00:00+00:00,9.33,30.99,0.0,0.0,0.0,236.63,2.49,64.0,91992.0 +2009-11-15 07:00:00+00:00,8.67,32.64,0.0,0.0,0.0,234.87,2.59,66.0,92001.0 +2009-11-15 08:00:00+00:00,8.01,34.3,0.0,0.0,0.0,233.1,2.69,68.0,92010.0 +2009-11-15 09:00:00+00:00,7.41,35.81,0.0,0.0,0.0,231.93,2.74,68.0,92025.0 +2009-11-15 10:00:00+00:00,6.81,37.31,0.0,0.0,0.0,230.77,2.8,68.0,92040.0 +2009-11-15 11:00:00+00:00,6.21,38.82,0.0,0.0,0.0,229.6,2.86,69.0,92055.0 +2009-11-15 12:00:00+00:00,6.67,38.62,0.0,0.0,0.0,228.78,2.72,71.0,92094.0 +2009-11-15 13:00:00+00:00,7.12,38.43,0.0,0.0,0.0,227.97,2.58,73.0,92133.0 +2009-11-15 14:00:00+00:00,7.58,38.23,0.0,0.0,0.0,227.15,2.44,75.0,92172.0 +2009-11-15 15:00:00+00:00,11.06,31.21,190.0,691.41,49.0,230.75,2.77,77.0,92136.0 +2009-11-15 16:00:00+00:00,14.54,24.2,394.0,871.49,67.0,234.35,3.09,78.0,92100.0 +2009-11-15 17:00:00+00:00,18.02,17.18,561.0,950.2,77.0,237.95,3.42,79.0,92064.0 +2009-11-15 18:00:00+00:00,19.52,15.12,673.0,987.91,83.0,240.22,3.6,81.0,91953.0 +2009-11-15 19:00:00+00:00,21.02,13.05,718.0,1000.32,85.0,242.48,3.77,82.0,91842.0 +2009-11-15 20:00:00+00:00,22.53,10.99,692.0,990.75,84.0,244.75,3.94,84.0,91731.0 +2009-11-15 21:00:00+00:00,21.95,11.31,598.0,959.05,79.0,245.42,3.72,84.0,91701.0 +2009-11-15 22:00:00+00:00,21.37,11.63,445.0,892.46,70.0,246.08,3.5,85.0,91671.0 +2009-11-15 23:00:00+00:00,20.8,11.95,250.0,752.89,55.0,246.75,3.28,86.0,91641.0 +2009-11-16 00:00:00+00:00,18.61,14.19,48.0,359.37,24.0,244.98,3.04,82.0,91671.0 +2009-11-16 01:00:00+00:00,16.42,16.43,0.0,0.0,0.0,243.22,2.8,79.0,91701.0 +2009-11-16 02:00:00+00:00,14.23,18.67,0.0,0.0,0.0,241.45,2.57,76.0,91731.0 +2009-11-16 03:00:00+00:00,13.06,20.53,0.0,0.0,0.0,240.33,2.58,76.0,91758.0 +2009-11-16 04:00:00+00:00,11.88,22.4,0.0,0.0,0.0,239.22,2.59,76.0,91785.0 +2009-11-16 05:00:00+00:00,10.71,24.26,0.0,0.0,0.0,238.1,2.61,76.0,91812.0 +2009-11-16 06:00:00+00:00,10.06,25.81,0.0,0.0,0.0,238.35,2.61,76.0,91815.0 +2009-11-16 07:00:00+00:00,9.4,27.36,0.0,0.0,0.0,238.6,2.62,76.0,91818.0 +2009-11-16 08:00:00+00:00,8.74,28.91,0.0,0.0,0.0,238.85,2.62,76.0,91821.0 +2009-11-16 09:00:00+00:00,8.09,30.07,0.0,0.0,0.0,239.28,2.62,76.0,91812.0 +2009-11-16 10:00:00+00:00,7.44,31.23,0.0,0.0,0.0,239.72,2.61,76.0,91803.0 +2009-11-16 11:00:00+00:00,6.79,32.39,0.0,0.0,0.0,240.15,2.61,75.0,91794.0 +2009-11-16 12:00:00+00:00,7.32,31.85,0.0,0.0,0.0,240.13,2.5,77.0,91800.0 +2009-11-16 13:00:00+00:00,7.85,31.32,0.0,0.0,0.0,240.12,2.4,79.0,91806.0 +2009-11-16 14:00:00+00:00,8.38,30.78,0.0,0.0,0.0,240.1,2.29,80.0,91812.0 +2009-11-16 15:00:00+00:00,12.17,25.28,181.0,668.2,47.0,243.87,2.49,83.0,91782.0 +2009-11-16 16:00:00+00:00,15.97,19.77,382.0,850.17,66.0,247.63,2.69,85.0,91752.0 +2009-11-16 17:00:00+00:00,19.77,14.27,547.0,931.22,76.0,251.4,2.9,87.0,91722.0 +2009-11-16 18:00:00+00:00,21.35,12.87,657.0,968.52,82.0,254.03,2.79,91.0,91599.0 +2009-11-16 19:00:00+00:00,22.93,11.46,701.0,980.28,84.0,256.67,2.68,95.0,91476.0 +2009-11-16 20:00:00+00:00,24.51,10.06,676.0,971.31,83.0,259.3,2.57,98.0,91352.0 +2009-11-16 21:00:00+00:00,23.96,10.96,584.0,940.02,78.0,259.93,2.38,99.0,91319.0 +2009-11-16 22:00:00+00:00,23.41,11.85,433.0,871.53,69.0,260.57,2.19,101.0,91286.0 +2009-11-16 23:00:00+00:00,22.86,12.75,241.0,728.1,54.0,261.2,2.0,102.0,91253.0 +2009-11-17 00:00:00+00:00,20.72,15.23,45.0,338.08,23.0,260.02,2.13,100.0,91277.0 +2009-11-17 01:00:00+00:00,18.57,17.72,0.0,0.0,0.0,258.83,2.26,98.0,91301.0 +2009-11-17 02:00:00+00:00,16.43,20.2,0.0,0.0,0.0,257.65,2.39,96.0,91325.0 +2009-11-17 03:00:00+00:00,14.99,23.0,0.0,0.0,0.0,257.0,2.33,95.0,91343.0 +2009-11-17 04:00:00+00:00,13.54,25.79,0.0,0.0,0.0,256.35,2.28,94.0,91361.0 +2009-11-17 05:00:00+00:00,12.1,28.59,0.0,0.0,0.0,255.7,2.22,93.0,91379.0 +2009-11-17 06:00:00+00:00,11.3,30.57,0.0,0.0,0.0,254.47,2.14,93.0,91373.0 +2009-11-17 07:00:00+00:00,10.5,32.56,0.0,0.0,0.0,253.23,2.06,93.0,91367.0 +2009-11-17 08:00:00+00:00,9.69,34.54,0.0,0.0,0.0,252.0,1.97,93.0,91361.0 +2009-11-17 09:00:00+00:00,9.13,35.92,0.0,0.0,0.0,251.05,1.96,94.0,91355.0 +2009-11-17 10:00:00+00:00,8.56,37.31,0.0,0.0,0.0,250.1,1.94,96.0,91349.0 +2009-11-17 11:00:00+00:00,7.99,38.69,0.0,0.0,0.0,249.15,1.93,98.0,91343.0 +2009-11-17 12:00:00+00:00,9.16,37.74,0.0,0.0,0.0,250.5,1.96,104.0,91367.0 +2009-11-17 13:00:00+00:00,10.32,36.78,0.0,0.0,0.0,251.85,2.0,111.0,91391.0 +2009-11-17 14:00:00+00:00,11.48,35.83,0.0,0.0,0.0,253.2,2.03,117.0,91416.0 +2009-11-17 15:00:00+00:00,15.06,29.66,172.0,639.04,46.0,258.83,2.2,139.0,91406.0 +2009-11-17 16:00:00+00:00,18.64,23.48,309.0,567.64,100.0,264.47,2.38,161.0,91397.0 +2009-11-17 17:00:00+00:00,22.22,17.31,420.0,481.83,178.0,270.1,2.55,183.0,91388.0 +2009-11-17 18:00:00+00:00,23.03,16.32,502.0,469.32,225.0,272.52,3.03,197.0,91292.0 +2009-11-17 19:00:00+00:00,23.84,15.34,684.0,959.93,83.0,274.93,3.52,211.0,91196.0 +2009-11-17 20:00:00+00:00,24.65,14.35,660.0,953.2,81.0,277.35,4.0,224.0,91100.0 +2009-11-17 21:00:00+00:00,24.0,14.83,286.0,84.03,241.0,277.65,3.69,228.0,91091.0 +2009-11-17 22:00:00+00:00,23.36,15.3,421.0,850.17,68.0,277.95,3.37,231.0,91082.0 +2009-11-17 23:00:00+00:00,22.72,15.78,233.0,706.56,53.0,278.25,3.06,234.0,91073.0 +2009-11-18 00:00:00+00:00,20.71,18.47,42.0,315.17,22.0,278.48,2.87,230.0,91109.0 +2009-11-18 01:00:00+00:00,18.7,21.17,0.0,0.0,0.0,278.72,2.68,226.0,91145.0 +2009-11-18 02:00:00+00:00,16.69,23.86,0.0,0.0,0.0,278.95,2.48,222.0,91181.0 +2009-11-18 03:00:00+00:00,15.96,24.01,0.0,0.0,0.0,278.7,2.38,214.0,91214.0 +2009-11-18 04:00:00+00:00,15.22,24.16,0.0,0.0,0.0,278.45,2.27,207.0,91247.0 +2009-11-18 05:00:00+00:00,14.49,24.31,0.0,0.0,0.0,278.2,2.17,199.0,91280.0 +2009-11-18 06:00:00+00:00,13.55,27.46,0.0,0.0,0.0,277.13,2.1,193.0,91295.0 +2009-11-18 07:00:00+00:00,12.61,30.6,0.0,0.0,0.0,276.07,2.04,188.0,91310.0 +2009-11-18 08:00:00+00:00,11.66,33.75,0.0,0.0,0.0,275.0,1.97,182.0,91325.0 +2009-11-18 09:00:00+00:00,11.13,36.12,0.0,0.0,0.0,275.1,1.82,177.0,91340.0 +2009-11-18 10:00:00+00:00,10.6,38.49,0.0,0.0,0.0,275.2,1.66,171.0,91355.0 +2009-11-18 11:00:00+00:00,10.07,40.86,0.0,0.0,0.0,275.3,1.5,166.0,91370.0 +2009-11-18 12:00:00+00:00,10.21,41.65,0.0,0.0,0.0,278.32,1.43,153.0,91410.0 +2009-11-18 13:00:00+00:00,10.34,42.45,0.0,0.0,0.0,281.33,1.37,139.0,91449.0 +2009-11-18 14:00:00+00:00,10.48,43.24,0.0,0.0,0.0,284.35,1.3,125.0,91488.0 +2009-11-18 15:00:00+00:00,13.48,34.42,168.0,629.44,46.0,289.22,1.09,131.0,91503.0 +2009-11-18 16:00:00+00:00,16.49,25.6,364.0,822.54,64.0,294.08,0.89,136.0,91518.0 +2009-11-18 17:00:00+00:00,19.5,16.78,526.0,906.25,74.0,298.95,0.69,142.0,91533.0 +2009-11-18 18:00:00+00:00,20.36,17.26,636.0,947.53,80.0,298.03,0.86,94.0,91461.0 +2009-11-18 19:00:00+00:00,21.22,17.73,681.0,961.74,82.0,297.12,1.03,46.0,91388.0 +2009-11-18 20:00:00+00:00,22.08,18.21,658.0,954.65,81.0,296.2,1.2,359.0,91316.0 +2009-11-18 21:00:00+00:00,21.85,18.26,568.0,921.56,77.0,292.13,1.39,357.0,91331.0 +2009-11-18 22:00:00+00:00,21.63,18.31,421.0,855.02,68.0,288.07,1.59,356.0,91346.0 +2009-11-18 23:00:00+00:00,21.41,18.36,232.0,708.14,53.0,284.0,1.78,354.0,91361.0 +2009-11-19 00:00:00+00:00,19.74,20.78,42.0,322.89,22.0,280.5,1.69,349.0,91428.0 +2009-11-19 01:00:00+00:00,18.07,23.21,0.0,0.0,0.0,277.0,1.6,344.0,91494.0 +2009-11-19 02:00:00+00:00,16.4,25.63,0.0,0.0,0.0,273.5,1.5,338.0,91560.0 +2009-11-19 03:00:00+00:00,15.33,25.36,0.0,0.0,0.0,272.27,1.52,344.0,91602.0 +2009-11-19 04:00:00+00:00,14.25,25.1,0.0,0.0,0.0,271.03,1.54,350.0,91644.0 +2009-11-19 05:00:00+00:00,13.18,24.83,0.0,0.0,0.0,269.8,1.56,356.0,91686.0 +2009-11-19 06:00:00+00:00,12.53,27.06,0.0,0.0,0.0,267.53,1.59,8.0,91692.0 +2009-11-19 07:00:00+00:00,11.88,29.29,0.0,0.0,0.0,265.27,1.62,20.0,91698.0 +2009-11-19 08:00:00+00:00,11.23,31.52,0.0,0.0,0.0,263.0,1.66,32.0,91704.0 +2009-11-19 09:00:00+00:00,10.51,32.95,0.0,0.0,0.0,260.35,1.65,44.0,91713.0 +2009-11-19 10:00:00+00:00,9.78,34.37,0.0,0.0,0.0,257.7,1.65,55.0,91722.0 +2009-11-19 11:00:00+00:00,9.05,35.8,0.0,0.0,0.0,255.05,1.64,67.0,91731.0 +2009-11-19 12:00:00+00:00,9.35,36.57,0.0,0.0,0.0,253.25,1.64,73.0,91770.0 +2009-11-19 13:00:00+00:00,9.64,37.34,0.0,0.0,0.0,251.45,1.64,78.0,91809.0 +2009-11-19 14:00:00+00:00,9.93,38.11,0.0,0.0,0.0,249.65,1.64,84.0,91848.0 +2009-11-19 15:00:00+00:00,13.77,30.28,171.0,656.16,46.0,252.78,1.77,86.0,91842.0 +2009-11-19 16:00:00+00:00,17.62,22.44,371.0,849.73,64.0,255.92,1.89,88.0,91836.0 +2009-11-19 17:00:00+00:00,21.47,14.61,536.0,930.74,75.0,259.05,2.01,89.0,91830.0 +2009-11-19 18:00:00+00:00,22.49,13.55,647.0,970.14,81.0,260.0,2.23,98.0,91737.0 +2009-11-19 19:00:00+00:00,23.51,12.48,693.0,984.45,83.0,260.95,2.44,107.0,91644.0 +2009-11-19 20:00:00+00:00,24.54,11.42,670.0,977.6,82.0,261.9,2.65,116.0,91551.0 +2009-11-19 21:00:00+00:00,24.35,12.57,579.0,946.86,77.0,261.27,2.31,119.0,91524.0 +2009-11-19 22:00:00+00:00,24.16,13.71,430.0,881.65,68.0,260.63,1.97,122.0,91497.0 +2009-11-19 23:00:00+00:00,23.97,14.86,238.0,737.38,53.0,260.0,1.63,125.0,91470.0 +2009-11-20 00:00:00+00:00,22.82,15.88,43.0,347.01,22.0,259.27,1.89,122.0,91458.0 +2009-11-20 01:00:00+00:00,21.66,16.91,0.0,0.0,0.0,258.53,2.14,118.0,91446.0 +2009-11-20 02:00:00+00:00,20.51,17.93,0.0,0.0,0.0,257.8,2.4,115.0,91434.0 +2009-11-20 03:00:00+00:00,18.08,21.18,0.0,0.0,0.0,256.47,2.38,112.0,91440.0 +2009-11-20 04:00:00+00:00,15.64,24.44,0.0,0.0,0.0,255.13,2.35,110.0,91446.0 +2009-11-20 05:00:00+00:00,13.21,27.69,0.0,0.0,0.0,253.8,2.33,107.0,91452.0 +2009-11-20 06:00:00+00:00,12.21,30.09,0.0,0.0,0.0,251.38,2.22,103.0,91440.0 +2009-11-20 07:00:00+00:00,11.21,32.5,0.0,0.0,0.0,248.97,2.1,100.0,91428.0 +2009-11-20 08:00:00+00:00,10.21,34.9,0.0,0.0,0.0,246.55,1.99,96.0,91416.0 +2009-11-20 09:00:00+00:00,9.39,36.12,0.0,0.0,0.0,244.85,1.99,96.0,91388.0 +2009-11-20 10:00:00+00:00,8.56,37.35,0.0,0.0,0.0,243.15,2.0,97.0,91361.0 +2009-11-20 11:00:00+00:00,7.73,38.57,0.0,0.0,0.0,241.45,2.0,97.0,91334.0 +2009-11-20 12:00:00+00:00,8.42,37.75,0.0,0.0,0.0,241.27,1.98,105.0,91331.0 +2009-11-20 13:00:00+00:00,9.1,36.93,0.0,0.0,0.0,241.08,1.96,112.0,91328.0 +2009-11-20 14:00:00+00:00,9.78,36.11,0.0,0.0,0.0,240.9,1.94,120.0,91325.0 +2009-11-20 15:00:00+00:00,13.73,29.77,167.0,651.67,45.0,245.47,2.24,141.0,91313.0 +2009-11-20 16:00:00+00:00,17.69,23.42,365.0,841.03,64.0,250.03,2.54,163.0,91301.0 +2009-11-20 17:00:00+00:00,21.65,17.08,529.0,924.98,74.0,254.6,2.84,185.0,91289.0 +2009-11-20 18:00:00+00:00,22.52,16.2,639.0,963.6,80.0,256.72,3.45,200.0,91202.0 +2009-11-20 19:00:00+00:00,23.4,15.33,684.0,976.47,82.0,258.83,4.06,215.0,91115.0 +2009-11-20 20:00:00+00:00,24.28,14.45,661.0,968.91,81.0,260.95,4.66,231.0,91028.0 +2009-11-20 21:00:00+00:00,23.5,15.96,570.0,936.25,76.0,261.58,4.29,235.0,91031.0 +2009-11-20 22:00:00+00:00,22.72,17.46,422.0,869.19,67.0,262.22,3.91,240.0,91034.0 +2009-11-20 23:00:00+00:00,21.95,18.97,232.0,722.6,52.0,262.85,3.53,245.0,91037.0 +2009-11-21 00:00:00+00:00,20.58,21.09,21.0,0.0,21.0,262.72,3.08,244.0,91085.0 +2009-11-21 01:00:00+00:00,19.21,23.22,0.0,0.0,0.0,262.58,2.62,242.0,91133.0 +2009-11-21 02:00:00+00:00,17.84,25.34,0.0,0.0,0.0,262.45,2.17,241.0,91181.0 +2009-11-21 03:00:00+00:00,17.21,25.73,0.0,0.0,0.0,261.82,2.0,232.0,91220.0 +2009-11-21 04:00:00+00:00,16.59,26.13,0.0,0.0,0.0,261.18,1.83,224.0,91259.0 +2009-11-21 05:00:00+00:00,15.96,26.52,0.0,0.0,0.0,260.55,1.66,215.0,91298.0 +2009-11-21 06:00:00+00:00,14.56,29.73,0.0,0.0,0.0,259.13,1.41,205.0,91310.0 +2009-11-21 07:00:00+00:00,13.16,32.93,0.0,0.0,0.0,257.72,1.17,195.0,91322.0 +2009-11-21 08:00:00+00:00,11.76,36.14,0.0,0.0,0.0,256.3,0.92,185.0,91334.0 +2009-11-21 09:00:00+00:00,10.59,38.92,0.0,0.0,0.0,255.12,0.98,164.0,91346.0 +2009-11-21 10:00:00+00:00,9.42,41.69,0.0,0.0,0.0,253.93,1.03,143.0,91358.0 +2009-11-21 11:00:00+00:00,8.25,44.47,0.0,0.0,0.0,252.75,1.09,121.0,91370.0 +2009-11-21 12:00:00+00:00,8.63,44.88,0.0,0.0,0.0,252.17,1.24,117.0,91400.0 +2009-11-21 13:00:00+00:00,9.01,45.28,0.0,0.0,0.0,251.58,1.38,113.0,91431.0 +2009-11-21 14:00:00+00:00,9.39,45.69,0.0,0.0,0.0,251.0,1.53,109.0,91461.0 +2009-11-21 15:00:00+00:00,12.98,37.08,165.0,652.36,45.0,254.97,1.49,119.0,91470.0 +2009-11-21 16:00:00+00:00,16.58,28.48,364.0,849.0,63.0,258.93,1.46,128.0,91479.0 +2009-11-21 17:00:00+00:00,20.18,19.87,531.0,935.42,74.0,262.9,1.42,138.0,91488.0 +2009-11-21 18:00:00+00:00,21.23,18.74,643.0,975.96,80.0,263.88,1.49,162.0,91410.0 +2009-11-21 19:00:00+00:00,22.29,17.62,690.0,991.11,82.0,264.87,1.57,186.0,91331.0 +2009-11-21 20:00:00+00:00,23.35,16.49,666.0,981.82,81.0,265.85,1.64,210.0,91253.0 +2009-11-21 21:00:00+00:00,22.76,17.51,575.0,950.13,76.0,265.62,1.72,217.0,91232.0 +2009-11-21 22:00:00+00:00,22.17,18.52,426.0,883.48,67.0,265.38,1.8,225.0,91211.0 +2009-11-21 23:00:00+00:00,21.59,19.54,234.0,735.63,52.0,265.15,1.88,232.0,91190.0 +2009-11-22 00:00:00+00:00,20.71,20.87,21.0,0.0,21.0,265.15,1.8,235.0,91238.0 +2009-11-22 01:00:00+00:00,19.83,22.2,0.0,0.0,0.0,265.15,1.73,238.0,91286.0 +2009-11-22 02:00:00+00:00,18.95,23.53,0.0,0.0,0.0,265.15,1.66,242.0,91334.0 +2009-11-22 03:00:00+00:00,18.13,23.81,0.0,0.0,0.0,264.53,1.48,231.0,91355.0 +2009-11-22 04:00:00+00:00,17.31,24.1,0.0,0.0,0.0,263.92,1.3,220.0,91376.0 +2009-11-22 05:00:00+00:00,16.49,24.38,0.0,0.0,0.0,263.3,1.12,210.0,91397.0 +2009-11-22 06:00:00+00:00,15.51,26.59,0.0,0.0,0.0,261.9,1.0,206.0,91419.0 +2009-11-22 07:00:00+00:00,14.53,28.79,0.0,0.0,0.0,260.5,0.89,203.0,91440.0 +2009-11-22 08:00:00+00:00,13.55,31.0,0.0,0.0,0.0,259.1,0.77,200.0,91461.0 +2009-11-22 09:00:00+00:00,12.17,34.21,0.0,0.0,0.0,257.9,0.8,182.0,91470.0 +2009-11-22 10:00:00+00:00,10.78,37.41,0.0,0.0,0.0,256.7,0.83,165.0,91479.0 +2009-11-22 11:00:00+00:00,9.39,40.62,0.0,0.0,0.0,255.5,0.86,147.0,91488.0 +2009-11-22 12:00:00+00:00,9.61,40.85,0.0,0.0,0.0,255.3,0.97,151.0,91524.0 +2009-11-22 13:00:00+00:00,9.83,41.08,0.0,0.0,0.0,255.1,1.09,155.0,91560.0 +2009-11-22 14:00:00+00:00,10.05,41.31,0.0,0.0,0.0,254.9,1.2,159.0,91596.0 +2009-11-22 15:00:00+00:00,13.3,33.44,157.0,630.82,43.0,259.33,1.26,189.0,91611.0 +2009-11-22 16:00:00+00:00,16.56,25.56,352.0,825.69,62.0,263.77,1.33,219.0,91626.0 +2009-11-22 17:00:00+00:00,19.82,17.69,514.0,908.81,73.0,268.2,1.39,250.0,91641.0 +2009-11-22 18:00:00+00:00,20.76,16.47,624.0,951.75,78.0,269.27,1.91,256.0,91566.0 +2009-11-22 19:00:00+00:00,21.7,15.24,670.0,964.82,81.0,270.33,2.42,263.0,91491.0 +2009-11-22 20:00:00+00:00,22.65,14.02,647.0,955.94,80.0,271.4,2.94,270.0,91416.0 +2009-11-22 21:00:00+00:00,22.07,14.48,559.0,925.72,75.0,271.02,2.71,276.0,91419.0 +2009-11-22 22:00:00+00:00,21.5,14.93,413.0,858.13,66.0,270.63,2.48,282.0,91422.0 +2009-11-22 23:00:00+00:00,20.93,15.39,226.0,711.93,51.0,270.25,2.25,288.0,91425.0 +2009-11-23 00:00:00+00:00,18.98,17.36,20.0,0.0,20.0,268.62,2.07,303.0,91479.0 +2009-11-23 01:00:00+00:00,17.04,19.33,0.0,0.0,0.0,266.98,1.9,317.0,91533.0 +2009-11-23 02:00:00+00:00,15.09,21.3,0.0,0.0,0.0,265.35,1.72,332.0,91587.0 +2009-11-23 03:00:00+00:00,14.04,23.27,0.0,0.0,0.0,264.12,1.68,355.0,91611.0 +2009-11-23 04:00:00+00:00,12.99,25.23,0.0,0.0,0.0,262.88,1.64,18.0,91635.0 +2009-11-23 05:00:00+00:00,11.94,27.2,0.0,0.0,0.0,261.65,1.6,42.0,91659.0 +2009-11-23 06:00:00+00:00,11.24,27.83,0.0,0.0,0.0,259.95,1.71,53.0,91668.0 +2009-11-23 07:00:00+00:00,10.54,28.45,0.0,0.0,0.0,258.25,1.81,65.0,91677.0 +2009-11-23 08:00:00+00:00,9.83,29.08,0.0,0.0,0.0,256.55,1.92,77.0,91686.0 +2009-11-23 09:00:00+00:00,9.06,30.06,0.0,0.0,0.0,255.22,2.0,76.0,91701.0 +2009-11-23 10:00:00+00:00,8.29,31.05,0.0,0.0,0.0,253.88,2.08,75.0,91716.0 +2009-11-23 11:00:00+00:00,7.52,32.03,0.0,0.0,0.0,252.55,2.17,74.0,91731.0 +2009-11-23 12:00:00+00:00,7.82,32.2,0.0,0.0,0.0,251.05,2.11,74.0,91773.0 +2009-11-23 13:00:00+00:00,8.12,32.38,0.0,0.0,0.0,249.55,2.05,73.0,91815.0 +2009-11-23 14:00:00+00:00,8.42,32.55,0.0,0.0,0.0,248.05,1.99,72.0,91857.0 +2009-11-23 15:00:00+00:00,12.33,26.42,155.0,630.92,43.0,251.77,2.26,74.0,91848.0 +2009-11-23 16:00:00+00:00,16.24,20.29,351.0,830.59,62.0,255.48,2.53,76.0,91839.0 +2009-11-23 17:00:00+00:00,20.15,14.16,514.0,917.0,72.0,259.2,2.8,78.0,91830.0 +2009-11-23 18:00:00+00:00,21.27,13.0,625.0,958.71,78.0,260.25,3.2,83.0,91737.0 +2009-11-23 19:00:00+00:00,22.39,11.84,671.0,972.73,80.0,261.3,3.6,88.0,91644.0 +2009-11-23 20:00:00+00:00,23.51,10.68,649.0,965.25,79.0,262.35,4.0,93.0,91551.0 +2009-11-23 21:00:00+00:00,22.79,11.18,560.0,931.67,75.0,261.6,3.83,92.0,91527.0 +2009-11-23 22:00:00+00:00,22.07,11.68,414.0,864.63,66.0,260.85,3.67,92.0,91503.0 +2009-11-23 23:00:00+00:00,21.35,12.18,226.0,716.3,51.0,260.1,3.5,91.0,91479.0 +2009-11-24 00:00:00+00:00,19.22,14.54,20.0,0.0,20.0,258.62,3.2,87.0,91515.0 +2009-11-24 01:00:00+00:00,17.1,16.9,0.0,0.0,0.0,257.13,2.9,82.0,91551.0 +2009-11-24 02:00:00+00:00,14.97,19.26,0.0,0.0,0.0,255.65,2.59,77.0,91587.0 +2009-11-24 03:00:00+00:00,13.7,20.57,0.0,0.0,0.0,253.95,2.54,75.0,91611.0 +2009-11-24 04:00:00+00:00,12.43,21.89,0.0,0.0,0.0,252.25,2.49,74.0,91635.0 +2009-11-24 05:00:00+00:00,11.16,23.2,0.0,0.0,0.0,250.55,2.44,72.0,91659.0 +2009-11-24 06:00:00+00:00,10.57,24.27,0.0,0.0,0.0,248.77,2.46,71.0,91671.0 +2009-11-24 07:00:00+00:00,9.98,25.35,0.0,0.0,0.0,246.98,2.49,71.0,91683.0 +2009-11-24 08:00:00+00:00,9.38,26.42,0.0,0.0,0.0,245.2,2.51,71.0,91695.0 +2009-11-24 09:00:00+00:00,8.82,27.15,0.0,0.0,0.0,244.32,2.55,71.0,91707.0 +2009-11-24 10:00:00+00:00,8.25,27.89,0.0,0.0,0.0,243.43,2.58,71.0,91719.0 +2009-11-24 11:00:00+00:00,7.68,28.62,0.0,0.0,0.0,242.55,2.62,71.0,91731.0 +2009-11-24 12:00:00+00:00,8.13,28.68,0.0,0.0,0.0,243.67,2.58,73.0,91749.0 +2009-11-24 13:00:00+00:00,8.58,28.74,0.0,0.0,0.0,244.78,2.54,74.0,91767.0 +2009-11-24 14:00:00+00:00,9.03,28.8,0.0,0.0,0.0,245.9,2.5,75.0,91785.0 +2009-11-24 15:00:00+00:00,12.46,24.17,153.0,642.36,41.0,249.25,2.74,76.0,91782.0 +2009-11-24 16:00:00+00:00,15.9,19.53,349.0,841.26,59.0,252.6,2.99,77.0,91779.0 +2009-11-24 17:00:00+00:00,19.34,14.9,514.0,929.38,69.0,255.95,3.24,78.0,91776.0 +2009-11-24 18:00:00+00:00,20.71,14.1,625.0,969.16,75.0,258.03,3.43,81.0,91677.0 +2009-11-24 19:00:00+00:00,22.08,13.3,672.0,983.89,77.0,260.12,3.63,83.0,91578.0 +2009-11-24 20:00:00+00:00,23.46,12.5,650.0,976.2,76.0,262.2,3.82,86.0,91479.0 +2009-11-24 21:00:00+00:00,22.83,13.32,562.0,945.22,72.0,262.57,3.72,85.0,91467.0 +2009-11-24 22:00:00+00:00,22.21,14.13,416.0,878.47,64.0,262.93,3.62,84.0,91455.0 +2009-11-24 23:00:00+00:00,21.59,14.95,228.0,736.89,49.0,263.3,3.52,83.0,91443.0 +2009-11-25 00:00:00+00:00,19.92,16.94,20.0,0.0,20.0,262.52,3.31,81.0,91491.0 +2009-11-25 01:00:00+00:00,18.26,18.94,0.0,0.0,0.0,261.73,3.11,80.0,91539.0 +2009-11-25 02:00:00+00:00,16.59,20.93,0.0,0.0,0.0,260.95,2.91,79.0,91587.0 +2009-11-25 03:00:00+00:00,15.49,22.75,0.0,0.0,0.0,259.47,2.92,77.0,91629.0 +2009-11-25 04:00:00+00:00,14.39,24.56,0.0,0.0,0.0,257.98,2.94,76.0,91671.0 +2009-11-25 05:00:00+00:00,13.29,26.38,0.0,0.0,0.0,256.5,2.95,75.0,91713.0 +2009-11-25 06:00:00+00:00,12.64,27.44,0.0,0.0,0.0,256.08,3.0,74.0,91731.0 +2009-11-25 07:00:00+00:00,11.99,28.49,0.0,0.0,0.0,255.67,3.04,73.0,91749.0 +2009-11-25 08:00:00+00:00,11.33,29.55,0.0,0.0,0.0,255.25,3.09,72.0,91767.0 +2009-11-25 09:00:00+00:00,10.81,29.58,0.0,0.0,0.0,256.28,3.11,72.0,91779.0 +2009-11-25 10:00:00+00:00,10.29,29.62,0.0,0.0,0.0,257.32,3.13,72.0,91791.0 +2009-11-25 11:00:00+00:00,9.77,29.65,0.0,0.0,0.0,258.35,3.14,72.0,91803.0 +2009-11-25 12:00:00+00:00,10.3,28.79,0.0,0.0,0.0,260.4,3.12,73.0,91806.0 +2009-11-25 13:00:00+00:00,10.83,27.94,0.0,0.0,0.0,262.45,3.09,73.0,91809.0 +2009-11-25 14:00:00+00:00,11.36,27.08,0.0,0.0,0.0,264.5,3.06,74.0,91812.0 +2009-11-25 15:00:00+00:00,14.52,23.98,147.0,624.87,40.0,268.5,3.63,80.0,91803.0 +2009-11-25 16:00:00+00:00,17.68,20.88,292.0,611.93,83.0,272.5,4.19,86.0,91794.0 +2009-11-25 17:00:00+00:00,20.84,17.78,401.0,502.43,162.0,276.5,4.76,92.0,91785.0 +2009-11-25 18:00:00+00:00,22.02,17.7,609.0,947.71,74.0,280.5,5.03,96.0,91704.0 +2009-11-25 19:00:00+00:00,23.2,17.62,537.0,561.47,199.0,284.5,5.31,100.0,91623.0 +2009-11-25 20:00:00+00:00,24.38,17.54,632.0,951.24,75.0,288.5,5.59,104.0,91542.0 +2009-11-25 21:00:00+00:00,23.75,19.04,545.0,918.04,71.0,288.83,4.97,103.0,91536.0 +2009-11-25 22:00:00+00:00,23.12,20.54,401.0,847.11,63.0,289.17,4.35,102.0,91530.0 +2009-11-25 23:00:00+00:00,22.5,22.04,218.0,703.61,48.0,289.5,3.74,101.0,91524.0 +2009-11-26 00:00:00+00:00,20.84,25.18,19.0,0.0,19.0,290.47,3.39,95.0,91557.0 +2009-11-26 01:00:00+00:00,19.19,28.31,0.0,0.0,0.0,291.43,3.04,90.0,91590.0 +2009-11-26 02:00:00+00:00,17.53,31.45,0.0,0.0,0.0,292.4,2.69,85.0,91623.0 +2009-11-26 03:00:00+00:00,16.41,34.04,0.0,0.0,0.0,290.93,2.53,82.0,91650.0 +2009-11-26 04:00:00+00:00,15.28,36.62,0.0,0.0,0.0,289.47,2.38,79.0,91677.0 +2009-11-26 05:00:00+00:00,14.16,39.21,0.0,0.0,0.0,288.0,2.22,77.0,91704.0 +2009-11-26 06:00:00+00:00,13.44,41.01,0.0,0.0,0.0,285.65,2.15,77.0,91707.0 +2009-11-26 07:00:00+00:00,12.72,42.81,0.0,0.0,0.0,283.3,2.08,77.0,91710.0 +2009-11-26 08:00:00+00:00,11.99,44.61,0.0,0.0,0.0,280.95,2.01,77.0,91713.0 +2009-11-26 09:00:00+00:00,11.39,45.82,0.0,0.0,0.0,279.25,1.98,79.0,91710.0 +2009-11-26 10:00:00+00:00,10.79,47.03,0.0,0.0,0.0,277.55,1.94,80.0,91707.0 +2009-11-26 11:00:00+00:00,10.18,48.24,0.0,0.0,0.0,275.85,1.9,82.0,91704.0 +2009-11-26 12:00:00+00:00,10.5,47.43,0.0,0.0,0.0,274.42,1.84,87.0,91704.0 +2009-11-26 13:00:00+00:00,10.82,46.61,0.0,0.0,0.0,272.98,1.78,91.0,91704.0 +2009-11-26 14:00:00+00:00,11.14,45.8,0.0,0.0,0.0,271.55,1.72,95.0,91704.0 +2009-11-26 15:00:00+00:00,14.77,38.68,137.0,582.81,39.0,276.08,1.71,109.0,91686.0 +2009-11-26 16:00:00+00:00,18.41,31.55,324.0,788.97,57.0,280.62,1.71,122.0,91668.0 +2009-11-26 17:00:00+00:00,22.05,24.43,483.0,880.21,67.0,285.15,1.7,135.0,91650.0 +2009-11-26 18:00:00+00:00,23.02,23.31,591.0,922.35,73.0,288.15,2.24,165.0,91542.0 +2009-11-26 19:00:00+00:00,24.0,22.18,637.0,937.72,75.0,291.15,2.78,196.0,91434.0 +2009-11-26 20:00:00+00:00,24.98,21.06,616.0,929.35,74.0,294.15,3.32,226.0,91325.0 +2009-11-26 21:00:00+00:00,24.43,22.3,532.0,898.25,70.0,302.23,3.23,228.0,91286.0 +2009-11-26 22:00:00+00:00,23.88,23.54,391.0,827.86,62.0,310.32,3.13,230.0,91247.0 +2009-11-26 23:00:00+00:00,23.34,24.78,212.0,682.17,48.0,318.4,3.03,232.0,91208.0 +2009-11-27 00:00:00+00:00,21.65,27.0,18.0,0.0,18.0,314.4,2.88,231.0,91211.0 +2009-11-27 01:00:00+00:00,19.97,29.21,0.0,0.0,0.0,310.4,2.72,230.0,91214.0 +2009-11-27 02:00:00+00:00,18.28,31.43,0.0,0.0,0.0,306.4,2.57,229.0,91217.0 +2009-11-27 03:00:00+00:00,17.32,32.99,0.0,0.0,0.0,303.15,2.52,221.0,91208.0 +2009-11-27 04:00:00+00:00,16.37,34.56,0.0,0.0,0.0,299.9,2.48,213.0,91199.0 +2009-11-27 05:00:00+00:00,15.41,36.12,0.0,0.0,0.0,296.65,2.44,206.0,91190.0 +2009-11-27 06:00:00+00:00,15.11,37.11,0.0,0.0,0.0,295.32,2.54,200.0,91160.0 +2009-11-27 07:00:00+00:00,14.81,38.09,0.0,0.0,0.0,293.98,2.63,195.0,91130.0 +2009-11-27 08:00:00+00:00,14.51,39.08,0.0,0.0,0.0,292.65,2.73,189.0,91100.0 +2009-11-27 09:00:00+00:00,14.42,40.38,0.0,0.0,0.0,294.57,2.97,188.0,91064.0 +2009-11-27 10:00:00+00:00,14.33,41.67,0.0,0.0,0.0,296.48,3.21,187.0,91028.0 +2009-11-27 11:00:00+00:00,14.24,42.97,0.0,0.0,0.0,298.4,3.45,186.0,90992.0 +2009-11-27 12:00:00+00:00,14.33,45.15,0.0,0.0,0.0,295.83,3.69,185.0,90980.0 +2009-11-27 13:00:00+00:00,14.41,47.32,0.0,0.0,0.0,293.27,3.93,185.0,90968.0 +2009-11-27 14:00:00+00:00,14.5,49.5,0.0,0.0,0.0,290.7,4.17,184.0,90956.0 +2009-11-27 15:00:00+00:00,15.92,46.2,50.0,0.0,50.0,295.45,5.18,188.0,90932.0 +2009-11-27 16:00:00+00:00,17.34,42.89,186.0,134.19,141.0,300.2,6.19,192.0,90908.0 +2009-11-27 17:00:00+00:00,18.77,39.59,377.0,428.02,176.0,304.95,7.2,196.0,90884.0 +2009-11-27 18:00:00+00:00,19.22,37.7,596.0,937.78,72.0,308.75,7.61,199.0,90794.0 +2009-11-27 19:00:00+00:00,19.68,35.82,641.0,950.16,74.0,312.55,8.03,201.0,90704.0 +2009-11-27 20:00:00+00:00,20.14,33.93,431.0,284.02,266.0,316.35,8.44,204.0,90613.0 +2009-11-27 21:00:00+00:00,19.21,36.46,372.0,284.91,226.0,315.6,7.54,205.0,90619.0 +2009-11-27 22:00:00+00:00,18.29,38.99,393.0,838.55,61.0,314.85,6.65,205.0,90625.0 +2009-11-27 23:00:00+00:00,17.37,41.52,116.0,87.75,95.0,314.1,5.75,206.0,90631.0 +2009-11-28 00:00:00+00:00,16.62,43.63,18.0,0.0,18.0,320.93,5.14,209.0,90707.0 +2009-11-28 01:00:00+00:00,15.88,45.75,0.0,0.0,0.0,327.77,4.52,213.0,90782.0 +2009-11-28 02:00:00+00:00,15.13,47.86,0.0,0.0,0.0,334.6,3.9,217.0,90857.0 +2009-11-28 03:00:00+00:00,14.36,51.06,0.0,0.0,0.0,336.95,3.81,218.0,90887.0 +2009-11-28 04:00:00+00:00,13.58,54.27,0.0,0.0,0.0,339.3,3.72,220.0,90917.0 +2009-11-28 05:00:00+00:00,12.81,57.47,0.0,0.0,0.0,341.65,3.63,221.0,90947.0 +2009-11-28 06:00:00+00:00,12.25,60.78,0.0,0.0,0.0,335.0,3.01,214.0,90941.0 +2009-11-28 07:00:00+00:00,11.69,64.1,0.0,0.0,0.0,328.35,2.39,207.0,90935.0 +2009-11-28 08:00:00+00:00,11.12,67.41,0.0,0.0,0.0,321.7,1.77,199.0,90929.0 +2009-11-28 09:00:00+00:00,10.61,71.49,0.0,0.0,0.0,313.93,1.75,192.0,90953.0 +2009-11-28 10:00:00+00:00,10.1,75.56,0.0,0.0,0.0,306.17,1.73,185.0,90977.0 +2009-11-28 11:00:00+00:00,9.59,79.64,0.0,0.0,0.0,298.4,1.71,178.0,91001.0 +2009-11-28 12:00:00+00:00,9.62,78.49,0.0,0.0,0.0,300.43,1.74,171.0,91052.0 +2009-11-28 13:00:00+00:00,9.64,77.35,0.0,0.0,0.0,302.47,1.77,164.0,91103.0 +2009-11-28 14:00:00+00:00,9.67,76.2,0.0,0.0,0.0,304.5,1.79,156.0,91154.0 +2009-11-28 15:00:00+00:00,10.5,70.64,92.0,215.89,57.0,304.13,2.37,158.0,91142.0 +2009-11-28 16:00:00+00:00,11.34,65.07,326.0,809.46,57.0,303.77,2.95,160.0,91130.0 +2009-11-28 17:00:00+00:00,12.18,59.51,487.0,900.0,67.0,303.4,3.53,162.0,91118.0 +2009-11-28 18:00:00+00:00,12.76,56.04,203.0,14.39,195.0,303.42,3.45,164.0,91052.0 +2009-11-28 19:00:00+00:00,13.34,52.58,643.0,957.52,74.0,303.43,3.37,166.0,90986.0 +2009-11-28 20:00:00+00:00,13.92,49.11,624.0,952.01,73.0,303.45,3.28,167.0,90920.0 +2009-11-28 21:00:00+00:00,13.7,50.55,539.0,920.39,69.0,304.77,2.99,164.0,90938.0 +2009-11-28 22:00:00+00:00,13.49,51.99,398.0,854.19,61.0,306.08,2.69,162.0,90956.0 +2009-11-28 23:00:00+00:00,13.28,53.43,215.0,704.98,47.0,307.4,2.4,159.0,90974.0 +2009-11-29 00:00:00+00:00,12.49,59.31,18.0,0.0,18.0,301.1,2.25,138.0,91097.0 +2009-11-29 01:00:00+00:00,11.71,65.2,0.0,0.0,0.0,294.8,2.1,117.0,91220.0 +2009-11-29 02:00:00+00:00,10.92,71.08,0.0,0.0,0.0,288.5,1.94,96.0,91343.0 +2009-11-29 03:00:00+00:00,10.52,73.43,0.0,0.0,0.0,290.17,1.99,98.0,91376.0 +2009-11-29 04:00:00+00:00,10.13,75.79,0.0,0.0,0.0,291.83,2.03,99.0,91410.0 +2009-11-29 05:00:00+00:00,9.73,78.14,0.0,0.0,0.0,293.5,2.07,100.0,91443.0 +2009-11-29 06:00:00+00:00,9.56,79.02,0.0,0.0,0.0,298.07,2.39,97.0,91455.0 +2009-11-29 07:00:00+00:00,9.39,79.9,0.0,0.0,0.0,302.63,2.71,94.0,91467.0 +2009-11-29 08:00:00+00:00,9.21,80.78,0.0,0.0,0.0,307.2,3.03,92.0,91479.0 +2009-11-29 09:00:00+00:00,8.91,84.35,0.0,0.0,0.0,299.72,3.18,87.0,91506.0 +2009-11-29 10:00:00+00:00,8.61,87.91,0.0,0.0,0.0,292.23,3.33,83.0,91533.0 +2009-11-29 11:00:00+00:00,8.31,91.48,0.0,0.0,0.0,284.75,3.48,79.0,91560.0 +2009-11-29 12:00:00+00:00,8.16,92.59,0.0,0.0,0.0,279.68,3.37,75.0,91590.0 +2009-11-29 13:00:00+00:00,8.0,93.69,0.0,0.0,0.0,274.62,3.27,72.0,91620.0 +2009-11-29 14:00:00+00:00,7.85,94.8,0.0,0.0,0.0,269.55,3.17,68.0,91650.0 +2009-11-29 15:00:00+00:00,9.35,83.53,95.0,257.59,54.0,270.07,4.1,74.0,91632.0 +2009-11-29 16:00:00+00:00,10.85,72.26,317.0,792.46,56.0,270.58,5.03,79.0,91614.0 +2009-11-29 17:00:00+00:00,12.36,60.99,477.0,886.17,66.0,271.1,5.96,85.0,91596.0 +2009-11-29 18:00:00+00:00,12.91,55.65,588.0,932.56,72.0,272.98,6.27,83.0,91506.0 +2009-11-29 19:00:00+00:00,13.47,50.32,509.0,486.63,221.0,274.87,6.57,82.0,91416.0 +2009-11-29 20:00:00+00:00,14.03,44.98,405.0,232.36,271.0,276.75,6.88,81.0,91325.0 +2009-11-29 21:00:00+00:00,13.55,48.29,381.0,322.22,217.0,277.93,6.64,78.0,91328.0 +2009-11-29 22:00:00+00:00,13.08,51.6,238.0,172.92,170.0,279.12,6.4,75.0,91331.0 +2009-11-29 23:00:00+00:00,12.61,54.91,53.0,0.0,53.0,280.3,6.17,71.0,91334.0 +2009-11-30 00:00:00+00:00,11.49,61.98,11.0,0.0,11.0,277.65,5.25,71.0,91397.0 +2009-11-30 01:00:00+00:00,10.37,69.06,0.0,0.0,0.0,275.0,4.34,72.0,91461.0 +2009-11-30 02:00:00+00:00,9.25,76.13,0.0,0.0,0.0,272.35,3.42,72.0,91524.0 +2009-11-30 03:00:00+00:00,8.56,79.55,0.0,0.0,0.0,265.18,3.07,67.0,91548.0 +2009-11-30 04:00:00+00:00,7.86,82.98,0.0,0.0,0.0,258.02,2.72,62.0,91572.0 +2009-11-30 05:00:00+00:00,7.16,86.4,0.0,0.0,0.0,250.85,2.37,57.0,91596.0 +2009-11-30 06:00:00+00:00,6.54,89.89,0.0,0.0,0.0,248.17,2.22,56.0,91587.0 +2009-11-30 07:00:00+00:00,5.93,93.38,0.0,0.0,0.0,245.48,2.07,55.0,91578.0 +2009-11-30 08:00:00+00:00,5.31,96.87,0.0,0.0,0.0,242.8,1.92,54.0,91569.0 +2009-11-30 09:00:00+00:00,4.76,97.91,0.0,0.0,0.0,241.95,1.72,55.0,91563.0 +2009-11-30 10:00:00+00:00,4.21,98.96,0.0,0.0,0.0,241.1,1.53,57.0,91557.0 +2009-11-30 11:00:00+00:00,3.67,100.0,0.0,0.0,0.0,240.25,1.34,58.0,91551.0 +2009-11-30 12:00:00+00:00,3.98,100.0,0.0,0.0,0.0,238.93,1.06,79.0,91557.0 +2009-11-30 13:00:00+00:00,4.3,100.0,0.0,0.0,0.0,237.62,0.79,100.0,91563.0 +2009-11-30 14:00:00+00:00,4.62,100.0,0.0,0.0,0.0,236.3,0.51,121.0,91569.0 +2009-11-30 15:00:00+00:00,7.21,86.08,129.0,588.74,37.0,241.7,0.89,65.0,91536.0 +2009-11-30 16:00:00+00:00,14.75,47.31,318.0,802.57,56.0,254.62,3.26,9.0,91503.0 +2009-11-30 17:00:00+00:00,14.41,48.8,480.0,898.07,66.0,254.15,3.21,313.0,91470.0 +2009-11-30 18:00:00+00:00,14.07,50.28,592.0,946.05,71.0,253.67,3.15,310.0,91364.0 +2009-11-30 19:00:00+00:00,13.73,51.76,641.0,961.83,74.0,253.19,3.09,308.0,91259.0 +2009-11-30 20:00:00+00:00,13.39,53.24,623.0,956.99,73.0,252.71,3.04,305.0,91154.0 +2009-11-30 21:00:00+00:00,13.05,54.72,540.0,928.32,69.0,252.23,2.98,301.0,91127.0 +2009-11-30 22:00:00+00:00,12.71,56.2,400.0,864.7,61.0,251.75,2.92,298.0,91100.0 +2009-11-30 23:00:00+00:00,12.37,57.69,219.0,726.96,47.0,251.28,2.87,294.0,91073.0 +2009-12-01 00:00:00+00:00,12.04,59.17,18.0,0.0,18.0,250.8,2.81,289.0,91112.0 +2009-12-01 01:00:00+00:00,11.7,60.65,0.0,0.0,0.0,250.32,2.75,284.0,91151.0 +2009-12-01 02:00:00+00:00,11.36,62.13,0.0,0.0,0.0,249.84,2.7,279.0,91190.0 +2009-12-01 03:00:00+00:00,11.02,63.61,0.0,0.0,0.0,249.36,2.64,271.0,91211.0 +2009-12-01 04:00:00+00:00,10.68,65.09,0.0,0.0,0.0,248.89,2.58,263.0,91232.0 +2009-12-01 05:00:00+00:00,10.34,66.58,0.0,0.0,0.0,248.41,2.53,255.0,91253.0 +2009-12-01 06:00:00+00:00,10.0,68.06,0.0,0.0,0.0,247.93,2.47,251.0,91262.0 +2009-12-01 07:00:00+00:00,9.66,69.54,0.0,0.0,0.0,247.45,2.41,247.0,91271.0 +2009-12-01 08:00:00+00:00,8.2,75.71,0.0,0.0,0.0,243.5,1.71,243.0,91280.0 +2009-12-01 09:00:00+00:00,7.71,77.67,0.0,0.0,0.0,244.38,1.64,240.0,91295.0 +2009-12-01 10:00:00+00:00,7.22,79.64,0.0,0.0,0.0,245.27,1.57,238.0,91310.0 +2009-12-01 11:00:00+00:00,6.73,81.6,0.0,0.0,0.0,246.15,1.5,235.0,91325.0 +2009-12-01 12:00:00+00:00,6.56,82.02,0.0,0.0,0.0,246.35,1.38,218.0,91355.0 +2009-12-01 13:00:00+00:00,6.4,82.45,0.0,0.0,0.0,246.55,1.26,200.0,91385.0 +2009-12-01 14:00:00+00:00,6.23,82.87,0.0,0.0,0.0,246.75,1.14,183.0,91416.0 +2009-12-01 15:00:00+00:00,8.79,70.94,130.0,606.2,37.0,250.22,1.15,207.0,91403.0 +2009-12-01 16:00:00+00:00,11.35,59.01,321.0,818.89,56.0,253.68,1.16,231.0,91391.0 +2009-12-01 17:00:00+00:00,13.9,47.08,484.0,912.15,66.0,257.15,1.17,255.0,91379.0 +2009-12-01 18:00:00+00:00,14.83,42.73,595.0,955.88,71.0,257.6,1.76,261.0,91289.0 +2009-12-01 19:00:00+00:00,15.77,38.38,644.0,972.3,73.0,258.05,2.34,268.0,91199.0 +2009-12-01 20:00:00+00:00,16.7,34.03,625.0,963.63,73.0,258.5,2.92,275.0,91109.0 +2009-12-01 21:00:00+00:00,16.2,36.74,540.0,933.03,68.0,256.92,2.79,277.0,91094.0 +2009-12-01 22:00:00+00:00,15.7,39.44,399.0,864.55,61.0,255.33,2.66,278.0,91079.0 +2009-12-01 23:00:00+00:00,15.2,42.15,217.0,720.64,47.0,253.75,2.52,280.0,91064.0 +2009-12-02 00:00:00+00:00,13.84,46.31,18.0,0.0,18.0,253.78,2.38,274.0,91085.0 +2009-12-02 01:00:00+00:00,12.49,50.47,0.0,0.0,0.0,253.82,2.23,269.0,91106.0 +2009-12-02 02:00:00+00:00,11.13,54.63,0.0,0.0,0.0,253.85,2.08,264.0,91127.0 +2009-12-02 03:00:00+00:00,11.29,53.67,0.0,0.0,0.0,253.35,1.81,256.0,91151.0 +2009-12-02 04:00:00+00:00,11.45,52.71,0.0,0.0,0.0,252.85,1.54,248.0,91175.0 +2009-12-02 05:00:00+00:00,11.61,51.75,0.0,0.0,0.0,252.35,1.27,240.0,91199.0 +2009-12-02 06:00:00+00:00,10.7,59.2,0.0,0.0,0.0,251.25,1.17,231.0,91202.0 +2009-12-02 07:00:00+00:00,9.78,66.64,0.0,0.0,0.0,250.15,1.08,221.0,91205.0 +2009-12-02 08:00:00+00:00,8.87,74.09,0.0,0.0,0.0,249.05,0.98,212.0,91208.0 +2009-12-02 09:00:00+00:00,8.17,77.82,0.0,0.0,0.0,248.25,1.01,207.0,91226.0 +2009-12-02 10:00:00+00:00,7.48,81.54,0.0,0.0,0.0,247.45,1.03,201.0,91244.0 +2009-12-02 11:00:00+00:00,6.79,85.27,0.0,0.0,0.0,246.65,1.06,196.0,91262.0 +2009-12-02 12:00:00+00:00,6.66,84.65,0.0,0.0,0.0,246.77,1.14,189.0,91286.0 +2009-12-02 13:00:00+00:00,6.54,84.03,0.0,0.0,0.0,246.88,1.23,182.0,91310.0 +2009-12-02 14:00:00+00:00,6.41,83.41,0.0,0.0,0.0,247.0,1.31,175.0,91334.0 +2009-12-02 15:00:00+00:00,9.12,70.13,126.0,597.54,36.0,250.47,1.59,199.0,91349.0 +2009-12-02 16:00:00+00:00,11.83,56.86,317.0,816.64,55.0,253.93,1.86,224.0,91364.0 +2009-12-02 17:00:00+00:00,14.53,43.58,479.0,908.7,65.0,257.4,2.14,248.0,91379.0 +2009-12-02 18:00:00+00:00,15.37,38.91,591.0,952.83,71.0,258.38,3.07,257.0,91325.0 +2009-12-02 19:00:00+00:00,16.21,34.24,639.0,967.32,73.0,259.37,4.0,266.0,91271.0 +2009-12-02 20:00:00+00:00,17.05,29.57,621.0,961.38,72.0,260.35,4.92,276.0,91217.0 +2009-12-02 21:00:00+00:00,16.46,29.0,538.0,931.64,68.0,260.02,4.57,276.0,91208.0 +2009-12-02 22:00:00+00:00,15.88,28.44,398.0,866.73,60.0,259.68,4.21,277.0,91199.0 +2009-12-02 23:00:00+00:00,15.3,27.87,216.0,718.23,47.0,259.35,3.85,277.0,91190.0 +2009-12-03 00:00:00+00:00,13.83,32.34,18.0,0.0,18.0,259.05,3.62,281.0,91247.0 +2009-12-03 01:00:00+00:00,12.37,36.81,0.0,0.0,0.0,258.75,3.4,284.0,91304.0 +2009-12-03 02:00:00+00:00,10.9,41.28,0.0,0.0,0.0,258.45,3.17,288.0,91361.0 +2009-12-03 03:00:00+00:00,10.22,42.56,0.0,0.0,0.0,256.97,2.89,291.0,91406.0 +2009-12-03 04:00:00+00:00,9.53,43.83,0.0,0.0,0.0,255.48,2.6,295.0,91452.0 +2009-12-03 05:00:00+00:00,8.84,45.11,0.0,0.0,0.0,254.0,2.32,298.0,91497.0 +2009-12-03 06:00:00+00:00,8.42,45.66,0.0,0.0,0.0,250.18,2.06,310.0,91560.0 +2009-12-03 07:00:00+00:00,8.01,46.22,0.0,0.0,0.0,246.37,1.8,322.0,91623.0 +2009-12-03 08:00:00+00:00,7.59,46.77,0.0,0.0,0.0,242.55,1.54,334.0,91686.0 +2009-12-03 09:00:00+00:00,6.4,47.21,0.0,0.0,0.0,239.22,1.78,356.0,91764.0 +2009-12-03 10:00:00+00:00,5.21,47.65,0.0,0.0,0.0,235.88,2.02,19.0,91842.0 +2009-12-03 11:00:00+00:00,4.02,48.09,0.0,0.0,0.0,232.55,2.26,41.0,91920.0 +2009-12-03 12:00:00+00:00,3.82,51.55,0.0,0.0,0.0,230.92,2.23,52.0,91989.0 +2009-12-03 13:00:00+00:00,3.62,55.01,0.0,0.0,0.0,229.28,2.21,62.0,92058.0 +2009-12-03 14:00:00+00:00,3.42,58.47,0.0,0.0,0.0,227.65,2.18,73.0,92127.0 +2009-12-03 15:00:00+00:00,6.32,46.63,130.0,628.91,37.0,230.05,2.36,77.0,92139.0 +2009-12-03 16:00:00+00:00,9.22,34.79,327.0,851.9,56.0,232.45,2.55,81.0,92151.0 +2009-12-03 17:00:00+00:00,12.12,22.95,495.0,946.99,66.0,234.85,2.73,86.0,92163.0 +2009-12-03 18:00:00+00:00,13.09,20.86,609.0,990.09,71.0,234.88,2.64,89.0,92070.0 +2009-12-03 19:00:00+00:00,14.05,18.77,659.0,1003.31,74.0,234.92,2.55,92.0,91977.0 +2009-12-03 20:00:00+00:00,15.02,16.68,641.0,997.6,73.0,234.95,2.46,95.0,91884.0 +2009-12-03 21:00:00+00:00,14.52,17.29,557.0,969.79,69.0,234.17,2.27,90.0,91851.0 +2009-12-03 22:00:00+00:00,14.02,17.91,413.0,904.68,61.0,233.38,2.09,86.0,91818.0 +2009-12-03 23:00:00+00:00,13.53,18.52,226.0,758.08,48.0,232.6,1.9,82.0,91785.0 +2009-12-04 00:00:00+00:00,11.65,21.66,19.0,0.0,19.0,231.17,1.96,85.0,91782.0 +2009-12-04 01:00:00+00:00,9.77,24.81,0.0,0.0,0.0,229.73,2.01,87.0,91779.0 +2009-12-04 02:00:00+00:00,7.89,27.95,0.0,0.0,0.0,228.3,2.07,90.0,91776.0 +2009-12-04 03:00:00+00:00,6.95,32.84,0.0,0.0,0.0,226.52,1.95,94.0,91791.0 +2009-12-04 04:00:00+00:00,6.0,37.72,0.0,0.0,0.0,224.73,1.84,99.0,91806.0 +2009-12-04 05:00:00+00:00,5.05,42.61,0.0,0.0,0.0,222.95,1.72,103.0,91821.0 +2009-12-04 06:00:00+00:00,4.48,46.01,0.0,0.0,0.0,221.83,1.69,100.0,91812.0 +2009-12-04 07:00:00+00:00,3.9,49.42,0.0,0.0,0.0,220.72,1.65,96.0,91803.0 +2009-12-04 08:00:00+00:00,3.33,52.82,0.0,0.0,0.0,219.6,1.61,93.0,91794.0 +2009-12-04 09:00:00+00:00,2.89,56.11,0.0,0.0,0.0,219.85,1.59,95.0,91743.0 +2009-12-04 10:00:00+00:00,2.46,59.41,0.0,0.0,0.0,220.1,1.57,97.0,91692.0 +2009-12-04 11:00:00+00:00,2.03,62.7,0.0,0.0,0.0,220.35,1.54,99.0,91641.0 +2009-12-04 12:00:00+00:00,2.67,62.47,0.0,0.0,0.0,225.52,1.66,103.0,91596.0 +2009-12-04 13:00:00+00:00,3.31,62.23,0.0,0.0,0.0,230.68,1.77,108.0,91551.0 +2009-12-04 14:00:00+00:00,3.95,62.0,0.0,0.0,0.0,235.85,1.88,113.0,91506.0 +2009-12-04 15:00:00+00:00,7.1,51.3,66.0,89.54,53.0,241.87,1.95,131.0,91449.0 +2009-12-04 16:00:00+00:00,10.24,40.59,276.0,662.52,67.0,247.88,2.02,149.0,91391.0 +2009-12-04 17:00:00+00:00,13.38,29.89,392.0,579.35,131.0,253.9,2.1,167.0,91334.0 +2009-12-04 18:00:00+00:00,14.49,24.98,486.0,598.76,162.0,258.25,2.5,186.0,91205.0 +2009-12-04 19:00:00+00:00,15.61,20.08,456.0,344.17,256.0,262.6,2.9,206.0,91076.0 +2009-12-04 20:00:00+00:00,16.72,15.17,359.0,154.99,271.0,266.95,3.3,226.0,90947.0 +2009-12-04 21:00:00+00:00,15.83,14.76,401.0,402.38,199.0,268.83,3.47,228.0,90923.0 +2009-12-04 22:00:00+00:00,14.94,14.34,286.0,355.39,148.0,270.72,3.65,230.0,90899.0 +2009-12-04 23:00:00+00:00,14.06,13.93,44.0,0.0,44.0,272.6,3.82,232.0,90875.0 +2009-12-05 00:00:00+00:00,12.85,15.74,14.0,0.0,14.0,272.1,3.61,228.0,90905.0 +2009-12-05 01:00:00+00:00,11.65,17.55,0.0,0.0,0.0,271.6,3.41,223.0,90935.0 +2009-12-05 02:00:00+00:00,10.44,19.36,0.0,0.0,0.0,271.1,3.2,219.0,90965.0 +2009-12-05 03:00:00+00:00,9.71,25.02,0.0,0.0,0.0,268.32,3.22,217.0,90995.0 +2009-12-05 04:00:00+00:00,8.98,30.67,0.0,0.0,0.0,265.53,3.24,216.0,91025.0 +2009-12-05 05:00:00+00:00,8.24,36.33,0.0,0.0,0.0,262.75,3.26,214.0,91055.0 +2009-12-05 06:00:00+00:00,7.9,45.39,0.0,0.0,0.0,252.15,3.38,213.0,91070.0 +2009-12-05 07:00:00+00:00,7.57,54.46,0.0,0.0,0.0,241.55,3.5,212.0,91085.0 +2009-12-05 08:00:00+00:00,7.23,63.52,0.0,0.0,0.0,230.95,3.63,211.0,91100.0 +2009-12-05 09:00:00+00:00,6.84,70.5,0.0,0.0,0.0,230.32,3.44,214.0,91148.0 +2009-12-05 10:00:00+00:00,6.45,77.48,0.0,0.0,0.0,229.68,3.25,216.0,91196.0 +2009-12-05 11:00:00+00:00,6.07,84.46,0.0,0.0,0.0,229.05,3.06,218.0,91244.0 +2009-12-05 12:00:00+00:00,6.48,84.07,0.0,0.0,0.0,230.37,3.14,215.0,91280.0 +2009-12-05 13:00:00+00:00,6.9,83.67,0.0,0.0,0.0,231.68,3.23,213.0,91316.0 +2009-12-05 14:00:00+00:00,7.32,83.28,0.0,0.0,0.0,233.0,3.31,210.0,91352.0 +2009-12-05 15:00:00+00:00,8.88,75.6,118.0,582.22,35.0,239.23,4.19,213.0,91352.0 +2009-12-05 16:00:00+00:00,10.43,67.91,307.0,808.61,54.0,245.47,5.08,216.0,91352.0 +2009-12-05 17:00:00+00:00,11.98,60.23,469.0,903.86,64.0,251.7,5.96,219.0,91352.0 +2009-12-05 18:00:00+00:00,12.96,55.96,581.0,950.02,69.0,255.55,6.15,221.0,91259.0 +2009-12-05 19:00:00+00:00,13.93,51.7,505.0,516.18,206.0,259.4,6.34,222.0,91166.0 +2009-12-05 20:00:00+00:00,14.91,47.43,452.0,372.6,241.0,263.25,6.54,224.0,91073.0 +2009-12-05 21:00:00+00:00,14.49,50.15,251.0,63.88,219.0,263.3,6.11,223.0,91073.0 +2009-12-05 22:00:00+00:00,14.07,52.88,274.0,306.99,155.0,263.35,5.68,223.0,91073.0 +2009-12-05 23:00:00+00:00,13.66,55.6,54.0,0.0,54.0,263.4,5.26,222.0,91073.0 +2009-12-06 00:00:00+00:00,12.99,60.1,16.0,0.0,16.0,268.38,4.86,222.0,91136.0 +2009-12-06 01:00:00+00:00,12.33,64.61,0.0,0.0,0.0,273.37,4.47,222.0,91199.0 +2009-12-06 02:00:00+00:00,11.66,69.11,0.0,0.0,0.0,278.35,4.08,222.0,91262.0 +2009-12-06 03:00:00+00:00,11.2,73.73,0.0,0.0,0.0,281.38,3.81,216.0,91286.0 +2009-12-06 04:00:00+00:00,10.73,78.35,0.0,0.0,0.0,284.42,3.54,210.0,91310.0 +2009-12-06 05:00:00+00:00,10.26,82.97,0.0,0.0,0.0,287.45,3.27,204.0,91334.0 +2009-12-06 06:00:00+00:00,10.04,85.45,0.0,0.0,0.0,287.97,3.31,200.0,91319.0 +2009-12-06 07:00:00+00:00,9.82,87.92,0.0,0.0,0.0,288.48,3.36,195.0,91304.0 +2009-12-06 08:00:00+00:00,9.6,90.4,0.0,0.0,0.0,289.0,3.41,191.0,91289.0 +2009-12-06 09:00:00+00:00,9.55,89.2,0.0,0.0,0.0,292.67,3.61,190.0,91274.0 +2009-12-06 10:00:00+00:00,9.5,87.99,0.0,0.0,0.0,296.33,3.81,189.0,91259.0 +2009-12-06 11:00:00+00:00,9.46,86.79,0.0,0.0,0.0,300.0,4.01,188.0,91244.0 +2009-12-06 12:00:00+00:00,9.76,87.77,0.0,0.0,0.0,313.5,4.16,190.0,91256.0 +2009-12-06 13:00:00+00:00,10.07,88.76,0.0,0.0,0.0,327.0,4.3,192.0,91268.0 +2009-12-06 14:00:00+00:00,10.37,89.74,0.0,0.0,0.0,340.5,4.44,194.0,91280.0 +2009-12-06 15:00:00+00:00,10.68,87.18,17.0,0.0,17.0,338.05,5.69,196.0,91250.0 +2009-12-06 16:00:00+00:00,10.99,84.63,54.0,0.0,54.0,335.6,6.93,199.0,91220.0 +2009-12-06 17:00:00+00:00,11.3,82.07,18.0,0.0,18.0,333.15,8.18,201.0,91190.0 +2009-12-06 18:00:00+00:00,11.64,81.42,241.0,37.25,221.0,327.28,8.52,204.0,91106.0 +2009-12-06 19:00:00+00:00,11.99,80.78,156.0,1.73,155.0,321.42,8.87,207.0,91022.0 +2009-12-06 20:00:00+00:00,12.33,80.13,212.0,14.16,204.0,315.55,9.21,210.0,90938.0 +2009-12-06 21:00:00+00:00,12.02,82.57,190.0,16.0,182.0,314.68,8.56,212.0,90902.0 +2009-12-06 22:00:00+00:00,11.71,85.01,6.0,0.0,6.0,313.82,7.9,213.0,90866.0 +2009-12-06 23:00:00+00:00,11.41,87.45,24.0,0.0,24.0,312.95,7.24,214.0,90830.0 +2009-12-07 00:00:00+00:00,11.25,91.2,3.0,0.0,3.0,319.85,7.68,213.0,90758.0 +2009-12-07 01:00:00+00:00,11.08,94.96,0.0,0.0,0.0,326.75,8.11,212.0,90686.0 +2009-12-07 02:00:00+00:00,10.92,98.71,0.0,0.0,0.0,333.65,8.55,210.0,90613.0 +2009-12-07 03:00:00+00:00,10.72,99.14,0.0,0.0,0.0,333.67,9.39,210.0,90580.0 +2009-12-07 04:00:00+00:00,10.52,99.57,0.0,0.0,0.0,333.68,10.23,210.0,90547.0 +2009-12-07 05:00:00+00:00,10.31,100.0,0.0,0.0,0.0,333.7,11.06,210.0,90514.0 +2009-12-07 06:00:00+00:00,10.36,100.0,0.0,0.0,0.0,335.27,11.34,213.0,90520.0 +2009-12-07 07:00:00+00:00,10.4,100.0,0.0,0.0,0.0,336.83,11.62,215.0,90526.0 +2009-12-07 08:00:00+00:00,10.45,100.0,0.0,0.0,0.0,338.4,11.9,217.0,90532.0 +2009-12-07 09:00:00+00:00,10.27,96.71,0.0,0.0,0.0,341.1,11.97,223.0,90665.0 +2009-12-07 10:00:00+00:00,10.09,93.41,0.0,0.0,0.0,343.8,12.04,229.0,90797.0 +2009-12-07 11:00:00+00:00,9.91,90.12,0.0,0.0,0.0,346.5,12.11,235.0,90929.0 +2009-12-07 12:00:00+00:00,9.31,90.52,0.0,0.0,0.0,347.28,11.54,243.0,91103.0 +2009-12-07 13:00:00+00:00,8.71,90.92,0.0,0.0,0.0,348.07,10.98,252.0,91277.0 +2009-12-07 14:00:00+00:00,8.11,91.32,0.0,0.0,0.0,348.85,10.41,260.0,91452.0 +2009-12-07 15:00:00+00:00,7.92,85.04,19.0,0.0,19.0,346.92,9.1,262.0,91545.0 +2009-12-07 16:00:00+00:00,7.73,78.76,108.0,3.25,107.0,344.98,7.79,264.0,91638.0 +2009-12-07 17:00:00+00:00,7.54,72.48,162.0,11.27,157.0,343.05,6.48,266.0,91731.0 +2009-12-07 18:00:00+00:00,8.17,67.33,592.0,975.99,70.0,338.23,6.02,262.0,91665.0 +2009-12-07 19:00:00+00:00,8.8,62.17,368.0,159.77,276.0,333.42,5.55,259.0,91599.0 +2009-12-07 20:00:00+00:00,9.43,57.02,307.0,85.16,259.0,328.6,5.09,256.0,91533.0 +2009-12-07 21:00:00+00:00,9.39,59.75,186.0,12.02,180.0,316.48,4.6,253.0,91542.0 +2009-12-07 22:00:00+00:00,9.35,62.47,279.0,331.1,151.0,304.37,4.11,251.0,91551.0 +2009-12-07 23:00:00+00:00,9.32,65.2,224.0,757.0,47.0,292.25,3.63,248.0,91560.0 +2009-12-08 00:00:00+00:00,8.81,68.13,19.0,0.0,19.0,296.87,3.19,247.0,91590.0 +2009-12-08 01:00:00+00:00,8.29,71.05,0.0,0.0,0.0,301.48,2.75,245.0,91620.0 +2009-12-08 02:00:00+00:00,7.78,73.98,0.0,0.0,0.0,306.1,2.32,243.0,91650.0 +2009-12-08 03:00:00+00:00,7.59,72.68,0.0,0.0,0.0,310.33,2.27,242.0,91686.0 +2009-12-08 04:00:00+00:00,7.4,71.39,0.0,0.0,0.0,314.57,2.23,241.0,91722.0 +2009-12-08 05:00:00+00:00,7.21,70.09,0.0,0.0,0.0,318.8,2.18,240.0,91758.0 +2009-12-08 06:00:00+00:00,6.86,75.2,0.0,0.0,0.0,316.97,2.06,240.0,91755.0 +2009-12-08 07:00:00+00:00,6.5,80.31,0.0,0.0,0.0,315.13,1.93,239.0,91752.0 +2009-12-08 08:00:00+00:00,6.15,85.42,0.0,0.0,0.0,313.3,1.81,239.0,91749.0 +2009-12-08 09:00:00+00:00,5.95,87.45,0.0,0.0,0.0,314.85,1.8,234.0,91737.0 +2009-12-08 10:00:00+00:00,5.75,89.47,0.0,0.0,0.0,316.4,1.8,229.0,91725.0 +2009-12-08 11:00:00+00:00,5.56,91.5,0.0,0.0,0.0,317.95,1.79,225.0,91713.0 +2009-12-08 12:00:00+00:00,6.11,89.47,0.0,0.0,0.0,317.3,1.89,230.0,91734.0 +2009-12-08 13:00:00+00:00,6.67,87.45,0.0,0.0,0.0,316.65,1.98,235.0,91755.0 +2009-12-08 14:00:00+00:00,7.22,85.42,0.0,0.0,0.0,316.0,2.07,240.0,91776.0 +2009-12-08 15:00:00+00:00,8.35,75.72,36.0,0.0,36.0,314.58,2.43,244.0,91770.0 +2009-12-08 16:00:00+00:00,9.48,66.03,111.0,6.55,109.0,313.17,2.79,249.0,91764.0 +2009-12-08 17:00:00+00:00,10.61,56.33,279.0,185.82,197.0,311.75,3.14,254.0,91758.0 +2009-12-08 18:00:00+00:00,11.56,53.36,571.0,943.83,68.0,301.98,3.46,257.0,91656.0 +2009-12-08 19:00:00+00:00,12.51,50.39,622.0,959.49,71.0,292.22,3.77,260.0,91554.0 +2009-12-08 20:00:00+00:00,13.46,47.42,608.0,956.51,70.0,282.45,4.08,263.0,91452.0 +2009-12-08 21:00:00+00:00,13.03,52.13,529.0,929.11,66.0,276.62,3.69,262.0,91446.0 +2009-12-08 22:00:00+00:00,12.6,56.83,392.0,862.17,59.0,270.78,3.29,261.0,91440.0 +2009-12-08 23:00:00+00:00,12.18,61.54,215.0,722.77,46.0,264.95,2.9,259.0,91434.0 +2009-12-09 00:00:00+00:00,11.56,65.62,18.0,0.0,18.0,263.43,2.32,253.0,91467.0 +2009-12-09 01:00:00+00:00,10.95,69.7,0.0,0.0,0.0,261.92,1.75,246.0,91500.0 +2009-12-09 02:00:00+00:00,10.33,73.78,0.0,0.0,0.0,260.4,1.17,239.0,91533.0 +2009-12-09 03:00:00+00:00,9.27,77.61,0.0,0.0,0.0,258.65,1.1,224.0,91557.0 +2009-12-09 04:00:00+00:00,8.21,81.43,0.0,0.0,0.0,256.9,1.03,209.0,91581.0 +2009-12-09 05:00:00+00:00,7.14,85.26,0.0,0.0,0.0,255.15,0.97,194.0,91605.0 +2009-12-09 06:00:00+00:00,6.63,88.38,0.0,0.0,0.0,254.4,0.94,186.0,91605.0 +2009-12-09 07:00:00+00:00,6.13,91.49,0.0,0.0,0.0,253.65,0.91,179.0,91605.0 +2009-12-09 08:00:00+00:00,5.62,94.61,0.0,0.0,0.0,252.9,0.88,171.0,91605.0 +2009-12-09 09:00:00+00:00,5.08,96.41,0.0,0.0,0.0,254.48,1.01,154.0,91602.0 +2009-12-09 10:00:00+00:00,4.54,98.2,0.0,0.0,0.0,256.07,1.14,137.0,91599.0 +2009-12-09 11:00:00+00:00,4.01,100.0,0.0,0.0,0.0,257.65,1.27,120.0,91596.0 +2009-12-09 12:00:00+00:00,4.27,99.33,0.0,0.0,0.0,269.47,1.35,125.0,91617.0 +2009-12-09 13:00:00+00:00,4.53,98.66,0.0,0.0,0.0,281.28,1.43,129.0,91638.0 +2009-12-09 14:00:00+00:00,4.79,97.99,0.0,0.0,0.0,293.1,1.5,134.0,91659.0 +2009-12-09 15:00:00+00:00,7.35,85.37,108.0,565.35,33.0,300.25,1.77,146.0,91641.0 +2009-12-09 16:00:00+00:00,9.91,72.74,297.0,804.51,53.0,307.4,2.05,158.0,91623.0 +2009-12-09 17:00:00+00:00,12.46,60.12,459.0,901.64,63.0,314.55,2.32,170.0,91605.0 +2009-12-09 18:00:00+00:00,13.65,54.03,572.0,948.93,68.0,299.23,2.57,192.0,91533.0 +2009-12-09 19:00:00+00:00,14.83,47.95,623.0,963.69,71.0,283.92,2.81,214.0,91461.0 +2009-12-09 20:00:00+00:00,16.02,41.86,608.0,958.34,70.0,268.6,3.06,236.0,91388.0 +2009-12-09 21:00:00+00:00,15.01,47.59,528.0,928.33,66.0,267.7,2.86,246.0,91406.0 +2009-12-09 22:00:00+00:00,14.0,53.31,391.0,860.16,59.0,266.8,2.66,256.0,91425.0 +2009-12-09 23:00:00+00:00,13.0,59.04,83.0,0.0,83.0,265.9,2.46,265.0,91443.0 +2009-12-10 00:00:00+00:00,12.39,60.88,13.0,0.0,13.0,263.23,2.1,262.0,91470.0 +2009-12-10 01:00:00+00:00,11.79,62.72,0.0,0.0,0.0,260.57,1.74,259.0,91497.0 +2009-12-10 02:00:00+00:00,11.18,64.56,0.0,0.0,0.0,257.9,1.38,255.0,91524.0 +2009-12-10 03:00:00+00:00,10.64,65.23,0.0,0.0,0.0,256.22,1.18,245.0,91557.0 +2009-12-10 04:00:00+00:00,10.1,65.91,0.0,0.0,0.0,254.53,0.97,234.0,91590.0 +2009-12-10 05:00:00+00:00,9.56,66.58,0.0,0.0,0.0,252.85,0.77,223.0,91623.0 +2009-12-10 06:00:00+00:00,8.24,73.64,0.0,0.0,0.0,252.47,0.71,198.0,91626.0 +2009-12-10 07:00:00+00:00,6.91,80.7,0.0,0.0,0.0,252.08,0.65,172.0,91629.0 +2009-12-10 08:00:00+00:00,5.59,87.76,0.0,0.0,0.0,251.7,0.59,146.0,91632.0 +2009-12-10 09:00:00+00:00,5.03,90.58,0.0,0.0,0.0,251.6,0.74,138.0,91641.0 +2009-12-10 10:00:00+00:00,4.48,93.39,0.0,0.0,0.0,251.5,0.9,130.0,91650.0 +2009-12-10 11:00:00+00:00,3.93,96.21,0.0,0.0,0.0,251.4,1.05,121.0,91659.0 +2009-12-10 12:00:00+00:00,3.98,97.16,0.0,0.0,0.0,250.9,1.29,124.0,91683.0 +2009-12-10 13:00:00+00:00,4.04,98.1,0.0,0.0,0.0,250.4,1.53,127.0,91707.0 +2009-12-10 14:00:00+00:00,4.1,99.05,0.0,0.0,0.0,249.9,1.77,129.0,91731.0 +2009-12-10 15:00:00+00:00,7.44,83.02,104.0,544.69,33.0,254.22,1.75,146.0,91722.0 +2009-12-10 16:00:00+00:00,10.77,66.99,290.0,790.48,52.0,258.53,1.73,163.0,91713.0 +2009-12-10 17:00:00+00:00,14.1,50.96,452.0,892.05,62.0,262.85,1.71,179.0,91704.0 +2009-12-10 18:00:00+00:00,15.09,45.83,481.0,625.23,150.0,264.52,2.17,201.0,91623.0 +2009-12-10 19:00:00+00:00,16.07,40.7,617.0,957.23,70.0,266.18,2.63,222.0,91542.0 +2009-12-10 20:00:00+00:00,17.06,35.57,603.0,951.06,70.0,267.85,3.09,243.0,91461.0 +2009-12-10 21:00:00+00:00,16.16,40.3,525.0,923.33,66.0,267.25,2.88,251.0,91461.0 +2009-12-10 22:00:00+00:00,15.26,45.02,390.0,857.91,59.0,266.65,2.68,259.0,91461.0 +2009-12-10 23:00:00+00:00,14.37,49.75,213.0,713.27,46.0,266.05,2.47,267.0,91461.0 +2009-12-11 00:00:00+00:00,13.37,56.44,18.0,0.0,18.0,265.53,2.23,266.0,91509.0 +2009-12-11 01:00:00+00:00,12.38,63.13,0.0,0.0,0.0,265.02,1.98,266.0,91557.0 +2009-12-11 02:00:00+00:00,11.38,69.82,0.0,0.0,0.0,264.5,1.74,266.0,91605.0 +2009-12-11 03:00:00+00:00,11.25,67.64,0.0,0.0,0.0,267.67,1.47,263.0,91626.0 +2009-12-11 04:00:00+00:00,11.12,65.45,0.0,0.0,0.0,270.83,1.2,259.0,91647.0 +2009-12-11 05:00:00+00:00,10.99,63.27,0.0,0.0,0.0,274.0,0.92,256.0,91668.0 +2009-12-11 06:00:00+00:00,10.31,68.53,0.0,0.0,0.0,270.97,0.89,247.0,91680.0 +2009-12-11 07:00:00+00:00,9.64,73.8,0.0,0.0,0.0,267.93,0.86,237.0,91692.0 +2009-12-11 08:00:00+00:00,8.96,79.06,0.0,0.0,0.0,264.9,0.83,228.0,91704.0 +2009-12-11 09:00:00+00:00,8.07,81.76,0.0,0.0,0.0,261.27,0.68,214.0,91710.0 +2009-12-11 10:00:00+00:00,7.18,84.45,0.0,0.0,0.0,257.63,0.53,200.0,91716.0 +2009-12-11 11:00:00+00:00,6.3,87.15,0.0,0.0,0.0,254.0,0.39,187.0,91722.0 +2009-12-11 12:00:00+00:00,6.09,87.38,0.0,0.0,0.0,253.3,0.75,176.0,91764.0 +2009-12-11 13:00:00+00:00,5.89,87.61,0.0,0.0,0.0,252.6,1.11,166.0,91806.0 +2009-12-11 14:00:00+00:00,5.69,87.84,0.0,0.0,0.0,251.9,1.48,156.0,91848.0 +2009-12-11 15:00:00+00:00,8.66,74.11,102.0,546.42,32.0,255.47,1.58,174.0,91857.0 +2009-12-11 16:00:00+00:00,11.63,60.39,288.0,789.42,52.0,259.03,1.69,192.0,91866.0 +2009-12-11 17:00:00+00:00,14.6,46.66,450.0,891.38,62.0,262.6,1.79,211.0,91875.0 +2009-12-11 18:00:00+00:00,15.46,45.55,564.0,939.77,68.0,263.2,2.29,222.0,91800.0 +2009-12-11 19:00:00+00:00,16.31,44.44,449.0,352.52,248.0,263.8,2.78,232.0,91725.0 +2009-12-11 20:00:00+00:00,17.17,43.33,438.0,352.06,241.0,264.4,3.27,243.0,91650.0 +2009-12-11 21:00:00+00:00,16.48,48.81,415.0,471.14,181.0,263.62,2.89,245.0,91632.0 +2009-12-11 22:00:00+00:00,15.79,54.29,392.0,863.2,59.0,262.83,2.51,247.0,91614.0 +2009-12-11 23:00:00+00:00,15.1,59.77,215.0,720.87,46.0,262.05,2.14,249.0,91596.0 +2009-12-12 00:00:00+00:00,14.78,61.1,18.0,0.0,18.0,261.42,1.51,233.0,91617.0 +2009-12-12 01:00:00+00:00,14.45,62.44,0.0,0.0,0.0,260.78,0.89,218.0,91638.0 +2009-12-12 02:00:00+00:00,14.13,63.77,0.0,0.0,0.0,260.15,0.26,202.0,91659.0 +2009-12-12 03:00:00+00:00,12.62,71.78,0.0,0.0,0.0,259.03,0.74,187.0,91656.0 +2009-12-12 04:00:00+00:00,11.1,79.8,0.0,0.0,0.0,257.92,1.22,171.0,91653.0 +2009-12-12 05:00:00+00:00,9.58,87.81,0.0,0.0,0.0,256.8,1.7,156.0,91650.0 +2009-12-12 06:00:00+00:00,8.89,88.79,0.0,0.0,0.0,255.8,1.83,159.0,91623.0 +2009-12-12 07:00:00+00:00,8.2,89.76,0.0,0.0,0.0,254.8,1.95,162.0,91596.0 +2009-12-12 08:00:00+00:00,7.51,90.74,0.0,0.0,0.0,253.8,2.08,165.0,91569.0 +2009-12-12 09:00:00+00:00,7.39,89.3,0.0,0.0,0.0,254.95,2.17,167.0,91554.0 +2009-12-12 10:00:00+00:00,7.28,87.87,0.0,0.0,0.0,256.1,2.25,169.0,91539.0 +2009-12-12 11:00:00+00:00,7.17,86.43,0.0,0.0,0.0,257.25,2.33,171.0,91524.0 +2009-12-12 12:00:00+00:00,7.65,84.04,0.0,0.0,0.0,257.22,2.35,177.0,91554.0 +2009-12-12 13:00:00+00:00,8.14,81.66,0.0,0.0,0.0,257.18,2.38,182.0,91584.0 +2009-12-12 14:00:00+00:00,8.63,79.27,0.0,0.0,0.0,257.15,2.4,187.0,91614.0 +2009-12-12 15:00:00+00:00,11.15,71.44,100.0,539.96,32.0,259.63,2.8,199.0,91596.0 +2009-12-12 16:00:00+00:00,13.67,63.6,117.0,20.21,111.0,262.12,3.21,210.0,91578.0 +2009-12-12 17:00:00+00:00,16.19,55.77,323.0,343.75,174.0,264.6,3.61,221.0,91560.0 +2009-12-12 18:00:00+00:00,16.78,54.42,414.0,368.63,220.0,266.68,4.48,227.0,91479.0 +2009-12-12 19:00:00+00:00,17.37,53.06,446.0,346.2,249.0,268.77,5.34,233.0,91397.0 +2009-12-12 20:00:00+00:00,17.96,51.71,398.0,246.95,260.0,270.85,6.21,239.0,91316.0 +2009-12-12 21:00:00+00:00,17.15,58.89,348.0,251.85,223.0,271.92,5.56,243.0,91343.0 +2009-12-12 22:00:00+00:00,16.35,66.06,173.0,44.06,156.0,272.98,4.91,246.0,91370.0 +2009-12-12 23:00:00+00:00,15.55,73.24,104.0,55.36,91.0,274.05,4.26,249.0,91397.0 +2009-12-13 00:00:00+00:00,14.75,77.96,19.0,0.0,19.0,274.27,3.44,248.0,91419.0 +2009-12-13 01:00:00+00:00,13.96,82.68,0.0,0.0,0.0,274.48,2.62,247.0,91440.0 +2009-12-13 02:00:00+00:00,13.16,87.4,0.0,0.0,0.0,274.7,1.79,246.0,91461.0 +2009-12-13 03:00:00+00:00,12.79,87.56,0.0,0.0,0.0,273.82,1.64,239.0,91476.0 +2009-12-13 04:00:00+00:00,12.42,87.72,0.0,0.0,0.0,272.93,1.48,232.0,91491.0 +2009-12-13 05:00:00+00:00,12.05,87.88,0.0,0.0,0.0,272.05,1.32,225.0,91506.0 +2009-12-13 06:00:00+00:00,11.5,90.59,0.0,0.0,0.0,270.98,1.22,222.0,91509.0 +2009-12-13 07:00:00+00:00,10.95,93.31,0.0,0.0,0.0,269.92,1.12,218.0,91512.0 +2009-12-13 08:00:00+00:00,10.4,96.02,0.0,0.0,0.0,268.85,1.02,215.0,91515.0 +2009-12-13 09:00:00+00:00,9.96,97.35,0.0,0.0,0.0,268.48,0.93,207.0,91527.0 +2009-12-13 10:00:00+00:00,9.53,98.67,0.0,0.0,0.0,268.12,0.84,199.0,91539.0 +2009-12-13 11:00:00+00:00,9.1,100.0,0.0,0.0,0.0,267.75,0.74,191.0,91551.0 +2009-12-13 12:00:00+00:00,8.95,99.61,0.0,0.0,0.0,267.93,0.89,195.0,91575.0 +2009-12-13 13:00:00+00:00,8.81,99.22,0.0,0.0,0.0,268.12,1.04,198.0,91599.0 +2009-12-13 14:00:00+00:00,8.67,98.83,0.0,0.0,0.0,268.3,1.19,202.0,91623.0 +2009-12-13 15:00:00+00:00,10.26,89.58,51.0,56.53,44.0,271.28,1.45,214.0,91656.0 +2009-12-13 16:00:00+00:00,11.85,80.34,149.0,91.54,122.0,274.27,1.72,226.0,91689.0 +2009-12-13 17:00:00+00:00,13.43,71.09,106.0,0.0,106.0,277.25,1.99,238.0,91722.0 +2009-12-13 18:00:00+00:00,14.23,64.12,318.0,137.18,246.0,277.12,2.68,246.0,91674.0 +2009-12-13 19:00:00+00:00,15.02,57.16,363.0,160.22,272.0,276.98,3.37,254.0,91626.0 +2009-12-13 20:00:00+00:00,15.82,50.19,596.0,944.15,69.0,276.85,4.07,261.0,91578.0 +2009-12-13 21:00:00+00:00,15.26,50.4,522.0,921.18,65.0,273.75,3.66,274.0,91599.0 +2009-12-13 22:00:00+00:00,14.7,50.62,390.0,860.12,58.0,270.65,3.25,286.0,91620.0 +2009-12-13 23:00:00+00:00,14.14,50.83,217.0,726.58,46.0,267.55,2.84,298.0,91641.0 +2009-12-14 00:00:00+00:00,12.97,55.93,19.0,0.0,19.0,264.97,2.77,318.0,91686.0 +2009-12-14 01:00:00+00:00,11.8,61.04,0.0,0.0,0.0,262.38,2.7,338.0,91731.0 +2009-12-14 02:00:00+00:00,10.63,66.14,0.0,0.0,0.0,259.8,2.63,357.0,91776.0 +2009-12-14 03:00:00+00:00,10.25,68.38,0.0,0.0,0.0,258.68,2.55,8.0,91818.0 +2009-12-14 04:00:00+00:00,9.87,70.61,0.0,0.0,0.0,257.57,2.46,18.0,91860.0 +2009-12-14 05:00:00+00:00,9.48,72.85,0.0,0.0,0.0,256.45,2.37,29.0,91902.0 +2009-12-14 06:00:00+00:00,8.97,75.03,0.0,0.0,0.0,254.17,2.32,36.0,91908.0 +2009-12-14 07:00:00+00:00,8.47,77.2,0.0,0.0,0.0,251.88,2.27,43.0,91914.0 +2009-12-14 08:00:00+00:00,7.96,79.38,0.0,0.0,0.0,249.6,2.22,51.0,91920.0 +2009-12-14 09:00:00+00:00,7.43,81.55,0.0,0.0,0.0,247.57,2.3,55.0,91941.0 +2009-12-14 10:00:00+00:00,6.91,83.73,0.0,0.0,0.0,245.53,2.38,59.0,91962.0 +2009-12-14 11:00:00+00:00,6.39,85.9,0.0,0.0,0.0,243.5,2.46,64.0,91983.0 +2009-12-14 12:00:00+00:00,6.32,87.98,0.0,0.0,0.0,243.22,2.43,64.0,92058.0 +2009-12-14 13:00:00+00:00,6.25,90.06,0.0,0.0,0.0,242.93,2.41,64.0,92133.0 +2009-12-14 14:00:00+00:00,6.18,92.14,0.0,0.0,0.0,242.65,2.39,64.0,92209.0 +2009-12-14 15:00:00+00:00,8.96,78.07,101.0,566.47,32.0,245.1,2.89,68.0,92227.0 +2009-12-14 16:00:00+00:00,11.73,64.0,294.0,825.77,52.0,247.55,3.4,72.0,92245.0 +2009-12-14 17:00:00+00:00,14.5,49.93,462.0,927.73,63.0,250.0,3.9,76.0,92263.0 +2009-12-14 18:00:00+00:00,15.65,44.41,581.0,979.89,68.0,251.6,4.57,79.0,92188.0 +2009-12-14 19:00:00+00:00,16.81,38.9,637.0,998.17,71.0,253.2,5.25,81.0,92112.0 +2009-12-14 20:00:00+00:00,17.96,33.38,625.0,995.26,70.0,254.8,5.92,84.0,92037.0 +2009-12-14 21:00:00+00:00,17.3,34.1,547.0,967.78,67.0,254.12,5.63,83.0,92046.0 +2009-12-14 22:00:00+00:00,16.65,34.83,407.0,900.95,59.0,253.43,5.34,82.0,92055.0 +2009-12-14 23:00:00+00:00,16.0,35.55,226.0,762.87,46.0,252.75,5.05,82.0,92064.0 +2009-12-15 00:00:00+00:00,14.45,42.13,20.0,0.0,20.0,251.9,4.31,79.0,92082.0 +2009-12-15 01:00:00+00:00,12.9,48.72,0.0,0.0,0.0,251.05,3.58,77.0,92100.0 +2009-12-15 02:00:00+00:00,11.35,55.3,0.0,0.0,0.0,250.2,2.84,75.0,92118.0 +2009-12-15 03:00:00+00:00,10.54,57.48,0.0,0.0,0.0,248.88,2.92,78.0,92142.0 +2009-12-15 04:00:00+00:00,9.73,59.65,0.0,0.0,0.0,247.57,3.0,80.0,92166.0 +2009-12-15 05:00:00+00:00,8.92,61.83,0.0,0.0,0.0,246.25,3.08,82.0,92191.0 +2009-12-15 06:00:00+00:00,8.37,62.7,0.0,0.0,0.0,245.62,3.08,82.0,92179.0 +2009-12-15 07:00:00+00:00,7.82,63.58,0.0,0.0,0.0,244.98,3.09,83.0,92166.0 +2009-12-15 08:00:00+00:00,7.27,64.45,0.0,0.0,0.0,244.35,3.09,83.0,92154.0 +2009-12-15 09:00:00+00:00,6.66,66.51,0.0,0.0,0.0,243.3,2.93,79.0,92160.0 +2009-12-15 10:00:00+00:00,6.06,68.58,0.0,0.0,0.0,242.25,2.77,75.0,92166.0 +2009-12-15 11:00:00+00:00,5.46,70.64,0.0,0.0,0.0,241.2,2.61,72.0,92172.0 +2009-12-15 12:00:00+00:00,5.75,71.04,0.0,0.0,0.0,241.2,2.57,71.0,92160.0 +2009-12-15 13:00:00+00:00,6.04,71.45,0.0,0.0,0.0,241.2,2.52,71.0,92148.0 +2009-12-15 14:00:00+00:00,6.33,71.85,0.0,0.0,0.0,241.2,2.48,71.0,92136.0 +2009-12-15 15:00:00+00:00,9.59,62.75,94.0,525.63,31.0,244.28,2.62,73.0,92133.0 +2009-12-15 16:00:00+00:00,12.84,53.64,281.0,789.66,51.0,247.37,2.76,76.0,92130.0 +2009-12-15 17:00:00+00:00,16.09,44.54,445.0,893.74,62.0,250.45,2.9,78.0,92127.0 +2009-12-15 18:00:00+00:00,17.44,41.08,560.0,943.88,67.0,253.03,2.85,80.0,92025.0 +2009-12-15 19:00:00+00:00,18.8,37.61,470.0,425.64,229.0,255.62,2.8,81.0,91923.0 +2009-12-15 20:00:00+00:00,20.15,34.15,469.0,450.45,218.0,258.2,2.76,83.0,91821.0 +2009-12-15 21:00:00+00:00,19.26,36.37,410.0,453.66,185.0,258.1,2.57,82.0,91797.0 +2009-12-15 22:00:00+00:00,18.37,38.59,295.0,395.73,142.0,258.0,2.39,80.0,91773.0 +2009-12-15 23:00:00+00:00,17.48,40.81,218.0,726.81,46.0,257.9,2.21,78.0,91749.0 +2009-12-16 00:00:00+00:00,15.68,47.97,19.0,0.0,19.0,257.2,2.29,75.0,91755.0 +2009-12-16 01:00:00+00:00,13.88,55.14,0.0,0.0,0.0,256.5,2.38,72.0,91761.0 +2009-12-16 02:00:00+00:00,12.08,62.3,0.0,0.0,0.0,255.8,2.47,68.0,91767.0 +2009-12-16 03:00:00+00:00,11.03,67.41,0.0,0.0,0.0,254.35,2.4,70.0,91773.0 +2009-12-16 04:00:00+00:00,9.97,72.51,0.0,0.0,0.0,252.9,2.34,71.0,91779.0 +2009-12-16 05:00:00+00:00,8.91,77.62,0.0,0.0,0.0,251.45,2.28,73.0,91785.0 +2009-12-16 06:00:00+00:00,8.35,80.54,0.0,0.0,0.0,250.02,2.23,72.0,91788.0 +2009-12-16 07:00:00+00:00,7.8,83.46,0.0,0.0,0.0,248.58,2.17,71.0,91791.0 +2009-12-16 08:00:00+00:00,7.24,86.38,0.0,0.0,0.0,247.15,2.12,70.0,91794.0 +2009-12-16 09:00:00+00:00,6.82,88.39,0.0,0.0,0.0,246.28,2.13,72.0,91791.0 +2009-12-16 10:00:00+00:00,6.4,90.4,0.0,0.0,0.0,245.42,2.13,74.0,91788.0 +2009-12-16 11:00:00+00:00,5.98,92.41,0.0,0.0,0.0,244.55,2.14,76.0,91785.0 +2009-12-16 12:00:00+00:00,6.15,91.34,0.0,0.0,0.0,244.72,2.06,78.0,91791.0 +2009-12-16 13:00:00+00:00,6.33,90.26,0.0,0.0,0.0,244.88,1.99,80.0,91797.0 +2009-12-16 14:00:00+00:00,6.5,89.19,0.0,0.0,0.0,245.05,1.92,82.0,91803.0 +2009-12-16 15:00:00+00:00,10.01,74.37,92.0,517.04,31.0,249.08,1.88,82.0,91806.0 +2009-12-16 16:00:00+00:00,13.52,59.56,278.0,783.96,51.0,253.12,1.84,83.0,91809.0 +2009-12-16 17:00:00+00:00,17.03,44.74,443.0,894.43,61.0,257.15,1.81,83.0,91812.0 +2009-12-16 18:00:00+00:00,18.6,40.13,561.0,947.82,67.0,260.42,1.61,83.0,91713.0 +2009-12-16 19:00:00+00:00,20.17,35.53,618.0,969.1,70.0,263.68,1.42,83.0,91614.0 +2009-12-16 20:00:00+00:00,21.74,30.92,608.0,967.86,69.0,266.95,1.23,83.0,91515.0 +2009-12-16 21:00:00+00:00,21.51,33.84,533.0,941.42,66.0,267.0,1.08,74.0,91506.0 +2009-12-16 22:00:00+00:00,21.28,36.76,400.0,880.91,59.0,267.05,0.92,65.0,91497.0 +2009-12-16 23:00:00+00:00,21.05,39.68,224.0,749.64,46.0,267.1,0.77,56.0,91488.0 +2009-12-17 00:00:00+00:00,19.14,44.7,20.0,0.0,20.0,265.5,0.93,63.0,91494.0 +2009-12-17 01:00:00+00:00,17.24,49.72,0.0,0.0,0.0,263.9,1.09,70.0,91500.0 +2009-12-17 02:00:00+00:00,15.33,54.74,0.0,0.0,0.0,262.3,1.26,78.0,91506.0 +2009-12-17 03:00:00+00:00,13.7,60.54,0.0,0.0,0.0,261.17,1.36,79.0,91521.0 +2009-12-17 04:00:00+00:00,12.07,66.35,0.0,0.0,0.0,260.03,1.47,81.0,91536.0 +2009-12-17 05:00:00+00:00,10.44,72.15,0.0,0.0,0.0,258.9,1.57,82.0,91551.0 +2009-12-17 06:00:00+00:00,9.67,75.32,0.0,0.0,0.0,257.13,1.61,83.0,91554.0 +2009-12-17 07:00:00+00:00,8.91,78.49,0.0,0.0,0.0,255.37,1.66,83.0,91557.0 +2009-12-17 08:00:00+00:00,8.14,81.66,0.0,0.0,0.0,253.6,1.7,84.0,91560.0 +2009-12-17 09:00:00+00:00,7.46,83.53,0.0,0.0,0.0,252.05,1.71,82.0,91569.0 +2009-12-17 10:00:00+00:00,6.78,85.41,0.0,0.0,0.0,250.5,1.71,80.0,91578.0 +2009-12-17 11:00:00+00:00,6.1,87.28,0.0,0.0,0.0,248.95,1.72,79.0,91587.0 +2009-12-17 12:00:00+00:00,5.98,87.01,0.0,0.0,0.0,247.45,1.78,80.0,91596.0 +2009-12-17 13:00:00+00:00,5.87,86.73,0.0,0.0,0.0,245.95,1.83,82.0,91605.0 +2009-12-17 14:00:00+00:00,5.75,86.46,0.0,0.0,0.0,244.45,1.89,84.0,91614.0 +2009-12-17 15:00:00+00:00,9.85,71.22,93.0,533.65,31.0,248.85,1.7,86.0,91623.0 +2009-12-17 16:00:00+00:00,13.95,55.98,282.0,802.26,51.0,253.25,1.51,88.0,91632.0 +2009-12-17 17:00:00+00:00,18.04,40.74,447.0,904.32,62.0,257.65,1.32,91.0,91641.0 +2009-12-17 18:00:00+00:00,19.24,36.28,564.0,955.43,67.0,261.55,0.98,87.0,91545.0 +2009-12-17 19:00:00+00:00,20.45,31.83,620.0,973.7,70.0,265.45,0.63,83.0,91449.0 +2009-12-17 20:00:00+00:00,21.65,27.37,610.0,971.81,69.0,269.35,0.29,79.0,91352.0 +2009-12-17 21:00:00+00:00,20.7,29.07,534.0,943.05,66.0,268.47,0.52,45.0,91340.0 +2009-12-17 22:00:00+00:00,19.76,30.76,400.0,879.6,59.0,267.58,0.76,12.0,91328.0 +2009-12-17 23:00:00+00:00,18.82,32.46,223.0,742.64,46.0,266.7,0.99,338.0,91316.0 +2009-12-18 00:00:00+00:00,17.3,35.97,20.0,0.0,20.0,264.23,0.98,359.0,91313.0 +2009-12-18 01:00:00+00:00,15.77,39.49,0.0,0.0,0.0,261.77,0.97,20.0,91310.0 +2009-12-18 02:00:00+00:00,14.25,43.0,0.0,0.0,0.0,259.3,0.97,40.0,91307.0 +2009-12-18 03:00:00+00:00,13.09,47.63,0.0,0.0,0.0,258.8,1.17,54.0,91325.0 +2009-12-18 04:00:00+00:00,11.92,52.25,0.0,0.0,0.0,258.3,1.38,68.0,91343.0 +2009-12-18 05:00:00+00:00,10.75,56.88,0.0,0.0,0.0,257.8,1.59,81.0,91361.0 +2009-12-18 06:00:00+00:00,9.89,60.4,0.0,0.0,0.0,256.6,1.71,81.0,91361.0 +2009-12-18 07:00:00+00:00,9.02,63.93,0.0,0.0,0.0,255.4,1.83,81.0,91361.0 +2009-12-18 08:00:00+00:00,8.16,67.45,0.0,0.0,0.0,254.2,1.94,81.0,91361.0 +2009-12-18 09:00:00+00:00,7.42,69.9,0.0,0.0,0.0,253.12,1.99,80.0,91382.0 +2009-12-18 10:00:00+00:00,6.68,72.34,0.0,0.0,0.0,252.03,2.04,80.0,91403.0 +2009-12-18 11:00:00+00:00,5.95,74.79,0.0,0.0,0.0,250.95,2.08,79.0,91425.0 +2009-12-18 12:00:00+00:00,5.82,74.4,0.0,0.0,0.0,249.0,2.14,76.0,91482.0 +2009-12-18 13:00:00+00:00,5.69,74.02,0.0,0.0,0.0,247.05,2.19,74.0,91539.0 +2009-12-18 14:00:00+00:00,5.56,73.63,0.0,0.0,0.0,245.1,2.25,71.0,91596.0 +2009-12-18 15:00:00+00:00,9.39,60.86,91.0,532.92,30.0,248.93,2.56,72.0,91638.0 +2009-12-18 16:00:00+00:00,13.22,48.08,279.0,796.08,51.0,252.77,2.87,72.0,91680.0 +2009-12-18 17:00:00+00:00,17.04,35.31,445.0,902.28,62.0,256.6,3.19,73.0,91722.0 +2009-12-18 18:00:00+00:00,18.06,31.94,563.0,955.17,67.0,258.12,3.97,78.0,91668.0 +2009-12-18 19:00:00+00:00,19.09,28.56,620.0,974.59,70.0,259.63,4.75,83.0,91614.0 +2009-12-18 20:00:00+00:00,20.11,25.19,611.0,971.98,70.0,261.15,5.53,88.0,91560.0 +2009-12-18 21:00:00+00:00,19.33,26.42,413.0,459.15,185.0,260.35,5.08,87.0,91581.0 +2009-12-18 22:00:00+00:00,18.56,27.66,310.0,453.19,134.0,259.55,4.62,87.0,91602.0 +2009-12-18 23:00:00+00:00,17.79,28.89,227.0,752.1,47.0,258.75,4.17,86.0,91623.0 +2009-12-19 00:00:00+00:00,16.04,33.23,20.0,0.0,20.0,257.97,3.64,81.0,91671.0 +2009-12-19 01:00:00+00:00,14.28,37.58,0.0,0.0,0.0,257.18,3.12,76.0,91719.0 +2009-12-19 02:00:00+00:00,12.53,41.92,0.0,0.0,0.0,256.4,2.59,70.0,91767.0 +2009-12-19 03:00:00+00:00,11.54,46.01,0.0,0.0,0.0,254.53,2.54,71.0,91782.0 +2009-12-19 04:00:00+00:00,10.55,50.09,0.0,0.0,0.0,252.67,2.48,72.0,91797.0 +2009-12-19 05:00:00+00:00,9.56,54.18,0.0,0.0,0.0,250.8,2.43,73.0,91812.0 +2009-12-19 06:00:00+00:00,8.85,57.92,0.0,0.0,0.0,248.32,2.36,73.0,91812.0 +2009-12-19 07:00:00+00:00,8.15,61.66,0.0,0.0,0.0,245.83,2.3,72.0,91812.0 +2009-12-19 08:00:00+00:00,7.44,65.4,0.0,0.0,0.0,243.35,2.23,72.0,91812.0 +2009-12-19 09:00:00+00:00,6.83,68.3,0.0,0.0,0.0,241.9,2.21,75.0,91821.0 +2009-12-19 10:00:00+00:00,6.22,71.19,0.0,0.0,0.0,240.45,2.19,77.0,91830.0 +2009-12-19 11:00:00+00:00,5.62,74.09,0.0,0.0,0.0,239.0,2.17,80.0,91839.0 +2009-12-19 12:00:00+00:00,5.87,72.72,0.0,0.0,0.0,238.22,2.12,82.0,91878.0 +2009-12-19 13:00:00+00:00,6.12,71.35,0.0,0.0,0.0,237.43,2.07,84.0,91917.0 +2009-12-19 14:00:00+00:00,6.37,69.98,0.0,0.0,0.0,236.65,2.03,85.0,91956.0 +2009-12-19 15:00:00+00:00,9.76,58.98,91.0,540.66,30.0,240.55,2.0,89.0,91971.0 +2009-12-19 16:00:00+00:00,13.15,47.99,281.0,807.12,51.0,244.45,1.98,92.0,91986.0 +2009-12-19 17:00:00+00:00,16.53,36.99,447.0,909.47,62.0,248.35,1.96,96.0,92001.0 +2009-12-19 18:00:00+00:00,17.98,33.41,414.0,391.53,211.0,252.22,1.82,114.0,91914.0 +2009-12-19 19:00:00+00:00,19.44,29.82,508.0,585.17,178.0,256.08,1.67,132.0,91827.0 +2009-12-19 20:00:00+00:00,20.89,26.24,439.0,357.52,240.0,259.95,1.53,151.0,91740.0 +2009-12-19 21:00:00+00:00,20.11,28.03,395.0,392.36,200.0,261.55,1.38,159.0,91713.0 +2009-12-19 22:00:00+00:00,19.34,29.82,292.0,370.05,148.0,263.15,1.23,168.0,91686.0 +2009-12-19 23:00:00+00:00,18.57,31.61,90.0,8.32,88.0,264.75,1.08,176.0,91659.0 +2009-12-20 00:00:00+00:00,18.21,34.38,22.0,0.0,22.0,267.35,1.23,166.0,91695.0 +2009-12-20 01:00:00+00:00,17.84,37.15,0.0,0.0,0.0,269.95,1.38,155.0,91731.0 +2009-12-20 02:00:00+00:00,17.48,39.92,0.0,0.0,0.0,272.55,1.53,145.0,91767.0 +2009-12-20 03:00:00+00:00,16.32,45.72,0.0,0.0,0.0,274.8,1.62,148.0,91776.0 +2009-12-20 04:00:00+00:00,15.16,51.51,0.0,0.0,0.0,277.05,1.71,151.0,91785.0 +2009-12-20 05:00:00+00:00,13.99,57.31,0.0,0.0,0.0,279.3,1.79,154.0,91794.0 +2009-12-20 06:00:00+00:00,13.17,58.36,0.0,0.0,0.0,279.82,1.69,156.0,91782.0 +2009-12-20 07:00:00+00:00,12.35,59.42,0.0,0.0,0.0,280.33,1.59,158.0,91770.0 +2009-12-20 08:00:00+00:00,11.53,60.47,0.0,0.0,0.0,280.85,1.49,160.0,91758.0 +2009-12-20 09:00:00+00:00,11.42,61.95,0.0,0.0,0.0,280.6,1.34,162.0,91758.0 +2009-12-20 10:00:00+00:00,11.32,63.42,0.0,0.0,0.0,280.35,1.19,164.0,91758.0 +2009-12-20 11:00:00+00:00,11.22,64.9,0.0,0.0,0.0,280.1,1.03,166.0,91758.0 +2009-12-20 12:00:00+00:00,10.74,62.53,0.0,0.0,0.0,276.38,1.15,162.0,91767.0 +2009-12-20 13:00:00+00:00,10.27,60.15,0.0,0.0,0.0,272.67,1.26,158.0,91776.0 +2009-12-20 14:00:00+00:00,9.8,57.78,0.0,0.0,0.0,268.95,1.38,155.0,91785.0 +2009-12-20 15:00:00+00:00,12.32,49.2,66.0,251.64,38.0,271.98,1.43,167.0,91788.0 +2009-12-20 16:00:00+00:00,14.84,40.63,207.0,398.43,94.0,275.02,1.47,180.0,91791.0 +2009-12-20 17:00:00+00:00,17.35,32.05,329.0,404.96,158.0,278.05,1.52,192.0,91794.0 +2009-12-20 18:00:00+00:00,18.19,28.84,379.0,285.83,231.0,278.4,2.13,204.0,91686.0 +2009-12-20 19:00:00+00:00,19.03,25.62,507.0,581.93,179.0,278.75,2.74,215.0,91578.0 +2009-12-20 20:00:00+00:00,19.87,22.41,471.0,454.44,218.0,279.1,3.35,226.0,91470.0 +2009-12-20 21:00:00+00:00,19.04,24.4,1.0,0.0,1.0,279.03,3.13,230.0,91446.0 +2009-12-20 22:00:00+00:00,18.21,26.39,305.0,420.49,141.0,278.97,2.9,234.0,91422.0 +2009-12-20 23:00:00+00:00,17.38,28.38,130.0,136.59,97.0,278.9,2.68,237.0,91397.0 +2009-12-21 00:00:00+00:00,16.01,31.82,22.0,0.0,22.0,281.23,2.53,231.0,91391.0 +2009-12-21 01:00:00+00:00,14.63,35.25,0.0,0.0,0.0,283.57,2.39,225.0,91385.0 +2009-12-21 02:00:00+00:00,13.26,38.69,0.0,0.0,0.0,285.9,2.25,218.0,91379.0 +2009-12-21 03:00:00+00:00,12.75,41.35,0.0,0.0,0.0,286.95,2.32,213.0,91376.0 +2009-12-21 04:00:00+00:00,12.24,44.0,0.0,0.0,0.0,288.0,2.4,207.0,91373.0 +2009-12-21 05:00:00+00:00,11.73,46.66,0.0,0.0,0.0,289.05,2.47,201.0,91370.0 +2009-12-21 06:00:00+00:00,11.56,47.43,0.0,0.0,0.0,288.8,2.5,200.0,91334.0 +2009-12-21 07:00:00+00:00,11.38,48.19,0.0,0.0,0.0,288.55,2.52,198.0,91298.0 +2009-12-21 08:00:00+00:00,11.21,48.96,0.0,0.0,0.0,288.3,2.55,197.0,91262.0 +2009-12-21 09:00:00+00:00,11.0,50.02,0.0,0.0,0.0,290.38,2.59,196.0,91235.0 +2009-12-21 10:00:00+00:00,10.79,51.08,0.0,0.0,0.0,292.47,2.63,196.0,91208.0 +2009-12-21 11:00:00+00:00,10.59,52.14,0.0,0.0,0.0,294.55,2.68,196.0,91181.0 +2009-12-21 12:00:00+00:00,10.86,53.4,0.0,0.0,0.0,298.63,3.0,195.0,91124.0 +2009-12-21 13:00:00+00:00,11.13,54.66,0.0,0.0,0.0,302.72,3.32,193.0,91067.0 +2009-12-21 14:00:00+00:00,11.4,55.92,0.0,0.0,0.0,306.8,3.64,191.0,91010.0 +2009-12-21 15:00:00+00:00,12.64,51.64,18.0,0.0,18.0,306.77,4.88,194.0,90950.0 +2009-12-21 16:00:00+00:00,13.87,47.35,158.0,152.29,115.0,306.73,6.12,197.0,90890.0 +2009-12-21 17:00:00+00:00,15.1,43.07,71.0,0.0,71.0,306.7,7.37,199.0,90830.0 +2009-12-21 18:00:00+00:00,15.5,41.35,443.0,496.91,186.0,297.62,8.44,207.0,90728.0 +2009-12-21 19:00:00+00:00,15.91,39.64,612.0,961.91,70.0,288.53,9.52,214.0,90625.0 +2009-12-21 20:00:00+00:00,16.31,37.92,605.0,962.36,69.0,279.45,10.59,221.0,90523.0 +2009-12-21 21:00:00+00:00,15.2,45.19,532.0,935.47,66.0,280.77,10.15,222.0,90511.0 +2009-12-21 22:00:00+00:00,14.1,52.45,401.0,874.66,59.0,282.08,9.7,223.0,90499.0 +2009-12-21 23:00:00+00:00,13.0,59.72,226.0,741.15,46.0,283.4,9.26,224.0,90487.0 +2009-12-22 00:00:00+00:00,12.24,64.99,22.0,0.0,22.0,283.28,8.85,225.0,90532.0 +2009-12-22 01:00:00+00:00,11.48,70.25,0.0,0.0,0.0,283.17,8.45,225.0,90577.0 +2009-12-22 02:00:00+00:00,10.72,75.52,0.0,0.0,0.0,283.05,8.04,226.0,90622.0 +2009-12-22 03:00:00+00:00,10.29,76.22,0.0,0.0,0.0,285.17,7.85,227.0,90659.0 +2009-12-22 04:00:00+00:00,9.86,76.91,0.0,0.0,0.0,287.28,7.66,228.0,90695.0 +2009-12-22 05:00:00+00:00,9.42,77.61,0.0,0.0,0.0,289.4,7.48,228.0,90731.0 +2009-12-22 06:00:00+00:00,8.96,77.42,0.0,0.0,0.0,302.33,7.53,232.0,90770.0 +2009-12-22 07:00:00+00:00,8.5,77.23,0.0,0.0,0.0,315.27,7.58,235.0,90809.0 +2009-12-22 08:00:00+00:00,8.04,77.04,0.0,0.0,0.0,328.2,7.63,239.0,90848.0 +2009-12-22 09:00:00+00:00,7.36,79.11,0.0,0.0,0.0,330.02,7.01,246.0,90908.0 +2009-12-22 10:00:00+00:00,6.68,81.18,0.0,0.0,0.0,331.83,6.4,254.0,90968.0 +2009-12-22 11:00:00+00:00,6.01,83.25,0.0,0.0,0.0,333.65,5.78,261.0,91028.0 +2009-12-22 12:00:00+00:00,5.66,82.19,0.0,0.0,0.0,327.93,4.88,269.0,91082.0 +2009-12-22 13:00:00+00:00,5.31,81.14,0.0,0.0,0.0,322.22,3.98,277.0,91136.0 +2009-12-22 14:00:00+00:00,4.96,80.08,0.0,0.0,0.0,316.5,3.08,285.0,91190.0 +2009-12-22 15:00:00+00:00,5.63,71.71,84.0,507.36,29.0,309.47,3.62,289.0,91229.0 +2009-12-22 16:00:00+00:00,6.3,63.34,271.0,785.93,50.0,302.43,4.17,292.0,91268.0 +2009-12-22 17:00:00+00:00,6.97,54.97,437.0,894.26,61.0,295.4,4.72,295.0,91307.0 +2009-12-22 18:00:00+00:00,7.91,51.62,555.0,944.44,67.0,282.28,5.41,301.0,91259.0 +2009-12-22 19:00:00+00:00,8.84,48.28,615.0,967.37,70.0,269.17,6.1,308.0,91211.0 +2009-12-22 20:00:00+00:00,9.78,44.93,608.0,965.36,70.0,256.05,6.79,314.0,91163.0 +2009-12-22 21:00:00+00:00,9.6,46.33,536.0,942.11,66.0,254.23,5.96,315.0,91187.0 +2009-12-22 22:00:00+00:00,9.43,47.74,406.0,884.99,59.0,252.42,5.13,317.0,91211.0 +2009-12-22 23:00:00+00:00,9.26,49.14,232.0,757.48,47.0,250.6,4.3,318.0,91235.0 +2009-12-23 00:00:00+00:00,7.94,57.89,22.0,0.0,22.0,244.1,3.7,313.0,91355.0 +2009-12-23 01:00:00+00:00,6.62,66.64,0.0,0.0,0.0,237.6,3.09,308.0,91476.0 +2009-12-23 02:00:00+00:00,5.3,75.39,0.0,0.0,0.0,231.1,2.48,303.0,91596.0 +2009-12-23 03:00:00+00:00,5.07,72.55,0.0,0.0,0.0,230.55,2.26,302.0,91635.0 +2009-12-23 04:00:00+00:00,4.83,69.72,0.0,0.0,0.0,230.0,2.04,300.0,91674.0 +2009-12-23 05:00:00+00:00,4.59,66.88,0.0,0.0,0.0,229.45,1.82,298.0,91713.0 +2009-12-23 06:00:00+00:00,4.22,69.75,0.0,0.0,0.0,228.92,1.84,301.0,91737.0 +2009-12-23 07:00:00+00:00,3.86,72.61,0.0,0.0,0.0,228.38,1.86,303.0,91761.0 +2009-12-23 08:00:00+00:00,3.49,75.48,0.0,0.0,0.0,227.85,1.88,306.0,91785.0 +2009-12-23 09:00:00+00:00,3.31,74.14,0.0,0.0,0.0,227.55,1.83,314.0,91794.0 +2009-12-23 10:00:00+00:00,3.14,72.8,0.0,0.0,0.0,227.25,1.79,323.0,91803.0 +2009-12-23 11:00:00+00:00,2.97,71.46,0.0,0.0,0.0,226.95,1.75,332.0,91812.0 +2009-12-23 12:00:00+00:00,2.59,74.87,0.0,0.0,0.0,226.6,1.51,354.0,91848.0 +2009-12-23 13:00:00+00:00,2.21,78.27,0.0,0.0,0.0,226.25,1.27,16.0,91884.0 +2009-12-23 14:00:00+00:00,1.83,81.68,0.0,0.0,0.0,225.9,1.03,38.0,91920.0 +2009-12-23 15:00:00+00:00,4.48,70.41,84.0,513.54,29.0,228.57,1.23,34.0,91929.0 +2009-12-23 16:00:00+00:00,7.13,59.15,273.0,792.5,51.0,231.23,1.43,30.0,91938.0 +2009-12-23 17:00:00+00:00,9.78,47.88,442.0,905.39,62.0,233.9,1.63,27.0,91947.0 +2009-12-23 18:00:00+00:00,10.84,44.37,564.0,960.62,68.0,234.25,1.77,12.0,91842.0 +2009-12-23 19:00:00+00:00,11.89,40.86,626.0,985.06,71.0,234.6,1.91,358.0,91737.0 +2009-12-23 20:00:00+00:00,12.95,37.35,621.0,987.89,70.0,234.95,2.06,344.0,91632.0 +2009-12-23 21:00:00+00:00,12.48,38.12,549.0,964.54,67.0,234.95,2.08,340.0,91611.0 +2009-12-23 22:00:00+00:00,12.01,38.89,298.0,378.86,149.0,234.95,2.11,337.0,91590.0 +2009-12-23 23:00:00+00:00,11.55,39.66,241.0,785.56,48.0,234.95,2.14,334.0,91569.0 +2009-12-24 00:00:00+00:00,9.83,48.01,23.0,0.0,23.0,233.77,2.09,337.0,91614.0 +2009-12-24 01:00:00+00:00,8.11,56.36,0.0,0.0,0.0,232.58,2.04,341.0,91659.0 +2009-12-24 02:00:00+00:00,6.39,64.71,0.0,0.0,0.0,231.4,1.99,345.0,91704.0 +2009-12-24 03:00:00+00:00,5.8,67.52,0.0,0.0,0.0,232.17,1.98,355.0,91725.0 +2009-12-24 04:00:00+00:00,5.2,70.34,0.0,0.0,0.0,232.93,1.97,4.0,91746.0 +2009-12-24 05:00:00+00:00,4.6,73.15,0.0,0.0,0.0,233.7,1.96,14.0,91767.0 +2009-12-24 06:00:00+00:00,3.95,76.59,0.0,0.0,0.0,232.58,1.8,25.0,91752.0 +2009-12-24 07:00:00+00:00,3.3,80.02,0.0,0.0,0.0,231.47,1.65,37.0,91737.0 +2009-12-24 08:00:00+00:00,2.65,83.46,0.0,0.0,0.0,230.35,1.49,48.0,91722.0 +2009-12-24 09:00:00+00:00,1.93,86.17,0.0,0.0,0.0,227.62,1.39,58.0,91707.0 +2009-12-24 10:00:00+00:00,1.21,88.89,0.0,0.0,0.0,224.88,1.3,67.0,91692.0 +2009-12-24 11:00:00+00:00,0.5,91.6,0.0,0.0,0.0,222.15,1.2,76.0,91677.0 +2009-12-24 12:00:00+00:00,0.59,92.57,0.0,0.0,0.0,222.18,1.1,87.0,91692.0 +2009-12-24 13:00:00+00:00,0.68,93.54,0.0,0.0,0.0,222.22,1.0,97.0,91707.0 +2009-12-24 14:00:00+00:00,0.77,94.51,0.0,0.0,0.0,222.25,0.9,108.0,91722.0 +2009-12-24 15:00:00+00:00,3.99,76.83,86.0,538.34,29.0,225.27,0.68,62.0,91692.0 +2009-12-24 16:00:00+00:00,7.21,59.14,279.0,816.76,51.0,228.28,0.46,17.0,91662.0 +2009-12-24 17:00:00+00:00,10.42,41.46,450.0,925.88,62.0,231.3,0.23,331.0,91632.0 +2009-12-24 18:00:00+00:00,11.63,36.75,572.0,976.62,68.0,231.62,0.78,315.0,91509.0 +2009-12-24 19:00:00+00:00,12.83,32.03,633.0,997.23,71.0,231.93,1.32,299.0,91385.0 +2009-12-24 20:00:00+00:00,14.04,27.32,627.0,995.86,71.0,232.25,1.86,283.0,91262.0 +2009-12-24 21:00:00+00:00,13.38,28.76,553.0,970.7,67.0,232.32,2.03,280.0,91241.0 +2009-12-24 22:00:00+00:00,12.73,30.2,421.0,914.93,60.0,232.38,2.2,277.0,91220.0 +2009-12-24 23:00:00+00:00,12.08,31.64,243.0,788.73,48.0,232.45,2.37,274.0,91199.0 +2009-12-25 00:00:00+00:00,10.93,36.56,23.0,0.0,23.0,231.35,2.21,269.0,91241.0 +2009-12-25 01:00:00+00:00,9.77,41.47,0.0,0.0,0.0,230.25,2.05,263.0,91283.0 +2009-12-25 02:00:00+00:00,8.62,46.39,0.0,0.0,0.0,229.15,1.89,257.0,91325.0 +2009-12-25 03:00:00+00:00,8.31,46.16,0.0,0.0,0.0,228.82,1.72,254.0,91373.0 +2009-12-25 04:00:00+00:00,8.0,45.94,0.0,0.0,0.0,228.48,1.56,251.0,91422.0 +2009-12-25 05:00:00+00:00,7.68,45.71,0.0,0.0,0.0,228.15,1.39,248.0,91470.0 +2009-12-25 06:00:00+00:00,7.02,51.1,0.0,0.0,0.0,227.4,1.33,242.0,91500.0 +2009-12-25 07:00:00+00:00,6.35,56.49,0.0,0.0,0.0,226.65,1.27,236.0,91530.0 +2009-12-25 08:00:00+00:00,5.69,61.88,0.0,0.0,0.0,225.9,1.21,230.0,91560.0 +2009-12-25 09:00:00+00:00,4.69,66.56,0.0,0.0,0.0,225.1,1.04,221.0,91587.0 +2009-12-25 10:00:00+00:00,3.7,71.23,0.0,0.0,0.0,224.3,0.87,212.0,91614.0 +2009-12-25 11:00:00+00:00,2.71,75.91,0.0,0.0,0.0,223.5,0.7,203.0,91641.0 +2009-12-25 12:00:00+00:00,2.08,77.6,0.0,0.0,0.0,223.57,0.9,172.0,91695.0 +2009-12-25 13:00:00+00:00,1.45,79.29,0.0,0.0,0.0,223.63,1.09,141.0,91749.0 +2009-12-25 14:00:00+00:00,0.82,80.98,0.0,0.0,0.0,223.7,1.28,110.0,91803.0 +2009-12-25 15:00:00+00:00,3.92,66.02,83.0,515.52,29.0,227.07,1.09,134.0,91836.0 +2009-12-25 16:00:00+00:00,7.01,51.07,273.0,797.77,51.0,230.43,0.89,159.0,91869.0 +2009-12-25 17:00:00+00:00,10.1,36.11,444.0,912.75,62.0,233.8,0.69,183.0,91902.0 +2009-12-25 18:00:00+00:00,11.05,32.85,567.0,967.23,68.0,234.75,0.97,208.0,91815.0 +2009-12-25 19:00:00+00:00,12.01,29.58,628.0,987.91,71.0,235.7,1.26,233.0,91728.0 +2009-12-25 20:00:00+00:00,12.96,26.32,458.0,404.31,232.0,236.65,1.54,258.0,91641.0 +2009-12-25 21:00:00+00:00,12.49,27.48,455.0,627.84,140.0,238.88,1.54,263.0,91641.0 +2009-12-25 22:00:00+00:00,12.02,28.63,309.0,414.19,145.0,241.12,1.54,268.0,91641.0 +2009-12-25 23:00:00+00:00,11.56,29.79,241.0,775.51,48.0,243.35,1.53,273.0,91641.0 +2009-12-26 00:00:00+00:00,10.67,33.77,23.0,0.0,23.0,241.0,1.26,298.0,91701.0 +2009-12-26 01:00:00+00:00,9.79,37.75,0.0,0.0,0.0,238.65,0.98,324.0,91761.0 +2009-12-26 02:00:00+00:00,8.9,41.73,0.0,0.0,0.0,236.3,0.7,350.0,91821.0 +2009-12-26 03:00:00+00:00,7.67,46.84,0.0,0.0,0.0,235.3,0.82,33.0,91851.0 +2009-12-26 04:00:00+00:00,6.44,51.95,0.0,0.0,0.0,234.3,0.93,77.0,91881.0 +2009-12-26 05:00:00+00:00,5.21,57.06,0.0,0.0,0.0,233.3,1.05,121.0,91911.0 +2009-12-26 06:00:00+00:00,4.37,60.05,0.0,0.0,0.0,232.87,1.11,117.0,91923.0 +2009-12-26 07:00:00+00:00,3.54,63.04,0.0,0.0,0.0,232.43,1.17,114.0,91935.0 +2009-12-26 08:00:00+00:00,2.7,66.03,0.0,0.0,0.0,232.0,1.23,110.0,91947.0 +2009-12-26 09:00:00+00:00,2.02,68.53,0.0,0.0,0.0,232.23,1.29,102.0,91962.0 +2009-12-26 10:00:00+00:00,1.34,71.04,0.0,0.0,0.0,232.47,1.36,94.0,91977.0 +2009-12-26 11:00:00+00:00,0.66,73.54,0.0,0.0,0.0,232.7,1.42,86.0,91992.0 +2009-12-26 12:00:00+00:00,0.66,74.46,0.0,0.0,0.0,231.15,1.46,87.0,92022.0 +2009-12-26 13:00:00+00:00,0.67,75.37,0.0,0.0,0.0,229.6,1.5,89.0,92052.0 +2009-12-26 14:00:00+00:00,0.67,76.29,0.0,0.0,0.0,228.05,1.54,91.0,92082.0 +2009-12-26 15:00:00+00:00,4.4,60.52,82.0,511.06,29.0,231.23,1.49,95.0,92076.0 +2009-12-26 16:00:00+00:00,8.12,44.75,273.0,800.01,51.0,234.42,1.44,98.0,92070.0 +2009-12-26 17:00:00+00:00,11.84,28.98,445.0,916.11,62.0,237.6,1.39,101.0,92064.0 +2009-12-26 18:00:00+00:00,12.96,25.99,568.0,969.26,68.0,240.22,1.17,109.0,91956.0 +2009-12-26 19:00:00+00:00,14.08,22.99,630.0,990.82,71.0,242.83,0.94,117.0,91848.0 +2009-12-26 20:00:00+00:00,15.2,20.0,625.0,989.72,71.0,245.45,0.72,125.0,91740.0 +2009-12-26 21:00:00+00:00,14.84,20.51,554.0,966.44,68.0,245.45,0.97,105.0,91722.0 +2009-12-26 22:00:00+00:00,14.49,21.02,423.0,910.86,61.0,245.45,1.23,85.0,91704.0 +2009-12-26 23:00:00+00:00,14.14,21.53,125.0,91.78,102.0,245.45,1.49,65.0,91686.0 +2009-12-27 00:00:00+00:00,12.03,25.34,26.0,0.0,26.0,243.03,1.63,61.0,91746.0 +2009-12-27 01:00:00+00:00,9.92,29.16,0.0,0.0,0.0,240.62,1.77,58.0,91806.0 +2009-12-27 02:00:00+00:00,7.81,32.97,0.0,0.0,0.0,238.2,1.92,55.0,91866.0 +2009-12-27 03:00:00+00:00,7.33,34.91,0.0,0.0,0.0,246.02,2.02,61.0,91860.0 +2009-12-27 04:00:00+00:00,6.84,36.85,0.0,0.0,0.0,253.83,2.13,68.0,91854.0 +2009-12-27 05:00:00+00:00,6.35,38.79,0.0,0.0,0.0,261.65,2.23,74.0,91848.0 +2009-12-27 06:00:00+00:00,6.24,40.73,0.0,0.0,0.0,265.7,2.29,75.0,91812.0 +2009-12-27 07:00:00+00:00,6.13,42.66,0.0,0.0,0.0,269.75,2.34,77.0,91776.0 +2009-12-27 08:00:00+00:00,6.02,44.6,0.0,0.0,0.0,273.8,2.39,78.0,91740.0 +2009-12-27 09:00:00+00:00,5.86,46.44,0.0,0.0,0.0,276.58,2.47,78.0,91743.0 +2009-12-27 10:00:00+00:00,5.71,48.27,0.0,0.0,0.0,279.37,2.55,78.0,91746.0 +2009-12-27 11:00:00+00:00,5.56,50.11,0.0,0.0,0.0,282.15,2.63,77.0,91749.0 +2009-12-27 12:00:00+00:00,5.61,49.87,0.0,0.0,0.0,283.42,2.72,77.0,91761.0 +2009-12-27 13:00:00+00:00,5.67,49.64,0.0,0.0,0.0,284.68,2.81,77.0,91773.0 +2009-12-27 14:00:00+00:00,5.72,49.4,0.0,0.0,0.0,285.95,2.9,77.0,91785.0 +2009-12-27 15:00:00+00:00,7.29,44.49,8.0,0.0,8.0,288.63,2.96,79.0,91791.0 +2009-12-27 16:00:00+00:00,8.85,39.58,79.0,0.0,79.0,291.32,3.02,80.0,91797.0 +2009-12-27 17:00:00+00:00,10.41,34.67,14.0,0.0,14.0,294.0,3.08,81.0,91803.0 +2009-12-27 18:00:00+00:00,12.11,31.63,143.0,0.0,143.0,289.83,3.2,85.0,91692.0 +2009-12-27 19:00:00+00:00,13.82,28.58,87.0,0.0,87.0,285.67,3.33,89.0,91581.0 +2009-12-27 20:00:00+00:00,15.52,25.54,199.0,10.7,193.0,281.5,3.46,93.0,91470.0 +2009-12-27 21:00:00+00:00,14.85,28.24,150.0,0.0,150.0,280.1,3.42,94.0,91443.0 +2009-12-27 22:00:00+00:00,14.19,30.94,220.0,110.27,176.0,278.7,3.37,95.0,91416.0 +2009-12-27 23:00:00+00:00,13.53,33.64,85.0,0.0,85.0,277.3,3.32,97.0,91388.0 +2009-12-28 00:00:00+00:00,12.46,35.9,27.0,0.0,27.0,282.42,3.04,93.0,91410.0 +2009-12-28 01:00:00+00:00,11.38,38.15,0.0,0.0,0.0,287.53,2.75,89.0,91431.0 +2009-12-28 02:00:00+00:00,10.31,40.41,0.0,0.0,0.0,292.65,2.47,85.0,91452.0 +2009-12-28 03:00:00+00:00,10.14,41.85,0.0,0.0,0.0,295.1,2.42,96.0,91476.0 +2009-12-28 04:00:00+00:00,9.97,43.3,0.0,0.0,0.0,297.55,2.38,107.0,91500.0 +2009-12-28 05:00:00+00:00,9.8,44.74,0.0,0.0,0.0,300.0,2.33,118.0,91524.0 +2009-12-28 06:00:00+00:00,9.48,46.14,0.0,0.0,0.0,305.67,2.11,114.0,91548.0 +2009-12-28 07:00:00+00:00,9.17,47.55,0.0,0.0,0.0,311.33,1.89,110.0,91572.0 +2009-12-28 08:00:00+00:00,8.85,48.95,0.0,0.0,0.0,317.0,1.67,107.0,91596.0 +2009-12-28 09:00:00+00:00,8.34,55.13,0.0,0.0,0.0,318.0,1.35,101.0,91641.0 +2009-12-28 10:00:00+00:00,7.84,61.31,0.0,0.0,0.0,319.0,1.03,95.0,91686.0 +2009-12-28 11:00:00+00:00,7.34,67.49,0.0,0.0,0.0,320.0,0.72,90.0,91731.0 +2009-12-28 12:00:00+00:00,7.44,64.98,0.0,0.0,0.0,320.12,1.05,115.0,91743.0 +2009-12-28 13:00:00+00:00,7.55,62.48,0.0,0.0,0.0,320.23,1.39,140.0,91755.0 +2009-12-28 14:00:00+00:00,7.66,59.97,0.0,0.0,0.0,320.35,1.72,165.0,91767.0 +2009-12-28 15:00:00+00:00,9.07,52.99,77.0,480.93,28.0,320.78,1.92,176.0,91761.0 +2009-12-28 16:00:00+00:00,10.47,46.01,113.0,28.96,105.0,321.22,2.12,187.0,91755.0 +2009-12-28 17:00:00+00:00,11.87,39.03,126.0,0.0,126.0,321.65,2.32,198.0,91749.0 +2009-12-28 18:00:00+00:00,12.99,34.81,411.0,385.6,212.0,312.45,2.79,219.0,91686.0 +2009-12-28 19:00:00+00:00,14.12,30.6,397.0,228.22,268.0,303.25,3.26,240.0,91623.0 +2009-12-28 20:00:00+00:00,15.24,26.38,393.0,226.13,266.0,294.05,3.74,261.0,91560.0 +2009-12-28 21:00:00+00:00,14.88,27.02,309.0,144.41,236.0,286.07,3.54,261.0,91572.0 +2009-12-28 22:00:00+00:00,14.52,27.67,280.0,277.03,169.0,278.08,3.33,260.0,91584.0 +2009-12-28 23:00:00+00:00,14.16,28.31,163.0,251.67,99.0,270.1,3.13,260.0,91596.0 +2009-12-29 00:00:00+00:00,12.42,32.45,27.0,0.0,27.0,263.88,2.89,253.0,91653.0 +2009-12-29 01:00:00+00:00,10.67,36.6,0.0,0.0,0.0,257.67,2.65,247.0,91710.0 +2009-12-29 02:00:00+00:00,8.93,40.74,0.0,0.0,0.0,251.45,2.41,240.0,91767.0 +2009-12-29 03:00:00+00:00,8.6,43.66,0.0,0.0,0.0,250.95,2.35,239.0,91830.0 +2009-12-29 04:00:00+00:00,8.27,46.59,0.0,0.0,0.0,250.45,2.29,237.0,91893.0 +2009-12-29 05:00:00+00:00,7.93,49.51,0.0,0.0,0.0,249.95,2.23,235.0,91956.0 +2009-12-29 06:00:00+00:00,7.58,51.23,0.0,0.0,0.0,249.2,2.15,231.0,91995.0 +2009-12-29 07:00:00+00:00,7.24,52.96,0.0,0.0,0.0,248.45,2.07,228.0,92034.0 +2009-12-29 08:00:00+00:00,6.89,54.68,0.0,0.0,0.0,247.7,1.99,224.0,92073.0 +2009-12-29 09:00:00+00:00,6.19,55.72,0.0,0.0,0.0,246.85,1.87,222.0,92088.0 +2009-12-29 10:00:00+00:00,5.5,56.75,0.0,0.0,0.0,246.0,1.75,220.0,92103.0 +2009-12-29 11:00:00+00:00,4.81,57.79,0.0,0.0,0.0,245.15,1.63,217.0,92118.0 +2009-12-29 12:00:00+00:00,4.52,59.67,0.0,0.0,0.0,245.23,1.77,210.0,92133.0 +2009-12-29 13:00:00+00:00,4.23,61.55,0.0,0.0,0.0,245.32,1.92,203.0,92148.0 +2009-12-29 14:00:00+00:00,3.94,63.43,0.0,0.0,0.0,245.4,2.07,196.0,92163.0 +2009-12-29 15:00:00+00:00,6.72,53.35,76.0,474.72,28.0,249.73,2.33,207.0,92172.0 +2009-12-29 16:00:00+00:00,9.5,43.27,261.0,765.2,50.0,254.07,2.59,217.0,92182.0 +2009-12-29 17:00:00+00:00,12.28,33.19,428.0,876.91,62.0,258.4,2.86,228.0,92191.0 +2009-12-29 18:00:00+00:00,13.31,30.94,549.0,931.54,68.0,256.5,3.83,235.0,92088.0 +2009-12-29 19:00:00+00:00,14.35,28.68,500.0,540.71,194.0,254.6,4.81,242.0,91986.0 +2009-12-29 20:00:00+00:00,15.38,26.43,453.0,378.52,240.0,252.7,5.79,249.0,91884.0 +2009-12-29 21:00:00+00:00,14.92,28.13,413.0,418.18,201.0,253.03,5.57,250.0,91842.0 +2009-12-29 22:00:00+00:00,14.46,29.83,334.0,501.94,132.0,253.37,5.35,250.0,91800.0 +2009-12-29 23:00:00+00:00,14.01,31.53,117.0,58.53,102.0,253.7,5.13,250.0,91758.0 +2009-12-30 00:00:00+00:00,12.8,34.51,40.0,148.86,28.0,255.12,4.71,253.0,91800.0 +2009-12-30 01:00:00+00:00,11.59,37.5,0.0,0.0,0.0,256.53,4.29,255.0,91842.0 +2009-12-30 02:00:00+00:00,10.38,40.48,0.0,0.0,0.0,257.95,3.88,258.0,91884.0 +2009-12-30 03:00:00+00:00,10.23,42.95,0.0,0.0,0.0,257.8,3.51,259.0,91932.0 +2009-12-30 04:00:00+00:00,10.08,45.42,0.0,0.0,0.0,257.65,3.15,261.0,91980.0 +2009-12-30 05:00:00+00:00,9.92,47.89,0.0,0.0,0.0,257.5,2.79,263.0,92028.0 +2009-12-30 06:00:00+00:00,9.53,50.23,0.0,0.0,0.0,260.27,2.73,270.0,92049.0 +2009-12-30 07:00:00+00:00,9.15,52.58,0.0,0.0,0.0,263.03,2.68,278.0,92070.0 +2009-12-30 08:00:00+00:00,8.76,54.92,0.0,0.0,0.0,265.8,2.62,285.0,92091.0 +2009-12-30 09:00:00+00:00,7.94,58.95,0.0,0.0,0.0,265.38,2.54,297.0,92115.0 +2009-12-30 10:00:00+00:00,7.13,62.99,0.0,0.0,0.0,264.97,2.46,308.0,92139.0 +2009-12-30 11:00:00+00:00,6.32,67.02,0.0,0.0,0.0,264.55,2.37,320.0,92163.0 +2009-12-30 12:00:00+00:00,6.3,70.6,0.0,0.0,0.0,260.22,2.45,331.0,92230.0 +2009-12-30 13:00:00+00:00,6.28,74.18,0.0,0.0,0.0,255.88,2.52,343.0,92296.0 +2009-12-30 14:00:00+00:00,6.26,77.76,0.0,0.0,0.0,251.55,2.59,354.0,92362.0 +2009-12-30 15:00:00+00:00,8.21,67.72,77.0,487.91,28.0,250.72,2.82,10.0,92389.0 +2009-12-30 16:00:00+00:00,10.15,57.69,268.0,788.06,51.0,249.88,3.05,26.0,92416.0 +2009-12-30 17:00:00+00:00,12.09,47.65,443.0,910.5,63.0,249.05,3.28,42.0,92443.0 +2009-12-30 18:00:00+00:00,13.21,40.08,571.0,971.49,69.0,247.58,3.69,51.0,92371.0 +2009-12-30 19:00:00+00:00,14.33,32.52,639.0,1000.49,72.0,246.12,4.09,61.0,92299.0 +2009-12-30 20:00:00+00:00,15.45,24.95,638.0,1003.68,72.0,244.65,4.5,71.0,92227.0 +2009-12-30 21:00:00+00:00,15.09,26.86,569.0,983.24,69.0,242.85,3.79,71.0,92233.0 +2009-12-30 22:00:00+00:00,14.73,28.77,438.0,930.02,62.0,241.05,3.09,72.0,92239.0 +2009-12-30 23:00:00+00:00,14.38,30.68,259.0,809.01,50.0,239.25,2.39,72.0,92245.0 +2009-12-31 00:00:00+00:00,13.12,32.59,65.0,467.49,26.0,238.22,2.74,73.0,92278.0 +2009-12-31 01:00:00+00:00,11.86,34.51,0.0,0.0,0.0,237.18,3.1,74.0,92311.0 +2009-12-31 02:00:00+00:00,10.6,36.42,0.0,0.0,0.0,236.15,3.46,74.0,92344.0 +2009-12-31 03:00:00+00:00,9.66,39.05,0.0,0.0,0.0,233.77,3.52,72.0,92362.0 +2009-12-31 04:00:00+00:00,8.71,41.67,0.0,0.0,0.0,231.38,3.58,69.0,92380.0 +2009-12-31 05:00:00+00:00,7.76,44.3,0.0,0.0,0.0,229.0,3.64,66.0,92398.0 +2009-12-31 06:00:00+00:00,6.95,46.57,0.0,0.0,0.0,226.92,3.62,66.0,92380.0 +2009-12-31 07:00:00+00:00,6.13,48.84,0.0,0.0,0.0,224.83,3.6,66.0,92362.0 +2009-12-31 08:00:00+00:00,5.31,51.11,0.0,0.0,0.0,222.75,3.57,66.0,92344.0 +2009-12-31 09:00:00+00:00,4.59,53.1,0.0,0.0,0.0,221.65,3.54,68.0,92344.0 +2009-12-31 10:00:00+00:00,3.87,55.08,0.0,0.0,0.0,220.55,3.51,69.0,92344.0 +2009-12-31 11:00:00+00:00,3.15,57.07,0.0,0.0,0.0,219.45,3.48,70.0,92344.0 +2009-12-31 12:00:00+00:00,3.14,58.02,0.0,0.0,0.0,218.95,3.56,72.0,92359.0 +2009-12-31 13:00:00+00:00,3.14,58.96,0.0,0.0,0.0,218.45,3.64,73.0,92374.0 +2009-12-31 14:00:00+00:00,3.14,59.91,0.0,0.0,0.0,217.95,3.72,75.0,92389.0 +2009-12-31 15:00:00+00:00,6.34,49.27,77.0,491.45,28.0,221.53,4.01,77.0,92359.0 +2009-12-31 16:00:00+00:00,16.39,13.71,268.0,789.04,51.0,230.32,4.57,78.0,92329.0 +2009-12-31 17:00:00+00:00,16.09,17.0,440.0,905.46,62.0,232.05,4.31,80.0,92299.0 +2009-12-31 18:00:00+00:00,15.79,20.29,565.0,960.65,68.0,233.77,4.04,79.0,92169.0 +2009-12-31 19:00:00+00:00,15.49,23.58,629.0,982.62,71.0,235.5,3.78,78.0,92040.0 +2009-12-31 20:00:00+00:00,15.19,26.88,625.0,979.54,71.0,237.22,3.52,77.0,91911.0 +2009-12-31 21:00:00+00:00,14.9,30.17,556.0,955.71,68.0,238.95,3.26,76.0,91872.0 +2009-12-31 22:00:00+00:00,14.6,33.46,427.0,899.84,61.0,240.67,3.0,75.0,91833.0 +2009-12-31 23:00:00+00:00,14.3,36.75,252.0,777.68,49.0,242.39,2.74,73.0,91794.0 From acf5b861cb2f84f310f144d25832101edfa2b4e2 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Wed, 5 Apr 2023 00:51:00 -0700 Subject: [PATCH 11/53] updated readme --- services/core/IEEE_2030_5/README.md | 135 ++++++++++++++++++++++++++-- 1 file changed, 128 insertions(+), 7 deletions(-) diff --git a/services/core/IEEE_2030_5/README.md b/services/core/IEEE_2030_5/README.md index ab6dfa7b2f..b31249faac 100644 --- a/services/core/IEEE_2030_5/README.md +++ b/services/core/IEEE_2030_5/README.md @@ -1,16 +1,137 @@ # VOLTTRON 2030.5 Agent The VOLTTRON 2030.5 agent communicates with a 2030.5 server using the IEEE 2030.5(2018) protocol. The primary concern of -this agent is to handle the communication between the platform.driver and the 2030.5 server. The 2030.5 protocol uses a +this agent is to handle the communication between the PlatformDriverAgent and the 2030.5 server. The agent will create MirrorUsagePoints and readings to the 2030.5 server. + +The following diagram illistrates the data flow for the 2030.5 agent from the PlatformDriverAgent to the 2030.5 server. + +```mermaid + sequenceDiagram + Client->>Server: Creates MirrorUsagePoints + Client->>PlatformDriverAgent: Subscribes to Device Data + PlatformDriverAgent->>Client: Publishes Device Data + Client->>Server: Posts MeterReadings(Device Data) + Server-->Client: 200 OK +``` + +## Agent Config File + +An example configuration file is at the root of the agent directory (example.config.yml) + +```yaml +# required parameters +# A host ip address or a resolvable dns entry is required for connecting to. +# The agent will connect to this during the startup of the agent. +server_hostname: 127.0.0.1 + +# The client and ca paramenters are required for bi-directional +# verification of certificates/keys. +cacertfile: ~/tls/certs/ca.pem +keyfile: ~/tls/private/dev1.pem +certfile: ~/tls/certs/dev1.pem + +# the pin number is used to verify the server is the correct server +pin: 111115 + +# SSL defaults to 443 +server_ssl_port: 8443 + +# The following is the definition of the MirrorUsagePoints +MirrorUsagePointList: + # MirrorMeterReading based on Table E.2 IEEE Std 2030.5-18 + # note the mRID in the MirrorMeterReading is the same that is in the + # MirrorUsagePoint. + # + # NOTE: The subscription point will be a member of an "all" message from + # the PlatformDriverAgent. + - subscription_point: p_ac + mRID: 5509D69F8B3535950000000000009182 + description: DER Inverter Real Power + roleFlags: 49 + serviceCategoryKind: 0 + status: 0 + MirrorMeterReading: + mRID: 5509D69F8B3535950000000000009182 + description: Real Power(W) Set + ReadingType: + accumulationBehavior: 12 + commodity: 1 + dataQualifier: 2 + intervalLength: 300 + powerOfTenMultiplier: 0 + uom: 38 + # NOTE: The subscription point will be a member of an "all" message from + # the PlatformDriverAgent. + - subscription_point: q_ac + mRID: 5509D69F8B3535950000000000009184 + description: DER Inverter Reactive Power + roleFlags: 49 + serviceCategoryKind: 0 + status: 0 + MirrorMeterReading: + mRID: 5509D69F8B3535950000000000009184 + description: Reactive Power(VAr) Set + ReadingType: + accumulationBehavior: 12 + commodity: 1 + dataQualifier: 2 + intervalLength: 300 + powerOfTenMultiplier: 0 + uom: 38 + +# publishes on the following subscriptions will +# be available to create and POST readings to the +# 2030.5 server. +subscriptions: + - devices/inverter1/all +``` + +## Agent Installation + +The 2030.5 agent can be installed using an activated terminal from the root of the volttron git repository: + +```bash +(volttron)>vctl install service/core/IEEE_2030_5 --agent-config example.config.yml --vip-identity inverter1 +``` + +## 2030.5 Protocol + +The 2030.5 protocol uses a REQUEST/RESPONSE pattern meaning that all communication with the 2030.5 server will start with a REQUEST being sent from the client. -## +### Communication + +The 2030.5 protocol starts with requests to the server for determining the DERProgram and DERControl that the client should be using. Once the default and scheduled DERControls are known then the client can act according to the 2030.5 server's requirements. + +The following diagram illistrates the request and response from the client to the server. ```mermaid - graph TD; - A-->B; - A-->C; - B-->D; - C-->D; + sequenceDiagram + Client->>Server: /dcap + Server-->Client: DeviceCapabilities + Client->>Server: /edev + Server-->Client: EndDeviceList(1) /* found */ + Client->>Server: /edev/0 + Server-->Client: EndDevice + Client->>Server: /edev/0/fsa + Server-->Client: FunctionSetAssignmentList + Client->>Server: /edev/0/fsa/0 + Server-->Client: FunctionSetAssignment + Client->>Server: /edev/0/fsa/0/derp + Server-->Client: DERProgramList + Client->>Server: /derp/0 + Server-->Client: DERProgram + Client->>Server: /derp/0/derc + Server-->Client: DERControlList + Client->>Server: /derp/0/dderc + Server-->Client: DERDefaultControl + Client->>Server: /derp/0/derca + Server-->Client: DERControlList ``` + +After the DERControls are found the client needs to poll the server for updates. Depending on the function set, the poll rate could be different. + +## GridAPPSD 2030.5 Server + +## Demo From 316d2e2d24965377875300fa804705fe218ad5fd Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Wed, 5 Apr 2023 00:57:01 -0700 Subject: [PATCH 12/53] Added polling for active DERControl --- services/core/IEEE_2030_5/example.config.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/services/core/IEEE_2030_5/example.config.yml b/services/core/IEEE_2030_5/example.config.yml index 11ec2677b7..5ab7658801 100644 --- a/services/core/IEEE_2030_5/example.config.yml +++ b/services/core/IEEE_2030_5/example.config.yml @@ -9,7 +9,7 @@ pin: 111115 # SSL defaults to 443 server_ssl_port: 8443 # http port defaults to none -server_http_port: 8080 +#server_http_port: 8080 MirrorUsagePointList: # MirrorMeterReading based on Table E.2 IEEE Std 2030.5-18 From 686f259323226c68d58d9e6fbbc90ede2ba372bd Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Wed, 5 Apr 2023 09:01:25 -0700 Subject: [PATCH 13/53] Moved to demo directory. --- .../inverter_runner.py | 0 .../{simulated_inverter => demo}/weather.txt | 0 services/core/IEEE_2030_5/demo/webgui.py | 191 ++++++++++++++++++ 3 files changed, 191 insertions(+) rename services/core/IEEE_2030_5/{simulated_inverter => demo}/inverter_runner.py (100%) rename services/core/IEEE_2030_5/{simulated_inverter => demo}/weather.txt (100%) create mode 100644 services/core/IEEE_2030_5/demo/webgui.py diff --git a/services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py b/services/core/IEEE_2030_5/demo/inverter_runner.py similarity index 100% rename from services/core/IEEE_2030_5/simulated_inverter/inverter_runner.py rename to services/core/IEEE_2030_5/demo/inverter_runner.py diff --git a/services/core/IEEE_2030_5/simulated_inverter/weather.txt b/services/core/IEEE_2030_5/demo/weather.txt similarity index 100% rename from services/core/IEEE_2030_5/simulated_inverter/weather.txt rename to services/core/IEEE_2030_5/demo/weather.txt diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py new file mode 100644 index 0000000000..a1f6643277 --- /dev/null +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -0,0 +1,191 @@ +#!/usr/bin/env python3 +from __future__ import annotations + +import asyncio +import json +import os.path +import platform +import shlex +import sys +import time +import uuid +from dataclasses import dataclass +from datetime import datetime, timedelta +from pathlib import Path +from typing import Any, Optional + +sys.path.insert(0, str(Path(__file__).parent.parent)) + +import ieee_2030_5.models as m +from nicegui import background_tasks, ui + +from services.core.IEEE_2030_5.ieee_2030_5 import dataclass_to_xml, xml_to_dataclass + +tasks = [] + +def add_my_task(task): + tasks.append(task) + + +def _send_control_event(): + default_pf = 0.99 + import requests + session = requests.Session() + session.cert = ('/home/os2004/tls/certs/admin.pem', '/home/os2004/tls/private/admin.pem') + session.verify = "/home/os2004/tls/certs/ca.pem" + + control_path = Path('inverter.ctl') + derc: m.DERControl = xml_to_dataclass(xml_text.value) + + + time_now = int(time.mktime((datetime.utcnow()).timetuple())) + + while time_now < derc.interval.start: + time.sleep(0.1) + time_now = int(time.mktime((datetime.utcnow()).timetuple())) + + with open(str(control_path), 'wt') as fp: + fp.write(json.dumps(dict(pf=derc.DERControlBase.opModFixedPFInjectW))) + + while time_now < derc.interval.start + derc.interval.duration: + time.sleep(0.1) + time_now = int(time.mktime((datetime.utcnow()).timetuple())) + + control_path.write(json.dump(dict(pf=default_pf))) + + + +def get_control_event_default(): + derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) + + time_plus_10 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) + + derc = m.DERControl(mRID=str(uuid.uuid4()), + description="New DER Control Event", + DERControlBase=derbase, + interval=m.DateTimeInterval(duration=10, start=time_plus_10)) + + + # setESLowVolt=0.917, + # setESHighVolt=1.05, + # setESLowFreq=59.5, + # setESHighFreq=60.1, + # setESRampTms=300, + # setESRandomDelay=0, + #DERControlBase=derbase) + # dderc = m.DefaultDERControl(href=hrefs.get_dderc_href(), + # mRID=str(uuid.uuid4()), + # description="Default DER Control Mode", + # setESDelay=300, + # setESLowVolt=0.917, + # setESHighVolt=1.05, + # setESLowFreq=59.5, + # setESHighFreq=60.1, + # setESRampTms=300, + # setESRandomDelay=0, + # DERControlBase=derbase) + return dataclass_to_xml(derc) + + +def _setup_event(element): + derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) + + time_plus_60 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) + + derc = m.DERControl(mRID=str(uuid.uuid4()), + description="New DER Control Event", + DERControlBase=derbase, + interval=m.DateTimeInterval(duration=10, start=time_plus_60)) + element.value=dataclass_to_xml(derc) + + +async def _reset_tasks(): + for task in tasks: + print(task.cancel()) + + await asyncio.sleep(0.1) + + # while not task.cancelled(): + # asyncio.sleep(0.1) + # print(task.cancelled()) + + + tasks.clear() + agent_log.clear() + proxy_log.clear() + inverter_log.clear() + + #background_tasks.running_tasks.clear() + +async def run_command(command: LabeledCommand) -> None: + '''Run a command in the background and display the output in the pre-created dialog.''' + + process = await asyncio.create_subprocess_exec( + *shlex.split(command.command), + stdout=asyncio.subprocess.PIPE, stderr=asyncio.subprocess.STDOUT, + cwd=command.working_dir + ) + + # NOTE we need to read the output in chunks, otherwise the process will block + output = '' + while True: + new = await process.stdout.readline() + if not new: + break + output = new.decode() + + try: + jsonparsed = json.loads(output) + if command.output_element is not None: + command.output_element().push(output.strip()) + except json.decoder.JSONDecodeError: + if not command.output_only_json: + command.output_element().push(output.strip()) + + # NOTE the content of the markdown element is replaced every time we have new output + #result.content = f'```\n{output}\n```' + +with ui.dialog() as dialog, ui.card(): + result = ui.markdown() + +@dataclass +class LabeledCommand: + label: str + command: str + output_element: Any + working_dir: str = str(Path(__file__).parent) + output_only_json: bool = True + +commands = [ + LabeledCommand("Start Inverter", f'{sys.executable} inverter_runner.py', lambda: inverter_log), + LabeledCommand("Start Proxy", f'/home/os2004/repos/gridappsd-2030_5/.venv/bin/python -m ieee_2030_5.basic_proxy config.yml ', lambda: proxy_log, "/home/os2004/repos/gridappsd-2030_5", + output_only_json=False), + LabeledCommand("Start Agent", f'{sys.executable} -m ieee_2030_5.agent', lambda: agent_log, "/home/os2004/repos/volttron/services/core/IEEE_2030_5", + output_only_json=False), +] + +with ui.column(): + # commands = [f'{sys.executable} inverter_runner.py'] + with ui.row(): + + for command in commands: + ui.button(command.label, on_click=lambda _, c=command: add_my_task(background_tasks.create(run_command(c)))).props('no-caps') + + ui.button("Reset", on_click=lambda: _reset_tasks()).props('no-caps') + #ui.button("Update Control Time", on_click=lambda: _setup_event(xml_text)).props('no-caps') + #ui.button("Send Control", on_click=lambda: _send_control_event()).props('no-caps') + # with ui.row(): + # xml_text = ui.textarea(label="xml", value=get_control_event_default()).props('rows=20').props('cols=120').classes('w-full, h-80') + with ui.row(): + ui.label("Inverter Log") + inverter_log = ui.log(10).props('rows=5').props('cols=120').classes('w-full h-80') + with ui.row(): + ui.label("Proxy Log") + proxy_log = ui.log(10).props('rows=5').props('cols=120').classes('w-full h-80') + with ui.row(): + ui.label("Agent Log") + agent_log = ui.log(10).props('rows=5').props('cols=120').classes('w-full h-80') + + +# NOTE on windows reload must be disabled to make asyncio.create_subprocess_exec work (see https://github.com/zauberzeug/nicegui/issues/486) +ui.run(reload=platform.system() != "Windows") \ No newline at end of file From 11615544cc8409832f2773f7f0e2dcae15f451f7 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Wed, 5 Apr 2023 09:41:40 -0700 Subject: [PATCH 14/53] Add AGENT_DEMO.md --- services/core/IEEE_2030_5/AGENT_DEMO.md | 71 +++++++++++++++++++++++++ services/core/IEEE_2030_5/README.md | 7 ++- 2 files changed, 77 insertions(+), 1 deletion(-) create mode 100644 services/core/IEEE_2030_5/AGENT_DEMO.md diff --git a/services/core/IEEE_2030_5/AGENT_DEMO.md b/services/core/IEEE_2030_5/AGENT_DEMO.md new file mode 100644 index 0000000000..c38f67c55a --- /dev/null +++ b/services/core/IEEE_2030_5/AGENT_DEMO.md @@ -0,0 +1,71 @@ +# 2030.5 Agent Demo + +This readme walks through a demo of an inverter publishing points to the VOLTTRON message bus where the 2030.5 agent will receive it. The 2030.5 agent will then create MirrorUsagePoints and POST MirrorMeterReadings to the 2030.5 server. In addition, the demo will also allow the user to create a DERControl event. During the activation of the event, the agent will log messages to the 2030.5 server. + +The demo will require three terminal windows to be open. The first will be for executing the main VOLTTRON process. The second will be for executing the 2030.5 server. The third will be for executing the agent demo through a web interface. For the rest of this document, VOLTTRON_ROOT is assumed to be where one has cloned the volttron repository. + +## 2030.5 Server + +For the server software we will be using a server from a team at PNNL. The GridAPPS-D team has created a 2030.5 server and it is available at . The source code is still in a private repo, but will be released at some time in the future. + +1. In a new terminal create a new virtual environment and install the gridappsd server. **This directory should be outside the main volttron tree** + + ```bash + > mkdir 2030_5_server + > cd 2030_5_server + + # creates an environment 'env' in the current directory + > python3 -m venv serverenv + + > source serverenv/bin/activate + + (serverenv)> pip install gridappsd-2030-5 + ``` + +1. The server is now installed. Next copy the openssl.cnf and server.yml file from the $VOLTTRON_ROOT/services/core/IEEE_2030_5/demo directory to the newly created 2030_5_server directory. After copying the current directory should look like the following. + + ```bash + (serverenv)> ls -l + serverenv + openssl.cnf + server.yml + ``` + +1. Start the server from the activated serverenv **This step will create development certificates for you**. By default the certificates will be generated and stored in ~/tls. One can change this location in the server.yml configuration file. + + ```bash + (serverenv)> 2030_5_server server.yml --no-validate + + # without creating certificates + # (serverenv)> 2030_5_server server.yml --no-validate --no-create-certs + ``` + +## Demo Requirements + +For this demo, start a VOLTTRON default instance from the command line. The following command will start VOLTTRON in the background writing to a volttron.log file. + +1. Activate and start the volttron instance. + + ```bash + > cd $VOLTTRON_ROOT + > source env/bin/activate + (volttron)> ./start-volttron + ``` + +1. Using the same terminal as the previous command install the demo requirements as follows. + + ```bash + (volttron) > cd service/core/IEEE_2030_5 + (volttron) > pip install -r requirements_demo.txt + ... + ``` + +1. Run the webgui.py script using the python interpretor. This should open a webpage allowing one to test the functionality of the 2030.5 agent. + + ```bash + (volttron)> python demo/webgui.py + ``` + +## The Demo + +Insert pictures here. diff --git a/services/core/IEEE_2030_5/README.md b/services/core/IEEE_2030_5/README.md index b31249faac..b9ca5ed18b 100644 --- a/services/core/IEEE_2030_5/README.md +++ b/services/core/IEEE_2030_5/README.md @@ -8,12 +8,17 @@ The following diagram illistrates the data flow for the 2030.5 agent from the Pl ```mermaid sequenceDiagram Client->>Server: Creates MirrorUsagePoints + Server-->>Client: 201 OK Client->>PlatformDriverAgent: Subscribes to Device Data PlatformDriverAgent->>Client: Publishes Device Data Client->>Server: Posts MeterReadings(Device Data) - Server-->Client: 200 OK + Server-->>Client: 201 OK + Client->>Server: Polls for active DERControls + Client->>PlatformDriverAgent: Publishes Event Controls ``` +To better visualize how this works please try out the [Agent Demo](AGENT_DEMO.md). + ## Agent Config File An example configuration file is at the root of the agent directory (example.config.yml) From 576719aa94db34bf16feff16d9e0ce0bbfb61b82 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Wed, 5 Apr 2023 10:14:47 -0700 Subject: [PATCH 15/53] Added openssl.cnf and server.yml file for demo. --- services/core/IEEE_2030_5/demo/openssl.cnf | 70 ++++++++++++++++ services/core/IEEE_2030_5/demo/server.yml | 93 ++++++++++++++++++++++ 2 files changed, 163 insertions(+) create mode 100644 services/core/IEEE_2030_5/demo/openssl.cnf create mode 100644 services/core/IEEE_2030_5/demo/server.yml diff --git a/services/core/IEEE_2030_5/demo/openssl.cnf b/services/core/IEEE_2030_5/demo/openssl.cnf new file mode 100644 index 0000000000..b7ec376faf --- /dev/null +++ b/services/core/IEEE_2030_5/demo/openssl.cnf @@ -0,0 +1,70 @@ +# OpenSSL example configuration file. +# This is mostly being used for generation of certificate requests. +# +# This definition stops the following lines choking if HOME isn't +# defined. +HOME = . +RANDFILE = $ENV::HOME/.rnd + +[ ca ] +default_ca = CA_default + +[ CA_default ] +database = index.txt +serial = serial.txt +policy = policy_default + +# For the CA policy +[ policy_match ] +countryName = optional +stateOrProvinceName = optional +organizationName = optional +organizationalUnitName = optional +commonName = supplied +emailAddress = optional + +[ policy_anything ] +countryName = optional +stateOrProvinceName = optional +localityName = optional +organizationName = optional +organizationalUnitName = optional +commonName = supplied +emailAddress = optional + +[ req ] +default_bits = 2048 +default_md = sha256 +default_keyfile = privkey.pem +distinguished_name = req_distinguished_name +attributes = req_attributes +x509_extensions = v3_ca # The extentions to add to the self signed cert + +[ req_distinguished_name ] +countryName = Country Name (2 letter code) +countryName_default = IN +countryName_min = 2 +countryName_max = 2 +stateOrProvinceName = State or Province Name (full name) +stateOrProvinceName_default = Some-State +localityName = Locality Name (eg, city) +localityName_default = BANGALORE +0.organizationName = Organization Name (eg, company) +0.organizationName_default = GoLinuxCloud +organizationalUnitName = Organizational Unit Name (eg, section) +commonName = Common Name (eg, your name or your server\'s hostname) +commonName_max = 64 +emailAddress = Email Address +emailAddress_max = 64 +[ v3_req ] +# Extensions to add to a certificate request +basicConstraints = CA:FALSE +keyUsage = nonRepudiation, digitalSignature, keyEncipherment +[ v3_ca ] +# Extensions for a typical CA +subjectKeyIdentifier=hash +authorityKeyIdentifier=keyid:always,issuer +basicConstraints = critical,CA:true +[ crl_ext ] +# issuerAltName=issuer:copy +authorityKeyIdentifier=keyid:always# diff --git a/services/core/IEEE_2030_5/demo/server.yml b/services/core/IEEE_2030_5/demo/server.yml new file mode 100644 index 0000000000..f7ece82dee --- /dev/null +++ b/services/core/IEEE_2030_5/demo/server.yml @@ -0,0 +1,93 @@ +--- +#server_hostname: 0.0.0.0:8443 + +server: 127.0.0.1 +# Only include if we need to have dcap be available +# http_port: 8080 +https_port: 7443 + +tls_repository: "~/tls" +openssl_cnf: "openssl.cnf" + +server_mode: enddevices_create_on_start + +# lfdi_mode: Determines what piece of information is used to calculate the lfdi +# +# Options: +# lfdi_mode_from_file - sha256 hash of certificate file's content. +# lfdi_mode_from_cert_fingerprint - sha256 hash of the certificates fingerprint. +# +# default: lfdi_mode_from_cert_fingerprint +#lfdi_mode: lfdi_mode_from_file +lfdi_mode: lfdi_mode_from_cert_fingerprint + +# Create an administrator certificate that can be used from +# browser/api to connect to the platform. +# +# this is important for the demo +generate_admin_cert: True + +log_event_list_poll_rate: 60 +device_capability_poll_rate: 60 +# derp_poll_rate: 10 + +# End Device +devices: + # SolarEdge SE6000H HD-Wave SetApp Enabled Inverter + - id: dev1 + # DeviceCategoryType from ieee_2030_5.models.device_category + deviceCategory: FUEL_CELL + pin: 111115 + + programs: + - description: Program 1 + + # nameplate: + # rtgMaxW: 6000 + ders: + - capabilities: + modesSupported: "1110000000000000" + type: 83 + +programs: + - description: Program 1 + default_control: Control 1 + controls: + - Control 2 + - Control 3 + curves: + - Curve 1 + primacy: 89 + + # - description: Program 2 + # default_control: Control 2 + # - description: Program 3 + # default_control: Control 2 + +controls: + - description: Control 1 + setESDelay: 30 + base: + opModConnect: True + opModMaxLimW: 9500 + + - description: Control 2 + - description: Control 3 + +events: + - control: 0 + +curves: + - description: Curve 1 + curveType: opModVoltVar + CurveData: + - xvalue: 5 + yvalue: 5 + + - description: Curve 2 + curveType: opModFreqWatt + CurveData: + # exitation is only available if yvalue is power factor + - exitation: 10 + xvalue: 5 + yvalue: 5 From 3d758ba54039f5eafc9a681ed0797e77cd4c9d2e Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Wed, 5 Apr 2023 13:16:49 -0700 Subject: [PATCH 16/53] Update demo items. --- services/core/IEEE_2030_5/AGENT_DEMO.md | 14 ++++++++++++-- services/core/IEEE_2030_5/README.md | 2 +- services/core/IEEE_2030_5/demo/inverter_runner.py | 14 +++++++------- services/core/IEEE_2030_5/demo/openssl.cnf | 1 + services/core/IEEE_2030_5/demo/server.yml | 4 +--- services/core/IEEE_2030_5/requirements_demo.txt | 3 ++- 6 files changed, 24 insertions(+), 14 deletions(-) diff --git a/services/core/IEEE_2030_5/AGENT_DEMO.md b/services/core/IEEE_2030_5/AGENT_DEMO.md index c38f67c55a..225447adc3 100644 --- a/services/core/IEEE_2030_5/AGENT_DEMO.md +++ b/services/core/IEEE_2030_5/AGENT_DEMO.md @@ -4,6 +4,8 @@ This readme walks through a demo of an inverter publishing points to the VOLTTRO The demo will require three terminal windows to be open. The first will be for executing the main VOLTTRON process. The second will be for executing the 2030.5 server. The third will be for executing the agent demo through a web interface. For the rest of this document, VOLTTRON_ROOT is assumed to be where one has cloned the volttron repository. +First configure the server then the VOLTTRON instance and findally the web based demo. + ## 2030.5 Server For the server software we will be using a server from a team at PNNL. The GridAPPS-D team has created a 2030.5 server and it is available at . The source code is still in a private repo, but will be released at some time in the future. @@ -31,6 +33,10 @@ For the server software we will be using a server from a team at PNNL. The Grid server.yml ``` +1. Modify the openssl.cnf to include the correct values for [req_distinguished_name]. Or use the defaults. The server will create self-signed certificates for the client to use. + +1. Modify the server.yml file. The default server.yml file contains a device (id: dev1) and DERProgram. **dev1 must be present for the demo to run smoothly.** + 1. Start the server from the activated serverenv **This step will create development certificates for you**. By default the certificates will be generated and stored in ~/tls. One can change this location in the server.yml configuration file. ```bash @@ -50,17 +56,21 @@ For this demo, start a VOLTTRON default instance from the command line. The fol > cd $VOLTTRON_ROOT > source env/bin/activate (volttron)> ./start-volttron + # Watch the volttron log + (volttron)> tail -f volttron.log ``` -1. Using the same terminal as the previous command install the demo requirements as follows. +1. Open another terminal to start the demo server in. ```bash + > cd $VOLTTRON_ROOT + > source env/bin/activate (volttron) > cd service/core/IEEE_2030_5 (volttron) > pip install -r requirements_demo.txt ... ``` -1. Run the webgui.py script using the python interpretor. This should open a webpage allowing one to test the functionality of the 2030.5 agent. +1. Run the webgui.py script using the python interpretor. This should open a webpage allowing one to test the functionality of the 2030.5 agent. By default it will open at . ```bash (volttron)> python demo/webgui.py diff --git a/services/core/IEEE_2030_5/README.md b/services/core/IEEE_2030_5/README.md index b9ca5ed18b..50176867dc 100644 --- a/services/core/IEEE_2030_5/README.md +++ b/services/core/IEEE_2030_5/README.md @@ -1,7 +1,7 @@ # VOLTTRON 2030.5 Agent The VOLTTRON 2030.5 agent communicates with a 2030.5 server using the IEEE 2030.5(2018) protocol. The primary concern of -this agent is to handle the communication between the PlatformDriverAgent and the 2030.5 server. The agent will create MirrorUsagePoints and readings to the 2030.5 server. +this agent is to handle the communication between the PlatformDriverAgent and the 2030.5 server. The agent will create MirrorUsagePoints and readings to the 2030.5 server and send control actions to the message bus during DERControl events. The following diagram illistrates the data flow for the 2030.5 agent from the PlatformDriverAgent to the 2030.5 server. diff --git a/services/core/IEEE_2030_5/demo/inverter_runner.py b/services/core/IEEE_2030_5/demo/inverter_runner.py index fcf08a924d..c511804fb7 100644 --- a/services/core/IEEE_2030_5/demo/inverter_runner.py +++ b/services/core/IEEE_2030_5/demo/inverter_runner.py @@ -98,18 +98,18 @@ def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Genera # print( # f"p_ac = {p_ac}, s_ac = {s_ac}, q_ac= {q_ac}, PF = {PF}, v_ac = {v_ac}, i_ac = {i_ac}" # ) - results = dict(v_mp=dc['v_mp'], + results = dict(PF=PF, + p_ac=p_ac, + q_ac=q_ac, + v_mp=dc['v_mp'], p_mp=dc['p_mp'], i_x=dc['i_x'], i_xx=dc['i_xx'], v_oc=dc['v_oc'], - i_sc=dc['i_sc'], - p_ac=p_ac, - s_ac=p_ac, - q_ac=q_ac, + i_sc=dc['i_sc'], + s_ac=p_ac, v_ac=v_ac, - i_ac=i_ac, - PF=PF) + i_ac=i_ac) print(json.dumps(results)) yield results # single phase circuit calculation diff --git a/services/core/IEEE_2030_5/demo/openssl.cnf b/services/core/IEEE_2030_5/demo/openssl.cnf index b7ec376faf..e2bbdbe22e 100644 --- a/services/core/IEEE_2030_5/demo/openssl.cnf +++ b/services/core/IEEE_2030_5/demo/openssl.cnf @@ -56,6 +56,7 @@ commonName = Common Name (eg, your name or your server\'s h commonName_max = 64 emailAddress = Email Address emailAddress_max = 64 + [ v3_req ] # Extensions to add to a certificate request basicConstraints = CA:FALSE diff --git a/services/core/IEEE_2030_5/demo/server.yml b/services/core/IEEE_2030_5/demo/server.yml index f7ece82dee..13fde30061 100644 --- a/services/core/IEEE_2030_5/demo/server.yml +++ b/services/core/IEEE_2030_5/demo/server.yml @@ -1,10 +1,8 @@ --- -#server_hostname: 0.0.0.0:8443 - server: 127.0.0.1 # Only include if we need to have dcap be available # http_port: 8080 -https_port: 7443 +https_port: 8443 tls_repository: "~/tls" openssl_cnf: "openssl.cnf" diff --git a/services/core/IEEE_2030_5/requirements_demo.txt b/services/core/IEEE_2030_5/requirements_demo.txt index 9648e20138..86815f8db5 100644 --- a/services/core/IEEE_2030_5/requirements_demo.txt +++ b/services/core/IEEE_2030_5/requirements_demo.txt @@ -1,2 +1,3 @@ pvlib -nicegui \ No newline at end of file +nicegui +requests \ No newline at end of file From 88e2757fb0b83efdf839e7043aa1512596a45102 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Mon, 17 Apr 2023 10:31:35 -0700 Subject: [PATCH 17/53] Update for demo --- .../core/IEEE_2030_5/demo/inverter_runner.py | 3 +- services/core/IEEE_2030_5/demo/keypair.json | 4 + services/core/IEEE_2030_5/demo/server.yml | 6 - services/core/IEEE_2030_5/demo/webgui.py | 230 +++++++---- .../core/IEEE_2030_5/ieee_2030_5/agent.py | 57 +-- .../core/IEEE_2030_5/ieee_2030_5/client.py | 391 +++++++++++++++--- 6 files changed, 494 insertions(+), 197 deletions(-) create mode 100644 services/core/IEEE_2030_5/demo/keypair.json diff --git a/services/core/IEEE_2030_5/demo/inverter_runner.py b/services/core/IEEE_2030_5/demo/inverter_runner.py index c511804fb7..670933139e 100644 --- a/services/core/IEEE_2030_5/demo/inverter_runner.py +++ b/services/core/IEEE_2030_5/demo/inverter_runner.py @@ -162,8 +162,7 @@ def frombus(message: List) -> AllPoints: points = AllPoints() for k, v in inv.items(): - if k == 'PF': - points.add(k, pf) + points.add(k, v) # publish agent.vip.pubsub.publish(peer="pubsub", topic=f"{topic_to_publish}", diff --git a/services/core/IEEE_2030_5/demo/keypair.json b/services/core/IEEE_2030_5/demo/keypair.json new file mode 100644 index 0000000000..77d8dd1527 --- /dev/null +++ b/services/core/IEEE_2030_5/demo/keypair.json @@ -0,0 +1,4 @@ +{ + "public": "YrRnX1ifv5hkctAtNsLMut1j3qr7dPf0gppvwH_53wE", + "secret": "C55SSFUKAM38dXZKjMSolRvFVfILbSTF9JkUQWlP8II" +} diff --git a/services/core/IEEE_2030_5/demo/server.yml b/services/core/IEEE_2030_5/demo/server.yml index 13fde30061..fd23623726 100644 --- a/services/core/IEEE_2030_5/demo/server.yml +++ b/services/core/IEEE_2030_5/demo/server.yml @@ -50,9 +50,6 @@ devices: programs: - description: Program 1 default_control: Control 1 - controls: - - Control 2 - - Control 3 curves: - Curve 1 primacy: 89 @@ -69,9 +66,6 @@ controls: opModConnect: True opModMaxLimW: 9500 - - description: Control 2 - - description: Control 3 - events: - control: 0 diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index a1f6643277..250a104a7e 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -2,56 +2,121 @@ from __future__ import annotations import asyncio +import atexit import json -import os.path +import os import platform +import re import shlex import sys import time import uuid +from asyncio.subprocess import Process from dataclasses import dataclass from datetime import datetime, timedelta from pathlib import Path from typing import Any, Optional +import yaml + +from volttron.platform import get_volttron_root + sys.path.insert(0, str(Path(__file__).parent.parent)) +import subprocess + import ieee_2030_5.models as m -from nicegui import background_tasks, ui +import requests +from nicegui import app, background_tasks, ui from services.core.IEEE_2030_5.ieee_2030_5 import dataclass_to_xml, xml_to_dataclass +session = requests.Session() +tlsdir = Path("~/tls").expanduser() +session.cert = (str(tlsdir.joinpath("certs/admin.pem")), str(tlsdir.joinpath("private/admin.pem"))) +session.verify = str(tlsdir.joinpath("certs/ca.pem")) + +def get_url(endpoint, not_admin: bool = False) -> str: + if endpoint.startswith('/'): + endpoint = endpoint[1:] + if not_admin: + return f"https://127.0.0.1:8443/{endpoint}" + return f"https://127.0.0.1:8443/admin/{endpoint}" + +filedirectory = Path(__file__).parent +pkfile = filedirectory.joinpath("keypair.json") +if not pkfile.exists(): + print(f"Key file not found in demo directory {pkfile}.") + sys.exit(0) + +pk_data = yaml.safe_load(pkfile.open().read()) + +os.environ['AGENT_PUBLICKEY'] = pk_data['public'] +os.environ['AGENT_SECRETEKY'] = pk_data['secret'] +os.environ['AGENT_VIP_IDENTITY'] = "inverter1" +os.environ['AGENT_CONFIG'] = str(filedirectory.parent.joinpath('example.config.yml')) +agent_py = str(filedirectory.parent.joinpath("ieee_2030_5/agent.py")) +py_launch = str(Path(get_volttron_root()).joinpath("scripts/pycharm-launch.py")) + tasks = [] def add_my_task(task): tasks.append(task) - -def _send_control_event(): - default_pf = 0.99 - import requests - session = requests.Session() - session.cert = ('/home/os2004/tls/certs/admin.pem', '/home/os2004/tls/private/admin.pem') - session.verify = "/home/os2004/tls/certs/ca.pem" - - control_path = Path('inverter.ctl') - derc: m.DERControl = xml_to_dataclass(xml_text.value) - +control_status = "None" +derp = "Not Set" +inverter_pf = "Not Set" +inverter_p = "Not Set" +inverter_q = "Not Set" +in_real = False +in_reactive = False +def new_agent_output(line: str): + global inverter_q, inverter_p, in_real, in_reactive - time_now = int(time.mktime((datetime.utcnow()).timetuple())) + if "url: /mup_1" in line: + in_reactive = True - while time_now < derc.interval.start: - time.sleep(0.1) - time_now = int(time.mktime((datetime.utcnow()).timetuple())) - - with open(str(control_path), 'wt') as fp: - fp.write(json.dumps(dict(pf=derc.DERControlBase.opModFixedPFInjectW))) + if in_reactive: + if line.startswith(""): + inverter_q = re.search(r'(.*?)', line).group(1) + in_reactive = False + status.content = updated_markdown() - while time_now < derc.interval.start + derc.interval.duration: - time.sleep(0.1) - time_now = int(time.mktime((datetime.utcnow()).timetuple())) - - control_path.write(json.dump(dict(pf=default_pf))) + if "url: /mup_1" in line: + in_real = True + + if in_real: + if line.startswith(""): + inverter_p = re.search(r'(.*?)', line).group(1) + in_real = False + status.content = updated_markdown() + + + +def _change_power_factor(new_pf): + global inverter_pf + + current_time = int(time.mktime(datetime.utcnow().timetuple())) + + ctrl_base = m.DERControlBase(opModConnect=True, opModMaxLimW=9500) + ctrl = m.DERControl(mRID="ctrl1mrdi", description="A control for the control list") + ctrl.DERControlBase = ctrl_base + ctrl.interval = m.DateTimeInterval(start=current_time + 10, duration=20) + ctrl.randomizeDuration = 180 + ctrl.randomizeStart = 180 + ctrl.DERControlBase.opModFixedW = 500 + ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactor(int(pf.value)) + + posted = dataclass_to_xml(ctrl) + utility_log.push(f"Event Posted to Change opModFixedPFInjectW to {pf.value}") + utility_log.push(posted) + resp = session.post(get_url("derp/0/derc"), data=posted) + resp = session.get(get_url(resp.headers.get('Location'), not_admin=True)) + pfingect = xml_to_dataclass(resp.text) + inverter_pf = pfingect.DERControlBase.opModFixedPFIngectW + status.content = updated_markdown() + + @@ -64,26 +129,7 @@ def get_control_event_default(): description="New DER Control Event", DERControlBase=derbase, interval=m.DateTimeInterval(duration=10, start=time_plus_10)) - - - # setESLowVolt=0.917, - # setESHighVolt=1.05, - # setESLowFreq=59.5, - # setESHighFreq=60.1, - # setESRampTms=300, - # setESRandomDelay=0, - #DERControlBase=derbase) - # dderc = m.DefaultDERControl(href=hrefs.get_dderc_href(), - # mRID=str(uuid.uuid4()), - # description="Default DER Control Mode", - # setESDelay=300, - # setESLowVolt=0.917, - # setESHighVolt=1.05, - # setESLowFreq=59.5, - # setESHighFreq=60.1, - # setESRampTms=300, - # setESRandomDelay=0, - # DERControlBase=derbase) + return dataclass_to_xml(derc) @@ -98,25 +144,26 @@ def _setup_event(element): interval=m.DateTimeInterval(duration=10, start=time_plus_60)) element.value=dataclass_to_xml(derc) - -async def _reset_tasks(): - for task in tasks: - print(task.cancel()) - - await asyncio.sleep(0.1) + #background_tasks.running_tasks.clear() + +async def _exit_background_tasks(): + for item in tasks: + if isinstance(item, Process): + try: + item.kill() # .cancel() + except ProcessLookupError: + pass + else: + item.cancel() + # async for proc, command in tasks: + # print(f"Stoping {command.label}") + # proc.cancel() - # while not task.cancelled(): - # asyncio.sleep(0.1) - # print(task.cancelled()) - - tasks.clear() agent_log.clear() - proxy_log.clear() inverter_log.clear() - - #background_tasks.running_tasks.clear() - + utility_log.clear() + async def run_command(command: LabeledCommand) -> None: '''Run a command in the background and display the output in the pre-created dialog.''' @@ -126,6 +173,8 @@ async def run_command(command: LabeledCommand) -> None: cwd=command.working_dir ) + add_my_task(process) + # NOTE we need to read the output in chunks, otherwise the process will block output = '' while True: @@ -133,6 +182,8 @@ async def run_command(command: LabeledCommand) -> None: if not new: break output = new.decode() + if command.agent_output: + new_agent_output(output.strip()) try: jsonparsed = json.loads(output) @@ -145,9 +196,6 @@ async def run_command(command: LabeledCommand) -> None: # NOTE the content of the markdown element is replaced every time we have new output #result.content = f'```\n{output}\n```' -with ui.dialog() as dialog, ui.card(): - result = ui.markdown() - @dataclass class LabeledCommand: label: str @@ -155,37 +203,65 @@ class LabeledCommand: output_element: Any working_dir: str = str(Path(__file__).parent) output_only_json: bool = True + agent_output: bool = False commands = [ - LabeledCommand("Start Inverter", f'{sys.executable} inverter_runner.py', lambda: inverter_log), - LabeledCommand("Start Proxy", f'/home/os2004/repos/gridappsd-2030_5/.venv/bin/python -m ieee_2030_5.basic_proxy config.yml ', lambda: proxy_log, "/home/os2004/repos/gridappsd-2030_5", - output_only_json=False), - LabeledCommand("Start Agent", f'{sys.executable} -m ieee_2030_5.agent', lambda: agent_log, "/home/os2004/repos/volttron/services/core/IEEE_2030_5", - output_only_json=False), + LabeledCommand("Start Inverter", + f'{sys.executable} inverter_runner.py', + lambda: inverter_log), + LabeledCommand("Start Agent", + f"{sys.executable} {py_launch} {agent_py}", + lambda: agent_log, filedirectory.parent, + output_only_json=False, + agent_output=True) ] +def updated_markdown() -> str: + return f"""## Status + DER Program: {derp} + Control: {control_status} + Real Power (p): {inverter_p} + Reactive Power (q): {inverter_q} + Power Factor (pf): {inverter_pf} + """ + with ui.column(): # commands = [f'{sys.executable} inverter_runner.py'] with ui.row(): for command in commands: ui.button(command.label, on_click=lambda _, c=command: add_my_task(background_tasks.create(run_command(c)))).props('no-caps') - - ui.button("Reset", on_click=lambda: _reset_tasks()).props('no-caps') + + pf = ui.select(options=[70, 80, 90], value=70, label="Power Factor").classes('w-32') + ui.button("Change Power Factor", on_click=lambda: _change_power_factor(pf.value)).props('no-caps') + ui.button("Reset", on_click=_exit_background_tasks).props('no-caps') + + with ui.row(): + status = ui.markdown(updated_markdown()) #ui.button("Update Control Time", on_click=lambda: _setup_event(xml_text)).props('no-caps') #ui.button("Send Control", on_click=lambda: _send_control_event()).props('no-caps') # with ui.row(): # xml_text = ui.textarea(label="xml", value=get_control_event_default()).props('rows=20').props('cols=120').classes('w-full, h-80') with ui.row(): ui.label("Inverter Log") - inverter_log = ui.log(10).props('rows=5').props('cols=120').classes('w-full h-80') - with ui.row(): - ui.label("Proxy Log") - proxy_log = ui.log(10).props('rows=5').props('cols=120').classes('w-full h-80') + inverter_log = ui.log().props('cols=120').classes('w-full h-20') + # with ui.row(): + # ui.label("Proxy Log") + # proxy_log = ui.log().props('cols=120').classes('w-full h-80') with ui.row(): ui.label("Agent Log") - agent_log = ui.log(10).props('rows=5').props('cols=120').classes('w-full h-80') + agent_log = ui.log().props('cols=120').classes('w-full h-80') + with ui.row(): + ui.label("Utility Log") + utility_log = ui.log().props('cols=120').classes('w-full h-20') + + -# NOTE on windows reload must be disabled to make asyncio.create_subprocess_exec work (see https://github.com/zauberzeug/nicegui/issues/486) -ui.run(reload=platform.system() != "Windows") \ No newline at end of file + +#atexit.register(_exit_background_tasks) +app.on_shutdown(_exit_background_tasks) + +# NOTE on windows reload must be disabled to make asyncio.create_subprocess_exec work +# (see https://github.com/zauberzeug/nicegui/issues/486) +ui.run(reload=platform.system() != "Windows", ) diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index 46b3b332ee..f31802f81a 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -158,7 +158,6 @@ def configure(self, config_name, action, contents): return for sub in self._subscriptions: - _log.info(f"Removing subscription: {sub}") self.vip.pubsub.unsubscribe(peer="pubsub", prefix=sub, callback=self._data_published) @@ -196,19 +195,8 @@ def configure(self, config_name, action, contents): self._server_usage_points = self._client.mirror_usage_point_list() - # for server_mup in self._server_usage_points.MirrorUsagePoint: - # # TODO: Make the config file have a list of meter readings for the points subscription - # mup_reading = m.MirrorMeterReading(mRID=server_mup.MirrorMeterReading[0].mRID, - # description=server_mup.MirrorMeterReading[0].description) - # # new mrid is based upon the mirror reading. - # mup_reading.MirrorReadingSet = m.MirrorReadingSet(mrid=mup_reading.mRID + "1") - # mup_reading.MirrorReadingSet.timePeriod.start = int(round(datetime.utcnow().timestamp())) - - # self._mup_readings[server_mup.MirrorMeterReading.mRID] = mup_reading - for sub in self._subscriptions: - _log.info(f"Subscribing to: {sub}") self.vip.pubsub.subscribe(peer="pubsub", prefix=sub, callback=self._data_published) @@ -220,6 +208,8 @@ def _data_published(self, peer, sender, bus, topic, headers, message): _log.debug("DATA Published") points = AllPoints.frombus(message) + _log.debug(points) + for index, pt in enumerate(self._mirror_usage_point_list): @@ -244,49 +234,6 @@ def _data_published(self, peer, sender, bus, topic, headers, message): _log.debug(points.__dict__) - # @Core.receiver("onstart") - # def onstart(self, sender, **kwargs): - # """ - # This is method is called once the Agent has successfully connected to the platform. - # This is a good place to setup subscriptions if they are not dynamic or - # do any other startup activities that require a connection to the message bus. - # Called after any configurations methods that are called at startup. - - # Usually not needed if using the configuration store. - # """ - # # Example publish to pubsub - # # self.vip.pubsub.publish('pubsub', "some/random/topic", message="HI!") - - # # Example RPC call - # # self.vip.rpc.call("some_agent", "some_method", arg1, arg2) - # pass - - # @Core.receiver("onstop") - # def onstop(self, sender, **kwargs): - # """ - # This method is called when the Agent is about to shutdown, but before it disconnects from - # the message bus. - # """ - # pass - - # @RPC.export - # def rpc_method(self, arg1, arg2, kwarg1=None, kwarg2=None): - # """ - # RPC method - - # May be called from another agent via self.vip.rpc.call - # """ - # return self.setting1 + arg1 - arg2 - - # @PubSub.subscribe('pubsub', '', all_platforms=True) - # def on_match(self, peer, sender, bus, topic, headers, message): - # """Use match_all to receive all messages and print them out.""" - # _log.debug( - # "Peer: {0}, Sender: {1}:, Bus: {2}, Topic: {3}, Headers: {4}, " - # "Message: \n{5}".format(peer, sender, bus, topic, headers, - # pformat(message))) - - def main(): """ Main method called during startup of agent. diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index 138de40190..5b02fddbe4 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -5,23 +5,50 @@ import ssl import subprocess import threading +import time import xml.dom.minidom +from datetime import datetime from http.client import HTTPMessage, HTTPSConnection from os import PathLike from pathlib import Path from threading import Timer -from typing import Dict, Optional, Tuple +from typing import Any, Callable, Dict, List, Optional, Set, Tuple from uuid import uuid4 import ieee_2030_5.models as m import xsdata +from blinker import Signal from ieee_2030_5 import dataclass_to_xml, xml_to_dataclass _log = logging.getLogger(__name__) +TimeType = int -class IEEE2030_5_Client: - clients: set[IEEE2030_5_Client] = set() +class _TimerThread(threading.Thread): + tick = Signal("tick") + + def __init__(self): + super().__init__() + self._tick = 0 + + @staticmethod + def user_readable(timestamp: int): + dt = datetime.fromtimestamp(timestamp) + return dt.strftime("%m/%d/%Y, %H:%M:%S") + + def run(self) -> None: + + while True: + self._tick = int(time.mktime(datetime.utcnow().timetuple())) + _TimerThread.tick.send(self._tick) + time.sleep(1) + +TimerThread = _TimerThread() +TimerThread.daemon = True +TimerThread.start() + +class IEEE_2030_5_Client: + clients: set[IEEE_2030_5_Client] = set() # noinspection PyUnresolvedReferences def __init__(self, @@ -31,7 +58,8 @@ def __init__(self, certfile: PathLike, pin: str, server_ssl_port: Optional[int] = 443, - debug: bool = True): + debug: bool = True, + device_capabilities_endpoint: str = "/dcap"): cafile = cafile if isinstance(cafile, PathLike) else Path(cafile) keyfile = keyfile if isinstance(keyfile, PathLike) else Path(keyfile) @@ -61,24 +89,243 @@ def __init__(self, context=self._ssl_context) self._response_headers: HTTPMessage self._response_status = None - - self._device_cap: m.DeviceCapability = m.DeviceCapability() - self._mup: m.MirrorUsagePointList = m.MirrorUsagePointList() - self._upt: m.UsagePointList = m.UsagePointList() - self._edev: m.EndDeviceListLink = m.EndDeviceListLink() - self._end_devices: m.EndDeviceList = m.EndDeviceList() - self._fsa_list: m.FunctionSetAssignmentsList = m.FunctionSetAssignmentsList() - self._der_programs: m.DERProgramList = m.DERProgramList() - self._mup: m.MirrorUsagePoint = m.MirrorUsagePoint() self._debug = debug + + + self._mup: m.MirrorUsagePointList = None # type: ignore + self._upt: m.UsagePointList = None # type: ignore + + self._dcap_poll_rate: int = 0 self._dcap_timer: Optional[Timer] = None self._disconnect: bool = False + + self._timers: Set[Timer] = set() + + # Offset between local udt and server udt + self._time_offset: int = 0 + + self._end_device_map: Dict[str, m.EndDeviceList] = {} + self._end_devices: Dict[str, m.EndDevice] = {} + + self._fsa_map: Dict[str, m.FunctionSetAssignmentsList] = {} + self._fsa: Dict[str, m.FunctionSetAssignments] = {} + + self._der_map: Dict[str, m.DERList] = {} + self._der: Dict[str, m.DER] = {} + + self._der_program_map: Dict[str, m.DERProgramList] = {} + self._der_program: Dict[str, m.DERProgram] = {} + + self._mirror_usage_point_map: Dict[str, m.MirrorUsagePointList] = {} + self._mirror_usage_point: Dict[str, m.MirrorUsagePoint] = {} + + self._usage_point_map: Dict[str, m.UsagePointList] = {} + self._usage_point: Dict[str, m.UsagePoint] = {} + self._before_dcap_update_signal = Signal('before-dcap-request') + self._after_dcap_update_signal = Signal('before-dcap-request') + self._before_client_start_signal = Signal('before-client-start') + self._after_client_start_signal = Signal('after-client-start') + + self._der_control_event_started_signal = Signal('der-control-event-started') + self._der_control_event_ended_signal = Signal('der-control-event-ended') + + self._before_event_start_signal = Signal('before-event-start') + self._after_event_end_signal = Signal('after-event-end') + + + self._dcap_endpoint = device_capabilities_endpoint # Starts a timer - self.update_state() + # self._update_dcap_tree(device_capabilities_endpoint) - IEEE2030_5_Client.clients.add(self) + IEEE_2030_5_Client.clients.add(self) + + def start(self): + """Starts the client connection to the 2030.5 server configured during construction. + """ + self._before_client_start_signal.send(self) + self._update_dcap_tree() + self._after_client_start_signal.send(self) + TimerThread.tick.connect(self._tick) + + def _tick(self, timestamp): + if timestamp % 5 == 0: + for derp in self._der_program_map.items(): + print(self.__get_request__(f"/derp_0_derc")) + + #_log.debug(f"Tick: {timestamp}") + + def der_control_event_started(self, fun: Callable): + self._der_control_event_started_signal.connect(fun) + + def der_control_event_ended(self, fun: Callable): + self._der_control_event_ended_signal.connect(fun) + + def before_dcap_update(self, fun: Callable): + self._before_dcap_update_signal.connect(fun) + + def after_dcap_update(self, fun: Callable): + self._after_dcap_update_signal.connect(fun) + + def after_client_start(self, fun: Callable): + self._after_client_start_signal.connect(fun) + + def before_client_start(self, fun: Callable): + self._before_client_start_signal.connect(fun) + + @property + def server_time(self) -> TimeType: + return int(time.mktime(datetime.utcnow().timetuple())) + self._time_offset + + + @property + def _is_ok(self): + return self._response_status == 200 + + def get_der_hrefs(self) -> List[str]: + return list(self._der.keys()) + + def get_der(self, href: str) -> Optional[m.DER]: + return self._der.get(href) + + def put_der_availability(self, der_href: str, new_availability: m.DERAvailability) -> int: + resp = self.__put__(der_href, dataclass_to_xml(new_availability)) + return resp.status + + def put_der_capability(self, der_href: str, new_capability: m.DERCapability) -> int: + resp = self.__put__(der_href, dataclass_to_xml(new_capability)) + return resp.status + + def put_der_settings(self, der_href: str, new_settings: m.DERSettings) -> int: + resp = self.__put__(der_href, dataclass_to_xml(new_settings)) + return resp.status + + def put_der_status(self, der_href: str, new_status: m.DERStatus) -> int: + resp = self.__put__(der_href, dataclass_to_xml(new_status)) + return resp.status + + def _update_dcap_tree(self, endpoint: Optional[str] = None): + """Retrieve the DeviceCapability and downstream link objects. + + Currently supports the following: + + + + Args: + + endpoint - /dcap by default but can be passed if there is a different entry point into hte + system. + """ + if not endpoint: + endpoint = self._dcap_endpoint + if not endpoint: + raise ValueError("Invalid device_capability_endpoint specified in constructor.") + + self._before_dcap_update_signal.send(self) + + # retrieve device capabilities from the server + dcap: m.DeviceCapability = self.__get_request__(endpoint) + if not self._is_ok: + raise RuntimeError(dcap) + + self._after_dcap_update_signal.send(self) + + # if time is available then grab and create an offset + if dcap.TimeLink is not None and dcap.TimeLink.href: + _time: m.Time = self.__get_request__(dcap.TimeLink.href) + self._time_offset = int(time.mktime(datetime.utcnow().timetuple())) - _time.currentTime + + if dcap.EndDeviceListLink is not None and dcap.EndDeviceListLink.all > 0: + + self._update_list(dcap.EndDeviceListLink.href, "EndDevice", self._end_device_map, self._end_devices) + + for ed in self._end_devices.values(): + if not self.is_end_device_registered(ed, self._pin): + raise ValueError(f"Device is not registered on this server!") + self._update_list(ed.FunctionSetAssignmentsListLink.href, + "FunctionSetAssignments", self._fsa_map, self._fsa) + + if ed.DERListLink: + derlist: m.DERList = self.__get_request__(ed.DERListLink.href) + self._der_map[derlist.href] = derlist + for index, der in enumerate(derlist.DER): + self._der[der.href] = der + + for fsa in self._fsa.values(): + if fsa.DERProgramListLink: + self._der_program_map[fsa.DERProgramListLink.href] = self.__get_request__(fsa.DERProgramListLink.href) + + + + if dcap.MirrorUsagePointListLink is not None and dcap.MirrorUsagePointListLink.href: + self._update_list(dcap.MirrorUsagePointListLink.href, "MirrorUsagePoint", self._mirror_usage_point_map, self._mirror_usage_point) + + + # if dcap.UsagePointListLink is not None and dcap.UsagePointListLink.href: + # self._update_list(dcap.UsagePointListLink.href, "UsagePoint", self._usage_point_map, self._usage_point) + + self._dcap = dcap + + + def post_log_event(self, end_device: m.EndDevice, log_event: m.LogEvent): + if not log_event.createdDateTime: + log_event.createdDateTime = self.server_time + + self.request(end_device.LogEventListLink.href, method="POST") + + + + def _update_list(self, path: str, list_prop: str, outer_map: Dict, inner_map: Dict): + """Update mappings using 2030.5 list nomoclature. + + Example structure for EndDeviceListLink + + EndDeviceListLink.href points to EndDeviceList. + EndDeviceList.EndDevice points to a list of EndDevice objects. + + Args: + + path: Original path of the list (in example EndDeviceListLink.href) + list_prop: The property on the object that holds a list of elements (in example EndDevice) + outer_mapping: Mapping where the original list object is stored by href + inner_mapping: Mapping where the inner objects are stored by href + + """ + my_response = self.__get_request__(path) + + if not self._is_ok: + raise RuntimeError(my_response) + + if my_response is not None: + href = getattr(my_response, "href") + outer_map[href] = my_response + for inner in getattr(my_response, list_prop): + href = getattr(inner, "href") + inner_map[href] = inner + + + def _get_device_capabilities(self, endpoint: str) -> m.DeviceCapability: + dcap: m.DeviceCapability = self.__get_request__(endpoint) + if self._response_status != 200: + raise RuntimeError(dcap) + + self._dcap = dcap + + + if self._device_cap.pollRate is not None: + self._dcap_poll_rate = self._device_cap.pollRate + else: + self._dcap_poll_rate = 600 + + _log.debug(f"devcap id {id(self._device_cap)}") + _log.debug(threading.currentThread().name) + _log.debug(f"DCAP: Poll rate: {self._dcap_poll_rate}") + self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, (self.device_capability, url)) + self._dcap_timer.start() + + return self._device_cap + @property def lfdi(self) -> str: @@ -102,41 +349,24 @@ def enddevices(self) -> m.EndDeviceList: return self._end_devices @property - def enddevice(self, index: int = 0) -> m.EndDevice: - return self._end_devices.EndDevice[index] + def enddevice(self, href: str = "") -> m.EndDevice: + """Retrieve a client's end device based upon the href of the end device. + + Args: + + href: If "" then in single client mode and return the only end device available. + """ + if not href: + href = list(self._end_devices.keys())[0] + + end_device = self._end_devices.get(href) + + return end_device def __hash__(self) -> int: return self._keyfile.read_text().__hash__() # type: ignore[attr-defined] - - def update_state(self) -> None: - self._device_cap = self.device_capability() - self._end_devices = self.get_enddevices() - ed = self.enddevice - if ed.FunctionSetAssignmentsListLink.href: - self._fsa_list: m.FunctionSetAssignmentsList = self.request(endpoint=ed.FunctionSetAssignmentsListLink.href) - if len(self._fsa_list.FunctionSetAssignments) > 1: - raise ValueError("Server responded with more than one function set assignment.") - for fsa in self._fsa_list.FunctionSetAssignments: - if fsa.DERProgramListLink.href: - self._der_programs = self.request(fsa.DERProgramListLink.href) - - - - # def register_end_device(self) -> str: - # lfid = utils.get_lfdi_from_cert(self._cert) - # sfid = utils.get_sfdi_from_lfdi(lfid) - # response = self.__post__(dcap.EndDeviceListLink.href, - # data=utils.dataclass_to_xml( - # m.EndDevice(sFDI=sfid))) - # print(response) - - # if response.status in (200, 201): - # return response.headers.get("Location") - - # raise werkzeug.exceptions.Forbidden() - def is_end_device_registered(self, end_device: m.EndDevice, pin: int) -> bool: reg = self.registration(end_device) @@ -203,13 +433,23 @@ def der_program_list(self, device: m.EndDevice) -> m.DERProgramList: return der_programs_list - def post_mirror_reading(self, reading: m.MirrorMeterReading): - print(reading) + def post_mirror_reading(self, reading: m.MirrorMeterReading) -> str: + data = dataclass_to_xml(reading) + resp = self.__post__(reading.href, data=data) + + if not int(resp.status) >= 200 and int(resp.status) < 300: + _log.error(f"Posting to {reading.href}") + _log.error(f"Response status: {resp.status}") + _log.error(f"{resp.read().decode('utf-8')}") + + + return resp.headers['Location'] + def mirror_usage_point_list(self) -> m.MirrorUsagePointList: - self._mup = self.__get_request__( - self._device_cap.MirrorUsagePointListLink.href) - return self._mup + mupl = self._mirror_usage_point_map.get(self._dcap.MirrorUsagePointListLink.href) + + return mupl def usage_point_list(self) -> m.UsagePointList: self._upt = self.__get_request__( @@ -228,7 +468,7 @@ def timelink(self): def disconnect(self): self._disconnect = True self._dcap_timer.cancel() - IEEE2030_5_Client.clients.remove(self) + IEEE_2030_5_Client.clients.remove(self) def request(self, endpoint: str, @@ -244,25 +484,62 @@ def request(self, return self.__post__(endpoint, body, headers=headers) def create_mirror_usage_point( - self, mirror_usage_point: m.MirrorUsagePoint) -> Tuple[int, str]: + self, mirror_usage_point: m.MirrorUsagePoint) -> str: + """Create a new mirror usage point on the server. + + Args: + + mirror_usage_point: Minimal type for MirrorUsagePoint + + Return: + + The location of the new usage point href for posting to. + """ data = dataclass_to_xml(mirror_usage_point) - resp = self.__post__(self._device_cap.MirrorUsagePointListLink.href, + resp = self.__post__(self._dcap.MirrorUsagePointListLink.href, data=data) - return resp.status, resp.headers['Location'] + return resp.headers['Location'] + def __put__(self, + url: str, + data: Any, + headers: Optional[Dict[str, str]] = None): + if not headers: + headers = {'Content-Type': 'text/xml'} + + if self._debug: + print(f"----> POST REQUEST") + print(f"url: {url} body: {data}") + + self.http_conn.request(method="POST", + headers=headers, + url=url, + body=data) + response = self._http_conn.getresponse() + return response + def __post__(self, url: str, data=None, headers: Optional[Dict[str, str]] = None): if not headers: headers = {'Content-Type': 'text/xml'} + + if self._debug: + print(f"----> POST REQUEST") + print(f"url: {url} body: {data}") self.http_conn.request(method="POST", headers=headers, url=url, body=data) response = self._http_conn.getresponse() + response_data = response.read().decode("utf-8") # response_data = response.read().decode("utf-8") + if response_data and self._debug: + print(f"<---- POST RESPONSE") + print(f"{response_data}") # toprettyxml()}") + return response @@ -310,9 +587,9 @@ def __close__(self): # noinspection PyTypeChecker def __release_clients__(): - for x in IEEE2030_5_Client.clients: + for x in IEEE_2030_5_Client.clients: x.__close__() - IEEE2030_5_Client.clients = None + IEEE_2030_5_Client.clients = None atexit.register(__release_clients__) @@ -336,7 +613,7 @@ def __release_clients__(): headers = {'Connection': 'Keep-Alive', 'Keep-Alive': "max=1000,timeout=30"} - h = IEEE2030_5_Client(cafile=SERVER_CA_CERT, + h = IEEE_2030_5_Client(cafile=SERVER_CA_CERT, server_hostname="127.0.0.1", server_ssl_port=8070, keyfile=KEY_FILE, From 8af4159a42113093f9ed0c72a2f2e1df8ec17648 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Mon, 17 Apr 2023 12:07:42 -0700 Subject: [PATCH 18/53] Client update and webui completion --- services/core/IEEE_2030_5/AGENT_DEMO.md | 21 +++++++++- .../demo/images/control_active.png | Bin 0 -> 14284 bytes .../demo/images/control_scheduled.png | Bin 0 -> 13992 bytes .../demo/images/initial_conditions.png | Bin 0 -> 12323 bytes .../demo/images/start_agent_and_inverter.png | Bin 0 -> 13766 bytes services/core/IEEE_2030_5/demo/webgui.py | 37 +++++++++++++----- .../core/IEEE_2030_5/ieee_2030_5/client.py | 4 +- 7 files changed, 49 insertions(+), 13 deletions(-) create mode 100644 services/core/IEEE_2030_5/demo/images/control_active.png create mode 100644 services/core/IEEE_2030_5/demo/images/control_scheduled.png create mode 100644 services/core/IEEE_2030_5/demo/images/initial_conditions.png create mode 100644 services/core/IEEE_2030_5/demo/images/start_agent_and_inverter.png diff --git a/services/core/IEEE_2030_5/AGENT_DEMO.md b/services/core/IEEE_2030_5/AGENT_DEMO.md index 225447adc3..05aa9fef89 100644 --- a/services/core/IEEE_2030_5/AGENT_DEMO.md +++ b/services/core/IEEE_2030_5/AGENT_DEMO.md @@ -65,11 +65,28 @@ For this demo, start a VOLTTRON default instance from the command line. The fol ```bash > cd $VOLTTRON_ROOT > source env/bin/activate - (volttron) > cd service/core/IEEE_2030_5 - (volttron) > pip install -r requirements_demo.txt + (volttron)> cd service/core/IEEE_2030_5 + (volttron)> pip install -r requirements_demo.txt ... ``` +1. Create an agent keypair for the 2030.5 agent to use (only needed for demo in real mode installing the agent would create this). + + ```bash + (volttron)> vctl keypair > demo/keypair.json + (volttron)> cat demo/keypair.json + { + "public": "YrRnX1ifv5hkctAtNsLMut1j3qr7dPf0gppvwH_53wE", + "secret": "C55SSFUKAM38dXZKjMSolRvFVfILbSTF9JkUQWlP8II" + } + ``` + +1. Add the publickey to VOLTTRON auth mechanism + + ```bash + (volttron)> vctl auth add --credentials "YrRnX1ifv5hkctAtNsLMut1j3qr7dPf0gppvwH_53wE" --user_id inverter1 + ``` + 1. Run the webgui.py script using the python interpretor. This should open a webpage allowing one to test the functionality of the 2030.5 agent. By default it will open at . ```bash diff --git a/services/core/IEEE_2030_5/demo/images/control_active.png b/services/core/IEEE_2030_5/demo/images/control_active.png new file mode 100644 index 0000000000000000000000000000000000000000..541d14cf09f345226677ac08c5fd0f6da5b68c9a GIT binary patch literal 14284 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 MsyZrV$~NKu0}(7|GXMYp literal 0 HcmV?d00001 diff --git a/services/core/IEEE_2030_5/demo/images/initial_conditions.png b/services/core/IEEE_2030_5/demo/images/initial_conditions.png new file mode 100644 index 0000000000000000000000000000000000000000..8b9c40c2f53adc7a9cd0dea8c7ba3093ac039112 GIT binary patch literal 12323 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' in line: + in_control = True + + if in_control: + if "" in line: + status_value = int(re.search(r'(.*?)', line).group(1)) + if status_value == -1: + control_status = "Control Complete" + elif status_value == 0: + control_status = "Control Scheduled" + elif status_value == 1: + control_status = "Active" + else: + control_status = "Not Set" + in_control = False + + status.content = updated_markdown() if "url: /mup_1" in line: in_reactive = True @@ -105,17 +124,18 @@ def _change_power_factor(new_pf): ctrl.randomizeDuration = 180 ctrl.randomizeStart = 180 ctrl.DERControlBase.opModFixedW = 500 - ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactor(int(pf.value)) + ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactorWithExcitation(displacement=int(pf.value)) posted = dataclass_to_xml(ctrl) utility_log.push(f"Event Posted to Change opModFixedPFInjectW to {pf.value}") utility_log.push(posted) resp = session.post(get_url("derp/0/derc"), data=posted) resp = session.get(get_url(resp.headers.get('Location'), not_admin=True)) - pfingect = xml_to_dataclass(resp.text) - inverter_pf = pfingect.DERControlBase.opModFixedPFIngectW + pfingect: m.DERControl = xml_to_dataclass(resp.text) + inverter_pf = pfingect.DERControlBase.opModFixedPFInjectW.displacement status.content = updated_markdown() + @@ -217,8 +237,7 @@ class LabeledCommand: ] def updated_markdown() -> str: - return f"""## Status - DER Program: {derp} + return f"""#### Status Control: {control_status} Real Power (p): {inverter_p} Reactive Power (q): {inverter_q} @@ -244,17 +263,17 @@ def updated_markdown() -> str: # xml_text = ui.textarea(label="xml", value=get_control_event_default()).props('rows=20').props('cols=120').classes('w-full, h-80') with ui.row(): ui.label("Inverter Log") - inverter_log = ui.log().props('cols=120').classes('w-full h-20') + inverter_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') # with ui.row(): # ui.label("Proxy Log") # proxy_log = ui.log().props('cols=120').classes('w-full h-80') with ui.row(): ui.label("Agent Log") - agent_log = ui.log().props('cols=120').classes('w-full h-80') + agent_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-80') with ui.row(): ui.label("Utility Log") - utility_log = ui.log().props('cols=120').classes('w-full h-20') + utility_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index 5b02fddbe4..627397b050 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -150,9 +150,9 @@ def start(self): TimerThread.tick.connect(self._tick) def _tick(self, timestamp): - if timestamp % 5 == 0: + if timestamp % 20 == 0: for derp in self._der_program_map.items(): - print(self.__get_request__(f"/derp_0_derc")) + print(self.__get_request__(f"/derp_0_derc_0")) #_log.debug(f"Tick: {timestamp}") From 18bc972aeabf0c3e7cc3690b30e450a4f58a26eb Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Mon, 17 Apr 2023 13:49:22 -0700 Subject: [PATCH 19/53] Updated images for agent demo --- services/core/IEEE_2030_5/AGENT_DEMO.md | 16 +++++++++++++++- .../demo/images/control_complete.png | Bin 0 -> 26071 bytes services/core/IEEE_2030_5/keypair.json | 4 ---- 3 files changed, 15 insertions(+), 5 deletions(-) create mode 100644 services/core/IEEE_2030_5/demo/images/control_complete.png delete mode 100644 services/core/IEEE_2030_5/keypair.json diff --git a/services/core/IEEE_2030_5/AGENT_DEMO.md b/services/core/IEEE_2030_5/AGENT_DEMO.md index 05aa9fef89..26499fdcbe 100644 --- a/services/core/IEEE_2030_5/AGENT_DEMO.md +++ b/services/core/IEEE_2030_5/AGENT_DEMO.md @@ -95,4 +95,18 @@ For this demo, start a VOLTTRON default instance from the command line. The fol ## The Demo -Insert pictures here. +The initial demo screen. + +![Startup Page](./demo/images/initial_conditions.png) + +Clicking on the Start Inverter and Start Agent buttons the status of Real and Reactive power should update based upon what is posted to the MirrorUsagePoints. + +![Agent and Inverter Started](./demo/images/start_agent_and_inverter.png) + +Changing the power factor to 80 and clicking on the Change Power Factor button (3) will show the scheduling, activating and completion of the event. + +![Scheduling Events Schedule](./demo/images/control_scheduled.png) + +![Scheduling Events Active](./demo/images/control_active.png) + +![Scheduling Events Complete](./demo/images/control_complete.png) diff --git a/services/core/IEEE_2030_5/demo/images/control_complete.png b/services/core/IEEE_2030_5/demo/images/control_complete.png new file mode 100644 index 0000000000000000000000000000000000000000..c258a255c1ed5984d9f59ee9e365c7e9faee8c28 GIT binary patch literal 26071 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 Date: Tue, 18 Apr 2023 11:23:38 -0700 Subject: [PATCH 20/53] Update openssl.cnf file --- services/core/IEEE_2030_5/demo/openssl.cnf | 62 ++++++++++++++++++++-- 1 file changed, 57 insertions(+), 5 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/openssl.cnf b/services/core/IEEE_2030_5/demo/openssl.cnf index e2bbdbe22e..3febb63be0 100644 --- a/services/core/IEEE_2030_5/demo/openssl.cnf +++ b/services/core/IEEE_2030_5/demo/openssl.cnf @@ -1,18 +1,60 @@ # OpenSSL example configuration file. # This is mostly being used for generation of certificate requests. # + # This definition stops the following lines choking if HOME isn't # defined. HOME = . RANDFILE = $ENV::HOME/.rnd +# Extra OBJECT IDENTIFIER info: +#oid_file = $ENV::HOME/.oid +oid_section = new_oids + +# To use this configuration file with the "-extfile" option of the +# "openssl x509" utility, name here the section containing the +# X.509v3 extensions to use: +# extensions = +# (Alternatively, use a configuration file that has only +# X.509v3 extensions in its main [= default] section.) + +[ new_oids ] + +# We can add new OIDs in here for use by 'ca', 'req' and 'ts'. +# Add a simple OID like this: +# testoid1=1.2.3.4 +# Or use config file substitution like this: +# testoid2=${testoid1}.5.6 + +# Policies used by the TSA examples. +tsa_policy1 = 1.2.3.4.1 +tsa_policy2 = 1.2.3.4.5.6 +tsa_policy3 = 1.2.3.4.5.7 + +#################################################################### [ ca ] -default_ca = CA_default +default_ca = CA_default # The default ca section [ CA_default ] -database = index.txt -serial = serial.txt -policy = policy_default +dir = $ENV::HOME/tls # Where everything is kept +certs = $dir/certs # Where the issued certs are kept +database = $dir/index.txt # database index file. + # several certs with same subject. +new_certs_dir = $dir/certs # default place for new certs. +certificate = $dir/certs/ec-cacert.pem # The CA certificate +serial = $dir/serial # The current serial number +crlnumber = $dir/crlnumber # the current crl number + # must be commented out to leave a V1 CRL +private_key = $dir/private/ec-cakey.pem # The private key + +name_opt = ca_default # Subject Name options +cert_opt = ca_default # Certificate field options + +default_days = 365 # how long to certify for +default_crl_days= 30 # how long before next CRL +default_md = sha256 # use SHA-256 by default +preserve = no # keep passed DN ordering +policy = policy_match # For the CA policy [ policy_match ] @@ -32,6 +74,7 @@ organizationalUnitName = optional commonName = supplied emailAddress = optional +#################################################################### [ req ] default_bits = 2048 default_md = sha256 @@ -57,15 +100,24 @@ commonName_max = 64 emailAddress = Email Address emailAddress_max = 64 +[ req_attributes ] +challengePassword = A challenge password +challengePassword_min = 4 +challengePassword_max = 20 +unstructuredName = An optional company name + + [ v3_req ] # Extensions to add to a certificate request basicConstraints = CA:FALSE keyUsage = nonRepudiation, digitalSignature, keyEncipherment + [ v3_ca ] # Extensions for a typical CA subjectKeyIdentifier=hash authorityKeyIdentifier=keyid:always,issuer basicConstraints = critical,CA:true + [ crl_ext ] # issuerAltName=issuer:copy -authorityKeyIdentifier=keyid:always# +authorityKeyIdentifier=keyid:always \ No newline at end of file From 965075802c37f8bc66b420bf0befd59de6bf6c38 Mon Sep 17 00:00:00 2001 From: Craig <3979063+craig8@users.noreply.github.com> Date: Tue, 18 Apr 2023 11:24:07 -0700 Subject: [PATCH 21/53] Removed old 2030.5 agent --- services/core/IEEE2030_5Agent/IDENTITY | 1 - .../IEEE2030_5Agent/IEEE2030_5/__init__.py | 87 - .../core/IEEE2030_5Agent/IEEE2030_5/agent.py | 564 - .../IEEE2030_5Agent/IEEE2030_5/end_device.py | 441 - .../IEEE2030_5Agent/IEEE2030_5/xsd_models.py | 35078 ---------------- services/core/IEEE2030_5Agent/README.md | 37 - services/core/IEEE2030_5Agent/config | 20 - services/core/IEEE2030_5Agent/conftest.py | 6 - services/core/IEEE2030_5Agent/setup.py | 72 - .../IEEE2030_5drivertest.config | 3 - .../IEEE2030_5DriverTestAgent/__init__.py | 0 .../tests/IEEE2030_5DriverTestAgent/setup.py | 0 .../test_agent/__init__.py | 0 .../test_agent/agent.py | 449 - .../IEEE2030_5Agent/tests/der.dera.PUT.xml | 11 - .../IEEE2030_5Agent/tests/der.dercap.PUT.xml | 32 - .../IEEE2030_5Agent/tests/der.derg.PUT.xml | 17 - .../IEEE2030_5Agent/tests/der.ders.PUT.xml | 19 - .../IEEE2030_5Agent/tests/edev.di.PUT.xml | 14 - .../IEEE2030_5Agent/tests/edev.dstat.PUT.xml | 6 - .../IEEE2030_5Agent/tests/edev.ps.PUT.xml | 27 - .../IEEE2030_5Agent/tests/mup.mmr.PUT.xml | 21 - .../IEEE2030_5Agent/tests/mup.mup.PUT.xml | 85 - .../IEEE2030_5Agent/tests/mup.mup2.PUT.xml | 15 - .../tests/test_IEEE2030_5_agent.py | 291 - .../tests/test_IEEE2030_5_driver.py | 232 - 26 files changed, 37528 deletions(-) delete mode 100644 services/core/IEEE2030_5Agent/IDENTITY delete mode 100644 services/core/IEEE2030_5Agent/IEEE2030_5/__init__.py delete mode 100644 services/core/IEEE2030_5Agent/IEEE2030_5/agent.py delete mode 100644 services/core/IEEE2030_5Agent/IEEE2030_5/end_device.py delete mode 100644 services/core/IEEE2030_5Agent/IEEE2030_5/xsd_models.py delete mode 100644 services/core/IEEE2030_5Agent/README.md delete mode 100644 services/core/IEEE2030_5Agent/config delete mode 100644 services/core/IEEE2030_5Agent/conftest.py delete mode 100644 services/core/IEEE2030_5Agent/setup.py delete mode 100644 services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/IEEE2030_5drivertest.config delete mode 100644 services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/__init__.py delete mode 100644 services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/setup.py delete mode 100644 services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/test_agent/__init__.py delete mode 100644 services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/test_agent/agent.py delete mode 100644 services/core/IEEE2030_5Agent/tests/der.dera.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/der.dercap.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/der.derg.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/der.ders.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/edev.di.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/edev.dstat.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/edev.ps.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/mup.mmr.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/mup.mup.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/mup.mup2.PUT.xml delete mode 100644 services/core/IEEE2030_5Agent/tests/test_IEEE2030_5_agent.py delete mode 100644 services/core/IEEE2030_5Agent/tests/test_IEEE2030_5_driver.py diff --git a/services/core/IEEE2030_5Agent/IDENTITY b/services/core/IEEE2030_5Agent/IDENTITY deleted file mode 100644 index e722eb9048..0000000000 --- a/services/core/IEEE2030_5Agent/IDENTITY +++ /dev/null @@ -1 +0,0 @@ -IEEE2030_5agent diff --git a/services/core/IEEE2030_5Agent/IEEE2030_5/__init__.py b/services/core/IEEE2030_5Agent/IEEE2030_5/__init__.py deleted file mode 100644 index e6ebd475e7..0000000000 --- a/services/core/IEEE2030_5Agent/IEEE2030_5/__init__.py +++ /dev/null @@ -1,87 +0,0 @@ -from collections import namedtuple - -STOR_UNKNOWN = -1 -STOR_DISCONNECTED = 1 -STOR_CONNECTED = 5 - -CONTROL_MODE_LOCAL = 0 -CONTROL_MODE_REMOTE = 1 - -INVERTER_STATUS_UNKNOWN = -1 -INVERTER_NORMAL = 0 -INVERTER_OFF = 1 -INVERTER_STARTING = 3 -INVERTER_FORCED_POWER_REDUCTION = 5 -INVERTER_FAULT = 7 -INVERTER_CELL_BALANCING = 10 - -MRID_SUFFIX_FUNCTION_SET_ASSIGNMENT = 3 -MRID_SUFFIX_DER_PROGRAM = 4 -MRID_SUFFIX_DER_CONTROL = 5 - -EVENT_STATUS_SCHEDULE = 0 -EVENT_STATUS_ACTIVE = 1 -EVENT_STATUS_CANCELLED = 2 -EVENT_STATUS_CANCELLED_RANDOM = 3 -EVENT_STATUS_SUPERCEDED = 4 - -QUALITY_NTP = 3 - -STATUS_CODES = { - 200: '200 OK', - 201: '201 Created', - 204: '204 No Content', - 500: '500 Internal Error', -} -XML_HEADERS = [("Content-Type", "application/sep+xml")] -CREATED_HEADERS = [("Content-Length", "0")] - -Endpoint = namedtuple('Endpoint', ['url', 'callback']) -IEEE2030_5_ENDPOINTS = { - "dcap": Endpoint(url="/dcap", callback='dcap'), - "tm": Endpoint(url="/dcap/tm", callback='tm'), - "sdev": Endpoint(url="/dcap/sdev", callback='sdev'), - "edev-list": Endpoint(url="/dcap/edev", callback='edev_list'), - - "sdev-di": Endpoint(url="/dcap/sdev/di", callback='sdev_di'), - "sdev-log": Endpoint(url="/dcap/sdev/log", callback='sdev_log'), - - "mup-list": Endpoint(url="/dcap/mup", callback='mup_list'), -} -IEEE2030_5_MUP_ENDPOINTS = { - "mup": Endpoint(url="/dcap/mup/{}", callback='mup'), -} -IEEE2030_5_EDEV_ENDPOINTS = { - "edev": Endpoint(url="/dcap/edev/{}", callback='edev'), - "reg": Endpoint(url="/dcap/edev/{}/reg", callback='edev_reg'), - "di": Endpoint(url="/dcap/edev/{}/di", callback='edev_di'), - "dstat": Endpoint(url="/dcap/edev/{}/dstat", callback='edev_dstat'), - "ps": Endpoint(url="/dcap/edev/{}/ps", callback='edev_ps'), - "der-list": Endpoint(url="/dcap/edev/{}/der", callback='edev_der_list'), - - "derp-list": Endpoint(url="/dcap/edev/{}/derp", callback='edev_derp_list'), - "derp": Endpoint(url="/dcap/edev/{}/derp/1", callback='edev_derp'), - - "der": Endpoint(url="/dcap/edev/{}/der/1", callback='edev_der'), - "dera": Endpoint(url="/dcap/edev/{}/der/1/dera", callback='edev_dera'), - "dercap": Endpoint(url="/dcap/edev/{}/der/1/dercap", callback='edev_dercap'), - "derg": Endpoint(url="/dcap/edev/{}/der/1/derg", callback='edev_derg'), - "ders": Endpoint(url="/dcap/edev/{}/der/1/ders", callback='edev_ders'), - - "derc-list": Endpoint(url="/dcap/edev/{}/derc", callback='edev_derc_list'), - "derc": Endpoint(url="/dcap/edev/{}/derc/1", callback='edev_derc'), - - "fsa-list": Endpoint(url="/dcap/edev/{}/fsa", callback='edev_fsa_list'), - "fsa": Endpoint(url="/dcap/edev/{}/fsa/0", callback='edev_fsa'), -} - -RESOURCE_MAPPING = { - "DeviceInformation": "device_information", - "MirrorMeterReading": "mup", - "DERStatus": "der_status", - "DERControl": "der_control", - "DERCapability": "der_capability", - "DERSettings": "der_settings", - "DERAvailability": "der_availability", - "PowerStatus": "power_status", -} diff --git a/services/core/IEEE2030_5Agent/IEEE2030_5/agent.py b/services/core/IEEE2030_5Agent/IEEE2030_5/agent.py deleted file mode 100644 index 332834b2e3..0000000000 --- a/services/core/IEEE2030_5Agent/IEEE2030_5/agent.py +++ /dev/null @@ -1,564 +0,0 @@ -# -*- coding: utf-8 -*- {{{ -# vim: set fenc=utf-8 ft=python sw=4 ts=4 sts=4 et: -# -# Copyright 2020, Battelle Memorial Institute. -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. -# -# This material was prepared as an account of work sponsored by an agency of -# the United States Government. Neither the United States Government nor the -# United States Department of Energy, nor Battelle, nor any of their -# employees, nor any jurisdiction or organization that has cooperated in the -# development of these materials, makes any warranty, express or -# implied, or assumes any legal liability or responsibility for the accuracy, -# completeness, or usefulness or any information, apparatus, product, -# software, or process disclosed, or represents that its use would not infringe -# privately owned rights. Reference herein to any specific commercial product, -# process, or service by trade name, trademark, manufacturer, or otherwise -# does not necessarily constitute or imply its endorsement, recommendation, or -# favoring by the United States Government or any agency thereof, or -# Battelle Memorial Institute. The views and opinions of authors expressed -# herein do not necessarily state or reflect those of the -# United States Government or any agency thereof. -# -# PACIFIC NORTHWEST NATIONAL LABORATORY operated by -# BATTELLE for the UNITED STATES DEPARTMENT OF ENERGY -# under Contract DE-AC05-76RL01830 -# }}} - -from .end_device import EndDevice, MUP, IEEE2030_5Renderer, IEEE2030_5Time -from datetime import datetime, timedelta -from volttron.platform.agent import utils -from volttron.platform.vip.agent import Agent, Core, RPC -import IEEE2030_5 -import base64 -import logging -import pytz -import sys -from . import xsd_models - -utils.setup_logging() -_log = logging.getLogger(__name__) -__version__ = '1.0' - - -class IEEE2030_5Exception(Exception): - pass - - -def IEEE2030_5_agent(config_path, **kwargs): - """Parses the IEEE2030_5 Agent configuration and returns an instance of - the agent created using that configuation. - - :param config_path: Path to a configuation file. - - :type config_path: str - :returns: IEEE 2030.5 Agent - :rtype: IEEE2030_5Agent - """ - try: - config = utils.load_config(config_path) - except Exception: - config = {} - - if not config: - _log.info("Using IEEE 2030.5 Agent defaults for starting configuration.") - - devices = config.get('devices', []) # To add devices, include them in a config file - # This default should be overridden in config file - IEEE2030_5_server_sfdi = config.get('IEEE2030_5_server_sfdi', 'foo') - # This default should be overridden in config file - IEEE2030_5_server_lfdi = config.get('IEEE2030_5_server_lfdi', 'bar') - load_shed_device_category = config.get('load_shed_device_category', '0020') - timezone = config.get('timezone', 'America/Los_Angeles') - - return IEEE2030_5Agent(devices, - IEEE2030_5_server_sfdi, - IEEE2030_5_server_lfdi, - load_shed_device_category, - timezone, - **kwargs) - - -class IEEE2030_5Agent(Agent): - """ - Agent that handles IEEE 2030.5 communication. - - IEEE2030_5Agent uses the VOLTTRON web service to communicate with IEEE 2030.5 end devices. - End device configuration is outlined in the agent config file. - - IEEE 2030.5 data is exposed via get_point(), get_points() and set_point() calls. - A IEEE 2030.5 device driver (IEEE2030_5.py under PlatformDriverAgent) can be configured, - which gets and sets data by sending RPCs to this agent. - - For further information about this subsystem, please see the VOLTTRON - IEEE 2030.5 DER Support specification, which is located in VOLTTRON readthedocs - under specifications/IEEE2030_5_agent.html. - - This agent can be installed as follows: - export IEEE2030_5_ROOT=$VOLTTRON_ROOT/services/core/IEEE2030_5Agent - cd $VOLTTRON_ROOT - python scripts/install-agent.py -s $IEEE2030_5_ROOT -i IEEE2030_5agent -c $IEEE2030_5_ROOT/config - -t IEEE2030_5agent -f - """ - - def __init__(self, device_config=[], IEEE2030_5_server_sfdi='foo', IEEE2030_5_server_lfdi='bar', - load_shed_device_category='0020', timezone='America/Los_Angeles', **kwargs): - super(IEEE2030_5Agent, self).__init__(enable_web=True, **kwargs) - - self.device_config = device_config - self.IEEE2030_5_server_sfdi = IEEE2030_5_server_sfdi - self.IEEE2030_5_server_lfdi = IEEE2030_5_server_lfdi - self.load_shed_device_category = load_shed_device_category - self.timezone = timezone - self.devices = {} - - self.default_config = {"devices": device_config, - "IEEE2030_5_server_sfdi": IEEE2030_5_server_sfdi, - "IEEE2030_5_server_lfdi": IEEE2030_5_server_lfdi, - "load_shed_device_category": load_shed_device_category, - "timezone": timezone} - self.vip.config.set_default("config", self.default_config) - self.devices = self.register_devices(device_config) - self.mups = [] - - self.vip.config.subscribe(self.configure, actions=["NEW", "UPDATE"], pattern="config") - - def configure(self, configure, actions, contents): - config = self.default_config.copy() - config.update(contents) - _log.debug("Configuring IEEE 2030.5 Agent") - - self.device_config = config["devices"] - self.IEEE2030_5_server_sfdi = config["IEEE2030_5_server_sfdi"] - self.IEEE2030_5_server_lfdi = config["IEEE2030_5_server_lfdi"] - self.load_shed_device_category = config["load_shed_device_category"] - self.timezone = config["timezone"] - self.devices = self.register_devices(self.device_config) - self.register_endpoints(self) - - @Core.receiver('onstart') - def register_endpoints(self, sender): - """ Register HTTP endpoints. - - Registers all IEEE 2030.5 related endpoints. Endpoints are defined in the end_device.py file. - """ - # _log.debug("Deregistering Endpoints: {}".format(self.__class__.__name__)) - for endpoint in self.vip.web._endpoints: - try: - split_path = endpoint.split('/') - if split_path[2] == 'edev' and int(split_path[3]): - if int(split_path[3]) not in self.devices.keys(): - pass - # If code is ever introduced to unregister an endpoint, do so here! - # self.vip.web.unregister_endpoint(endpoint) - except (IndexError, ValueError): - pass - - _log.debug("Registering Endpoints: {}".format(self.__class__.__name__)) - for _, endpoint in IEEE2030_5.IEEE2030_5_ENDPOINTS.items(): - if endpoint.url not in self.vip.web._endpoints: - self.vip.web.register_endpoint(endpoint.url, getattr(self, endpoint.callback), "raw") - for device_id, device in self.devices.items(): - for _, endpoint in IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS.items(): - if endpoint.url.format(device_id) not in self.vip.web._endpoints: - self.vip.web.register_endpoint(endpoint.url.format(device_id), - getattr(self, endpoint.callback), "raw") - - def register_devices(self, devices): - """ Register IEEE 2030.5 end devices. - - :param devices: End devices from agent config file. - :type devices: List - - :return: Dictionary of EndDevice objects keyed by ID. - """ - _log.debug("Loading Devices: {}".format(self.__class__.__name__)) - end_devices = self.devices - for device in devices: - if device['sfdi'] not in [k.sfdi for k in end_devices.values()]: - d = EndDevice(sfdi=device["sfdi"], - lfdi=device["lfdi"], - load_shed_device_category=device["load_shed_device_category"], - pin_code=device["pin_code"]) - end_devices[d.id] = d - else: - d = self.get_end_device(sfdi=device['sfdi']) - d.lfdi = device['lfdi'] - d.load_shed_device_category = device['load_shed_device_category'] - d.pin_code = device['pin_code'] - - old_indices = [] - for index, d in end_devices.items(): - if d.sfdi not in [device['sfdi'] for device in devices]: - old_indices.append(index) - for i in old_indices: - end_devices.pop(i) - return end_devices - - def get_end_device(self, path=None, sfdi=None, lfdi=None): - """ Helper function to return end device object. - - Only one of path or sfdi should be used for End Device lookup - - :param path: Path Info of HTTP endpoint request - :param sfdi: SFDI of end device - :param lfdi: LFDI of end device - :return: EndDevice object - """ - if path: - end_device_id = path.split('/')[3] - try: - device = self.devices[int(end_device_id)] - return device - except KeyError: - raise IEEE2030_5Exception("Invalid end device requested") - else: - end_device = None - for device in self.devices.values(): - if device.sfdi == sfdi or device.lfdi == lfdi: - end_device = device - if end_device is None: - raise IEEE2030_5Exception("Invalid end device requested") - return end_device - - def process_edev(self, env, data, xsd_type, attr_name): - """ Process HTTP requests and prepare response - - :param env: Request Environment variables - :param data: Request data - :param xsd_type: XSD object type request represents - :param attr_name: Attribute of EndDevice object that corresponds to the XSD Object - :return: Tuple of (Status Code, Response Data, Headers) - """ - device = self.get_end_device(env['PATH_INFO']) - if env['REQUEST_METHOD'] in ('POST', 'PUT'): - obj = xsd_models.parseString(data, silence=True) - if type(obj) == xsd_type: - setattr(device, attr_name, obj) - return [IEEE2030_5.STATUS_CODES[204], '', IEEE2030_5.CREATED_HEADERS] - else: - _log.warning("Bad XML input for HTTP Endpoint.") - return [IEEE2030_5.STATUS_CODES[500], '', IEEE2030_5.XML_HEADERS] - else: - return IEEE2030_5Agent.prep_200_response({'received_data': data, 'result': getattr(device, attr_name)}) - - @staticmethod - def add_meter_readings(mup, meter_readings): - """ Update/Create Meter Readings for MUP based on existance. - - If Meter Reading already exists, send an update. If it does not, create new Meter Reading for MUP. - - :param mup: MUP object - :param meter_readings: List of incoming Meter Readings to insert into MUP object. - :return: None - """ - for meter_reading in meter_readings: - flag = True - for index, xsd in enumerate(mup.mup_xsd.get_MirrorMeterReading()): - if meter_reading.description == mup.mup_xsd.get_MirrorMeterReading()[index].description: - mup.mup_xsd.replace_MirrorMeterReading_at(index, meter_reading) - flag = False - if flag: - mup.mup_xsd.add_MirrorMeterReading(meter_reading) - - @staticmethod - def prep_200_response(render_dict): - """Helper function to prep standard 200 responses with XML formatted data - - :param render_dict: dictionary to render into XML serializable string - - :return: Tuple of (Status Code, Response Data, Headers) - """ - return (IEEE2030_5.STATUS_CODES[200], - base64.b64encode(IEEE2030_5Renderer.render(render_dict)).decode('ascii'), - IEEE2030_5.XML_HEADERS) - - @RPC.export - def get_point(self, sfdi, point_name): - _log.debug("EndDevice {0}: Getting value for {1}".format(sfdi, point_name)) - end_device = self.get_end_device(sfdi=sfdi) - try: - point_definition = end_device.mappings[point_name] - return end_device.field_value(point_definition['IEEE 2030.5 Resource Name'], - point_definition['IEEE 2030.5 Field Name']) - except KeyError: - raise IEEE2030_5Exception("{0} not a configured point name.".format(point_name)) - - @RPC.export - def get_points(self, sfdi): - _log.debug("EndDevice {0}: Getting all configured point values".format(sfdi)) - end_device = self.get_end_device(sfdi=sfdi) - try: - end_device_points = {} - for volttron_point_name, point_definition in end_device.mappings.items(): - field_value = end_device.field_value(point_definition['IEEE 2030.5 Resource Name'], - point_definition['IEEE 2030.5 Field Name']) - end_device_points[volttron_point_name] = field_value - return end_device_points - except Exception as e: - raise IEEE2030_5Exception(e) - - @RPC.export - def set_point(self, sfdi, point_name, value): - _log.debug("EndDevice {0}: Setting {1} to {2}".format(sfdi, point_name, value)) - end_device = self.get_end_device(sfdi=sfdi) - try: - setattr(end_device, point_name, value) - except Exception as e: - raise IEEE2030_5Exception(e) - - @RPC.export - def config_points(self, sfdi, point_map): - _log.debug("EndDevice {0}: Configuring points: {1}".format(sfdi, point_map)) - end_device = self.get_end_device(sfdi=sfdi) - end_device.mappings = point_map - - ########################################################################## - # The following methods are callback functions for IEEE 2030.5 Endpoints # - ########################################################################## - - def dcap(self, env, data): - dcap = xsd_models.DeviceCapability( - EndDeviceListLink=xsd_models.EndDeviceListLink(), - MirrorUsagePointListLink=xsd_models.MirrorUsagePointListLink(), - SelfDeviceLink=xsd_models.SelfDeviceLink() - ) - dcap.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["dcap"].url) - - dcap.EndDeviceListLink.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["edev-list"].url) - dcap.SelfDeviceLink.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["sdev"].url) - - dcap.TimeLink = xsd_models.TimeLink() - dcap.TimeLink.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["tm"].url) - - dcap.MirrorUsagePointListLink.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["mup-list"].url) - - return IEEE2030_5Agent.prep_200_response({"result": dcap}) - - def sdev(self, env, data): - sdev = xsd_models.SelfDevice() - sdev.sFDI = xsd_models.SFDIType(valueOf_=int(self.IEEE2030_5_server_sfdi)) - sdev.loadShedDeviceCategory = xsd_models.DeviceCategoryType(valueOf_=self.load_shed_device_category) - sdev.DeviceInformationLink = xsd_models.DeviceInformationLink() - sdev.DeviceInformationLink.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["sdev-di"].url) - sdev.LogEventListLink = xsd_models.LogEventListLink() - sdev.LogEventListLink.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["sdev-log"].url) - sdev.LogEventListLink.set_all(1) - return IEEE2030_5Agent.prep_200_response({"result": sdev}) - - def sdev_di(self, env, data): - sep_device_information = xsd_models.DeviceInformation(lFDI=self.IEEE2030_5_server_lfdi) - return IEEE2030_5Agent.prep_200_response({"result": sep_device_information}) - - def sdev_log(self, env, data): - sep_log_event_list = xsd_models.LogEventList() - return IEEE2030_5Agent.prep_200_response({"result": sep_log_event_list}) - - def tm(self, env, data): - now_utc = datetime.utcnow().replace(tzinfo=pytz.utc) - local_tz = pytz.timezone(self.timezone) - now_local = datetime.now().replace(tzinfo=local_tz) - - start_dst_utc, end_dst_utc = [dt for dt in local_tz._utc_transition_times if dt.year == now_local.year] - - utc_offset = local_tz.utcoffset(start_dst_utc - timedelta(days=1)) - dst_offset = local_tz.utcoffset(start_dst_utc + timedelta(days=1)) - utc_offset - local_but_utc = datetime.now().replace(tzinfo=pytz.utc) - - tm = xsd_models.Time( - currentTime=IEEE2030_5Time(now_utc), - dstEndTime=IEEE2030_5Time(end_dst_utc.replace(tzinfo=pytz.utc)), - dstOffset=xsd_models.TimeOffsetType(valueOf_=int(dst_offset.total_seconds())), - dstStartTime=IEEE2030_5Time(start_dst_utc.replace(tzinfo=pytz.utc)), - localTime=IEEE2030_5Time(local_but_utc), - quality=IEEE2030_5.QUALITY_NTP, - tzOffset=xsd_models.TimeOffsetType(valueOf_=int(utc_offset.total_seconds())) - ) - tm.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["tm"].url) - return IEEE2030_5Agent.prep_200_response({"result": tm}) - - def edev_list(self, env, data): - device_list = xsd_models.EndDeviceList() - start, limit = parse_list_query(env['QUERY_STRING'].encode('ascii', 'ignore'), len(self.devices)) - - for i in range(start, limit): - device_list.add_EndDevice(self.devices[i].end_device) - - device_list.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["edev-list"].url) - device_list.set_results(max(0, len(range(start, limit)))) - device_list.set_all(len(self.devices)) - - return IEEE2030_5Agent.prep_200_response({'received_data': data, 'result': device_list}) - - def edev(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.EndDevice, attr_name="end_device") - - def edev_di(self, env, data): - return self.process_edev(env=env, data=data, - xsd_type=xsd_models.DeviceInformation, attr_name="device_information") - - def edev_dstat(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.DeviceStatus, attr_name="device_status") - - def edev_fsa_list(self, env, data): - device = self.get_end_device(env['PATH_INFO']) - fsa_list = xsd_models.FunctionSetAssignmentsList() - fsa_list.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS["fsa-list"].url.format(device.id)) - fsa_list.add_FunctionSetAssignments(device.function_set_assignments) - fsa_list.set_all(1) - fsa_list.set_results(1) - return IEEE2030_5Agent.prep_200_response({"result": fsa_list}) - - def edev_fsa(self, env, data): - return self.process_edev(env=env, data=data, - xsd_type=xsd_models.FunctionSetAssignments, attr_name="function_set_assignments") - - def edev_ps(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.PowerStatus, attr_name="power_status") - - def edev_reg(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.Registration, attr_name="registration") - - def edev_der_list(self, env, data): - device = self.get_end_device(env['PATH_INFO']) - der_list = xsd_models.DERList() - der_list.set_all(1) - der_list.set_results(1) - der_list.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS["der-list"].url.format(device.id)) - der_list.add_DER(device.der) - return IEEE2030_5Agent.prep_200_response({"result": der_list}) - - def edev_der(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.DER, attr_name="der") - - def edev_dera(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.DERAvailability, attr_name="der_availability") - - def edev_derc_list(self, env, data): - device = self.get_end_device(env['PATH_INFO']) - derc_list = xsd_models.DERControlList() - derc_list.set_all(1) - derc_list.set_results(1) - derc_list.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS["derc-list"].url.format(device.id)) - derc_list.add_DERControl(device.der_control_xsd_object()) - return IEEE2030_5Agent.prep_200_response({"result": derc_list}) - - def edev_derc(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.DERControl, attr_name="der_control") - - def edev_dercap(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.DERCapability, attr_name="der_capability") - - def edev_derg(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.DERSettings, attr_name="der_settings") - - def edev_derp_list(self, env, data): - device = self.get_end_device(env['PATH_INFO']) - derp_list = xsd_models.DERProgramList() - derp_list.set_all(1) - derp_list.set_results(1) - derp_list.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS["derp-list"].url.format(device.id)) - derp_list.add_DERProgram(device.der_program) - return IEEE2030_5Agent.prep_200_response({"result": derp_list}) - - def edev_derp(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.DERProgram, attr_name="der_program") - - def edev_ders(self, env, data): - return self.process_edev(env=env, data=data, xsd_type=xsd_models.DERStatus, attr_name="der_status") - - def mup_list(self, env, data): - if env['REQUEST_METHOD'] in ('POST', 'PUT'): - endpoint = IEEE2030_5.IEEE2030_5_MUP_ENDPOINTS["mup"] - mup = xsd_models.parseString(data, silence=True) - device = self.get_end_device(lfdi=mup.get_deviceLFDI()) - if device.mup is None: - m = MUP(mup) - m.mup_xsd.set_href(endpoint.url.format(m.id)) - device.mup = m - self.mups.append(m) - if endpoint.url.format(m.id) not in self.vip.web._endpoints: - self.vip.web.register_endpoint(endpoint.url.format(m.id), getattr(self, endpoint.callback), "raw") - else: - IEEE2030_5Agent.add_meter_readings(device.mup, mup.get_MirrorMeterReading()) - - return [IEEE2030_5.STATUS_CODES[201], - '', - IEEE2030_5.XML_HEADERS+[("Location", endpoint.url.format(device.mup.id))]] - - else: - mup_list = xsd_models.MirrorUsagePointList() - - start, limit = parse_list_query(env['QUERY_STRING'].encode('ascii', 'ignore'), len(self.mups)) - - for i in range(start, limit): - mup_list.add_MirrorUsagePoint(self.mups[i].mup_xsd) - - mup_list.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["mup-list"].url) - mup_list.set_results(max(0, len(range(start, limit)))) - mup_list.set_all(len(self.mups)) - - return IEEE2030_5Agent.prep_200_response({"result": mup_list}) - - def mup(self, env, data): - mup_id = env['PATH_INFO'].split('/')[3] - mup = self.mups[int(mup_id)] - if env['REQUEST_METHOD'] in ('POST', 'PUT'): - device = self.get_end_device(lfdi=mup.mup_xsd.get_deviceLFDI()) - obj = xsd_models.parseString(data, silence=True) - if type(obj) == xsd_models.MirrorUsagePoint: - readings = obj.get_MirrorMeterReading() - elif type(obj) == xsd_models.MirrorMeterReading: - readings = [obj] - else: - _log.warning("Bad XML input for HTTP Endpoint.") - return [IEEE2030_5.STATUS_CODES[500], '', IEEE2030_5.XML_HEADERS] - IEEE2030_5Agent.add_meter_readings(device.mup, readings) - - return [IEEE2030_5.STATUS_CODES[201], - '', - IEEE2030_5.XML_HEADERS + [ - ("Location", IEEE2030_5.IEEE2030_5_MUP_ENDPOINTS["mup"].url.format(mup.id))]] - else: - xsd_object = getattr(mup, 'mup_xsd') - return IEEE2030_5Agent.prep_200_response({'received_data': data, 'result': xsd_object}) - - -def parse_list_query(query, length): - """Parses the IEEE 2030.5 query string parameters associated with list resources. - - There is some defensive code here to avoid errors on negative numbers. - - :param query: The request QUERY PARAMS dictionary - :param length: Length of the list - :return: (start index 0 based, limit) - xrange style - """ - params = {a[0]: a[1] for a in [x.split('=') for x in query.split("&")]} if len(query) > 0 else {} - start = max(0, int(params.get('s', '0'))) - limit = max(0, min(length, start + int(params.get('l', '255')))) - return start, limit - - -def main(): - """Main method called to start the agent.""" - utils.vip_main(IEEE2030_5_agent, identity='IEEE2030_5agent', - version=__version__) - - -if __name__ == '__main__': - # Entry point for script - try: - sys.exit(main()) - except KeyboardInterrupt: - pass diff --git a/services/core/IEEE2030_5Agent/IEEE2030_5/end_device.py b/services/core/IEEE2030_5Agent/IEEE2030_5/end_device.py deleted file mode 100644 index 5bd6f3ae49..0000000000 --- a/services/core/IEEE2030_5Agent/IEEE2030_5/end_device.py +++ /dev/null @@ -1,441 +0,0 @@ -# }}} - -from datetime import datetime, timedelta -import IEEE2030_5 -import calendar -import logging -import pytz -import io -import time -from . import xsd_models -from volttron.platform.agent import utils - -utils.setup_logging() -_log = logging.getLogger(__name__) - - -class EndDevice: - """ Object representing an End Device in IEEE 2030.5 - - End Devices talk with the IEEE 2030.5 Agent over HTTP using XML formatting. This End Device representation stores - configuration information about the End Device and exports that information as XSD Objects when various - endpoint urls are queried. - """ - enddevice_id = 0 - - def __init__(self, sfdi, lfdi, load_shed_device_category, pin_code): - """Representation of End Device object. - - :param sfdi: Short Form Device Identifier - :param lfdi: Long Form Device Identifier - :param load_shed_device_category: Load Shed Device Category - :param pin_code: Pin Code - """ - - # Basic Device Configurations - self.sfdi = sfdi - self.lfdi = lfdi - self.loadShedDeviceCategory = load_shed_device_category - self.pinCode = pin_code - self.registeredOn = datetime.utcnow().replace(tzinfo=pytz.utc) - - # Global Device ID. Updates as End Devices are registered. - self.id = EndDevice.enddevice_id - EndDevice.enddevice_id += 1 - - self.mappings = {} - - # IEEE 2030.5 Resource Initialization - self._end_device = xsd_models.EndDevice( - FunctionSetAssignmentsListLink=xsd_models.FunctionSetAssignmentsListLink(), - RegistrationLink=xsd_models.RegistrationLink(), - ) - self._end_device.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['edev'].url.format(self.id)) - self._end_device.sFDI = xsd_models.SFDIType(valueOf_=self.sfdi) - self._end_device.loadShedDeviceCategory = xsd_models.DeviceCategoryType(valueOf_=self.loadShedDeviceCategory) - self._end_device.FunctionSetAssignmentsListLink.\ - set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['fsa-list'].url.format(self.id)) - self._end_device.FunctionSetAssignmentsListLink.set_all(1) - self._end_device.RegistrationLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['reg'].url.format(self.id)) - self._end_device.DeviceInformationLink = xsd_models.DeviceInformationLink() - self._end_device.DeviceInformationLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['di'].url.format(self.id)) - self._end_device.DeviceStatusLink = xsd_models.DeviceStatus() - self._end_device.DeviceStatusLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['dstat'].url.format(self.id)) - self._end_device.PowerStatusLink = xsd_models.PowerStatusLink() - self._end_device.PowerStatusLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['ps'].url.format(self.id)) - self._end_device.DERListLink = xsd_models.DERListLink() - self._end_device.DERListLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['der-list'].url.format(self.id)) - self._end_device.DERListLink.set_all(1) - - self._device_information = xsd_models.DeviceInformation() - self._device_status = xsd_models.DeviceStatus() - self._power_status = xsd_models.PowerStatus() - - self._function_set_assignments = xsd_models.FunctionSetAssignments( - subscribable='0', - mRID=xsd_models.mRIDType(valueOf_=mrid_helper(self.id, IEEE2030_5.MRID_SUFFIX_FUNCTION_SET_ASSIGNMENT)), - description="FSA", - ) - self._function_set_assignments.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS["fsa"].url.format(self.id)) - self._function_set_assignments.DERProgramListLink = xsd_models.DERProgramListLink() - self._function_set_assignments.DERProgramListLink.\ - set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS["derp-list"].url.format(self.id)) - self._function_set_assignments.DERProgramListLink.set_all(1) - self._function_set_assignments.TimeLink = xsd_models.TimeLink() - self._function_set_assignments.TimeLink.set_href(IEEE2030_5.IEEE2030_5_ENDPOINTS["tm"].url) - - self._registration = xsd_models.Registration( - dateTimeRegistered=IEEE2030_5Time(self.registeredOn), - pIN=xsd_models.PINType(valueOf_=int(self.pinCode))) - self._registration.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['reg'].url.format(self.id)) - - self._der = xsd_models.DER( - AssociatedDERProgramListLink=xsd_models.AssociatedDERProgramListLink(), - CurrentDERProgramLink=xsd_models.CurrentDERProgramLink(), - DERAvailabilityLink=xsd_models.DERAvailabilityLink(), - DERCapabilityLink=xsd_models.DERCapabilityLink(), - DERSettingsLink=xsd_models.DERSettingsLink(), - DERStatusLink=xsd_models.DERStatusLink() - ) - self._der.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['der'].url.format(self.id)) - self._der.AssociatedDERProgramListLink.set_href( - IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['derp-list'].url.format(self.id)) - self._der.AssociatedDERProgramListLink.set_all(1) - self._der.CurrentDERProgramLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['derp'].url.format(self.id)) - self._der.DERAvailabilityLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['dera'].url.format(self.id)) - self._der.DERCapabilityLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['dercap'].url.format(self.id)) - self._der.DERSettingsLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['derg'].url.format(self.id)) - self._der.DERStatusLink.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['ders'].url.format(self.id)) - - self._der_program = xsd_models.DERProgram( - DERControlListLink=xsd_models.DERControlListLink(), - primacy=xsd_models.PrimacyType(valueOf_=1) - ) - self._der_program.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['derp'].url.format(self.id)) - self._der_program.set_mRID( - xsd_models.mRIDType(valueOf_=mrid_helper(self.id, IEEE2030_5.MRID_SUFFIX_DER_PROGRAM))) - self._der_program.set_version(xsd_models.VersionType(valueOf_='0')) - self._der_program.set_description("DER Program") - self._der_program.DERControlListLink.set_href( - IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['derc-list'].url.format(self.id)) - self._der_program.DERControlListLink.set_all(1) - - self._der_settings = xsd_models.DERSettings() - self._der_capability = xsd_models.DERCapability() - self._der_status = xsd_models.DERStatus() - self._der_availability = xsd_models.DERAvailability() - - self._der_control = xsd_models.DERControl(DERControlBase=xsd_models.DERControlBase()) - self._der_control.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['derc'].url.format(self.id)) - self._der_control.set_description("DER Control") - - self._mup = None - - def meter_reading_helper(self, attr_name): - """ Helper method for attributes that use meter readings - - :param attr_name: Name of SunSpec attribute - :return: Value of IEEE 2030.5 Meter Reading correlated with SunSpec attribute - """ - if self.mup is not None: - for reading in self.mup.mup_xsd.get_MirrorMeterReading(): - if reading.get_description() == attr_name: - power_of_ten = reading.get_ReadingType() - value = reading.get_Reading().get_value() - return float(value) * pow(10, int(power_of_ten.get_powerOfTenMultiplier().get_valueOf_())) \ - if power_of_ten is not None else float(value) - return None - - ##################################################################### - # Currently WChaMax is the only SunSpec register we support # - # writing to. Because of the way IEEE 2030.5 is set up, we can read # - # any register by giving it a proper IEEE 2030.5 resource and field # - # but writing to registers will require special agent config # - ##################################################################### - - def b124_WChaMax(self, value): - now = datetime.utcnow().replace(tzinfo=pytz.utc) - mrid = mrid_helper(self.id, int(time.mktime(now.timetuple()))) - self.der_control.get_DERControlBase().set_opModFixedFlow(xsd_models.SignedPerCent(valueOf_=value)) - self.der_control.set_mRID(xsd_models.mRIDType(valueOf_=mrid)) - self.der_control.set_creationTime(IEEE2030_5Time(now)) - self.der_control.set_EventStatus(xsd_models.EventStatus( - currentStatus=IEEE2030_5.EVENT_STATUS_ACTIVE, - dateTime=IEEE2030_5Time(now), - potentiallySuperseded=True, - potentiallySupersededTime=IEEE2030_5Time(now), - reason="Dispatch" - )) - self.der_control.set_interval(xsd_models.DateTimeInterval(duration=3600 * 24, start=IEEE2030_5Time(now))) - - def field_value(self, resource, field): - """ Given a IEEE 2030.5 field name, return the value of that field. - :param resource: IEEE 2030.5 resource name - :param field: IEEE 2030.5 field name (may be dotted notation if a nested field) - :return: field value - """ - - # Special Corner cases that exist outside of official IEEE 2030.5 fields - if field == 'sFDI': - return self.sfdi - elif field == 'SOC': - _log.debug('Calculating DERAvailability.soc...') - if self.field_value("DERAvailability", "availabilityDuration") is not None and \ - self.field_value("DERSettings", "setMaxChargeRate") is not None: - duration = self.field_value("DERAvailability", "availabilityDuration") / 3600.0 - max_charge = self.field_value("DERSettings", "setMaxChargeRate") - soc = duration * max_charge - else: - soc = None - return soc - - # Translate from IEEE 2030.5 resource (DeviceInformation) to EndDevice attribute (device_information) - converted_resource = IEEE2030_5.RESOURCE_MAPPING[resource] - if hasattr(self, converted_resource): - IEEE2030_5_resource = getattr(self, converted_resource) - else: - raise AttributeError("{} is not a valid IEEE 2030.5 Resource".format(resource)) - - # MUPs have special case handling - if converted_resource == "mup": - return self.meter_reading_helper(field) - - IEEE2030_5_field = self.get_field(IEEE2030_5_resource, field) - if hasattr(IEEE2030_5_field, 'value'): - field_value = IEEE2030_5_field.value - if hasattr(IEEE2030_5_field, 'multiplier') and type(IEEE2030_5_field.multiplier) == \ - xsd_models.PowerOfTenMultiplierType: - field_value = float(field_value) * pow(10, int(IEEE2030_5_field.multiplier.get_valueOf_())) - elif type(field_value) == xsd_models.PerCent: - field_value = int(field_value.get_valueOf_()) / 100.0 - else: - # Depending on field choice, this could be a nested xsd model, not JSON serializable. - pass - else: - field_value = IEEE2030_5_field - - return field_value - - @staticmethod - def get_field(resource, field): - """ Recursive helper method to retrieve field from IEEE 2030.5 resource - - If IEEE 2030.5 fields have not been defined, this method will return None - - :param resource: IEEE 2030.5 resource (xsd_models object) - :param field: IEEE 2030.5 field name - :return: value of field - """ - fields = field.split('.', 1) - if len(fields) == 1: - IEEE2030_5_field = getattr(resource, field, None) - else: - meta_field = getattr(resource, fields[0], None) - IEEE2030_5_field = EndDevice.get_field(meta_field, fields[1]) if meta_field else None - return IEEE2030_5_field - - ############################################################ - # XSD Object representation methods. # - # These objects represent various IEEE2030_5 Resources. # - # These Resource objects mirror HTTP request GET and POSTS # - ############################################################ - - @property - def end_device(self): - return self._end_device - - @property - def device_information(self): - return self._device_information - - @device_information.setter - def device_information(self, value): - self._device_information = value - self._device_information.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['di'].url.format(self.id)) - - @property - def device_status(self): - return self._device_status - - @device_status.setter - def device_status(self, value): - self._device_status = value - self._device_status.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['dstat'].url.format(self.id)) - - @property - def function_set_assignments(self): - return self._function_set_assignments - - @property - def power_status(self): - return self._power_status - - @power_status.setter - def power_status(self, value): - self._power_status = value - self._power_status.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['ps'].url.format(self.id)) - - @property - def registration(self): - return self._registration - - @property - def der(self): - return self._der - - @property - def der_program(self): - return self._der_program - - @property - def der_control(self): - return self._der_control - - @property - def der_availability(self): - return self._der_availability - - @der_availability.setter - def der_availability(self, value): - self._der_availability = value - self._der_availability.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['dera'].url.format(self.id)) - - @property - def der_capability(self): - return self._der_capability - - @der_capability.setter - def der_capability(self, value): - self._der_capability = value - self._der_capability.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['dercap'].url.format(self.id)) - - @property - def der_status(self): - return self._der_status - - @der_status.setter - def der_status(self, value): - self._der_status = value - self._der_status.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['ders'].url.format(self.id)) - - @property - def der_settings(self): - return self._der_settings - - @der_settings.setter - def der_settings(self, value): - self._der_settings = value - self._der_settings.set_href(IEEE2030_5.IEEE2030_5_EDEV_ENDPOINTS['derg'].url.format(self.id)) - - @property - def mup(self): - return self._mup - - @mup.setter - def mup(self, value): - self._mup = value - - -class MUP: - """ Object representing an MUP in IEEE2030_5 """ - mup_id = 0 - - def __init__(self, xsd): - self.id = MUP.mup_id - MUP.mup_id += 1 - self.mup_xsd = xsd - - -class IEEE2030_5Renderer: - """ Takes IEEE 2030.5 Type objects and renders them as XML formatted data for HTTP response. """ - - media_type = 'application/sep+xml' - - @staticmethod - def export(xsd_object, make_pretty=True): - """Export IEEE 2030.5 object into serializable XML - - :param xsd_object: IEEE 2030.5 object to export - :param make_pretty: Boolean value determining whether or not to use newline characters between XML elements. - - :return: String of XML serialized data. - """ - buff = io.StringIO() - xsd_object.export( - buff, - 1, - namespacedef_='xmlns="http://zigbee.org/sep" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"', - pretty_print=make_pretty - ) - return buff.getvalue() - - @staticmethod - def render(data): - """ Wrapper function around the export method. - - :param data: XSD object to render. Empty string if data does not come in correctly. - :return: Formatted XML string. - """ - if data is None: - return '' - - if 'rendered_result' not in data: - if 'result' not in data: - data['rendered_result'] = '' - else: - make_pretty = True - data['rendered_result'] = IEEE2030_5Renderer.export(data['result'], make_pretty) - - return data['rendered_result'] - - -class IEEE2030_5Parser: - """ Takes XML formatted string and renders it as an XSD object. """ - media_type = 'application/sep+xml' - - @staticmethod - def parse(stream): - """ Parses the incoming bytestream as XML and returns the resulting data. """ - return xsd_models.parseString(stream, silence=True) - - -def mrid_helper(edev_pk, resource_suffix): - """ Helper method to create universally unique ID for any resource object - - :param edev_pk: Primary Key of End Device object - :param resource_suffix: Suffix to add to hash to create unique ID - :return: UUID (MRID) value. (In hex-decimal) - """ - hex_string = hex(int(edev_pk)*10000000000000+resource_suffix*100)[2:].upper() - if hex_string.endswith('L'): - hex_string = hex_string[:-1] - if (len(hex_string)) % 2 == 1: - hex_string = "0{0}".format(hex_string) - return hex_string - - -def IEEE2030_5Time(dt_obj, local=False): - """ Return a proper IEEE2030_5 TimeType object for the dt_obj passed in. - - From IEEE 2030.5 spec: - TimeType Object (Int64) - Time is a signed 64 bit value representing the number of seconds - since 0 hours, 0 minutes, 0 seconds, on the 1st of January, 1970, - in UTC, not counting leap seconds. - - :param dt_obj: Datetime object to convert to IEEE2030_5 TimeType object. - :param local: dt_obj is in UTC or Local time. Default to UTC time. - :return: Time XSD object - :raises: If utc_dt_obj is not UTC - """ - - if dt_obj.tzinfo is None: - raise Exception("IEEE 2030.5 times should be timezone aware UTC or local") - - if dt_obj.utcoffset() != timedelta(0) and not local: - raise Exception("IEEE 2030.5 TimeType should be based on UTC") - - if local: - return xsd_models.TimeType(valueOf_=int(time.mktime(dt_obj.timetuple()))) - else: - return xsd_models.TimeType(valueOf_=int(calendar.timegm(dt_obj.timetuple()))) diff --git a/services/core/IEEE2030_5Agent/IEEE2030_5/xsd_models.py b/services/core/IEEE2030_5Agent/IEEE2030_5/xsd_models.py deleted file mode 100644 index 8d76e5a883..0000000000 --- a/services/core/IEEE2030_5Agent/IEEE2030_5/xsd_models.py +++ /dev/null @@ -1,35078 +0,0 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - -# -# Generated Sat Oct 11 16:09:18 2014 by generateDS.py version 2.13a. -# -# Command line options: -# ('-o', 'xsd_models.py') -# -# Command line arguments: -# sep.xsd -# -# Command line: -# generateDS.py -o "xsd_models.py" sep.xsd -# -# Current working directory (os.getcwd()): -# sep2 -# - -import sys -import getopt -import re as re_ -import base64 -import datetime as datetime_ - -etree_ = None -Verbose_import_ = False -( - XMLParser_import_none, XMLParser_import_lxml, - XMLParser_import_elementtree -) = list(range(3)) -XMLParser_import_library = None -try: - # lxml - from lxml import etree as etree_ - XMLParser_import_library = XMLParser_import_lxml - if Verbose_import_: - print("running with lxml.etree") -except ImportError: - try: - # cElementTree from Python 2.5+ - import xml.etree.cElementTree as etree_ - XMLParser_import_library = XMLParser_import_elementtree - if Verbose_import_: - print("running with cElementTree on Python 2.5+") - except ImportError: - try: - # ElementTree from Python 2.5+ - import xml.etree.ElementTree as etree_ - XMLParser_import_library = XMLParser_import_elementtree - if Verbose_import_: - print("running with ElementTree on Python 2.5+") - except ImportError: - try: - # normal cElementTree install - import cElementTree as etree_ - XMLParser_import_library = XMLParser_import_elementtree - if Verbose_import_: - print("running with cElementTree") - except ImportError: - try: - # normal ElementTree install - import elementtree.ElementTree as etree_ - XMLParser_import_library = XMLParser_import_elementtree - if Verbose_import_: - print("running with ElementTree") - except ImportError: - raise ImportError( - "Failed to import ElementTree from any known place") - - -def parsexml_(*args, **kwargs): - if (XMLParser_import_library == XMLParser_import_lxml and - 'parser' not in kwargs): - # Use the lxml ElementTree compatible parser so that, e.g., - # we ignore comments. - kwargs['parser'] = etree_.ETCompatXMLParser() - doc = etree_.parse(*args, **kwargs) - return doc - -# -# User methods -# -# Calls to the methods in these classes are generated by generateDS.py. -# You can replace these methods by re-implementing the following class -# in a module named generatedssuper.py. - -try: - from generatedssuper import GeneratedsSuper -except ImportError as exp: - - class GeneratedsSuper: - tzoff_pattern = re_.compile(r'(\+|-)((0\d|1[0-3]):[0-5]\d|14:00)$') - class _FixedOffsetTZ(datetime_.tzinfo): - def __init__(self, offset, name): #pylint: disable=super-init-not-called - self.__offset = datetime_.timedelta(minutes=offset) - self.__name = name - def utcoffset(self, dt): - return self.__offset - def tzname(self, dt): - return self.__name - def dst(self, dt): - return None - def gds_format_string(self, input_data, input_name=''): - return input_data - def gds_validate_string(self, input_data, node, input_name=''): - if not input_data: - return '' - else: - return input_data - def gds_format_base64(self, input_data, input_name=''): - return base64.b64encode(input_data) - def gds_validate_base64(self, input_data, node, input_name=''): - return input_data - def gds_format_integer(self, input_data, input_name=''): - return '%d' % input_data - def gds_validate_integer(self, input_data, node, input_name=''): - return input_data - def gds_format_integer_list(self, input_data, input_name=''): - return '%s' % input_data - def gds_validate_integer_list(self, input_data, node, input_name=''): - values = input_data.split() - for value in values: - try: - float(value) - except (TypeError, ValueError): - raise_parse_error(node, 'Requires sequence of integers') - return input_data - def gds_format_float(self, input_data, input_name=''): - return ('%.15f' % input_data).rstrip('0') - def gds_validate_float(self, input_data, node, input_name=''): - return input_data - def gds_format_float_list(self, input_data, input_name=''): - return '%s' % input_data - def gds_validate_float_list(self, input_data, node, input_name=''): - values = input_data.split() - for value in values: - try: - float(value) - except (TypeError, ValueError): - raise_parse_error(node, 'Requires sequence of floats') - return input_data - def gds_format_double(self, input_data, input_name=''): - return '%e' % input_data - def gds_validate_double(self, input_data, node, input_name=''): - return input_data - def gds_format_double_list(self, input_data, input_name=''): - return '%s' % input_data - def gds_validate_double_list(self, input_data, node, input_name=''): - values = input_data.split() - for value in values: - try: - float(value) - except (TypeError, ValueError): - raise_parse_error(node, 'Requires sequence of doubles') - return input_data - def gds_format_boolean(self, input_data, input_name=''): - return ('%s' % input_data).lower() - def gds_validate_boolean(self, input_data, node, input_name=''): - return input_data - def gds_format_boolean_list(self, input_data, input_name=''): - return '%s' % input_data - def gds_validate_boolean_list(self, input_data, node, input_name=''): - values = input_data.split() - for value in values: - if value not in ('true', '1', 'false', '0', ): - raise_parse_error( - node, - 'Requires sequence of booleans ' - '("true", "1", "false", "0")') - return input_data - def gds_validate_datetime(self, input_data, node, input_name=''): - return input_data - def gds_format_datetime(self, input_data, input_name=''): - if input_data.microsecond == 0: - _svalue = '%04d-%02d-%02dT%02d:%02d:%02d' % ( - input_data.year, - input_data.month, - input_data.day, - input_data.hour, - input_data.minute, - input_data.second, - ) - else: - _svalue = '%04d-%02d-%02dT%02d:%02d:%02d.%s' % ( - input_data.year, - input_data.month, - input_data.day, - input_data.hour, - input_data.minute, - input_data.second, - ('%f' % (float(input_data.microsecond) / 1000000))[2:], - ) - if input_data.tzinfo is not None: - tzoff = input_data.tzinfo.utcoffset(input_data) - if tzoff is not None: - total_seconds = tzoff.seconds + (86400 * tzoff.days) - if total_seconds == 0: - _svalue += 'Z' - else: - if total_seconds < 0: - _svalue += '-' - total_seconds *= -1 - else: - _svalue += '+' - hours = total_seconds // 3600 - minutes = (total_seconds - (hours * 3600)) // 60 - _svalue += '{0:02d}:{1:02d}'.format(hours, minutes) - return _svalue - @classmethod - def gds_parse_datetime(cls, input_data): - tz = None - if input_data[-1] == 'Z': - tz = GeneratedsSuper._FixedOffsetTZ(0, 'UTC') - input_data = input_data[:-1] - else: - results = GeneratedsSuper.tzoff_pattern.search(input_data) - if results is not None: - tzoff_parts = results.group(2).split(':') - tzoff = int(tzoff_parts[0]) * 60 + int(tzoff_parts[1]) - if results.group(1) == '-': - tzoff *= -1 - tz = GeneratedsSuper._FixedOffsetTZ( - tzoff, results.group(0)) - input_data = input_data[:-6] - time_parts = input_data.split('.') - if len(time_parts) > 1: - micro_seconds = int(float('0.' + time_parts[1]) * 1000000) - input_data = '%s.%s' % (time_parts[0], micro_seconds, ) - dt = datetime_.datetime.strptime( - input_data, '%Y-%m-%dT%H:%M:%S.%f') - else: - dt = datetime_.datetime.strptime( - input_data, '%Y-%m-%dT%H:%M:%S') - dt = dt.replace(tzinfo=tz) - return dt - def gds_validate_date(self, input_data, node, input_name=''): - return input_data - def gds_format_date(self, input_data, input_name=''): - _svalue = '%04d-%02d-%02d' % ( - input_data.year, - input_data.month, - input_data.day, - ) - try: - if input_data.tzinfo is not None: - tzoff = input_data.tzinfo.utcoffset(input_data) - if tzoff is not None: - total_seconds = tzoff.seconds + (86400 * tzoff.days) - if total_seconds == 0: - _svalue += 'Z' - else: - if total_seconds < 0: - _svalue += '-' - total_seconds *= -1 - else: - _svalue += '+' - hours = total_seconds // 3600 - minutes = (total_seconds - (hours * 3600)) // 60 - _svalue += '{0:02d}:{1:02d}'.format(hours, minutes) - except AttributeError: - pass - return _svalue - @classmethod - def gds_parse_date(cls, input_data): - tz = None - if input_data[-1] == 'Z': - tz = GeneratedsSuper._FixedOffsetTZ(0, 'UTC') - input_data = input_data[:-1] - else: - results = GeneratedsSuper.tzoff_pattern.search(input_data) - if results is not None: - tzoff_parts = results.group(2).split(':') - tzoff = int(tzoff_parts[0]) * 60 + int(tzoff_parts[1]) - if results.group(1) == '-': - tzoff *= -1 - tz = GeneratedsSuper._FixedOffsetTZ( - tzoff, results.group(0)) - input_data = input_data[:-6] - dt = datetime_.datetime.strptime(input_data, '%Y-%m-%d') - dt = dt.replace(tzinfo=tz) - return dt.date() - def gds_validate_time(self, input_data, node, input_name=''): - return input_data - def gds_format_time(self, input_data, input_name=''): - if input_data.microsecond == 0: - _svalue = '%02d:%02d:%02d' % ( - input_data.hour, - input_data.minute, - input_data.second, - ) - else: - _svalue = '%02d:%02d:%02d.%s' % ( - input_data.hour, - input_data.minute, - input_data.second, - ('%f' % (float(input_data.microsecond) / 1000000))[2:], - ) - if input_data.tzinfo is not None: - tzoff = input_data.tzinfo.utcoffset(input_data) - if tzoff is not None: - total_seconds = tzoff.seconds + (86400 * tzoff.days) - if total_seconds == 0: - _svalue += 'Z' - else: - if total_seconds < 0: - _svalue += '-' - total_seconds *= -1 - else: - _svalue += '+' - hours = total_seconds // 3600 - minutes = (total_seconds - (hours * 3600)) // 60 - _svalue += '{0:02d}:{1:02d}'.format(hours, minutes) - return _svalue - @classmethod - def gds_parse_time(cls, input_data): - tz = None - if input_data[-1] == 'Z': - tz = GeneratedsSuper._FixedOffsetTZ(0, 'UTC') - input_data = input_data[:-1] - else: - results = GeneratedsSuper.tzoff_pattern.search(input_data) - if results is not None: - tzoff_parts = results.group(2).split(':') - tzoff = int(tzoff_parts[0]) * 60 + int(tzoff_parts[1]) - if results.group(1) == '-': - tzoff *= -1 - tz = GeneratedsSuper._FixedOffsetTZ( - tzoff, results.group(0)) - input_data = input_data[:-6] - if len(input_data.split('.')) > 1: - dt = datetime_.datetime.strptime(input_data, '%H:%M:%S.%f') - else: - dt = datetime_.datetime.strptime(input_data, '%H:%M:%S') - dt = dt.replace(tzinfo=tz) - return dt.time() - def gds_str_lower(self, instring): - return instring.lower() - def get_path_(self, node): - path_list = [] - self.get_path_list_(node, path_list) - path_list.reverse() - path = '/'.join(path_list) - return path - Tag_strip_pattern_ = re_.compile(r'\{.*\}') - def get_path_list_(self, node, path_list): - if node is None: - return - tag = GeneratedsSuper.Tag_strip_pattern_.sub('', node.tag) - if tag: - path_list.append(tag) - self.get_path_list_(node.getparent(), path_list) - def get_class_obj_(self, node, default_class=None): - class_obj1 = default_class - if 'xsi' in node.nsmap: - classname = node.get('{%s}type' % node.nsmap['xsi']) - if classname is not None: - names = classname.split(':') - if len(names) == 2: - classname = names[1] - class_obj2 = globals().get(classname) - if class_obj2 is not None: - class_obj1 = class_obj2 - return class_obj1 - def gds_build_any(self, node, type_name=None): - return None - @classmethod - def gds_reverse_node_mapping(cls, mapping): - return dict(((v, k) for k, v in mapping.items())) - - -# -# If you have installed IPython you can uncomment and use the following. -# IPython is available from http://ipython.scipy.org/. -# - -## from IPython.Shell import IPShellEmbed -## args = '' -## ipshell = IPShellEmbed(args, -## banner = 'Dropping into IPython', -## exit_msg = 'Leaving Interpreter, back to program.') - -# Then use the following line where and when you want to drop into the -# IPython shell: -# ipshell(' -- Entering ipshell.\nHit Ctrl-D to exit') - -# -# Globals -# - -ExternalEncoding = 'ascii' -Tag_pattern_ = re_.compile(r'({.*})?(.*)') -String_cleanup_pat_ = re_.compile(r"[\n\r\s]+") -Namespace_extract_pat_ = re_.compile(r'{(.*)}(.*)') - -# -# Support/utility functions. -# - - -def showIndent(outfile, level, pretty_print=True): - if pretty_print: - for idx in range(level): - outfile.write(' ') - - -def quote_xml(inStr): - if not inStr: - return '' - s1 = (isinstance(inStr, str) and inStr or - '%s' % inStr) - s1 = s1.replace('&', '&') - s1 = s1.replace('<', '<') - s1 = s1.replace('>', '>') - return s1 - - -def quote_attrib(inStr): - s1 = (isinstance(inStr, str) and inStr or - '%s' % inStr) - s1 = s1.replace('&', '&') - s1 = s1.replace('<', '<') - s1 = s1.replace('>', '>') - if '"' in s1: - if "'" in s1: - s1 = '"%s"' % s1.replace('"', """) - else: - s1 = "'%s'" % s1 - else: - s1 = '"%s"' % s1 - return s1 - - -def quote_python(inStr): - s1 = inStr - if s1.find("'") == -1: - if s1.find('\n') == -1: - return "'%s'" % s1 - else: - return "'''%s'''" % s1 - else: - if s1.find('"') != -1: - s1 = s1.replace('"', '\\"') - if s1.find('\n') == -1: - return '"%s"' % s1 - else: - return '"""%s"""' % s1 - - -def get_all_text_(node): - if node.text is not None: - text = node.text - else: - text = '' - for child in node: - if child.tail is not None: - text += child.tail - return text - - -def find_attr_value_(attr_name, node): - attrs = node.attrib - attr_parts = attr_name.split(':') - value = None - if len(attr_parts) == 1: - value = attrs.get(attr_name) - elif len(attr_parts) == 2: - prefix, name = attr_parts - namespace = node.nsmap.get(prefix) - if namespace is not None: - value = attrs.get('{%s}%s' % (namespace, name, )) - return value - - -class GDSParseError(Exception): - pass - - -def raise_parse_error(node, msg): - if XMLParser_import_library == XMLParser_import_lxml: - msg = '%s (element %s/line %d)' % ( - msg, node.tag, node.sourceline, ) - else: - msg = '%s (element %s)' % (msg, node.tag, ) - raise GDSParseError(msg) - - -class MixedContainer: - # Constants for category: - CategoryNone = 0 - CategoryText = 1 - CategorySimple = 2 - CategoryComplex = 3 - # Constants for content_type: - TypeNone = 0 - TypeText = 1 - TypeString = 2 - TypeInteger = 3 - TypeFloat = 4 - TypeDecimal = 5 - TypeDouble = 6 - TypeBoolean = 7 - TypeBase64 = 8 - def __init__(self, category, content_type, name, value): - self.category = category - self.content_type = content_type - self.name = name - self.value = value - def getCategory(self): - return self.category - def getContenttype(self, content_type): - return self.content_type - def getValue(self): - return self.value - def getName(self): - return self.name - def export(self, outfile, level, name, namespace, pretty_print=True): - if self.category == MixedContainer.CategoryText: - # Prevent exporting empty content as empty lines. - if self.value.strip(): - outfile.write(self.value) - elif self.category == MixedContainer.CategorySimple: - self.exportSimple(outfile, level, name) - else: # category == MixedContainer.CategoryComplex - self.value.export(outfile, level, namespace, name, pretty_print) - def exportSimple(self, outfile, level, name): - if self.content_type == MixedContainer.TypeString: - outfile.write('<%s>%s' % ( - self.name, self.value, self.name)) - elif self.content_type == MixedContainer.TypeInteger or \ - self.content_type == MixedContainer.TypeBoolean: - outfile.write('<%s>%d' % ( - self.name, self.value, self.name)) - elif self.content_type == MixedContainer.TypeFloat or \ - self.content_type == MixedContainer.TypeDecimal: - outfile.write('<%s>%f' % ( - self.name, self.value, self.name)) - elif self.content_type == MixedContainer.TypeDouble: - outfile.write('<%s>%g' % ( - self.name, self.value, self.name)) - elif self.content_type == MixedContainer.TypeBase64: - outfile.write('<%s>%s' % ( - self.name, base64.b64encode(self.value), self.name)) - def to_etree(self, element): - if self.category == MixedContainer.CategoryText: - # Prevent exporting empty content as empty lines. - if self.value.strip(): - if len(element) > 0: - if element[-1].tail is None: - element[-1].tail = self.value - else: - element[-1].tail += self.value - else: - if element.text is None: - element.text = self.value - else: - element.text += self.value - elif self.category == MixedContainer.CategorySimple: - subelement = etree_.SubElement(element, '%s' % self.name) - subelement.text = self.to_etree_simple() - else: # category == MixedContainer.CategoryComplex - self.value.to_etree(element) - def to_etree_simple(self): - if self.content_type == MixedContainer.TypeString: - text = self.value - elif (self.content_type == MixedContainer.TypeInteger or - self.content_type == MixedContainer.TypeBoolean): - text = '%d' % self.value - elif (self.content_type == MixedContainer.TypeFloat or - self.content_type == MixedContainer.TypeDecimal): - text = '%f' % self.value - elif self.content_type == MixedContainer.TypeDouble: - text = '%g' % self.value - elif self.content_type == MixedContainer.TypeBase64: - text = '%s' % base64.b64encode(self.value) - return text - def exportLiteral(self, outfile, level, name): - if self.category == MixedContainer.CategoryText: - showIndent(outfile, level) - outfile.write( - 'model_.MixedContainer(%d, %d, "%s", "%s"),\n' % ( - self.category, self.content_type, self.name, self.value)) - elif self.category == MixedContainer.CategorySimple: - showIndent(outfile, level) - outfile.write( - 'model_.MixedContainer(%d, %d, "%s", "%s"),\n' % ( - self.category, self.content_type, self.name, self.value)) - else: # category == MixedContainer.CategoryComplex - showIndent(outfile, level) - outfile.write( - 'model_.MixedContainer(%d, %d, "%s",\n' % ( - self.category, self.content_type, self.name,)) - self.value.exportLiteral(outfile, level + 1) - showIndent(outfile, level) - outfile.write(')\n') - - -class MemberSpec_: - def __init__(self, name='', data_type='', container=0): - self.name = name - self.data_type = data_type - self.container = container - def set_name(self, name): self.name = name - def get_name(self): return self.name - def set_data_type(self, data_type): self.data_type = data_type - def get_data_type_chain(self): return self.data_type - def get_data_type(self): - if isinstance(self.data_type, list): - if len(self.data_type) > 0: - return self.data_type[-1] - else: - return 'xs:string' - else: - return self.data_type - def set_container(self, container): self.container = container - def get_container(self): return self.container - - -def _cast(typ, value): - if typ is None or value is None: - return value - return typ(value) - -# -# Data representation classes. -# - - -class Temperature(GeneratedsSuper): - """Specification of a temperature.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, subject=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.subject = subject - self.value = value - def factory(*args_, **kwargs_): - if Temperature.subclass: - return Temperature.subclass(*args_, **kwargs_) - else: - return Temperature(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_subject(self): return self.subject - def set_subject(self, subject): self.subject = subject - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_Int16(self, value): - # Validate type Int16, a restriction on xs:short. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.subject is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Temperature', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Temperature') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Temperature', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Temperature'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='Temperature', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.subject is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssubject>%s%s' % (namespace_, self.gds_format_integer(self.subject, input_name='subject'), namespace_, eol_)) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Temperature'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.subject is not None: - showIndent(outfile, level) - outfile.write('subject=%d,\n' % self.subject) - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'subject': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'subject') - self.subject = ival_ - self.validate_UInt8(self.subject) # validate type UInt8 - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int16(self.value) # validate type Int16 -# end class Temperature - - -class Condition(GeneratedsSuper): - """Indicates a condition that must be satisfied for the Notification to - be triggered.""" - subclass = None - superclass = None - def __init__(self, attributeIdentifier=None, lowerThreshold=None, upperThreshold=None): - self.original_tagname_ = None - self.attributeIdentifier = attributeIdentifier - self.lowerThreshold = lowerThreshold - self.upperThreshold = upperThreshold - def factory(*args_, **kwargs_): - if Condition.subclass: - return Condition.subclass(*args_, **kwargs_) - else: - return Condition(*args_, **kwargs_) - factory = staticmethod(factory) - def get_attributeIdentifier(self): return self.attributeIdentifier - def set_attributeIdentifier(self, attributeIdentifier): self.attributeIdentifier = attributeIdentifier - def get_lowerThreshold(self): return self.lowerThreshold - def set_lowerThreshold(self, lowerThreshold): self.lowerThreshold = lowerThreshold - def get_upperThreshold(self): return self.upperThreshold - def set_upperThreshold(self, upperThreshold): self.upperThreshold = upperThreshold - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_Int48(self, value): - # Validate type Int48, a restriction on xs:long. - pass - def hasContent_(self): - if ( - self.attributeIdentifier is not None or - self.lowerThreshold is not None or - self.upperThreshold is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Condition', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Condition') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Condition', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Condition'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='Condition', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.attributeIdentifier is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sattributeIdentifier>%s%s' % (namespace_, self.gds_format_integer(self.attributeIdentifier, input_name='attributeIdentifier'), namespace_, eol_)) - if self.lowerThreshold is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slowerThreshold>%s%s' % (namespace_, self.gds_format_integer(self.lowerThreshold, input_name='lowerThreshold'), namespace_, eol_)) - if self.upperThreshold is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%supperThreshold>%s%s' % (namespace_, self.gds_format_integer(self.upperThreshold, input_name='upperThreshold'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Condition'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.attributeIdentifier is not None: - showIndent(outfile, level) - outfile.write('attributeIdentifier=%d,\n' % self.attributeIdentifier) - if self.lowerThreshold is not None: - showIndent(outfile, level) - outfile.write('lowerThreshold=%d,\n' % self.lowerThreshold) - if self.upperThreshold is not None: - showIndent(outfile, level) - outfile.write('upperThreshold=%d,\n' % self.upperThreshold) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'attributeIdentifier': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'attributeIdentifier') - self.attributeIdentifier = ival_ - self.validate_UInt8(self.attributeIdentifier) # validate type UInt8 - elif nodeName_ == 'lowerThreshold': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'lowerThreshold') - self.lowerThreshold = ival_ - self.validate_Int48(self.lowerThreshold) # validate type Int48 - elif nodeName_ == 'upperThreshold': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'upperThreshold') - self.upperThreshold = ival_ - self.validate_Int48(self.upperThreshold) # validate type Int48 -# end class Condition - - -class AppliedTargetReduction(GeneratedsSuper): - """Specifies the value of the TargetReduction applied by the device.""" - subclass = None - superclass = None - def __init__(self, type_=None, value=None): - self.original_tagname_ = None - self.type_ = type_ - self.value = value - def factory(*args_, **kwargs_): - if AppliedTargetReduction.subclass: - return AppliedTargetReduction.subclass(*args_, **kwargs_) - else: - return AppliedTargetReduction(*args_, **kwargs_) - factory = staticmethod(factory) - def get_type(self): return self.type_ - def set_type(self, type_): self.type_ = type_ - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.type_ is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AppliedTargetReduction', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AppliedTargetReduction') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AppliedTargetReduction', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AppliedTargetReduction'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='AppliedTargetReduction', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.type_ is not None: - self.type_.export(outfile, level, namespace_, name_='type', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='AppliedTargetReduction'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.type_ is not None: - showIndent(outfile, level) - outfile.write('type_=model_.UnitType(\n') - self.type_.exportLiteral(outfile, level, name_='type') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'type': - obj_ = UnitType.factory() - obj_.build(child_) - self.type_ = obj_ - obj_.original_tagname_ = 'type' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt16(self.value) # validate type UInt16 -# end class AppliedTargetReduction - - -class DRLCCapabilities(GeneratedsSuper): - """Contains information about the static capabilities of the device, to - allow service providers to know what types of functions are - supported, what the normal operating ranges and limits are, and - other similar information, in order to provide better - suggestions of applicable programs to receive the maximum - benefit.""" - subclass = None - superclass = None - def __init__(self, averageEnergy=None, maxDemand=None, optionsImplemented=None): - self.original_tagname_ = None - self.averageEnergy = averageEnergy - self.maxDemand = maxDemand - self.optionsImplemented = optionsImplemented - def factory(*args_, **kwargs_): - if DRLCCapabilities.subclass: - return DRLCCapabilities.subclass(*args_, **kwargs_) - else: - return DRLCCapabilities(*args_, **kwargs_) - factory = staticmethod(factory) - def get_averageEnergy(self): return self.averageEnergy - def set_averageEnergy(self, averageEnergy): self.averageEnergy = averageEnergy - def get_maxDemand(self): return self.maxDemand - def set_maxDemand(self, maxDemand): self.maxDemand = maxDemand - def get_optionsImplemented(self): return self.optionsImplemented - def set_optionsImplemented(self, optionsImplemented): self.optionsImplemented = optionsImplemented - def validate_HexBinary32(self, value): - # Validate type HexBinary32, a restriction on xs:hexBinary. - pass - def hasContent_(self): - if ( - self.averageEnergy is not None or - self.maxDemand is not None or - self.optionsImplemented is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DRLCCapabilities', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DRLCCapabilities') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DRLCCapabilities', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DRLCCapabilities'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DRLCCapabilities', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.averageEnergy is not None: - self.averageEnergy.export(outfile, level, namespace_, name_='averageEnergy', pretty_print=pretty_print) - if self.maxDemand is not None: - self.maxDemand.export(outfile, level, namespace_, name_='maxDemand', pretty_print=pretty_print) - if self.optionsImplemented is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%soptionsImplemented>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.optionsImplemented).encode(ExternalEncoding), input_name='optionsImplemented'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='DRLCCapabilities'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.averageEnergy is not None: - showIndent(outfile, level) - outfile.write('averageEnergy=model_.RealEnergy(\n') - self.averageEnergy.exportLiteral(outfile, level, name_='averageEnergy') - showIndent(outfile, level) - outfile.write('),\n') - if self.maxDemand is not None: - showIndent(outfile, level) - outfile.write('maxDemand=model_.ActivePower(\n') - self.maxDemand.exportLiteral(outfile, level, name_='maxDemand') - showIndent(outfile, level) - outfile.write('),\n') - if self.optionsImplemented is not None: - showIndent(outfile, level) - outfile.write('optionsImplemented=%s,\n' % quote_python(self.optionsImplemented).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'averageEnergy': - obj_ = RealEnergy.factory() - obj_.build(child_) - self.averageEnergy = obj_ - obj_.original_tagname_ = 'averageEnergy' - elif nodeName_ == 'maxDemand': - obj_ = ActivePower.factory() - obj_.build(child_) - self.maxDemand = obj_ - obj_.original_tagname_ = 'maxDemand' - elif nodeName_ == 'optionsImplemented': - optionsImplemented_ = child_.text - optionsImplemented_ = self.gds_validate_string(optionsImplemented_, node, 'optionsImplemented') - self.optionsImplemented = optionsImplemented_ - self.validate_HexBinary32(self.optionsImplemented) # validate type HexBinary32 -# end class DRLCCapabilities - - -class PowerSourceType(GeneratedsSuper): - """0 - none 1 - mains 2 - battery 3 - local generation 4 - emergency 5 - - unknown All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PowerSourceType.subclass: - return PowerSourceType.subclass(*args_, **kwargs_) - else: - return PowerSourceType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PowerSourceType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PowerSourceType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PowerSourceType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PowerSourceType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PowerSourceType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PowerSourceType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PowerSourceType - - -class PEVInfo(GeneratedsSuper): - """Contains attributes that can be exposed by PEVs and other devices - that have charging requirements.""" - subclass = None - superclass = None - def __init__(self, chargingPowerNow=None, energyRequestNow=None, maxForwardPower=None, minimumChargingDuration=None, targetStateOfCharge=None, timeChargeIsNeeded=None, timeChargingStatusPEV=None): - self.original_tagname_ = None - self.chargingPowerNow = chargingPowerNow - self.energyRequestNow = energyRequestNow - self.maxForwardPower = maxForwardPower - self.minimumChargingDuration = minimumChargingDuration - self.targetStateOfCharge = targetStateOfCharge - self.timeChargeIsNeeded = timeChargeIsNeeded - self.timeChargingStatusPEV = timeChargingStatusPEV - def factory(*args_, **kwargs_): - if PEVInfo.subclass: - return PEVInfo.subclass(*args_, **kwargs_) - else: - return PEVInfo(*args_, **kwargs_) - factory = staticmethod(factory) - def get_chargingPowerNow(self): return self.chargingPowerNow - def set_chargingPowerNow(self, chargingPowerNow): self.chargingPowerNow = chargingPowerNow - def get_energyRequestNow(self): return self.energyRequestNow - def set_energyRequestNow(self, energyRequestNow): self.energyRequestNow = energyRequestNow - def get_maxForwardPower(self): return self.maxForwardPower - def set_maxForwardPower(self, maxForwardPower): self.maxForwardPower = maxForwardPower - def get_minimumChargingDuration(self): return self.minimumChargingDuration - def set_minimumChargingDuration(self, minimumChargingDuration): self.minimumChargingDuration = minimumChargingDuration - def get_targetStateOfCharge(self): return self.targetStateOfCharge - def set_targetStateOfCharge(self, targetStateOfCharge): self.targetStateOfCharge = targetStateOfCharge - def get_timeChargeIsNeeded(self): return self.timeChargeIsNeeded - def set_timeChargeIsNeeded(self, timeChargeIsNeeded): self.timeChargeIsNeeded = timeChargeIsNeeded - def get_timeChargingStatusPEV(self): return self.timeChargingStatusPEV - def set_timeChargingStatusPEV(self, timeChargingStatusPEV): self.timeChargingStatusPEV = timeChargingStatusPEV - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def hasContent_(self): - if ( - self.chargingPowerNow is not None or - self.energyRequestNow is not None or - self.maxForwardPower is not None or - self.minimumChargingDuration is not None or - self.targetStateOfCharge is not None or - self.timeChargeIsNeeded is not None or - self.timeChargingStatusPEV is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PEVInfo', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PEVInfo') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PEVInfo', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PEVInfo'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PEVInfo', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.chargingPowerNow is not None: - self.chargingPowerNow.export(outfile, level, namespace_, name_='chargingPowerNow', pretty_print=pretty_print) - if self.energyRequestNow is not None: - self.energyRequestNow.export(outfile, level, namespace_, name_='energyRequestNow', pretty_print=pretty_print) - if self.maxForwardPower is not None: - self.maxForwardPower.export(outfile, level, namespace_, name_='maxForwardPower', pretty_print=pretty_print) - if self.minimumChargingDuration is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sminimumChargingDuration>%s%s' % (namespace_, self.gds_format_integer(self.minimumChargingDuration, input_name='minimumChargingDuration'), namespace_, eol_)) - if self.targetStateOfCharge is not None: - self.targetStateOfCharge.export(outfile, level, namespace_, name_='targetStateOfCharge', pretty_print=pretty_print) - if self.timeChargeIsNeeded is not None: - self.timeChargeIsNeeded.export(outfile, level, namespace_, name_='timeChargeIsNeeded', pretty_print=pretty_print) - if self.timeChargingStatusPEV is not None: - self.timeChargingStatusPEV.export(outfile, level, namespace_, name_='timeChargingStatusPEV', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='PEVInfo'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.chargingPowerNow is not None: - showIndent(outfile, level) - outfile.write('chargingPowerNow=model_.ActivePower(\n') - self.chargingPowerNow.exportLiteral(outfile, level, name_='chargingPowerNow') - showIndent(outfile, level) - outfile.write('),\n') - if self.energyRequestNow is not None: - showIndent(outfile, level) - outfile.write('energyRequestNow=model_.RealEnergy(\n') - self.energyRequestNow.exportLiteral(outfile, level, name_='energyRequestNow') - showIndent(outfile, level) - outfile.write('),\n') - if self.maxForwardPower is not None: - showIndent(outfile, level) - outfile.write('maxForwardPower=model_.ActivePower(\n') - self.maxForwardPower.exportLiteral(outfile, level, name_='maxForwardPower') - showIndent(outfile, level) - outfile.write('),\n') - if self.minimumChargingDuration is not None: - showIndent(outfile, level) - outfile.write('minimumChargingDuration=%d,\n' % self.minimumChargingDuration) - if self.targetStateOfCharge is not None: - showIndent(outfile, level) - outfile.write('targetStateOfCharge=model_.PerCent(\n') - self.targetStateOfCharge.exportLiteral(outfile, level, name_='targetStateOfCharge') - showIndent(outfile, level) - outfile.write('),\n') - if self.timeChargeIsNeeded is not None: - showIndent(outfile, level) - outfile.write('timeChargeIsNeeded=model_.TimeType(\n') - self.timeChargeIsNeeded.exportLiteral(outfile, level, name_='timeChargeIsNeeded') - showIndent(outfile, level) - outfile.write('),\n') - if self.timeChargingStatusPEV is not None: - showIndent(outfile, level) - outfile.write('timeChargingStatusPEV=model_.TimeType(\n') - self.timeChargingStatusPEV.exportLiteral(outfile, level, name_='timeChargingStatusPEV') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'chargingPowerNow': - obj_ = ActivePower.factory() - obj_.build(child_) - self.chargingPowerNow = obj_ - obj_.original_tagname_ = 'chargingPowerNow' - elif nodeName_ == 'energyRequestNow': - obj_ = RealEnergy.factory() - obj_.build(child_) - self.energyRequestNow = obj_ - obj_.original_tagname_ = 'energyRequestNow' - elif nodeName_ == 'maxForwardPower': - obj_ = ActivePower.factory() - obj_.build(child_) - self.maxForwardPower = obj_ - obj_.original_tagname_ = 'maxForwardPower' - elif nodeName_ == 'minimumChargingDuration': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'minimumChargingDuration') - self.minimumChargingDuration = ival_ - self.validate_UInt32(self.minimumChargingDuration) # validate type UInt32 - elif nodeName_ == 'targetStateOfCharge': - obj_ = PerCent.factory() - obj_.build(child_) - self.targetStateOfCharge = obj_ - obj_.original_tagname_ = 'targetStateOfCharge' - elif nodeName_ == 'timeChargeIsNeeded': - obj_ = TimeType.factory() - obj_.build(child_) - self.timeChargeIsNeeded = obj_ - obj_.original_tagname_ = 'timeChargeIsNeeded' - elif nodeName_ == 'timeChargingStatusPEV': - obj_ = TimeType.factory() - obj_.build(child_) - self.timeChargingStatusPEV = obj_ - obj_.original_tagname_ = 'timeChargingStatusPEV' -# end class PEVInfo - - -class IEEE_802_15_4(GeneratedsSuper): - """Contains 802.15.4 link layer specific attributes.""" - subclass = None - superclass = None - def __init__(self, capabilityInfo=None, NeighborListLink=None, shortAddress=None): - self.original_tagname_ = None - self.capabilityInfo = capabilityInfo - self.NeighborListLink = NeighborListLink - self.shortAddress = shortAddress - def factory(*args_, **kwargs_): - if IEEE_802_15_4.subclass: - return IEEE_802_15_4.subclass(*args_, **kwargs_) - else: - return IEEE_802_15_4(*args_, **kwargs_) - factory = staticmethod(factory) - def get_capabilityInfo(self): return self.capabilityInfo - def set_capabilityInfo(self, capabilityInfo): self.capabilityInfo = capabilityInfo - def get_NeighborListLink(self): return self.NeighborListLink - def set_NeighborListLink(self, NeighborListLink): self.NeighborListLink = NeighborListLink - def get_shortAddress(self): return self.shortAddress - def set_shortAddress(self, shortAddress): self.shortAddress = shortAddress - def validate_HexBinary8(self, value): - # Validate type HexBinary8, a restriction on xs:hexBinary. - pass - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.capabilityInfo is not None or - self.NeighborListLink is not None or - self.shortAddress is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='IEEE_802_15_4', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='IEEE_802_15_4') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='IEEE_802_15_4', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='IEEE_802_15_4'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='IEEE_802_15_4', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.capabilityInfo is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%scapabilityInfo>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.capabilityInfo).encode(ExternalEncoding), input_name='capabilityInfo'), namespace_, eol_)) - if self.NeighborListLink is not None: - self.NeighborListLink.export(outfile, level, namespace_, name_='NeighborListLink', pretty_print=pretty_print) - if self.shortAddress is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sshortAddress>%s%s' % (namespace_, self.gds_format_integer(self.shortAddress, input_name='shortAddress'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='IEEE_802_15_4'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.capabilityInfo is not None: - showIndent(outfile, level) - outfile.write('capabilityInfo=%s,\n' % quote_python(self.capabilityInfo).encode(ExternalEncoding)) - if self.NeighborListLink is not None: - showIndent(outfile, level) - outfile.write('NeighborListLink=model_.NeighborListLink(\n') - self.NeighborListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.shortAddress is not None: - showIndent(outfile, level) - outfile.write('shortAddress=%d,\n' % self.shortAddress) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'capabilityInfo': - capabilityInfo_ = child_.text - capabilityInfo_ = self.gds_validate_string(capabilityInfo_, node, 'capabilityInfo') - self.capabilityInfo = capabilityInfo_ - self.validate_HexBinary8(self.capabilityInfo) # validate type HexBinary8 - elif nodeName_ == 'NeighborListLink': - obj_ = NeighborListLink.factory() - obj_.build(child_) - self.NeighborListLink = obj_ - obj_.original_tagname_ = 'NeighborListLink' - elif nodeName_ == 'shortAddress': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'shortAddress') - self.shortAddress = ival_ - self.validate_UInt16(self.shortAddress) # validate type UInt16 -# end class IEEE_802_15_4 - - -class loWPAN(GeneratedsSuper): - """Contains information specific to 6LoWPAN.""" - subclass = None - superclass = None - def __init__(self, octetsRx=None, octetsTx=None, packetsRx=None, packetsTx=None, rxFragError=None): - self.original_tagname_ = None - self.octetsRx = octetsRx - self.octetsTx = octetsTx - self.packetsRx = packetsRx - self.packetsTx = packetsTx - self.rxFragError = rxFragError - def factory(*args_, **kwargs_): - if loWPAN.subclass: - return loWPAN.subclass(*args_, **kwargs_) - else: - return loWPAN(*args_, **kwargs_) - factory = staticmethod(factory) - def get_octetsRx(self): return self.octetsRx - def set_octetsRx(self, octetsRx): self.octetsRx = octetsRx - def get_octetsTx(self): return self.octetsTx - def set_octetsTx(self, octetsTx): self.octetsTx = octetsTx - def get_packetsRx(self): return self.packetsRx - def set_packetsRx(self, packetsRx): self.packetsRx = packetsRx - def get_packetsTx(self): return self.packetsTx - def set_packetsTx(self, packetsTx): self.packetsTx = packetsTx - def get_rxFragError(self): return self.rxFragError - def set_rxFragError(self, rxFragError): self.rxFragError = rxFragError - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def hasContent_(self): - if ( - self.octetsRx is not None or - self.octetsTx is not None or - self.packetsRx is not None or - self.packetsTx is not None or - self.rxFragError is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='loWPAN', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='loWPAN') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='loWPAN', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='loWPAN'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='loWPAN', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.octetsRx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%soctetsRx>%s%s' % (namespace_, self.gds_format_integer(self.octetsRx, input_name='octetsRx'), namespace_, eol_)) - if self.octetsTx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%soctetsTx>%s%s' % (namespace_, self.gds_format_integer(self.octetsTx, input_name='octetsTx'), namespace_, eol_)) - if self.packetsRx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%spacketsRx>%s%s' % (namespace_, self.gds_format_integer(self.packetsRx, input_name='packetsRx'), namespace_, eol_)) - if self.packetsTx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%spacketsTx>%s%s' % (namespace_, self.gds_format_integer(self.packetsTx, input_name='packetsTx'), namespace_, eol_)) - if self.rxFragError is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srxFragError>%s%s' % (namespace_, self.gds_format_integer(self.rxFragError, input_name='rxFragError'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='loWPAN'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.octetsRx is not None: - showIndent(outfile, level) - outfile.write('octetsRx=%d,\n' % self.octetsRx) - if self.octetsTx is not None: - showIndent(outfile, level) - outfile.write('octetsTx=%d,\n' % self.octetsTx) - if self.packetsRx is not None: - showIndent(outfile, level) - outfile.write('packetsRx=%d,\n' % self.packetsRx) - if self.packetsTx is not None: - showIndent(outfile, level) - outfile.write('packetsTx=%d,\n' % self.packetsTx) - if self.rxFragError is not None: - showIndent(outfile, level) - outfile.write('rxFragError=%d,\n' % self.rxFragError) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'octetsRx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'octetsRx') - self.octetsRx = ival_ - self.validate_UInt32(self.octetsRx) # validate type UInt32 - elif nodeName_ == 'octetsTx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'octetsTx') - self.octetsTx = ival_ - self.validate_UInt32(self.octetsTx) # validate type UInt32 - elif nodeName_ == 'packetsRx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'packetsRx') - self.packetsRx = ival_ - self.validate_UInt32(self.packetsRx) # validate type UInt32 - elif nodeName_ == 'packetsTx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'packetsTx') - self.packetsTx = ival_ - self.validate_UInt32(self.packetsTx) # validate type UInt32 - elif nodeName_ == 'rxFragError': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'rxFragError') - self.rxFragError = ival_ - self.validate_UInt32(self.rxFragError) # validate type UInt32 -# end class loWPAN - - -class PowerConfiguration(GeneratedsSuper): - """Contains configuration related to the device's power sources""" - subclass = None - superclass = None - def __init__(self, batteryInstallTime=None, lowChargeThreshold=None): - self.original_tagname_ = None - self.batteryInstallTime = batteryInstallTime - self.lowChargeThreshold = lowChargeThreshold - def factory(*args_, **kwargs_): - if PowerConfiguration.subclass: - return PowerConfiguration.subclass(*args_, **kwargs_) - else: - return PowerConfiguration(*args_, **kwargs_) - factory = staticmethod(factory) - def get_batteryInstallTime(self): return self.batteryInstallTime - def set_batteryInstallTime(self, batteryInstallTime): self.batteryInstallTime = batteryInstallTime - def get_lowChargeThreshold(self): return self.lowChargeThreshold - def set_lowChargeThreshold(self, lowChargeThreshold): self.lowChargeThreshold = lowChargeThreshold - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def hasContent_(self): - if ( - self.batteryInstallTime is not None or - self.lowChargeThreshold is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PowerConfiguration', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PowerConfiguration') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PowerConfiguration', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PowerConfiguration'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PowerConfiguration', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.batteryInstallTime is not None: - self.batteryInstallTime.export(outfile, level, namespace_, name_='batteryInstallTime', pretty_print=pretty_print) - if self.lowChargeThreshold is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slowChargeThreshold>%s%s' % (namespace_, self.gds_format_integer(self.lowChargeThreshold, input_name='lowChargeThreshold'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='PowerConfiguration'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.batteryInstallTime is not None: - showIndent(outfile, level) - outfile.write('batteryInstallTime=model_.TimeType(\n') - self.batteryInstallTime.exportLiteral(outfile, level, name_='batteryInstallTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.lowChargeThreshold is not None: - showIndent(outfile, level) - outfile.write('lowChargeThreshold=%d,\n' % self.lowChargeThreshold) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'batteryInstallTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.batteryInstallTime = obj_ - obj_.original_tagname_ = 'batteryInstallTime' - elif nodeName_ == 'lowChargeThreshold': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'lowChargeThreshold') - self.lowChargeThreshold = ival_ - self.validate_UInt32(self.lowChargeThreshold) # validate type UInt32 -# end class PowerConfiguration - - -class TimeConfiguration(GeneratedsSuper): - """Contains attributes related to the configuration of the time - service.""" - subclass = None - superclass = None - def __init__(self, dstEndRule=None, dstOffset=None, dstStartRule=None, tzOffset=None): - self.original_tagname_ = None - self.dstEndRule = dstEndRule - self.dstOffset = dstOffset - self.dstStartRule = dstStartRule - self.tzOffset = tzOffset - def factory(*args_, **kwargs_): - if TimeConfiguration.subclass: - return TimeConfiguration.subclass(*args_, **kwargs_) - else: - return TimeConfiguration(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dstEndRule(self): return self.dstEndRule - def set_dstEndRule(self, dstEndRule): self.dstEndRule = dstEndRule - def get_dstOffset(self): return self.dstOffset - def set_dstOffset(self, dstOffset): self.dstOffset = dstOffset - def get_dstStartRule(self): return self.dstStartRule - def set_dstStartRule(self, dstStartRule): self.dstStartRule = dstStartRule - def get_tzOffset(self): return self.tzOffset - def set_tzOffset(self, tzOffset): self.tzOffset = tzOffset - def hasContent_(self): - if ( - self.dstEndRule is not None or - self.dstOffset is not None or - self.dstStartRule is not None or - self.tzOffset is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TimeConfiguration', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TimeConfiguration') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TimeConfiguration', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TimeConfiguration'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='TimeConfiguration', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dstEndRule is not None: - self.dstEndRule.export(outfile, level, namespace_, name_='dstEndRule', pretty_print=pretty_print) - if self.dstOffset is not None: - self.dstOffset.export(outfile, level, namespace_, name_='dstOffset', pretty_print=pretty_print) - if self.dstStartRule is not None: - self.dstStartRule.export(outfile, level, namespace_, name_='dstStartRule', pretty_print=pretty_print) - if self.tzOffset is not None: - self.tzOffset.export(outfile, level, namespace_, name_='tzOffset', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='TimeConfiguration'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dstEndRule is not None: - showIndent(outfile, level) - outfile.write('dstEndRule=model_.DstRuleType(\n') - self.dstEndRule.exportLiteral(outfile, level, name_='dstEndRule') - showIndent(outfile, level) - outfile.write('),\n') - if self.dstOffset is not None: - showIndent(outfile, level) - outfile.write('dstOffset=model_.TimeOffsetType(\n') - self.dstOffset.exportLiteral(outfile, level, name_='dstOffset') - showIndent(outfile, level) - outfile.write('),\n') - if self.dstStartRule is not None: - showIndent(outfile, level) - outfile.write('dstStartRule=model_.DstRuleType(\n') - self.dstStartRule.exportLiteral(outfile, level, name_='dstStartRule') - showIndent(outfile, level) - outfile.write('),\n') - if self.tzOffset is not None: - showIndent(outfile, level) - outfile.write('tzOffset=model_.TimeOffsetType(\n') - self.tzOffset.exportLiteral(outfile, level, name_='tzOffset') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dstEndRule': - obj_ = DstRuleType.factory() - obj_.build(child_) - self.dstEndRule = obj_ - obj_.original_tagname_ = 'dstEndRule' - elif nodeName_ == 'dstOffset': - obj_ = TimeOffsetType.factory() - obj_.build(child_) - self.dstOffset = obj_ - obj_.original_tagname_ = 'dstOffset' - elif nodeName_ == 'dstStartRule': - obj_ = DstRuleType.factory() - obj_.build(child_) - self.dstStartRule = obj_ - obj_.original_tagname_ = 'dstStartRule' - elif nodeName_ == 'tzOffset': - obj_ = TimeOffsetType.factory() - obj_.build(child_) - self.tzOffset = obj_ - obj_.original_tagname_ = 'tzOffset' -# end class TimeConfiguration - - -class ApplianceLoadReduction(GeneratedsSuper): - """The ApplianceLoadReduction object is used by a Demand Response - service provider to provide signals for ENERGY STAR compliant - appliances. See the definition of ApplianceLoadReductionType for - more information.""" - subclass = None - superclass = None - def __init__(self, type_=None): - self.original_tagname_ = None - self.type_ = type_ - def factory(*args_, **kwargs_): - if ApplianceLoadReduction.subclass: - return ApplianceLoadReduction.subclass(*args_, **kwargs_) - else: - return ApplianceLoadReduction(*args_, **kwargs_) - factory = staticmethod(factory) - def get_type(self): return self.type_ - def set_type(self, type_): self.type_ = type_ - def hasContent_(self): - if ( - self.type_ is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ApplianceLoadReduction', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ApplianceLoadReduction') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ApplianceLoadReduction', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ApplianceLoadReduction'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ApplianceLoadReduction', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.type_ is not None: - self.type_.export(outfile, level, namespace_, name_='type', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ApplianceLoadReduction'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.type_ is not None: - showIndent(outfile, level) - outfile.write('type_=model_.ApplianceLoadReductionType(\n') - self.type_.exportLiteral(outfile, level, name_='type') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'type': - obj_ = ApplianceLoadReductionType.factory() - obj_.build(child_) - self.type_ = obj_ - obj_.original_tagname_ = 'type' -# end class ApplianceLoadReduction - - -class DutyCycle(GeneratedsSuper): - """Duty cycle control is a device specific issue and is managed by the - device. The duty cycle of the device under control should span - the shortest practical time period in accordance with the nature - of the device under control and the intent of the request for - demand reduction. The default factory setting SHOULD be three - minutes for each 10% of duty cycle. This indicates that the - default time period over which a duty cycle is applied is 30 - minutes, meaning a 10% duty cycle would cause a device to be ON - for 3 minutes. The “off state” SHALL precede the “on - state”.""" - subclass = None - superclass = None - def __init__(self, normalValue=None): - self.original_tagname_ = None - self.normalValue = normalValue - def factory(*args_, **kwargs_): - if DutyCycle.subclass: - return DutyCycle.subclass(*args_, **kwargs_) - else: - return DutyCycle(*args_, **kwargs_) - factory = staticmethod(factory) - def get_normalValue(self): return self.normalValue - def set_normalValue(self, normalValue): self.normalValue = normalValue - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.normalValue is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DutyCycle', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DutyCycle') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DutyCycle', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DutyCycle'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DutyCycle', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.normalValue is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%snormalValue>%s%s' % (namespace_, self.gds_format_integer(self.normalValue, input_name='normalValue'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='DutyCycle'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.normalValue is not None: - showIndent(outfile, level) - outfile.write('normalValue=%d,\n' % self.normalValue) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'normalValue': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'normalValue') - self.normalValue = ival_ - self.validate_UInt8(self.normalValue) # validate type UInt8 -# end class DutyCycle - - -class Offset(GeneratedsSuper): - """If a temperature offset is sent that causes the heating or cooling - temperature set point to exceed the limit boundaries that are - programmed into the device, the device SHALL respond by setting - the temperature at the limit. If an EDC is being targeted at - multiple devices or to a device that controls multiple devices - (e.g., EMS), it can provide multiple Offset types within one - EDC. For events with multiple Offset types, a client SHALL - select the Offset that best fits their operating function. - Alternatively, an event with a single Offset type can be - targeted at an EMS in order to request a percentage load - reduction on the average energy usage of the entire premise. An - EMS SHOULD use the Metering function set to determine the - initial load in the premise, reduce energy consumption by - controlling devices at its disposal, and at the conclusion of - the event, once again use the Metering function set to determine - if the desired load reduction was achieved.""" - subclass = None - superclass = None - def __init__(self, coolingOffset=None, heatingOffset=None, loadAdjustmentPercentageOffset=None): - self.original_tagname_ = None - self.coolingOffset = coolingOffset - self.heatingOffset = heatingOffset - self.loadAdjustmentPercentageOffset = loadAdjustmentPercentageOffset - def factory(*args_, **kwargs_): - if Offset.subclass: - return Offset.subclass(*args_, **kwargs_) - else: - return Offset(*args_, **kwargs_) - factory = staticmethod(factory) - def get_coolingOffset(self): return self.coolingOffset - def set_coolingOffset(self, coolingOffset): self.coolingOffset = coolingOffset - def get_heatingOffset(self): return self.heatingOffset - def set_heatingOffset(self, heatingOffset): self.heatingOffset = heatingOffset - def get_loadAdjustmentPercentageOffset(self): return self.loadAdjustmentPercentageOffset - def set_loadAdjustmentPercentageOffset(self, loadAdjustmentPercentageOffset): self.loadAdjustmentPercentageOffset = loadAdjustmentPercentageOffset - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.coolingOffset is not None or - self.heatingOffset is not None or - self.loadAdjustmentPercentageOffset is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Offset', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Offset') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Offset', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Offset'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='Offset', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.coolingOffset is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%scoolingOffset>%s%s' % (namespace_, self.gds_format_integer(self.coolingOffset, input_name='coolingOffset'), namespace_, eol_)) - if self.heatingOffset is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sheatingOffset>%s%s' % (namespace_, self.gds_format_integer(self.heatingOffset, input_name='heatingOffset'), namespace_, eol_)) - if self.loadAdjustmentPercentageOffset is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sloadAdjustmentPercentageOffset>%s%s' % (namespace_, self.gds_format_integer(self.loadAdjustmentPercentageOffset, input_name='loadAdjustmentPercentageOffset'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Offset'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.coolingOffset is not None: - showIndent(outfile, level) - outfile.write('coolingOffset=%d,\n' % self.coolingOffset) - if self.heatingOffset is not None: - showIndent(outfile, level) - outfile.write('heatingOffset=%d,\n' % self.heatingOffset) - if self.loadAdjustmentPercentageOffset is not None: - showIndent(outfile, level) - outfile.write('loadAdjustmentPercentageOffset=%d,\n' % self.loadAdjustmentPercentageOffset) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'coolingOffset': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'coolingOffset') - self.coolingOffset = ival_ - self.validate_UInt8(self.coolingOffset) # validate type UInt8 - elif nodeName_ == 'heatingOffset': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'heatingOffset') - self.heatingOffset = ival_ - self.validate_UInt8(self.heatingOffset) # validate type UInt8 - elif nodeName_ == 'loadAdjustmentPercentageOffset': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'loadAdjustmentPercentageOffset') - self.loadAdjustmentPercentageOffset = ival_ - self.validate_UInt8(self.loadAdjustmentPercentageOffset) # validate type UInt8 -# end class Offset - - -class SetPoint(GeneratedsSuper): - """The SetPoint object is used to apply specific temperature set points - to a temperature control device. The values of the - heatingSetpoint and coolingSetpoint attributes SHALL be - calculated as follows: Cooling/Heating Temperature Set Point / - 100 = temperature in degrees Celsius where -273.15°C <= - temperature <= 327.67°C, corresponding to a Cooling and/or - Heating Temperature Set Point. The maximum resolution this - format allows is 0.01°C. The field not present in a Response - indicates that this field has not been used by the end device. - If a temperature is sent that exceeds the temperature limit - boundaries that are programmed into the device, the device SHALL - respond by setting the temperature at the limit.""" - subclass = None - superclass = None - def __init__(self, coolingSetpoint=None, heatingSetpoint=None): - self.original_tagname_ = None - self.coolingSetpoint = coolingSetpoint - self.heatingSetpoint = heatingSetpoint - def factory(*args_, **kwargs_): - if SetPoint.subclass: - return SetPoint.subclass(*args_, **kwargs_) - else: - return SetPoint(*args_, **kwargs_) - factory = staticmethod(factory) - def get_coolingSetpoint(self): return self.coolingSetpoint - def set_coolingSetpoint(self, coolingSetpoint): self.coolingSetpoint = coolingSetpoint - def get_heatingSetpoint(self): return self.heatingSetpoint - def set_heatingSetpoint(self, heatingSetpoint): self.heatingSetpoint = heatingSetpoint - def validate_Int16(self, value): - # Validate type Int16, a restriction on xs:short. - pass - def hasContent_(self): - if ( - self.coolingSetpoint is not None or - self.heatingSetpoint is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SetPoint', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SetPoint') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SetPoint', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SetPoint'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='SetPoint', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.coolingSetpoint is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%scoolingSetpoint>%s%s' % (namespace_, self.gds_format_integer(self.coolingSetpoint, input_name='coolingSetpoint'), namespace_, eol_)) - if self.heatingSetpoint is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sheatingSetpoint>%s%s' % (namespace_, self.gds_format_integer(self.heatingSetpoint, input_name='heatingSetpoint'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='SetPoint'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.coolingSetpoint is not None: - showIndent(outfile, level) - outfile.write('coolingSetpoint=%d,\n' % self.coolingSetpoint) - if self.heatingSetpoint is not None: - showIndent(outfile, level) - outfile.write('heatingSetpoint=%d,\n' % self.heatingSetpoint) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'coolingSetpoint': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'coolingSetpoint') - self.coolingSetpoint = ival_ - self.validate_Int16(self.coolingSetpoint) # validate type Int16 - elif nodeName_ == 'heatingSetpoint': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'heatingSetpoint') - self.heatingSetpoint = ival_ - self.validate_Int16(self.heatingSetpoint) # validate type Int16 -# end class SetPoint - - -class TargetReduction(GeneratedsSuper): - """The TargetReduction object is used by a Demand Response service - provider to provide a RECOMMENDED threshold that a - device/premises should maintain its consumption below. For - example, a service provider can provide a RECOMMENDED threshold - of some kWh for a 3-hour event. This means that the - device/premises would maintain its consumption below the - specified limit for the specified period.""" - subclass = None - superclass = None - def __init__(self, type_=None, value=None): - self.original_tagname_ = None - self.type_ = type_ - self.value = value - def factory(*args_, **kwargs_): - if TargetReduction.subclass: - return TargetReduction.subclass(*args_, **kwargs_) - else: - return TargetReduction(*args_, **kwargs_) - factory = staticmethod(factory) - def get_type(self): return self.type_ - def set_type(self, type_): self.type_ = type_ - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.type_ is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TargetReduction', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TargetReduction') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TargetReduction', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TargetReduction'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='TargetReduction', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.type_ is not None: - self.type_.export(outfile, level, namespace_, name_='type', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='TargetReduction'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.type_ is not None: - showIndent(outfile, level) - outfile.write('type_=model_.UnitType(\n') - self.type_.exportLiteral(outfile, level, name_='type') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'type': - obj_ = UnitType.factory() - obj_.build(child_) - self.type_ = obj_ - obj_.original_tagname_ = 'type' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt16(self.value) # validate type UInt16 -# end class TargetReduction - - -class CostKindType(GeneratedsSuper): - """0 - Carbon Dioxide emissions, in grams per unit 1 - Sulfur Dioxide - emissions, in grams per unit 2 - Nitrogen Oxides emissions, in - grams per unit 3 - Renewable generation, as a percentage of - overall generation All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if CostKindType.subclass: - return CostKindType.subclass(*args_, **kwargs_) - else: - return CostKindType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CostKindType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CostKindType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='CostKindType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CostKindType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CostKindType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='CostKindType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class CostKindType - - -class EnvironmentalCost(GeneratedsSuper): - """Provides alternative or secondary price information for the relevant - RateComponent. Supports jurisdictions that seek to convey the - environmental price per unit of the specified commodity not - expressed in currency. Implementers and consumers can use this - attribute to prioritize operations of their HAN devices (e.g., - PEV charging during times of high availability of renewable - electricity resources).""" - subclass = None - superclass = None - def __init__(self, amount=None, costKind=None, costLevel=None, numCostLevels=None): - self.original_tagname_ = None - self.amount = amount - self.costKind = costKind - self.costLevel = costLevel - self.numCostLevels = numCostLevels - def factory(*args_, **kwargs_): - if EnvironmentalCost.subclass: - return EnvironmentalCost.subclass(*args_, **kwargs_) - else: - return EnvironmentalCost(*args_, **kwargs_) - factory = staticmethod(factory) - def get_amount(self): return self.amount - def set_amount(self, amount): self.amount = amount - def get_costKind(self): return self.costKind - def set_costKind(self, costKind): self.costKind = costKind - def get_costLevel(self): return self.costLevel - def set_costLevel(self, costLevel): self.costLevel = costLevel - def get_numCostLevels(self): return self.numCostLevels - def set_numCostLevels(self, numCostLevels): self.numCostLevels = numCostLevels - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.amount is not None or - self.costKind is not None or - self.costLevel is not None or - self.numCostLevels is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EnvironmentalCost', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EnvironmentalCost') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EnvironmentalCost', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EnvironmentalCost'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='EnvironmentalCost', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.amount is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%samount>%s%s' % (namespace_, self.gds_format_integer(self.amount, input_name='amount'), namespace_, eol_)) - if self.costKind is not None: - self.costKind.export(outfile, level, namespace_, name_='costKind', pretty_print=pretty_print) - if self.costLevel is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%scostLevel>%s%s' % (namespace_, self.gds_format_integer(self.costLevel, input_name='costLevel'), namespace_, eol_)) - if self.numCostLevels is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%snumCostLevels>%s%s' % (namespace_, self.gds_format_integer(self.numCostLevels, input_name='numCostLevels'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='EnvironmentalCost'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.amount is not None: - showIndent(outfile, level) - outfile.write('amount=%d,\n' % self.amount) - if self.costKind is not None: - showIndent(outfile, level) - outfile.write('costKind=model_.CostKindType(\n') - self.costKind.exportLiteral(outfile, level, name_='costKind') - showIndent(outfile, level) - outfile.write('),\n') - if self.costLevel is not None: - showIndent(outfile, level) - outfile.write('costLevel=%d,\n' % self.costLevel) - if self.numCostLevels is not None: - showIndent(outfile, level) - outfile.write('numCostLevels=%d,\n' % self.numCostLevels) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'amount': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'amount') - self.amount = ival_ - self.validate_UInt32(self.amount) # validate type UInt32 - elif nodeName_ == 'costKind': - obj_ = CostKindType.factory() - obj_.build(child_) - self.costKind = obj_ - obj_.original_tagname_ = 'costKind' - elif nodeName_ == 'costLevel': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'costLevel') - self.costLevel = ival_ - self.validate_UInt8(self.costLevel) # validate type UInt8 - elif nodeName_ == 'numCostLevels': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'numCostLevels') - self.numCostLevels = ival_ - self.validate_UInt8(self.numCostLevels) # validate type UInt8 -# end class EnvironmentalCost - - -class PriorityType(GeneratedsSuper): - """Indicates the priority of a message: 0 - Low 1 - Normal 2 - High 3 - - Critical All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PriorityType.subclass: - return PriorityType.subclass(*args_, **kwargs_) - else: - return PriorityType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PriorityType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PriorityType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PriorityType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PriorityType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PriorityType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PriorityType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PriorityType - - -class Charge(GeneratedsSuper): - """Charges contain charges on a customer bill. These could be items - like taxes, levies, surcharges, rebates, or others. This is - meant to allow the HAN device to retrieve enough information to - be able to reconstruct an estimate of what the total bill would - look like. Providers can provide line item billing, including - multiple charge kinds (e.g. taxes, surcharges) at whatever - granularity desired, using as many Charges as desired during a - billing period. There can also be any number of Charges - associated with different ReadingTypes to distinguish between - TOU tiers, consumption blocks, or demand charges.""" - subclass = None - superclass = None - def __init__(self, description=None, kind=None, value=None): - self.original_tagname_ = None - self.description = description - self.kind = kind - self.value = value - def factory(*args_, **kwargs_): - if Charge.subclass: - return Charge.subclass(*args_, **kwargs_) - else: - return Charge(*args_, **kwargs_) - factory = staticmethod(factory) - def get_description(self): return self.description - def set_description(self, description): self.description = description - def get_kind(self): return self.kind - def set_kind(self, kind): self.kind = kind - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_String20(self, value): - # Validate type String20, a restriction on xs:string. - pass - def validate_Int32(self, value): - # Validate type Int32, a restriction on xs:int. - pass - def hasContent_(self): - if ( - self.description is not None or - self.kind is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Charge', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Charge') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Charge', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Charge'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='Charge', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.description is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdescription>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.description).encode(ExternalEncoding), input_name='description'), namespace_, eol_)) - if self.kind is not None: - self.kind.export(outfile, level, namespace_, name_='kind', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Charge'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.description is not None: - showIndent(outfile, level) - outfile.write('description=%s,\n' % quote_python(self.description).encode(ExternalEncoding)) - if self.kind is not None: - showIndent(outfile, level) - outfile.write('kind=model_.ChargeKind(\n') - self.kind.exportLiteral(outfile, level, name_='kind') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'description': - description_ = child_.text - description_ = self.gds_validate_string(description_, node, 'description') - self.description = description_ - self.validate_String20(self.description) # validate type String20 - elif nodeName_ == 'kind': - obj_ = ChargeKind.factory() - obj_.build(child_) - self.kind = obj_ - obj_.original_tagname_ = 'kind' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int32(self.value) # validate type Int32 -# end class Charge - - -class ChargeKind(GeneratedsSuper): - """Kind of charge. 0 - Consumption Charge 1 - Rebate 2 - Auxiliary - Charge 3 - Demand Charge 4 - Tax Charge""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if ChargeKind.subclass: - return ChargeKind.subclass(*args_, **kwargs_) - else: - return ChargeKind(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ChargeKind', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ChargeKind') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='ChargeKind', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ChargeKind'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ChargeKind', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='ChargeKind'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class ChargeKind - - -class AccountingUnit(GeneratedsSuper): - """Unit for accounting; use either 'energyUnit' or 'currencyUnit' to - specify the unit for 'value'.""" - subclass = None - superclass = None - def __init__(self, energyUnit=None, monetaryUnit=None, multiplier=None, value=None): - self.original_tagname_ = None - self.energyUnit = energyUnit - self.monetaryUnit = monetaryUnit - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if AccountingUnit.subclass: - return AccountingUnit.subclass(*args_, **kwargs_) - else: - return AccountingUnit(*args_, **kwargs_) - factory = staticmethod(factory) - def get_energyUnit(self): return self.energyUnit - def set_energyUnit(self, energyUnit): self.energyUnit = energyUnit - def get_monetaryUnit(self): return self.monetaryUnit - def set_monetaryUnit(self, monetaryUnit): self.monetaryUnit = monetaryUnit - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_Int32(self, value): - # Validate type Int32, a restriction on xs:int. - pass - def hasContent_(self): - if ( - self.energyUnit is not None or - self.monetaryUnit is not None or - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AccountingUnit', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AccountingUnit') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AccountingUnit', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AccountingUnit'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='AccountingUnit', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.energyUnit is not None: - self.energyUnit.export(outfile, level, namespace_, name_='energyUnit', pretty_print=pretty_print) - if self.monetaryUnit is not None: - self.monetaryUnit.export(outfile, level, namespace_, name_='monetaryUnit', pretty_print=pretty_print) - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='AccountingUnit'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.energyUnit is not None: - showIndent(outfile, level) - outfile.write('energyUnit=model_.RealEnergy(\n') - self.energyUnit.exportLiteral(outfile, level, name_='energyUnit') - showIndent(outfile, level) - outfile.write('),\n') - if self.monetaryUnit is not None: - showIndent(outfile, level) - outfile.write('monetaryUnit=model_.CurrencyCode(\n') - self.monetaryUnit.exportLiteral(outfile, level, name_='monetaryUnit') - showIndent(outfile, level) - outfile.write('),\n') - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'energyUnit': - obj_ = RealEnergy.factory() - obj_.build(child_) - self.energyUnit = obj_ - obj_.original_tagname_ = 'energyUnit' - elif nodeName_ == 'monetaryUnit': - obj_ = CurrencyCode.factory() - obj_.build(child_) - self.monetaryUnit = obj_ - obj_.original_tagname_ = 'monetaryUnit' - elif nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int32(self.value) # validate type Int32 -# end class AccountingUnit - - -class PrepayModeType(GeneratedsSuper): - """0 - Central Wallet 1 - ESI 2 - Local 3 - Credit All other values - reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PrepayModeType.subclass: - return PrepayModeType.subclass(*args_, **kwargs_) - else: - return PrepayModeType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PrepayModeType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PrepayModeType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PrepayModeType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PrepayModeType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PrepayModeType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PrepayModeType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PrepayModeType - - -class ServiceChange(GeneratedsSuper): - """Specifies a change to the service status.""" - subclass = None - superclass = None - def __init__(self, newStatus=None, startTime=None): - self.original_tagname_ = None - self.newStatus = newStatus - self.startTime = startTime - def factory(*args_, **kwargs_): - if ServiceChange.subclass: - return ServiceChange.subclass(*args_, **kwargs_) - else: - return ServiceChange(*args_, **kwargs_) - factory = staticmethod(factory) - def get_newStatus(self): return self.newStatus - def set_newStatus(self, newStatus): self.newStatus = newStatus - def get_startTime(self): return self.startTime - def set_startTime(self, startTime): self.startTime = startTime - def hasContent_(self): - if ( - self.newStatus is not None or - self.startTime is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ServiceChange', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceChange') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ServiceChange', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ServiceChange'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ServiceChange', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.newStatus is not None: - self.newStatus.export(outfile, level, namespace_, name_='newStatus', pretty_print=pretty_print) - if self.startTime is not None: - self.startTime.export(outfile, level, namespace_, name_='startTime', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ServiceChange'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.newStatus is not None: - showIndent(outfile, level) - outfile.write('newStatus=model_.ServiceStatusType(\n') - self.newStatus.exportLiteral(outfile, level, name_='newStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.startTime is not None: - showIndent(outfile, level) - outfile.write('startTime=model_.TimeType(\n') - self.startTime.exportLiteral(outfile, level, name_='startTime') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'newStatus': - obj_ = ServiceStatusType.factory() - obj_.build(child_) - self.newStatus = obj_ - obj_.original_tagname_ = 'newStatus' - elif nodeName_ == 'startTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.startTime = obj_ - obj_.original_tagname_ = 'startTime' -# end class ServiceChange - - -class CreditStatusType(GeneratedsSuper): - """0 - Credit Ok 1 - Credit Low 2 - Credit Exhausted 3 - Credit - Negative All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if CreditStatusType.subclass: - return CreditStatusType.subclass(*args_, **kwargs_) - else: - return CreditStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CreditStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CreditStatusType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='CreditStatusType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CreditStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CreditStatusType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='CreditStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class CreditStatusType - - -class CreditTypeType(GeneratedsSuper): - """0 - Regular 1 - Emergency 2 - Regular, then Emergency 3 - Emergency, - then Regular All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if CreditTypeType.subclass: - return CreditTypeType.subclass(*args_, **kwargs_) - else: - return CreditTypeType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CreditTypeType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CreditTypeType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='CreditTypeType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CreditTypeType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CreditTypeType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='CreditTypeType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class CreditTypeType - - -class CreditTypeChange(GeneratedsSuper): - """Specifies a change to the credit type.""" - subclass = None - superclass = None - def __init__(self, newType=None, startTime=None): - self.original_tagname_ = None - self.newType = newType - self.startTime = startTime - def factory(*args_, **kwargs_): - if CreditTypeChange.subclass: - return CreditTypeChange.subclass(*args_, **kwargs_) - else: - return CreditTypeChange(*args_, **kwargs_) - factory = staticmethod(factory) - def get_newType(self): return self.newType - def set_newType(self, newType): self.newType = newType - def get_startTime(self): return self.startTime - def set_startTime(self, startTime): self.startTime = startTime - def hasContent_(self): - if ( - self.newType is not None or - self.startTime is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CreditTypeChange', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CreditTypeChange') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CreditTypeChange', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CreditTypeChange'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CreditTypeChange', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.newType is not None: - self.newType.export(outfile, level, namespace_, name_='newType', pretty_print=pretty_print) - if self.startTime is not None: - self.startTime.export(outfile, level, namespace_, name_='startTime', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='CreditTypeChange'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.newType is not None: - showIndent(outfile, level) - outfile.write('newType=model_.CreditTypeType(\n') - self.newType.exportLiteral(outfile, level, name_='newType') - showIndent(outfile, level) - outfile.write('),\n') - if self.startTime is not None: - showIndent(outfile, level) - outfile.write('startTime=model_.TimeType(\n') - self.startTime.exportLiteral(outfile, level, name_='startTime') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'newType': - obj_ = CreditTypeType.factory() - obj_.build(child_) - self.newType = obj_ - obj_.original_tagname_ = 'newType' - elif nodeName_ == 'startTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.startTime = obj_ - obj_.original_tagname_ = 'startTime' -# end class CreditTypeChange - - -class ServiceStatusType(GeneratedsSuper): - """0 - Connected 1 - Disconnected 2 - Armed for Connect 3 - Armed for - Disconnect 4 - No Contactor 5 - Load Limited All other values - reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if ServiceStatusType.subclass: - return ServiceStatusType.subclass(*args_, **kwargs_) - else: - return ServiceStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ServiceStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceStatusType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='ServiceStatusType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ServiceStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ServiceStatusType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='ServiceStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class ServiceStatusType - - -class RequestStatus(GeneratedsSuper): - """The RequestStatus object is used to indicate the current status of a - Flow Reservation Request.""" - subclass = None - superclass = None - def __init__(self, dateTime=None, requestStatus=None): - self.original_tagname_ = None - self.dateTime = dateTime - self.requestStatus = requestStatus - def factory(*args_, **kwargs_): - if RequestStatus.subclass: - return RequestStatus.subclass(*args_, **kwargs_) - else: - return RequestStatus(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_requestStatus(self): return self.requestStatus - def set_requestStatus(self, requestStatus): self.requestStatus = requestStatus - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.dateTime is not None or - self.requestStatus is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RequestStatus', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RequestStatus') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RequestStatus', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RequestStatus'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='RequestStatus', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.requestStatus is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srequestStatus>%s%s' % (namespace_, self.gds_format_integer(self.requestStatus, input_name='requestStatus'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='RequestStatus'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.requestStatus is not None: - showIndent(outfile, level) - outfile.write('requestStatus=%d,\n' % self.requestStatus) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'requestStatus': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'requestStatus') - self.requestStatus = ival_ - self.validate_UInt8(self.requestStatus) # validate type UInt8 -# end class RequestStatus - - -class DERType(GeneratedsSuper): - """0 - Not applicable / Unknown 1 - Virtual or mixed DER 2 - - Reciprocating engine 3 - Fuel cell 4 - Photovoltaic system 5 - - Combined heat and power 80 - Storage (immobile) 81 - Electric - vehicle / EVSE 82 - Combined PV and storage All other values - reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if DERType.subclass: - return DERType.subclass(*args_, **kwargs_) - else: - return DERType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DERType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='DERType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class DERType - - -class DERControlBase(GeneratedsSuper): - """Distributed Energy Resource (DER) control values.""" - subclass = None - superclass = None - def __init__(self, opModFixedFlow=None, opModFixedPF=None, opModFixedVAr=None, opModFixedW=None, opModFreqWatt=None, opModHVRT=None, opModLVRT=None, opModVoltVAr=None, opModVoltWatt=None, opModWattPF=None, rampTms=None): - self.original_tagname_ = None - self.opModFixedFlow = opModFixedFlow - self.opModFixedPF = opModFixedPF - self.opModFixedVAr = opModFixedVAr - self.opModFixedW = opModFixedW - self.opModFreqWatt = opModFreqWatt - self.opModHVRT = opModHVRT - self.opModLVRT = opModLVRT - self.opModVoltVAr = opModVoltVAr - self.opModVoltWatt = opModVoltWatt - self.opModWattPF = opModWattPF - self.rampTms = rampTms - def factory(*args_, **kwargs_): - if DERControlBase.subclass: - return DERControlBase.subclass(*args_, **kwargs_) - else: - return DERControlBase(*args_, **kwargs_) - factory = staticmethod(factory) - def get_opModFixedFlow(self): return self.opModFixedFlow - def set_opModFixedFlow(self, opModFixedFlow): self.opModFixedFlow = opModFixedFlow - def get_opModFixedPF(self): return self.opModFixedPF - def set_opModFixedPF(self, opModFixedPF): self.opModFixedPF = opModFixedPF - def get_opModFixedVAr(self): return self.opModFixedVAr - def set_opModFixedVAr(self, opModFixedVAr): self.opModFixedVAr = opModFixedVAr - def get_opModFixedW(self): return self.opModFixedW - def set_opModFixedW(self, opModFixedW): self.opModFixedW = opModFixedW - def get_opModFreqWatt(self): return self.opModFreqWatt - def set_opModFreqWatt(self, opModFreqWatt): self.opModFreqWatt = opModFreqWatt - def get_opModHVRT(self): return self.opModHVRT - def set_opModHVRT(self, opModHVRT): self.opModHVRT = opModHVRT - def get_opModLVRT(self): return self.opModLVRT - def set_opModLVRT(self, opModLVRT): self.opModLVRT = opModLVRT - def get_opModVoltVAr(self): return self.opModVoltVAr - def set_opModVoltVAr(self, opModVoltVAr): self.opModVoltVAr = opModVoltVAr - def get_opModVoltWatt(self): return self.opModVoltWatt - def set_opModVoltWatt(self, opModVoltWatt): self.opModVoltWatt = opModVoltWatt - def get_opModWattPF(self): return self.opModWattPF - def set_opModWattPF(self, opModWattPF): self.opModWattPF = opModWattPF - def get_rampTms(self): return self.rampTms - def set_rampTms(self, rampTms): self.rampTms = rampTms - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.opModFixedFlow is not None or - self.opModFixedPF is not None or - self.opModFixedVAr is not None or - self.opModFixedW is not None or - self.opModFreqWatt is not None or - self.opModHVRT is not None or - self.opModLVRT is not None or - self.opModVoltVAr is not None or - self.opModVoltWatt is not None or - self.opModWattPF is not None or - self.rampTms is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERControlBase', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERControlBase') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERControlBase', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERControlBase'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DERControlBase', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.opModFixedFlow is not None: - self.opModFixedFlow.export(outfile, level, namespace_, name_='opModFixedFlow', pretty_print=pretty_print) - if self.opModFixedPF is not None: - self.opModFixedPF.export(outfile, level, namespace_, name_='opModFixedPF', pretty_print=pretty_print) - if self.opModFixedVAr is not None: - self.opModFixedVAr.export(outfile, level, namespace_, name_='opModFixedVAr', pretty_print=pretty_print) - if self.opModFixedW is not None: - self.opModFixedW.export(outfile, level, namespace_, name_='opModFixedW', pretty_print=pretty_print) - if self.opModFreqWatt is not None: - self.opModFreqWatt.export(outfile, level, namespace_, name_='opModFreqWatt', pretty_print=pretty_print) - if self.opModHVRT is not None: - self.opModHVRT.export(outfile, level, namespace_, name_='opModHVRT', pretty_print=pretty_print) - if self.opModLVRT is not None: - self.opModLVRT.export(outfile, level, namespace_, name_='opModLVRT', pretty_print=pretty_print) - if self.opModVoltVAr is not None: - self.opModVoltVAr.export(outfile, level, namespace_, name_='opModVoltVAr', pretty_print=pretty_print) - if self.opModVoltWatt is not None: - self.opModVoltWatt.export(outfile, level, namespace_, name_='opModVoltWatt', pretty_print=pretty_print) - if self.opModWattPF is not None: - self.opModWattPF.export(outfile, level, namespace_, name_='opModWattPF', pretty_print=pretty_print) - if self.rampTms is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srampTms>%s%s' % (namespace_, self.gds_format_integer(self.rampTms, input_name='rampTms'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='DERControlBase'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.opModFixedFlow is not None: - showIndent(outfile, level) - outfile.write('opModFixedFlow=model_.SignedPerCent(\n') - self.opModFixedFlow.exportLiteral(outfile, level, name_='opModFixedFlow') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModFixedPF is not None: - showIndent(outfile, level) - outfile.write('opModFixedPF=model_.FixedPowerFactor(\n') - self.opModFixedPF.exportLiteral(outfile, level, name_='opModFixedPF') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModFixedVAr is not None: - showIndent(outfile, level) - outfile.write('opModFixedVAr=model_.FixedVAr(\n') - self.opModFixedVAr.exportLiteral(outfile, level, name_='opModFixedVAr') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModFixedW is not None: - showIndent(outfile, level) - outfile.write('opModFixedW=model_.PerCent(\n') - self.opModFixedW.exportLiteral(outfile, level, name_='opModFixedW') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModFreqWatt is not None: - showIndent(outfile, level) - outfile.write('opModFreqWatt=model_.DERCurveLink(\n') - self.opModFreqWatt.exportLiteral(outfile, level, name_='opModFreqWatt') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModHVRT is not None: - showIndent(outfile, level) - outfile.write('opModHVRT=model_.CurvePairType(\n') - self.opModHVRT.exportLiteral(outfile, level, name_='opModHVRT') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModLVRT is not None: - showIndent(outfile, level) - outfile.write('opModLVRT=model_.CurvePairType(\n') - self.opModLVRT.exportLiteral(outfile, level, name_='opModLVRT') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModVoltVAr is not None: - showIndent(outfile, level) - outfile.write('opModVoltVAr=model_.DERCurveLink(\n') - self.opModVoltVAr.exportLiteral(outfile, level, name_='opModVoltVAr') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModVoltWatt is not None: - showIndent(outfile, level) - outfile.write('opModVoltWatt=model_.DERCurveLink(\n') - self.opModVoltWatt.exportLiteral(outfile, level, name_='opModVoltWatt') - showIndent(outfile, level) - outfile.write('),\n') - if self.opModWattPF is not None: - showIndent(outfile, level) - outfile.write('opModWattPF=model_.DERCurveLink(\n') - self.opModWattPF.exportLiteral(outfile, level, name_='opModWattPF') - showIndent(outfile, level) - outfile.write('),\n') - if self.rampTms is not None: - showIndent(outfile, level) - outfile.write('rampTms=%d,\n' % self.rampTms) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'opModFixedFlow': - obj_ = SignedPerCent.factory() - obj_.build(child_) - self.opModFixedFlow = obj_ - obj_.original_tagname_ = 'opModFixedFlow' - elif nodeName_ == 'opModFixedPF': - obj_ = FixedPowerFactor.factory() - obj_.build(child_) - self.opModFixedPF = obj_ - obj_.original_tagname_ = 'opModFixedPF' - elif nodeName_ == 'opModFixedVAr': - obj_ = FixedVAr.factory() - obj_.build(child_) - self.opModFixedVAr = obj_ - obj_.original_tagname_ = 'opModFixedVAr' - elif nodeName_ == 'opModFixedW': - obj_ = PerCent.factory() - obj_.build(child_) - self.opModFixedW = obj_ - obj_.original_tagname_ = 'opModFixedW' - elif nodeName_ == 'opModFreqWatt': - obj_ = DERCurveLink.factory() - obj_.build(child_) - self.opModFreqWatt = obj_ - obj_.original_tagname_ = 'opModFreqWatt' - elif nodeName_ == 'opModHVRT': - obj_ = CurvePairType.factory() - obj_.build(child_) - self.opModHVRT = obj_ - obj_.original_tagname_ = 'opModHVRT' - elif nodeName_ == 'opModLVRT': - obj_ = CurvePairType.factory() - obj_.build(child_) - self.opModLVRT = obj_ - obj_.original_tagname_ = 'opModLVRT' - elif nodeName_ == 'opModVoltVAr': - obj_ = DERCurveLink.factory() - obj_.build(child_) - self.opModVoltVAr = obj_ - obj_.original_tagname_ = 'opModVoltVAr' - elif nodeName_ == 'opModVoltWatt': - obj_ = DERCurveLink.factory() - obj_.build(child_) - self.opModVoltWatt = obj_ - obj_.original_tagname_ = 'opModVoltWatt' - elif nodeName_ == 'opModWattPF': - obj_ = DERCurveLink.factory() - obj_.build(child_) - self.opModWattPF = obj_ - obj_.original_tagname_ = 'opModWattPF' - elif nodeName_ == 'rampTms': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'rampTms') - self.rampTms = ival_ - self.validate_UInt16(self.rampTms) # validate type UInt16 -# end class DERControlBase - - -class DERControlType(GeneratedsSuper): - """Control modes supported by the DER. Bit positions SHALL be defined - as follows: 0 - Volt-VAr Mode 1 - Frequency-Watt Mode 2 - Watt- - PowerFactor Mode 3 - Volt-Watt Mode 4 - Low Voltage Ride Through - Mode 5 - High Voltage Ride Through Mode 6-9 - reserved 10 - - setGenConnect 11 - setStorConnect 12 - Fixed W 13 - Fixed VAr 14 - - Fixed PF 15 - Charge mode 16 - Discharge mode All other values - reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if DERControlType.subclass: - return DERControlType.subclass(*args_, **kwargs_) - else: - return DERControlType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERControlType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERControlType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERControlType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERControlType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DERControlType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='DERControlType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class DERControlType - - -class CurveData(GeneratedsSuper): - """Data point values for defining a curve or schedule""" - subclass = None - superclass = None - def __init__(self, excitation=None, xvalue=None, yvalue=None): - self.original_tagname_ = None - self.excitation = excitation - self.xvalue = xvalue - self.yvalue = yvalue - def factory(*args_, **kwargs_): - if CurveData.subclass: - return CurveData.subclass(*args_, **kwargs_) - else: - return CurveData(*args_, **kwargs_) - factory = staticmethod(factory) - def get_excitation(self): return self.excitation - def set_excitation(self, excitation): self.excitation = excitation - def get_xvalue(self): return self.xvalue - def set_xvalue(self, xvalue): self.xvalue = xvalue - def get_yvalue(self): return self.yvalue - def set_yvalue(self, yvalue): self.yvalue = yvalue - def validate_Int8(self, value): - # Validate type Int8, a restriction on xs:byte. - pass - def validate_Int32(self, value): - # Validate type Int32, a restriction on xs:int. - pass - def hasContent_(self): - if ( - self.excitation is not None or - self.xvalue is not None or - self.yvalue is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CurveData', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CurveData') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CurveData', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CurveData'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CurveData', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.excitation is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sexcitation>%s%s' % (namespace_, self.gds_format_integer(self.excitation, input_name='excitation'), namespace_, eol_)) - if self.xvalue is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sxvalue>%s%s' % (namespace_, self.gds_format_integer(self.xvalue, input_name='xvalue'), namespace_, eol_)) - if self.yvalue is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%syvalue>%s%s' % (namespace_, self.gds_format_integer(self.yvalue, input_name='yvalue'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='CurveData'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.excitation is not None: - showIndent(outfile, level) - outfile.write('excitation=%d,\n' % self.excitation) - if self.xvalue is not None: - showIndent(outfile, level) - outfile.write('xvalue=%d,\n' % self.xvalue) - if self.yvalue is not None: - showIndent(outfile, level) - outfile.write('yvalue=%d,\n' % self.yvalue) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'excitation': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'excitation') - self.excitation = ival_ - self.validate_Int8(self.excitation) # validate type Int8 - elif nodeName_ == 'xvalue': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'xvalue') - self.xvalue = ival_ - self.validate_Int32(self.xvalue) # validate type Int32 - elif nodeName_ == 'yvalue': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'yvalue') - self.yvalue = ival_ - self.validate_Int32(self.yvalue) # validate type Int32 -# end class CurveData - - -class DERCurveType(GeneratedsSuper): - """0 - Volt-VAr Mode 1 - Frequency-Watt Curve Mode 2 - Watt-PowerFactor - Mode 3 - Volt-Watt Mode 4 - Low Voltage Ride Through Mode 5 - - High Voltage Ride Through Mode All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if DERCurveType.subclass: - return DERCurveType.subclass(*args_, **kwargs_) - else: - return DERCurveType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERCurveType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurveType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERCurveType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERCurveType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DERCurveType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='DERCurveType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class DERCurveType - - -class CurvePairType(GeneratedsSuper): - """Specifies a pair of DERCurves.""" - subclass = None - superclass = None - def __init__(self, lowerLimit=None, upperLimit=None): - self.original_tagname_ = None - self.lowerLimit = lowerLimit - self.upperLimit = upperLimit - def factory(*args_, **kwargs_): - if CurvePairType.subclass: - return CurvePairType.subclass(*args_, **kwargs_) - else: - return CurvePairType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_lowerLimit(self): return self.lowerLimit - def set_lowerLimit(self, lowerLimit): self.lowerLimit = lowerLimit - def get_upperLimit(self): return self.upperLimit - def set_upperLimit(self, upperLimit): self.upperLimit = upperLimit - def hasContent_(self): - if ( - self.lowerLimit is not None or - self.upperLimit is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CurvePairType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CurvePairType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CurvePairType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CurvePairType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CurvePairType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.lowerLimit is not None: - self.lowerLimit.export(outfile, level, namespace_, name_='lowerLimit', pretty_print=pretty_print) - if self.upperLimit is not None: - self.upperLimit.export(outfile, level, namespace_, name_='upperLimit', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='CurvePairType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.lowerLimit is not None: - showIndent(outfile, level) - outfile.write('lowerLimit=model_.DERCurveLink(\n') - self.lowerLimit.exportLiteral(outfile, level, name_='lowerLimit') - showIndent(outfile, level) - outfile.write('),\n') - if self.upperLimit is not None: - showIndent(outfile, level) - outfile.write('upperLimit=model_.DERCurveLink(\n') - self.upperLimit.exportLiteral(outfile, level, name_='upperLimit') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'lowerLimit': - obj_ = DERCurveLink.factory() - obj_.build(child_) - self.lowerLimit = obj_ - obj_.original_tagname_ = 'lowerLimit' - elif nodeName_ == 'upperLimit': - obj_ = DERCurveLink.factory() - obj_.build(child_) - self.upperLimit = obj_ - obj_.original_tagname_ = 'upperLimit' -# end class CurvePairType - - -class DERUnitRefType(GeneratedsSuper): - """Specifies context for interpreting percent values: 0 - N/A 1 - - %setMaxW 2 - %setMaxVAr 3 - %statVArAvail 4 - %setEffectiveV 5 - - %setMaxChargeRate 6 - %setMaxDischargeRate All other values - reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if DERUnitRefType.subclass: - return DERUnitRefType.subclass(*args_, **kwargs_) - else: - return DERUnitRefType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERUnitRefType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERUnitRefType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERUnitRefType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERUnitRefType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DERUnitRefType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='DERUnitRefType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class DERUnitRefType - - -class CurrentRMS(GeneratedsSuper): - """Average flow of charge through a conductor.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if CurrentRMS.subclass: - return CurrentRMS.subclass(*args_, **kwargs_) - else: - return CurrentRMS(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CurrentRMS', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CurrentRMS') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CurrentRMS', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CurrentRMS'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CurrentRMS', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='CurrentRMS'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt16(self.value) # validate type UInt16 -# end class CurrentRMS - - -class FixedPointType(GeneratedsSuper): - """Abstract type for specifying a fixed-point value without a given - unit of measure.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if FixedPointType.subclass: - return FixedPointType.subclass(*args_, **kwargs_) - else: - return FixedPointType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_Int16(self, value): - # Validate type Int16, a restriction on xs:short. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FixedPointType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FixedPointType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FixedPointType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FixedPointType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='FixedPointType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='FixedPointType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int16(self.value) # validate type Int16 -# end class FixedPointType - - -class UnsignedFixedPointType(GeneratedsSuper): - """Abstract type for specifying an unsigned fixed-point value without a - given unit of measure.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if UnsignedFixedPointType.subclass: - return UnsignedFixedPointType.subclass(*args_, **kwargs_) - else: - return UnsignedFixedPointType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UnsignedFixedPointType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UnsignedFixedPointType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='UnsignedFixedPointType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UnsignedFixedPointType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='UnsignedFixedPointType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='UnsignedFixedPointType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt16(self.value) # validate type UInt16 -# end class UnsignedFixedPointType - - -class ActivePower(GeneratedsSuper): - """The active (real) power P (in W) is the product of root-mean-square - (RMS) voltage, RMS current, and cos(theta) where theta is the - phase angle of current relative to voltage. It is the primary - measure of the rate of flow of energy.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if ActivePower.subclass: - return ActivePower.subclass(*args_, **kwargs_) - else: - return ActivePower(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_Int16(self, value): - # Validate type Int16, a restriction on xs:short. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActivePower', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActivePower') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActivePower', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActivePower'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ActivePower', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='ActivePower'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int16(self.value) # validate type Int16 -# end class ActivePower - - -class AmpereHour(GeneratedsSuper): - """Available electric charge""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if AmpereHour.subclass: - return AmpereHour.subclass(*args_, **kwargs_) - else: - return AmpereHour(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AmpereHour', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AmpereHour') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AmpereHour', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AmpereHour'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='AmpereHour', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='AmpereHour'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt16(self.value) # validate type UInt16 -# end class AmpereHour - - -class ApparentPower(GeneratedsSuper): - """The apparent power S (in VA) is the product of root mean square - (RMS) voltage and RMS current.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if ApparentPower.subclass: - return ApparentPower.subclass(*args_, **kwargs_) - else: - return ApparentPower(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ApparentPower', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ApparentPower') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ApparentPower', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ApparentPower'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ApparentPower', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='ApparentPower'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt16(self.value) # validate type UInt16 -# end class ApparentPower - - -class ReactivePower(GeneratedsSuper): - """The reactive power Q (in var) is the product of root mean square - (RMS) voltage, RMS current, and sin(theta) where theta is the - phase angle of current relative to voltage.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if ReactivePower.subclass: - return ReactivePower.subclass(*args_, **kwargs_) - else: - return ReactivePower(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_Int16(self, value): - # Validate type Int16, a restriction on xs:short. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReactivePower', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReactivePower') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReactivePower', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReactivePower'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ReactivePower', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='ReactivePower'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int16(self.value) # validate type Int16 -# end class ReactivePower - - -class FixedPowerFactor(GeneratedsSuper): - """Specifies a setpoint for Displacement Power Factor, the ratio - between apparent and active powers at the fundamental frequency - (e.g. 60 Hz).""" - subclass = None - superclass = None - def __init__(self, displacement=None, multiplier=None): - self.original_tagname_ = None - self.displacement = displacement - self.multiplier = multiplier - def factory(*args_, **kwargs_): - if FixedPowerFactor.subclass: - return FixedPowerFactor.subclass(*args_, **kwargs_) - else: - return FixedPowerFactor(*args_, **kwargs_) - factory = staticmethod(factory) - def get_displacement(self): return self.displacement - def set_displacement(self, displacement): self.displacement = displacement - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def validate_Int16(self, value): - # Validate type Int16, a restriction on xs:short. - pass - def hasContent_(self): - if ( - self.displacement is not None or - self.multiplier is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FixedPowerFactor', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FixedPowerFactor') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FixedPowerFactor', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FixedPowerFactor'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='FixedPowerFactor', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.displacement is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdisplacement>%s%s' % (namespace_, self.gds_format_integer(self.displacement, input_name='displacement'), namespace_, eol_)) - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FixedPowerFactor'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.displacement is not None: - showIndent(outfile, level) - outfile.write('displacement=%d,\n' % self.displacement) - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'displacement': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'displacement') - self.displacement = ival_ - self.validate_Int16(self.displacement) # validate type Int16 - elif nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' -# end class FixedPowerFactor - - -class FixedVAr(GeneratedsSuper): - """Specifies a signed setpoint for reactive power.""" - subclass = None - superclass = None - def __init__(self, refType=None, value=None): - self.original_tagname_ = None - self.refType = refType - self.value = value - def factory(*args_, **kwargs_): - if FixedVAr.subclass: - return FixedVAr.subclass(*args_, **kwargs_) - else: - return FixedVAr(*args_, **kwargs_) - factory = staticmethod(factory) - def get_refType(self): return self.refType - def set_refType(self, refType): self.refType = refType - def get_value(self): return self.value - def set_value(self, value): self.value = value - def hasContent_(self): - if ( - self.refType is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FixedVAr', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FixedVAr') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FixedVAr', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FixedVAr'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='FixedVAr', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.refType is not None: - self.refType.export(outfile, level, namespace_, name_='refType', pretty_print=pretty_print) - if self.value is not None: - self.value.export(outfile, level, namespace_, name_='value', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FixedVAr'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.refType is not None: - showIndent(outfile, level) - outfile.write('refType=model_.DERUnitRefType(\n') - self.refType.exportLiteral(outfile, level, name_='refType') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=model_.SignedPerCent(\n') - self.value.exportLiteral(outfile, level, name_='value') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'refType': - obj_ = DERUnitRefType.factory() - obj_.build(child_) - self.refType = obj_ - obj_.original_tagname_ = 'refType' - elif nodeName_ == 'value': - obj_ = SignedPerCent.factory() - obj_.build(child_) - self.value = obj_ - obj_.original_tagname_ = 'value' -# end class FixedVAr - - -class WattHour(GeneratedsSuper): - """Active (real) energy""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if WattHour.subclass: - return WattHour.subclass(*args_, **kwargs_) - else: - return WattHour(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='WattHour', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='WattHour') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='WattHour', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='WattHour'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='WattHour', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='WattHour'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt16(self.value) # validate type UInt16 -# end class WattHour - - -class VoltageRMS(GeneratedsSuper): - """Average electric potential difference between two points.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if VoltageRMS.subclass: - return VoltageRMS.subclass(*args_, **kwargs_) - else: - return VoltageRMS(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='VoltageRMS', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='VoltageRMS') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='VoltageRMS', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='VoltageRMS'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='VoltageRMS', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='VoltageRMS'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt16(self.value) # validate type UInt16 -# end class VoltageRMS - - -class ConnectStatusType(GeneratedsSuper): - """DER ConnectStatus value: 0 - N/A 1 - disconnected_unavail 2 - - disconnected_avail 3 - connected_unavail 4 - connected_avail 5 - - connected_on 6 - test_mode All other values reserved.""" - subclass = None - superclass = None - def __init__(self, dateTime=None, value=None): - self.original_tagname_ = None - self.dateTime = dateTime - self.value = value - def factory(*args_, **kwargs_): - if ConnectStatusType.subclass: - return ConnectStatusType.subclass(*args_, **kwargs_) - else: - return ConnectStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.dateTime is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ConnectStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ConnectStatusType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ConnectStatusType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ConnectStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ConnectStatusType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='ConnectStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt8(self.value) # validate type UInt8 -# end class ConnectStatusType - - -class InverterStatusType(GeneratedsSuper): - """DER InverterStatus value: 0 - N/A 1 - off 2 - sleeping (auto- - shutdown) or DER is at low output power/voltage 3 - starting up - or ON but not producing power 4 - tracking MPPT power point 5 - - forced power reduction/derating 6 - shutting down 7 - one or - more faults exist 8 - standby (service on unit) - DER may be at - high output voltage/power 9 - test mode 10 - as defined in - manufacturer status All other values reserved.""" - subclass = None - superclass = None - def __init__(self, dateTime=None, value=None): - self.original_tagname_ = None - self.dateTime = dateTime - self.value = value - def factory(*args_, **kwargs_): - if InverterStatusType.subclass: - return InverterStatusType.subclass(*args_, **kwargs_) - else: - return InverterStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.dateTime is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='InverterStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='InverterStatusType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='InverterStatusType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='InverterStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='InverterStatusType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='InverterStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt8(self.value) # validate type UInt8 -# end class InverterStatusType - - -class LocalControlModeStatusType(GeneratedsSuper): - """DER LocalControlModeStatus/value: 0 – local control 1 – remote - control All other values reserved.""" - subclass = None - superclass = None - def __init__(self, dateTime=None, value=None): - self.original_tagname_ = None - self.dateTime = dateTime - self.value = value - def factory(*args_, **kwargs_): - if LocalControlModeStatusType.subclass: - return LocalControlModeStatusType.subclass(*args_, **kwargs_) - else: - return LocalControlModeStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.dateTime is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LocalControlModeStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LocalControlModeStatusType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LocalControlModeStatusType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LocalControlModeStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='LocalControlModeStatusType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='LocalControlModeStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt8(self.value) # validate type UInt8 -# end class LocalControlModeStatusType - - -class ManufacturerStatusType(GeneratedsSuper): - """DER ManufacturerStatus/value: String data type""" - subclass = None - superclass = None - def __init__(self, dateTime=None, value=None): - self.original_tagname_ = None - self.dateTime = dateTime - self.value = value - def factory(*args_, **kwargs_): - if ManufacturerStatusType.subclass: - return ManufacturerStatusType.subclass(*args_, **kwargs_) - else: - return ManufacturerStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_String6(self, value): - # Validate type String6, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.dateTime is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ManufacturerStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ManufacturerStatusType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ManufacturerStatusType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ManufacturerStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ManufacturerStatusType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.value).encode(ExternalEncoding), input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='ManufacturerStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%s,\n' % quote_python(self.value).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'value': - value_ = child_.text - value_ = self.gds_validate_string(value_, node, 'value') - self.value = value_ - self.validate_String6(self.value) # validate type String6 -# end class ManufacturerStatusType - - -class OperationalModeStatusType(GeneratedsSuper): - """DER OperationalModeStatus value: 0 - Not applicable / Unknown 1 - - Off 2 - Operational mode 3 - Test mode All other values - reserved.""" - subclass = None - superclass = None - def __init__(self, dateTime=None, value=None): - self.original_tagname_ = None - self.dateTime = dateTime - self.value = value - def factory(*args_, **kwargs_): - if OperationalModeStatusType.subclass: - return OperationalModeStatusType.subclass(*args_, **kwargs_) - else: - return OperationalModeStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.dateTime is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='OperationalModeStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='OperationalModeStatusType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='OperationalModeStatusType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='OperationalModeStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='OperationalModeStatusType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='OperationalModeStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt8(self.value) # validate type UInt8 -# end class OperationalModeStatusType - - -class StateOfChargeStatusType(GeneratedsSuper): - """DER StateOfChargeStatus value: Percent data type""" - subclass = None - superclass = None - def __init__(self, dateTime=None, value=None): - self.original_tagname_ = None - self.dateTime = dateTime - self.value = value - def factory(*args_, **kwargs_): - if StateOfChargeStatusType.subclass: - return StateOfChargeStatusType.subclass(*args_, **kwargs_) - else: - return StateOfChargeStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_value(self): return self.value - def set_value(self, value): self.value = value - def hasContent_(self): - if ( - self.dateTime is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='StateOfChargeStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='StateOfChargeStatusType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='StateOfChargeStatusType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='StateOfChargeStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='StateOfChargeStatusType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.value is not None: - self.value.export(outfile, level, namespace_, name_='value', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='StateOfChargeStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=model_.PerCent(\n') - self.value.exportLiteral(outfile, level, name_='value') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'value': - obj_ = PerCent.factory() - obj_.build(child_) - self.value = obj_ - obj_.original_tagname_ = 'value' -# end class StateOfChargeStatusType - - -class StorageModeStatusType(GeneratedsSuper): - """DER StorageModeStatus value: 0 – storage charging 1 – storage - discharging 2 – storage holding All other values reserved.""" - subclass = None - superclass = None - def __init__(self, dateTime=None, value=None): - self.original_tagname_ = None - self.dateTime = dateTime - self.value = value - def factory(*args_, **kwargs_): - if StorageModeStatusType.subclass: - return StorageModeStatusType.subclass(*args_, **kwargs_) - else: - return StorageModeStatusType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.dateTime is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='StorageModeStatusType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='StorageModeStatusType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='StorageModeStatusType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='StorageModeStatusType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='StorageModeStatusType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='StorageModeStatusType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt8(self.value) # validate type UInt8 -# end class StorageModeStatusType - - -class Link(GeneratedsSuper): - """Links provide a reference, via URI, to another resource.A URI - reference.""" - subclass = None - superclass = None - def __init__(self, href=None): - self.original_tagname_ = None - self.href = _cast(None, href) - def factory(*args_, **kwargs_): - if Link.subclass: - return Link.subclass(*args_, **kwargs_) - else: - return Link(*args_, **kwargs_) - factory = staticmethod(factory) - def get_href(self): return self.href - def set_href(self, href): self.href = href - def hasContent_(self): - if ( - - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Link', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Link') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Link', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Link'): - if self.href is not None and 'href' not in already_processed: - already_processed.add('href') - outfile.write(' href=%s' % (self.gds_format_string(quote_attrib(self.href).encode(ExternalEncoding), input_name='href'), )) - def exportChildren(self, outfile, level, namespace_='', name_='Link', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='Link'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.href is not None and 'href' not in already_processed: - already_processed.add('href') - showIndent(outfile, level) - outfile.write('href="%s",\n' % (self.href,)) - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('href', node) - if value is not None and 'href' not in already_processed: - already_processed.add('href') - self.href = value - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class Link - - -class ListLink(Link): - """ListLinks provide a reference, via URI, to a List.Indicates the - total number of items in the referenced list.""" - subclass = None - superclass = Link - def __init__(self, all=None): - self.original_tagname_ = None - super(ListLink, self).__init__() - self.all = _cast(None, all) - def factory(*args_, **kwargs_): - if ListLink.subclass: - return ListLink.subclass(*args_, **kwargs_) - else: - return ListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def get_all(self): return self.all - def set_all(self, all): self.all = all - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - super(ListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ListLink'): - super(ListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ListLink') - if self.all is not None and 'all' not in already_processed: - already_processed.add('all') - outfile.write(' all=%s' % (quote_attrib(self.all), )) - def exportChildren(self, outfile, level, namespace_='', name_='ListLink', fromsubclass_=False, pretty_print=True): - super(ListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.all is not None and 'all' not in already_processed: - already_processed.add('all') - showIndent(outfile, level) - outfile.write('all=%d,\n' % (self.all,)) - super(ListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('all', node) - if value is not None and 'all' not in already_processed: - already_processed.add('all') - try: - self.all = int(value) - except ValueError as exp: - raise_parse_error(node, 'Bad integer attribute: %s' % exp) - self.validate_UInt16(self.all) # validate type UInt16 - super(ListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ListLink - - -class Resource(GeneratedsSuper): - """A resource is an addressable unit of information, either a - collection (List) or instance of an object (identifiedObject, or - simply, Resource)A reference to the resource address (URI). - Required in a response to a GET, ignored otherwise.""" - subclass = None - superclass = None - def __init__(self, href=None): - self.original_tagname_ = None - self.href = _cast(None, href) - def factory(*args_, **kwargs_): - if Resource.subclass: - return Resource.subclass(*args_, **kwargs_) - else: - return Resource(*args_, **kwargs_) - factory = staticmethod(factory) - def get_href(self): return self.href - def set_href(self, href): self.href = href - def hasContent_(self): - if ( - - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Resource', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Resource') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Resource', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Resource'): - if self.href is not None and 'href' not in already_processed: - already_processed.add('href') - outfile.write(' href=%s' % (self.gds_format_string(quote_attrib(self.href).encode(ExternalEncoding), input_name='href'), )) - def exportChildren(self, outfile, level, namespace_='', name_='Resource', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='Resource'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.href is not None and 'href' not in already_processed: - already_processed.add('href') - showIndent(outfile, level) - outfile.write('href="%s",\n' % (self.href,)) - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('href', node) - if value is not None and 'href' not in already_processed: - already_processed.add('href') - self.href = value - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class Resource - - -class RespondableResource(Resource): - """A Resource to which a Response can be requested.A reference to the - response resource address (URI). Required on a response to a GET - if responseRequired is "true".Indicates whether or not a - response is required upon receipt, creation or update of this - resource. Responses shall be posted to the collection specified - in "replyTo". If the resource has a deviceCategory field, - devices that match one or more of the device types indicated in - deviceCategory SHALL respond according to the rules listed - below. If the category does not match, the device SHALL NOT - respond. If the resource does not have a deviceCategory field, a - device receiving the resource SHALL respond according to the - rules listed below. Value encoded as hex according to the - following bit assignments, any combination is possible. See - Table 10-10 for the list of appropriate Response status codes to - be sent for these purposes. 0 - End device shall indicate that - message was received 1 - End device shall indicate specific - response. 2 - End user / customer response is required. All - other values reserved.""" - subclass = None - superclass = Resource - def __init__(self, replyTo=None, responseRequired='00'): - self.original_tagname_ = None - super(RespondableResource, self).__init__() - self.replyTo = _cast(None, replyTo) - self.responseRequired = _cast(None, responseRequired) - def factory(*args_, **kwargs_): - if RespondableResource.subclass: - return RespondableResource.subclass(*args_, **kwargs_) - else: - return RespondableResource(*args_, **kwargs_) - factory = staticmethod(factory) - def get_replyTo(self): return self.replyTo - def set_replyTo(self, replyTo): self.replyTo = replyTo - def get_responseRequired(self): return self.responseRequired - def set_responseRequired(self, responseRequired): self.responseRequired = responseRequired - def validate_HexBinary8(self, value): - # Validate type HexBinary8, a restriction on xs:hexBinary. - pass - def hasContent_(self): - if ( - super(RespondableResource, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RespondableResource', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RespondableResource') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RespondableResource', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RespondableResource'): - super(RespondableResource, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RespondableResource') - if self.replyTo is not None and 'replyTo' not in already_processed: - already_processed.add('replyTo') - outfile.write(' replyTo=%s' % (self.gds_format_string(quote_attrib(self.replyTo).encode(ExternalEncoding), input_name='replyTo'), )) - if self.responseRequired is not None and 'responseRequired' not in already_processed: - already_processed.add('responseRequired') - outfile.write(' responseRequired=%s' % (quote_attrib(self.responseRequired), )) - def exportChildren(self, outfile, level, namespace_='', name_='RespondableResource', fromsubclass_=False, pretty_print=True): - super(RespondableResource, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='RespondableResource'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.replyTo is not None and 'replyTo' not in already_processed: - already_processed.add('replyTo') - showIndent(outfile, level) - outfile.write('replyTo="%s",\n' % (self.replyTo,)) - if self.responseRequired is not None and 'responseRequired' not in already_processed: - already_processed.add('responseRequired') - showIndent(outfile, level) - outfile.write('responseRequired="%s",\n' % (self.responseRequired,)) - super(RespondableResource, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RespondableResource, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('replyTo', node) - if value is not None and 'replyTo' not in already_processed: - already_processed.add('replyTo') - self.replyTo = value - value = find_attr_value_('responseRequired', node) - if value is not None and 'responseRequired' not in already_processed: - already_processed.add('responseRequired') - self.responseRequired = value - self.validate_HexBinary8(self.responseRequired) # validate type HexBinary8 - super(RespondableResource, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(RespondableResource, self).buildChildren(child_, node, nodeName_, True) - pass -# end class RespondableResource - - -class RespondableSubscribableIdentifiedObject(RespondableResource): - """An IdentifiedObject to which a Response can be requested.Indicates - whether or not subscriptions are supported for this resource, - and whether or not conditional (thresholds) are supported. If - not specified, is "not subscribable" (0).""" - subclass = None - superclass = RespondableResource - def __init__(self, subscribable='0', mRID=None, description=None, version=None): - self.original_tagname_ = None - super(RespondableSubscribableIdentifiedObject, self).__init__() - self.subscribable = _cast(None, subscribable) - self.mRID = mRID - self.description = description - self.version = version - def factory(*args_, **kwargs_): - if RespondableSubscribableIdentifiedObject.subclass: - return RespondableSubscribableIdentifiedObject.subclass(*args_, **kwargs_) - else: - return RespondableSubscribableIdentifiedObject(*args_, **kwargs_) - factory = staticmethod(factory) - def get_mRID(self): return self.mRID - def set_mRID(self, mRID): self.mRID = mRID - def get_description(self): return self.description - def set_description(self, description): self.description = description - def get_version(self): return self.version - def set_version(self, version): self.version = version - def get_subscribable(self): return self.subscribable - def set_subscribable(self, subscribable): self.subscribable = subscribable - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def validate_SubscribableType(self, value): - # Validate type SubscribableType, a restriction on UInt8. - pass - def hasContent_(self): - if ( - self.mRID is not None or - self.description is not None or - self.version is not None or - super(RespondableSubscribableIdentifiedObject, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RespondableSubscribableIdentifiedObject', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RespondableSubscribableIdentifiedObject') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RespondableSubscribableIdentifiedObject', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RespondableSubscribableIdentifiedObject'): - super(RespondableSubscribableIdentifiedObject, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RespondableSubscribableIdentifiedObject') - if self.subscribable is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - outfile.write(' subscribable=%s' % (quote_attrib(self.subscribable), )) - def exportChildren(self, outfile, level, namespace_='', name_='RespondableSubscribableIdentifiedObject', fromsubclass_=False, pretty_print=True): - super(RespondableSubscribableIdentifiedObject, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.mRID is not None: - self.mRID.export(outfile, level, namespace_, name_='mRID', pretty_print=pretty_print) - if self.description is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdescription>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.description).encode(ExternalEncoding), input_name='description'), namespace_, eol_)) - if self.version is not None: - self.version.export(outfile, level, namespace_, name_='version', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='RespondableSubscribableIdentifiedObject'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.subscribable is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - showIndent(outfile, level) - outfile.write('subscribable=%d,\n' % (self.subscribable,)) - super(RespondableSubscribableIdentifiedObject, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RespondableSubscribableIdentifiedObject, self).exportLiteralChildren(outfile, level, name_) - if self.mRID is not None: - showIndent(outfile, level) - outfile.write('mRID=model_.mRIDType(\n') - self.mRID.exportLiteral(outfile, level, name_='mRID') - showIndent(outfile, level) - outfile.write('),\n') - if self.description is not None: - showIndent(outfile, level) - outfile.write('description=%s,\n' % quote_python(self.description).encode(ExternalEncoding)) - if self.version is not None: - showIndent(outfile, level) - outfile.write('version=model_.VersionType(\n') - self.version.exportLiteral(outfile, level, name_='version') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('subscribable', node) - if value is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - self.subscribable = value - self.validate_SubscribableType(self.subscribable) # validate type SubscribableType - super(RespondableSubscribableIdentifiedObject, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'mRID': - obj_ = mRIDType.factory() - obj_.build(child_) - self.mRID = obj_ - obj_.original_tagname_ = 'mRID' - elif nodeName_ == 'description': - description_ = child_.text - description_ = self.gds_validate_string(description_, node, 'description') - self.description = description_ - self.validate_String32(self.description) # validate type String32 - elif nodeName_ == 'version': - obj_ = VersionType.factory() - obj_.build(child_) - self.version = obj_ - obj_.original_tagname_ = 'version' - super(RespondableSubscribableIdentifiedObject, self).buildChildren(child_, node, nodeName_, True) -# end class RespondableSubscribableIdentifiedObject - - -class SubscribableResource(Resource): - """A Resource to which a Subscription can be requested.Indicates - whether or not subscriptions are supported for this resource, - and whether or not conditional (thresholds) are supported. If - not specified, is "not subscribable" (0).""" - subclass = None - superclass = Resource - def __init__(self, subscribable='0'): - self.original_tagname_ = None - super(SubscribableResource, self).__init__() - self.subscribable = _cast(None, subscribable) - def factory(*args_, **kwargs_): - if SubscribableResource.subclass: - return SubscribableResource.subclass(*args_, **kwargs_) - else: - return SubscribableResource(*args_, **kwargs_) - factory = staticmethod(factory) - def get_subscribable(self): return self.subscribable - def set_subscribable(self, subscribable): self.subscribable = subscribable - def validate_SubscribableType(self, value): - # Validate type SubscribableType, a restriction on UInt8. - pass - def hasContent_(self): - if ( - super(SubscribableResource, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SubscribableResource', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SubscribableResource') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SubscribableResource', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SubscribableResource'): - super(SubscribableResource, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SubscribableResource') - if self.subscribable is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - outfile.write(' subscribable=%s' % (quote_attrib(self.subscribable), )) - def exportChildren(self, outfile, level, namespace_='', name_='SubscribableResource', fromsubclass_=False, pretty_print=True): - super(SubscribableResource, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='SubscribableResource'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.subscribable is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - showIndent(outfile, level) - outfile.write('subscribable=%d,\n' % (self.subscribable,)) - super(SubscribableResource, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SubscribableResource, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('subscribable', node) - if value is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - self.subscribable = value - self.validate_SubscribableType(self.subscribable) # validate type SubscribableType - super(SubscribableResource, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(SubscribableResource, self).buildChildren(child_, node, nodeName_, True) - pass -# end class SubscribableResource - - -class Error(GeneratedsSuper): - """Contains information about the nature of an error if a request could - not be completed successfully.""" - subclass = None - superclass = None - def __init__(self, maxRetryDuration=None, reasonCode=None): - self.original_tagname_ = None - self.maxRetryDuration = maxRetryDuration - self.reasonCode = reasonCode - def factory(*args_, **kwargs_): - if Error.subclass: - return Error.subclass(*args_, **kwargs_) - else: - return Error(*args_, **kwargs_) - factory = staticmethod(factory) - def get_maxRetryDuration(self): return self.maxRetryDuration - def set_maxRetryDuration(self, maxRetryDuration): self.maxRetryDuration = maxRetryDuration - def get_reasonCode(self): return self.reasonCode - def set_reasonCode(self, reasonCode): self.reasonCode = reasonCode - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.maxRetryDuration is not None or - self.reasonCode is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Error', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Error') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Error', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Error'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='Error', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.maxRetryDuration is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smaxRetryDuration>%s%s' % (namespace_, self.gds_format_integer(self.maxRetryDuration, input_name='maxRetryDuration'), namespace_, eol_)) - if self.reasonCode is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sreasonCode>%s%s' % (namespace_, self.gds_format_integer(self.reasonCode, input_name='reasonCode'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Error'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.maxRetryDuration is not None: - showIndent(outfile, level) - outfile.write('maxRetryDuration=%d,\n' % self.maxRetryDuration) - if self.reasonCode is not None: - showIndent(outfile, level) - outfile.write('reasonCode=%d,\n' % self.reasonCode) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'maxRetryDuration': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'maxRetryDuration') - self.maxRetryDuration = ival_ - self.validate_UInt16(self.maxRetryDuration) # validate type UInt16 - elif nodeName_ == 'reasonCode': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'reasonCode') - self.reasonCode = ival_ - self.validate_UInt16(self.reasonCode) # validate type UInt16 -# end class Error - - -class Event(RespondableSubscribableIdentifiedObject): - """An Event indicates information that applies to a particular period - of time. Events SHALL be executed relative to the time of the - server, as described in the Time function set section 11.1.""" - subclass = None - superclass = RespondableSubscribableIdentifiedObject - def __init__(self, creationTime=None, EventStatus=None, interval=None): - self.original_tagname_ = None - super(Event, self).__init__() - self.creationTime = creationTime - self.EventStatus = EventStatus - self.interval = interval - def factory(*args_, **kwargs_): - if Event.subclass: - return Event.subclass(*args_, **kwargs_) - else: - return Event(*args_, **kwargs_) - factory = staticmethod(factory) - def get_creationTime(self): return self.creationTime - def set_creationTime(self, creationTime): self.creationTime = creationTime - def get_EventStatus(self): return self.EventStatus - def set_EventStatus(self, EventStatus): self.EventStatus = EventStatus - def get_interval(self): return self.interval - def set_interval(self, interval): self.interval = interval - def hasContent_(self): - if ( - self.creationTime is not None or - self.EventStatus is not None or - self.interval is not None or - super(Event, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Event', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Event') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Event', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Event'): - super(Event, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Event') - def exportChildren(self, outfile, level, namespace_='', name_='Event', fromsubclass_=False, pretty_print=True): - super(Event, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.creationTime is not None: - self.creationTime.export(outfile, level, namespace_, name_='creationTime', pretty_print=pretty_print) - if self.EventStatus is not None: - self.EventStatus.export(outfile, level, namespace_, name_='EventStatus', pretty_print=pretty_print) - if self.interval is not None: - self.interval.export(outfile, level, namespace_, name_='interval', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='Event'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Event, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Event, self).exportLiteralChildren(outfile, level, name_) - if self.creationTime is not None: - showIndent(outfile, level) - outfile.write('creationTime=model_.TimeType(\n') - self.creationTime.exportLiteral(outfile, level, name_='creationTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.EventStatus is not None: - showIndent(outfile, level) - outfile.write('EventStatus=model_.EventStatus(\n') - self.EventStatus.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.interval is not None: - showIndent(outfile, level) - outfile.write('interval=model_.DateTimeInterval(\n') - self.interval.exportLiteral(outfile, level, name_='interval') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Event, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'creationTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.creationTime = obj_ - obj_.original_tagname_ = 'creationTime' - elif nodeName_ == 'EventStatus': - obj_ = EventStatus.factory() - obj_.build(child_) - self.EventStatus = obj_ - obj_.original_tagname_ = 'EventStatus' - elif nodeName_ == 'interval': - obj_ = DateTimeInterval.factory() - obj_.build(child_) - self.interval = obj_ - obj_.original_tagname_ = 'interval' - super(Event, self).buildChildren(child_, node, nodeName_, True) -# end class Event - - -class EventStatus(GeneratedsSuper): - """Current status information relevant to a specific object. The Status - object is used to indicate the current status of an Event. - Devices can read the containing resource (e.g. TextMessage) to - get the most up to date status of the event. Devices can also - subscribe to a specific resource instance to get updates when - any of its attributes change, including the Status object.""" - subclass = None - superclass = None - def __init__(self, currentStatus=None, dateTime=None, potentiallySuperseded=None, potentiallySupersededTime=None, reason=None): - self.original_tagname_ = None - self.currentStatus = currentStatus - self.dateTime = dateTime - self.potentiallySuperseded = potentiallySuperseded - self.potentiallySupersededTime = potentiallySupersededTime - self.reason = reason - def factory(*args_, **kwargs_): - if EventStatus.subclass: - return EventStatus.subclass(*args_, **kwargs_) - else: - return EventStatus(*args_, **kwargs_) - factory = staticmethod(factory) - def get_currentStatus(self): return self.currentStatus - def set_currentStatus(self, currentStatus): self.currentStatus = currentStatus - def get_dateTime(self): return self.dateTime - def set_dateTime(self, dateTime): self.dateTime = dateTime - def get_potentiallySuperseded(self): return self.potentiallySuperseded - def set_potentiallySuperseded(self, potentiallySuperseded): self.potentiallySuperseded = potentiallySuperseded - def get_potentiallySupersededTime(self): return self.potentiallySupersededTime - def set_potentiallySupersededTime(self, potentiallySupersededTime): self.potentiallySupersededTime = potentiallySupersededTime - def get_reason(self): return self.reason - def set_reason(self, reason): self.reason = reason - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_String192(self, value): - # Validate type String192, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.currentStatus is not None or - self.dateTime is not None or - self.potentiallySuperseded is not None or - self.potentiallySupersededTime is not None or - self.reason is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EventStatus', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EventStatus') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EventStatus', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EventStatus'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='EventStatus', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.currentStatus is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%scurrentStatus>%s%s' % (namespace_, self.gds_format_integer(self.currentStatus, input_name='currentStatus'), namespace_, eol_)) - if self.dateTime is not None: - self.dateTime.export(outfile, level, namespace_, name_='dateTime', pretty_print=pretty_print) - if self.potentiallySuperseded is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%spotentiallySuperseded>%s%s' % (namespace_, self.gds_format_boolean(self.potentiallySuperseded, input_name='potentiallySuperseded'), namespace_, eol_)) - if self.potentiallySupersededTime is not None: - self.potentiallySupersededTime.export(outfile, level, namespace_, name_='potentiallySupersededTime', pretty_print=pretty_print) - if self.reason is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sreason>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.reason).encode(ExternalEncoding), input_name='reason'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='EventStatus'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.currentStatus is not None: - showIndent(outfile, level) - outfile.write('currentStatus=%d,\n' % self.currentStatus) - if self.dateTime is not None: - showIndent(outfile, level) - outfile.write('dateTime=model_.TimeType(\n') - self.dateTime.exportLiteral(outfile, level, name_='dateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.potentiallySuperseded is not None: - showIndent(outfile, level) - outfile.write('potentiallySuperseded=%s,\n' % self.potentiallySuperseded) - if self.potentiallySupersededTime is not None: - showIndent(outfile, level) - outfile.write('potentiallySupersededTime=model_.TimeType(\n') - self.potentiallySupersededTime.exportLiteral(outfile, level, name_='potentiallySupersededTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.reason is not None: - showIndent(outfile, level) - outfile.write('reason=%s,\n' % quote_python(self.reason).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'currentStatus': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'currentStatus') - self.currentStatus = ival_ - self.validate_UInt8(self.currentStatus) # validate type UInt8 - elif nodeName_ == 'dateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTime = obj_ - obj_.original_tagname_ = 'dateTime' - elif nodeName_ == 'potentiallySuperseded': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'potentiallySuperseded') - self.potentiallySuperseded = ival_ - elif nodeName_ == 'potentiallySupersededTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.potentiallySupersededTime = obj_ - obj_.original_tagname_ = 'potentiallySupersededTime' - elif nodeName_ == 'reason': - reason_ = child_.text - reason_ = self.gds_validate_string(reason_, node, 'reason') - self.reason = reason_ - self.validate_String192(self.reason) # validate type String192 -# end class EventStatus - - -class RandomizableEvent(Event): - """An Event that can indicate time ranges over which the start time and - duration SHALL be randomized.""" - subclass = None - superclass = Event - def __init__(self, randomizeDuration=None, randomizeStart=None): - self.original_tagname_ = None - super(RandomizableEvent, self).__init__() - self.randomizeDuration = randomizeDuration - self.randomizeStart = randomizeStart - def factory(*args_, **kwargs_): - if RandomizableEvent.subclass: - return RandomizableEvent.subclass(*args_, **kwargs_) - else: - return RandomizableEvent(*args_, **kwargs_) - factory = staticmethod(factory) - def get_randomizeDuration(self): return self.randomizeDuration - def set_randomizeDuration(self, randomizeDuration): self.randomizeDuration = randomizeDuration - def get_randomizeStart(self): return self.randomizeStart - def set_randomizeStart(self, randomizeStart): self.randomizeStart = randomizeStart - def hasContent_(self): - if ( - self.randomizeDuration is not None or - self.randomizeStart is not None or - super(RandomizableEvent, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RandomizableEvent', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RandomizableEvent') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RandomizableEvent', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RandomizableEvent'): - super(RandomizableEvent, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RandomizableEvent') - def exportChildren(self, outfile, level, namespace_='', name_='RandomizableEvent', fromsubclass_=False, pretty_print=True): - super(RandomizableEvent, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.randomizeDuration is not None: - self.randomizeDuration.export(outfile, level, namespace_, name_='randomizeDuration', pretty_print=pretty_print) - if self.randomizeStart is not None: - self.randomizeStart.export(outfile, level, namespace_, name_='randomizeStart', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='RandomizableEvent'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RandomizableEvent, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RandomizableEvent, self).exportLiteralChildren(outfile, level, name_) - if self.randomizeDuration is not None: - showIndent(outfile, level) - outfile.write('randomizeDuration=model_.OneHourRangeType(\n') - self.randomizeDuration.exportLiteral(outfile, level, name_='randomizeDuration') - showIndent(outfile, level) - outfile.write('),\n') - if self.randomizeStart is not None: - showIndent(outfile, level) - outfile.write('randomizeStart=model_.OneHourRangeType(\n') - self.randomizeStart.exportLiteral(outfile, level, name_='randomizeStart') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RandomizableEvent, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'randomizeDuration': - obj_ = OneHourRangeType.factory() - obj_.build(child_) - self.randomizeDuration = obj_ - obj_.original_tagname_ = 'randomizeDuration' - elif nodeName_ == 'randomizeStart': - obj_ = OneHourRangeType.factory() - obj_.build(child_) - self.randomizeStart = obj_ - obj_.original_tagname_ = 'randomizeStart' - super(RandomizableEvent, self).buildChildren(child_, node, nodeName_, True) -# end class RandomizableEvent - - -class AccumulationBehaviourType(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 3 = Cumulative The - sum of the previous billing period values. Note: - “Cumulative” is commonly used in conjunction with - “demand.” Each demand reset causes the maximum demand value - for the present billing period (since the last demand reset) to - accumulate as an accumulative total of all maximum demands. So - instead of “zeroing” the demand register, a demand reset has - the affect of adding the present maximum demand to this - accumulating total. 4 = DeltaData The difference between the - value at the end of the prescribed interval and the beginning of - the interval. This is used for incremental interval data. Note: - One common application would be for load profile data, another - use might be to report the number of events within an interval - (such as the number of equipment energizations within the - specified period of time.) 6 = Indicating As if a needle is - swung out on the meter face to a value to indicate the current - value. (Note: An “indicating” value is typically measured - over hundreds of milliseconds or greater, or may imply a - “pusher” mechanism to capture a value. Compare this to - “instantaneous” which is measured over a shorter period of - time.) 9 = Summation A form of accumulation which is selective - with respect to time. Note : “Summation” could be considered - a specialization of “Bulk Quantity” according to the rules - of inheritance where “Summation” selectively accumulates - pulses over a timing pattern, and “BulkQuantity” accumulates - pulses all of the time. 12 = Instantaneous Typically measured - over the fastest period of time allowed by the definition of the - metric (usually milliseconds or tens of milliseconds.) (Note: - “Instantaneous” was moved to attribute #3 in 61968-9Ed2 from - attribute #1 in 61968-9Ed1.) All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if AccumulationBehaviourType.subclass: - return AccumulationBehaviourType.subclass(*args_, **kwargs_) - else: - return AccumulationBehaviourType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AccumulationBehaviourType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AccumulationBehaviourType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='AccumulationBehaviourType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AccumulationBehaviourType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='AccumulationBehaviourType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='AccumulationBehaviourType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class AccumulationBehaviourType - - -class ApplianceLoadReductionType(GeneratedsSuper): - """0 - Delay Appliance Load Parameter requesting the appliance to - respond by providing a moderate load reduction for the duration - of a delay period. Typically referring to a “non-emergency” - event in which appliances can continue operating if already in a - load consuming period. 1 - Temporary Appliance Load Reduction - Parameter requesting the appliance to respond by providing an - aggressive load reduction for a short time period. Typically - referring to an “emergency/spinning reserve” event in which - an appliance should start shedding load if currently in a load - consuming period. * Full definition of how appliances react when - receiving each parameter is document in the EPA document - - ENERGY STAR® Program Requirements, Product Specification for - Residential Refrigerators and Freezers, Eligibility Criteria 5, - Draft 2 Version 5.0. All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if ApplianceLoadReductionType.subclass: - return ApplianceLoadReductionType.subclass(*args_, **kwargs_) - else: - return ApplianceLoadReductionType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ApplianceLoadReductionType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ApplianceLoadReductionType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='ApplianceLoadReductionType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ApplianceLoadReductionType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ApplianceLoadReductionType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='ApplianceLoadReductionType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class ApplianceLoadReductionType - - -class CommodityType(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 1 = Electricity - secondary metered value (a premises meter is typically a - secondary meter) 2 = Electricity primary metered value 4 = Air 7 - = NaturalGas 8 = Propane 9 = PotableWater 10 = Steam 11 = - WasteWater 12 = HeatingFluid 13 = CoolingFluid All other values - reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if CommodityType.subclass: - return CommodityType.subclass(*args_, **kwargs_) - else: - return CommodityType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CommodityType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CommodityType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='CommodityType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CommodityType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CommodityType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='CommodityType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class CommodityType - - -class ConsumptionBlockType(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 1 = Block 1 2 = Block - 2 3 = Block 3 4 = Block 4 5 = Block 5 6 = Block 6 7 = Block 7 8 - = Block 8 9 = Block 9 10 = Block 10 11 = Block 11 12 = Block 12 - 13 = Block 13 14 = Block 14 15 = Block 15 16 = Block 16 All - other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if ConsumptionBlockType.subclass: - return ConsumptionBlockType.subclass(*args_, **kwargs_) - else: - return ConsumptionBlockType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ConsumptionBlockType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ConsumptionBlockType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='ConsumptionBlockType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ConsumptionBlockType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ConsumptionBlockType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='ConsumptionBlockType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class ConsumptionBlockType - - -class CurrencyCode(GeneratedsSuper): - """Follows codes defined in [ISO 4217]. 0 - Not Applicable (default, if - not specified) 36 - Australian Dollar 124 - Canadian Dollar 840 - - US Dollar 978 - Euro This is not a complete list.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if CurrencyCode.subclass: - return CurrencyCode.subclass(*args_, **kwargs_) - else: - return CurrencyCode(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CurrencyCode', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CurrencyCode') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='CurrencyCode', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CurrencyCode'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='CurrencyCode', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='CurrencyCode'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class CurrencyCode - - -class DataQualifierType(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 2 = Average 8 = - Maximum 9 = Minimum 12 = Normal All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if DataQualifierType.subclass: - return DataQualifierType.subclass(*args_, **kwargs_) - else: - return DataQualifierType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DataQualifierType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DataQualifierType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='DataQualifierType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DataQualifierType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DataQualifierType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='DataQualifierType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class DataQualifierType - - -class DateTimeInterval(GeneratedsSuper): - """Interval of date and time.""" - subclass = None - superclass = None - def __init__(self, duration=None, start=None): - self.original_tagname_ = None - self.duration = duration - self.start = start - def factory(*args_, **kwargs_): - if DateTimeInterval.subclass: - return DateTimeInterval.subclass(*args_, **kwargs_) - else: - return DateTimeInterval(*args_, **kwargs_) - factory = staticmethod(factory) - def get_duration(self): return self.duration - def set_duration(self, duration): self.duration = duration - def get_start(self): return self.start - def set_start(self, start): self.start = start - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def hasContent_(self): - if ( - self.duration is not None or - self.start is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DateTimeInterval', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DateTimeInterval') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DateTimeInterval', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DateTimeInterval'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DateTimeInterval', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.duration is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sduration>%s%s' % (namespace_, self.gds_format_integer(self.duration, input_name='duration'), namespace_, eol_)) - if self.start is not None: - self.start.export(outfile, level, namespace_, name_='start', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DateTimeInterval'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.duration is not None: - showIndent(outfile, level) - outfile.write('duration=%d,\n' % self.duration) - if self.start is not None: - showIndent(outfile, level) - outfile.write('start=model_.TimeType(\n') - self.start.exportLiteral(outfile, level, name_='start') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'duration': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'duration') - self.duration = ival_ - self.validate_UInt32(self.duration) # validate type UInt32 - elif nodeName_ == 'start': - obj_ = TimeType.factory() - obj_.build(child_) - self.start = obj_ - obj_.original_tagname_ = 'start' -# end class DateTimeInterval - - -class DeviceCategoryType(GeneratedsSuper): - """The Device category types defined. Bit positions SHALL be defined as - follows: 0 - Programmable Communicating Thermostat 1 - Strip - Heaters 2 - Baseboard Heaters 3 - Water Heater 4 - Pool Pump 5 - - Sauna 6 - Hot tub 7 - Smart Appliance 8 - Irrigation Pump 9 - - Managed Commercial and Industrial (C&I) Loads 10 - Simple - misc. (Residential On/Off) loads 11 - Exterior Lighting 12 - - Interior Lighting 13 - Electric Vehicle 14 - Generation Systems - 15 - Load Control Switch 16 - Smart Inverter 17 - EVSE 18 - RESU - 19 - Energy Management System 20 - Smart Energy Module All other - values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if DeviceCategoryType.subclass: - return DeviceCategoryType.subclass(*args_, **kwargs_) - else: - return DeviceCategoryType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DeviceCategoryType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceCategoryType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='DeviceCategoryType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DeviceCategoryType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DeviceCategoryType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='DeviceCategoryType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class DeviceCategoryType - - -class DstRuleType(GeneratedsSuper): - """Bit map encoded rule from which is calculated the start or end time, - within the current year, to which daylight savings time offset - must be applied. The rule encoding: Bits 0 - 11: seconds 0 - - 3599 Bits 12 - 16: hours 0 - 23 Bits 17 - 19: day of the week 0 - = not applicable, 1 - 7 (Monday = 1) Bits:20 - 24: day of the - month 0 = not applicable, 1 - 31 Bits: 25 - 27: operator - (detailed below) Bits: 28 - 31: month 1 - 12 Rule value of - 0xFFFFFFFF means rule processing/DST correction is disabled. The - operators: 0: DST starts/ends on the Day of the Month 1: DST - starts/ends on the Day of the Week that is on or after the Day - of the Month 2: DST starts/ends on the first occurrence of the - Day of the Week in a month 3: DST starts/ends on the second - occurrence of the Day of the Week in a month 4: DST starts/ends - on the third occurrence of the Day of the Week in a month 5: DST - starts/ends on the forth occurrence of the Day of the Week in a - month 6: DST starts/ends on the fifth occurrence of the Day of - the Week in a month 7: DST starts/ends on the last occurrence of - the Day of the Week in a month An example: DST starts on third - Friday in March at 1:45 AM. The rule... Seconds: 2700 Hours: 1 - Day of Week: 5 Day of Month: 0 Operator: 4 Month: 3""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if DstRuleType.subclass: - return DstRuleType.subclass(*args_, **kwargs_) - else: - return DstRuleType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DstRuleType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DstRuleType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='DstRuleType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DstRuleType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='DstRuleType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='DstRuleType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class DstRuleType - - -class FlowDirectionType(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 1 = Forward - (delivered to customer) 19 = Reverse (received from customer) - All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if FlowDirectionType.subclass: - return FlowDirectionType.subclass(*args_, **kwargs_) - else: - return FlowDirectionType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FlowDirectionType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FlowDirectionType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='FlowDirectionType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FlowDirectionType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='FlowDirectionType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='FlowDirectionType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class FlowDirectionType - - -class KindType(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 3 = Currency 8 = - Demand 12 = Energy 37 = Power All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if KindType.subclass: - return KindType.subclass(*args_, **kwargs_) - else: - return KindType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='KindType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='KindType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='KindType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='KindType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='KindType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='KindType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class KindType - - -class LocaleType(GeneratedsSuper): - """[RFC 4646] identifier of a language-region""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if LocaleType.subclass: - return LocaleType.subclass(*args_, **kwargs_) - else: - return LocaleType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LocaleType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LocaleType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='LocaleType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LocaleType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='LocaleType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='LocaleType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class LocaleType - - -class mRIDType(GeneratedsSuper): - """A master resource identifier. The IANA PEN [PEN] provider ID SHALL - be specified in bits 0-31, the least-significant bits, and - objects created by that provider SHALL be assigned unique IDs - with the remaining 96 bits. - 0xFFFFFFFFFFFFFFFFFFFFFFFF[XXXXXXXX], where [XXXXXXXX] is the - PEN, is reserved for a object that is being created (e.g., a - ReadingSet for the current time that is still accumulating). - Except for this special reserved identifier, each modification - of an object (resource) representation MUST have a different - "version".""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if mRIDType.subclass: - return mRIDType.subclass(*args_, **kwargs_) - else: - return mRIDType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='mRIDType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='mRIDType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='mRIDType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='mRIDType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='mRIDType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='mRIDType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class mRIDType - - -class OneHourRangeType(GeneratedsSuper): - """A signed time offset, typically applied to a Time value, expressed - in seconds, with range -3600 to 3600.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if OneHourRangeType.subclass: - return OneHourRangeType.subclass(*args_, **kwargs_) - else: - return OneHourRangeType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='OneHourRangeType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='OneHourRangeType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='OneHourRangeType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='OneHourRangeType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='OneHourRangeType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='OneHourRangeType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class OneHourRangeType - - -class PENType(GeneratedsSuper): - """IANA Private Enterprise Number [PEN].""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PENType.subclass: - return PENType.subclass(*args_, **kwargs_) - else: - return PENType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PENType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PENType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PENType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PENType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PENType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PENType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PENType - - -class PerCent(GeneratedsSuper): - """Used for percentages, specified in hundredths of a percent, 0 - - 10000. (10000 = 100%)""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PerCent.subclass: - return PerCent.subclass(*args_, **kwargs_) - else: - return PerCent(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PerCent', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PerCent') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PerCent', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PerCent'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PerCent', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PerCent'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PerCent - - -class PhaseCode(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 32 = Phase C (and S2) - 33 = Phase CN (and S2N) 40 = Phase CA 64 = Phase B 65 = Phase BN - 66 = Phase BC 128 = Phase A (and S1) 129 = Phase AN (and S1N) - 132 = Phase AB 224 = Phase ABC All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PhaseCode.subclass: - return PhaseCode.subclass(*args_, **kwargs_) - else: - return PhaseCode(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PhaseCode', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PhaseCode') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PhaseCode', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PhaseCode'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PhaseCode', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PhaseCode'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PhaseCode - - -class PINType(GeneratedsSuper): - """6 digit unsigned decimal integer (0 - 999999). (Note that this only - requires 20 bits, if it can be allocated.)""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PINType.subclass: - return PINType.subclass(*args_, **kwargs_) - else: - return PINType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PINType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PINType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PINType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PINType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PINType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PINType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PINType - - -class PowerOfTenMultiplierType(GeneratedsSuper): - """-9 = nano=x10^-9 -6 = micro=x10^-6 -3 = milli=x10^-3 0 = none=x1 - (default, if not specified) 1 = deca=x10 2 = hecto=x100 3 = - kilo=x1000 6 = Mega=x10^6 9 = Giga=x10^9 This is not a complete - list. Any integer between -9 and 9 SHALL be supported, - indicating the power of ten multiplier for the units.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PowerOfTenMultiplierType.subclass: - return PowerOfTenMultiplierType.subclass(*args_, **kwargs_) - else: - return PowerOfTenMultiplierType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PowerOfTenMultiplierType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PowerOfTenMultiplierType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PowerOfTenMultiplierType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PowerOfTenMultiplierType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PowerOfTenMultiplierType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PowerOfTenMultiplierType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PowerOfTenMultiplierType - - -class PrimacyType(GeneratedsSuper): - """Values possible for indication of "Primary" provider: 0: In home - energy management system 1: Contracted premises service provider - 2: Non-contractual service provider All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if PrimacyType.subclass: - return PrimacyType.subclass(*args_, **kwargs_) - else: - return PrimacyType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PrimacyType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PrimacyType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='PrimacyType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PrimacyType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='PrimacyType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='PrimacyType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class PrimacyType - - -class RealEnergy(GeneratedsSuper): - """Real electrical energy""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if RealEnergy.subclass: - return RealEnergy.subclass(*args_, **kwargs_) - else: - return RealEnergy(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_UInt48(self, value): - # Validate type UInt48, a restriction on xs:unsignedLong. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RealEnergy', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RealEnergy') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RealEnergy', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RealEnergy'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='RealEnergy', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='RealEnergy'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_UInt48(self.value) # validate type UInt48 -# end class RealEnergy - - -class RoleFlagsType(GeneratedsSuper): - """Specifies the roles that apply to a usage point. Bit 0 - isMirror - - SHALL be set if the server is not the measurement device Bit 1 - - isPremisesAggregationPoint - SHALL be set if the UsagePoint is - the point of delivery for a premises Bit 2 - isPEV - SHALL be - set if the usage applies to an electric vehicle Bit 3 - isDER - - SHALL be set if the usage applies to a distributed energy - resource, capable of delivering power to the grid. Bit 4 - - isRevenueQuality - SHALL be set if usage was measured by a - device certified as revenue quality Bit 5 - isDC - SHALL be set - if the usage point measures direct current Bit 6 - isSubmeter - - SHALL be set if the usage point is not a premises aggregation - point Bit 7-15 - Reserved""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if RoleFlagsType.subclass: - return RoleFlagsType.subclass(*args_, **kwargs_) - else: - return RoleFlagsType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RoleFlagsType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RoleFlagsType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='RoleFlagsType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RoleFlagsType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='RoleFlagsType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='RoleFlagsType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class RoleFlagsType - - -class ServiceKind(GeneratedsSuper): - """Service kind 0 - electricity 1 - gas 2 - water 3 - time 4 - pressure - 5 - heat 6 - cooling All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if ServiceKind.subclass: - return ServiceKind.subclass(*args_, **kwargs_) - else: - return ServiceKind(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ServiceKind', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceKind') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='ServiceKind', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ServiceKind'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='ServiceKind', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='ServiceKind'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class ServiceKind - - -class SFDIType(GeneratedsSuper): - """Unsigned integer, max inclusive 687194767359, which is 2^36-1 - (68719476735), with added check digit. See Section 8.3.2 for - check digit calculation.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if SFDIType.subclass: - return SFDIType.subclass(*args_, **kwargs_) - else: - return SFDIType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SFDIType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SFDIType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='SFDIType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SFDIType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='SFDIType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='SFDIType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class SFDIType - - -class SignedPerCent(GeneratedsSuper): - """Used for signed percentages, specified in hundredths of a percent, - -10000 - 10000. (10000 = 100%)""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if SignedPerCent.subclass: - return SignedPerCent.subclass(*args_, **kwargs_) - else: - return SignedPerCent(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - # Added by Kisensum so that 0 value will generate element - self.valueOf_ is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SignedPerCent', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SignedPerCent') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='SignedPerCent', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SignedPerCent'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='SignedPerCent', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='SignedPerCent'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class SignedPerCent - - -class SignedRealEnergy(GeneratedsSuper): - """Real electrical energy, signed.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.value = value - def factory(*args_, **kwargs_): - if SignedRealEnergy.subclass: - return SignedRealEnergy.subclass(*args_, **kwargs_) - else: - return SignedRealEnergy(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_Int48(self, value): - # Validate type Int48, a restriction on xs:long. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SignedRealEnergy', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SignedRealEnergy') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SignedRealEnergy', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SignedRealEnergy'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='SignedRealEnergy', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='SignedRealEnergy'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int48(self.value) # validate type Int48 -# end class SignedRealEnergy - - -class TimeOffsetType(GeneratedsSuper): - """A signed time offset, typically applied to a Time value, expressed - in seconds.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if TimeOffsetType.subclass: - return TimeOffsetType.subclass(*args_, **kwargs_) - else: - return TimeOffsetType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TimeOffsetType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TimeOffsetType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='TimeOffsetType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TimeOffsetType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='TimeOffsetType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='TimeOffsetType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class TimeOffsetType - - -class TimeType(GeneratedsSuper): - """Time is a signed 64 bit value representing the number of seconds - since 0 hours, 0 minutes, 0 seconds, on the 1st of January, - 1970, in UTC, not counting leap seconds.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if TimeType.subclass: - return TimeType.subclass(*args_, **kwargs_) - else: - return TimeType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TimeType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TimeType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='TimeType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TimeType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='TimeType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='TimeType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class TimeType - - -class TOUType(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 1 = TOU A 2 = TOU B 3 - = TOU C 4 = TOU D 5 = TOU E 6 = TOU F 7 = TOU G 8 = TOU H 9 = - TOU I 10 = TOU J 11 = TOU K 12 = TOU L 13 = TOU M 14 = TOU N 15 - = TOU O All other values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if TOUType.subclass: - return TOUType.subclass(*args_, **kwargs_) - else: - return TOUType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TOUType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TOUType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='TOUType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TOUType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='TOUType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='TOUType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class TOUType - - -class UnitType(GeneratedsSuper): - """The unit types defined for end device control target reductions. 0 - - kWh 1 - kW 2 - Watts 3 - Cubic Meters 4 - Cubic Feet 5 - US - Gallons 6 - Imperial Gallons 7 - BTUs 8 - Liters 9 - kPA (gauge) - 10 - kPA (absolute) 11 - Mega Joule 12 - Unitless All other - values reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if UnitType.subclass: - return UnitType.subclass(*args_, **kwargs_) - else: - return UnitType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UnitType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UnitType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='UnitType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UnitType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='UnitType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='UnitType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class UnitType - - -class UnitValueType(GeneratedsSuper): - """Type for specification of a specific value, with units and power of - ten multiplier.""" - subclass = None - superclass = None - def __init__(self, multiplier=None, unit=None, value=None): - self.original_tagname_ = None - self.multiplier = multiplier - self.unit = unit - self.value = value - def factory(*args_, **kwargs_): - if UnitValueType.subclass: - return UnitValueType.subclass(*args_, **kwargs_) - else: - return UnitValueType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_multiplier(self): return self.multiplier - def set_multiplier(self, multiplier): self.multiplier = multiplier - def get_unit(self): return self.unit - def set_unit(self, unit): self.unit = unit - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_Int32(self, value): - # Validate type Int32, a restriction on xs:int. - pass - def hasContent_(self): - if ( - self.multiplier is not None or - self.unit is not None or - self.value is not None - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UnitValueType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UnitValueType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='UnitValueType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UnitValueType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='UnitValueType', fromsubclass_=False, pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.multiplier is not None: - self.multiplier.export(outfile, level, namespace_, name_='multiplier', pretty_print=pretty_print) - if self.unit is not None: - self.unit.export(outfile, level, namespace_, name_='unit', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='UnitValueType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - if self.multiplier is not None: - showIndent(outfile, level) - outfile.write('multiplier=model_.PowerOfTenMultiplierType(\n') - self.multiplier.exportLiteral(outfile, level, name_='multiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.unit is not None: - showIndent(outfile, level) - outfile.write('unit=model_.UomType(\n') - self.unit.exportLiteral(outfile, level, name_='unit') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'multiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.multiplier = obj_ - obj_.original_tagname_ = 'multiplier' - elif nodeName_ == 'unit': - obj_ = UomType.factory() - obj_.build(child_) - self.unit = obj_ - obj_.original_tagname_ = 'unit' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int32(self.value) # validate type Int32 -# end class UnitValueType - - -class UomType(GeneratedsSuper): - """0 = Not Applicable (default, if not specified) 5 = A (Current in - Amperes (RMS)) 6 = Kelvin (Temperature) 23 = Degrees Celsius - (Relative temperature) 29 = Voltage 31 = J (Energy joule) 33 = - Hz (Frequency) 38 =W (Real power in Watts) 42 = m3 (Cubic Meter) - 61 = VA (Apparent power) 63 = var (Reactive power) 65 = CosTheta - (Displacement Power Factor) 67 = V² (Volts squared) 69 = A² - (Amp squared) 71 = VAh (Apparent energy) 72 = Wh (Real energy in - Watt-hours) 73 = varh (Reactive energy) 106 = Ah (Ampere-hours / - Available Charge) 119 = ft3 (Cubic Feet) 122 = ft3/h (Cubic Feet - per Hour) 125 = m3/h (Cubic Meter per Hour) 128 = US gl (US - Gallons) 129 = US gl/h (US Gallons per Hour) 130 = IMP gl - (Imperial Gallons) 131 = IMP gl/h (Imperial Gallons per Hour) - 132 = BTU 133 = BTU/h 134 = Liter 137 = L/h (Liters per Hour) - 140 = PA(gauge) 155 = PA(absolute) 169 = Therm All other values - reserved.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if UomType.subclass: - return UomType.subclass(*args_, **kwargs_) - else: - return UomType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UomType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UomType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='UomType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UomType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='UomType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='UomType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class UomType - - -class VersionType(GeneratedsSuper): - """Version SHALL indicate a distinct identifier for each revision of an - IdentifiedObject. If not specified, a default version of "0" - (initial version) SHALL be assumed. Upon modification of any - IdentifiedObject, the mRID SHALL remain the same, but the - version SHALL be incremented. Servers MAY NOT modify objects - that they did not create, unless they were notified of the - change from the entity controlling the object's PEN.""" - subclass = None - superclass = None - def __init__(self, valueOf_=None): - self.original_tagname_ = None - self.valueOf_ = valueOf_ - def factory(*args_, **kwargs_): - if VersionType.subclass: - return VersionType.subclass(*args_, **kwargs_) - else: - return VersionType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_valueOf_(self): return self.valueOf_ - def set_valueOf_(self, valueOf_): self.valueOf_ = valueOf_ - def hasContent_(self): - if ( - self.valueOf_ - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='VersionType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='VersionType') - if self.hasContent_(): - outfile.write('>') - outfile.write(str(self.valueOf_).encode(ExternalEncoding)) - self.exportChildren(outfile, level + 1, namespace_='', name_='VersionType', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='VersionType'): - pass - def exportChildren(self, outfile, level, namespace_='', name_='VersionType', fromsubclass_=False, pretty_print=True): - pass - def exportLiteral(self, outfile, level, name_='VersionType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('valueOf_ = """%s""",\n' % (self.valueOf_,)) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - pass - def exportLiteralChildren(self, outfile, level, name_): - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - self.valueOf_ = get_all_text_(node) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - pass - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - pass -# end class VersionType - - -class ReadingBase(Resource): - """Specific value measured by a meter or other asset. ReadingBase is - abstract, used to define the elements common to Reading and - IntervalReading.""" - subclass = None - superclass = Resource - def __init__(self, consumptionBlock=None, qualityFlags=None, timePeriod=None, touTier=None, value=None): - self.original_tagname_ = None - super(ReadingBase, self).__init__() - self.consumptionBlock = consumptionBlock - self.qualityFlags = qualityFlags - self.timePeriod = timePeriod - self.touTier = touTier - self.value = value - def factory(*args_, **kwargs_): - if ReadingBase.subclass: - return ReadingBase.subclass(*args_, **kwargs_) - else: - return ReadingBase(*args_, **kwargs_) - factory = staticmethod(factory) - def get_consumptionBlock(self): return self.consumptionBlock - def set_consumptionBlock(self, consumptionBlock): self.consumptionBlock = consumptionBlock - def get_qualityFlags(self): return self.qualityFlags - def set_qualityFlags(self, qualityFlags): self.qualityFlags = qualityFlags - def get_timePeriod(self): return self.timePeriod - def set_timePeriod(self, timePeriod): self.timePeriod = timePeriod - def get_touTier(self): return self.touTier - def set_touTier(self, touTier): self.touTier = touTier - def get_value(self): return self.value - def set_value(self, value): self.value = value - def validate_HexBinary16(self, value): - # Validate type HexBinary16, a restriction on xs:hexBinary. - pass - def validate_Int48(self, value): - # Validate type Int48, a restriction on xs:long. - pass - def hasContent_(self): - if ( - self.consumptionBlock is not None or - self.qualityFlags is not None or - self.timePeriod is not None or - self.touTier is not None or - self.value is not None or - super(ReadingBase, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingBase', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingBase') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingBase', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingBase'): - super(ReadingBase, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingBase') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingBase', fromsubclass_=False, pretty_print=True): - super(ReadingBase, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.consumptionBlock is not None: - self.consumptionBlock.export(outfile, level, namespace_, name_='consumptionBlock', pretty_print=pretty_print) - if self.qualityFlags is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%squalityFlags>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.qualityFlags).encode(ExternalEncoding), input_name='qualityFlags'), namespace_, eol_)) - if self.timePeriod is not None: - self.timePeriod.export(outfile, level, namespace_, name_='timePeriod', pretty_print=pretty_print) - if self.touTier is not None: - self.touTier.export(outfile, level, namespace_, name_='touTier', pretty_print=pretty_print) - if self.value is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%svalue>%s%s' % (namespace_, self.gds_format_integer(self.value, input_name='value'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='ReadingBase'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingBase, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingBase, self).exportLiteralChildren(outfile, level, name_) - if self.consumptionBlock is not None: - showIndent(outfile, level) - outfile.write('consumptionBlock=model_.ConsumptionBlockType(\n') - self.consumptionBlock.exportLiteral(outfile, level, name_='consumptionBlock') - showIndent(outfile, level) - outfile.write('),\n') - if self.qualityFlags is not None: - showIndent(outfile, level) - outfile.write('qualityFlags=%s,\n' % quote_python(self.qualityFlags).encode(ExternalEncoding)) - if self.timePeriod is not None: - showIndent(outfile, level) - outfile.write('timePeriod=model_.DateTimeInterval(\n') - self.timePeriod.exportLiteral(outfile, level, name_='timePeriod') - showIndent(outfile, level) - outfile.write('),\n') - if self.touTier is not None: - showIndent(outfile, level) - outfile.write('touTier=model_.TOUType(\n') - self.touTier.exportLiteral(outfile, level, name_='touTier') - showIndent(outfile, level) - outfile.write('),\n') - if self.value is not None: - showIndent(outfile, level) - outfile.write('value=%d,\n' % self.value) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingBase, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'consumptionBlock': - obj_ = ConsumptionBlockType.factory() - obj_.build(child_) - self.consumptionBlock = obj_ - obj_.original_tagname_ = 'consumptionBlock' - elif nodeName_ == 'qualityFlags': - qualityFlags_ = child_.text - qualityFlags_ = self.gds_validate_string(qualityFlags_, node, 'qualityFlags') - self.qualityFlags = qualityFlags_ - self.validate_HexBinary16(self.qualityFlags) # validate type HexBinary16 - elif nodeName_ == 'timePeriod': - obj_ = DateTimeInterval.factory() - obj_.build(child_) - self.timePeriod = obj_ - obj_.original_tagname_ = 'timePeriod' - elif nodeName_ == 'touTier': - obj_ = TOUType.factory() - obj_.build(child_) - self.touTier = obj_ - obj_.original_tagname_ = 'touTier' - elif nodeName_ == 'value': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'value') - self.value = ival_ - self.validate_Int48(self.value) # validate type Int48 - super(ReadingBase, self).buildChildren(child_, node, nodeName_, True) -# end class ReadingBase - - -class SubscribableList(SubscribableResource): - """A List to which a Subscription can be requested.The number - specifying "all" of the items in the list. Required on GET, - ignored otherwise.Indicates the number of items in this page of - results.""" - subclass = None - superclass = SubscribableResource - def __init__(self, all=None, results=None): - self.original_tagname_ = None - super(SubscribableList, self).__init__() - self.all = _cast(None, all) - self.results = _cast(None, results) - def factory(*args_, **kwargs_): - if SubscribableList.subclass: - return SubscribableList.subclass(*args_, **kwargs_) - else: - return SubscribableList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_all(self): return self.all - def set_all(self, all): self.all = all - def get_results(self): return self.results - def set_results(self, results): self.results = results - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - super(SubscribableList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SubscribableList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SubscribableList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SubscribableList', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SubscribableList'): - super(SubscribableList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SubscribableList') - if self.all is not None and 'all' not in already_processed: - already_processed.add('all') - outfile.write(' all=%s' % (quote_attrib(self.all), )) - if self.results is not None and 'results' not in already_processed: - already_processed.add('results') - outfile.write(' results=%s' % (quote_attrib(self.results), )) - def exportChildren(self, outfile, level, namespace_='', name_='SubscribableList', fromsubclass_=False, pretty_print=True): - super(SubscribableList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='SubscribableList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.all is not None and 'all' not in already_processed: - already_processed.add('all') - showIndent(outfile, level) - outfile.write('all=%d,\n' % (self.all,)) - if self.results is not None and 'results' not in already_processed: - already_processed.add('results') - showIndent(outfile, level) - outfile.write('results=%d,\n' % (self.results,)) - super(SubscribableList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SubscribableList, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('all', node) - if value is not None and 'all' not in already_processed: - already_processed.add('all') - try: - self.all = int(value) - except ValueError as exp: - raise_parse_error(node, 'Bad integer attribute: %s' % exp) - self.validate_UInt16(self.all) # validate type UInt16 - value = find_attr_value_('results', node) - if value is not None and 'results' not in already_processed: - already_processed.add('results') - try: - self.results = int(value) - except ValueError as exp: - raise_parse_error(node, 'Bad integer attribute: %s' % exp) - self.validate_UInt8(self.results) # validate type UInt8 - super(SubscribableList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(SubscribableList, self).buildChildren(child_, node, nodeName_, True) - pass -# end class SubscribableList - - -class SubscribableIdentifiedObject(SubscribableResource): - """An IdentifiedObject to which a Subscription can be requested.""" - subclass = None - superclass = SubscribableResource - def __init__(self, mRID=None, description=None, version=None): - self.original_tagname_ = None - super(SubscribableIdentifiedObject, self).__init__() - self.mRID = mRID - self.description = description - self.version = version - def factory(*args_, **kwargs_): - if SubscribableIdentifiedObject.subclass: - return SubscribableIdentifiedObject.subclass(*args_, **kwargs_) - else: - return SubscribableIdentifiedObject(*args_, **kwargs_) - factory = staticmethod(factory) - def get_mRID(self): return self.mRID - def set_mRID(self, mRID): self.mRID = mRID - def get_description(self): return self.description - def set_description(self, description): self.description = description - def get_version(self): return self.version - def set_version(self, version): self.version = version - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.mRID is not None or - self.description is not None or - self.version is not None or - super(SubscribableIdentifiedObject, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SubscribableIdentifiedObject', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SubscribableIdentifiedObject') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SubscribableIdentifiedObject', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SubscribableIdentifiedObject'): - super(SubscribableIdentifiedObject, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SubscribableIdentifiedObject') - def exportChildren(self, outfile, level, namespace_='', name_='SubscribableIdentifiedObject', fromsubclass_=False, pretty_print=True): - super(SubscribableIdentifiedObject, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.mRID is not None: - self.mRID.export(outfile, level, namespace_, name_='mRID', pretty_print=pretty_print) - if self.description is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdescription>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.description).encode(ExternalEncoding), input_name='description'), namespace_, eol_)) - if self.version is not None: - self.version.export(outfile, level, namespace_, name_='version', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='SubscribableIdentifiedObject'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SubscribableIdentifiedObject, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SubscribableIdentifiedObject, self).exportLiteralChildren(outfile, level, name_) - if self.mRID is not None: - showIndent(outfile, level) - outfile.write('mRID=model_.mRIDType(\n') - self.mRID.exportLiteral(outfile, level, name_='mRID') - showIndent(outfile, level) - outfile.write('),\n') - if self.description is not None: - showIndent(outfile, level) - outfile.write('description=%s,\n' % quote_python(self.description).encode(ExternalEncoding)) - if self.version is not None: - showIndent(outfile, level) - outfile.write('version=model_.VersionType(\n') - self.version.exportLiteral(outfile, level, name_='version') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SubscribableIdentifiedObject, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'mRID': - obj_ = mRIDType.factory() - obj_.build(child_) - self.mRID = obj_ - obj_.original_tagname_ = 'mRID' - elif nodeName_ == 'description': - description_ = child_.text - description_ = self.gds_validate_string(description_, node, 'description') - self.description = description_ - self.validate_String32(self.description) # validate type String32 - elif nodeName_ == 'version': - obj_ = VersionType.factory() - obj_.build(child_) - self.version = obj_ - obj_.original_tagname_ = 'version' - super(SubscribableIdentifiedObject, self).buildChildren(child_, node, nodeName_, True) -# end class SubscribableIdentifiedObject - - -class RespondableIdentifiedObject(RespondableResource): - """An IdentifiedObject to which a Response can be requested.""" - subclass = None - superclass = RespondableResource - def __init__(self, mRID=None, description=None, version=None): - self.original_tagname_ = None - super(RespondableIdentifiedObject, self).__init__() - self.mRID = mRID - self.description = description - self.version = version - def factory(*args_, **kwargs_): - if RespondableIdentifiedObject.subclass: - return RespondableIdentifiedObject.subclass(*args_, **kwargs_) - else: - return RespondableIdentifiedObject(*args_, **kwargs_) - factory = staticmethod(factory) - def get_mRID(self): return self.mRID - def set_mRID(self, mRID): self.mRID = mRID - def get_description(self): return self.description - def set_description(self, description): self.description = description - def get_version(self): return self.version - def set_version(self, version): self.version = version - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.mRID is not None or - self.description is not None or - self.version is not None or - super(RespondableIdentifiedObject, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RespondableIdentifiedObject', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RespondableIdentifiedObject') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RespondableIdentifiedObject', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RespondableIdentifiedObject'): - super(RespondableIdentifiedObject, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RespondableIdentifiedObject') - def exportChildren(self, outfile, level, namespace_='', name_='RespondableIdentifiedObject', fromsubclass_=False, pretty_print=True): - super(RespondableIdentifiedObject, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.mRID is not None: - self.mRID.export(outfile, level, namespace_, name_='mRID', pretty_print=pretty_print) - if self.description is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdescription>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.description).encode(ExternalEncoding), input_name='description'), namespace_, eol_)) - if self.version is not None: - self.version.export(outfile, level, namespace_, name_='version', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='RespondableIdentifiedObject'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RespondableIdentifiedObject, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RespondableIdentifiedObject, self).exportLiteralChildren(outfile, level, name_) - if self.mRID is not None: - showIndent(outfile, level) - outfile.write('mRID=model_.mRIDType(\n') - self.mRID.exportLiteral(outfile, level, name_='mRID') - showIndent(outfile, level) - outfile.write('),\n') - if self.description is not None: - showIndent(outfile, level) - outfile.write('description=%s,\n' % quote_python(self.description).encode(ExternalEncoding)) - if self.version is not None: - showIndent(outfile, level) - outfile.write('version=model_.VersionType(\n') - self.version.exportLiteral(outfile, level, name_='version') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RespondableIdentifiedObject, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'mRID': - obj_ = mRIDType.factory() - obj_.build(child_) - self.mRID = obj_ - obj_.original_tagname_ = 'mRID' - elif nodeName_ == 'description': - description_ = child_.text - description_ = self.gds_validate_string(description_, node, 'description') - self.description = description_ - self.validate_String32(self.description) # validate type String32 - elif nodeName_ == 'version': - obj_ = VersionType.factory() - obj_.build(child_) - self.version = obj_ - obj_.original_tagname_ = 'version' - super(RespondableIdentifiedObject, self).buildChildren(child_, node, nodeName_, True) -# end class RespondableIdentifiedObject - - -class List(Resource): - """Container to hold a collection of object instances or references. - See [ZB 11-0167] Design Patterns section for additional - details.The number specifying "all" of the items in the list. - Required on a response to a GET, ignored otherwise.Indicates the - number of items in this page of results.""" - subclass = None - superclass = Resource - def __init__(self, all=None, results=None): - self.original_tagname_ = None - super(List, self).__init__() - self.all = _cast(None, all) - self.results = _cast(None, results) - def factory(*args_, **kwargs_): - if List.subclass: - return List.subclass(*args_, **kwargs_) - else: - return List(*args_, **kwargs_) - factory = staticmethod(factory) - def get_all(self): return self.all - def set_all(self, all): self.all = all - def get_results(self): return self.results - def set_results(self, results): self.results = results - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - super(List, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='List', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='List') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='List', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='List'): - super(List, self).exportAttributes(outfile, level, already_processed, namespace_, name_='List') - if self.all is not None and 'all' not in already_processed: - already_processed.add('all') - outfile.write(' all=%s' % (quote_attrib(self.all), )) - if self.results is not None and 'results' not in already_processed: - already_processed.add('results') - outfile.write(' results=%s' % (quote_attrib(self.results), )) - def exportChildren(self, outfile, level, namespace_='', name_='List', fromsubclass_=False, pretty_print=True): - super(List, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='List'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.all is not None and 'all' not in already_processed: - already_processed.add('all') - showIndent(outfile, level) - outfile.write('all=%d,\n' % (self.all,)) - if self.results is not None and 'results' not in already_processed: - already_processed.add('results') - showIndent(outfile, level) - outfile.write('results=%d,\n' % (self.results,)) - super(List, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(List, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('all', node) - if value is not None and 'all' not in already_processed: - already_processed.add('all') - try: - self.all = int(value) - except ValueError as exp: - raise_parse_error(node, 'Bad integer attribute: %s' % exp) - self.validate_UInt16(self.all) # validate type UInt16 - value = find_attr_value_('results', node) - if value is not None and 'results' not in already_processed: - already_processed.add('results') - try: - self.results = int(value) - except ValueError as exp: - raise_parse_error(node, 'Bad integer attribute: %s' % exp) - self.validate_UInt8(self.results) # validate type UInt8 - super(List, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(List, self).buildChildren(child_, node, nodeName_, True) - pass -# end class List - - -class IdentifiedObject(Resource): - """This is a root class to provide common naming attributes for all - classes needing naming attributes""" - subclass = None - superclass = Resource - def __init__(self, mRID=None, description=None, version=None): - self.original_tagname_ = None - super(IdentifiedObject, self).__init__() - self.mRID = mRID - self.description = description - self.version = version - def factory(*args_, **kwargs_): - if IdentifiedObject.subclass: - return IdentifiedObject.subclass(*args_, **kwargs_) - else: - return IdentifiedObject(*args_, **kwargs_) - factory = staticmethod(factory) - def get_mRID(self): return self.mRID - def set_mRID(self, mRID): self.mRID = mRID - def get_description(self): return self.description - def set_description(self, description): self.description = description - def get_version(self): return self.version - def set_version(self, version): self.version = version - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.mRID is not None or - self.description is not None or - self.version is not None or - super(IdentifiedObject, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='IdentifiedObject', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='IdentifiedObject') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='IdentifiedObject', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='IdentifiedObject'): - super(IdentifiedObject, self).exportAttributes(outfile, level, already_processed, namespace_, name_='IdentifiedObject') - def exportChildren(self, outfile, level, namespace_='', name_='IdentifiedObject', fromsubclass_=False, pretty_print=True): - super(IdentifiedObject, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.mRID is not None: - self.mRID.export(outfile, level, namespace_, name_='mRID', pretty_print=pretty_print) - if self.description is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdescription>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.description).encode(ExternalEncoding), input_name='description'), namespace_, eol_)) - if self.version is not None: - self.version.export(outfile, level, namespace_, name_='version', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='IdentifiedObject'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(IdentifiedObject, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(IdentifiedObject, self).exportLiteralChildren(outfile, level, name_) - if self.mRID is not None: - showIndent(outfile, level) - outfile.write('mRID=model_.mRIDType(\n') - self.mRID.exportLiteral(outfile, level, name_='mRID') - showIndent(outfile, level) - outfile.write('),\n') - if self.description is not None: - showIndent(outfile, level) - outfile.write('description=%s,\n' % quote_python(self.description).encode(ExternalEncoding)) - if self.version is not None: - showIndent(outfile, level) - outfile.write('version=model_.VersionType(\n') - self.version.exportLiteral(outfile, level, name_='version') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(IdentifiedObject, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'mRID': - obj_ = mRIDType.factory() - obj_.build(child_) - self.mRID = obj_ - obj_.original_tagname_ = 'mRID' - elif nodeName_ == 'description': - description_ = child_.text - description_ = self.gds_validate_string(description_, node, 'description') - self.description = description_ - self.validate_String32(self.description) # validate type String32 - elif nodeName_ == 'version': - obj_ = VersionType.factory() - obj_.build(child_) - self.version = obj_ - obj_.original_tagname_ = 'version' - super(IdentifiedObject, self).buildChildren(child_, node, nodeName_, True) -# end class IdentifiedObject - - -class UsagePointListLink(ListLink): - """SHALL contain a Link to a List of UsagePoint instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(UsagePointListLink, self).__init__() - def factory(*args_, **kwargs_): - if UsagePointListLink.subclass: - return UsagePointListLink.subclass(*args_, **kwargs_) - else: - return UsagePointListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(UsagePointListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UsagePointListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePointListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='UsagePointListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UsagePointListLink'): - super(UsagePointListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePointListLink') - def exportChildren(self, outfile, level, namespace_='', name_='UsagePointListLink', fromsubclass_=False, pretty_print=True): - super(UsagePointListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='UsagePointListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(UsagePointListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(UsagePointListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(UsagePointListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(UsagePointListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class UsagePointListLink - - -class UsagePointLink(Link): - """SHALL contain a Link to an instance of UsagePoint.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(UsagePointLink, self).__init__() - def factory(*args_, **kwargs_): - if UsagePointLink.subclass: - return UsagePointLink.subclass(*args_, **kwargs_) - else: - return UsagePointLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(UsagePointLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UsagePointLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePointLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='UsagePointLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UsagePointLink'): - super(UsagePointLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePointLink') - def exportChildren(self, outfile, level, namespace_='', name_='UsagePointLink', fromsubclass_=False, pretty_print=True): - super(UsagePointLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='UsagePointLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(UsagePointLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(UsagePointLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(UsagePointLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(UsagePointLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class UsagePointLink - - -class TimeTariffIntervalListLink(ListLink): - """SHALL contain a Link to a List of TimeTariffInterval instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(TimeTariffIntervalListLink, self).__init__() - def factory(*args_, **kwargs_): - if TimeTariffIntervalListLink.subclass: - return TimeTariffIntervalListLink.subclass(*args_, **kwargs_) - else: - return TimeTariffIntervalListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(TimeTariffIntervalListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TimeTariffIntervalListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TimeTariffIntervalListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TimeTariffIntervalListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TimeTariffIntervalListLink'): - super(TimeTariffIntervalListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TimeTariffIntervalListLink') - def exportChildren(self, outfile, level, namespace_='', name_='TimeTariffIntervalListLink', fromsubclass_=False, pretty_print=True): - super(TimeTariffIntervalListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='TimeTariffIntervalListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TimeTariffIntervalListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TimeTariffIntervalListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TimeTariffIntervalListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(TimeTariffIntervalListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class TimeTariffIntervalListLink - - -class TimeLink(Link): - """SHALL contain a Link to an instance of Time.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(TimeLink, self).__init__() - def factory(*args_, **kwargs_): - if TimeLink.subclass: - return TimeLink.subclass(*args_, **kwargs_) - else: - return TimeLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(TimeLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TimeLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TimeLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TimeLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TimeLink'): - super(TimeLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TimeLink') - def exportChildren(self, outfile, level, namespace_='', name_='TimeLink', fromsubclass_=False, pretty_print=True): - super(TimeLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='TimeLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TimeLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TimeLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TimeLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(TimeLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class TimeLink - - -class TextMessageListLink(ListLink): - """SHALL contain a Link to a List of TextMessage instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(TextMessageListLink, self).__init__() - def factory(*args_, **kwargs_): - if TextMessageListLink.subclass: - return TextMessageListLink.subclass(*args_, **kwargs_) - else: - return TextMessageListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(TextMessageListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TextMessageListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TextMessageListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TextMessageListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TextMessageListLink'): - super(TextMessageListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TextMessageListLink') - def exportChildren(self, outfile, level, namespace_='', name_='TextMessageListLink', fromsubclass_=False, pretty_print=True): - super(TextMessageListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='TextMessageListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TextMessageListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TextMessageListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TextMessageListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(TextMessageListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class TextMessageListLink - - -class TariffProfileListLink(ListLink): - """SHALL contain a Link to a List of TariffProfile instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(TariffProfileListLink, self).__init__() - def factory(*args_, **kwargs_): - if TariffProfileListLink.subclass: - return TariffProfileListLink.subclass(*args_, **kwargs_) - else: - return TariffProfileListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(TariffProfileListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TariffProfileListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TariffProfileListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TariffProfileListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TariffProfileListLink'): - super(TariffProfileListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TariffProfileListLink') - def exportChildren(self, outfile, level, namespace_='', name_='TariffProfileListLink', fromsubclass_=False, pretty_print=True): - super(TariffProfileListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='TariffProfileListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TariffProfileListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TariffProfileListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TariffProfileListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(TariffProfileListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class TariffProfileListLink - - -class TariffProfileLink(Link): - """SHALL contain a Link to an instance of TariffProfile.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(TariffProfileLink, self).__init__() - def factory(*args_, **kwargs_): - if TariffProfileLink.subclass: - return TariffProfileLink.subclass(*args_, **kwargs_) - else: - return TariffProfileLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(TariffProfileLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TariffProfileLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TariffProfileLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TariffProfileLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TariffProfileLink'): - super(TariffProfileLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TariffProfileLink') - def exportChildren(self, outfile, level, namespace_='', name_='TariffProfileLink', fromsubclass_=False, pretty_print=True): - super(TariffProfileLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='TariffProfileLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TariffProfileLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TariffProfileLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TariffProfileLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(TariffProfileLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class TariffProfileLink - - -class TargetReadingListLink(ListLink): - """SHALL contain a Link to a List of TargetReading instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(TargetReadingListLink, self).__init__() - def factory(*args_, **kwargs_): - if TargetReadingListLink.subclass: - return TargetReadingListLink.subclass(*args_, **kwargs_) - else: - return TargetReadingListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(TargetReadingListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TargetReadingListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TargetReadingListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TargetReadingListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TargetReadingListLink'): - super(TargetReadingListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TargetReadingListLink') - def exportChildren(self, outfile, level, namespace_='', name_='TargetReadingListLink', fromsubclass_=False, pretty_print=True): - super(TargetReadingListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='TargetReadingListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TargetReadingListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TargetReadingListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TargetReadingListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(TargetReadingListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class TargetReadingListLink - - -class SupportedLocaleListLink(ListLink): - """SHALL contain a Link to a List of SupportedLocale instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(SupportedLocaleListLink, self).__init__() - def factory(*args_, **kwargs_): - if SupportedLocaleListLink.subclass: - return SupportedLocaleListLink.subclass(*args_, **kwargs_) - else: - return SupportedLocaleListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(SupportedLocaleListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SupportedLocaleListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SupportedLocaleListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SupportedLocaleListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SupportedLocaleListLink'): - super(SupportedLocaleListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SupportedLocaleListLink') - def exportChildren(self, outfile, level, namespace_='', name_='SupportedLocaleListLink', fromsubclass_=False, pretty_print=True): - super(SupportedLocaleListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='SupportedLocaleListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SupportedLocaleListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SupportedLocaleListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SupportedLocaleListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(SupportedLocaleListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class SupportedLocaleListLink - - -class SupplyInterruptionOverrideListLink(ListLink): - """SHALL contain a Link to a List of SupplyInterruptionOverride - instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(SupplyInterruptionOverrideListLink, self).__init__() - def factory(*args_, **kwargs_): - if SupplyInterruptionOverrideListLink.subclass: - return SupplyInterruptionOverrideListLink.subclass(*args_, **kwargs_) - else: - return SupplyInterruptionOverrideListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(SupplyInterruptionOverrideListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SupplyInterruptionOverrideListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SupplyInterruptionOverrideListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SupplyInterruptionOverrideListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SupplyInterruptionOverrideListLink'): - super(SupplyInterruptionOverrideListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SupplyInterruptionOverrideListLink') - def exportChildren(self, outfile, level, namespace_='', name_='SupplyInterruptionOverrideListLink', fromsubclass_=False, pretty_print=True): - super(SupplyInterruptionOverrideListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='SupplyInterruptionOverrideListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SupplyInterruptionOverrideListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SupplyInterruptionOverrideListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SupplyInterruptionOverrideListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(SupplyInterruptionOverrideListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class SupplyInterruptionOverrideListLink - - -class SubscriptionListLink(ListLink): - """SHALL contain a Link to a List of Subscription instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(SubscriptionListLink, self).__init__() - def factory(*args_, **kwargs_): - if SubscriptionListLink.subclass: - return SubscriptionListLink.subclass(*args_, **kwargs_) - else: - return SubscriptionListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(SubscriptionListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SubscriptionListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SubscriptionListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SubscriptionListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SubscriptionListLink'): - super(SubscriptionListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SubscriptionListLink') - def exportChildren(self, outfile, level, namespace_='', name_='SubscriptionListLink', fromsubclass_=False, pretty_print=True): - super(SubscriptionListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='SubscriptionListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SubscriptionListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SubscriptionListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SubscriptionListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(SubscriptionListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class SubscriptionListLink - - -class ServiceSupplierLink(Link): - """SHALL contain a Link to an instance of ServiceSupplier.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(ServiceSupplierLink, self).__init__() - def factory(*args_, **kwargs_): - if ServiceSupplierLink.subclass: - return ServiceSupplierLink.subclass(*args_, **kwargs_) - else: - return ServiceSupplierLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ServiceSupplierLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ServiceSupplierLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceSupplierLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ServiceSupplierLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ServiceSupplierLink'): - super(ServiceSupplierLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceSupplierLink') - def exportChildren(self, outfile, level, namespace_='', name_='ServiceSupplierLink', fromsubclass_=False, pretty_print=True): - super(ServiceSupplierLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ServiceSupplierLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ServiceSupplierLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ServiceSupplierLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ServiceSupplierLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ServiceSupplierLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ServiceSupplierLink - - -class SelfDeviceLink(Link): - """SHALL contain a Link to an instance of SelfDevice.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(SelfDeviceLink, self).__init__() - def factory(*args_, **kwargs_): - if SelfDeviceLink.subclass: - return SelfDeviceLink.subclass(*args_, **kwargs_) - else: - return SelfDeviceLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(SelfDeviceLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SelfDeviceLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SelfDeviceLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SelfDeviceLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SelfDeviceLink'): - super(SelfDeviceLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SelfDeviceLink') - def exportChildren(self, outfile, level, namespace_='', name_='SelfDeviceLink', fromsubclass_=False, pretty_print=True): - super(SelfDeviceLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='SelfDeviceLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SelfDeviceLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SelfDeviceLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SelfDeviceLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(SelfDeviceLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class SelfDeviceLink - - -class RPLSourceRoutesListLink(ListLink): - """SHALL contain a Link to a List of RPLSourceRoutes instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(RPLSourceRoutesListLink, self).__init__() - def factory(*args_, **kwargs_): - if RPLSourceRoutesListLink.subclass: - return RPLSourceRoutesListLink.subclass(*args_, **kwargs_) - else: - return RPLSourceRoutesListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(RPLSourceRoutesListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RPLSourceRoutesListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RPLSourceRoutesListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RPLSourceRoutesListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RPLSourceRoutesListLink'): - super(RPLSourceRoutesListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RPLSourceRoutesListLink') - def exportChildren(self, outfile, level, namespace_='', name_='RPLSourceRoutesListLink', fromsubclass_=False, pretty_print=True): - super(RPLSourceRoutesListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='RPLSourceRoutesListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RPLSourceRoutesListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RPLSourceRoutesListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RPLSourceRoutesListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(RPLSourceRoutesListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class RPLSourceRoutesListLink - - -class RPLInstanceListLink(ListLink): - """SHALL contain a Link to a List of RPLInterface instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(RPLInstanceListLink, self).__init__() - def factory(*args_, **kwargs_): - if RPLInstanceListLink.subclass: - return RPLInstanceListLink.subclass(*args_, **kwargs_) - else: - return RPLInstanceListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(RPLInstanceListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RPLInstanceListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RPLInstanceListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RPLInstanceListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RPLInstanceListLink'): - super(RPLInstanceListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RPLInstanceListLink') - def exportChildren(self, outfile, level, namespace_='', name_='RPLInstanceListLink', fromsubclass_=False, pretty_print=True): - super(RPLInstanceListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='RPLInstanceListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RPLInstanceListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RPLInstanceListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RPLInstanceListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(RPLInstanceListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class RPLInstanceListLink - - -class ResponseSetListLink(ListLink): - """SHALL contain a Link to a List of ResponseSet instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ResponseSetListLink, self).__init__() - def factory(*args_, **kwargs_): - if ResponseSetListLink.subclass: - return ResponseSetListLink.subclass(*args_, **kwargs_) - else: - return ResponseSetListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ResponseSetListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ResponseSetListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseSetListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ResponseSetListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ResponseSetListLink'): - super(ResponseSetListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseSetListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ResponseSetListLink', fromsubclass_=False, pretty_print=True): - super(ResponseSetListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ResponseSetListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ResponseSetListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ResponseSetListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ResponseSetListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ResponseSetListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ResponseSetListLink - - -class ResponseListLink(ListLink): - """SHALL contain a Link to a List of Response instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ResponseListLink, self).__init__() - def factory(*args_, **kwargs_): - if ResponseListLink.subclass: - return ResponseListLink.subclass(*args_, **kwargs_) - else: - return ResponseListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ResponseListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ResponseListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ResponseListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ResponseListLink'): - super(ResponseListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ResponseListLink', fromsubclass_=False, pretty_print=True): - super(ResponseListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ResponseListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ResponseListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ResponseListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ResponseListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ResponseListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ResponseListLink - - -class RegistrationLink(Link): - """SHALL contain a Link to an instance of Registration.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(RegistrationLink, self).__init__() - def factory(*args_, **kwargs_): - if RegistrationLink.subclass: - return RegistrationLink.subclass(*args_, **kwargs_) - else: - return RegistrationLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(RegistrationLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RegistrationLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RegistrationLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RegistrationLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RegistrationLink'): - super(RegistrationLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RegistrationLink') - def exportChildren(self, outfile, level, namespace_='', name_='RegistrationLink', fromsubclass_=False, pretty_print=True): - super(RegistrationLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='RegistrationLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RegistrationLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RegistrationLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RegistrationLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(RegistrationLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class RegistrationLink - - -class ReadingTypeLink(Link): - """SHALL contain a Link to an instance of ReadingType.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(ReadingTypeLink, self).__init__() - def factory(*args_, **kwargs_): - if ReadingTypeLink.subclass: - return ReadingTypeLink.subclass(*args_, **kwargs_) - else: - return ReadingTypeLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ReadingTypeLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingTypeLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingTypeLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingTypeLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingTypeLink'): - super(ReadingTypeLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingTypeLink') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingTypeLink', fromsubclass_=False, pretty_print=True): - super(ReadingTypeLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ReadingTypeLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingTypeLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingTypeLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingTypeLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ReadingTypeLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ReadingTypeLink - - -class ReadingSetListLink(ListLink): - """SHALL contain a Link to a List of ReadingSet instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ReadingSetListLink, self).__init__() - def factory(*args_, **kwargs_): - if ReadingSetListLink.subclass: - return ReadingSetListLink.subclass(*args_, **kwargs_) - else: - return ReadingSetListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ReadingSetListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingSetListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingSetListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingSetListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingSetListLink'): - super(ReadingSetListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingSetListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingSetListLink', fromsubclass_=False, pretty_print=True): - super(ReadingSetListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ReadingSetListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingSetListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingSetListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingSetListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ReadingSetListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ReadingSetListLink - - -class ReadingListLink(ListLink): - """SHALL contain a Link to a List of Reading instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ReadingListLink, self).__init__() - def factory(*args_, **kwargs_): - if ReadingListLink.subclass: - return ReadingListLink.subclass(*args_, **kwargs_) - else: - return ReadingListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ReadingListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingListLink'): - super(ReadingListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingListLink', fromsubclass_=False, pretty_print=True): - super(ReadingListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ReadingListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ReadingListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ReadingListLink - - -class ReadingLink(Link): - """A Link to a Reading.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(ReadingLink, self).__init__() - def factory(*args_, **kwargs_): - if ReadingLink.subclass: - return ReadingLink.subclass(*args_, **kwargs_) - else: - return ReadingLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ReadingLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingLink'): - super(ReadingLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingLink') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingLink', fromsubclass_=False, pretty_print=True): - super(ReadingLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ReadingLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ReadingLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ReadingLink - - -class RateComponentListLink(ListLink): - """SHALL contain a Link to a List of RateComponent instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(RateComponentListLink, self).__init__() - def factory(*args_, **kwargs_): - if RateComponentListLink.subclass: - return RateComponentListLink.subclass(*args_, **kwargs_) - else: - return RateComponentListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(RateComponentListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RateComponentListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RateComponentListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RateComponentListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RateComponentListLink'): - super(RateComponentListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RateComponentListLink') - def exportChildren(self, outfile, level, namespace_='', name_='RateComponentListLink', fromsubclass_=False, pretty_print=True): - super(RateComponentListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='RateComponentListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RateComponentListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RateComponentListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RateComponentListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(RateComponentListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class RateComponentListLink - - -class RateComponentLink(Link): - """SHALL contain a Link to an instance of RateComponent.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(RateComponentLink, self).__init__() - def factory(*args_, **kwargs_): - if RateComponentLink.subclass: - return RateComponentLink.subclass(*args_, **kwargs_) - else: - return RateComponentLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(RateComponentLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RateComponentLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RateComponentLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RateComponentLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RateComponentLink'): - super(RateComponentLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RateComponentLink') - def exportChildren(self, outfile, level, namespace_='', name_='RateComponentLink', fromsubclass_=False, pretty_print=True): - super(RateComponentLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='RateComponentLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RateComponentLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RateComponentLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RateComponentLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(RateComponentLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class RateComponentLink - - -class ProjectionReadingListLink(ListLink): - """SHALL contain a Link to a List of ProjectionReading instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ProjectionReadingListLink, self).__init__() - def factory(*args_, **kwargs_): - if ProjectionReadingListLink.subclass: - return ProjectionReadingListLink.subclass(*args_, **kwargs_) - else: - return ProjectionReadingListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ProjectionReadingListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ProjectionReadingListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ProjectionReadingListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ProjectionReadingListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ProjectionReadingListLink'): - super(ProjectionReadingListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ProjectionReadingListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ProjectionReadingListLink', fromsubclass_=False, pretty_print=True): - super(ProjectionReadingListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ProjectionReadingListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ProjectionReadingListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ProjectionReadingListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ProjectionReadingListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ProjectionReadingListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ProjectionReadingListLink - - -class PriceResponseCfgListLink(ListLink): - """SHALL contain a Link to a List of PriceResponseCfg instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(PriceResponseCfgListLink, self).__init__() - def factory(*args_, **kwargs_): - if PriceResponseCfgListLink.subclass: - return PriceResponseCfgListLink.subclass(*args_, **kwargs_) - else: - return PriceResponseCfgListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(PriceResponseCfgListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PriceResponseCfgListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PriceResponseCfgListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PriceResponseCfgListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PriceResponseCfgListLink'): - super(PriceResponseCfgListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PriceResponseCfgListLink') - def exportChildren(self, outfile, level, namespace_='', name_='PriceResponseCfgListLink', fromsubclass_=False, pretty_print=True): - super(PriceResponseCfgListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='PriceResponseCfgListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PriceResponseCfgListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PriceResponseCfgListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PriceResponseCfgListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(PriceResponseCfgListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class PriceResponseCfgListLink - - -class PrepayOperationStatusLink(Link): - """SHALL contain a Link to an instance of PrepayOperationStatus.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(PrepayOperationStatusLink, self).__init__() - def factory(*args_, **kwargs_): - if PrepayOperationStatusLink.subclass: - return PrepayOperationStatusLink.subclass(*args_, **kwargs_) - else: - return PrepayOperationStatusLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(PrepayOperationStatusLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PrepayOperationStatusLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PrepayOperationStatusLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PrepayOperationStatusLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PrepayOperationStatusLink'): - super(PrepayOperationStatusLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PrepayOperationStatusLink') - def exportChildren(self, outfile, level, namespace_='', name_='PrepayOperationStatusLink', fromsubclass_=False, pretty_print=True): - super(PrepayOperationStatusLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='PrepayOperationStatusLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PrepayOperationStatusLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PrepayOperationStatusLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PrepayOperationStatusLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(PrepayOperationStatusLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class PrepayOperationStatusLink - - -class PrepaymentListLink(ListLink): - """SHALL contain a Link to a List of Prepayment instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(PrepaymentListLink, self).__init__() - def factory(*args_, **kwargs_): - if PrepaymentListLink.subclass: - return PrepaymentListLink.subclass(*args_, **kwargs_) - else: - return PrepaymentListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(PrepaymentListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PrepaymentListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PrepaymentListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PrepaymentListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PrepaymentListLink'): - super(PrepaymentListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PrepaymentListLink') - def exportChildren(self, outfile, level, namespace_='', name_='PrepaymentListLink', fromsubclass_=False, pretty_print=True): - super(PrepaymentListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='PrepaymentListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PrepaymentListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PrepaymentListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PrepaymentListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(PrepaymentListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class PrepaymentListLink - - -class PrepaymentLink(Link): - """SHALL contain a Link to an instance of Prepayment.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(PrepaymentLink, self).__init__() - def factory(*args_, **kwargs_): - if PrepaymentLink.subclass: - return PrepaymentLink.subclass(*args_, **kwargs_) - else: - return PrepaymentLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(PrepaymentLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PrepaymentLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PrepaymentLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PrepaymentLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PrepaymentLink'): - super(PrepaymentLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PrepaymentLink') - def exportChildren(self, outfile, level, namespace_='', name_='PrepaymentLink', fromsubclass_=False, pretty_print=True): - super(PrepaymentLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='PrepaymentLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PrepaymentLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PrepaymentLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PrepaymentLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(PrepaymentLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class PrepaymentLink - - -class PowerStatusLink(Link): - """SHALL contain a Link to an instance of PowerStatus.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(PowerStatusLink, self).__init__() - def factory(*args_, **kwargs_): - if PowerStatusLink.subclass: - return PowerStatusLink.subclass(*args_, **kwargs_) - else: - return PowerStatusLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(PowerStatusLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PowerStatusLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PowerStatusLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PowerStatusLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PowerStatusLink'): - super(PowerStatusLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PowerStatusLink') - def exportChildren(self, outfile, level, namespace_='', name_='PowerStatusLink', fromsubclass_=False, pretty_print=True): - super(PowerStatusLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='PowerStatusLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PowerStatusLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PowerStatusLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PowerStatusLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(PowerStatusLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class PowerStatusLink - - -class NotificationListLink(ListLink): - """SHALL contain a Link to a List of Notification instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(NotificationListLink, self).__init__() - def factory(*args_, **kwargs_): - if NotificationListLink.subclass: - return NotificationListLink.subclass(*args_, **kwargs_) - else: - return NotificationListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(NotificationListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='NotificationListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='NotificationListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='NotificationListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='NotificationListLink'): - super(NotificationListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='NotificationListLink') - def exportChildren(self, outfile, level, namespace_='', name_='NotificationListLink', fromsubclass_=False, pretty_print=True): - super(NotificationListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='NotificationListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(NotificationListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(NotificationListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(NotificationListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(NotificationListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class NotificationListLink - - -class NeighborListLink(ListLink): - """SHALL contain a Link to a List of Neighbor instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(NeighborListLink, self).__init__() - def factory(*args_, **kwargs_): - if NeighborListLink.subclass: - return NeighborListLink.subclass(*args_, **kwargs_) - else: - return NeighborListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(NeighborListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='NeighborListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='NeighborListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='NeighborListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='NeighborListLink'): - super(NeighborListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='NeighborListLink') - def exportChildren(self, outfile, level, namespace_='', name_='NeighborListLink', fromsubclass_=False, pretty_print=True): - super(NeighborListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='NeighborListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(NeighborListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(NeighborListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(NeighborListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(NeighborListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class NeighborListLink - - -class MirrorUsagePointListLink(ListLink): - """SHALL contain a Link to a List of MirrorUsagePoint instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(MirrorUsagePointListLink, self).__init__() - def factory(*args_, **kwargs_): - if MirrorUsagePointListLink.subclass: - return MirrorUsagePointListLink.subclass(*args_, **kwargs_) - else: - return MirrorUsagePointListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(MirrorUsagePointListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MirrorUsagePointListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorUsagePointListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MirrorUsagePointListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MirrorUsagePointListLink'): - super(MirrorUsagePointListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorUsagePointListLink') - def exportChildren(self, outfile, level, namespace_='', name_='MirrorUsagePointListLink', fromsubclass_=False, pretty_print=True): - super(MirrorUsagePointListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='MirrorUsagePointListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MirrorUsagePointListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MirrorUsagePointListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MirrorUsagePointListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(MirrorUsagePointListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class MirrorUsagePointListLink - - -class MeterReadingListLink(ListLink): - """SHALL contain a Link to a List of MeterReading instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(MeterReadingListLink, self).__init__() - def factory(*args_, **kwargs_): - if MeterReadingListLink.subclass: - return MeterReadingListLink.subclass(*args_, **kwargs_) - else: - return MeterReadingListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(MeterReadingListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MeterReadingListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReadingListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MeterReadingListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MeterReadingListLink'): - super(MeterReadingListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReadingListLink') - def exportChildren(self, outfile, level, namespace_='', name_='MeterReadingListLink', fromsubclass_=False, pretty_print=True): - super(MeterReadingListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='MeterReadingListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MeterReadingListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MeterReadingListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MeterReadingListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(MeterReadingListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class MeterReadingListLink - - -class MeterReadingLink(Link): - """SHALL contain a Link to an instance of MeterReading.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(MeterReadingLink, self).__init__() - def factory(*args_, **kwargs_): - if MeterReadingLink.subclass: - return MeterReadingLink.subclass(*args_, **kwargs_) - else: - return MeterReadingLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(MeterReadingLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MeterReadingLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReadingLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MeterReadingLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MeterReadingLink'): - super(MeterReadingLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReadingLink') - def exportChildren(self, outfile, level, namespace_='', name_='MeterReadingLink', fromsubclass_=False, pretty_print=True): - super(MeterReadingLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='MeterReadingLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MeterReadingLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MeterReadingLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MeterReadingLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(MeterReadingLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class MeterReadingLink - - -class MessagingProgramListLink(ListLink): - """SHALL contain a Link to a List of MessagingProgram instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(MessagingProgramListLink, self).__init__() - def factory(*args_, **kwargs_): - if MessagingProgramListLink.subclass: - return MessagingProgramListLink.subclass(*args_, **kwargs_) - else: - return MessagingProgramListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(MessagingProgramListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MessagingProgramListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MessagingProgramListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MessagingProgramListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MessagingProgramListLink'): - super(MessagingProgramListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MessagingProgramListLink') - def exportChildren(self, outfile, level, namespace_='', name_='MessagingProgramListLink', fromsubclass_=False, pretty_print=True): - super(MessagingProgramListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='MessagingProgramListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MessagingProgramListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MessagingProgramListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MessagingProgramListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(MessagingProgramListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class MessagingProgramListLink - - -class LogEventListLink(ListLink): - """SHALL contain a Link to a List of LogEvent instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(LogEventListLink, self).__init__() - def factory(*args_, **kwargs_): - if LogEventListLink.subclass: - return LogEventListLink.subclass(*args_, **kwargs_) - else: - return LogEventListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(LogEventListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LogEventListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LogEventListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LogEventListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LogEventListLink'): - super(LogEventListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='LogEventListLink') - def exportChildren(self, outfile, level, namespace_='', name_='LogEventListLink', fromsubclass_=False, pretty_print=True): - super(LogEventListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='LogEventListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(LogEventListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(LogEventListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(LogEventListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(LogEventListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class LogEventListLink - - -class LoadShedAvailabilityLink(Link): - """SHALL contain a Link to an instance of LoadShedAvailability.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(LoadShedAvailabilityLink, self).__init__() - def factory(*args_, **kwargs_): - if LoadShedAvailabilityLink.subclass: - return LoadShedAvailabilityLink.subclass(*args_, **kwargs_) - else: - return LoadShedAvailabilityLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(LoadShedAvailabilityLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LoadShedAvailabilityLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LoadShedAvailabilityLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LoadShedAvailabilityLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LoadShedAvailabilityLink'): - super(LoadShedAvailabilityLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='LoadShedAvailabilityLink') - def exportChildren(self, outfile, level, namespace_='', name_='LoadShedAvailabilityLink', fromsubclass_=False, pretty_print=True): - super(LoadShedAvailabilityLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='LoadShedAvailabilityLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(LoadShedAvailabilityLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(LoadShedAvailabilityLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(LoadShedAvailabilityLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(LoadShedAvailabilityLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class LoadShedAvailabilityLink - - -class LLInterfaceListLink(ListLink): - """SHALL contain a Link to a List of LLInterface instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(LLInterfaceListLink, self).__init__() - def factory(*args_, **kwargs_): - if LLInterfaceListLink.subclass: - return LLInterfaceListLink.subclass(*args_, **kwargs_) - else: - return LLInterfaceListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(LLInterfaceListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LLInterfaceListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LLInterfaceListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LLInterfaceListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LLInterfaceListLink'): - super(LLInterfaceListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='LLInterfaceListLink') - def exportChildren(self, outfile, level, namespace_='', name_='LLInterfaceListLink', fromsubclass_=False, pretty_print=True): - super(LLInterfaceListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='LLInterfaceListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(LLInterfaceListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(LLInterfaceListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(LLInterfaceListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(LLInterfaceListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class LLInterfaceListLink - - -class IPInterfaceListLink(ListLink): - """SHALL contain a Link to a List of IPInterface instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(IPInterfaceListLink, self).__init__() - def factory(*args_, **kwargs_): - if IPInterfaceListLink.subclass: - return IPInterfaceListLink.subclass(*args_, **kwargs_) - else: - return IPInterfaceListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(IPInterfaceListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='IPInterfaceListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='IPInterfaceListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='IPInterfaceListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='IPInterfaceListLink'): - super(IPInterfaceListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='IPInterfaceListLink') - def exportChildren(self, outfile, level, namespace_='', name_='IPInterfaceListLink', fromsubclass_=False, pretty_print=True): - super(IPInterfaceListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='IPInterfaceListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(IPInterfaceListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(IPInterfaceListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(IPInterfaceListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(IPInterfaceListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class IPInterfaceListLink - - -class IPAddrListLink(ListLink): - """SHALL contain a Link to a List of IPAddr instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(IPAddrListLink, self).__init__() - def factory(*args_, **kwargs_): - if IPAddrListLink.subclass: - return IPAddrListLink.subclass(*args_, **kwargs_) - else: - return IPAddrListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(IPAddrListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='IPAddrListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='IPAddrListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='IPAddrListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='IPAddrListLink'): - super(IPAddrListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='IPAddrListLink') - def exportChildren(self, outfile, level, namespace_='', name_='IPAddrListLink', fromsubclass_=False, pretty_print=True): - super(IPAddrListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='IPAddrListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(IPAddrListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(IPAddrListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(IPAddrListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(IPAddrListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class IPAddrListLink - - -class HistoricalReadingListLink(ListLink): - """SHALL contain a Link to a List of HistoricalReading instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(HistoricalReadingListLink, self).__init__() - def factory(*args_, **kwargs_): - if HistoricalReadingListLink.subclass: - return HistoricalReadingListLink.subclass(*args_, **kwargs_) - else: - return HistoricalReadingListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(HistoricalReadingListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='HistoricalReadingListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='HistoricalReadingListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='HistoricalReadingListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='HistoricalReadingListLink'): - super(HistoricalReadingListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='HistoricalReadingListLink') - def exportChildren(self, outfile, level, namespace_='', name_='HistoricalReadingListLink', fromsubclass_=False, pretty_print=True): - super(HistoricalReadingListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='HistoricalReadingListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(HistoricalReadingListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(HistoricalReadingListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(HistoricalReadingListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(HistoricalReadingListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class HistoricalReadingListLink - - -class FunctionSetAssignmentsListLink(ListLink): - """SHALL contain a Link to a List of FunctionSetAssignments instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(FunctionSetAssignmentsListLink, self).__init__() - def factory(*args_, **kwargs_): - if FunctionSetAssignmentsListLink.subclass: - return FunctionSetAssignmentsListLink.subclass(*args_, **kwargs_) - else: - return FunctionSetAssignmentsListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(FunctionSetAssignmentsListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FunctionSetAssignmentsListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FunctionSetAssignmentsListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FunctionSetAssignmentsListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FunctionSetAssignmentsListLink'): - super(FunctionSetAssignmentsListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FunctionSetAssignmentsListLink') - def exportChildren(self, outfile, level, namespace_='', name_='FunctionSetAssignmentsListLink', fromsubclass_=False, pretty_print=True): - super(FunctionSetAssignmentsListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='FunctionSetAssignmentsListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FunctionSetAssignmentsListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FunctionSetAssignmentsListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FunctionSetAssignmentsListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(FunctionSetAssignmentsListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class FunctionSetAssignmentsListLink - - -class FlowReservationResponseListLink(ListLink): - """SHALL contain a Link to a List of FlowReservationResponse instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(FlowReservationResponseListLink, self).__init__() - def factory(*args_, **kwargs_): - if FlowReservationResponseListLink.subclass: - return FlowReservationResponseListLink.subclass(*args_, **kwargs_) - else: - return FlowReservationResponseListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(FlowReservationResponseListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FlowReservationResponseListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationResponseListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FlowReservationResponseListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FlowReservationResponseListLink'): - super(FlowReservationResponseListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationResponseListLink') - def exportChildren(self, outfile, level, namespace_='', name_='FlowReservationResponseListLink', fromsubclass_=False, pretty_print=True): - super(FlowReservationResponseListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='FlowReservationResponseListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FlowReservationResponseListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FlowReservationResponseListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FlowReservationResponseListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(FlowReservationResponseListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class FlowReservationResponseListLink - - -class FlowReservationRequestListLink(ListLink): - """SHALL contain a Link to a List of FlowReservationRequest instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(FlowReservationRequestListLink, self).__init__() - def factory(*args_, **kwargs_): - if FlowReservationRequestListLink.subclass: - return FlowReservationRequestListLink.subclass(*args_, **kwargs_) - else: - return FlowReservationRequestListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(FlowReservationRequestListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FlowReservationRequestListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationRequestListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FlowReservationRequestListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FlowReservationRequestListLink'): - super(FlowReservationRequestListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationRequestListLink') - def exportChildren(self, outfile, level, namespace_='', name_='FlowReservationRequestListLink', fromsubclass_=False, pretty_print=True): - super(FlowReservationRequestListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='FlowReservationRequestListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FlowReservationRequestListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FlowReservationRequestListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FlowReservationRequestListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(FlowReservationRequestListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class FlowReservationRequestListLink - - -class FileStatusLink(Link): - """SHALL contain a Link to an instance of FileStatus.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(FileStatusLink, self).__init__() - def factory(*args_, **kwargs_): - if FileStatusLink.subclass: - return FileStatusLink.subclass(*args_, **kwargs_) - else: - return FileStatusLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(FileStatusLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FileStatusLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FileStatusLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FileStatusLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FileStatusLink'): - super(FileStatusLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FileStatusLink') - def exportChildren(self, outfile, level, namespace_='', name_='FileStatusLink', fromsubclass_=False, pretty_print=True): - super(FileStatusLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='FileStatusLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FileStatusLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FileStatusLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FileStatusLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(FileStatusLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class FileStatusLink - - -class FileListLink(ListLink): - """SHALL contain a Link to a List of File instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(FileListLink, self).__init__() - def factory(*args_, **kwargs_): - if FileListLink.subclass: - return FileListLink.subclass(*args_, **kwargs_) - else: - return FileListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(FileListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FileListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FileListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FileListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FileListLink'): - super(FileListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FileListLink') - def exportChildren(self, outfile, level, namespace_='', name_='FileListLink', fromsubclass_=False, pretty_print=True): - super(FileListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='FileListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FileListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FileListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FileListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(FileListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class FileListLink - - -class FileLink(Link): - """This element MUST be set to the URI of the most recent File being - loaded/activated by the LD. In the case of file status 0, this - element MUST be omitted.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(FileLink, self).__init__() - def factory(*args_, **kwargs_): - if FileLink.subclass: - return FileLink.subclass(*args_, **kwargs_) - else: - return FileLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(FileLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FileLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FileLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FileLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FileLink'): - super(FileLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FileLink') - def exportChildren(self, outfile, level, namespace_='', name_='FileLink', fromsubclass_=False, pretty_print=True): - super(FileLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='FileLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FileLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FileLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FileLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(FileLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class FileLink - - -class EndDeviceListLink(ListLink): - """SHALL contain a Link to a List of EndDevice instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(EndDeviceListLink, self).__init__() - def factory(*args_, **kwargs_): - if EndDeviceListLink.subclass: - return EndDeviceListLink.subclass(*args_, **kwargs_) - else: - return EndDeviceListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(EndDeviceListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EndDeviceListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EndDeviceListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EndDeviceListLink'): - super(EndDeviceListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceListLink') - def exportChildren(self, outfile, level, namespace_='', name_='EndDeviceListLink', fromsubclass_=False, pretty_print=True): - super(EndDeviceListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='EndDeviceListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(EndDeviceListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(EndDeviceListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(EndDeviceListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(EndDeviceListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class EndDeviceListLink - - -class EndDeviceLink(Link): - """SHALL contain a Link to an instance of EndDevice.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(EndDeviceLink, self).__init__() - def factory(*args_, **kwargs_): - if EndDeviceLink.subclass: - return EndDeviceLink.subclass(*args_, **kwargs_) - else: - return EndDeviceLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(EndDeviceLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EndDeviceLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EndDeviceLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EndDeviceLink'): - super(EndDeviceLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceLink') - def exportChildren(self, outfile, level, namespace_='', name_='EndDeviceLink', fromsubclass_=False, pretty_print=True): - super(EndDeviceLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='EndDeviceLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(EndDeviceLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(EndDeviceLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(EndDeviceLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(EndDeviceLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class EndDeviceLink - - -class EndDeviceControlListLink(ListLink): - """SHALL contain a Link to a List of EndDeviceControl instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(EndDeviceControlListLink, self).__init__() - def factory(*args_, **kwargs_): - if EndDeviceControlListLink.subclass: - return EndDeviceControlListLink.subclass(*args_, **kwargs_) - else: - return EndDeviceControlListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(EndDeviceControlListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EndDeviceControlListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceControlListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EndDeviceControlListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EndDeviceControlListLink'): - super(EndDeviceControlListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceControlListLink') - def exportChildren(self, outfile, level, namespace_='', name_='EndDeviceControlListLink', fromsubclass_=False, pretty_print=True): - super(EndDeviceControlListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='EndDeviceControlListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(EndDeviceControlListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(EndDeviceControlListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(EndDeviceControlListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(EndDeviceControlListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class EndDeviceControlListLink - - -class DeviceStatusLink(Link): - """SHALL contain a Link to an instance of DeviceStatus.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DeviceStatusLink, self).__init__() - def factory(*args_, **kwargs_): - if DeviceStatusLink.subclass: - return DeviceStatusLink.subclass(*args_, **kwargs_) - else: - return DeviceStatusLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DeviceStatusLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DeviceStatusLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceStatusLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DeviceStatusLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DeviceStatusLink'): - super(DeviceStatusLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceStatusLink') - def exportChildren(self, outfile, level, namespace_='', name_='DeviceStatusLink', fromsubclass_=False, pretty_print=True): - super(DeviceStatusLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DeviceStatusLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DeviceStatusLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DeviceStatusLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DeviceStatusLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DeviceStatusLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DeviceStatusLink - - -class DeviceInformationLink(Link): - """SHALL contain a Link to an instance of DeviceInformation.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DeviceInformationLink, self).__init__() - def factory(*args_, **kwargs_): - if DeviceInformationLink.subclass: - return DeviceInformationLink.subclass(*args_, **kwargs_) - else: - return DeviceInformationLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DeviceInformationLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DeviceInformationLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceInformationLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DeviceInformationLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DeviceInformationLink'): - super(DeviceInformationLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceInformationLink') - def exportChildren(self, outfile, level, namespace_='', name_='DeviceInformationLink', fromsubclass_=False, pretty_print=True): - super(DeviceInformationLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DeviceInformationLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DeviceInformationLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DeviceInformationLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DeviceInformationLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DeviceInformationLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DeviceInformationLink - - -class DeviceCapabilityLink(Link): - """SHALL contain a Link to an instance of DeviceCapability.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DeviceCapabilityLink, self).__init__() - def factory(*args_, **kwargs_): - if DeviceCapabilityLink.subclass: - return DeviceCapabilityLink.subclass(*args_, **kwargs_) - else: - return DeviceCapabilityLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DeviceCapabilityLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DeviceCapabilityLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceCapabilityLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DeviceCapabilityLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DeviceCapabilityLink'): - super(DeviceCapabilityLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceCapabilityLink') - def exportChildren(self, outfile, level, namespace_='', name_='DeviceCapabilityLink', fromsubclass_=False, pretty_print=True): - super(DeviceCapabilityLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DeviceCapabilityLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DeviceCapabilityLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DeviceCapabilityLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DeviceCapabilityLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DeviceCapabilityLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DeviceCapabilityLink - - -class DERStatusLink(Link): - """SHALL contain a Link to an instance of DERStatus.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DERStatusLink, self).__init__() - def factory(*args_, **kwargs_): - if DERStatusLink.subclass: - return DERStatusLink.subclass(*args_, **kwargs_) - else: - return DERStatusLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERStatusLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERStatusLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERStatusLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERStatusLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERStatusLink'): - super(DERStatusLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERStatusLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERStatusLink', fromsubclass_=False, pretty_print=True): - super(DERStatusLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERStatusLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERStatusLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERStatusLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERStatusLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERStatusLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERStatusLink - - -class DERSettingsLink(Link): - """SHALL contain a Link to an instance of DERSettings.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DERSettingsLink, self).__init__() - def factory(*args_, **kwargs_): - if DERSettingsLink.subclass: - return DERSettingsLink.subclass(*args_, **kwargs_) - else: - return DERSettingsLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERSettingsLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERSettingsLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERSettingsLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERSettingsLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERSettingsLink'): - super(DERSettingsLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERSettingsLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERSettingsLink', fromsubclass_=False, pretty_print=True): - super(DERSettingsLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERSettingsLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERSettingsLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERSettingsLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERSettingsLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERSettingsLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERSettingsLink - - -class DERProgramListLink(ListLink): - """SHALL contain a Link to a List of DERProgram instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(DERProgramListLink, self).__init__() - def factory(*args_, **kwargs_): - if DERProgramListLink.subclass: - return DERProgramListLink.subclass(*args_, **kwargs_) - else: - return DERProgramListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERProgramListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERProgramListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERProgramListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERProgramListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERProgramListLink'): - super(DERProgramListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERProgramListLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERProgramListLink', fromsubclass_=False, pretty_print=True): - super(DERProgramListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERProgramListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERProgramListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERProgramListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERProgramListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERProgramListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERProgramListLink - - -class DERProgramLink(Link): - """SHALL contain a Link to an instance of DERProgram.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DERProgramLink, self).__init__() - def factory(*args_, **kwargs_): - if DERProgramLink.subclass: - return DERProgramLink.subclass(*args_, **kwargs_) - else: - return DERProgramLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERProgramLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERProgramLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERProgramLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERProgramLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERProgramLink'): - super(DERProgramLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERProgramLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERProgramLink', fromsubclass_=False, pretty_print=True): - super(DERProgramLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERProgramLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERProgramLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERProgramLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERProgramLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERProgramLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERProgramLink - - -class DERListLink(ListLink): - """SHALL contain a Link to a List of DER instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(DERListLink, self).__init__() - def factory(*args_, **kwargs_): - if DERListLink.subclass: - return DERListLink.subclass(*args_, **kwargs_) - else: - return DERListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERListLink'): - super(DERListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERListLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERListLink', fromsubclass_=False, pretty_print=True): - super(DERListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERListLink - - -class DERLink(Link): - """SHALL contain a Link to an instance of DER.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DERLink, self).__init__() - def factory(*args_, **kwargs_): - if DERLink.subclass: - return DERLink.subclass(*args_, **kwargs_) - else: - return DERLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERLink'): - super(DERLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERLink', fromsubclass_=False, pretty_print=True): - super(DERLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERLink - - -class DERCurveListLink(ListLink): - """SHALL contain a Link to a List of DERCurve instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(DERCurveListLink, self).__init__() - def factory(*args_, **kwargs_): - if DERCurveListLink.subclass: - return DERCurveListLink.subclass(*args_, **kwargs_) - else: - return DERCurveListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERCurveListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERCurveListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurveListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERCurveListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERCurveListLink'): - super(DERCurveListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurveListLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERCurveListLink', fromsubclass_=False, pretty_print=True): - super(DERCurveListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERCurveListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERCurveListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERCurveListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERCurveListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERCurveListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERCurveListLink - - -class DERCurveLink(Link): - """SHALL contain a Link to an instance of DERCurve.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DERCurveLink, self).__init__() - def factory(*args_, **kwargs_): - if DERCurveLink.subclass: - return DERCurveLink.subclass(*args_, **kwargs_) - else: - return DERCurveLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERCurveLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERCurveLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurveLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERCurveLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERCurveLink'): - super(DERCurveLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurveLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERCurveLink', fromsubclass_=False, pretty_print=True): - super(DERCurveLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERCurveLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERCurveLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERCurveLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERCurveLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERCurveLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERCurveLink - - -class DERControlListLink(ListLink): - """SHALL contain a Link to a List of DERControl instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(DERControlListLink, self).__init__() - def factory(*args_, **kwargs_): - if DERControlListLink.subclass: - return DERControlListLink.subclass(*args_, **kwargs_) - else: - return DERControlListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERControlListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERControlListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERControlListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERControlListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERControlListLink'): - super(DERControlListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERControlListLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERControlListLink', fromsubclass_=False, pretty_print=True): - super(DERControlListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERControlListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERControlListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERControlListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERControlListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERControlListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERControlListLink - - -class DERCapabilityLink(Link): - """SHALL contain a Link to an instance of DERCapability.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DERCapabilityLink, self).__init__() - def factory(*args_, **kwargs_): - if DERCapabilityLink.subclass: - return DERCapabilityLink.subclass(*args_, **kwargs_) - else: - return DERCapabilityLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERCapabilityLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERCapabilityLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERCapabilityLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERCapabilityLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERCapabilityLink'): - super(DERCapabilityLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERCapabilityLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERCapabilityLink', fromsubclass_=False, pretty_print=True): - super(DERCapabilityLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERCapabilityLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERCapabilityLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERCapabilityLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERCapabilityLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERCapabilityLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERCapabilityLink - - -class DefaultDERControlLink(Link): - """SHALL contain a Link to an instance of DefaultDERControl. This is - the default mode of the DER which MAY be overridden by - DERControl events.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DefaultDERControlLink, self).__init__() - def factory(*args_, **kwargs_): - if DefaultDERControlLink.subclass: - return DefaultDERControlLink.subclass(*args_, **kwargs_) - else: - return DefaultDERControlLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DefaultDERControlLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DefaultDERControlLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DefaultDERControlLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DefaultDERControlLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DefaultDERControlLink'): - super(DefaultDERControlLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DefaultDERControlLink') - def exportChildren(self, outfile, level, namespace_='', name_='DefaultDERControlLink', fromsubclass_=False, pretty_print=True): - super(DefaultDERControlLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DefaultDERControlLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DefaultDERControlLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DefaultDERControlLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DefaultDERControlLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DefaultDERControlLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DefaultDERControlLink - - -class DERAvailabilityLink(Link): - """SHALL contain a Link to an instance of DERAvailability.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DERAvailabilityLink, self).__init__() - def factory(*args_, **kwargs_): - if DERAvailabilityLink.subclass: - return DERAvailabilityLink.subclass(*args_, **kwargs_) - else: - return DERAvailabilityLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DERAvailabilityLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERAvailabilityLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERAvailabilityLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERAvailabilityLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERAvailabilityLink'): - super(DERAvailabilityLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERAvailabilityLink') - def exportChildren(self, outfile, level, namespace_='', name_='DERAvailabilityLink', fromsubclass_=False, pretty_print=True): - super(DERAvailabilityLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DERAvailabilityLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERAvailabilityLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERAvailabilityLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERAvailabilityLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DERAvailabilityLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DERAvailabilityLink - - -class DemandResponseProgramListLink(ListLink): - """SHALL contain a Link to a List of DemandResponseProgram instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(DemandResponseProgramListLink, self).__init__() - def factory(*args_, **kwargs_): - if DemandResponseProgramListLink.subclass: - return DemandResponseProgramListLink.subclass(*args_, **kwargs_) - else: - return DemandResponseProgramListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DemandResponseProgramListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DemandResponseProgramListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DemandResponseProgramListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DemandResponseProgramListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DemandResponseProgramListLink'): - super(DemandResponseProgramListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DemandResponseProgramListLink') - def exportChildren(self, outfile, level, namespace_='', name_='DemandResponseProgramListLink', fromsubclass_=False, pretty_print=True): - super(DemandResponseProgramListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DemandResponseProgramListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DemandResponseProgramListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DemandResponseProgramListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DemandResponseProgramListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DemandResponseProgramListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DemandResponseProgramListLink - - -class DemandResponseProgramLink(Link): - """SHALL contain a Link to an instance of DemandResponseProgram.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(DemandResponseProgramLink, self).__init__() - def factory(*args_, **kwargs_): - if DemandResponseProgramLink.subclass: - return DemandResponseProgramLink.subclass(*args_, **kwargs_) - else: - return DemandResponseProgramLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(DemandResponseProgramLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DemandResponseProgramLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DemandResponseProgramLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DemandResponseProgramLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DemandResponseProgramLink'): - super(DemandResponseProgramLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DemandResponseProgramLink') - def exportChildren(self, outfile, level, namespace_='', name_='DemandResponseProgramLink', fromsubclass_=False, pretty_print=True): - super(DemandResponseProgramLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='DemandResponseProgramLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DemandResponseProgramLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DemandResponseProgramLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DemandResponseProgramLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(DemandResponseProgramLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class DemandResponseProgramLink - - -class CustomerAgreementListLink(ListLink): - """SHALL contain a Link to a List of CustomerAgreement instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(CustomerAgreementListLink, self).__init__() - def factory(*args_, **kwargs_): - if CustomerAgreementListLink.subclass: - return CustomerAgreementListLink.subclass(*args_, **kwargs_) - else: - return CustomerAgreementListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(CustomerAgreementListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CustomerAgreementListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAgreementListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CustomerAgreementListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CustomerAgreementListLink'): - super(CustomerAgreementListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAgreementListLink') - def exportChildren(self, outfile, level, namespace_='', name_='CustomerAgreementListLink', fromsubclass_=False, pretty_print=True): - super(CustomerAgreementListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='CustomerAgreementListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CustomerAgreementListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CustomerAgreementListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CustomerAgreementListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(CustomerAgreementListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class CustomerAgreementListLink - - -class CustomerAccountListLink(ListLink): - """SHALL contain a Link to a List of CustomerAccount instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(CustomerAccountListLink, self).__init__() - def factory(*args_, **kwargs_): - if CustomerAccountListLink.subclass: - return CustomerAccountListLink.subclass(*args_, **kwargs_) - else: - return CustomerAccountListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(CustomerAccountListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CustomerAccountListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAccountListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CustomerAccountListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CustomerAccountListLink'): - super(CustomerAccountListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAccountListLink') - def exportChildren(self, outfile, level, namespace_='', name_='CustomerAccountListLink', fromsubclass_=False, pretty_print=True): - super(CustomerAccountListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='CustomerAccountListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CustomerAccountListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CustomerAccountListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CustomerAccountListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(CustomerAccountListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class CustomerAccountListLink - - -class CustomerAccountLink(Link): - """SHALL contain a Link to an instance of CustomerAccount.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(CustomerAccountLink, self).__init__() - def factory(*args_, **kwargs_): - if CustomerAccountLink.subclass: - return CustomerAccountLink.subclass(*args_, **kwargs_) - else: - return CustomerAccountLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(CustomerAccountLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CustomerAccountLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAccountLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CustomerAccountLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CustomerAccountLink'): - super(CustomerAccountLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAccountLink') - def exportChildren(self, outfile, level, namespace_='', name_='CustomerAccountLink', fromsubclass_=False, pretty_print=True): - super(CustomerAccountLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='CustomerAccountLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CustomerAccountLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CustomerAccountLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CustomerAccountLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(CustomerAccountLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class CustomerAccountLink - - -class CreditRegisterListLink(ListLink): - """SHALL contain a Link to a List of CreditRegister instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(CreditRegisterListLink, self).__init__() - def factory(*args_, **kwargs_): - if CreditRegisterListLink.subclass: - return CreditRegisterListLink.subclass(*args_, **kwargs_) - else: - return CreditRegisterListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(CreditRegisterListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CreditRegisterListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CreditRegisterListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CreditRegisterListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CreditRegisterListLink'): - super(CreditRegisterListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CreditRegisterListLink') - def exportChildren(self, outfile, level, namespace_='', name_='CreditRegisterListLink', fromsubclass_=False, pretty_print=True): - super(CreditRegisterListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='CreditRegisterListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CreditRegisterListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CreditRegisterListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CreditRegisterListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(CreditRegisterListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class CreditRegisterListLink - - -class ConsumptionTariffIntervalListLink(ListLink): - """SHALL contain a Link to a List of ConsumptionTariffInterval - instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ConsumptionTariffIntervalListLink, self).__init__() - def factory(*args_, **kwargs_): - if ConsumptionTariffIntervalListLink.subclass: - return ConsumptionTariffIntervalListLink.subclass(*args_, **kwargs_) - else: - return ConsumptionTariffIntervalListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ConsumptionTariffIntervalListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ConsumptionTariffIntervalListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ConsumptionTariffIntervalListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ConsumptionTariffIntervalListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ConsumptionTariffIntervalListLink'): - super(ConsumptionTariffIntervalListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ConsumptionTariffIntervalListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ConsumptionTariffIntervalListLink', fromsubclass_=False, pretty_print=True): - super(ConsumptionTariffIntervalListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ConsumptionTariffIntervalListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ConsumptionTariffIntervalListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ConsumptionTariffIntervalListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ConsumptionTariffIntervalListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ConsumptionTariffIntervalListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ConsumptionTariffIntervalListLink - - -class ConfigurationLink(Link): - """SHALL contain a Link to an instance of Configuration.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(ConfigurationLink, self).__init__() - def factory(*args_, **kwargs_): - if ConfigurationLink.subclass: - return ConfigurationLink.subclass(*args_, **kwargs_) - else: - return ConfigurationLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ConfigurationLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ConfigurationLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ConfigurationLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ConfigurationLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ConfigurationLink'): - super(ConfigurationLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ConfigurationLink') - def exportChildren(self, outfile, level, namespace_='', name_='ConfigurationLink', fromsubclass_=False, pretty_print=True): - super(ConfigurationLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ConfigurationLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ConfigurationLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ConfigurationLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ConfigurationLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ConfigurationLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ConfigurationLink - - -class BillingReadingSetListLink(ListLink): - """SHALL contain a Link to a List of BillingReadingSet instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(BillingReadingSetListLink, self).__init__() - def factory(*args_, **kwargs_): - if BillingReadingSetListLink.subclass: - return BillingReadingSetListLink.subclass(*args_, **kwargs_) - else: - return BillingReadingSetListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(BillingReadingSetListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingReadingSetListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingSetListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingReadingSetListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingReadingSetListLink'): - super(BillingReadingSetListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingSetListLink') - def exportChildren(self, outfile, level, namespace_='', name_='BillingReadingSetListLink', fromsubclass_=False, pretty_print=True): - super(BillingReadingSetListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='BillingReadingSetListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingReadingSetListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingReadingSetListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingReadingSetListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(BillingReadingSetListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class BillingReadingSetListLink - - -class BillingReadingListLink(ListLink): - """SHALL contain a Link to a List of BillingReading instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(BillingReadingListLink, self).__init__() - def factory(*args_, **kwargs_): - if BillingReadingListLink.subclass: - return BillingReadingListLink.subclass(*args_, **kwargs_) - else: - return BillingReadingListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(BillingReadingListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingReadingListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingReadingListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingReadingListLink'): - super(BillingReadingListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingListLink') - def exportChildren(self, outfile, level, namespace_='', name_='BillingReadingListLink', fromsubclass_=False, pretty_print=True): - super(BillingReadingListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='BillingReadingListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingReadingListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingReadingListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingReadingListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(BillingReadingListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class BillingReadingListLink - - -class BillingPeriodListLink(ListLink): - """SHALL contain a Link to a List of BillingPeriod instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(BillingPeriodListLink, self).__init__() - def factory(*args_, **kwargs_): - if BillingPeriodListLink.subclass: - return BillingPeriodListLink.subclass(*args_, **kwargs_) - else: - return BillingPeriodListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(BillingPeriodListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingPeriodListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingPeriodListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingPeriodListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingPeriodListLink'): - super(BillingPeriodListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingPeriodListLink') - def exportChildren(self, outfile, level, namespace_='', name_='BillingPeriodListLink', fromsubclass_=False, pretty_print=True): - super(BillingPeriodListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='BillingPeriodListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingPeriodListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingPeriodListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingPeriodListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(BillingPeriodListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class BillingPeriodListLink - - -class AssociatedUsagePointLink(Link): - """SHALL contain a Link to an instance of UsagePoint. If present, this - is the submeter that monitors the DER output.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(AssociatedUsagePointLink, self).__init__() - def factory(*args_, **kwargs_): - if AssociatedUsagePointLink.subclass: - return AssociatedUsagePointLink.subclass(*args_, **kwargs_) - else: - return AssociatedUsagePointLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(AssociatedUsagePointLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AssociatedUsagePointLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AssociatedUsagePointLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AssociatedUsagePointLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AssociatedUsagePointLink'): - super(AssociatedUsagePointLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='AssociatedUsagePointLink') - def exportChildren(self, outfile, level, namespace_='', name_='AssociatedUsagePointLink', fromsubclass_=False, pretty_print=True): - super(AssociatedUsagePointLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='AssociatedUsagePointLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(AssociatedUsagePointLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(AssociatedUsagePointLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(AssociatedUsagePointLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(AssociatedUsagePointLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class AssociatedUsagePointLink - - -class AssociatedDERProgramListLink(ListLink): - """SHALL contain a Link to a List of DERPrograms having the - DERControl(s) for this DER.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(AssociatedDERProgramListLink, self).__init__() - def factory(*args_, **kwargs_): - if AssociatedDERProgramListLink.subclass: - return AssociatedDERProgramListLink.subclass(*args_, **kwargs_) - else: - return AssociatedDERProgramListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(AssociatedDERProgramListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AssociatedDERProgramListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AssociatedDERProgramListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AssociatedDERProgramListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AssociatedDERProgramListLink'): - super(AssociatedDERProgramListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='AssociatedDERProgramListLink') - def exportChildren(self, outfile, level, namespace_='', name_='AssociatedDERProgramListLink', fromsubclass_=False, pretty_print=True): - super(AssociatedDERProgramListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='AssociatedDERProgramListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(AssociatedDERProgramListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(AssociatedDERProgramListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(AssociatedDERProgramListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(AssociatedDERProgramListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class AssociatedDERProgramListLink - - -class ActiveTimeTariffIntervalListLink(ListLink): - """SHALL contain a Link to a List of active TimeTariffInterval - instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveTimeTariffIntervalListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveTimeTariffIntervalListLink.subclass: - return ActiveTimeTariffIntervalListLink.subclass(*args_, **kwargs_) - else: - return ActiveTimeTariffIntervalListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveTimeTariffIntervalListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveTimeTariffIntervalListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveTimeTariffIntervalListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveTimeTariffIntervalListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveTimeTariffIntervalListLink'): - super(ActiveTimeTariffIntervalListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveTimeTariffIntervalListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveTimeTariffIntervalListLink', fromsubclass_=False, pretty_print=True): - super(ActiveTimeTariffIntervalListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveTimeTariffIntervalListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveTimeTariffIntervalListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveTimeTariffIntervalListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveTimeTariffIntervalListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveTimeTariffIntervalListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveTimeTariffIntervalListLink - - -class ActiveTextMessageListLink(ListLink): - """SHALL contain a Link to a List of active TextMessage instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveTextMessageListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveTextMessageListLink.subclass: - return ActiveTextMessageListLink.subclass(*args_, **kwargs_) - else: - return ActiveTextMessageListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveTextMessageListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveTextMessageListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveTextMessageListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveTextMessageListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveTextMessageListLink'): - super(ActiveTextMessageListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveTextMessageListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveTextMessageListLink', fromsubclass_=False, pretty_print=True): - super(ActiveTextMessageListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveTextMessageListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveTextMessageListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveTextMessageListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveTextMessageListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveTextMessageListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveTextMessageListLink - - -class ActiveTargetReadingListLink(ListLink): - """SHALL contain a Link to a List of active TargetReading instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveTargetReadingListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveTargetReadingListLink.subclass: - return ActiveTargetReadingListLink.subclass(*args_, **kwargs_) - else: - return ActiveTargetReadingListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveTargetReadingListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveTargetReadingListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveTargetReadingListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveTargetReadingListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveTargetReadingListLink'): - super(ActiveTargetReadingListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveTargetReadingListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveTargetReadingListLink', fromsubclass_=False, pretty_print=True): - super(ActiveTargetReadingListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveTargetReadingListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveTargetReadingListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveTargetReadingListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveTargetReadingListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveTargetReadingListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveTargetReadingListLink - - -class ActiveSupplyInterruptionOverrideListLink(ListLink): - """SHALL contain a Link to a List of active SupplyInterruptionOverride - instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveSupplyInterruptionOverrideListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveSupplyInterruptionOverrideListLink.subclass: - return ActiveSupplyInterruptionOverrideListLink.subclass(*args_, **kwargs_) - else: - return ActiveSupplyInterruptionOverrideListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveSupplyInterruptionOverrideListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveSupplyInterruptionOverrideListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveSupplyInterruptionOverrideListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveSupplyInterruptionOverrideListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveSupplyInterruptionOverrideListLink'): - super(ActiveSupplyInterruptionOverrideListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveSupplyInterruptionOverrideListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveSupplyInterruptionOverrideListLink', fromsubclass_=False, pretty_print=True): - super(ActiveSupplyInterruptionOverrideListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveSupplyInterruptionOverrideListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveSupplyInterruptionOverrideListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveSupplyInterruptionOverrideListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveSupplyInterruptionOverrideListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveSupplyInterruptionOverrideListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveSupplyInterruptionOverrideListLink - - -class ActiveProjectionReadingListLink(ListLink): - """SHALL contain a Link to a List of active ProjectionReading - instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveProjectionReadingListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveProjectionReadingListLink.subclass: - return ActiveProjectionReadingListLink.subclass(*args_, **kwargs_) - else: - return ActiveProjectionReadingListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveProjectionReadingListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveProjectionReadingListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveProjectionReadingListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveProjectionReadingListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveProjectionReadingListLink'): - super(ActiveProjectionReadingListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveProjectionReadingListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveProjectionReadingListLink', fromsubclass_=False, pretty_print=True): - super(ActiveProjectionReadingListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveProjectionReadingListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveProjectionReadingListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveProjectionReadingListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveProjectionReadingListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveProjectionReadingListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveProjectionReadingListLink - - -class ActiveFlowReservationListLink(ListLink): - """SHALL contain a Link to a List of active FlowReservation instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveFlowReservationListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveFlowReservationListLink.subclass: - return ActiveFlowReservationListLink.subclass(*args_, **kwargs_) - else: - return ActiveFlowReservationListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveFlowReservationListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveFlowReservationListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveFlowReservationListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveFlowReservationListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveFlowReservationListLink'): - super(ActiveFlowReservationListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveFlowReservationListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveFlowReservationListLink', fromsubclass_=False, pretty_print=True): - super(ActiveFlowReservationListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveFlowReservationListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveFlowReservationListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveFlowReservationListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveFlowReservationListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveFlowReservationListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveFlowReservationListLink - - -class ActiveEndDeviceControlListLink(ListLink): - """SHALL contain a Link to a List of active EndDeviceControl instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveEndDeviceControlListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveEndDeviceControlListLink.subclass: - return ActiveEndDeviceControlListLink.subclass(*args_, **kwargs_) - else: - return ActiveEndDeviceControlListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveEndDeviceControlListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveEndDeviceControlListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveEndDeviceControlListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveEndDeviceControlListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveEndDeviceControlListLink'): - super(ActiveEndDeviceControlListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveEndDeviceControlListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveEndDeviceControlListLink', fromsubclass_=False, pretty_print=True): - super(ActiveEndDeviceControlListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveEndDeviceControlListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveEndDeviceControlListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveEndDeviceControlListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveEndDeviceControlListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveEndDeviceControlListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveEndDeviceControlListLink - - -class ActiveDERControlListLink(ListLink): - """SHALL contain a Link to a List of active DERControl instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveDERControlListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveDERControlListLink.subclass: - return ActiveDERControlListLink.subclass(*args_, **kwargs_) - else: - return ActiveDERControlListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveDERControlListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveDERControlListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveDERControlListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveDERControlListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveDERControlListLink'): - super(ActiveDERControlListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveDERControlListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveDERControlListLink', fromsubclass_=False, pretty_print=True): - super(ActiveDERControlListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveDERControlListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveDERControlListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveDERControlListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveDERControlListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveDERControlListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveDERControlListLink - - -class ActiveCreditRegisterListLink(ListLink): - """SHALL contain a Link to a List of active CreditRegister instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveCreditRegisterListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveCreditRegisterListLink.subclass: - return ActiveCreditRegisterListLink.subclass(*args_, **kwargs_) - else: - return ActiveCreditRegisterListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveCreditRegisterListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveCreditRegisterListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveCreditRegisterListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveCreditRegisterListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveCreditRegisterListLink'): - super(ActiveCreditRegisterListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveCreditRegisterListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveCreditRegisterListLink', fromsubclass_=False, pretty_print=True): - super(ActiveCreditRegisterListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveCreditRegisterListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveCreditRegisterListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveCreditRegisterListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveCreditRegisterListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveCreditRegisterListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveCreditRegisterListLink - - -class ActiveBillingPeriodListLink(ListLink): - """SHALL contain a Link to a List of active BillingPeriod instances.""" - subclass = None - superclass = ListLink - def __init__(self): - self.original_tagname_ = None - super(ActiveBillingPeriodListLink, self).__init__() - def factory(*args_, **kwargs_): - if ActiveBillingPeriodListLink.subclass: - return ActiveBillingPeriodListLink.subclass(*args_, **kwargs_) - else: - return ActiveBillingPeriodListLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ActiveBillingPeriodListLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ActiveBillingPeriodListLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveBillingPeriodListLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ActiveBillingPeriodListLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ActiveBillingPeriodListLink'): - super(ActiveBillingPeriodListLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ActiveBillingPeriodListLink') - def exportChildren(self, outfile, level, namespace_='', name_='ActiveBillingPeriodListLink', fromsubclass_=False, pretty_print=True): - super(ActiveBillingPeriodListLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ActiveBillingPeriodListLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ActiveBillingPeriodListLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ActiveBillingPeriodListLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ActiveBillingPeriodListLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ActiveBillingPeriodListLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ActiveBillingPeriodListLink - - -class AccountBalanceLink(Link): - """SHALL contain a Link to an instance of AccountBalance.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(AccountBalanceLink, self).__init__() - def factory(*args_, **kwargs_): - if AccountBalanceLink.subclass: - return AccountBalanceLink.subclass(*args_, **kwargs_) - else: - return AccountBalanceLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(AccountBalanceLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AccountBalanceLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AccountBalanceLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AccountBalanceLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AccountBalanceLink'): - super(AccountBalanceLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='AccountBalanceLink') - def exportChildren(self, outfile, level, namespace_='', name_='AccountBalanceLink', fromsubclass_=False, pretty_print=True): - super(AccountBalanceLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='AccountBalanceLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(AccountBalanceLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(AccountBalanceLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(AccountBalanceLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(AccountBalanceLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class AccountBalanceLink - - -class DERStatus(SubscribableResource): - """DER status information.""" - subclass = None - superclass = SubscribableResource - def __init__(self, genConnectStatus=None, inverterStatus=None, localControlModeStatus=None, manufacturerStatus=None, operationalModeStatus=None, readingTime=None, stateOfChargeStatus=None, storageModeStatus=None, storConnectStatus=None): - self.original_tagname_ = None - super(DERStatus, self).__init__() - self.genConnectStatus = genConnectStatus - self.inverterStatus = inverterStatus - self.localControlModeStatus = localControlModeStatus - self.manufacturerStatus = manufacturerStatus - self.operationalModeStatus = operationalModeStatus - self.readingTime = readingTime - self.stateOfChargeStatus = stateOfChargeStatus - self.storageModeStatus = storageModeStatus - self.storConnectStatus = storConnectStatus - def factory(*args_, **kwargs_): - if DERStatus.subclass: - return DERStatus.subclass(*args_, **kwargs_) - else: - return DERStatus(*args_, **kwargs_) - factory = staticmethod(factory) - def get_genConnectStatus(self): return self.genConnectStatus - def set_genConnectStatus(self, genConnectStatus): self.genConnectStatus = genConnectStatus - def get_inverterStatus(self): return self.inverterStatus - def set_inverterStatus(self, inverterStatus): self.inverterStatus = inverterStatus - def get_localControlModeStatus(self): return self.localControlModeStatus - def set_localControlModeStatus(self, localControlModeStatus): self.localControlModeStatus = localControlModeStatus - def get_manufacturerStatus(self): return self.manufacturerStatus - def set_manufacturerStatus(self, manufacturerStatus): self.manufacturerStatus = manufacturerStatus - def get_operationalModeStatus(self): return self.operationalModeStatus - def set_operationalModeStatus(self, operationalModeStatus): self.operationalModeStatus = operationalModeStatus - def get_readingTime(self): return self.readingTime - def set_readingTime(self, readingTime): self.readingTime = readingTime - def get_stateOfChargeStatus(self): return self.stateOfChargeStatus - def set_stateOfChargeStatus(self, stateOfChargeStatus): self.stateOfChargeStatus = stateOfChargeStatus - def get_storageModeStatus(self): return self.storageModeStatus - def set_storageModeStatus(self, storageModeStatus): self.storageModeStatus = storageModeStatus - def get_storConnectStatus(self): return self.storConnectStatus - def set_storConnectStatus(self, storConnectStatus): self.storConnectStatus = storConnectStatus - def hasContent_(self): - if ( - self.genConnectStatus is not None or - self.inverterStatus is not None or - self.localControlModeStatus is not None or - self.manufacturerStatus is not None or - self.operationalModeStatus is not None or - self.readingTime is not None or - self.stateOfChargeStatus is not None or - self.storageModeStatus is not None or - self.storConnectStatus is not None or - super(DERStatus, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERStatus', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERStatus') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERStatus', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERStatus'): - super(DERStatus, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERStatus') - def exportChildren(self, outfile, level, namespace_='', name_='DERStatus', fromsubclass_=False, pretty_print=True): - super(DERStatus, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.genConnectStatus is not None: - self.genConnectStatus.export(outfile, level, namespace_, name_='genConnectStatus', pretty_print=pretty_print) - if self.inverterStatus is not None: - self.inverterStatus.export(outfile, level, namespace_, name_='inverterStatus', pretty_print=pretty_print) - if self.localControlModeStatus is not None: - self.localControlModeStatus.export(outfile, level, namespace_, name_='localControlModeStatus', pretty_print=pretty_print) - if self.manufacturerStatus is not None: - self.manufacturerStatus.export(outfile, level, namespace_, name_='manufacturerStatus', pretty_print=pretty_print) - if self.operationalModeStatus is not None: - self.operationalModeStatus.export(outfile, level, namespace_, name_='operationalModeStatus', pretty_print=pretty_print) - if self.readingTime is not None: - self.readingTime.export(outfile, level, namespace_, name_='readingTime', pretty_print=pretty_print) - if self.stateOfChargeStatus is not None: - self.stateOfChargeStatus.export(outfile, level, namespace_, name_='stateOfChargeStatus', pretty_print=pretty_print) - if self.storageModeStatus is not None: - self.storageModeStatus.export(outfile, level, namespace_, name_='storageModeStatus', pretty_print=pretty_print) - if self.storConnectStatus is not None: - self.storConnectStatus.export(outfile, level, namespace_, name_='storConnectStatus', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERStatus'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERStatus, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERStatus, self).exportLiteralChildren(outfile, level, name_) - if self.genConnectStatus is not None: - showIndent(outfile, level) - outfile.write('genConnectStatus=model_.ConnectStatusType(\n') - self.genConnectStatus.exportLiteral(outfile, level, name_='genConnectStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.inverterStatus is not None: - showIndent(outfile, level) - outfile.write('inverterStatus=model_.InverterStatusType(\n') - self.inverterStatus.exportLiteral(outfile, level, name_='inverterStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.localControlModeStatus is not None: - showIndent(outfile, level) - outfile.write('localControlModeStatus=model_.LocalControlModeStatusType(\n') - self.localControlModeStatus.exportLiteral(outfile, level, name_='localControlModeStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.manufacturerStatus is not None: - showIndent(outfile, level) - outfile.write('manufacturerStatus=model_.ManufacturerStatusType(\n') - self.manufacturerStatus.exportLiteral(outfile, level, name_='manufacturerStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.operationalModeStatus is not None: - showIndent(outfile, level) - outfile.write('operationalModeStatus=model_.OperationalModeStatusType(\n') - self.operationalModeStatus.exportLiteral(outfile, level, name_='operationalModeStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.readingTime is not None: - showIndent(outfile, level) - outfile.write('readingTime=model_.TimeType(\n') - self.readingTime.exportLiteral(outfile, level, name_='readingTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.stateOfChargeStatus is not None: - showIndent(outfile, level) - outfile.write('stateOfChargeStatus=model_.StateOfChargeStatusType(\n') - self.stateOfChargeStatus.exportLiteral(outfile, level, name_='stateOfChargeStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.storageModeStatus is not None: - showIndent(outfile, level) - outfile.write('storageModeStatus=model_.StorageModeStatusType(\n') - self.storageModeStatus.exportLiteral(outfile, level, name_='storageModeStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.storConnectStatus is not None: - showIndent(outfile, level) - outfile.write('storConnectStatus=model_.ConnectStatusType(\n') - self.storConnectStatus.exportLiteral(outfile, level, name_='storConnectStatus') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERStatus, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'genConnectStatus': - obj_ = ConnectStatusType.factory() - obj_.build(child_) - self.genConnectStatus = obj_ - obj_.original_tagname_ = 'genConnectStatus' - elif nodeName_ == 'inverterStatus': - obj_ = InverterStatusType.factory() - obj_.build(child_) - self.inverterStatus = obj_ - obj_.original_tagname_ = 'inverterStatus' - elif nodeName_ == 'localControlModeStatus': - obj_ = LocalControlModeStatusType.factory() - obj_.build(child_) - self.localControlModeStatus = obj_ - obj_.original_tagname_ = 'localControlModeStatus' - elif nodeName_ == 'manufacturerStatus': - obj_ = ManufacturerStatusType.factory() - obj_.build(child_) - self.manufacturerStatus = obj_ - obj_.original_tagname_ = 'manufacturerStatus' - elif nodeName_ == 'operationalModeStatus': - obj_ = OperationalModeStatusType.factory() - obj_.build(child_) - self.operationalModeStatus = obj_ - obj_.original_tagname_ = 'operationalModeStatus' - elif nodeName_ == 'readingTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.readingTime = obj_ - obj_.original_tagname_ = 'readingTime' - elif nodeName_ == 'stateOfChargeStatus': - obj_ = StateOfChargeStatusType.factory() - obj_.build(child_) - self.stateOfChargeStatus = obj_ - obj_.original_tagname_ = 'stateOfChargeStatus' - elif nodeName_ == 'storageModeStatus': - obj_ = StorageModeStatusType.factory() - obj_.build(child_) - self.storageModeStatus = obj_ - obj_.original_tagname_ = 'storageModeStatus' - elif nodeName_ == 'storConnectStatus': - obj_ = ConnectStatusType.factory() - obj_.build(child_) - self.storConnectStatus = obj_ - obj_.original_tagname_ = 'storConnectStatus' - super(DERStatus, self).buildChildren(child_, node, nodeName_, True) -# end class DERStatus - - -class DERProgramList(List): - """A List element to hold DERProgram objects.""" - subclass = None - superclass = List - def __init__(self, DERProgram=None): - self.original_tagname_ = None - super(DERProgramList, self).__init__() - if DERProgram is None: - self.DERProgram = [] - else: - self.DERProgram = DERProgram - def factory(*args_, **kwargs_): - if DERProgramList.subclass: - return DERProgramList.subclass(*args_, **kwargs_) - else: - return DERProgramList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DERProgram(self): return self.DERProgram - def set_DERProgram(self, DERProgram): self.DERProgram = DERProgram - def add_DERProgram(self, value): self.DERProgram.append(value) - def insert_DERProgram_at(self, index, value): self.DERProgram.insert(index, value) - def replace_DERProgram_at(self, index, value): self.DERProgram[index] = value - def hasContent_(self): - if ( - self.DERProgram or - super(DERProgramList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERProgramList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERProgramList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERProgramList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERProgramList'): - super(DERProgramList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERProgramList') - def exportChildren(self, outfile, level, namespace_='', name_='DERProgramList', fromsubclass_=False, pretty_print=True): - super(DERProgramList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for DERProgram_ in self.DERProgram: - DERProgram_.export(outfile, level, namespace_, name_='DERProgram', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERProgramList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERProgramList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERProgramList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('DERProgram=[\n') - level += 1 - for DERProgram_ in self.DERProgram: - showIndent(outfile, level) - outfile.write('model_.DERProgram(\n') - DERProgram_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERProgramList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DERProgram': - obj_ = DERProgram.factory() - obj_.build(child_) - self.DERProgram.append(obj_) - obj_.original_tagname_ = 'DERProgram' - super(DERProgramList, self).buildChildren(child_, node, nodeName_, True) -# end class DERProgramList - - -class DERProgram(IdentifiedObject): - """Distributed Energy Resource program.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, ActiveDERControlListLink=None, DefaultDERControlLink=None, DERControlListLink=None, DERCurveListLink=None, primacy=None): - self.original_tagname_ = None - super(DERProgram, self).__init__() - self.ActiveDERControlListLink = ActiveDERControlListLink - self.DefaultDERControlLink = DefaultDERControlLink - self.DERControlListLink = DERControlListLink - self.DERCurveListLink = DERCurveListLink - self.primacy = primacy - def factory(*args_, **kwargs_): - if DERProgram.subclass: - return DERProgram.subclass(*args_, **kwargs_) - else: - return DERProgram(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ActiveDERControlListLink(self): return self.ActiveDERControlListLink - def set_ActiveDERControlListLink(self, ActiveDERControlListLink): self.ActiveDERControlListLink = ActiveDERControlListLink - def get_DefaultDERControlLink(self): return self.DefaultDERControlLink - def set_DefaultDERControlLink(self, DefaultDERControlLink): self.DefaultDERControlLink = DefaultDERControlLink - def get_DERControlListLink(self): return self.DERControlListLink - def set_DERControlListLink(self, DERControlListLink): self.DERControlListLink = DERControlListLink - def get_DERCurveListLink(self): return self.DERCurveListLink - def set_DERCurveListLink(self, DERCurveListLink): self.DERCurveListLink = DERCurveListLink - def get_primacy(self): return self.primacy - def set_primacy(self, primacy): self.primacy = primacy - def hasContent_(self): - if ( - self.ActiveDERControlListLink is not None or - self.DefaultDERControlLink is not None or - self.DERControlListLink is not None or - self.DERCurveListLink is not None or - self.primacy is not None or - super(DERProgram, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERProgram', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERProgram') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERProgram', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERProgram'): - super(DERProgram, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERProgram') - def exportChildren(self, outfile, level, namespace_='', name_='DERProgram', fromsubclass_=False, pretty_print=True): - super(DERProgram, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ActiveDERControlListLink is not None: - self.ActiveDERControlListLink.export(outfile, level, namespace_, name_='ActiveDERControlListLink', pretty_print=pretty_print) - if self.DefaultDERControlLink is not None: - self.DefaultDERControlLink.export(outfile, level, namespace_, name_='DefaultDERControlLink', pretty_print=pretty_print) - if self.DERControlListLink is not None: - self.DERControlListLink.export(outfile, level, namespace_, name_='DERControlListLink', pretty_print=pretty_print) - if self.DERCurveListLink is not None: - self.DERCurveListLink.export(outfile, level, namespace_, name_='DERCurveListLink', pretty_print=pretty_print) - if self.primacy is not None: - self.primacy.export(outfile, level, namespace_, name_='primacy', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERProgram'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERProgram, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERProgram, self).exportLiteralChildren(outfile, level, name_) - if self.ActiveDERControlListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveDERControlListLink=model_.ActiveDERControlListLink(\n') - self.ActiveDERControlListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DefaultDERControlLink is not None: - showIndent(outfile, level) - outfile.write('DefaultDERControlLink=model_.DefaultDERControlLink(\n') - self.DefaultDERControlLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DERControlListLink is not None: - showIndent(outfile, level) - outfile.write('DERControlListLink=model_.DERControlListLink(\n') - self.DERControlListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DERCurveListLink is not None: - showIndent(outfile, level) - outfile.write('DERCurveListLink=model_.DERCurveListLink(\n') - self.DERCurveListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.primacy is not None: - showIndent(outfile, level) - outfile.write('primacy=model_.PrimacyType(\n') - self.primacy.exportLiteral(outfile, level, name_='primacy') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERProgram, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ActiveDERControlListLink': - obj_ = ActiveDERControlListLink.factory() - obj_.build(child_) - self.ActiveDERControlListLink = obj_ - obj_.original_tagname_ = 'ActiveDERControlListLink' - elif nodeName_ == 'DefaultDERControlLink': - obj_ = DefaultDERControlLink.factory() - obj_.build(child_) - self.DefaultDERControlLink = obj_ - obj_.original_tagname_ = 'DefaultDERControlLink' - elif nodeName_ == 'DERControlListLink': - obj_ = DERControlListLink.factory() - obj_.build(child_) - self.DERControlListLink = obj_ - obj_.original_tagname_ = 'DERControlListLink' - elif nodeName_ == 'DERCurveListLink': - obj_ = DERCurveListLink.factory() - obj_.build(child_) - self.DERCurveListLink = obj_ - obj_.original_tagname_ = 'DERCurveListLink' - elif nodeName_ == 'primacy': - obj_ = PrimacyType.factory() - obj_.build(child_) - self.primacy = obj_ - obj_.original_tagname_ = 'primacy' - super(DERProgram, self).buildChildren(child_, node, nodeName_, True) -# end class DERProgram - - -class DERCurveList(List): - """A List element to hold DERCurve objects.""" - subclass = None - superclass = List - def __init__(self, DERCurve=None): - self.original_tagname_ = None - super(DERCurveList, self).__init__() - if DERCurve is None: - self.DERCurve = [] - else: - self.DERCurve = DERCurve - def factory(*args_, **kwargs_): - if DERCurveList.subclass: - return DERCurveList.subclass(*args_, **kwargs_) - else: - return DERCurveList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DERCurve(self): return self.DERCurve - def set_DERCurve(self, DERCurve): self.DERCurve = DERCurve - def add_DERCurve(self, value): self.DERCurve.append(value) - def insert_DERCurve_at(self, index, value): self.DERCurve.insert(index, value) - def replace_DERCurve_at(self, index, value): self.DERCurve[index] = value - def hasContent_(self): - if ( - self.DERCurve or - super(DERCurveList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERCurveList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurveList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERCurveList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERCurveList'): - super(DERCurveList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurveList') - def exportChildren(self, outfile, level, namespace_='', name_='DERCurveList', fromsubclass_=False, pretty_print=True): - super(DERCurveList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for DERCurve_ in self.DERCurve: - DERCurve_.export(outfile, level, namespace_, name_='DERCurve', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERCurveList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERCurveList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERCurveList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('DERCurve=[\n') - level += 1 - for DERCurve_ in self.DERCurve: - showIndent(outfile, level) - outfile.write('model_.DERCurve(\n') - DERCurve_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERCurveList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DERCurve': - obj_ = DERCurve.factory() - obj_.build(child_) - self.DERCurve.append(obj_) - obj_.original_tagname_ = 'DERCurve' - super(DERCurveList, self).buildChildren(child_, node, nodeName_, True) -# end class DERCurveList - - -class CurrentDERProgramLink(Link): - """SHALL contain a Link to an instance of DERProgram. If present, this - is the DERProgram containing the currently active DERControl.""" - subclass = None - superclass = Link - def __init__(self): - self.original_tagname_ = None - super(CurrentDERProgramLink, self).__init__() - def factory(*args_, **kwargs_): - if CurrentDERProgramLink.subclass: - return CurrentDERProgramLink.subclass(*args_, **kwargs_) - else: - return CurrentDERProgramLink(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(CurrentDERProgramLink, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CurrentDERProgramLink', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CurrentDERProgramLink') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CurrentDERProgramLink', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CurrentDERProgramLink'): - super(CurrentDERProgramLink, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CurrentDERProgramLink') - def exportChildren(self, outfile, level, namespace_='', name_='CurrentDERProgramLink', fromsubclass_=False, pretty_print=True): - super(CurrentDERProgramLink, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='CurrentDERProgramLink'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CurrentDERProgramLink, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CurrentDERProgramLink, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CurrentDERProgramLink, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(CurrentDERProgramLink, self).buildChildren(child_, node, nodeName_, True) - pass -# end class CurrentDERProgramLink - - -class DERCurve(IdentifiedObject): - """DER related curves such as Volt-VAr mode curves. Relationship - between an independent variable (X-axis) and one or two - dependent variables (Y-axis and excitation).""" - subclass = None - superclass = IdentifiedObject - def __init__(self, creationTime=None, CurveData=None, curveType=None, rampDecTms=None, rampIncTms=None, rampPT1Tms=None, xMultiplier=None, yMultiplier=None, yRefType=None): - self.original_tagname_ = None - super(DERCurve, self).__init__() - self.creationTime = creationTime - if CurveData is None: - self.CurveData = [] - else: - self.CurveData = CurveData - self.curveType = curveType - self.rampDecTms = rampDecTms - self.rampIncTms = rampIncTms - self.rampPT1Tms = rampPT1Tms - self.xMultiplier = xMultiplier - self.yMultiplier = yMultiplier - self.yRefType = yRefType - def factory(*args_, **kwargs_): - if DERCurve.subclass: - return DERCurve.subclass(*args_, **kwargs_) - else: - return DERCurve(*args_, **kwargs_) - factory = staticmethod(factory) - def get_creationTime(self): return self.creationTime - def set_creationTime(self, creationTime): self.creationTime = creationTime - def get_CurveData(self): return self.CurveData - def set_CurveData(self, CurveData): self.CurveData = CurveData - def add_CurveData(self, value): self.CurveData.append(value) - def insert_CurveData_at(self, index, value): self.CurveData.insert(index, value) - def replace_CurveData_at(self, index, value): self.CurveData[index] = value - def get_curveType(self): return self.curveType - def set_curveType(self, curveType): self.curveType = curveType - def get_rampDecTms(self): return self.rampDecTms - def set_rampDecTms(self, rampDecTms): self.rampDecTms = rampDecTms - def get_rampIncTms(self): return self.rampIncTms - def set_rampIncTms(self, rampIncTms): self.rampIncTms = rampIncTms - def get_rampPT1Tms(self): return self.rampPT1Tms - def set_rampPT1Tms(self, rampPT1Tms): self.rampPT1Tms = rampPT1Tms - def get_xMultiplier(self): return self.xMultiplier - def set_xMultiplier(self, xMultiplier): self.xMultiplier = xMultiplier - def get_yMultiplier(self): return self.yMultiplier - def set_yMultiplier(self, yMultiplier): self.yMultiplier = yMultiplier - def get_yRefType(self): return self.yRefType - def set_yRefType(self, yRefType): self.yRefType = yRefType - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.creationTime is not None or - self.CurveData or - self.curveType is not None or - self.rampDecTms is not None or - self.rampIncTms is not None or - self.rampPT1Tms is not None or - self.xMultiplier is not None or - self.yMultiplier is not None or - self.yRefType is not None or - super(DERCurve, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERCurve', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurve') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERCurve', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERCurve'): - super(DERCurve, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERCurve') - def exportChildren(self, outfile, level, namespace_='', name_='DERCurve', fromsubclass_=False, pretty_print=True): - super(DERCurve, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.creationTime is not None: - self.creationTime.export(outfile, level, namespace_, name_='creationTime', pretty_print=pretty_print) - for CurveData_ in self.CurveData: - CurveData_.export(outfile, level, namespace_, name_='CurveData', pretty_print=pretty_print) - if self.curveType is not None: - self.curveType.export(outfile, level, namespace_, name_='curveType', pretty_print=pretty_print) - if self.rampDecTms is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srampDecTms>%s%s' % (namespace_, self.gds_format_integer(self.rampDecTms, input_name='rampDecTms'), namespace_, eol_)) - if self.rampIncTms is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srampIncTms>%s%s' % (namespace_, self.gds_format_integer(self.rampIncTms, input_name='rampIncTms'), namespace_, eol_)) - if self.rampPT1Tms is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srampPT1Tms>%s%s' % (namespace_, self.gds_format_integer(self.rampPT1Tms, input_name='rampPT1Tms'), namespace_, eol_)) - if self.xMultiplier is not None: - self.xMultiplier.export(outfile, level, namespace_, name_='xMultiplier', pretty_print=pretty_print) - if self.yMultiplier is not None: - self.yMultiplier.export(outfile, level, namespace_, name_='yMultiplier', pretty_print=pretty_print) - if self.yRefType is not None: - self.yRefType.export(outfile, level, namespace_, name_='yRefType', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERCurve'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERCurve, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERCurve, self).exportLiteralChildren(outfile, level, name_) - if self.creationTime is not None: - showIndent(outfile, level) - outfile.write('creationTime=model_.TimeType(\n') - self.creationTime.exportLiteral(outfile, level, name_='creationTime') - showIndent(outfile, level) - outfile.write('),\n') - showIndent(outfile, level) - outfile.write('CurveData=[\n') - level += 1 - for CurveData_ in self.CurveData: - showIndent(outfile, level) - outfile.write('model_.CurveData(\n') - CurveData_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - if self.curveType is not None: - showIndent(outfile, level) - outfile.write('curveType=model_.DERCurveType(\n') - self.curveType.exportLiteral(outfile, level, name_='curveType') - showIndent(outfile, level) - outfile.write('),\n') - if self.rampDecTms is not None: - showIndent(outfile, level) - outfile.write('rampDecTms=%d,\n' % self.rampDecTms) - if self.rampIncTms is not None: - showIndent(outfile, level) - outfile.write('rampIncTms=%d,\n' % self.rampIncTms) - if self.rampPT1Tms is not None: - showIndent(outfile, level) - outfile.write('rampPT1Tms=%d,\n' % self.rampPT1Tms) - if self.xMultiplier is not None: - showIndent(outfile, level) - outfile.write('xMultiplier=model_.PowerOfTenMultiplierType(\n') - self.xMultiplier.exportLiteral(outfile, level, name_='xMultiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.yMultiplier is not None: - showIndent(outfile, level) - outfile.write('yMultiplier=model_.PowerOfTenMultiplierType(\n') - self.yMultiplier.exportLiteral(outfile, level, name_='yMultiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.yRefType is not None: - showIndent(outfile, level) - outfile.write('yRefType=model_.DERUnitRefType(\n') - self.yRefType.exportLiteral(outfile, level, name_='yRefType') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERCurve, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'creationTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.creationTime = obj_ - obj_.original_tagname_ = 'creationTime' - elif nodeName_ == 'CurveData': - obj_ = CurveData.factory() - obj_.build(child_) - self.CurveData.append(obj_) - obj_.original_tagname_ = 'CurveData' - elif nodeName_ == 'curveType': - obj_ = DERCurveType.factory() - obj_.build(child_) - self.curveType = obj_ - obj_.original_tagname_ = 'curveType' - elif nodeName_ == 'rampDecTms': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'rampDecTms') - self.rampDecTms = ival_ - self.validate_UInt16(self.rampDecTms) # validate type UInt16 - elif nodeName_ == 'rampIncTms': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'rampIncTms') - self.rampIncTms = ival_ - self.validate_UInt16(self.rampIncTms) # validate type UInt16 - elif nodeName_ == 'rampPT1Tms': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'rampPT1Tms') - self.rampPT1Tms = ival_ - self.validate_UInt16(self.rampPT1Tms) # validate type UInt16 - elif nodeName_ == 'xMultiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.xMultiplier = obj_ - obj_.original_tagname_ = 'xMultiplier' - elif nodeName_ == 'yMultiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.yMultiplier = obj_ - obj_.original_tagname_ = 'yMultiplier' - elif nodeName_ == 'yRefType': - obj_ = DERUnitRefType.factory() - obj_.build(child_) - self.yRefType = obj_ - obj_.original_tagname_ = 'yRefType' - super(DERCurve, self).buildChildren(child_, node, nodeName_, True) -# end class DERCurve - - -class DERControlList(SubscribableList): - """A List element to hold DERControl objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, DERControl=None): - self.original_tagname_ = None - super(DERControlList, self).__init__() - if DERControl is None: - self.DERControl = [] - else: - self.DERControl = DERControl - def factory(*args_, **kwargs_): - if DERControlList.subclass: - return DERControlList.subclass(*args_, **kwargs_) - else: - return DERControlList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DERControl(self): return self.DERControl - def set_DERControl(self, DERControl): self.DERControl = DERControl - def add_DERControl(self, value): self.DERControl.append(value) - def insert_DERControl_at(self, index, value): self.DERControl.insert(index, value) - def replace_DERControl_at(self, index, value): self.DERControl[index] = value - def hasContent_(self): - if ( - self.DERControl or - super(DERControlList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERControlList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERControlList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERControlList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERControlList'): - super(DERControlList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERControlList') - def exportChildren(self, outfile, level, namespace_='', name_='DERControlList', fromsubclass_=False, pretty_print=True): - super(DERControlList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for DERControl_ in self.DERControl: - DERControl_.export(outfile, level, namespace_, name_='DERControl', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERControlList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERControlList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERControlList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('DERControl=[\n') - level += 1 - for DERControl_ in self.DERControl: - showIndent(outfile, level) - outfile.write('model_.DERControl(\n') - DERControl_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERControlList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DERControl': - obj_ = DERControl.factory() - obj_.build(child_) - self.DERControl.append(obj_) - obj_.original_tagname_ = 'DERControl' - super(DERControlList, self).buildChildren(child_, node, nodeName_, True) -# end class DERControlList - - -class DERControl(RandomizableEvent): - """Distributed Energy Resource (DER) time/event-based control.""" - subclass = None - superclass = RandomizableEvent - def __init__(self, DERControlBase=None): - self.original_tagname_ = None - super(DERControl, self).__init__() - self.DERControlBase = DERControlBase - def factory(*args_, **kwargs_): - if DERControl.subclass: - return DERControl.subclass(*args_, **kwargs_) - else: - return DERControl(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DERControlBase(self): return self.DERControlBase - def set_DERControlBase(self, DERControlBase): self.DERControlBase = DERControlBase - def hasContent_(self): - if ( - self.DERControlBase is not None or - super(DERControl, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERControl', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERControl') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERControl', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERControl'): - super(DERControl, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERControl') - def exportChildren(self, outfile, level, namespace_='', name_='DERControl', fromsubclass_=False, pretty_print=True): - super(DERControl, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.DERControlBase is not None: - self.DERControlBase.export(outfile, level, namespace_, name_='DERControlBase', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERControl'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERControl, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERControl, self).exportLiteralChildren(outfile, level, name_) - if self.DERControlBase is not None: - showIndent(outfile, level) - outfile.write('DERControlBase=model_.DERControlBase(\n') - self.DERControlBase.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERControl, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DERControlBase': - obj_ = DERControlBase.factory() - obj_.build(child_) - self.DERControlBase = obj_ - obj_.original_tagname_ = 'DERControlBase' - super(DERControl, self).buildChildren(child_, node, nodeName_, True) -# end class DERControl - - -class DERCapability(Resource): - """Distributed energy resource type and nameplate ratings.""" - subclass = None - superclass = Resource - def __init__(self, modesSupported=None, rtgA=None, rtgAh=None, rtgMaxChargeRate=None, rtgMaxDischargeRate=None, rtgMinPF=None, rtgMinPFNeg=None, rtgVA=None, rtgVAr=None, rtgVArNeg=None, rtgW=None, rtgWh=None, type_=None): - self.original_tagname_ = None - super(DERCapability, self).__init__() - self.modesSupported = modesSupported - self.rtgA = rtgA - self.rtgAh = rtgAh - self.rtgMaxChargeRate = rtgMaxChargeRate - self.rtgMaxDischargeRate = rtgMaxDischargeRate - self.rtgMinPF = rtgMinPF - self.rtgMinPFNeg = rtgMinPFNeg - self.rtgVA = rtgVA - self.rtgVAr = rtgVAr - self.rtgVArNeg = rtgVArNeg - self.rtgW = rtgW - self.rtgWh = rtgWh - self.type_ = type_ - def factory(*args_, **kwargs_): - if DERCapability.subclass: - return DERCapability.subclass(*args_, **kwargs_) - else: - return DERCapability(*args_, **kwargs_) - factory = staticmethod(factory) - def get_modesSupported(self): return self.modesSupported - def set_modesSupported(self, modesSupported): self.modesSupported = modesSupported - def get_rtgA(self): return self.rtgA - def set_rtgA(self, rtgA): self.rtgA = rtgA - def get_rtgAh(self): return self.rtgAh - def set_rtgAh(self, rtgAh): self.rtgAh = rtgAh - def get_rtgMaxChargeRate(self): return self.rtgMaxChargeRate - def set_rtgMaxChargeRate(self, rtgMaxChargeRate): self.rtgMaxChargeRate = rtgMaxChargeRate - def get_rtgMaxDischargeRate(self): return self.rtgMaxDischargeRate - def set_rtgMaxDischargeRate(self, rtgMaxDischargeRate): self.rtgMaxDischargeRate = rtgMaxDischargeRate - def get_rtgMinPF(self): return self.rtgMinPF - def set_rtgMinPF(self, rtgMinPF): self.rtgMinPF = rtgMinPF - def get_rtgMinPFNeg(self): return self.rtgMinPFNeg - def set_rtgMinPFNeg(self, rtgMinPFNeg): self.rtgMinPFNeg = rtgMinPFNeg - def get_rtgVA(self): return self.rtgVA - def set_rtgVA(self, rtgVA): self.rtgVA = rtgVA - def get_rtgVAr(self): return self.rtgVAr - def set_rtgVAr(self, rtgVAr): self.rtgVAr = rtgVAr - def get_rtgVArNeg(self): return self.rtgVArNeg - def set_rtgVArNeg(self, rtgVArNeg): self.rtgVArNeg = rtgVArNeg - def get_rtgW(self): return self.rtgW - def set_rtgW(self, rtgW): self.rtgW = rtgW - def get_rtgWh(self): return self.rtgWh - def set_rtgWh(self, rtgWh): self.rtgWh = rtgWh - def get_type(self): return self.type_ - def set_type(self, type_): self.type_ = type_ - def hasContent_(self): - if ( - self.modesSupported is not None or - self.rtgA is not None or - self.rtgAh is not None or - self.rtgMaxChargeRate is not None or - self.rtgMaxDischargeRate is not None or - self.rtgMinPF is not None or - self.rtgMinPFNeg is not None or - self.rtgVA is not None or - self.rtgVAr is not None or - self.rtgVArNeg is not None or - self.rtgW is not None or - self.rtgWh is not None or - self.type_ is not None or - super(DERCapability, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERCapability', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERCapability') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERCapability', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERCapability'): - super(DERCapability, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERCapability') - def exportChildren(self, outfile, level, namespace_='', name_='DERCapability', fromsubclass_=False, pretty_print=True): - super(DERCapability, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.modesSupported is not None: - self.modesSupported.export(outfile, level, namespace_, name_='modesSupported', pretty_print=pretty_print) - if self.rtgA is not None: - self.rtgA.export(outfile, level, namespace_, name_='rtgA', pretty_print=pretty_print) - if self.rtgAh is not None: - self.rtgAh.export(outfile, level, namespace_, name_='rtgAh', pretty_print=pretty_print) - if self.rtgMaxChargeRate is not None: - self.rtgMaxChargeRate.export(outfile, level, namespace_, name_='rtgMaxChargeRate', pretty_print=pretty_print) - if self.rtgMaxDischargeRate is not None: - self.rtgMaxDischargeRate.export(outfile, level, namespace_, name_='rtgMaxDischargeRate', pretty_print=pretty_print) - if self.rtgMinPF is not None: - self.rtgMinPF.export(outfile, level, namespace_, name_='rtgMinPF', pretty_print=pretty_print) - if self.rtgMinPFNeg is not None: - self.rtgMinPFNeg.export(outfile, level, namespace_, name_='rtgMinPFNeg', pretty_print=pretty_print) - if self.rtgVA is not None: - self.rtgVA.export(outfile, level, namespace_, name_='rtgVA', pretty_print=pretty_print) - if self.rtgVAr is not None: - self.rtgVAr.export(outfile, level, namespace_, name_='rtgVAr', pretty_print=pretty_print) - if self.rtgVArNeg is not None: - self.rtgVArNeg.export(outfile, level, namespace_, name_='rtgVArNeg', pretty_print=pretty_print) - if self.rtgW is not None: - self.rtgW.export(outfile, level, namespace_, name_='rtgW', pretty_print=pretty_print) - if self.rtgWh is not None: - self.rtgWh.export(outfile, level, namespace_, name_='rtgWh', pretty_print=pretty_print) - if self.type_ is not None: - self.type_.export(outfile, level, namespace_, name_='type', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERCapability'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERCapability, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERCapability, self).exportLiteralChildren(outfile, level, name_) - if self.modesSupported is not None: - showIndent(outfile, level) - outfile.write('modesSupported=model_.DERControlType(\n') - self.modesSupported.exportLiteral(outfile, level, name_='modesSupported') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgA is not None: - showIndent(outfile, level) - outfile.write('rtgA=model_.CurrentRMS(\n') - self.rtgA.exportLiteral(outfile, level, name_='rtgA') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgAh is not None: - showIndent(outfile, level) - outfile.write('rtgAh=model_.AmpereHour(\n') - self.rtgAh.exportLiteral(outfile, level, name_='rtgAh') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgMaxChargeRate is not None: - showIndent(outfile, level) - outfile.write('rtgMaxChargeRate=model_.ActivePower(\n') - self.rtgMaxChargeRate.exportLiteral(outfile, level, name_='rtgMaxChargeRate') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgMaxDischargeRate is not None: - showIndent(outfile, level) - outfile.write('rtgMaxDischargeRate=model_.ActivePower(\n') - self.rtgMaxDischargeRate.exportLiteral(outfile, level, name_='rtgMaxDischargeRate') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgMinPF is not None: - showIndent(outfile, level) - outfile.write('rtgMinPF=model_.UnsignedFixedPointType(\n') - self.rtgMinPF.exportLiteral(outfile, level, name_='rtgMinPF') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgMinPFNeg is not None: - showIndent(outfile, level) - outfile.write('rtgMinPFNeg=model_.FixedPointType(\n') - self.rtgMinPFNeg.exportLiteral(outfile, level, name_='rtgMinPFNeg') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgVA is not None: - showIndent(outfile, level) - outfile.write('rtgVA=model_.ApparentPower(\n') - self.rtgVA.exportLiteral(outfile, level, name_='rtgVA') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgVAr is not None: - showIndent(outfile, level) - outfile.write('rtgVAr=model_.ReactivePower(\n') - self.rtgVAr.exportLiteral(outfile, level, name_='rtgVAr') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgVArNeg is not None: - showIndent(outfile, level) - outfile.write('rtgVArNeg=model_.ReactivePower(\n') - self.rtgVArNeg.exportLiteral(outfile, level, name_='rtgVArNeg') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgW is not None: - showIndent(outfile, level) - outfile.write('rtgW=model_.ActivePower(\n') - self.rtgW.exportLiteral(outfile, level, name_='rtgW') - showIndent(outfile, level) - outfile.write('),\n') - if self.rtgWh is not None: - showIndent(outfile, level) - outfile.write('rtgWh=model_.WattHour(\n') - self.rtgWh.exportLiteral(outfile, level, name_='rtgWh') - showIndent(outfile, level) - outfile.write('),\n') - if self.type_ is not None: - showIndent(outfile, level) - outfile.write('type_=model_.DERType(\n') - self.type_.exportLiteral(outfile, level, name_='type') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERCapability, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'modesSupported': - obj_ = DERControlType.factory() - obj_.build(child_) - self.modesSupported = obj_ - obj_.original_tagname_ = 'modesSupported' - elif nodeName_ == 'rtgA': - obj_ = CurrentRMS.factory() - obj_.build(child_) - self.rtgA = obj_ - obj_.original_tagname_ = 'rtgA' - elif nodeName_ == 'rtgAh': - obj_ = AmpereHour.factory() - obj_.build(child_) - self.rtgAh = obj_ - obj_.original_tagname_ = 'rtgAh' - elif nodeName_ == 'rtgMaxChargeRate': - obj_ = ActivePower.factory() - obj_.build(child_) - self.rtgMaxChargeRate = obj_ - obj_.original_tagname_ = 'rtgMaxChargeRate' - elif nodeName_ == 'rtgMaxDischargeRate': - obj_ = ActivePower.factory() - obj_.build(child_) - self.rtgMaxDischargeRate = obj_ - obj_.original_tagname_ = 'rtgMaxDischargeRate' - elif nodeName_ == 'rtgMinPF': - obj_ = UnsignedFixedPointType.factory() - obj_.build(child_) - self.rtgMinPF = obj_ - obj_.original_tagname_ = 'rtgMinPF' - elif nodeName_ == 'rtgMinPFNeg': - obj_ = FixedPointType.factory() - obj_.build(child_) - self.rtgMinPFNeg = obj_ - obj_.original_tagname_ = 'rtgMinPFNeg' - elif nodeName_ == 'rtgVA': - obj_ = ApparentPower.factory() - obj_.build(child_) - self.rtgVA = obj_ - obj_.original_tagname_ = 'rtgVA' - elif nodeName_ == 'rtgVAr': - obj_ = ReactivePower.factory() - obj_.build(child_) - self.rtgVAr = obj_ - obj_.original_tagname_ = 'rtgVAr' - elif nodeName_ == 'rtgVArNeg': - obj_ = ReactivePower.factory() - obj_.build(child_) - self.rtgVArNeg = obj_ - obj_.original_tagname_ = 'rtgVArNeg' - elif nodeName_ == 'rtgW': - obj_ = ActivePower.factory() - obj_.build(child_) - self.rtgW = obj_ - obj_.original_tagname_ = 'rtgW' - elif nodeName_ == 'rtgWh': - obj_ = WattHour.factory() - obj_.build(child_) - self.rtgWh = obj_ - obj_.original_tagname_ = 'rtgWh' - elif nodeName_ == 'type': - obj_ = DERType.factory() - obj_.build(child_) - self.type_ = obj_ - obj_.original_tagname_ = 'type' - super(DERCapability, self).buildChildren(child_, node, nodeName_, True) -# end class DERCapability - - -class DERAvailability(SubscribableResource): - """Indicates current reserve generation status""" - subclass = None - superclass = SubscribableResource - def __init__(self, availabilityDuration=None, maxChargeDuration=None, readingTime=None, reserveChargePercent=None, reservePercent=None, statVArAvail=None, statWAvail=None): - self.original_tagname_ = None - super(DERAvailability, self).__init__() - self.availabilityDuration = availabilityDuration - self.maxChargeDuration = maxChargeDuration - self.readingTime = readingTime - self.reserveChargePercent = reserveChargePercent - self.reservePercent = reservePercent - self.statVArAvail = statVArAvail - self.statWAvail = statWAvail - def factory(*args_, **kwargs_): - if DERAvailability.subclass: - return DERAvailability.subclass(*args_, **kwargs_) - else: - return DERAvailability(*args_, **kwargs_) - factory = staticmethod(factory) - def get_availabilityDuration(self): return self.availabilityDuration - def set_availabilityDuration(self, availabilityDuration): self.availabilityDuration = availabilityDuration - def get_maxChargeDuration(self): return self.maxChargeDuration - def set_maxChargeDuration(self, maxChargeDuration): self.maxChargeDuration = maxChargeDuration - def get_readingTime(self): return self.readingTime - def set_readingTime(self, readingTime): self.readingTime = readingTime - def get_reserveChargePercent(self): return self.reserveChargePercent - def set_reserveChargePercent(self, reserveChargePercent): self.reserveChargePercent = reserveChargePercent - def get_reservePercent(self): return self.reservePercent - def set_reservePercent(self, reservePercent): self.reservePercent = reservePercent - def get_statVArAvail(self): return self.statVArAvail - def set_statVArAvail(self, statVArAvail): self.statVArAvail = statVArAvail - def get_statWAvail(self): return self.statWAvail - def set_statWAvail(self, statWAvail): self.statWAvail = statWAvail - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def hasContent_(self): - if ( - self.availabilityDuration is not None or - self.maxChargeDuration is not None or - self.readingTime is not None or - self.reserveChargePercent is not None or - self.reservePercent is not None or - self.statVArAvail is not None or - self.statWAvail is not None or - super(DERAvailability, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERAvailability', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERAvailability') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERAvailability', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERAvailability'): - super(DERAvailability, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERAvailability') - def exportChildren(self, outfile, level, namespace_='', name_='DERAvailability', fromsubclass_=False, pretty_print=True): - super(DERAvailability, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.availabilityDuration is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%savailabilityDuration>%s%s' % (namespace_, self.gds_format_integer(self.availabilityDuration, input_name='availabilityDuration'), namespace_, eol_)) - if self.maxChargeDuration is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smaxChargeDuration>%s%s' % (namespace_, self.gds_format_integer(self.maxChargeDuration, input_name='maxChargeDuration'), namespace_, eol_)) - if self.readingTime is not None: - self.readingTime.export(outfile, level, namespace_, name_='readingTime', pretty_print=pretty_print) - if self.reserveChargePercent is not None: - self.reserveChargePercent.export(outfile, level, namespace_, name_='reserveChargePercent', pretty_print=pretty_print) - if self.reservePercent is not None: - self.reservePercent.export(outfile, level, namespace_, name_='reservePercent', pretty_print=pretty_print) - if self.statVArAvail is not None: - self.statVArAvail.export(outfile, level, namespace_, name_='statVArAvail', pretty_print=pretty_print) - if self.statWAvail is not None: - self.statWAvail.export(outfile, level, namespace_, name_='statWAvail', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERAvailability'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERAvailability, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERAvailability, self).exportLiteralChildren(outfile, level, name_) - if self.availabilityDuration is not None: - showIndent(outfile, level) - outfile.write('availabilityDuration=%d,\n' % self.availabilityDuration) - if self.maxChargeDuration is not None: - showIndent(outfile, level) - outfile.write('maxChargeDuration=%d,\n' % self.maxChargeDuration) - if self.readingTime is not None: - showIndent(outfile, level) - outfile.write('readingTime=model_.TimeType(\n') - self.readingTime.exportLiteral(outfile, level, name_='readingTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.reserveChargePercent is not None: - showIndent(outfile, level) - outfile.write('reserveChargePercent=model_.PerCent(\n') - self.reserveChargePercent.exportLiteral(outfile, level, name_='reserveChargePercent') - showIndent(outfile, level) - outfile.write('),\n') - if self.reservePercent is not None: - showIndent(outfile, level) - outfile.write('reservePercent=model_.PerCent(\n') - self.reservePercent.exportLiteral(outfile, level, name_='reservePercent') - showIndent(outfile, level) - outfile.write('),\n') - if self.statVArAvail is not None: - showIndent(outfile, level) - outfile.write('statVArAvail=model_.ReactivePower(\n') - self.statVArAvail.exportLiteral(outfile, level, name_='statVArAvail') - showIndent(outfile, level) - outfile.write('),\n') - if self.statWAvail is not None: - showIndent(outfile, level) - outfile.write('statWAvail=model_.ActivePower(\n') - self.statWAvail.exportLiteral(outfile, level, name_='statWAvail') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERAvailability, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'availabilityDuration': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'availabilityDuration') - self.availabilityDuration = ival_ - self.validate_UInt32(self.availabilityDuration) # validate type UInt32 - elif nodeName_ == 'maxChargeDuration': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'maxChargeDuration') - self.maxChargeDuration = ival_ - self.validate_UInt32(self.maxChargeDuration) # validate type UInt32 - elif nodeName_ == 'readingTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.readingTime = obj_ - obj_.original_tagname_ = 'readingTime' - elif nodeName_ == 'reserveChargePercent': - obj_ = PerCent.factory() - obj_.build(child_) - self.reserveChargePercent = obj_ - obj_.original_tagname_ = 'reserveChargePercent' - elif nodeName_ == 'reservePercent': - obj_ = PerCent.factory() - obj_.build(child_) - self.reservePercent = obj_ - obj_.original_tagname_ = 'reservePercent' - elif nodeName_ == 'statVArAvail': - obj_ = ReactivePower.factory() - obj_.build(child_) - self.statVArAvail = obj_ - obj_.original_tagname_ = 'statVArAvail' - elif nodeName_ == 'statWAvail': - obj_ = ActivePower.factory() - obj_.build(child_) - self.statWAvail = obj_ - obj_.original_tagname_ = 'statWAvail' - super(DERAvailability, self).buildChildren(child_, node, nodeName_, True) -# end class DERAvailability - - -class DERSettings(SubscribableResource): - """Distributed energy resource settings""" - subclass = None - superclass = SubscribableResource - def __init__(self, setGenConnect=None, setGradW=None, setMaxChargeRate=None, setMaxDischargeRate=None, setMaxVA=None, setMaxVAr=None, setMaxVArNeg=None, setMaxW=None, setMinPF=None, setMinPFNeg=None, setStorConnect=None, setVRef=None, setVRefOfs=None, updatedTime=None): - self.original_tagname_ = None - super(DERSettings, self).__init__() - self.setGenConnect = setGenConnect - self.setGradW = setGradW - self.setMaxChargeRate = setMaxChargeRate - self.setMaxDischargeRate = setMaxDischargeRate - self.setMaxVA = setMaxVA - self.setMaxVAr = setMaxVAr - self.setMaxVArNeg = setMaxVArNeg - self.setMaxW = setMaxW - self.setMinPF = setMinPF - self.setMinPFNeg = setMinPFNeg - self.setStorConnect = setStorConnect - self.setVRef = setVRef - self.setVRefOfs = setVRefOfs - self.updatedTime = updatedTime - def factory(*args_, **kwargs_): - if DERSettings.subclass: - return DERSettings.subclass(*args_, **kwargs_) - else: - return DERSettings(*args_, **kwargs_) - factory = staticmethod(factory) - def get_setGenConnect(self): return self.setGenConnect - def set_setGenConnect(self, setGenConnect): self.setGenConnect = setGenConnect - def get_setGradW(self): return self.setGradW - def set_setGradW(self, setGradW): self.setGradW = setGradW - def get_setMaxChargeRate(self): return self.setMaxChargeRate - def set_setMaxChargeRate(self, setMaxChargeRate): self.setMaxChargeRate = setMaxChargeRate - def get_setMaxDischargeRate(self): return self.setMaxDischargeRate - def set_setMaxDischargeRate(self, setMaxDischargeRate): self.setMaxDischargeRate = setMaxDischargeRate - def get_setMaxVA(self): return self.setMaxVA - def set_setMaxVA(self, setMaxVA): self.setMaxVA = setMaxVA - def get_setMaxVAr(self): return self.setMaxVAr - def set_setMaxVAr(self, setMaxVAr): self.setMaxVAr = setMaxVAr - def get_setMaxVArNeg(self): return self.setMaxVArNeg - def set_setMaxVArNeg(self, setMaxVArNeg): self.setMaxVArNeg = setMaxVArNeg - def get_setMaxW(self): return self.setMaxW - def set_setMaxW(self, setMaxW): self.setMaxW = setMaxW - def get_setMinPF(self): return self.setMinPF - def set_setMinPF(self, setMinPF): self.setMinPF = setMinPF - def get_setMinPFNeg(self): return self.setMinPFNeg - def set_setMinPFNeg(self, setMinPFNeg): self.setMinPFNeg = setMinPFNeg - def get_setStorConnect(self): return self.setStorConnect - def set_setStorConnect(self, setStorConnect): self.setStorConnect = setStorConnect - def get_setVRef(self): return self.setVRef - def set_setVRef(self, setVRef): self.setVRef = setVRef - def get_setVRefOfs(self): return self.setVRefOfs - def set_setVRefOfs(self, setVRefOfs): self.setVRefOfs = setVRefOfs - def get_updatedTime(self): return self.updatedTime - def set_updatedTime(self, updatedTime): self.updatedTime = updatedTime - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.setGenConnect is not None or - self.setGradW is not None or - self.setMaxChargeRate is not None or - self.setMaxDischargeRate is not None or - self.setMaxVA is not None or - self.setMaxVAr is not None or - self.setMaxVArNeg is not None or - self.setMaxW is not None or - self.setMinPF is not None or - self.setMinPFNeg is not None or - self.setStorConnect is not None or - self.setVRef is not None or - self.setVRefOfs is not None or - self.updatedTime is not None or - super(DERSettings, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERSettings', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERSettings') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERSettings', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERSettings'): - super(DERSettings, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERSettings') - def exportChildren(self, outfile, level, namespace_='', name_='DERSettings', fromsubclass_=False, pretty_print=True): - super(DERSettings, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.setGenConnect is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssetGenConnect>%s%s' % (namespace_, self.gds_format_boolean(self.setGenConnect, input_name='setGenConnect'), namespace_, eol_)) - if self.setGradW is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssetGradW>%s%s' % (namespace_, self.gds_format_integer(self.setGradW, input_name='setGradW'), namespace_, eol_)) - if self.setMaxChargeRate is not None: - self.setMaxChargeRate.export(outfile, level, namespace_, name_='setMaxChargeRate', pretty_print=pretty_print) - if self.setMaxDischargeRate is not None: - self.setMaxDischargeRate.export(outfile, level, namespace_, name_='setMaxDischargeRate', pretty_print=pretty_print) - if self.setMaxVA is not None: - self.setMaxVA.export(outfile, level, namespace_, name_='setMaxVA', pretty_print=pretty_print) - if self.setMaxVAr is not None: - self.setMaxVAr.export(outfile, level, namespace_, name_='setMaxVAr', pretty_print=pretty_print) - if self.setMaxVArNeg is not None: - self.setMaxVArNeg.export(outfile, level, namespace_, name_='setMaxVArNeg', pretty_print=pretty_print) - if self.setMaxW is not None: - self.setMaxW.export(outfile, level, namespace_, name_='setMaxW', pretty_print=pretty_print) - if self.setMinPF is not None: - self.setMinPF.export(outfile, level, namespace_, name_='setMinPF', pretty_print=pretty_print) - if self.setMinPFNeg is not None: - self.setMinPFNeg.export(outfile, level, namespace_, name_='setMinPFNeg', pretty_print=pretty_print) - if self.setStorConnect is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssetStorConnect>%s%s' % (namespace_, self.gds_format_boolean(self.setStorConnect, input_name='setStorConnect'), namespace_, eol_)) - if self.setVRef is not None: - self.setVRef.export(outfile, level, namespace_, name_='setVRef', pretty_print=pretty_print) - if self.setVRefOfs is not None: - self.setVRefOfs.export(outfile, level, namespace_, name_='setVRefOfs', pretty_print=pretty_print) - if self.updatedTime is not None: - self.updatedTime.export(outfile, level, namespace_, name_='updatedTime', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERSettings'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERSettings, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERSettings, self).exportLiteralChildren(outfile, level, name_) - if self.setGenConnect is not None: - showIndent(outfile, level) - outfile.write('setGenConnect=%s,\n' % self.setGenConnect) - if self.setGradW is not None: - showIndent(outfile, level) - outfile.write('setGradW=%d,\n' % self.setGradW) - if self.setMaxChargeRate is not None: - showIndent(outfile, level) - outfile.write('setMaxChargeRate=model_.ActivePower(\n') - self.setMaxChargeRate.exportLiteral(outfile, level, name_='setMaxChargeRate') - showIndent(outfile, level) - outfile.write('),\n') - if self.setMaxDischargeRate is not None: - showIndent(outfile, level) - outfile.write('setMaxDischargeRate=model_.ActivePower(\n') - self.setMaxDischargeRate.exportLiteral(outfile, level, name_='setMaxDischargeRate') - showIndent(outfile, level) - outfile.write('),\n') - if self.setMaxVA is not None: - showIndent(outfile, level) - outfile.write('setMaxVA=model_.ApparentPower(\n') - self.setMaxVA.exportLiteral(outfile, level, name_='setMaxVA') - showIndent(outfile, level) - outfile.write('),\n') - if self.setMaxVAr is not None: - showIndent(outfile, level) - outfile.write('setMaxVAr=model_.ReactivePower(\n') - self.setMaxVAr.exportLiteral(outfile, level, name_='setMaxVAr') - showIndent(outfile, level) - outfile.write('),\n') - if self.setMaxVArNeg is not None: - showIndent(outfile, level) - outfile.write('setMaxVArNeg=model_.ReactivePower(\n') - self.setMaxVArNeg.exportLiteral(outfile, level, name_='setMaxVArNeg') - showIndent(outfile, level) - outfile.write('),\n') - if self.setMaxW is not None: - showIndent(outfile, level) - outfile.write('setMaxW=model_.ActivePower(\n') - self.setMaxW.exportLiteral(outfile, level, name_='setMaxW') - showIndent(outfile, level) - outfile.write('),\n') - if self.setMinPF is not None: - showIndent(outfile, level) - outfile.write('setMinPF=model_.UnsignedFixedPointType(\n') - self.setMinPF.exportLiteral(outfile, level, name_='setMinPF') - showIndent(outfile, level) - outfile.write('),\n') - if self.setMinPFNeg is not None: - showIndent(outfile, level) - outfile.write('setMinPFNeg=model_.FixedPointType(\n') - self.setMinPFNeg.exportLiteral(outfile, level, name_='setMinPFNeg') - showIndent(outfile, level) - outfile.write('),\n') - if self.setStorConnect is not None: - showIndent(outfile, level) - outfile.write('setStorConnect=%s,\n' % self.setStorConnect) - if self.setVRef is not None: - showIndent(outfile, level) - outfile.write('setVRef=model_.VoltageRMS(\n') - self.setVRef.exportLiteral(outfile, level, name_='setVRef') - showIndent(outfile, level) - outfile.write('),\n') - if self.setVRefOfs is not None: - showIndent(outfile, level) - outfile.write('setVRefOfs=model_.VoltageRMS(\n') - self.setVRefOfs.exportLiteral(outfile, level, name_='setVRefOfs') - showIndent(outfile, level) - outfile.write('),\n') - if self.updatedTime is not None: - showIndent(outfile, level) - outfile.write('updatedTime=model_.TimeType(\n') - self.updatedTime.exportLiteral(outfile, level, name_='updatedTime') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERSettings, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'setGenConnect': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'setGenConnect') - self.setGenConnect = ival_ - elif nodeName_ == 'setGradW': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'setGradW') - self.setGradW = ival_ - self.validate_UInt16(self.setGradW) # validate type UInt16 - elif nodeName_ == 'setMaxChargeRate': - obj_ = ActivePower.factory() - obj_.build(child_) - self.setMaxChargeRate = obj_ - obj_.original_tagname_ = 'setMaxChargeRate' - elif nodeName_ == 'setMaxDischargeRate': - obj_ = ActivePower.factory() - obj_.build(child_) - self.setMaxDischargeRate = obj_ - obj_.original_tagname_ = 'setMaxDischargeRate' - elif nodeName_ == 'setMaxVA': - obj_ = ApparentPower.factory() - obj_.build(child_) - self.setMaxVA = obj_ - obj_.original_tagname_ = 'setMaxVA' - elif nodeName_ == 'setMaxVAr': - obj_ = ReactivePower.factory() - obj_.build(child_) - self.setMaxVAr = obj_ - obj_.original_tagname_ = 'setMaxVAr' - elif nodeName_ == 'setMaxVArNeg': - obj_ = ReactivePower.factory() - obj_.build(child_) - self.setMaxVArNeg = obj_ - obj_.original_tagname_ = 'setMaxVArNeg' - elif nodeName_ == 'setMaxW': - obj_ = ActivePower.factory() - obj_.build(child_) - self.setMaxW = obj_ - obj_.original_tagname_ = 'setMaxW' - elif nodeName_ == 'setMinPF': - obj_ = UnsignedFixedPointType.factory() - obj_.build(child_) - self.setMinPF = obj_ - obj_.original_tagname_ = 'setMinPF' - elif nodeName_ == 'setMinPFNeg': - obj_ = FixedPointType.factory() - obj_.build(child_) - self.setMinPFNeg = obj_ - obj_.original_tagname_ = 'setMinPFNeg' - elif nodeName_ == 'setStorConnect': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'setStorConnect') - self.setStorConnect = ival_ - elif nodeName_ == 'setVRef': - obj_ = VoltageRMS.factory() - obj_.build(child_) - self.setVRef = obj_ - obj_.original_tagname_ = 'setVRef' - elif nodeName_ == 'setVRefOfs': - obj_ = VoltageRMS.factory() - obj_.build(child_) - self.setVRefOfs = obj_ - obj_.original_tagname_ = 'setVRefOfs' - elif nodeName_ == 'updatedTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.updatedTime = obj_ - obj_.original_tagname_ = 'updatedTime' - super(DERSettings, self).buildChildren(child_, node, nodeName_, True) -# end class DERSettings - - -class DERList(List): - """A List element to hold DER objects.""" - subclass = None - superclass = List - def __init__(self, DER=None): - self.original_tagname_ = None - super(DERList, self).__init__() - if DER is None: - self.DER = [] - else: - self.DER = DER - def factory(*args_, **kwargs_): - if DERList.subclass: - return DERList.subclass(*args_, **kwargs_) - else: - return DERList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DER(self): return self.DER - def set_DER(self, DER): self.DER = DER - def add_DER(self, value): self.DER.append(value) - def insert_DER_at(self, index, value): self.DER.insert(index, value) - def replace_DER_at(self, index, value): self.DER[index] = value - def hasContent_(self): - if ( - self.DER or - super(DERList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DERList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DERList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DERList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DERList'): - super(DERList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DERList') - def exportChildren(self, outfile, level, namespace_='', name_='DERList', fromsubclass_=False, pretty_print=True): - super(DERList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for DER_ in self.DER: - DER_.export(outfile, level, namespace_, name_='DER', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DERList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DERList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DERList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('DER=[\n') - level += 1 - for DER_ in self.DER: - showIndent(outfile, level) - outfile.write('model_.DER(\n') - DER_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DERList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DER': - obj_ = DER.factory() - obj_.build(child_) - self.DER.append(obj_) - obj_.original_tagname_ = 'DER' - super(DERList, self).buildChildren(child_, node, nodeName_, True) -# end class DERList - - -class DER(SubscribableResource): - """Contains links to DER resources.""" - subclass = None - superclass = SubscribableResource - def __init__(self, AssociatedDERProgramListLink=None, AssociatedUsagePointLink=None, CurrentDERProgramLink=None, DERAvailabilityLink=None, DERCapabilityLink=None, DERSettingsLink=None, DERStatusLink=None): - self.original_tagname_ = None - super(DER, self).__init__() - self.AssociatedDERProgramListLink = AssociatedDERProgramListLink - self.AssociatedUsagePointLink = AssociatedUsagePointLink - self.CurrentDERProgramLink = CurrentDERProgramLink - self.DERAvailabilityLink = DERAvailabilityLink - self.DERCapabilityLink = DERCapabilityLink - self.DERSettingsLink = DERSettingsLink - self.DERStatusLink = DERStatusLink - def factory(*args_, **kwargs_): - if DER.subclass: - return DER.subclass(*args_, **kwargs_) - else: - return DER(*args_, **kwargs_) - factory = staticmethod(factory) - def get_AssociatedDERProgramListLink(self): return self.AssociatedDERProgramListLink - def set_AssociatedDERProgramListLink(self, AssociatedDERProgramListLink): self.AssociatedDERProgramListLink = AssociatedDERProgramListLink - def get_AssociatedUsagePointLink(self): return self.AssociatedUsagePointLink - def set_AssociatedUsagePointLink(self, AssociatedUsagePointLink): self.AssociatedUsagePointLink = AssociatedUsagePointLink - def get_CurrentDERProgramLink(self): return self.CurrentDERProgramLink - def set_CurrentDERProgramLink(self, CurrentDERProgramLink): self.CurrentDERProgramLink = CurrentDERProgramLink - def get_DERAvailabilityLink(self): return self.DERAvailabilityLink - def set_DERAvailabilityLink(self, DERAvailabilityLink): self.DERAvailabilityLink = DERAvailabilityLink - def get_DERCapabilityLink(self): return self.DERCapabilityLink - def set_DERCapabilityLink(self, DERCapabilityLink): self.DERCapabilityLink = DERCapabilityLink - def get_DERSettingsLink(self): return self.DERSettingsLink - def set_DERSettingsLink(self, DERSettingsLink): self.DERSettingsLink = DERSettingsLink - def get_DERStatusLink(self): return self.DERStatusLink - def set_DERStatusLink(self, DERStatusLink): self.DERStatusLink = DERStatusLink - def hasContent_(self): - if ( - self.AssociatedDERProgramListLink is not None or - self.AssociatedUsagePointLink is not None or - self.CurrentDERProgramLink is not None or - self.DERAvailabilityLink is not None or - self.DERCapabilityLink is not None or - self.DERSettingsLink is not None or - self.DERStatusLink is not None or - super(DER, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DER', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DER') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DER', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DER'): - super(DER, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DER') - def exportChildren(self, outfile, level, namespace_='', name_='DER', fromsubclass_=False, pretty_print=True): - super(DER, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.AssociatedDERProgramListLink is not None: - self.AssociatedDERProgramListLink.export(outfile, level, namespace_, name_='AssociatedDERProgramListLink', pretty_print=pretty_print) - if self.AssociatedUsagePointLink is not None: - self.AssociatedUsagePointLink.export(outfile, level, namespace_, name_='AssociatedUsagePointLink', pretty_print=pretty_print) - if self.CurrentDERProgramLink is not None: - self.CurrentDERProgramLink.export(outfile, level, namespace_, name_='CurrentDERProgramLink', pretty_print=pretty_print) - if self.DERAvailabilityLink is not None: - self.DERAvailabilityLink.export(outfile, level, namespace_, name_='DERAvailabilityLink', pretty_print=pretty_print) - if self.DERCapabilityLink is not None: - self.DERCapabilityLink.export(outfile, level, namespace_, name_='DERCapabilityLink', pretty_print=pretty_print) - if self.DERSettingsLink is not None: - self.DERSettingsLink.export(outfile, level, namespace_, name_='DERSettingsLink', pretty_print=pretty_print) - if self.DERStatusLink is not None: - self.DERStatusLink.export(outfile, level, namespace_, name_='DERStatusLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DER'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DER, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DER, self).exportLiteralChildren(outfile, level, name_) - if self.AssociatedDERProgramListLink is not None: - showIndent(outfile, level) - outfile.write('AssociatedDERProgramListLink=model_.AssociatedDERProgramListLink(\n') - self.AssociatedDERProgramListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.AssociatedUsagePointLink is not None: - showIndent(outfile, level) - outfile.write('AssociatedUsagePointLink=model_.AssociatedUsagePointLink(\n') - self.AssociatedUsagePointLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.CurrentDERProgramLink is not None: - showIndent(outfile, level) - outfile.write('CurrentDERProgramLink=model_.CurrentDERProgramLink(\n') - self.CurrentDERProgramLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DERAvailabilityLink is not None: - showIndent(outfile, level) - outfile.write('DERAvailabilityLink=model_.DERAvailabilityLink(\n') - self.DERAvailabilityLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DERCapabilityLink is not None: - showIndent(outfile, level) - outfile.write('DERCapabilityLink=model_.DERCapabilityLink(\n') - self.DERCapabilityLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DERSettingsLink is not None: - showIndent(outfile, level) - outfile.write('DERSettingsLink=model_.DERSettingsLink(\n') - self.DERSettingsLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DERStatusLink is not None: - showIndent(outfile, level) - outfile.write('DERStatusLink=model_.DERStatusLink(\n') - self.DERStatusLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DER, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'AssociatedDERProgramListLink': - obj_ = AssociatedDERProgramListLink.factory() - obj_.build(child_) - self.AssociatedDERProgramListLink = obj_ - obj_.original_tagname_ = 'AssociatedDERProgramListLink' - elif nodeName_ == 'AssociatedUsagePointLink': - obj_ = AssociatedUsagePointLink.factory() - obj_.build(child_) - self.AssociatedUsagePointLink = obj_ - obj_.original_tagname_ = 'AssociatedUsagePointLink' - elif nodeName_ == 'CurrentDERProgramLink': - obj_ = CurrentDERProgramLink.factory() - obj_.build(child_) - self.CurrentDERProgramLink = obj_ - obj_.original_tagname_ = 'CurrentDERProgramLink' - elif nodeName_ == 'DERAvailabilityLink': - obj_ = DERAvailabilityLink.factory() - obj_.build(child_) - self.DERAvailabilityLink = obj_ - obj_.original_tagname_ = 'DERAvailabilityLink' - elif nodeName_ == 'DERCapabilityLink': - obj_ = DERCapabilityLink.factory() - obj_.build(child_) - self.DERCapabilityLink = obj_ - obj_.original_tagname_ = 'DERCapabilityLink' - elif nodeName_ == 'DERSettingsLink': - obj_ = DERSettingsLink.factory() - obj_.build(child_) - self.DERSettingsLink = obj_ - obj_.original_tagname_ = 'DERSettingsLink' - elif nodeName_ == 'DERStatusLink': - obj_ = DERStatusLink.factory() - obj_.build(child_) - self.DERStatusLink = obj_ - obj_.original_tagname_ = 'DERStatusLink' - super(DER, self).buildChildren(child_, node, nodeName_, True) -# end class DER - - -class DefaultDERControl(SubscribableIdentifiedObject): - """Contains control mode information to be used if no active DERControl - is found.""" - subclass = None - superclass = SubscribableIdentifiedObject - def __init__(self, DERControlBase=None): - self.original_tagname_ = None - super(DefaultDERControl, self).__init__() - self.DERControlBase = DERControlBase - def factory(*args_, **kwargs_): - if DefaultDERControl.subclass: - return DefaultDERControl.subclass(*args_, **kwargs_) - else: - return DefaultDERControl(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DERControlBase(self): return self.DERControlBase - def set_DERControlBase(self, DERControlBase): self.DERControlBase = DERControlBase - def hasContent_(self): - if ( - self.DERControlBase is not None or - super(DefaultDERControl, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DefaultDERControl', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DefaultDERControl') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DefaultDERControl', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DefaultDERControl'): - super(DefaultDERControl, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DefaultDERControl') - def exportChildren(self, outfile, level, namespace_='', name_='DefaultDERControl', fromsubclass_=False, pretty_print=True): - super(DefaultDERControl, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.DERControlBase is not None: - self.DERControlBase.export(outfile, level, namespace_, name_='DERControlBase', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DefaultDERControl'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DefaultDERControl, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DefaultDERControl, self).exportLiteralChildren(outfile, level, name_) - if self.DERControlBase is not None: - showIndent(outfile, level) - outfile.write('DERControlBase=model_.DERControlBase(\n') - self.DERControlBase.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DefaultDERControl, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DERControlBase': - obj_ = DERControlBase.factory() - obj_.build(child_) - self.DERControlBase = obj_ - obj_.original_tagname_ = 'DERControlBase' - super(DefaultDERControl, self).buildChildren(child_, node, nodeName_, True) -# end class DefaultDERControl - - -class FlowReservationResponseList(SubscribableList): - """A List element to hold FlowReservationResponse objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, FlowReservationResponse=None): - self.original_tagname_ = None - super(FlowReservationResponseList, self).__init__() - if FlowReservationResponse is None: - self.FlowReservationResponse = [] - else: - self.FlowReservationResponse = FlowReservationResponse - def factory(*args_, **kwargs_): - if FlowReservationResponseList.subclass: - return FlowReservationResponseList.subclass(*args_, **kwargs_) - else: - return FlowReservationResponseList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_FlowReservationResponse(self): return self.FlowReservationResponse - def set_FlowReservationResponse(self, FlowReservationResponse): self.FlowReservationResponse = FlowReservationResponse - def add_FlowReservationResponse(self, value): self.FlowReservationResponse.append(value) - def insert_FlowReservationResponse_at(self, index, value): self.FlowReservationResponse.insert(index, value) - def replace_FlowReservationResponse_at(self, index, value): self.FlowReservationResponse[index] = value - def hasContent_(self): - if ( - self.FlowReservationResponse or - super(FlowReservationResponseList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FlowReservationResponseList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationResponseList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FlowReservationResponseList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FlowReservationResponseList'): - super(FlowReservationResponseList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationResponseList') - def exportChildren(self, outfile, level, namespace_='', name_='FlowReservationResponseList', fromsubclass_=False, pretty_print=True): - super(FlowReservationResponseList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for FlowReservationResponse_ in self.FlowReservationResponse: - FlowReservationResponse_.export(outfile, level, namespace_, name_='FlowReservationResponse', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FlowReservationResponseList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FlowReservationResponseList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FlowReservationResponseList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('FlowReservationResponse=[\n') - level += 1 - for FlowReservationResponse_ in self.FlowReservationResponse: - showIndent(outfile, level) - outfile.write('model_.FlowReservationResponse(\n') - FlowReservationResponse_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FlowReservationResponseList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'FlowReservationResponse': - obj_ = FlowReservationResponse.factory() - obj_.build(child_) - self.FlowReservationResponse.append(obj_) - obj_.original_tagname_ = 'FlowReservationResponse' - super(FlowReservationResponseList, self).buildChildren(child_, node, nodeName_, True) -# end class FlowReservationResponseList - - -class FlowReservationResponse(Event): - """The server may modify the charging or discharging parameters and - interval to provide a lower aggregated demand at the premises, - or within a larger part of the distribution system.""" - subclass = None - superclass = Event - def __init__(self, energyAvailable=None, powerAvailable=None, subject=None): - self.original_tagname_ = None - super(FlowReservationResponse, self).__init__() - self.energyAvailable = energyAvailable - self.powerAvailable = powerAvailable - self.subject = subject - def factory(*args_, **kwargs_): - if FlowReservationResponse.subclass: - return FlowReservationResponse.subclass(*args_, **kwargs_) - else: - return FlowReservationResponse(*args_, **kwargs_) - factory = staticmethod(factory) - def get_energyAvailable(self): return self.energyAvailable - def set_energyAvailable(self, energyAvailable): self.energyAvailable = energyAvailable - def get_powerAvailable(self): return self.powerAvailable - def set_powerAvailable(self, powerAvailable): self.powerAvailable = powerAvailable - def get_subject(self): return self.subject - def set_subject(self, subject): self.subject = subject - def hasContent_(self): - if ( - self.energyAvailable is not None or - self.powerAvailable is not None or - self.subject is not None or - super(FlowReservationResponse, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FlowReservationResponse', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationResponse') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FlowReservationResponse', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FlowReservationResponse'): - super(FlowReservationResponse, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationResponse') - def exportChildren(self, outfile, level, namespace_='', name_='FlowReservationResponse', fromsubclass_=False, pretty_print=True): - super(FlowReservationResponse, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.energyAvailable is not None: - self.energyAvailable.export(outfile, level, namespace_, name_='energyAvailable', pretty_print=pretty_print) - if self.powerAvailable is not None: - self.powerAvailable.export(outfile, level, namespace_, name_='powerAvailable', pretty_print=pretty_print) - if self.subject is not None: - self.subject.export(outfile, level, namespace_, name_='subject', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FlowReservationResponse'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FlowReservationResponse, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FlowReservationResponse, self).exportLiteralChildren(outfile, level, name_) - if self.energyAvailable is not None: - showIndent(outfile, level) - outfile.write('energyAvailable=model_.RealEnergy(\n') - self.energyAvailable.exportLiteral(outfile, level, name_='energyAvailable') - showIndent(outfile, level) - outfile.write('),\n') - if self.powerAvailable is not None: - showIndent(outfile, level) - outfile.write('powerAvailable=model_.ActivePower(\n') - self.powerAvailable.exportLiteral(outfile, level, name_='powerAvailable') - showIndent(outfile, level) - outfile.write('),\n') - if self.subject is not None: - showIndent(outfile, level) - outfile.write('subject=model_.mRIDType(\n') - self.subject.exportLiteral(outfile, level, name_='subject') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FlowReservationResponse, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'energyAvailable': - obj_ = RealEnergy.factory() - obj_.build(child_) - self.energyAvailable = obj_ - obj_.original_tagname_ = 'energyAvailable' - elif nodeName_ == 'powerAvailable': - obj_ = ActivePower.factory() - obj_.build(child_) - self.powerAvailable = obj_ - obj_.original_tagname_ = 'powerAvailable' - elif nodeName_ == 'subject': - obj_ = mRIDType.factory() - obj_.build(child_) - self.subject = obj_ - obj_.original_tagname_ = 'subject' - super(FlowReservationResponse, self).buildChildren(child_, node, nodeName_, True) -# end class FlowReservationResponse - - -class FlowReservationRequestList(List): - """A List element to hold FlowReservationRequest objects.""" - subclass = None - superclass = List - def __init__(self, FlowReservationRequest=None): - self.original_tagname_ = None - super(FlowReservationRequestList, self).__init__() - if FlowReservationRequest is None: - self.FlowReservationRequest = [] - else: - self.FlowReservationRequest = FlowReservationRequest - def factory(*args_, **kwargs_): - if FlowReservationRequestList.subclass: - return FlowReservationRequestList.subclass(*args_, **kwargs_) - else: - return FlowReservationRequestList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_FlowReservationRequest(self): return self.FlowReservationRequest - def set_FlowReservationRequest(self, FlowReservationRequest): self.FlowReservationRequest = FlowReservationRequest - def add_FlowReservationRequest(self, value): self.FlowReservationRequest.append(value) - def insert_FlowReservationRequest_at(self, index, value): self.FlowReservationRequest.insert(index, value) - def replace_FlowReservationRequest_at(self, index, value): self.FlowReservationRequest[index] = value - def hasContent_(self): - if ( - self.FlowReservationRequest or - super(FlowReservationRequestList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FlowReservationRequestList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationRequestList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FlowReservationRequestList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FlowReservationRequestList'): - super(FlowReservationRequestList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationRequestList') - def exportChildren(self, outfile, level, namespace_='', name_='FlowReservationRequestList', fromsubclass_=False, pretty_print=True): - super(FlowReservationRequestList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for FlowReservationRequest_ in self.FlowReservationRequest: - FlowReservationRequest_.export(outfile, level, namespace_, name_='FlowReservationRequest', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FlowReservationRequestList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FlowReservationRequestList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FlowReservationRequestList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('FlowReservationRequest=[\n') - level += 1 - for FlowReservationRequest_ in self.FlowReservationRequest: - showIndent(outfile, level) - outfile.write('model_.FlowReservationRequest(\n') - FlowReservationRequest_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FlowReservationRequestList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'FlowReservationRequest': - obj_ = FlowReservationRequest.factory() - obj_.build(child_) - self.FlowReservationRequest.append(obj_) - obj_.original_tagname_ = 'FlowReservationRequest' - super(FlowReservationRequestList, self).buildChildren(child_, node, nodeName_, True) -# end class FlowReservationRequestList - - -class FlowReservationRequest(IdentifiedObject): - """Used to request flow transactions. Client EndDevices submit a - request for charging or discharging from the server. The server - creates an associated FlowReservationResponse containing the - charging parameters and interval to provide a lower aggregated - demand at the premises, or within a larger part of the - distribution system.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, creationTime=None, durationRequested=None, energyRequested=None, intervalRequested=None, powerRequested=None, RequestStatus=None): - self.original_tagname_ = None - super(FlowReservationRequest, self).__init__() - self.creationTime = creationTime - self.durationRequested = durationRequested - self.energyRequested = energyRequested - self.intervalRequested = intervalRequested - self.powerRequested = powerRequested - self.RequestStatus = RequestStatus - def factory(*args_, **kwargs_): - if FlowReservationRequest.subclass: - return FlowReservationRequest.subclass(*args_, **kwargs_) - else: - return FlowReservationRequest(*args_, **kwargs_) - factory = staticmethod(factory) - def get_creationTime(self): return self.creationTime - def set_creationTime(self, creationTime): self.creationTime = creationTime - def get_durationRequested(self): return self.durationRequested - def set_durationRequested(self, durationRequested): self.durationRequested = durationRequested - def get_energyRequested(self): return self.energyRequested - def set_energyRequested(self, energyRequested): self.energyRequested = energyRequested - def get_intervalRequested(self): return self.intervalRequested - def set_intervalRequested(self, intervalRequested): self.intervalRequested = intervalRequested - def get_powerRequested(self): return self.powerRequested - def set_powerRequested(self, powerRequested): self.powerRequested = powerRequested - def get_RequestStatus(self): return self.RequestStatus - def set_RequestStatus(self, RequestStatus): self.RequestStatus = RequestStatus - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.creationTime is not None or - self.durationRequested is not None or - self.energyRequested is not None or - self.intervalRequested is not None or - self.powerRequested is not None or - self.RequestStatus is not None or - super(FlowReservationRequest, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FlowReservationRequest', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationRequest') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FlowReservationRequest', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FlowReservationRequest'): - super(FlowReservationRequest, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FlowReservationRequest') - def exportChildren(self, outfile, level, namespace_='', name_='FlowReservationRequest', fromsubclass_=False, pretty_print=True): - super(FlowReservationRequest, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.creationTime is not None: - self.creationTime.export(outfile, level, namespace_, name_='creationTime', pretty_print=pretty_print) - if self.durationRequested is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdurationRequested>%s%s' % (namespace_, self.gds_format_integer(self.durationRequested, input_name='durationRequested'), namespace_, eol_)) - if self.energyRequested is not None: - self.energyRequested.export(outfile, level, namespace_, name_='energyRequested', pretty_print=pretty_print) - if self.intervalRequested is not None: - self.intervalRequested.export(outfile, level, namespace_, name_='intervalRequested', pretty_print=pretty_print) - if self.powerRequested is not None: - self.powerRequested.export(outfile, level, namespace_, name_='powerRequested', pretty_print=pretty_print) - if self.RequestStatus is not None: - self.RequestStatus.export(outfile, level, namespace_, name_='RequestStatus', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FlowReservationRequest'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FlowReservationRequest, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FlowReservationRequest, self).exportLiteralChildren(outfile, level, name_) - if self.creationTime is not None: - showIndent(outfile, level) - outfile.write('creationTime=model_.TimeType(\n') - self.creationTime.exportLiteral(outfile, level, name_='creationTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.durationRequested is not None: - showIndent(outfile, level) - outfile.write('durationRequested=%d,\n' % self.durationRequested) - if self.energyRequested is not None: - showIndent(outfile, level) - outfile.write('energyRequested=model_.SignedRealEnergy(\n') - self.energyRequested.exportLiteral(outfile, level, name_='energyRequested') - showIndent(outfile, level) - outfile.write('),\n') - if self.intervalRequested is not None: - showIndent(outfile, level) - outfile.write('intervalRequested=model_.DateTimeInterval(\n') - self.intervalRequested.exportLiteral(outfile, level, name_='intervalRequested') - showIndent(outfile, level) - outfile.write('),\n') - if self.powerRequested is not None: - showIndent(outfile, level) - outfile.write('powerRequested=model_.ActivePower(\n') - self.powerRequested.exportLiteral(outfile, level, name_='powerRequested') - showIndent(outfile, level) - outfile.write('),\n') - if self.RequestStatus is not None: - showIndent(outfile, level) - outfile.write('RequestStatus=model_.RequestStatus(\n') - self.RequestStatus.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FlowReservationRequest, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'creationTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.creationTime = obj_ - obj_.original_tagname_ = 'creationTime' - elif nodeName_ == 'durationRequested': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'durationRequested') - self.durationRequested = ival_ - self.validate_UInt16(self.durationRequested) # validate type UInt16 - elif nodeName_ == 'energyRequested': - obj_ = SignedRealEnergy.factory() - obj_.build(child_) - self.energyRequested = obj_ - obj_.original_tagname_ = 'energyRequested' - elif nodeName_ == 'intervalRequested': - obj_ = DateTimeInterval.factory() - obj_.build(child_) - self.intervalRequested = obj_ - obj_.original_tagname_ = 'intervalRequested' - elif nodeName_ == 'powerRequested': - obj_ = ActivePower.factory() - obj_.build(child_) - self.powerRequested = obj_ - obj_.original_tagname_ = 'powerRequested' - elif nodeName_ == 'RequestStatus': - obj_ = RequestStatus.factory() - obj_.build(child_) - self.RequestStatus = obj_ - obj_.original_tagname_ = 'RequestStatus' - super(FlowReservationRequest, self).buildChildren(child_, node, nodeName_, True) -# end class FlowReservationRequest - - -class AbstractFlowReservation(Event): - """Provides definition of FlowReservation elements in common between - Requests and Responses.""" - subclass = None - superclass = Event - def __init__(self): - self.original_tagname_ = None - super(AbstractFlowReservation, self).__init__() - def factory(*args_, **kwargs_): - if AbstractFlowReservation.subclass: - return AbstractFlowReservation.subclass(*args_, **kwargs_) - else: - return AbstractFlowReservation(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(AbstractFlowReservation, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AbstractFlowReservation', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AbstractFlowReservation') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AbstractFlowReservation', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AbstractFlowReservation'): - super(AbstractFlowReservation, self).exportAttributes(outfile, level, already_processed, namespace_, name_='AbstractFlowReservation') - def exportChildren(self, outfile, level, namespace_='', name_='AbstractFlowReservation', fromsubclass_=False, pretty_print=True): - super(AbstractFlowReservation, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='AbstractFlowReservation'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(AbstractFlowReservation, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(AbstractFlowReservation, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(AbstractFlowReservation, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(AbstractFlowReservation, self).buildChildren(child_, node, nodeName_, True) - pass -# end class AbstractFlowReservation - - -class SupplyInterruptionOverrideList(List): - """A List element to hold SupplyInterruptionOverride objects.""" - subclass = None - superclass = List - def __init__(self, SupplyInterruptionOverride=None): - self.original_tagname_ = None - super(SupplyInterruptionOverrideList, self).__init__() - if SupplyInterruptionOverride is None: - self.SupplyInterruptionOverride = [] - else: - self.SupplyInterruptionOverride = SupplyInterruptionOverride - def factory(*args_, **kwargs_): - if SupplyInterruptionOverrideList.subclass: - return SupplyInterruptionOverrideList.subclass(*args_, **kwargs_) - else: - return SupplyInterruptionOverrideList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_SupplyInterruptionOverride(self): return self.SupplyInterruptionOverride - def set_SupplyInterruptionOverride(self, SupplyInterruptionOverride): self.SupplyInterruptionOverride = SupplyInterruptionOverride - def add_SupplyInterruptionOverride(self, value): self.SupplyInterruptionOverride.append(value) - def insert_SupplyInterruptionOverride_at(self, index, value): self.SupplyInterruptionOverride.insert(index, value) - def replace_SupplyInterruptionOverride_at(self, index, value): self.SupplyInterruptionOverride[index] = value - def hasContent_(self): - if ( - self.SupplyInterruptionOverride or - super(SupplyInterruptionOverrideList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SupplyInterruptionOverrideList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SupplyInterruptionOverrideList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SupplyInterruptionOverrideList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SupplyInterruptionOverrideList'): - super(SupplyInterruptionOverrideList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SupplyInterruptionOverrideList') - def exportChildren(self, outfile, level, namespace_='', name_='SupplyInterruptionOverrideList', fromsubclass_=False, pretty_print=True): - super(SupplyInterruptionOverrideList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for SupplyInterruptionOverride_ in self.SupplyInterruptionOverride: - SupplyInterruptionOverride_.export(outfile, level, namespace_, name_='SupplyInterruptionOverride', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='SupplyInterruptionOverrideList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SupplyInterruptionOverrideList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SupplyInterruptionOverrideList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('SupplyInterruptionOverride=[\n') - level += 1 - for SupplyInterruptionOverride_ in self.SupplyInterruptionOverride: - showIndent(outfile, level) - outfile.write('model_.SupplyInterruptionOverride(\n') - SupplyInterruptionOverride_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SupplyInterruptionOverrideList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'SupplyInterruptionOverride': - obj_ = SupplyInterruptionOverride.factory() - obj_.build(child_) - self.SupplyInterruptionOverride.append(obj_) - obj_.original_tagname_ = 'SupplyInterruptionOverride' - super(SupplyInterruptionOverrideList, self).buildChildren(child_, node, nodeName_, True) -# end class SupplyInterruptionOverrideList - - -class SupplyInterruptionOverride(Resource): - """SupplyInterruptionOverride: There may be periods of time when - social, regulatory or other concerns mean that service should - not be interrupted, even when available credit has been - exhausted. Each Prepayment instance links to a List of - SupplyInterruptionOverride instances. Each - SupplyInterruptionOverride defines a contiguous period of time - during which supply SHALL NOT be interrupted.""" - subclass = None - superclass = Resource - def __init__(self, description=None, interval=None): - self.original_tagname_ = None - super(SupplyInterruptionOverride, self).__init__() - self.description = description - self.interval = interval - def factory(*args_, **kwargs_): - if SupplyInterruptionOverride.subclass: - return SupplyInterruptionOverride.subclass(*args_, **kwargs_) - else: - return SupplyInterruptionOverride(*args_, **kwargs_) - factory = staticmethod(factory) - def get_description(self): return self.description - def set_description(self, description): self.description = description - def get_interval(self): return self.interval - def set_interval(self, interval): self.interval = interval - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.description is not None or - self.interval is not None or - super(SupplyInterruptionOverride, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SupplyInterruptionOverride', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SupplyInterruptionOverride') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SupplyInterruptionOverride', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SupplyInterruptionOverride'): - super(SupplyInterruptionOverride, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SupplyInterruptionOverride') - def exportChildren(self, outfile, level, namespace_='', name_='SupplyInterruptionOverride', fromsubclass_=False, pretty_print=True): - super(SupplyInterruptionOverride, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.description is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdescription>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.description).encode(ExternalEncoding), input_name='description'), namespace_, eol_)) - if self.interval is not None: - self.interval.export(outfile, level, namespace_, name_='interval', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='SupplyInterruptionOverride'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SupplyInterruptionOverride, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SupplyInterruptionOverride, self).exportLiteralChildren(outfile, level, name_) - if self.description is not None: - showIndent(outfile, level) - outfile.write('description=%s,\n' % quote_python(self.description).encode(ExternalEncoding)) - if self.interval is not None: - showIndent(outfile, level) - outfile.write('interval=model_.DateTimeInterval(\n') - self.interval.exportLiteral(outfile, level, name_='interval') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SupplyInterruptionOverride, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'description': - description_ = child_.text - description_ = self.gds_validate_string(description_, node, 'description') - self.description = description_ - self.validate_String32(self.description) # validate type String32 - elif nodeName_ == 'interval': - obj_ = DateTimeInterval.factory() - obj_.build(child_) - self.interval = obj_ - obj_.original_tagname_ = 'interval' - super(SupplyInterruptionOverride, self).buildChildren(child_, node, nodeName_, True) -# end class SupplyInterruptionOverride - - -class PrepayOperationStatus(Resource): - """PrepayOperationStatus describes the status of the service or - commodity being conditionally controlled by the Prepayment - function set.""" - subclass = None - superclass = Resource - def __init__(self, creditTypeChange=None, creditTypeInUse=None, serviceChange=None, serviceStatus=None): - self.original_tagname_ = None - super(PrepayOperationStatus, self).__init__() - self.creditTypeChange = creditTypeChange - self.creditTypeInUse = creditTypeInUse - self.serviceChange = serviceChange - self.serviceStatus = serviceStatus - def factory(*args_, **kwargs_): - if PrepayOperationStatus.subclass: - return PrepayOperationStatus.subclass(*args_, **kwargs_) - else: - return PrepayOperationStatus(*args_, **kwargs_) - factory = staticmethod(factory) - def get_creditTypeChange(self): return self.creditTypeChange - def set_creditTypeChange(self, creditTypeChange): self.creditTypeChange = creditTypeChange - def get_creditTypeInUse(self): return self.creditTypeInUse - def set_creditTypeInUse(self, creditTypeInUse): self.creditTypeInUse = creditTypeInUse - def get_serviceChange(self): return self.serviceChange - def set_serviceChange(self, serviceChange): self.serviceChange = serviceChange - def get_serviceStatus(self): return self.serviceStatus - def set_serviceStatus(self, serviceStatus): self.serviceStatus = serviceStatus - def hasContent_(self): - if ( - self.creditTypeChange is not None or - self.creditTypeInUse is not None or - self.serviceChange is not None or - self.serviceStatus is not None or - super(PrepayOperationStatus, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PrepayOperationStatus', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PrepayOperationStatus') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PrepayOperationStatus', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PrepayOperationStatus'): - super(PrepayOperationStatus, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PrepayOperationStatus') - def exportChildren(self, outfile, level, namespace_='', name_='PrepayOperationStatus', fromsubclass_=False, pretty_print=True): - super(PrepayOperationStatus, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.creditTypeChange is not None: - self.creditTypeChange.export(outfile, level, namespace_, name_='creditTypeChange', pretty_print=pretty_print) - if self.creditTypeInUse is not None: - self.creditTypeInUse.export(outfile, level, namespace_, name_='creditTypeInUse', pretty_print=pretty_print) - if self.serviceChange is not None: - self.serviceChange.export(outfile, level, namespace_, name_='serviceChange', pretty_print=pretty_print) - if self.serviceStatus is not None: - self.serviceStatus.export(outfile, level, namespace_, name_='serviceStatus', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='PrepayOperationStatus'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PrepayOperationStatus, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PrepayOperationStatus, self).exportLiteralChildren(outfile, level, name_) - if self.creditTypeChange is not None: - showIndent(outfile, level) - outfile.write('creditTypeChange=model_.CreditTypeChange(\n') - self.creditTypeChange.exportLiteral(outfile, level, name_='creditTypeChange') - showIndent(outfile, level) - outfile.write('),\n') - if self.creditTypeInUse is not None: - showIndent(outfile, level) - outfile.write('creditTypeInUse=model_.CreditTypeType(\n') - self.creditTypeInUse.exportLiteral(outfile, level, name_='creditTypeInUse') - showIndent(outfile, level) - outfile.write('),\n') - if self.serviceChange is not None: - showIndent(outfile, level) - outfile.write('serviceChange=model_.ServiceChange(\n') - self.serviceChange.exportLiteral(outfile, level, name_='serviceChange') - showIndent(outfile, level) - outfile.write('),\n') - if self.serviceStatus is not None: - showIndent(outfile, level) - outfile.write('serviceStatus=model_.ServiceStatusType(\n') - self.serviceStatus.exportLiteral(outfile, level, name_='serviceStatus') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PrepayOperationStatus, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'creditTypeChange': - obj_ = CreditTypeChange.factory() - obj_.build(child_) - self.creditTypeChange = obj_ - obj_.original_tagname_ = 'creditTypeChange' - elif nodeName_ == 'creditTypeInUse': - obj_ = CreditTypeType.factory() - obj_.build(child_) - self.creditTypeInUse = obj_ - obj_.original_tagname_ = 'creditTypeInUse' - elif nodeName_ == 'serviceChange': - obj_ = ServiceChange.factory() - obj_.build(child_) - self.serviceChange = obj_ - obj_.original_tagname_ = 'serviceChange' - elif nodeName_ == 'serviceStatus': - obj_ = ServiceStatusType.factory() - obj_.build(child_) - self.serviceStatus = obj_ - obj_.original_tagname_ = 'serviceStatus' - super(PrepayOperationStatus, self).buildChildren(child_, node, nodeName_, True) -# end class PrepayOperationStatus - - -class PrepaymentList(SubscribableList): - """A List element to hold Prepayment objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, Prepayment=None): - self.original_tagname_ = None - super(PrepaymentList, self).__init__() - if Prepayment is None: - self.Prepayment = [] - else: - self.Prepayment = Prepayment - def factory(*args_, **kwargs_): - if PrepaymentList.subclass: - return PrepaymentList.subclass(*args_, **kwargs_) - else: - return PrepaymentList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Prepayment(self): return self.Prepayment - def set_Prepayment(self, Prepayment): self.Prepayment = Prepayment - def add_Prepayment(self, value): self.Prepayment.append(value) - def insert_Prepayment_at(self, index, value): self.Prepayment.insert(index, value) - def replace_Prepayment_at(self, index, value): self.Prepayment[index] = value - def hasContent_(self): - if ( - self.Prepayment or - super(PrepaymentList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PrepaymentList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PrepaymentList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PrepaymentList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PrepaymentList'): - super(PrepaymentList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PrepaymentList') - def exportChildren(self, outfile, level, namespace_='', name_='PrepaymentList', fromsubclass_=False, pretty_print=True): - super(PrepaymentList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for Prepayment_ in self.Prepayment: - Prepayment_.export(outfile, level, namespace_, name_='Prepayment', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='PrepaymentList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PrepaymentList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PrepaymentList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('Prepayment=[\n') - level += 1 - for Prepayment_ in self.Prepayment: - showIndent(outfile, level) - outfile.write('model_.Prepayment(\n') - Prepayment_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PrepaymentList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Prepayment': - obj_ = Prepayment.factory() - obj_.build(child_) - self.Prepayment.append(obj_) - obj_.original_tagname_ = 'Prepayment' - super(PrepaymentList, self).buildChildren(child_, node, nodeName_, True) -# end class PrepaymentList - - -class Prepayment(IdentifiedObject): - """Prepayment (inherited from CIM SDPAccountingFunction)""" - subclass = None - superclass = IdentifiedObject - def __init__(self, AccountBalanceLink=None, ActiveCreditRegisterListLink=None, ActiveSupplyInterruptionOverrideListLink=None, creditExpiryLevel=None, CreditRegisterListLink=None, lowCreditWarningLevel=None, lowEmergencyCreditWarningLevel=None, prepayMode=None, PrepayOperationStatusLink=None, SupplyInterruptionOverrideListLink=None, UsagePoint=None, UsagePointLink=None): - self.original_tagname_ = None - super(Prepayment, self).__init__() - self.AccountBalanceLink = AccountBalanceLink - self.ActiveCreditRegisterListLink = ActiveCreditRegisterListLink - self.ActiveSupplyInterruptionOverrideListLink = ActiveSupplyInterruptionOverrideListLink - self.creditExpiryLevel = creditExpiryLevel - self.CreditRegisterListLink = CreditRegisterListLink - self.lowCreditWarningLevel = lowCreditWarningLevel - self.lowEmergencyCreditWarningLevel = lowEmergencyCreditWarningLevel - self.prepayMode = prepayMode - self.PrepayOperationStatusLink = PrepayOperationStatusLink - self.SupplyInterruptionOverrideListLink = SupplyInterruptionOverrideListLink - if UsagePoint is None: - self.UsagePoint = [] - else: - self.UsagePoint = UsagePoint - self.UsagePointLink = UsagePointLink - def factory(*args_, **kwargs_): - if Prepayment.subclass: - return Prepayment.subclass(*args_, **kwargs_) - else: - return Prepayment(*args_, **kwargs_) - factory = staticmethod(factory) - def get_AccountBalanceLink(self): return self.AccountBalanceLink - def set_AccountBalanceLink(self, AccountBalanceLink): self.AccountBalanceLink = AccountBalanceLink - def get_ActiveCreditRegisterListLink(self): return self.ActiveCreditRegisterListLink - def set_ActiveCreditRegisterListLink(self, ActiveCreditRegisterListLink): self.ActiveCreditRegisterListLink = ActiveCreditRegisterListLink - def get_ActiveSupplyInterruptionOverrideListLink(self): return self.ActiveSupplyInterruptionOverrideListLink - def set_ActiveSupplyInterruptionOverrideListLink(self, ActiveSupplyInterruptionOverrideListLink): self.ActiveSupplyInterruptionOverrideListLink = ActiveSupplyInterruptionOverrideListLink - def get_creditExpiryLevel(self): return self.creditExpiryLevel - def set_creditExpiryLevel(self, creditExpiryLevel): self.creditExpiryLevel = creditExpiryLevel - def get_CreditRegisterListLink(self): return self.CreditRegisterListLink - def set_CreditRegisterListLink(self, CreditRegisterListLink): self.CreditRegisterListLink = CreditRegisterListLink - def get_lowCreditWarningLevel(self): return self.lowCreditWarningLevel - def set_lowCreditWarningLevel(self, lowCreditWarningLevel): self.lowCreditWarningLevel = lowCreditWarningLevel - def get_lowEmergencyCreditWarningLevel(self): return self.lowEmergencyCreditWarningLevel - def set_lowEmergencyCreditWarningLevel(self, lowEmergencyCreditWarningLevel): self.lowEmergencyCreditWarningLevel = lowEmergencyCreditWarningLevel - def get_prepayMode(self): return self.prepayMode - def set_prepayMode(self, prepayMode): self.prepayMode = prepayMode - def get_PrepayOperationStatusLink(self): return self.PrepayOperationStatusLink - def set_PrepayOperationStatusLink(self, PrepayOperationStatusLink): self.PrepayOperationStatusLink = PrepayOperationStatusLink - def get_SupplyInterruptionOverrideListLink(self): return self.SupplyInterruptionOverrideListLink - def set_SupplyInterruptionOverrideListLink(self, SupplyInterruptionOverrideListLink): self.SupplyInterruptionOverrideListLink = SupplyInterruptionOverrideListLink - def get_UsagePoint(self): return self.UsagePoint - def set_UsagePoint(self, UsagePoint): self.UsagePoint = UsagePoint - def add_UsagePoint(self, value): self.UsagePoint.append(value) - def insert_UsagePoint_at(self, index, value): self.UsagePoint.insert(index, value) - def replace_UsagePoint_at(self, index, value): self.UsagePoint[index] = value - def get_UsagePointLink(self): return self.UsagePointLink - def set_UsagePointLink(self, UsagePointLink): self.UsagePointLink = UsagePointLink - def hasContent_(self): - if ( - self.AccountBalanceLink is not None or - self.ActiveCreditRegisterListLink is not None or - self.ActiveSupplyInterruptionOverrideListLink is not None or - self.creditExpiryLevel is not None or - self.CreditRegisterListLink is not None or - self.lowCreditWarningLevel is not None or - self.lowEmergencyCreditWarningLevel is not None or - self.prepayMode is not None or - self.PrepayOperationStatusLink is not None or - self.SupplyInterruptionOverrideListLink is not None or - self.UsagePoint or - self.UsagePointLink is not None or - super(Prepayment, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Prepayment', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Prepayment') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Prepayment', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Prepayment'): - super(Prepayment, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Prepayment') - def exportChildren(self, outfile, level, namespace_='', name_='Prepayment', fromsubclass_=False, pretty_print=True): - super(Prepayment, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.AccountBalanceLink is not None: - self.AccountBalanceLink.export(outfile, level, namespace_, name_='AccountBalanceLink', pretty_print=pretty_print) - if self.ActiveCreditRegisterListLink is not None: - self.ActiveCreditRegisterListLink.export(outfile, level, namespace_, name_='ActiveCreditRegisterListLink', pretty_print=pretty_print) - if self.ActiveSupplyInterruptionOverrideListLink is not None: - self.ActiveSupplyInterruptionOverrideListLink.export(outfile, level, namespace_, name_='ActiveSupplyInterruptionOverrideListLink', pretty_print=pretty_print) - if self.creditExpiryLevel is not None: - self.creditExpiryLevel.export(outfile, level, namespace_, name_='creditExpiryLevel', pretty_print=pretty_print) - if self.CreditRegisterListLink is not None: - self.CreditRegisterListLink.export(outfile, level, namespace_, name_='CreditRegisterListLink', pretty_print=pretty_print) - if self.lowCreditWarningLevel is not None: - self.lowCreditWarningLevel.export(outfile, level, namespace_, name_='lowCreditWarningLevel', pretty_print=pretty_print) - if self.lowEmergencyCreditWarningLevel is not None: - self.lowEmergencyCreditWarningLevel.export(outfile, level, namespace_, name_='lowEmergencyCreditWarningLevel', pretty_print=pretty_print) - if self.prepayMode is not None: - self.prepayMode.export(outfile, level, namespace_, name_='prepayMode', pretty_print=pretty_print) - if self.PrepayOperationStatusLink is not None: - self.PrepayOperationStatusLink.export(outfile, level, namespace_, name_='PrepayOperationStatusLink', pretty_print=pretty_print) - if self.SupplyInterruptionOverrideListLink is not None: - self.SupplyInterruptionOverrideListLink.export(outfile, level, namespace_, name_='SupplyInterruptionOverrideListLink', pretty_print=pretty_print) - for UsagePoint_ in self.UsagePoint: - UsagePoint_.export(outfile, level, namespace_, name_='UsagePoint', pretty_print=pretty_print) - if self.UsagePointLink is not None: - self.UsagePointLink.export(outfile, level, namespace_, name_='UsagePointLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='Prepayment'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Prepayment, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Prepayment, self).exportLiteralChildren(outfile, level, name_) - if self.AccountBalanceLink is not None: - showIndent(outfile, level) - outfile.write('AccountBalanceLink=model_.AccountBalanceLink(\n') - self.AccountBalanceLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ActiveCreditRegisterListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveCreditRegisterListLink=model_.ActiveCreditRegisterListLink(\n') - self.ActiveCreditRegisterListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ActiveSupplyInterruptionOverrideListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveSupplyInterruptionOverrideListLink=model_.ActiveSupplyInterruptionOverrideListLink(\n') - self.ActiveSupplyInterruptionOverrideListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.creditExpiryLevel is not None: - showIndent(outfile, level) - outfile.write('creditExpiryLevel=model_.AccountingUnit(\n') - self.creditExpiryLevel.exportLiteral(outfile, level, name_='creditExpiryLevel') - showIndent(outfile, level) - outfile.write('),\n') - if self.CreditRegisterListLink is not None: - showIndent(outfile, level) - outfile.write('CreditRegisterListLink=model_.CreditRegisterListLink(\n') - self.CreditRegisterListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.lowCreditWarningLevel is not None: - showIndent(outfile, level) - outfile.write('lowCreditWarningLevel=model_.AccountingUnit(\n') - self.lowCreditWarningLevel.exportLiteral(outfile, level, name_='lowCreditWarningLevel') - showIndent(outfile, level) - outfile.write('),\n') - if self.lowEmergencyCreditWarningLevel is not None: - showIndent(outfile, level) - outfile.write('lowEmergencyCreditWarningLevel=model_.AccountingUnit(\n') - self.lowEmergencyCreditWarningLevel.exportLiteral(outfile, level, name_='lowEmergencyCreditWarningLevel') - showIndent(outfile, level) - outfile.write('),\n') - if self.prepayMode is not None: - showIndent(outfile, level) - outfile.write('prepayMode=model_.PrepayModeType(\n') - self.prepayMode.exportLiteral(outfile, level, name_='prepayMode') - showIndent(outfile, level) - outfile.write('),\n') - if self.PrepayOperationStatusLink is not None: - showIndent(outfile, level) - outfile.write('PrepayOperationStatusLink=model_.PrepayOperationStatusLink(\n') - self.PrepayOperationStatusLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.SupplyInterruptionOverrideListLink is not None: - showIndent(outfile, level) - outfile.write('SupplyInterruptionOverrideListLink=model_.SupplyInterruptionOverrideListLink(\n') - self.SupplyInterruptionOverrideListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - showIndent(outfile, level) - outfile.write('UsagePoint=[\n') - level += 1 - for UsagePoint_ in self.UsagePoint: - showIndent(outfile, level) - outfile.write('model_.UsagePoint(\n') - UsagePoint_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - if self.UsagePointLink is not None: - showIndent(outfile, level) - outfile.write('UsagePointLink=model_.UsagePointLink(\n') - self.UsagePointLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Prepayment, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'AccountBalanceLink': - obj_ = AccountBalanceLink.factory() - obj_.build(child_) - self.AccountBalanceLink = obj_ - obj_.original_tagname_ = 'AccountBalanceLink' - elif nodeName_ == 'ActiveCreditRegisterListLink': - obj_ = ActiveCreditRegisterListLink.factory() - obj_.build(child_) - self.ActiveCreditRegisterListLink = obj_ - obj_.original_tagname_ = 'ActiveCreditRegisterListLink' - elif nodeName_ == 'ActiveSupplyInterruptionOverrideListLink': - obj_ = ActiveSupplyInterruptionOverrideListLink.factory() - obj_.build(child_) - self.ActiveSupplyInterruptionOverrideListLink = obj_ - obj_.original_tagname_ = 'ActiveSupplyInterruptionOverrideListLink' - elif nodeName_ == 'creditExpiryLevel': - obj_ = AccountingUnit.factory() - obj_.build(child_) - self.creditExpiryLevel = obj_ - obj_.original_tagname_ = 'creditExpiryLevel' - elif nodeName_ == 'CreditRegisterListLink': - obj_ = CreditRegisterListLink.factory() - obj_.build(child_) - self.CreditRegisterListLink = obj_ - obj_.original_tagname_ = 'CreditRegisterListLink' - elif nodeName_ == 'lowCreditWarningLevel': - obj_ = AccountingUnit.factory() - obj_.build(child_) - self.lowCreditWarningLevel = obj_ - obj_.original_tagname_ = 'lowCreditWarningLevel' - elif nodeName_ == 'lowEmergencyCreditWarningLevel': - obj_ = AccountingUnit.factory() - obj_.build(child_) - self.lowEmergencyCreditWarningLevel = obj_ - obj_.original_tagname_ = 'lowEmergencyCreditWarningLevel' - elif nodeName_ == 'prepayMode': - obj_ = PrepayModeType.factory() - obj_.build(child_) - self.prepayMode = obj_ - obj_.original_tagname_ = 'prepayMode' - elif nodeName_ == 'PrepayOperationStatusLink': - obj_ = PrepayOperationStatusLink.factory() - obj_.build(child_) - self.PrepayOperationStatusLink = obj_ - obj_.original_tagname_ = 'PrepayOperationStatusLink' - elif nodeName_ == 'SupplyInterruptionOverrideListLink': - obj_ = SupplyInterruptionOverrideListLink.factory() - obj_.build(child_) - self.SupplyInterruptionOverrideListLink = obj_ - obj_.original_tagname_ = 'SupplyInterruptionOverrideListLink' - elif nodeName_ == 'UsagePoint': - obj_ = UsagePoint.factory() - obj_.build(child_) - self.UsagePoint.append(obj_) - obj_.original_tagname_ = 'UsagePoint' - elif nodeName_ == 'UsagePointLink': - obj_ = UsagePointLink.factory() - obj_.build(child_) - self.UsagePointLink = obj_ - obj_.original_tagname_ = 'UsagePointLink' - super(Prepayment, self).buildChildren(child_, node, nodeName_, True) -# end class Prepayment - - -class CreditRegisterList(List): - """A List element to hold CreditRegister objects.""" - subclass = None - superclass = List - def __init__(self, CreditRegister=None): - self.original_tagname_ = None - super(CreditRegisterList, self).__init__() - if CreditRegister is None: - self.CreditRegister = [] - else: - self.CreditRegister = CreditRegister - def factory(*args_, **kwargs_): - if CreditRegisterList.subclass: - return CreditRegisterList.subclass(*args_, **kwargs_) - else: - return CreditRegisterList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_CreditRegister(self): return self.CreditRegister - def set_CreditRegister(self, CreditRegister): self.CreditRegister = CreditRegister - def add_CreditRegister(self, value): self.CreditRegister.append(value) - def insert_CreditRegister_at(self, index, value): self.CreditRegister.insert(index, value) - def replace_CreditRegister_at(self, index, value): self.CreditRegister[index] = value - def hasContent_(self): - if ( - self.CreditRegister or - super(CreditRegisterList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CreditRegisterList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CreditRegisterList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CreditRegisterList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CreditRegisterList'): - super(CreditRegisterList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CreditRegisterList') - def exportChildren(self, outfile, level, namespace_='', name_='CreditRegisterList', fromsubclass_=False, pretty_print=True): - super(CreditRegisterList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for CreditRegister_ in self.CreditRegister: - CreditRegister_.export(outfile, level, namespace_, name_='CreditRegister', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='CreditRegisterList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CreditRegisterList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CreditRegisterList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('CreditRegister=[\n') - level += 1 - for CreditRegister_ in self.CreditRegister: - showIndent(outfile, level) - outfile.write('model_.CreditRegister(\n') - CreditRegister_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CreditRegisterList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'CreditRegister': - obj_ = CreditRegister.factory() - obj_.build(child_) - self.CreditRegister.append(obj_) - obj_.original_tagname_ = 'CreditRegister' - super(CreditRegisterList, self).buildChildren(child_, node, nodeName_, True) -# end class CreditRegisterList - - -class CreditRegister(IdentifiedObject): - """CreditRegister instances define a credit-modifying transaction. - Typically this would be a credit-adding transaction, but may be - a subtracting transaction (perhaps in response to an out-of-band - debt signal).""" - subclass = None - superclass = IdentifiedObject - def __init__(self, creditAmount=None, creditType=None, effectiveTime=None, token=None): - self.original_tagname_ = None - super(CreditRegister, self).__init__() - self.creditAmount = creditAmount - self.creditType = creditType - self.effectiveTime = effectiveTime - self.token = token - def factory(*args_, **kwargs_): - if CreditRegister.subclass: - return CreditRegister.subclass(*args_, **kwargs_) - else: - return CreditRegister(*args_, **kwargs_) - factory = staticmethod(factory) - def get_creditAmount(self): return self.creditAmount - def set_creditAmount(self, creditAmount): self.creditAmount = creditAmount - def get_creditType(self): return self.creditType - def set_creditType(self, creditType): self.creditType = creditType - def get_effectiveTime(self): return self.effectiveTime - def set_effectiveTime(self, effectiveTime): self.effectiveTime = effectiveTime - def get_token(self): return self.token - def set_token(self, token): self.token = token - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.creditAmount is not None or - self.creditType is not None or - self.effectiveTime is not None or - self.token is not None or - super(CreditRegister, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CreditRegister', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CreditRegister') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CreditRegister', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CreditRegister'): - super(CreditRegister, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CreditRegister') - def exportChildren(self, outfile, level, namespace_='', name_='CreditRegister', fromsubclass_=False, pretty_print=True): - super(CreditRegister, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.creditAmount is not None: - self.creditAmount.export(outfile, level, namespace_, name_='creditAmount', pretty_print=pretty_print) - if self.creditType is not None: - self.creditType.export(outfile, level, namespace_, name_='creditType', pretty_print=pretty_print) - if self.effectiveTime is not None: - self.effectiveTime.export(outfile, level, namespace_, name_='effectiveTime', pretty_print=pretty_print) - if self.token is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%stoken>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.token).encode(ExternalEncoding), input_name='token'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='CreditRegister'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CreditRegister, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CreditRegister, self).exportLiteralChildren(outfile, level, name_) - if self.creditAmount is not None: - showIndent(outfile, level) - outfile.write('creditAmount=model_.AccountingUnit(\n') - self.creditAmount.exportLiteral(outfile, level, name_='creditAmount') - showIndent(outfile, level) - outfile.write('),\n') - if self.creditType is not None: - showIndent(outfile, level) - outfile.write('creditType=model_.CreditTypeType(\n') - self.creditType.exportLiteral(outfile, level, name_='creditType') - showIndent(outfile, level) - outfile.write('),\n') - if self.effectiveTime is not None: - showIndent(outfile, level) - outfile.write('effectiveTime=model_.TimeType(\n') - self.effectiveTime.exportLiteral(outfile, level, name_='effectiveTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.token is not None: - showIndent(outfile, level) - outfile.write('token=%s,\n' % quote_python(self.token).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CreditRegister, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'creditAmount': - obj_ = AccountingUnit.factory() - obj_.build(child_) - self.creditAmount = obj_ - obj_.original_tagname_ = 'creditAmount' - elif nodeName_ == 'creditType': - obj_ = CreditTypeType.factory() - obj_.build(child_) - self.creditType = obj_ - obj_.original_tagname_ = 'creditType' - elif nodeName_ == 'effectiveTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.effectiveTime = obj_ - obj_.original_tagname_ = 'effectiveTime' - elif nodeName_ == 'token': - token_ = child_.text - token_ = self.gds_validate_string(token_, node, 'token') - self.token = token_ - self.validate_String32(self.token) # validate type String32 - super(CreditRegister, self).buildChildren(child_, node, nodeName_, True) -# end class CreditRegister - - -class AccountBalance(Resource): - """AccountBalance contains the regular credit and emergency credit - balance for this given service or commodity prepay instance. It - may also contain status information concerning the balance data.""" - subclass = None - superclass = Resource - def __init__(self, availableCredit=None, creditStatus=None, emergencyCredit=None, emergencyCreditStatus=None): - self.original_tagname_ = None - super(AccountBalance, self).__init__() - self.availableCredit = availableCredit - self.creditStatus = creditStatus - self.emergencyCredit = emergencyCredit - self.emergencyCreditStatus = emergencyCreditStatus - def factory(*args_, **kwargs_): - if AccountBalance.subclass: - return AccountBalance.subclass(*args_, **kwargs_) - else: - return AccountBalance(*args_, **kwargs_) - factory = staticmethod(factory) - def get_availableCredit(self): return self.availableCredit - def set_availableCredit(self, availableCredit): self.availableCredit = availableCredit - def get_creditStatus(self): return self.creditStatus - def set_creditStatus(self, creditStatus): self.creditStatus = creditStatus - def get_emergencyCredit(self): return self.emergencyCredit - def set_emergencyCredit(self, emergencyCredit): self.emergencyCredit = emergencyCredit - def get_emergencyCreditStatus(self): return self.emergencyCreditStatus - def set_emergencyCreditStatus(self, emergencyCreditStatus): self.emergencyCreditStatus = emergencyCreditStatus - def hasContent_(self): - if ( - self.availableCredit is not None or - self.creditStatus is not None or - self.emergencyCredit is not None or - self.emergencyCreditStatus is not None or - super(AccountBalance, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AccountBalance', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AccountBalance') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AccountBalance', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AccountBalance'): - super(AccountBalance, self).exportAttributes(outfile, level, already_processed, namespace_, name_='AccountBalance') - def exportChildren(self, outfile, level, namespace_='', name_='AccountBalance', fromsubclass_=False, pretty_print=True): - super(AccountBalance, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.availableCredit is not None: - self.availableCredit.export(outfile, level, namespace_, name_='availableCredit', pretty_print=pretty_print) - if self.creditStatus is not None: - self.creditStatus.export(outfile, level, namespace_, name_='creditStatus', pretty_print=pretty_print) - if self.emergencyCredit is not None: - self.emergencyCredit.export(outfile, level, namespace_, name_='emergencyCredit', pretty_print=pretty_print) - if self.emergencyCreditStatus is not None: - self.emergencyCreditStatus.export(outfile, level, namespace_, name_='emergencyCreditStatus', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='AccountBalance'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(AccountBalance, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(AccountBalance, self).exportLiteralChildren(outfile, level, name_) - if self.availableCredit is not None: - showIndent(outfile, level) - outfile.write('availableCredit=model_.AccountingUnit(\n') - self.availableCredit.exportLiteral(outfile, level, name_='availableCredit') - showIndent(outfile, level) - outfile.write('),\n') - if self.creditStatus is not None: - showIndent(outfile, level) - outfile.write('creditStatus=model_.CreditStatusType(\n') - self.creditStatus.exportLiteral(outfile, level, name_='creditStatus') - showIndent(outfile, level) - outfile.write('),\n') - if self.emergencyCredit is not None: - showIndent(outfile, level) - outfile.write('emergencyCredit=model_.AccountingUnit(\n') - self.emergencyCredit.exportLiteral(outfile, level, name_='emergencyCredit') - showIndent(outfile, level) - outfile.write('),\n') - if self.emergencyCreditStatus is not None: - showIndent(outfile, level) - outfile.write('emergencyCreditStatus=model_.CreditStatusType(\n') - self.emergencyCreditStatus.exportLiteral(outfile, level, name_='emergencyCreditStatus') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(AccountBalance, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'availableCredit': - obj_ = AccountingUnit.factory() - obj_.build(child_) - self.availableCredit = obj_ - obj_.original_tagname_ = 'availableCredit' - elif nodeName_ == 'creditStatus': - obj_ = CreditStatusType.factory() - obj_.build(child_) - self.creditStatus = obj_ - obj_.original_tagname_ = 'creditStatus' - elif nodeName_ == 'emergencyCredit': - obj_ = AccountingUnit.factory() - obj_.build(child_) - self.emergencyCredit = obj_ - obj_.original_tagname_ = 'emergencyCredit' - elif nodeName_ == 'emergencyCreditStatus': - obj_ = CreditStatusType.factory() - obj_.build(child_) - self.emergencyCreditStatus = obj_ - obj_.original_tagname_ = 'emergencyCreditStatus' - super(AccountBalance, self).buildChildren(child_, node, nodeName_, True) -# end class AccountBalance - - -class ServiceSupplierList(List): - """A List element to hold ServiceSupplier objects.""" - subclass = None - superclass = List - def __init__(self, ServiceSupplier=None): - self.original_tagname_ = None - super(ServiceSupplierList, self).__init__() - if ServiceSupplier is None: - self.ServiceSupplier = [] - else: - self.ServiceSupplier = ServiceSupplier - def factory(*args_, **kwargs_): - if ServiceSupplierList.subclass: - return ServiceSupplierList.subclass(*args_, **kwargs_) - else: - return ServiceSupplierList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ServiceSupplier(self): return self.ServiceSupplier - def set_ServiceSupplier(self, ServiceSupplier): self.ServiceSupplier = ServiceSupplier - def add_ServiceSupplier(self, value): self.ServiceSupplier.append(value) - def insert_ServiceSupplier_at(self, index, value): self.ServiceSupplier.insert(index, value) - def replace_ServiceSupplier_at(self, index, value): self.ServiceSupplier[index] = value - def hasContent_(self): - if ( - self.ServiceSupplier or - super(ServiceSupplierList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ServiceSupplierList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceSupplierList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ServiceSupplierList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ServiceSupplierList'): - super(ServiceSupplierList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceSupplierList') - def exportChildren(self, outfile, level, namespace_='', name_='ServiceSupplierList', fromsubclass_=False, pretty_print=True): - super(ServiceSupplierList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for ServiceSupplier_ in self.ServiceSupplier: - ServiceSupplier_.export(outfile, level, namespace_, name_='ServiceSupplier', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ServiceSupplierList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ServiceSupplierList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ServiceSupplierList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('ServiceSupplier=[\n') - level += 1 - for ServiceSupplier_ in self.ServiceSupplier: - showIndent(outfile, level) - outfile.write('model_.ServiceSupplier(\n') - ServiceSupplier_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ServiceSupplierList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ServiceSupplier': - obj_ = ServiceSupplier.factory() - obj_.build(child_) - self.ServiceSupplier.append(obj_) - obj_.original_tagname_ = 'ServiceSupplier' - super(ServiceSupplierList, self).buildChildren(child_, node, nodeName_, True) -# end class ServiceSupplierList - - -class ServiceSupplier(IdentifiedObject): - """Organisation that provides services to Customers.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, email=None, phone=None, providerID=None, web=None): - self.original_tagname_ = None - super(ServiceSupplier, self).__init__() - self.email = email - self.phone = phone - self.providerID = providerID - self.web = web - def factory(*args_, **kwargs_): - if ServiceSupplier.subclass: - return ServiceSupplier.subclass(*args_, **kwargs_) - else: - return ServiceSupplier(*args_, **kwargs_) - factory = staticmethod(factory) - def get_email(self): return self.email - def set_email(self, email): self.email = email - def get_phone(self): return self.phone - def set_phone(self, phone): self.phone = phone - def get_providerID(self): return self.providerID - def set_providerID(self, providerID): self.providerID = providerID - def get_web(self): return self.web - def set_web(self, web): self.web = web - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def validate_String20(self, value): - # Validate type String20, a restriction on xs:string. - pass - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def validate_String42(self, value): - # Validate type String42, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.email is not None or - self.phone is not None or - self.providerID is not None or - self.web is not None or - super(ServiceSupplier, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ServiceSupplier', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceSupplier') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ServiceSupplier', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ServiceSupplier'): - super(ServiceSupplier, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ServiceSupplier') - def exportChildren(self, outfile, level, namespace_='', name_='ServiceSupplier', fromsubclass_=False, pretty_print=True): - super(ServiceSupplier, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.email is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%semail>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.email).encode(ExternalEncoding), input_name='email'), namespace_, eol_)) - if self.phone is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sphone>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.phone).encode(ExternalEncoding), input_name='phone'), namespace_, eol_)) - if self.providerID is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sproviderID>%s%s' % (namespace_, self.gds_format_integer(self.providerID, input_name='providerID'), namespace_, eol_)) - if self.web is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sweb>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.web).encode(ExternalEncoding), input_name='web'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='ServiceSupplier'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ServiceSupplier, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ServiceSupplier, self).exportLiteralChildren(outfile, level, name_) - if self.email is not None: - showIndent(outfile, level) - outfile.write('email=%s,\n' % quote_python(self.email).encode(ExternalEncoding)) - if self.phone is not None: - showIndent(outfile, level) - outfile.write('phone=%s,\n' % quote_python(self.phone).encode(ExternalEncoding)) - if self.providerID is not None: - showIndent(outfile, level) - outfile.write('providerID=%d,\n' % self.providerID) - if self.web is not None: - showIndent(outfile, level) - outfile.write('web=%s,\n' % quote_python(self.web).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ServiceSupplier, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'email': - email_ = child_.text - email_ = self.gds_validate_string(email_, node, 'email') - self.email = email_ - self.validate_String32(self.email) # validate type String32 - elif nodeName_ == 'phone': - phone_ = child_.text - phone_ = self.gds_validate_string(phone_, node, 'phone') - self.phone = phone_ - self.validate_String20(self.phone) # validate type String20 - elif nodeName_ == 'providerID': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'providerID') - self.providerID = ival_ - self.validate_UInt32(self.providerID) # validate type UInt32 - elif nodeName_ == 'web': - web_ = child_.text - web_ = self.gds_validate_string(web_, node, 'web') - self.web = web_ - self.validate_String42(self.web) # validate type String42 - super(ServiceSupplier, self).buildChildren(child_, node, nodeName_, True) -# end class ServiceSupplier - - -class TargetReadingList(List): - """A List element to hold TargetReading objects.""" - subclass = None - superclass = List - def __init__(self, TargetReading=None): - self.original_tagname_ = None - super(TargetReadingList, self).__init__() - if TargetReading is None: - self.TargetReading = [] - else: - self.TargetReading = TargetReading - def factory(*args_, **kwargs_): - if TargetReadingList.subclass: - return TargetReadingList.subclass(*args_, **kwargs_) - else: - return TargetReadingList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_TargetReading(self): return self.TargetReading - def set_TargetReading(self, TargetReading): self.TargetReading = TargetReading - def add_TargetReading(self, value): self.TargetReading.append(value) - def insert_TargetReading_at(self, index, value): self.TargetReading.insert(index, value) - def replace_TargetReading_at(self, index, value): self.TargetReading[index] = value - def hasContent_(self): - if ( - self.TargetReading or - super(TargetReadingList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TargetReadingList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TargetReadingList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TargetReadingList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TargetReadingList'): - super(TargetReadingList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TargetReadingList') - def exportChildren(self, outfile, level, namespace_='', name_='TargetReadingList', fromsubclass_=False, pretty_print=True): - super(TargetReadingList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for TargetReading_ in self.TargetReading: - TargetReading_.export(outfile, level, namespace_, name_='TargetReading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='TargetReadingList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TargetReadingList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TargetReadingList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('TargetReading=[\n') - level += 1 - for TargetReading_ in self.TargetReading: - showIndent(outfile, level) - outfile.write('model_.TargetReading(\n') - TargetReading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TargetReadingList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'TargetReading': - obj_ = TargetReading.factory() - obj_.build(child_) - self.TargetReading.append(obj_) - obj_.original_tagname_ = 'TargetReading' - super(TargetReadingList, self).buildChildren(child_, node, nodeName_, True) -# end class TargetReadingList - - -class ProjectionReadingList(List): - """A List element to hold ProjectionReading objects.""" - subclass = None - superclass = List - def __init__(self, ProjectionReading=None): - self.original_tagname_ = None - super(ProjectionReadingList, self).__init__() - if ProjectionReading is None: - self.ProjectionReading = [] - else: - self.ProjectionReading = ProjectionReading - def factory(*args_, **kwargs_): - if ProjectionReadingList.subclass: - return ProjectionReadingList.subclass(*args_, **kwargs_) - else: - return ProjectionReadingList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ProjectionReading(self): return self.ProjectionReading - def set_ProjectionReading(self, ProjectionReading): self.ProjectionReading = ProjectionReading - def add_ProjectionReading(self, value): self.ProjectionReading.append(value) - def insert_ProjectionReading_at(self, index, value): self.ProjectionReading.insert(index, value) - def replace_ProjectionReading_at(self, index, value): self.ProjectionReading[index] = value - def hasContent_(self): - if ( - self.ProjectionReading or - super(ProjectionReadingList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ProjectionReadingList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ProjectionReadingList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ProjectionReadingList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ProjectionReadingList'): - super(ProjectionReadingList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ProjectionReadingList') - def exportChildren(self, outfile, level, namespace_='', name_='ProjectionReadingList', fromsubclass_=False, pretty_print=True): - super(ProjectionReadingList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for ProjectionReading_ in self.ProjectionReading: - ProjectionReading_.export(outfile, level, namespace_, name_='ProjectionReading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ProjectionReadingList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ProjectionReadingList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ProjectionReadingList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('ProjectionReading=[\n') - level += 1 - for ProjectionReading_ in self.ProjectionReading: - showIndent(outfile, level) - outfile.write('model_.ProjectionReading(\n') - ProjectionReading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ProjectionReadingList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ProjectionReading': - obj_ = ProjectionReading.factory() - obj_.build(child_) - self.ProjectionReading.append(obj_) - obj_.original_tagname_ = 'ProjectionReading' - super(ProjectionReadingList, self).buildChildren(child_, node, nodeName_, True) -# end class ProjectionReadingList - - -class HistoricalReadingList(List): - """A List element to hold HistoricalReading objects.""" - subclass = None - superclass = List - def __init__(self, HistoricalReading=None): - self.original_tagname_ = None - super(HistoricalReadingList, self).__init__() - if HistoricalReading is None: - self.HistoricalReading = [] - else: - self.HistoricalReading = HistoricalReading - def factory(*args_, **kwargs_): - if HistoricalReadingList.subclass: - return HistoricalReadingList.subclass(*args_, **kwargs_) - else: - return HistoricalReadingList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_HistoricalReading(self): return self.HistoricalReading - def set_HistoricalReading(self, HistoricalReading): self.HistoricalReading = HistoricalReading - def add_HistoricalReading(self, value): self.HistoricalReading.append(value) - def insert_HistoricalReading_at(self, index, value): self.HistoricalReading.insert(index, value) - def replace_HistoricalReading_at(self, index, value): self.HistoricalReading[index] = value - def hasContent_(self): - if ( - self.HistoricalReading or - super(HistoricalReadingList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='HistoricalReadingList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='HistoricalReadingList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='HistoricalReadingList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='HistoricalReadingList'): - super(HistoricalReadingList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='HistoricalReadingList') - def exportChildren(self, outfile, level, namespace_='', name_='HistoricalReadingList', fromsubclass_=False, pretty_print=True): - super(HistoricalReadingList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for HistoricalReading_ in self.HistoricalReading: - HistoricalReading_.export(outfile, level, namespace_, name_='HistoricalReading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='HistoricalReadingList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(HistoricalReadingList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(HistoricalReadingList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('HistoricalReading=[\n') - level += 1 - for HistoricalReading_ in self.HistoricalReading: - showIndent(outfile, level) - outfile.write('model_.HistoricalReading(\n') - HistoricalReading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(HistoricalReadingList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'HistoricalReading': - obj_ = HistoricalReading.factory() - obj_.build(child_) - self.HistoricalReading.append(obj_) - obj_.original_tagname_ = 'HistoricalReading' - super(HistoricalReadingList, self).buildChildren(child_, node, nodeName_, True) -# end class HistoricalReadingList - - -class CustomerAgreementList(SubscribableList): - """A List element to hold CustomerAgreement objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, CustomerAgreement=None): - self.original_tagname_ = None - super(CustomerAgreementList, self).__init__() - if CustomerAgreement is None: - self.CustomerAgreement = [] - else: - self.CustomerAgreement = CustomerAgreement - def factory(*args_, **kwargs_): - if CustomerAgreementList.subclass: - return CustomerAgreementList.subclass(*args_, **kwargs_) - else: - return CustomerAgreementList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_CustomerAgreement(self): return self.CustomerAgreement - def set_CustomerAgreement(self, CustomerAgreement): self.CustomerAgreement = CustomerAgreement - def add_CustomerAgreement(self, value): self.CustomerAgreement.append(value) - def insert_CustomerAgreement_at(self, index, value): self.CustomerAgreement.insert(index, value) - def replace_CustomerAgreement_at(self, index, value): self.CustomerAgreement[index] = value - def hasContent_(self): - if ( - self.CustomerAgreement or - super(CustomerAgreementList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CustomerAgreementList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAgreementList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CustomerAgreementList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CustomerAgreementList'): - super(CustomerAgreementList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAgreementList') - def exportChildren(self, outfile, level, namespace_='', name_='CustomerAgreementList', fromsubclass_=False, pretty_print=True): - super(CustomerAgreementList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for CustomerAgreement_ in self.CustomerAgreement: - CustomerAgreement_.export(outfile, level, namespace_, name_='CustomerAgreement', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='CustomerAgreementList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CustomerAgreementList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CustomerAgreementList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('CustomerAgreement=[\n') - level += 1 - for CustomerAgreement_ in self.CustomerAgreement: - showIndent(outfile, level) - outfile.write('model_.CustomerAgreement(\n') - CustomerAgreement_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CustomerAgreementList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'CustomerAgreement': - obj_ = CustomerAgreement.factory() - obj_.build(child_) - self.CustomerAgreement.append(obj_) - obj_.original_tagname_ = 'CustomerAgreement' - super(CustomerAgreementList, self).buildChildren(child_, node, nodeName_, True) -# end class CustomerAgreementList - - -class CustomerAgreement(IdentifiedObject): - """Agreement between the customer and the service supplier to pay for - service at a specific service location. It records certain - billing information about the type of service provided at the - service location and is used during charge creation to determine - the type of service.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, ActiveBillingPeriodListLink=None, ActiveProjectionReadingListLink=None, ActiveTargetReadingListLink=None, BillingPeriodListLink=None, HistoricalReadingListLink=None, PrepaymentLink=None, ProjectionReadingListLink=None, serviceAccount=None, serviceLocation=None, TargetReadingListLink=None, TariffProfileLink=None, UsagePointLink=None): - self.original_tagname_ = None - super(CustomerAgreement, self).__init__() - self.ActiveBillingPeriodListLink = ActiveBillingPeriodListLink - self.ActiveProjectionReadingListLink = ActiveProjectionReadingListLink - self.ActiveTargetReadingListLink = ActiveTargetReadingListLink - self.BillingPeriodListLink = BillingPeriodListLink - self.HistoricalReadingListLink = HistoricalReadingListLink - self.PrepaymentLink = PrepaymentLink - self.ProjectionReadingListLink = ProjectionReadingListLink - self.serviceAccount = serviceAccount - self.serviceLocation = serviceLocation - self.TargetReadingListLink = TargetReadingListLink - self.TariffProfileLink = TariffProfileLink - self.UsagePointLink = UsagePointLink - def factory(*args_, **kwargs_): - if CustomerAgreement.subclass: - return CustomerAgreement.subclass(*args_, **kwargs_) - else: - return CustomerAgreement(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ActiveBillingPeriodListLink(self): return self.ActiveBillingPeriodListLink - def set_ActiveBillingPeriodListLink(self, ActiveBillingPeriodListLink): self.ActiveBillingPeriodListLink = ActiveBillingPeriodListLink - def get_ActiveProjectionReadingListLink(self): return self.ActiveProjectionReadingListLink - def set_ActiveProjectionReadingListLink(self, ActiveProjectionReadingListLink): self.ActiveProjectionReadingListLink = ActiveProjectionReadingListLink - def get_ActiveTargetReadingListLink(self): return self.ActiveTargetReadingListLink - def set_ActiveTargetReadingListLink(self, ActiveTargetReadingListLink): self.ActiveTargetReadingListLink = ActiveTargetReadingListLink - def get_BillingPeriodListLink(self): return self.BillingPeriodListLink - def set_BillingPeriodListLink(self, BillingPeriodListLink): self.BillingPeriodListLink = BillingPeriodListLink - def get_HistoricalReadingListLink(self): return self.HistoricalReadingListLink - def set_HistoricalReadingListLink(self, HistoricalReadingListLink): self.HistoricalReadingListLink = HistoricalReadingListLink - def get_PrepaymentLink(self): return self.PrepaymentLink - def set_PrepaymentLink(self, PrepaymentLink): self.PrepaymentLink = PrepaymentLink - def get_ProjectionReadingListLink(self): return self.ProjectionReadingListLink - def set_ProjectionReadingListLink(self, ProjectionReadingListLink): self.ProjectionReadingListLink = ProjectionReadingListLink - def get_serviceAccount(self): return self.serviceAccount - def set_serviceAccount(self, serviceAccount): self.serviceAccount = serviceAccount - def get_serviceLocation(self): return self.serviceLocation - def set_serviceLocation(self, serviceLocation): self.serviceLocation = serviceLocation - def get_TargetReadingListLink(self): return self.TargetReadingListLink - def set_TargetReadingListLink(self, TargetReadingListLink): self.TargetReadingListLink = TargetReadingListLink - def get_TariffProfileLink(self): return self.TariffProfileLink - def set_TariffProfileLink(self, TariffProfileLink): self.TariffProfileLink = TariffProfileLink - def get_UsagePointLink(self): return self.UsagePointLink - def set_UsagePointLink(self, UsagePointLink): self.UsagePointLink = UsagePointLink - def validate_String42(self, value): - # Validate type String42, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.ActiveBillingPeriodListLink is not None or - self.ActiveProjectionReadingListLink is not None or - self.ActiveTargetReadingListLink is not None or - self.BillingPeriodListLink is not None or - self.HistoricalReadingListLink is not None or - self.PrepaymentLink is not None or - self.ProjectionReadingListLink is not None or - self.serviceAccount is not None or - self.serviceLocation is not None or - self.TargetReadingListLink is not None or - self.TariffProfileLink is not None or - self.UsagePointLink is not None or - super(CustomerAgreement, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CustomerAgreement', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAgreement') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CustomerAgreement', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CustomerAgreement'): - super(CustomerAgreement, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAgreement') - def exportChildren(self, outfile, level, namespace_='', name_='CustomerAgreement', fromsubclass_=False, pretty_print=True): - super(CustomerAgreement, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ActiveBillingPeriodListLink is not None: - self.ActiveBillingPeriodListLink.export(outfile, level, namespace_, name_='ActiveBillingPeriodListLink', pretty_print=pretty_print) - if self.ActiveProjectionReadingListLink is not None: - self.ActiveProjectionReadingListLink.export(outfile, level, namespace_, name_='ActiveProjectionReadingListLink', pretty_print=pretty_print) - if self.ActiveTargetReadingListLink is not None: - self.ActiveTargetReadingListLink.export(outfile, level, namespace_, name_='ActiveTargetReadingListLink', pretty_print=pretty_print) - if self.BillingPeriodListLink is not None: - self.BillingPeriodListLink.export(outfile, level, namespace_, name_='BillingPeriodListLink', pretty_print=pretty_print) - if self.HistoricalReadingListLink is not None: - self.HistoricalReadingListLink.export(outfile, level, namespace_, name_='HistoricalReadingListLink', pretty_print=pretty_print) - if self.PrepaymentLink is not None: - self.PrepaymentLink.export(outfile, level, namespace_, name_='PrepaymentLink', pretty_print=pretty_print) - if self.ProjectionReadingListLink is not None: - self.ProjectionReadingListLink.export(outfile, level, namespace_, name_='ProjectionReadingListLink', pretty_print=pretty_print) - if self.serviceAccount is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sserviceAccount>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.serviceAccount).encode(ExternalEncoding), input_name='serviceAccount'), namespace_, eol_)) - if self.serviceLocation is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sserviceLocation>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.serviceLocation).encode(ExternalEncoding), input_name='serviceLocation'), namespace_, eol_)) - if self.TargetReadingListLink is not None: - self.TargetReadingListLink.export(outfile, level, namespace_, name_='TargetReadingListLink', pretty_print=pretty_print) - if self.TariffProfileLink is not None: - self.TariffProfileLink.export(outfile, level, namespace_, name_='TariffProfileLink', pretty_print=pretty_print) - if self.UsagePointLink is not None: - self.UsagePointLink.export(outfile, level, namespace_, name_='UsagePointLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='CustomerAgreement'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CustomerAgreement, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CustomerAgreement, self).exportLiteralChildren(outfile, level, name_) - if self.ActiveBillingPeriodListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveBillingPeriodListLink=model_.ActiveBillingPeriodListLink(\n') - self.ActiveBillingPeriodListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ActiveProjectionReadingListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveProjectionReadingListLink=model_.ActiveProjectionReadingListLink(\n') - self.ActiveProjectionReadingListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ActiveTargetReadingListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveTargetReadingListLink=model_.ActiveTargetReadingListLink(\n') - self.ActiveTargetReadingListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.BillingPeriodListLink is not None: - showIndent(outfile, level) - outfile.write('BillingPeriodListLink=model_.BillingPeriodListLink(\n') - self.BillingPeriodListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.HistoricalReadingListLink is not None: - showIndent(outfile, level) - outfile.write('HistoricalReadingListLink=model_.HistoricalReadingListLink(\n') - self.HistoricalReadingListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.PrepaymentLink is not None: - showIndent(outfile, level) - outfile.write('PrepaymentLink=model_.PrepaymentLink(\n') - self.PrepaymentLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ProjectionReadingListLink is not None: - showIndent(outfile, level) - outfile.write('ProjectionReadingListLink=model_.ProjectionReadingListLink(\n') - self.ProjectionReadingListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.serviceAccount is not None: - showIndent(outfile, level) - outfile.write('serviceAccount=%s,\n' % quote_python(self.serviceAccount).encode(ExternalEncoding)) - if self.serviceLocation is not None: - showIndent(outfile, level) - outfile.write('serviceLocation=%s,\n' % quote_python(self.serviceLocation).encode(ExternalEncoding)) - if self.TargetReadingListLink is not None: - showIndent(outfile, level) - outfile.write('TargetReadingListLink=model_.TargetReadingListLink(\n') - self.TargetReadingListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.TariffProfileLink is not None: - showIndent(outfile, level) - outfile.write('TariffProfileLink=model_.TariffProfileLink(\n') - self.TariffProfileLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.UsagePointLink is not None: - showIndent(outfile, level) - outfile.write('UsagePointLink=model_.UsagePointLink(\n') - self.UsagePointLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CustomerAgreement, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ActiveBillingPeriodListLink': - obj_ = ActiveBillingPeriodListLink.factory() - obj_.build(child_) - self.ActiveBillingPeriodListLink = obj_ - obj_.original_tagname_ = 'ActiveBillingPeriodListLink' - elif nodeName_ == 'ActiveProjectionReadingListLink': - obj_ = ActiveProjectionReadingListLink.factory() - obj_.build(child_) - self.ActiveProjectionReadingListLink = obj_ - obj_.original_tagname_ = 'ActiveProjectionReadingListLink' - elif nodeName_ == 'ActiveTargetReadingListLink': - obj_ = ActiveTargetReadingListLink.factory() - obj_.build(child_) - self.ActiveTargetReadingListLink = obj_ - obj_.original_tagname_ = 'ActiveTargetReadingListLink' - elif nodeName_ == 'BillingPeriodListLink': - obj_ = BillingPeriodListLink.factory() - obj_.build(child_) - self.BillingPeriodListLink = obj_ - obj_.original_tagname_ = 'BillingPeriodListLink' - elif nodeName_ == 'HistoricalReadingListLink': - obj_ = HistoricalReadingListLink.factory() - obj_.build(child_) - self.HistoricalReadingListLink = obj_ - obj_.original_tagname_ = 'HistoricalReadingListLink' - elif nodeName_ == 'PrepaymentLink': - obj_ = PrepaymentLink.factory() - obj_.build(child_) - self.PrepaymentLink = obj_ - obj_.original_tagname_ = 'PrepaymentLink' - elif nodeName_ == 'ProjectionReadingListLink': - obj_ = ProjectionReadingListLink.factory() - obj_.build(child_) - self.ProjectionReadingListLink = obj_ - obj_.original_tagname_ = 'ProjectionReadingListLink' - elif nodeName_ == 'serviceAccount': - serviceAccount_ = child_.text - serviceAccount_ = self.gds_validate_string(serviceAccount_, node, 'serviceAccount') - self.serviceAccount = serviceAccount_ - self.validate_String42(self.serviceAccount) # validate type String42 - elif nodeName_ == 'serviceLocation': - serviceLocation_ = child_.text - serviceLocation_ = self.gds_validate_string(serviceLocation_, node, 'serviceLocation') - self.serviceLocation = serviceLocation_ - self.validate_String42(self.serviceLocation) # validate type String42 - elif nodeName_ == 'TargetReadingListLink': - obj_ = TargetReadingListLink.factory() - obj_.build(child_) - self.TargetReadingListLink = obj_ - obj_.original_tagname_ = 'TargetReadingListLink' - elif nodeName_ == 'TariffProfileLink': - obj_ = TariffProfileLink.factory() - obj_.build(child_) - self.TariffProfileLink = obj_ - obj_.original_tagname_ = 'TariffProfileLink' - elif nodeName_ == 'UsagePointLink': - obj_ = UsagePointLink.factory() - obj_.build(child_) - self.UsagePointLink = obj_ - obj_.original_tagname_ = 'UsagePointLink' - super(CustomerAgreement, self).buildChildren(child_, node, nodeName_, True) -# end class CustomerAgreement - - -class CustomerAccountList(SubscribableList): - """A List element to hold CustomerAccount objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, CustomerAccount=None): - self.original_tagname_ = None - super(CustomerAccountList, self).__init__() - if CustomerAccount is None: - self.CustomerAccount = [] - else: - self.CustomerAccount = CustomerAccount - def factory(*args_, **kwargs_): - if CustomerAccountList.subclass: - return CustomerAccountList.subclass(*args_, **kwargs_) - else: - return CustomerAccountList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_CustomerAccount(self): return self.CustomerAccount - def set_CustomerAccount(self, CustomerAccount): self.CustomerAccount = CustomerAccount - def add_CustomerAccount(self, value): self.CustomerAccount.append(value) - def insert_CustomerAccount_at(self, index, value): self.CustomerAccount.insert(index, value) - def replace_CustomerAccount_at(self, index, value): self.CustomerAccount[index] = value - def hasContent_(self): - if ( - self.CustomerAccount or - super(CustomerAccountList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CustomerAccountList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAccountList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CustomerAccountList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CustomerAccountList'): - super(CustomerAccountList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAccountList') - def exportChildren(self, outfile, level, namespace_='', name_='CustomerAccountList', fromsubclass_=False, pretty_print=True): - super(CustomerAccountList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for CustomerAccount_ in self.CustomerAccount: - CustomerAccount_.export(outfile, level, namespace_, name_='CustomerAccount', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='CustomerAccountList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CustomerAccountList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CustomerAccountList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('CustomerAccount=[\n') - level += 1 - for CustomerAccount_ in self.CustomerAccount: - showIndent(outfile, level) - outfile.write('model_.CustomerAccount(\n') - CustomerAccount_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CustomerAccountList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'CustomerAccount': - obj_ = CustomerAccount.factory() - obj_.build(child_) - self.CustomerAccount.append(obj_) - obj_.original_tagname_ = 'CustomerAccount' - super(CustomerAccountList, self).buildChildren(child_, node, nodeName_, True) -# end class CustomerAccountList - - -class CustomerAccount(IdentifiedObject): - """Assignment of a group of products and services purchased by the - Customer through a CustomerAgreement, used as a mechanism for - customer billing and payment. It contains common information - from the various types of CustomerAgreements to create billings - (invoices) for a Customer and receive payment.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, currency=None, customerAccount=None, CustomerAgreementListLink=None, customerName=None, pricePowerOfTenMultiplier=None, ServiceSupplierLink=None): - self.original_tagname_ = None - super(CustomerAccount, self).__init__() - self.currency = currency - self.customerAccount = customerAccount - self.CustomerAgreementListLink = CustomerAgreementListLink - self.customerName = customerName - self.pricePowerOfTenMultiplier = pricePowerOfTenMultiplier - self.ServiceSupplierLink = ServiceSupplierLink - def factory(*args_, **kwargs_): - if CustomerAccount.subclass: - return CustomerAccount.subclass(*args_, **kwargs_) - else: - return CustomerAccount(*args_, **kwargs_) - factory = staticmethod(factory) - def get_currency(self): return self.currency - def set_currency(self, currency): self.currency = currency - def get_customerAccount(self): return self.customerAccount - def set_customerAccount(self, customerAccount): self.customerAccount = customerAccount - def get_CustomerAgreementListLink(self): return self.CustomerAgreementListLink - def set_CustomerAgreementListLink(self, CustomerAgreementListLink): self.CustomerAgreementListLink = CustomerAgreementListLink - def get_customerName(self): return self.customerName - def set_customerName(self, customerName): self.customerName = customerName - def get_pricePowerOfTenMultiplier(self): return self.pricePowerOfTenMultiplier - def set_pricePowerOfTenMultiplier(self, pricePowerOfTenMultiplier): self.pricePowerOfTenMultiplier = pricePowerOfTenMultiplier - def get_ServiceSupplierLink(self): return self.ServiceSupplierLink - def set_ServiceSupplierLink(self, ServiceSupplierLink): self.ServiceSupplierLink = ServiceSupplierLink - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def validate_String42(self, value): - # Validate type String42, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.currency is not None or - self.customerAccount is not None or - self.CustomerAgreementListLink is not None or - self.customerName is not None or - self.pricePowerOfTenMultiplier is not None or - self.ServiceSupplierLink is not None or - super(CustomerAccount, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='CustomerAccount', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAccount') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='CustomerAccount', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='CustomerAccount'): - super(CustomerAccount, self).exportAttributes(outfile, level, already_processed, namespace_, name_='CustomerAccount') - def exportChildren(self, outfile, level, namespace_='', name_='CustomerAccount', fromsubclass_=False, pretty_print=True): - super(CustomerAccount, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.currency is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%scurrency>%s%s' % (namespace_, self.gds_format_integer(self.currency, input_name='currency'), namespace_, eol_)) - if self.customerAccount is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%scustomerAccount>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.customerAccount).encode(ExternalEncoding), input_name='customerAccount'), namespace_, eol_)) - if self.CustomerAgreementListLink is not None: - self.CustomerAgreementListLink.export(outfile, level, namespace_, name_='CustomerAgreementListLink', pretty_print=pretty_print) - if self.customerName is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%scustomerName>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.customerName).encode(ExternalEncoding), input_name='customerName'), namespace_, eol_)) - if self.pricePowerOfTenMultiplier is not None: - self.pricePowerOfTenMultiplier.export(outfile, level, namespace_, name_='pricePowerOfTenMultiplier', pretty_print=pretty_print) - if self.ServiceSupplierLink is not None: - self.ServiceSupplierLink.export(outfile, level, namespace_, name_='ServiceSupplierLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='CustomerAccount'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(CustomerAccount, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(CustomerAccount, self).exportLiteralChildren(outfile, level, name_) - if self.currency is not None: - showIndent(outfile, level) - outfile.write('currency=%d,\n' % self.currency) - if self.customerAccount is not None: - showIndent(outfile, level) - outfile.write('customerAccount=%s,\n' % quote_python(self.customerAccount).encode(ExternalEncoding)) - if self.CustomerAgreementListLink is not None: - showIndent(outfile, level) - outfile.write('CustomerAgreementListLink=model_.CustomerAgreementListLink(\n') - self.CustomerAgreementListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.customerName is not None: - showIndent(outfile, level) - outfile.write('customerName=%s,\n' % quote_python(self.customerName).encode(ExternalEncoding)) - if self.pricePowerOfTenMultiplier is not None: - showIndent(outfile, level) - outfile.write('pricePowerOfTenMultiplier=model_.PowerOfTenMultiplierType(\n') - self.pricePowerOfTenMultiplier.exportLiteral(outfile, level, name_='pricePowerOfTenMultiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.ServiceSupplierLink is not None: - showIndent(outfile, level) - outfile.write('ServiceSupplierLink=model_.ServiceSupplierLink(\n') - self.ServiceSupplierLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(CustomerAccount, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'currency': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'currency') - self.currency = ival_ - self.validate_UInt16(self.currency) # validate type UInt16 - elif nodeName_ == 'customerAccount': - customerAccount_ = child_.text - customerAccount_ = self.gds_validate_string(customerAccount_, node, 'customerAccount') - self.customerAccount = customerAccount_ - self.validate_String42(self.customerAccount) # validate type String42 - elif nodeName_ == 'CustomerAgreementListLink': - obj_ = CustomerAgreementListLink.factory() - obj_.build(child_) - self.CustomerAgreementListLink = obj_ - obj_.original_tagname_ = 'CustomerAgreementListLink' - elif nodeName_ == 'customerName': - customerName_ = child_.text - customerName_ = self.gds_validate_string(customerName_, node, 'customerName') - self.customerName = customerName_ - self.validate_String42(self.customerName) # validate type String42 - elif nodeName_ == 'pricePowerOfTenMultiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.pricePowerOfTenMultiplier = obj_ - obj_.original_tagname_ = 'pricePowerOfTenMultiplier' - elif nodeName_ == 'ServiceSupplierLink': - obj_ = ServiceSupplierLink.factory() - obj_.build(child_) - self.ServiceSupplierLink = obj_ - obj_.original_tagname_ = 'ServiceSupplierLink' - super(CustomerAccount, self).buildChildren(child_, node, nodeName_, True) -# end class CustomerAccount - - -class BillingReadingSetList(SubscribableList): - """A List element to hold BillingReadingSet objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, BillingReadingSet=None): - self.original_tagname_ = None - super(BillingReadingSetList, self).__init__() - if BillingReadingSet is None: - self.BillingReadingSet = [] - else: - self.BillingReadingSet = BillingReadingSet - def factory(*args_, **kwargs_): - if BillingReadingSetList.subclass: - return BillingReadingSetList.subclass(*args_, **kwargs_) - else: - return BillingReadingSetList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_BillingReadingSet(self): return self.BillingReadingSet - def set_BillingReadingSet(self, BillingReadingSet): self.BillingReadingSet = BillingReadingSet - def add_BillingReadingSet(self, value): self.BillingReadingSet.append(value) - def insert_BillingReadingSet_at(self, index, value): self.BillingReadingSet.insert(index, value) - def replace_BillingReadingSet_at(self, index, value): self.BillingReadingSet[index] = value - def hasContent_(self): - if ( - self.BillingReadingSet or - super(BillingReadingSetList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingReadingSetList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingSetList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingReadingSetList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingReadingSetList'): - super(BillingReadingSetList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingSetList') - def exportChildren(self, outfile, level, namespace_='', name_='BillingReadingSetList', fromsubclass_=False, pretty_print=True): - super(BillingReadingSetList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for BillingReadingSet_ in self.BillingReadingSet: - BillingReadingSet_.export(outfile, level, namespace_, name_='BillingReadingSet', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='BillingReadingSetList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingReadingSetList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingReadingSetList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('BillingReadingSet=[\n') - level += 1 - for BillingReadingSet_ in self.BillingReadingSet: - showIndent(outfile, level) - outfile.write('model_.BillingReadingSet(\n') - BillingReadingSet_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingReadingSetList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'BillingReadingSet': - obj_ = BillingReadingSet.factory() - obj_.build(child_) - self.BillingReadingSet.append(obj_) - obj_.original_tagname_ = 'BillingReadingSet' - super(BillingReadingSetList, self).buildChildren(child_, node, nodeName_, True) -# end class BillingReadingSetList - - -class BillingReadingList(List): - """A List element to hold BillingReading objects.""" - subclass = None - superclass = List - def __init__(self, BillingReading=None): - self.original_tagname_ = None - super(BillingReadingList, self).__init__() - if BillingReading is None: - self.BillingReading = [] - else: - self.BillingReading = BillingReading - def factory(*args_, **kwargs_): - if BillingReadingList.subclass: - return BillingReadingList.subclass(*args_, **kwargs_) - else: - return BillingReadingList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_BillingReading(self): return self.BillingReading - def set_BillingReading(self, BillingReading): self.BillingReading = BillingReading - def add_BillingReading(self, value): self.BillingReading.append(value) - def insert_BillingReading_at(self, index, value): self.BillingReading.insert(index, value) - def replace_BillingReading_at(self, index, value): self.BillingReading[index] = value - def hasContent_(self): - if ( - self.BillingReading or - super(BillingReadingList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingReadingList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingReadingList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingReadingList'): - super(BillingReadingList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingList') - def exportChildren(self, outfile, level, namespace_='', name_='BillingReadingList', fromsubclass_=False, pretty_print=True): - super(BillingReadingList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for BillingReading_ in self.BillingReading: - BillingReading_.export(outfile, level, namespace_, name_='BillingReading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='BillingReadingList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingReadingList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingReadingList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('BillingReading=[\n') - level += 1 - for BillingReading_ in self.BillingReading: - showIndent(outfile, level) - outfile.write('model_.BillingReading(\n') - BillingReading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingReadingList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'BillingReading': - obj_ = BillingReading.factory() - obj_.build(child_) - self.BillingReading.append(obj_) - obj_.original_tagname_ = 'BillingReading' - super(BillingReadingList, self).buildChildren(child_, node, nodeName_, True) -# end class BillingReadingList - - -class BillingReading(ReadingBase): - """Data captured at regular intervals of time. Interval data could be - captured as incremental data, absolute data, or relative data. - The source for the data is usually a tariff quantity or an - engineering quantity. Data is typically captured in time-tagged, - uniform, fixed-length intervals of 5 min, 10 min, 15 min, 30 - min, or 60 min. However, consumption aggregations can also be - represented with this class.""" - subclass = None - superclass = ReadingBase - def __init__(self, Charge=None): - self.original_tagname_ = None - super(BillingReading, self).__init__() - if Charge is None: - self.Charge = [] - else: - self.Charge = Charge - def factory(*args_, **kwargs_): - if BillingReading.subclass: - return BillingReading.subclass(*args_, **kwargs_) - else: - return BillingReading(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Charge(self): return self.Charge - def set_Charge(self, Charge): self.Charge = Charge - def add_Charge(self, value): self.Charge.append(value) - def insert_Charge_at(self, index, value): self.Charge.insert(index, value) - def replace_Charge_at(self, index, value): self.Charge[index] = value - def hasContent_(self): - if ( - self.Charge or - super(BillingReading, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingReading', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReading') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingReading', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingReading'): - super(BillingReading, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReading') - def exportChildren(self, outfile, level, namespace_='', name_='BillingReading', fromsubclass_=False, pretty_print=True): - super(BillingReading, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for Charge_ in self.Charge: - Charge_.export(outfile, level, namespace_, name_='Charge', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='BillingReading'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingReading, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingReading, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('Charge=[\n') - level += 1 - for Charge_ in self.Charge: - showIndent(outfile, level) - outfile.write('model_.Charge(\n') - Charge_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingReading, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Charge': - obj_ = Charge.factory() - obj_.build(child_) - self.Charge.append(obj_) - obj_.original_tagname_ = 'Charge' - super(BillingReading, self).buildChildren(child_, node, nodeName_, True) -# end class BillingReading - - -class BillingPeriodList(SubscribableList): - """A List element to hold BillingPeriod objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, BillingPeriod=None): - self.original_tagname_ = None - super(BillingPeriodList, self).__init__() - if BillingPeriod is None: - self.BillingPeriod = [] - else: - self.BillingPeriod = BillingPeriod - def factory(*args_, **kwargs_): - if BillingPeriodList.subclass: - return BillingPeriodList.subclass(*args_, **kwargs_) - else: - return BillingPeriodList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_BillingPeriod(self): return self.BillingPeriod - def set_BillingPeriod(self, BillingPeriod): self.BillingPeriod = BillingPeriod - def add_BillingPeriod(self, value): self.BillingPeriod.append(value) - def insert_BillingPeriod_at(self, index, value): self.BillingPeriod.insert(index, value) - def replace_BillingPeriod_at(self, index, value): self.BillingPeriod[index] = value - def hasContent_(self): - if ( - self.BillingPeriod or - super(BillingPeriodList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingPeriodList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingPeriodList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingPeriodList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingPeriodList'): - super(BillingPeriodList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingPeriodList') - def exportChildren(self, outfile, level, namespace_='', name_='BillingPeriodList', fromsubclass_=False, pretty_print=True): - super(BillingPeriodList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for BillingPeriod_ in self.BillingPeriod: - BillingPeriod_.export(outfile, level, namespace_, name_='BillingPeriod', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='BillingPeriodList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingPeriodList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingPeriodList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('BillingPeriod=[\n') - level += 1 - for BillingPeriod_ in self.BillingPeriod: - showIndent(outfile, level) - outfile.write('model_.BillingPeriod(\n') - BillingPeriod_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingPeriodList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'BillingPeriod': - obj_ = BillingPeriod.factory() - obj_.build(child_) - self.BillingPeriod.append(obj_) - obj_.original_tagname_ = 'BillingPeriod' - super(BillingPeriodList, self).buildChildren(child_, node, nodeName_, True) -# end class BillingPeriodList - - -class BillingPeriod(Resource): - """A Billing Period relates to the period of time on which a customer - is billed. As an example the billing period interval for a - particular customer might be 31 days starting on July 1, 2011. - The start date and interval can change on each billing period. - There may also be multiple billing periods related to a customer - agreement to support different tariff structures.""" - subclass = None - superclass = Resource - def __init__(self, billLastPeriod=None, billToDate=None, interval=None, statusTimeStamp=None): - self.original_tagname_ = None - super(BillingPeriod, self).__init__() - self.billLastPeriod = billLastPeriod - self.billToDate = billToDate - self.interval = interval - self.statusTimeStamp = statusTimeStamp - def factory(*args_, **kwargs_): - if BillingPeriod.subclass: - return BillingPeriod.subclass(*args_, **kwargs_) - else: - return BillingPeriod(*args_, **kwargs_) - factory = staticmethod(factory) - def get_billLastPeriod(self): return self.billLastPeriod - def set_billLastPeriod(self, billLastPeriod): self.billLastPeriod = billLastPeriod - def get_billToDate(self): return self.billToDate - def set_billToDate(self, billToDate): self.billToDate = billToDate - def get_interval(self): return self.interval - def set_interval(self, interval): self.interval = interval - def get_statusTimeStamp(self): return self.statusTimeStamp - def set_statusTimeStamp(self, statusTimeStamp): self.statusTimeStamp = statusTimeStamp - def validate_Int48(self, value): - # Validate type Int48, a restriction on xs:long. - pass - def hasContent_(self): - if ( - self.billLastPeriod is not None or - self.billToDate is not None or - self.interval is not None or - self.statusTimeStamp is not None or - super(BillingPeriod, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingPeriod', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingPeriod') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingPeriod', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingPeriod'): - super(BillingPeriod, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingPeriod') - def exportChildren(self, outfile, level, namespace_='', name_='BillingPeriod', fromsubclass_=False, pretty_print=True): - super(BillingPeriod, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.billLastPeriod is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sbillLastPeriod>%s%s' % (namespace_, self.gds_format_integer(self.billLastPeriod, input_name='billLastPeriod'), namespace_, eol_)) - if self.billToDate is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sbillToDate>%s%s' % (namespace_, self.gds_format_integer(self.billToDate, input_name='billToDate'), namespace_, eol_)) - if self.interval is not None: - self.interval.export(outfile, level, namespace_, name_='interval', pretty_print=pretty_print) - if self.statusTimeStamp is not None: - self.statusTimeStamp.export(outfile, level, namespace_, name_='statusTimeStamp', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='BillingPeriod'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingPeriod, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingPeriod, self).exportLiteralChildren(outfile, level, name_) - if self.billLastPeriod is not None: - showIndent(outfile, level) - outfile.write('billLastPeriod=%d,\n' % self.billLastPeriod) - if self.billToDate is not None: - showIndent(outfile, level) - outfile.write('billToDate=%d,\n' % self.billToDate) - if self.interval is not None: - showIndent(outfile, level) - outfile.write('interval=model_.DateTimeInterval(\n') - self.interval.exportLiteral(outfile, level, name_='interval') - showIndent(outfile, level) - outfile.write('),\n') - if self.statusTimeStamp is not None: - showIndent(outfile, level) - outfile.write('statusTimeStamp=model_.TimeType(\n') - self.statusTimeStamp.exportLiteral(outfile, level, name_='statusTimeStamp') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingPeriod, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'billLastPeriod': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'billLastPeriod') - self.billLastPeriod = ival_ - self.validate_Int48(self.billLastPeriod) # validate type Int48 - elif nodeName_ == 'billToDate': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'billToDate') - self.billToDate = ival_ - self.validate_Int48(self.billToDate) # validate type Int48 - elif nodeName_ == 'interval': - obj_ = DateTimeInterval.factory() - obj_.build(child_) - self.interval = obj_ - obj_.original_tagname_ = 'interval' - elif nodeName_ == 'statusTimeStamp': - obj_ = TimeType.factory() - obj_.build(child_) - self.statusTimeStamp = obj_ - obj_.original_tagname_ = 'statusTimeStamp' - super(BillingPeriod, self).buildChildren(child_, node, nodeName_, True) -# end class BillingPeriod - - -class TextMessageList(SubscribableList): - """A List element to hold TextMessage objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, TextMessage=None): - self.original_tagname_ = None - super(TextMessageList, self).__init__() - if TextMessage is None: - self.TextMessage = [] - else: - self.TextMessage = TextMessage - def factory(*args_, **kwargs_): - if TextMessageList.subclass: - return TextMessageList.subclass(*args_, **kwargs_) - else: - return TextMessageList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_TextMessage(self): return self.TextMessage - def set_TextMessage(self, TextMessage): self.TextMessage = TextMessage - def add_TextMessage(self, value): self.TextMessage.append(value) - def insert_TextMessage_at(self, index, value): self.TextMessage.insert(index, value) - def replace_TextMessage_at(self, index, value): self.TextMessage[index] = value - def hasContent_(self): - if ( - self.TextMessage or - super(TextMessageList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TextMessageList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TextMessageList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TextMessageList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TextMessageList'): - super(TextMessageList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TextMessageList') - def exportChildren(self, outfile, level, namespace_='', name_='TextMessageList', fromsubclass_=False, pretty_print=True): - super(TextMessageList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for TextMessage_ in self.TextMessage: - TextMessage_.export(outfile, level, namespace_, name_='TextMessage', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='TextMessageList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TextMessageList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TextMessageList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('TextMessage=[\n') - level += 1 - for TextMessage_ in self.TextMessage: - showIndent(outfile, level) - outfile.write('model_.TextMessage(\n') - TextMessage_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TextMessageList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'TextMessage': - obj_ = TextMessage.factory() - obj_.build(child_) - self.TextMessage.append(obj_) - obj_.original_tagname_ = 'TextMessage' - super(TextMessageList, self).buildChildren(child_, node, nodeName_, True) -# end class TextMessageList - - -class TextMessage(Event): - """Text message such as a notification.""" - subclass = None - superclass = Event - def __init__(self, originator=None, priority=None, textMessage=None): - self.original_tagname_ = None - super(TextMessage, self).__init__() - self.originator = originator - self.priority = priority - self.textMessage = textMessage - def factory(*args_, **kwargs_): - if TextMessage.subclass: - return TextMessage.subclass(*args_, **kwargs_) - else: - return TextMessage(*args_, **kwargs_) - factory = staticmethod(factory) - def get_originator(self): return self.originator - def set_originator(self, originator): self.originator = originator - def get_priority(self): return self.priority - def set_priority(self, priority): self.priority = priority - def get_textMessage(self): return self.textMessage - def set_textMessage(self, textMessage): self.textMessage = textMessage - def validate_String20(self, value): - # Validate type String20, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.originator is not None or - self.priority is not None or - self.textMessage is not None or - super(TextMessage, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TextMessage', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TextMessage') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TextMessage', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TextMessage'): - super(TextMessage, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TextMessage') - def exportChildren(self, outfile, level, namespace_='', name_='TextMessage', fromsubclass_=False, pretty_print=True): - super(TextMessage, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.originator is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%soriginator>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.originator).encode(ExternalEncoding), input_name='originator'), namespace_, eol_)) - if self.priority is not None: - self.priority.export(outfile, level, namespace_, name_='priority', pretty_print=pretty_print) - if self.textMessage is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%stextMessage>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.textMessage).encode(ExternalEncoding), input_name='textMessage'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='TextMessage'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TextMessage, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TextMessage, self).exportLiteralChildren(outfile, level, name_) - if self.originator is not None: - showIndent(outfile, level) - outfile.write('originator=%s,\n' % quote_python(self.originator).encode(ExternalEncoding)) - if self.priority is not None: - showIndent(outfile, level) - outfile.write('priority=model_.PriorityType(\n') - self.priority.exportLiteral(outfile, level, name_='priority') - showIndent(outfile, level) - outfile.write('),\n') - if self.textMessage is not None: - showIndent(outfile, level) - outfile.write('textMessage=%s,\n' % quote_python(self.textMessage).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TextMessage, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'originator': - originator_ = child_.text - originator_ = self.gds_validate_string(originator_, node, 'originator') - self.originator = originator_ - self.validate_String20(self.originator) # validate type String20 - elif nodeName_ == 'priority': - obj_ = PriorityType.factory() - obj_.build(child_) - self.priority = obj_ - obj_.original_tagname_ = 'priority' - elif nodeName_ == 'textMessage': - textMessage_ = child_.text - textMessage_ = self.gds_validate_string(textMessage_, node, 'textMessage') - self.textMessage = textMessage_ - super(TextMessage, self).buildChildren(child_, node, nodeName_, True) -# end class TextMessage - - -class MessagingProgramList(SubscribableList): - """A List element to hold MessagingProgram objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, MessagingProgram=None): - self.original_tagname_ = None - super(MessagingProgramList, self).__init__() - if MessagingProgram is None: - self.MessagingProgram = [] - else: - self.MessagingProgram = MessagingProgram - def factory(*args_, **kwargs_): - if MessagingProgramList.subclass: - return MessagingProgramList.subclass(*args_, **kwargs_) - else: - return MessagingProgramList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_MessagingProgram(self): return self.MessagingProgram - def set_MessagingProgram(self, MessagingProgram): self.MessagingProgram = MessagingProgram - def add_MessagingProgram(self, value): self.MessagingProgram.append(value) - def insert_MessagingProgram_at(self, index, value): self.MessagingProgram.insert(index, value) - def replace_MessagingProgram_at(self, index, value): self.MessagingProgram[index] = value - def hasContent_(self): - if ( - self.MessagingProgram or - super(MessagingProgramList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MessagingProgramList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MessagingProgramList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MessagingProgramList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MessagingProgramList'): - super(MessagingProgramList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MessagingProgramList') - def exportChildren(self, outfile, level, namespace_='', name_='MessagingProgramList', fromsubclass_=False, pretty_print=True): - super(MessagingProgramList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for MessagingProgram_ in self.MessagingProgram: - MessagingProgram_.export(outfile, level, namespace_, name_='MessagingProgram', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MessagingProgramList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MessagingProgramList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MessagingProgramList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('MessagingProgram=[\n') - level += 1 - for MessagingProgram_ in self.MessagingProgram: - showIndent(outfile, level) - outfile.write('model_.MessagingProgram(\n') - MessagingProgram_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MessagingProgramList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'MessagingProgram': - obj_ = MessagingProgram.factory() - obj_.build(child_) - self.MessagingProgram.append(obj_) - obj_.original_tagname_ = 'MessagingProgram' - super(MessagingProgramList, self).buildChildren(child_, node, nodeName_, True) -# end class MessagingProgramList - - -class MessagingProgram(SubscribableIdentifiedObject): - """Provides a container for collections of text messages.""" - subclass = None - superclass = SubscribableIdentifiedObject - def __init__(self, ActiveTextMessageListLink=None, locale=None, primacy=None, TextMessageListLink=None): - self.original_tagname_ = None - super(MessagingProgram, self).__init__() - self.ActiveTextMessageListLink = ActiveTextMessageListLink - self.locale = locale - self.primacy = primacy - self.TextMessageListLink = TextMessageListLink - def factory(*args_, **kwargs_): - if MessagingProgram.subclass: - return MessagingProgram.subclass(*args_, **kwargs_) - else: - return MessagingProgram(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ActiveTextMessageListLink(self): return self.ActiveTextMessageListLink - def set_ActiveTextMessageListLink(self, ActiveTextMessageListLink): self.ActiveTextMessageListLink = ActiveTextMessageListLink - def get_locale(self): return self.locale - def set_locale(self, locale): self.locale = locale - def get_primacy(self): return self.primacy - def set_primacy(self, primacy): self.primacy = primacy - def get_TextMessageListLink(self): return self.TextMessageListLink - def set_TextMessageListLink(self, TextMessageListLink): self.TextMessageListLink = TextMessageListLink - def hasContent_(self): - if ( - self.ActiveTextMessageListLink is not None or - self.locale is not None or - self.primacy is not None or - self.TextMessageListLink is not None or - super(MessagingProgram, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MessagingProgram', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MessagingProgram') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MessagingProgram', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MessagingProgram'): - super(MessagingProgram, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MessagingProgram') - def exportChildren(self, outfile, level, namespace_='', name_='MessagingProgram', fromsubclass_=False, pretty_print=True): - super(MessagingProgram, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ActiveTextMessageListLink is not None: - self.ActiveTextMessageListLink.export(outfile, level, namespace_, name_='ActiveTextMessageListLink', pretty_print=pretty_print) - if self.locale is not None: - self.locale.export(outfile, level, namespace_, name_='locale', pretty_print=pretty_print) - if self.primacy is not None: - self.primacy.export(outfile, level, namespace_, name_='primacy', pretty_print=pretty_print) - if self.TextMessageListLink is not None: - self.TextMessageListLink.export(outfile, level, namespace_, name_='TextMessageListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MessagingProgram'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MessagingProgram, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MessagingProgram, self).exportLiteralChildren(outfile, level, name_) - if self.ActiveTextMessageListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveTextMessageListLink=model_.ActiveTextMessageListLink(\n') - self.ActiveTextMessageListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.locale is not None: - showIndent(outfile, level) - outfile.write('locale=model_.LocaleType(\n') - self.locale.exportLiteral(outfile, level, name_='locale') - showIndent(outfile, level) - outfile.write('),\n') - if self.primacy is not None: - showIndent(outfile, level) - outfile.write('primacy=model_.PrimacyType(\n') - self.primacy.exportLiteral(outfile, level, name_='primacy') - showIndent(outfile, level) - outfile.write('),\n') - if self.TextMessageListLink is not None: - showIndent(outfile, level) - outfile.write('TextMessageListLink=model_.TextMessageListLink(\n') - self.TextMessageListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MessagingProgram, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ActiveTextMessageListLink': - obj_ = ActiveTextMessageListLink.factory() - obj_.build(child_) - self.ActiveTextMessageListLink = obj_ - obj_.original_tagname_ = 'ActiveTextMessageListLink' - elif nodeName_ == 'locale': - obj_ = LocaleType.factory() - obj_.build(child_) - self.locale = obj_ - obj_.original_tagname_ = 'locale' - elif nodeName_ == 'primacy': - obj_ = PrimacyType.factory() - obj_.build(child_) - self.primacy = obj_ - obj_.original_tagname_ = 'primacy' - elif nodeName_ == 'TextMessageListLink': - obj_ = TextMessageListLink.factory() - obj_.build(child_) - self.TextMessageListLink = obj_ - obj_.original_tagname_ = 'TextMessageListLink' - super(MessagingProgram, self).buildChildren(child_, node, nodeName_, True) -# end class MessagingProgram - - -class TimeTariffIntervalList(SubscribableList): - """A List element to hold TimeTariffInterval objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, TimeTariffInterval=None): - self.original_tagname_ = None - super(TimeTariffIntervalList, self).__init__() - if TimeTariffInterval is None: - self.TimeTariffInterval = [] - else: - self.TimeTariffInterval = TimeTariffInterval - def factory(*args_, **kwargs_): - if TimeTariffIntervalList.subclass: - return TimeTariffIntervalList.subclass(*args_, **kwargs_) - else: - return TimeTariffIntervalList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_TimeTariffInterval(self): return self.TimeTariffInterval - def set_TimeTariffInterval(self, TimeTariffInterval): self.TimeTariffInterval = TimeTariffInterval - def add_TimeTariffInterval(self, value): self.TimeTariffInterval.append(value) - def insert_TimeTariffInterval_at(self, index, value): self.TimeTariffInterval.insert(index, value) - def replace_TimeTariffInterval_at(self, index, value): self.TimeTariffInterval[index] = value - def hasContent_(self): - if ( - self.TimeTariffInterval or - super(TimeTariffIntervalList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TimeTariffIntervalList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TimeTariffIntervalList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TimeTariffIntervalList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TimeTariffIntervalList'): - super(TimeTariffIntervalList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TimeTariffIntervalList') - def exportChildren(self, outfile, level, namespace_='', name_='TimeTariffIntervalList', fromsubclass_=False, pretty_print=True): - super(TimeTariffIntervalList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for TimeTariffInterval_ in self.TimeTariffInterval: - TimeTariffInterval_.export(outfile, level, namespace_, name_='TimeTariffInterval', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='TimeTariffIntervalList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TimeTariffIntervalList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TimeTariffIntervalList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('TimeTariffInterval=[\n') - level += 1 - for TimeTariffInterval_ in self.TimeTariffInterval: - showIndent(outfile, level) - outfile.write('model_.TimeTariffInterval(\n') - TimeTariffInterval_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TimeTariffIntervalList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'TimeTariffInterval': - obj_ = TimeTariffInterval.factory() - obj_.build(child_) - self.TimeTariffInterval.append(obj_) - obj_.original_tagname_ = 'TimeTariffInterval' - super(TimeTariffIntervalList, self).buildChildren(child_, node, nodeName_, True) -# end class TimeTariffIntervalList - - -class TimeTariffInterval(RandomizableEvent): - """Describes the time-differentiated portion of the RateComponent, if - applicable, and provides the ability to specify multiple time - intervals, each with its own consumption-based components and - other attributes.""" - subclass = None - superclass = RandomizableEvent - def __init__(self, ConsumptionTariffIntervalListLink=None, touTier=None): - self.original_tagname_ = None - super(TimeTariffInterval, self).__init__() - self.ConsumptionTariffIntervalListLink = ConsumptionTariffIntervalListLink - self.touTier = touTier - def factory(*args_, **kwargs_): - if TimeTariffInterval.subclass: - return TimeTariffInterval.subclass(*args_, **kwargs_) - else: - return TimeTariffInterval(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ConsumptionTariffIntervalListLink(self): return self.ConsumptionTariffIntervalListLink - def set_ConsumptionTariffIntervalListLink(self, ConsumptionTariffIntervalListLink): self.ConsumptionTariffIntervalListLink = ConsumptionTariffIntervalListLink - def get_touTier(self): return self.touTier - def set_touTier(self, touTier): self.touTier = touTier - def hasContent_(self): - if ( - self.ConsumptionTariffIntervalListLink is not None or - self.touTier is not None or - super(TimeTariffInterval, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TimeTariffInterval', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TimeTariffInterval') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TimeTariffInterval', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TimeTariffInterval'): - super(TimeTariffInterval, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TimeTariffInterval') - def exportChildren(self, outfile, level, namespace_='', name_='TimeTariffInterval', fromsubclass_=False, pretty_print=True): - super(TimeTariffInterval, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ConsumptionTariffIntervalListLink is not None: - self.ConsumptionTariffIntervalListLink.export(outfile, level, namespace_, name_='ConsumptionTariffIntervalListLink', pretty_print=pretty_print) - if self.touTier is not None: - self.touTier.export(outfile, level, namespace_, name_='touTier', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='TimeTariffInterval'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TimeTariffInterval, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TimeTariffInterval, self).exportLiteralChildren(outfile, level, name_) - if self.ConsumptionTariffIntervalListLink is not None: - showIndent(outfile, level) - outfile.write('ConsumptionTariffIntervalListLink=model_.ConsumptionTariffIntervalListLink(\n') - self.ConsumptionTariffIntervalListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.touTier is not None: - showIndent(outfile, level) - outfile.write('touTier=model_.TOUType(\n') - self.touTier.exportLiteral(outfile, level, name_='touTier') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TimeTariffInterval, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ConsumptionTariffIntervalListLink': - obj_ = ConsumptionTariffIntervalListLink.factory() - obj_.build(child_) - self.ConsumptionTariffIntervalListLink = obj_ - obj_.original_tagname_ = 'ConsumptionTariffIntervalListLink' - elif nodeName_ == 'touTier': - obj_ = TOUType.factory() - obj_.build(child_) - self.touTier = obj_ - obj_.original_tagname_ = 'touTier' - super(TimeTariffInterval, self).buildChildren(child_, node, nodeName_, True) -# end class TimeTariffInterval - - -class TariffProfileList(SubscribableList): - """A List element to hold TariffProfile objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, TariffProfile=None): - self.original_tagname_ = None - super(TariffProfileList, self).__init__() - if TariffProfile is None: - self.TariffProfile = [] - else: - self.TariffProfile = TariffProfile - def factory(*args_, **kwargs_): - if TariffProfileList.subclass: - return TariffProfileList.subclass(*args_, **kwargs_) - else: - return TariffProfileList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_TariffProfile(self): return self.TariffProfile - def set_TariffProfile(self, TariffProfile): self.TariffProfile = TariffProfile - def add_TariffProfile(self, value): self.TariffProfile.append(value) - def insert_TariffProfile_at(self, index, value): self.TariffProfile.insert(index, value) - def replace_TariffProfile_at(self, index, value): self.TariffProfile[index] = value - def hasContent_(self): - if ( - self.TariffProfile or - super(TariffProfileList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TariffProfileList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TariffProfileList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TariffProfileList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TariffProfileList'): - super(TariffProfileList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TariffProfileList') - def exportChildren(self, outfile, level, namespace_='', name_='TariffProfileList', fromsubclass_=False, pretty_print=True): - super(TariffProfileList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for TariffProfile_ in self.TariffProfile: - TariffProfile_.export(outfile, level, namespace_, name_='TariffProfile', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='TariffProfileList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TariffProfileList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TariffProfileList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('TariffProfile=[\n') - level += 1 - for TariffProfile_ in self.TariffProfile: - showIndent(outfile, level) - outfile.write('model_.TariffProfile(\n') - TariffProfile_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TariffProfileList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'TariffProfile': - obj_ = TariffProfile.factory() - obj_.build(child_) - self.TariffProfile.append(obj_) - obj_.original_tagname_ = 'TariffProfile' - super(TariffProfileList, self).buildChildren(child_, node, nodeName_, True) -# end class TariffProfileList - - -class TariffProfile(IdentifiedObject): - """A schedule of charges; structure that allows the definition of - tariff structures such as step (block) and time of use (tier) - when used in conjunction with TimeTariffInterval and - ConsumptionTariffInterval.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, currency=None, pricePowerOfTenMultiplier=None, primacy=None, rateCode=None, RateComponentListLink=None, serviceCategoryKind=None): - self.original_tagname_ = None - super(TariffProfile, self).__init__() - self.currency = currency - self.pricePowerOfTenMultiplier = pricePowerOfTenMultiplier - self.primacy = primacy - self.rateCode = rateCode - self.RateComponentListLink = RateComponentListLink - self.serviceCategoryKind = serviceCategoryKind - def factory(*args_, **kwargs_): - if TariffProfile.subclass: - return TariffProfile.subclass(*args_, **kwargs_) - else: - return TariffProfile(*args_, **kwargs_) - factory = staticmethod(factory) - def get_currency(self): return self.currency - def set_currency(self, currency): self.currency = currency - def get_pricePowerOfTenMultiplier(self): return self.pricePowerOfTenMultiplier - def set_pricePowerOfTenMultiplier(self, pricePowerOfTenMultiplier): self.pricePowerOfTenMultiplier = pricePowerOfTenMultiplier - def get_primacy(self): return self.primacy - def set_primacy(self, primacy): self.primacy = primacy - def get_rateCode(self): return self.rateCode - def set_rateCode(self, rateCode): self.rateCode = rateCode - def get_RateComponentListLink(self): return self.RateComponentListLink - def set_RateComponentListLink(self, RateComponentListLink): self.RateComponentListLink = RateComponentListLink - def get_serviceCategoryKind(self): return self.serviceCategoryKind - def set_serviceCategoryKind(self, serviceCategoryKind): self.serviceCategoryKind = serviceCategoryKind - def validate_String20(self, value): - # Validate type String20, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.currency is not None or - self.pricePowerOfTenMultiplier is not None or - self.primacy is not None or - self.rateCode is not None or - self.RateComponentListLink is not None or - self.serviceCategoryKind is not None or - super(TariffProfile, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TariffProfile', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TariffProfile') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TariffProfile', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TariffProfile'): - super(TariffProfile, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TariffProfile') - def exportChildren(self, outfile, level, namespace_='', name_='TariffProfile', fromsubclass_=False, pretty_print=True): - super(TariffProfile, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.currency is not None: - self.currency.export(outfile, level, namespace_, name_='currency', pretty_print=pretty_print) - if self.pricePowerOfTenMultiplier is not None: - self.pricePowerOfTenMultiplier.export(outfile, level, namespace_, name_='pricePowerOfTenMultiplier', pretty_print=pretty_print) - if self.primacy is not None: - self.primacy.export(outfile, level, namespace_, name_='primacy', pretty_print=pretty_print) - if self.rateCode is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srateCode>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.rateCode).encode(ExternalEncoding), input_name='rateCode'), namespace_, eol_)) - if self.RateComponentListLink is not None: - self.RateComponentListLink.export(outfile, level, namespace_, name_='RateComponentListLink', pretty_print=pretty_print) - if self.serviceCategoryKind is not None: - self.serviceCategoryKind.export(outfile, level, namespace_, name_='serviceCategoryKind', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='TariffProfile'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TariffProfile, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TariffProfile, self).exportLiteralChildren(outfile, level, name_) - if self.currency is not None: - showIndent(outfile, level) - outfile.write('currency=model_.CurrencyCode(\n') - self.currency.exportLiteral(outfile, level, name_='currency') - showIndent(outfile, level) - outfile.write('),\n') - if self.pricePowerOfTenMultiplier is not None: - showIndent(outfile, level) - outfile.write('pricePowerOfTenMultiplier=model_.PowerOfTenMultiplierType(\n') - self.pricePowerOfTenMultiplier.exportLiteral(outfile, level, name_='pricePowerOfTenMultiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.primacy is not None: - showIndent(outfile, level) - outfile.write('primacy=model_.PrimacyType(\n') - self.primacy.exportLiteral(outfile, level, name_='primacy') - showIndent(outfile, level) - outfile.write('),\n') - if self.rateCode is not None: - showIndent(outfile, level) - outfile.write('rateCode=%s,\n' % quote_python(self.rateCode).encode(ExternalEncoding)) - if self.RateComponentListLink is not None: - showIndent(outfile, level) - outfile.write('RateComponentListLink=model_.RateComponentListLink(\n') - self.RateComponentListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.serviceCategoryKind is not None: - showIndent(outfile, level) - outfile.write('serviceCategoryKind=model_.ServiceKind(\n') - self.serviceCategoryKind.exportLiteral(outfile, level, name_='serviceCategoryKind') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TariffProfile, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'currency': - obj_ = CurrencyCode.factory() - obj_.build(child_) - self.currency = obj_ - obj_.original_tagname_ = 'currency' - elif nodeName_ == 'pricePowerOfTenMultiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.pricePowerOfTenMultiplier = obj_ - obj_.original_tagname_ = 'pricePowerOfTenMultiplier' - elif nodeName_ == 'primacy': - obj_ = PrimacyType.factory() - obj_.build(child_) - self.primacy = obj_ - obj_.original_tagname_ = 'primacy' - elif nodeName_ == 'rateCode': - rateCode_ = child_.text - rateCode_ = self.gds_validate_string(rateCode_, node, 'rateCode') - self.rateCode = rateCode_ - self.validate_String20(self.rateCode) # validate type String20 - elif nodeName_ == 'RateComponentListLink': - obj_ = RateComponentListLink.factory() - obj_.build(child_) - self.RateComponentListLink = obj_ - obj_.original_tagname_ = 'RateComponentListLink' - elif nodeName_ == 'serviceCategoryKind': - obj_ = ServiceKind.factory() - obj_.build(child_) - self.serviceCategoryKind = obj_ - obj_.original_tagname_ = 'serviceCategoryKind' - super(TariffProfile, self).buildChildren(child_, node, nodeName_, True) -# end class TariffProfile - - -class RateComponentList(List): - """A List element to hold RateComponent objects.""" - subclass = None - superclass = List - def __init__(self, RateComponent=None): - self.original_tagname_ = None - super(RateComponentList, self).__init__() - if RateComponent is None: - self.RateComponent = [] - else: - self.RateComponent = RateComponent - def factory(*args_, **kwargs_): - if RateComponentList.subclass: - return RateComponentList.subclass(*args_, **kwargs_) - else: - return RateComponentList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_RateComponent(self): return self.RateComponent - def set_RateComponent(self, RateComponent): self.RateComponent = RateComponent - def add_RateComponent(self, value): self.RateComponent.append(value) - def insert_RateComponent_at(self, index, value): self.RateComponent.insert(index, value) - def replace_RateComponent_at(self, index, value): self.RateComponent[index] = value - def hasContent_(self): - if ( - self.RateComponent or - super(RateComponentList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RateComponentList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RateComponentList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RateComponentList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RateComponentList'): - super(RateComponentList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RateComponentList') - def exportChildren(self, outfile, level, namespace_='', name_='RateComponentList', fromsubclass_=False, pretty_print=True): - super(RateComponentList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for RateComponent_ in self.RateComponent: - RateComponent_.export(outfile, level, namespace_, name_='RateComponent', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='RateComponentList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RateComponentList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RateComponentList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('RateComponent=[\n') - level += 1 - for RateComponent_ in self.RateComponent: - showIndent(outfile, level) - outfile.write('model_.RateComponent(\n') - RateComponent_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RateComponentList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'RateComponent': - obj_ = RateComponent.factory() - obj_.build(child_) - self.RateComponent.append(obj_) - obj_.original_tagname_ = 'RateComponent' - super(RateComponentList, self).buildChildren(child_, node, nodeName_, True) -# end class RateComponentList - - -class RateComponent(IdentifiedObject): - """Specifies the applicable charges for a single component of the rate, - which could be generation price or consumption price, for - example.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, ActiveTimeTariffIntervalListLink=None, flowRateEndLimit=None, flowRateStartLimit=None, ReadingTypeLink=None, roleFlags=None, TimeTariffIntervalListLink=None): - self.original_tagname_ = None - super(RateComponent, self).__init__() - self.ActiveTimeTariffIntervalListLink = ActiveTimeTariffIntervalListLink - self.flowRateEndLimit = flowRateEndLimit - self.flowRateStartLimit = flowRateStartLimit - self.ReadingTypeLink = ReadingTypeLink - self.roleFlags = roleFlags - self.TimeTariffIntervalListLink = TimeTariffIntervalListLink - def factory(*args_, **kwargs_): - if RateComponent.subclass: - return RateComponent.subclass(*args_, **kwargs_) - else: - return RateComponent(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ActiveTimeTariffIntervalListLink(self): return self.ActiveTimeTariffIntervalListLink - def set_ActiveTimeTariffIntervalListLink(self, ActiveTimeTariffIntervalListLink): self.ActiveTimeTariffIntervalListLink = ActiveTimeTariffIntervalListLink - def get_flowRateEndLimit(self): return self.flowRateEndLimit - def set_flowRateEndLimit(self, flowRateEndLimit): self.flowRateEndLimit = flowRateEndLimit - def get_flowRateStartLimit(self): return self.flowRateStartLimit - def set_flowRateStartLimit(self, flowRateStartLimit): self.flowRateStartLimit = flowRateStartLimit - def get_ReadingTypeLink(self): return self.ReadingTypeLink - def set_ReadingTypeLink(self, ReadingTypeLink): self.ReadingTypeLink = ReadingTypeLink - def get_roleFlags(self): return self.roleFlags - def set_roleFlags(self, roleFlags): self.roleFlags = roleFlags - def get_TimeTariffIntervalListLink(self): return self.TimeTariffIntervalListLink - def set_TimeTariffIntervalListLink(self, TimeTariffIntervalListLink): self.TimeTariffIntervalListLink = TimeTariffIntervalListLink - def hasContent_(self): - if ( - self.ActiveTimeTariffIntervalListLink is not None or - self.flowRateEndLimit is not None or - self.flowRateStartLimit is not None or - self.ReadingTypeLink is not None or - self.roleFlags is not None or - self.TimeTariffIntervalListLink is not None or - super(RateComponent, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RateComponent', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RateComponent') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RateComponent', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RateComponent'): - super(RateComponent, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RateComponent') - def exportChildren(self, outfile, level, namespace_='', name_='RateComponent', fromsubclass_=False, pretty_print=True): - super(RateComponent, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ActiveTimeTariffIntervalListLink is not None: - self.ActiveTimeTariffIntervalListLink.export(outfile, level, namespace_, name_='ActiveTimeTariffIntervalListLink', pretty_print=pretty_print) - if self.flowRateEndLimit is not None: - self.flowRateEndLimit.export(outfile, level, namespace_, name_='flowRateEndLimit', pretty_print=pretty_print) - if self.flowRateStartLimit is not None: - self.flowRateStartLimit.export(outfile, level, namespace_, name_='flowRateStartLimit', pretty_print=pretty_print) - if self.ReadingTypeLink is not None: - self.ReadingTypeLink.export(outfile, level, namespace_, name_='ReadingTypeLink', pretty_print=pretty_print) - if self.roleFlags is not None: - self.roleFlags.export(outfile, level, namespace_, name_='roleFlags', pretty_print=pretty_print) - if self.TimeTariffIntervalListLink is not None: - self.TimeTariffIntervalListLink.export(outfile, level, namespace_, name_='TimeTariffIntervalListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='RateComponent'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RateComponent, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RateComponent, self).exportLiteralChildren(outfile, level, name_) - if self.ActiveTimeTariffIntervalListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveTimeTariffIntervalListLink=model_.ActiveTimeTariffIntervalListLink(\n') - self.ActiveTimeTariffIntervalListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.flowRateEndLimit is not None: - showIndent(outfile, level) - outfile.write('flowRateEndLimit=model_.UnitValueType(\n') - self.flowRateEndLimit.exportLiteral(outfile, level, name_='flowRateEndLimit') - showIndent(outfile, level) - outfile.write('),\n') - if self.flowRateStartLimit is not None: - showIndent(outfile, level) - outfile.write('flowRateStartLimit=model_.UnitValueType(\n') - self.flowRateStartLimit.exportLiteral(outfile, level, name_='flowRateStartLimit') - showIndent(outfile, level) - outfile.write('),\n') - if self.ReadingTypeLink is not None: - showIndent(outfile, level) - outfile.write('ReadingTypeLink=model_.ReadingTypeLink(\n') - self.ReadingTypeLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.roleFlags is not None: - showIndent(outfile, level) - outfile.write('roleFlags=model_.RoleFlagsType(\n') - self.roleFlags.exportLiteral(outfile, level, name_='roleFlags') - showIndent(outfile, level) - outfile.write('),\n') - if self.TimeTariffIntervalListLink is not None: - showIndent(outfile, level) - outfile.write('TimeTariffIntervalListLink=model_.TimeTariffIntervalListLink(\n') - self.TimeTariffIntervalListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RateComponent, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ActiveTimeTariffIntervalListLink': - obj_ = ActiveTimeTariffIntervalListLink.factory() - obj_.build(child_) - self.ActiveTimeTariffIntervalListLink = obj_ - obj_.original_tagname_ = 'ActiveTimeTariffIntervalListLink' - elif nodeName_ == 'flowRateEndLimit': - obj_ = UnitValueType.factory() - obj_.build(child_) - self.flowRateEndLimit = obj_ - obj_.original_tagname_ = 'flowRateEndLimit' - elif nodeName_ == 'flowRateStartLimit': - obj_ = UnitValueType.factory() - obj_.build(child_) - self.flowRateStartLimit = obj_ - obj_.original_tagname_ = 'flowRateStartLimit' - elif nodeName_ == 'ReadingTypeLink': - obj_ = ReadingTypeLink.factory() - obj_.build(child_) - self.ReadingTypeLink = obj_ - obj_.original_tagname_ = 'ReadingTypeLink' - elif nodeName_ == 'roleFlags': - obj_ = RoleFlagsType.factory() - obj_.build(child_) - self.roleFlags = obj_ - obj_.original_tagname_ = 'roleFlags' - elif nodeName_ == 'TimeTariffIntervalListLink': - obj_ = TimeTariffIntervalListLink.factory() - obj_.build(child_) - self.TimeTariffIntervalListLink = obj_ - obj_.original_tagname_ = 'TimeTariffIntervalListLink' - super(RateComponent, self).buildChildren(child_, node, nodeName_, True) -# end class RateComponent - - -class ConsumptionTariffIntervalList(List): - """A List element to hold ConsumptionTariffInterval objects.""" - subclass = None - superclass = List - def __init__(self, ConsumptionTariffInterval=None): - self.original_tagname_ = None - super(ConsumptionTariffIntervalList, self).__init__() - if ConsumptionTariffInterval is None: - self.ConsumptionTariffInterval = [] - else: - self.ConsumptionTariffInterval = ConsumptionTariffInterval - def factory(*args_, **kwargs_): - if ConsumptionTariffIntervalList.subclass: - return ConsumptionTariffIntervalList.subclass(*args_, **kwargs_) - else: - return ConsumptionTariffIntervalList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ConsumptionTariffInterval(self): return self.ConsumptionTariffInterval - def set_ConsumptionTariffInterval(self, ConsumptionTariffInterval): self.ConsumptionTariffInterval = ConsumptionTariffInterval - def add_ConsumptionTariffInterval(self, value): self.ConsumptionTariffInterval.append(value) - def insert_ConsumptionTariffInterval_at(self, index, value): self.ConsumptionTariffInterval.insert(index, value) - def replace_ConsumptionTariffInterval_at(self, index, value): self.ConsumptionTariffInterval[index] = value - def hasContent_(self): - if ( - self.ConsumptionTariffInterval or - super(ConsumptionTariffIntervalList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ConsumptionTariffIntervalList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ConsumptionTariffIntervalList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ConsumptionTariffIntervalList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ConsumptionTariffIntervalList'): - super(ConsumptionTariffIntervalList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ConsumptionTariffIntervalList') - def exportChildren(self, outfile, level, namespace_='', name_='ConsumptionTariffIntervalList', fromsubclass_=False, pretty_print=True): - super(ConsumptionTariffIntervalList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for ConsumptionTariffInterval_ in self.ConsumptionTariffInterval: - ConsumptionTariffInterval_.export(outfile, level, namespace_, name_='ConsumptionTariffInterval', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ConsumptionTariffIntervalList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ConsumptionTariffIntervalList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ConsumptionTariffIntervalList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('ConsumptionTariffInterval=[\n') - level += 1 - for ConsumptionTariffInterval_ in self.ConsumptionTariffInterval: - showIndent(outfile, level) - outfile.write('model_.ConsumptionTariffInterval(\n') - ConsumptionTariffInterval_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ConsumptionTariffIntervalList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ConsumptionTariffInterval': - obj_ = ConsumptionTariffInterval.factory() - obj_.build(child_) - self.ConsumptionTariffInterval.append(obj_) - obj_.original_tagname_ = 'ConsumptionTariffInterval' - super(ConsumptionTariffIntervalList, self).buildChildren(child_, node, nodeName_, True) -# end class ConsumptionTariffIntervalList - - -class ConsumptionTariffInterval(Resource): - """One of a sequence of thresholds defined in terms of consumption - quantity of a service such as electricity, water, gas, etc. It - defines the steps or blocks in a step tariff structure, where - startValue simultaneously defines the entry value of this step - and the closing value of the previous step. Where consumption is - greater than startValue, it falls within this block and where - consumption is less than or equal to startValue, it falls within - one of the previous blocks.""" - subclass = None - superclass = Resource - def __init__(self, consumptionBlock=None, EnvironmentalCost=None, price=None, startValue=None): - self.original_tagname_ = None - super(ConsumptionTariffInterval, self).__init__() - self.consumptionBlock = consumptionBlock - if EnvironmentalCost is None: - self.EnvironmentalCost = [] - else: - self.EnvironmentalCost = EnvironmentalCost - self.price = price - self.startValue = startValue - def factory(*args_, **kwargs_): - if ConsumptionTariffInterval.subclass: - return ConsumptionTariffInterval.subclass(*args_, **kwargs_) - else: - return ConsumptionTariffInterval(*args_, **kwargs_) - factory = staticmethod(factory) - def get_consumptionBlock(self): return self.consumptionBlock - def set_consumptionBlock(self, consumptionBlock): self.consumptionBlock = consumptionBlock - def get_EnvironmentalCost(self): return self.EnvironmentalCost - def set_EnvironmentalCost(self, EnvironmentalCost): self.EnvironmentalCost = EnvironmentalCost - def add_EnvironmentalCost(self, value): self.EnvironmentalCost.append(value) - def insert_EnvironmentalCost_at(self, index, value): self.EnvironmentalCost.insert(index, value) - def replace_EnvironmentalCost_at(self, index, value): self.EnvironmentalCost[index] = value - def get_price(self): return self.price - def set_price(self, price): self.price = price - def get_startValue(self): return self.startValue - def set_startValue(self, startValue): self.startValue = startValue - def validate_Int32(self, value): - # Validate type Int32, a restriction on xs:int. - pass - def validate_UInt48(self, value): - # Validate type UInt48, a restriction on xs:unsignedLong. - pass - def hasContent_(self): - if ( - self.consumptionBlock is not None or - self.EnvironmentalCost or - self.price is not None or - self.startValue is not None or - super(ConsumptionTariffInterval, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ConsumptionTariffInterval', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ConsumptionTariffInterval') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ConsumptionTariffInterval', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ConsumptionTariffInterval'): - super(ConsumptionTariffInterval, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ConsumptionTariffInterval') - def exportChildren(self, outfile, level, namespace_='', name_='ConsumptionTariffInterval', fromsubclass_=False, pretty_print=True): - super(ConsumptionTariffInterval, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.consumptionBlock is not None: - self.consumptionBlock.export(outfile, level, namespace_, name_='consumptionBlock', pretty_print=pretty_print) - for EnvironmentalCost_ in self.EnvironmentalCost: - EnvironmentalCost_.export(outfile, level, namespace_, name_='EnvironmentalCost', pretty_print=pretty_print) - if self.price is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sprice>%s%s' % (namespace_, self.gds_format_integer(self.price, input_name='price'), namespace_, eol_)) - if self.startValue is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sstartValue>%s%s' % (namespace_, self.gds_format_integer(self.startValue, input_name='startValue'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='ConsumptionTariffInterval'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ConsumptionTariffInterval, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ConsumptionTariffInterval, self).exportLiteralChildren(outfile, level, name_) - if self.consumptionBlock is not None: - showIndent(outfile, level) - outfile.write('consumptionBlock=model_.ConsumptionBlockType(\n') - self.consumptionBlock.exportLiteral(outfile, level, name_='consumptionBlock') - showIndent(outfile, level) - outfile.write('),\n') - showIndent(outfile, level) - outfile.write('EnvironmentalCost=[\n') - level += 1 - for EnvironmentalCost_ in self.EnvironmentalCost: - showIndent(outfile, level) - outfile.write('model_.EnvironmentalCost(\n') - EnvironmentalCost_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - if self.price is not None: - showIndent(outfile, level) - outfile.write('price=%d,\n' % self.price) - if self.startValue is not None: - showIndent(outfile, level) - outfile.write('startValue=%d,\n' % self.startValue) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ConsumptionTariffInterval, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'consumptionBlock': - obj_ = ConsumptionBlockType.factory() - obj_.build(child_) - self.consumptionBlock = obj_ - obj_.original_tagname_ = 'consumptionBlock' - elif nodeName_ == 'EnvironmentalCost': - obj_ = EnvironmentalCost.factory() - obj_.build(child_) - self.EnvironmentalCost.append(obj_) - obj_.original_tagname_ = 'EnvironmentalCost' - elif nodeName_ == 'price': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'price') - self.price = ival_ - self.validate_Int32(self.price) # validate type Int32 - elif nodeName_ == 'startValue': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'startValue') - self.startValue = ival_ - self.validate_UInt48(self.startValue) # validate type UInt48 - super(ConsumptionTariffInterval, self).buildChildren(child_, node, nodeName_, True) -# end class ConsumptionTariffInterval - - -class UsagePointList(SubscribableList): - """A List element to hold UsagePoint objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, UsagePoint=None): - self.original_tagname_ = None - super(UsagePointList, self).__init__() - if UsagePoint is None: - self.UsagePoint = [] - else: - self.UsagePoint = UsagePoint - def factory(*args_, **kwargs_): - if UsagePointList.subclass: - return UsagePointList.subclass(*args_, **kwargs_) - else: - return UsagePointList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_UsagePoint(self): return self.UsagePoint - def set_UsagePoint(self, UsagePoint): self.UsagePoint = UsagePoint - def add_UsagePoint(self, value): self.UsagePoint.append(value) - def insert_UsagePoint_at(self, index, value): self.UsagePoint.insert(index, value) - def replace_UsagePoint_at(self, index, value): self.UsagePoint[index] = value - def hasContent_(self): - if ( - self.UsagePoint or - super(UsagePointList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UsagePointList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePointList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='UsagePointList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UsagePointList'): - super(UsagePointList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePointList') - def exportChildren(self, outfile, level, namespace_='', name_='UsagePointList', fromsubclass_=False, pretty_print=True): - super(UsagePointList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for UsagePoint_ in self.UsagePoint: - UsagePoint_.export(outfile, level, namespace_, name_='UsagePoint', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='UsagePointList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(UsagePointList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(UsagePointList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('UsagePoint=[\n') - level += 1 - for UsagePoint_ in self.UsagePoint: - showIndent(outfile, level) - outfile.write('model_.UsagePoint(\n') - UsagePoint_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(UsagePointList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'UsagePoint': - obj_ = UsagePoint.factory() - obj_.build(child_) - self.UsagePoint.append(obj_) - obj_.original_tagname_ = 'UsagePoint' - super(UsagePointList, self).buildChildren(child_, node, nodeName_, True) -# end class UsagePointList - - -class ReadingType(Resource): - """Type of data conveyed by a specific Reading. See IEC 61968 Part 9 - Annex C for full definitions of these values.""" - subclass = None - superclass = Resource - def __init__(self, accumulationBehaviour=None, calorificValue=None, commodity=None, conversionFactor=None, dataQualifier=None, flowDirection=None, intervalLength=None, kind=None, maxNumberOfIntervals=None, numberOfConsumptionBlocks=None, numberOfTouTiers=None, phase=None, powerOfTenMultiplier=None, subIntervalLength=None, supplyLimit=None, tieredConsumptionBlocks=None, uom=None): - self.original_tagname_ = None - super(ReadingType, self).__init__() - self.accumulationBehaviour = accumulationBehaviour - self.calorificValue = calorificValue - self.commodity = commodity - self.conversionFactor = conversionFactor - self.dataQualifier = dataQualifier - self.flowDirection = flowDirection - self.intervalLength = intervalLength - self.kind = kind - self.maxNumberOfIntervals = maxNumberOfIntervals - self.numberOfConsumptionBlocks = numberOfConsumptionBlocks - self.numberOfTouTiers = numberOfTouTiers - self.phase = phase - self.powerOfTenMultiplier = powerOfTenMultiplier - self.subIntervalLength = subIntervalLength - self.supplyLimit = supplyLimit - self.tieredConsumptionBlocks = tieredConsumptionBlocks - self.uom = uom - def factory(*args_, **kwargs_): - if ReadingType.subclass: - return ReadingType.subclass(*args_, **kwargs_) - else: - return ReadingType(*args_, **kwargs_) - factory = staticmethod(factory) - def get_accumulationBehaviour(self): return self.accumulationBehaviour - def set_accumulationBehaviour(self, accumulationBehaviour): self.accumulationBehaviour = accumulationBehaviour - def get_calorificValue(self): return self.calorificValue - def set_calorificValue(self, calorificValue): self.calorificValue = calorificValue - def get_commodity(self): return self.commodity - def set_commodity(self, commodity): self.commodity = commodity - def get_conversionFactor(self): return self.conversionFactor - def set_conversionFactor(self, conversionFactor): self.conversionFactor = conversionFactor - def get_dataQualifier(self): return self.dataQualifier - def set_dataQualifier(self, dataQualifier): self.dataQualifier = dataQualifier - def get_flowDirection(self): return self.flowDirection - def set_flowDirection(self, flowDirection): self.flowDirection = flowDirection - def get_intervalLength(self): return self.intervalLength - def set_intervalLength(self, intervalLength): self.intervalLength = intervalLength - def get_kind(self): return self.kind - def set_kind(self, kind): self.kind = kind - def get_maxNumberOfIntervals(self): return self.maxNumberOfIntervals - def set_maxNumberOfIntervals(self, maxNumberOfIntervals): self.maxNumberOfIntervals = maxNumberOfIntervals - def get_numberOfConsumptionBlocks(self): return self.numberOfConsumptionBlocks - def set_numberOfConsumptionBlocks(self, numberOfConsumptionBlocks): self.numberOfConsumptionBlocks = numberOfConsumptionBlocks - def get_numberOfTouTiers(self): return self.numberOfTouTiers - def set_numberOfTouTiers(self, numberOfTouTiers): self.numberOfTouTiers = numberOfTouTiers - def get_phase(self): return self.phase - def set_phase(self, phase): self.phase = phase - def get_powerOfTenMultiplier(self): return self.powerOfTenMultiplier - def set_powerOfTenMultiplier(self, powerOfTenMultiplier): self.powerOfTenMultiplier = powerOfTenMultiplier - def get_subIntervalLength(self): return self.subIntervalLength - def set_subIntervalLength(self, subIntervalLength): self.subIntervalLength = subIntervalLength - def get_supplyLimit(self): return self.supplyLimit - def set_supplyLimit(self, supplyLimit): self.supplyLimit = supplyLimit - def get_tieredConsumptionBlocks(self): return self.tieredConsumptionBlocks - def set_tieredConsumptionBlocks(self, tieredConsumptionBlocks): self.tieredConsumptionBlocks = tieredConsumptionBlocks - def get_uom(self): return self.uom - def set_uom(self, uom): self.uom = uom - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_UInt48(self, value): - # Validate type UInt48, a restriction on xs:unsignedLong. - pass - def hasContent_(self): - if ( - self.accumulationBehaviour is not None or - self.calorificValue is not None or - self.commodity is not None or - self.conversionFactor is not None or - self.dataQualifier is not None or - self.flowDirection is not None or - self.intervalLength is not None or - self.kind is not None or - self.maxNumberOfIntervals is not None or - self.numberOfConsumptionBlocks is not None or - self.numberOfTouTiers is not None or - self.phase is not None or - self.powerOfTenMultiplier is not None or - self.subIntervalLength is not None or - self.supplyLimit is not None or - self.tieredConsumptionBlocks is not None or - self.uom is not None or - super(ReadingType, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingType', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingType') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingType', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingType'): - super(ReadingType, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingType') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingType', fromsubclass_=False, pretty_print=True): - super(ReadingType, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.accumulationBehaviour is not None: - self.accumulationBehaviour.export(outfile, level, namespace_, name_='accumulationBehaviour', pretty_print=pretty_print) - if self.calorificValue is not None: - self.calorificValue.export(outfile, level, namespace_, name_='calorificValue', pretty_print=pretty_print) - if self.commodity is not None: - self.commodity.export(outfile, level, namespace_, name_='commodity', pretty_print=pretty_print) - if self.conversionFactor is not None: - self.conversionFactor.export(outfile, level, namespace_, name_='conversionFactor', pretty_print=pretty_print) - if self.dataQualifier is not None: - self.dataQualifier.export(outfile, level, namespace_, name_='dataQualifier', pretty_print=pretty_print) - if self.flowDirection is not None: - self.flowDirection.export(outfile, level, namespace_, name_='flowDirection', pretty_print=pretty_print) - if self.intervalLength is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sintervalLength>%s%s' % (namespace_, self.gds_format_integer(self.intervalLength, input_name='intervalLength'), namespace_, eol_)) - if self.kind is not None: - self.kind.export(outfile, level, namespace_, name_='kind', pretty_print=pretty_print) - if self.maxNumberOfIntervals is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smaxNumberOfIntervals>%s%s' % (namespace_, self.gds_format_integer(self.maxNumberOfIntervals, input_name='maxNumberOfIntervals'), namespace_, eol_)) - if self.numberOfConsumptionBlocks is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%snumberOfConsumptionBlocks>%s%s' % (namespace_, self.gds_format_integer(self.numberOfConsumptionBlocks, input_name='numberOfConsumptionBlocks'), namespace_, eol_)) - if self.numberOfTouTiers is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%snumberOfTouTiers>%s%s' % (namespace_, self.gds_format_integer(self.numberOfTouTiers, input_name='numberOfTouTiers'), namespace_, eol_)) - if self.phase is not None: - self.phase.export(outfile, level, namespace_, name_='phase', pretty_print=pretty_print) - if self.powerOfTenMultiplier is not None: - self.powerOfTenMultiplier.export(outfile, level, namespace_, name_='powerOfTenMultiplier', pretty_print=pretty_print) - if self.subIntervalLength is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssubIntervalLength>%s%s' % (namespace_, self.gds_format_integer(self.subIntervalLength, input_name='subIntervalLength'), namespace_, eol_)) - if self.supplyLimit is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssupplyLimit>%s%s' % (namespace_, self.gds_format_integer(self.supplyLimit, input_name='supplyLimit'), namespace_, eol_)) - if self.tieredConsumptionBlocks is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%stieredConsumptionBlocks>%s%s' % (namespace_, self.gds_format_boolean(self.tieredConsumptionBlocks, input_name='tieredConsumptionBlocks'), namespace_, eol_)) - if self.uom is not None: - self.uom.export(outfile, level, namespace_, name_='uom', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ReadingType'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingType, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingType, self).exportLiteralChildren(outfile, level, name_) - if self.accumulationBehaviour is not None: - showIndent(outfile, level) - outfile.write('accumulationBehaviour=model_.AccumulationBehaviourType(\n') - self.accumulationBehaviour.exportLiteral(outfile, level, name_='accumulationBehaviour') - showIndent(outfile, level) - outfile.write('),\n') - if self.calorificValue is not None: - showIndent(outfile, level) - outfile.write('calorificValue=model_.UnitValueType(\n') - self.calorificValue.exportLiteral(outfile, level, name_='calorificValue') - showIndent(outfile, level) - outfile.write('),\n') - if self.commodity is not None: - showIndent(outfile, level) - outfile.write('commodity=model_.CommodityType(\n') - self.commodity.exportLiteral(outfile, level, name_='commodity') - showIndent(outfile, level) - outfile.write('),\n') - if self.conversionFactor is not None: - showIndent(outfile, level) - outfile.write('conversionFactor=model_.UnitValueType(\n') - self.conversionFactor.exportLiteral(outfile, level, name_='conversionFactor') - showIndent(outfile, level) - outfile.write('),\n') - if self.dataQualifier is not None: - showIndent(outfile, level) - outfile.write('dataQualifier=model_.DataQualifierType(\n') - self.dataQualifier.exportLiteral(outfile, level, name_='dataQualifier') - showIndent(outfile, level) - outfile.write('),\n') - if self.flowDirection is not None: - showIndent(outfile, level) - outfile.write('flowDirection=model_.FlowDirectionType(\n') - self.flowDirection.exportLiteral(outfile, level, name_='flowDirection') - showIndent(outfile, level) - outfile.write('),\n') - if self.intervalLength is not None: - showIndent(outfile, level) - outfile.write('intervalLength=%d,\n' % self.intervalLength) - if self.kind is not None: - showIndent(outfile, level) - outfile.write('kind=model_.KindType(\n') - self.kind.exportLiteral(outfile, level, name_='kind') - showIndent(outfile, level) - outfile.write('),\n') - if self.maxNumberOfIntervals is not None: - showIndent(outfile, level) - outfile.write('maxNumberOfIntervals=%d,\n' % self.maxNumberOfIntervals) - if self.numberOfConsumptionBlocks is not None: - showIndent(outfile, level) - outfile.write('numberOfConsumptionBlocks=%d,\n' % self.numberOfConsumptionBlocks) - if self.numberOfTouTiers is not None: - showIndent(outfile, level) - outfile.write('numberOfTouTiers=%d,\n' % self.numberOfTouTiers) - if self.phase is not None: - showIndent(outfile, level) - outfile.write('phase=model_.PhaseCode(\n') - self.phase.exportLiteral(outfile, level, name_='phase') - showIndent(outfile, level) - outfile.write('),\n') - if self.powerOfTenMultiplier is not None: - showIndent(outfile, level) - outfile.write('powerOfTenMultiplier=model_.PowerOfTenMultiplierType(\n') - self.powerOfTenMultiplier.exportLiteral(outfile, level, name_='powerOfTenMultiplier') - showIndent(outfile, level) - outfile.write('),\n') - if self.subIntervalLength is not None: - showIndent(outfile, level) - outfile.write('subIntervalLength=%d,\n' % self.subIntervalLength) - if self.supplyLimit is not None: - showIndent(outfile, level) - outfile.write('supplyLimit=%d,\n' % self.supplyLimit) - if self.tieredConsumptionBlocks is not None: - showIndent(outfile, level) - outfile.write('tieredConsumptionBlocks=%s,\n' % self.tieredConsumptionBlocks) - if self.uom is not None: - showIndent(outfile, level) - outfile.write('uom=model_.UomType(\n') - self.uom.exportLiteral(outfile, level, name_='uom') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingType, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'accumulationBehaviour': - obj_ = AccumulationBehaviourType.factory() - obj_.build(child_) - self.accumulationBehaviour = obj_ - obj_.original_tagname_ = 'accumulationBehaviour' - elif nodeName_ == 'calorificValue': - obj_ = UnitValueType.factory() - obj_.build(child_) - self.calorificValue = obj_ - obj_.original_tagname_ = 'calorificValue' - elif nodeName_ == 'commodity': - obj_ = CommodityType.factory() - obj_.build(child_) - self.commodity = obj_ - obj_.original_tagname_ = 'commodity' - elif nodeName_ == 'conversionFactor': - obj_ = UnitValueType.factory() - obj_.build(child_) - self.conversionFactor = obj_ - obj_.original_tagname_ = 'conversionFactor' - elif nodeName_ == 'dataQualifier': - obj_ = DataQualifierType.factory() - obj_.build(child_) - self.dataQualifier = obj_ - obj_.original_tagname_ = 'dataQualifier' - elif nodeName_ == 'flowDirection': - obj_ = FlowDirectionType.factory() - obj_.build(child_) - self.flowDirection = obj_ - obj_.original_tagname_ = 'flowDirection' - elif nodeName_ == 'intervalLength': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'intervalLength') - self.intervalLength = ival_ - self.validate_UInt32(self.intervalLength) # validate type UInt32 - elif nodeName_ == 'kind': - obj_ = KindType.factory() - obj_.build(child_) - self.kind = obj_ - obj_.original_tagname_ = 'kind' - elif nodeName_ == 'maxNumberOfIntervals': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'maxNumberOfIntervals') - self.maxNumberOfIntervals = ival_ - self.validate_UInt8(self.maxNumberOfIntervals) # validate type UInt8 - elif nodeName_ == 'numberOfConsumptionBlocks': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'numberOfConsumptionBlocks') - self.numberOfConsumptionBlocks = ival_ - self.validate_UInt8(self.numberOfConsumptionBlocks) # validate type UInt8 - elif nodeName_ == 'numberOfTouTiers': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'numberOfTouTiers') - self.numberOfTouTiers = ival_ - self.validate_UInt8(self.numberOfTouTiers) # validate type UInt8 - elif nodeName_ == 'phase': - obj_ = PhaseCode.factory() - obj_.build(child_) - self.phase = obj_ - obj_.original_tagname_ = 'phase' - elif nodeName_ == 'powerOfTenMultiplier': - obj_ = PowerOfTenMultiplierType.factory() - obj_.build(child_) - self.powerOfTenMultiplier = obj_ - obj_.original_tagname_ = 'powerOfTenMultiplier' - elif nodeName_ == 'subIntervalLength': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'subIntervalLength') - self.subIntervalLength = ival_ - self.validate_UInt32(self.subIntervalLength) # validate type UInt32 - elif nodeName_ == 'supplyLimit': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'supplyLimit') - self.supplyLimit = ival_ - self.validate_UInt48(self.supplyLimit) # validate type UInt48 - elif nodeName_ == 'tieredConsumptionBlocks': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'tieredConsumptionBlocks') - self.tieredConsumptionBlocks = ival_ - elif nodeName_ == 'uom': - obj_ = UomType.factory() - obj_.build(child_) - self.uom = obj_ - obj_.original_tagname_ = 'uom' - super(ReadingType, self).buildChildren(child_, node, nodeName_, True) -# end class ReadingType - - -class ReadingSetList(SubscribableList): - """A List element to hold ReadingSet objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, ReadingSet=None): - self.original_tagname_ = None - super(ReadingSetList, self).__init__() - if ReadingSet is None: - self.ReadingSet = [] - else: - self.ReadingSet = ReadingSet - def factory(*args_, **kwargs_): - if ReadingSetList.subclass: - return ReadingSetList.subclass(*args_, **kwargs_) - else: - return ReadingSetList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ReadingSet(self): return self.ReadingSet - def set_ReadingSet(self, ReadingSet): self.ReadingSet = ReadingSet - def add_ReadingSet(self, value): self.ReadingSet.append(value) - def insert_ReadingSet_at(self, index, value): self.ReadingSet.insert(index, value) - def replace_ReadingSet_at(self, index, value): self.ReadingSet[index] = value - def hasContent_(self): - if ( - self.ReadingSet or - super(ReadingSetList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingSetList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingSetList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingSetList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingSetList'): - super(ReadingSetList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingSetList') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingSetList', fromsubclass_=False, pretty_print=True): - super(ReadingSetList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for ReadingSet_ in self.ReadingSet: - ReadingSet_.export(outfile, level, namespace_, name_='ReadingSet', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ReadingSetList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingSetList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingSetList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('ReadingSet=[\n') - level += 1 - for ReadingSet_ in self.ReadingSet: - showIndent(outfile, level) - outfile.write('model_.ReadingSet(\n') - ReadingSet_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingSetList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ReadingSet': - obj_ = ReadingSet.factory() - obj_.build(child_) - self.ReadingSet.append(obj_) - obj_.original_tagname_ = 'ReadingSet' - super(ReadingSetList, self).buildChildren(child_, node, nodeName_, True) -# end class ReadingSetList - - -class ReadingList(SubscribableList): - """A List element to hold Reading objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, Reading=None): - self.original_tagname_ = None - super(ReadingList, self).__init__() - if Reading is None: - self.Reading = [] - else: - self.Reading = Reading - def factory(*args_, **kwargs_): - if ReadingList.subclass: - return ReadingList.subclass(*args_, **kwargs_) - else: - return ReadingList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Reading(self): return self.Reading - def set_Reading(self, Reading): self.Reading = Reading - def add_Reading(self, value): self.Reading.append(value) - def insert_Reading_at(self, index, value): self.Reading.insert(index, value) - def replace_Reading_at(self, index, value): self.Reading[index] = value - def hasContent_(self): - if ( - self.Reading or - super(ReadingList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingList'): - super(ReadingList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingList') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingList', fromsubclass_=False, pretty_print=True): - super(ReadingList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for Reading_ in self.Reading: - Reading_.export(outfile, level, namespace_, name_='Reading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ReadingList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('Reading=[\n') - level += 1 - for Reading_ in self.Reading: - showIndent(outfile, level) - outfile.write('model_.Reading(\n') - Reading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Reading': - obj_ = Reading.factory() - obj_.build(child_) - self.Reading.append(obj_) - obj_.original_tagname_ = 'Reading' - super(ReadingList, self).buildChildren(child_, node, nodeName_, True) -# end class ReadingList - - -class Reading(ReadingBase): - """Specific value measured by a meter or other asset.Indicates whether - or not subscriptions are supported for this resource, and - whether or not conditional (thresholds) are supported. If not - specified, is "not subscribable" (0).""" - subclass = None - superclass = ReadingBase - def __init__(self, subscribable='0', localID=None): - self.original_tagname_ = None - super(Reading, self).__init__() - self.subscribable = _cast(None, subscribable) - self.localID = localID - def factory(*args_, **kwargs_): - if Reading.subclass: - return Reading.subclass(*args_, **kwargs_) - else: - return Reading(*args_, **kwargs_) - factory = staticmethod(factory) - def get_localID(self): return self.localID - def set_localID(self, localID): self.localID = localID - def get_subscribable(self): return self.subscribable - def set_subscribable(self, subscribable): self.subscribable = subscribable - def validate_HexBinary16(self, value): - # Validate type HexBinary16, a restriction on xs:hexBinary. - pass - def validate_SubscribableType(self, value): - # Validate type SubscribableType, a restriction on UInt8. - pass - def hasContent_(self): - if ( - self.localID is not None or - super(Reading, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Reading', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Reading') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Reading', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Reading'): - super(Reading, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Reading') - if self.subscribable is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - outfile.write(' subscribable=%s' % (quote_attrib(self.subscribable), )) - def exportChildren(self, outfile, level, namespace_='', name_='Reading', fromsubclass_=False, pretty_print=True): - super(Reading, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.localID is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slocalID>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.localID).encode(ExternalEncoding), input_name='localID'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Reading'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.subscribable is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - showIndent(outfile, level) - outfile.write('subscribable=%d,\n' % (self.subscribable,)) - super(Reading, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Reading, self).exportLiteralChildren(outfile, level, name_) - if self.localID is not None: - showIndent(outfile, level) - outfile.write('localID=%s,\n' % quote_python(self.localID).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('subscribable', node) - if value is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - self.subscribable = value - self.validate_SubscribableType(self.subscribable) # validate type SubscribableType - super(Reading, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'localID': - localID_ = child_.text - localID_ = self.gds_validate_string(localID_, node, 'localID') - self.localID = localID_ - self.validate_HexBinary16(self.localID) # validate type HexBinary16 - super(Reading, self).buildChildren(child_, node, nodeName_, True) -# end class Reading - - -class MeterReadingList(SubscribableList): - """A List element to hold MeterReading objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, MeterReading=None): - self.original_tagname_ = None - super(MeterReadingList, self).__init__() - if MeterReading is None: - self.MeterReading = [] - else: - self.MeterReading = MeterReading - def factory(*args_, **kwargs_): - if MeterReadingList.subclass: - return MeterReadingList.subclass(*args_, **kwargs_) - else: - return MeterReadingList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_MeterReading(self): return self.MeterReading - def set_MeterReading(self, MeterReading): self.MeterReading = MeterReading - def add_MeterReading(self, value): self.MeterReading.append(value) - def insert_MeterReading_at(self, index, value): self.MeterReading.insert(index, value) - def replace_MeterReading_at(self, index, value): self.MeterReading[index] = value - def hasContent_(self): - if ( - self.MeterReading or - super(MeterReadingList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MeterReadingList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReadingList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MeterReadingList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MeterReadingList'): - super(MeterReadingList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReadingList') - def exportChildren(self, outfile, level, namespace_='', name_='MeterReadingList', fromsubclass_=False, pretty_print=True): - super(MeterReadingList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for MeterReading_ in self.MeterReading: - MeterReading_.export(outfile, level, namespace_, name_='MeterReading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MeterReadingList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MeterReadingList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MeterReadingList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('MeterReading=[\n') - level += 1 - for MeterReading_ in self.MeterReading: - showIndent(outfile, level) - outfile.write('model_.MeterReading(\n') - MeterReading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MeterReadingList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'MeterReading': - obj_ = MeterReading.factory() - obj_.build(child_) - self.MeterReading.append(obj_) - obj_.original_tagname_ = 'MeterReading' - super(MeterReadingList, self).buildChildren(child_, node, nodeName_, True) -# end class MeterReadingList - - -class LoadShedAvailability(Resource): - """Indicates current consumption status and ability to shed load.""" - subclass = None - superclass = Resource - def __init__(self, availabilityDuration=None, DemandResponseProgramLink=None, sheddablePercent=None, sheddablePower=None): - self.original_tagname_ = None - super(LoadShedAvailability, self).__init__() - self.availabilityDuration = availabilityDuration - self.DemandResponseProgramLink = DemandResponseProgramLink - self.sheddablePercent = sheddablePercent - self.sheddablePower = sheddablePower - def factory(*args_, **kwargs_): - if LoadShedAvailability.subclass: - return LoadShedAvailability.subclass(*args_, **kwargs_) - else: - return LoadShedAvailability(*args_, **kwargs_) - factory = staticmethod(factory) - def get_availabilityDuration(self): return self.availabilityDuration - def set_availabilityDuration(self, availabilityDuration): self.availabilityDuration = availabilityDuration - def get_DemandResponseProgramLink(self): return self.DemandResponseProgramLink - def set_DemandResponseProgramLink(self, DemandResponseProgramLink): self.DemandResponseProgramLink = DemandResponseProgramLink - def get_sheddablePercent(self): return self.sheddablePercent - def set_sheddablePercent(self, sheddablePercent): self.sheddablePercent = sheddablePercent - def get_sheddablePower(self): return self.sheddablePower - def set_sheddablePower(self, sheddablePower): self.sheddablePower = sheddablePower - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def hasContent_(self): - if ( - self.availabilityDuration is not None or - self.DemandResponseProgramLink is not None or - self.sheddablePercent is not None or - self.sheddablePower is not None or - super(LoadShedAvailability, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LoadShedAvailability', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LoadShedAvailability') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LoadShedAvailability', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LoadShedAvailability'): - super(LoadShedAvailability, self).exportAttributes(outfile, level, already_processed, namespace_, name_='LoadShedAvailability') - def exportChildren(self, outfile, level, namespace_='', name_='LoadShedAvailability', fromsubclass_=False, pretty_print=True): - super(LoadShedAvailability, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.availabilityDuration is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%savailabilityDuration>%s%s' % (namespace_, self.gds_format_integer(self.availabilityDuration, input_name='availabilityDuration'), namespace_, eol_)) - if self.DemandResponseProgramLink is not None: - self.DemandResponseProgramLink.export(outfile, level, namespace_, name_='DemandResponseProgramLink', pretty_print=pretty_print) - if self.sheddablePercent is not None: - self.sheddablePercent.export(outfile, level, namespace_, name_='sheddablePercent', pretty_print=pretty_print) - if self.sheddablePower is not None: - self.sheddablePower.export(outfile, level, namespace_, name_='sheddablePower', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='LoadShedAvailability'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(LoadShedAvailability, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(LoadShedAvailability, self).exportLiteralChildren(outfile, level, name_) - if self.availabilityDuration is not None: - showIndent(outfile, level) - outfile.write('availabilityDuration=%d,\n' % self.availabilityDuration) - if self.DemandResponseProgramLink is not None: - showIndent(outfile, level) - outfile.write('DemandResponseProgramLink=model_.DemandResponseProgramLink(\n') - self.DemandResponseProgramLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.sheddablePercent is not None: - showIndent(outfile, level) - outfile.write('sheddablePercent=model_.PerCent(\n') - self.sheddablePercent.exportLiteral(outfile, level, name_='sheddablePercent') - showIndent(outfile, level) - outfile.write('),\n') - if self.sheddablePower is not None: - showIndent(outfile, level) - outfile.write('sheddablePower=model_.ActivePower(\n') - self.sheddablePower.exportLiteral(outfile, level, name_='sheddablePower') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(LoadShedAvailability, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'availabilityDuration': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'availabilityDuration') - self.availabilityDuration = ival_ - self.validate_UInt32(self.availabilityDuration) # validate type UInt32 - elif nodeName_ == 'DemandResponseProgramLink': - obj_ = DemandResponseProgramLink.factory() - obj_.build(child_) - self.DemandResponseProgramLink = obj_ - obj_.original_tagname_ = 'DemandResponseProgramLink' - elif nodeName_ == 'sheddablePercent': - obj_ = PerCent.factory() - obj_.build(child_) - self.sheddablePercent = obj_ - obj_.original_tagname_ = 'sheddablePercent' - elif nodeName_ == 'sheddablePower': - obj_ = ActivePower.factory() - obj_.build(child_) - self.sheddablePower = obj_ - obj_.original_tagname_ = 'sheddablePower' - super(LoadShedAvailability, self).buildChildren(child_, node, nodeName_, True) -# end class LoadShedAvailability - - -class EndDeviceControlList(SubscribableList): - """A List element to hold EndDeviceControl objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, EndDeviceControl=None): - self.original_tagname_ = None - super(EndDeviceControlList, self).__init__() - if EndDeviceControl is None: - self.EndDeviceControl = [] - else: - self.EndDeviceControl = EndDeviceControl - def factory(*args_, **kwargs_): - if EndDeviceControlList.subclass: - return EndDeviceControlList.subclass(*args_, **kwargs_) - else: - return EndDeviceControlList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_EndDeviceControl(self): return self.EndDeviceControl - def set_EndDeviceControl(self, EndDeviceControl): self.EndDeviceControl = EndDeviceControl - def add_EndDeviceControl(self, value): self.EndDeviceControl.append(value) - def insert_EndDeviceControl_at(self, index, value): self.EndDeviceControl.insert(index, value) - def replace_EndDeviceControl_at(self, index, value): self.EndDeviceControl[index] = value - def hasContent_(self): - if ( - self.EndDeviceControl or - super(EndDeviceControlList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EndDeviceControlList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceControlList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EndDeviceControlList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EndDeviceControlList'): - super(EndDeviceControlList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceControlList') - def exportChildren(self, outfile, level, namespace_='', name_='EndDeviceControlList', fromsubclass_=False, pretty_print=True): - super(EndDeviceControlList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for EndDeviceControl_ in self.EndDeviceControl: - EndDeviceControl_.export(outfile, level, namespace_, name_='EndDeviceControl', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='EndDeviceControlList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(EndDeviceControlList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(EndDeviceControlList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('EndDeviceControl=[\n') - level += 1 - for EndDeviceControl_ in self.EndDeviceControl: - showIndent(outfile, level) - outfile.write('model_.EndDeviceControl(\n') - EndDeviceControl_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(EndDeviceControlList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'EndDeviceControl': - obj_ = EndDeviceControl.factory() - obj_.build(child_) - self.EndDeviceControl.append(obj_) - obj_.original_tagname_ = 'EndDeviceControl' - super(EndDeviceControlList, self).buildChildren(child_, node, nodeName_, True) -# end class EndDeviceControlList - - -class EndDeviceControl(RandomizableEvent): - """Instructs an EndDevice to perform a specified action.""" - subclass = None - superclass = RandomizableEvent - def __init__(self, ApplianceLoadReduction=None, deviceCategory=None, drProgramMandatory=None, DutyCycle=None, loadShiftForward=None, Offset=None, overrideDuration=None, SetPoint=None, TargetReduction=None): - self.original_tagname_ = None - super(EndDeviceControl, self).__init__() - self.ApplianceLoadReduction = ApplianceLoadReduction - self.deviceCategory = deviceCategory - self.drProgramMandatory = drProgramMandatory - self.DutyCycle = DutyCycle - self.loadShiftForward = loadShiftForward - self.Offset = Offset - self.overrideDuration = overrideDuration - self.SetPoint = SetPoint - self.TargetReduction = TargetReduction - def factory(*args_, **kwargs_): - if EndDeviceControl.subclass: - return EndDeviceControl.subclass(*args_, **kwargs_) - else: - return EndDeviceControl(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ApplianceLoadReduction(self): return self.ApplianceLoadReduction - def set_ApplianceLoadReduction(self, ApplianceLoadReduction): self.ApplianceLoadReduction = ApplianceLoadReduction - def get_deviceCategory(self): return self.deviceCategory - def set_deviceCategory(self, deviceCategory): self.deviceCategory = deviceCategory - def get_drProgramMandatory(self): return self.drProgramMandatory - def set_drProgramMandatory(self, drProgramMandatory): self.drProgramMandatory = drProgramMandatory - def get_DutyCycle(self): return self.DutyCycle - def set_DutyCycle(self, DutyCycle): self.DutyCycle = DutyCycle - def get_loadShiftForward(self): return self.loadShiftForward - def set_loadShiftForward(self, loadShiftForward): self.loadShiftForward = loadShiftForward - def get_Offset(self): return self.Offset - def set_Offset(self, Offset): self.Offset = Offset - def get_overrideDuration(self): return self.overrideDuration - def set_overrideDuration(self, overrideDuration): self.overrideDuration = overrideDuration - def get_SetPoint(self): return self.SetPoint - def set_SetPoint(self, SetPoint): self.SetPoint = SetPoint - def get_TargetReduction(self): return self.TargetReduction - def set_TargetReduction(self, TargetReduction): self.TargetReduction = TargetReduction - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.ApplianceLoadReduction is not None or - self.deviceCategory is not None or - self.drProgramMandatory is not None or - self.DutyCycle is not None or - self.loadShiftForward is not None or - self.Offset is not None or - self.overrideDuration is not None or - self.SetPoint is not None or - self.TargetReduction is not None or - super(EndDeviceControl, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EndDeviceControl', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceControl') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EndDeviceControl', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EndDeviceControl'): - super(EndDeviceControl, self).exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceControl') - def exportChildren(self, outfile, level, namespace_='', name_='EndDeviceControl', fromsubclass_=False, pretty_print=True): - super(EndDeviceControl, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ApplianceLoadReduction is not None: - self.ApplianceLoadReduction.export(outfile, level, namespace_, name_='ApplianceLoadReduction', pretty_print=pretty_print) - if self.deviceCategory is not None: - self.deviceCategory.export(outfile, level, namespace_, name_='deviceCategory', pretty_print=pretty_print) - if self.drProgramMandatory is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdrProgramMandatory>%s%s' % (namespace_, self.gds_format_boolean(self.drProgramMandatory, input_name='drProgramMandatory'), namespace_, eol_)) - if self.DutyCycle is not None: - self.DutyCycle.export(outfile, level, namespace_, name_='DutyCycle', pretty_print=pretty_print) - if self.loadShiftForward is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sloadShiftForward>%s%s' % (namespace_, self.gds_format_boolean(self.loadShiftForward, input_name='loadShiftForward'), namespace_, eol_)) - if self.Offset is not None: - self.Offset.export(outfile, level, namespace_, name_='Offset', pretty_print=pretty_print) - if self.overrideDuration is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%soverrideDuration>%s%s' % (namespace_, self.gds_format_integer(self.overrideDuration, input_name='overrideDuration'), namespace_, eol_)) - if self.SetPoint is not None: - self.SetPoint.export(outfile, level, namespace_, name_='SetPoint', pretty_print=pretty_print) - if self.TargetReduction is not None: - self.TargetReduction.export(outfile, level, namespace_, name_='TargetReduction', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='EndDeviceControl'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(EndDeviceControl, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(EndDeviceControl, self).exportLiteralChildren(outfile, level, name_) - if self.ApplianceLoadReduction is not None: - showIndent(outfile, level) - outfile.write('ApplianceLoadReduction=model_.ApplianceLoadReduction(\n') - self.ApplianceLoadReduction.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.deviceCategory is not None: - showIndent(outfile, level) - outfile.write('deviceCategory=model_.DeviceCategoryType(\n') - self.deviceCategory.exportLiteral(outfile, level, name_='deviceCategory') - showIndent(outfile, level) - outfile.write('),\n') - if self.drProgramMandatory is not None: - showIndent(outfile, level) - outfile.write('drProgramMandatory=%s,\n' % self.drProgramMandatory) - if self.DutyCycle is not None: - showIndent(outfile, level) - outfile.write('DutyCycle=model_.DutyCycle(\n') - self.DutyCycle.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.loadShiftForward is not None: - showIndent(outfile, level) - outfile.write('loadShiftForward=%s,\n' % self.loadShiftForward) - if self.Offset is not None: - showIndent(outfile, level) - outfile.write('Offset=model_.Offset(\n') - self.Offset.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.overrideDuration is not None: - showIndent(outfile, level) - outfile.write('overrideDuration=%d,\n' % self.overrideDuration) - if self.SetPoint is not None: - showIndent(outfile, level) - outfile.write('SetPoint=model_.SetPoint(\n') - self.SetPoint.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.TargetReduction is not None: - showIndent(outfile, level) - outfile.write('TargetReduction=model_.TargetReduction(\n') - self.TargetReduction.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(EndDeviceControl, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ApplianceLoadReduction': - obj_ = ApplianceLoadReduction.factory() - obj_.build(child_) - self.ApplianceLoadReduction = obj_ - obj_.original_tagname_ = 'ApplianceLoadReduction' - elif nodeName_ == 'deviceCategory': - obj_ = DeviceCategoryType.factory() - obj_.build(child_) - self.deviceCategory = obj_ - obj_.original_tagname_ = 'deviceCategory' - elif nodeName_ == 'drProgramMandatory': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'drProgramMandatory') - self.drProgramMandatory = ival_ - elif nodeName_ == 'DutyCycle': - obj_ = DutyCycle.factory() - obj_.build(child_) - self.DutyCycle = obj_ - obj_.original_tagname_ = 'DutyCycle' - elif nodeName_ == 'loadShiftForward': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'loadShiftForward') - self.loadShiftForward = ival_ - elif nodeName_ == 'Offset': - obj_ = Offset.factory() - obj_.build(child_) - self.Offset = obj_ - obj_.original_tagname_ = 'Offset' - elif nodeName_ == 'overrideDuration': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'overrideDuration') - self.overrideDuration = ival_ - self.validate_UInt16(self.overrideDuration) # validate type UInt16 - elif nodeName_ == 'SetPoint': - obj_ = SetPoint.factory() - obj_.build(child_) - self.SetPoint = obj_ - obj_.original_tagname_ = 'SetPoint' - elif nodeName_ == 'TargetReduction': - obj_ = TargetReduction.factory() - obj_.build(child_) - self.TargetReduction = obj_ - obj_.original_tagname_ = 'TargetReduction' - super(EndDeviceControl, self).buildChildren(child_, node, nodeName_, True) -# end class EndDeviceControl - - -class DemandResponseProgramList(SubscribableList): - """A List element to hold DemandResponseProgram objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, DemandResponseProgram=None): - self.original_tagname_ = None - super(DemandResponseProgramList, self).__init__() - if DemandResponseProgram is None: - self.DemandResponseProgram = [] - else: - self.DemandResponseProgram = DemandResponseProgram - def factory(*args_, **kwargs_): - if DemandResponseProgramList.subclass: - return DemandResponseProgramList.subclass(*args_, **kwargs_) - else: - return DemandResponseProgramList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DemandResponseProgram(self): return self.DemandResponseProgram - def set_DemandResponseProgram(self, DemandResponseProgram): self.DemandResponseProgram = DemandResponseProgram - def add_DemandResponseProgram(self, value): self.DemandResponseProgram.append(value) - def insert_DemandResponseProgram_at(self, index, value): self.DemandResponseProgram.insert(index, value) - def replace_DemandResponseProgram_at(self, index, value): self.DemandResponseProgram[index] = value - def hasContent_(self): - if ( - self.DemandResponseProgram or - super(DemandResponseProgramList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DemandResponseProgramList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DemandResponseProgramList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DemandResponseProgramList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DemandResponseProgramList'): - super(DemandResponseProgramList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DemandResponseProgramList') - def exportChildren(self, outfile, level, namespace_='', name_='DemandResponseProgramList', fromsubclass_=False, pretty_print=True): - super(DemandResponseProgramList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for DemandResponseProgram_ in self.DemandResponseProgram: - DemandResponseProgram_.export(outfile, level, namespace_, name_='DemandResponseProgram', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DemandResponseProgramList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DemandResponseProgramList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DemandResponseProgramList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('DemandResponseProgram=[\n') - level += 1 - for DemandResponseProgram_ in self.DemandResponseProgram: - showIndent(outfile, level) - outfile.write('model_.DemandResponseProgram(\n') - DemandResponseProgram_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DemandResponseProgramList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DemandResponseProgram': - obj_ = DemandResponseProgram.factory() - obj_.build(child_) - self.DemandResponseProgram.append(obj_) - obj_.original_tagname_ = 'DemandResponseProgram' - super(DemandResponseProgramList, self).buildChildren(child_, node, nodeName_, True) -# end class DemandResponseProgramList - - -class DemandResponseProgram(IdentifiedObject): - """Demand response program.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, ActiveEndDeviceControlListLink=None, availabilityUpdatePercentChangeThreshold=None, availabilityUpdatePowerChangeThreshold=None, EndDeviceControlListLink=None, primacy=None): - self.original_tagname_ = None - super(DemandResponseProgram, self).__init__() - self.ActiveEndDeviceControlListLink = ActiveEndDeviceControlListLink - self.availabilityUpdatePercentChangeThreshold = availabilityUpdatePercentChangeThreshold - self.availabilityUpdatePowerChangeThreshold = availabilityUpdatePowerChangeThreshold - self.EndDeviceControlListLink = EndDeviceControlListLink - self.primacy = primacy - def factory(*args_, **kwargs_): - if DemandResponseProgram.subclass: - return DemandResponseProgram.subclass(*args_, **kwargs_) - else: - return DemandResponseProgram(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ActiveEndDeviceControlListLink(self): return self.ActiveEndDeviceControlListLink - def set_ActiveEndDeviceControlListLink(self, ActiveEndDeviceControlListLink): self.ActiveEndDeviceControlListLink = ActiveEndDeviceControlListLink - def get_availabilityUpdatePercentChangeThreshold(self): return self.availabilityUpdatePercentChangeThreshold - def set_availabilityUpdatePercentChangeThreshold(self, availabilityUpdatePercentChangeThreshold): self.availabilityUpdatePercentChangeThreshold = availabilityUpdatePercentChangeThreshold - def get_availabilityUpdatePowerChangeThreshold(self): return self.availabilityUpdatePowerChangeThreshold - def set_availabilityUpdatePowerChangeThreshold(self, availabilityUpdatePowerChangeThreshold): self.availabilityUpdatePowerChangeThreshold = availabilityUpdatePowerChangeThreshold - def get_EndDeviceControlListLink(self): return self.EndDeviceControlListLink - def set_EndDeviceControlListLink(self, EndDeviceControlListLink): self.EndDeviceControlListLink = EndDeviceControlListLink - def get_primacy(self): return self.primacy - def set_primacy(self, primacy): self.primacy = primacy - def hasContent_(self): - if ( - self.ActiveEndDeviceControlListLink is not None or - self.availabilityUpdatePercentChangeThreshold is not None or - self.availabilityUpdatePowerChangeThreshold is not None or - self.EndDeviceControlListLink is not None or - self.primacy is not None or - super(DemandResponseProgram, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DemandResponseProgram', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DemandResponseProgram') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DemandResponseProgram', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DemandResponseProgram'): - super(DemandResponseProgram, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DemandResponseProgram') - def exportChildren(self, outfile, level, namespace_='', name_='DemandResponseProgram', fromsubclass_=False, pretty_print=True): - super(DemandResponseProgram, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ActiveEndDeviceControlListLink is not None: - self.ActiveEndDeviceControlListLink.export(outfile, level, namespace_, name_='ActiveEndDeviceControlListLink', pretty_print=pretty_print) - if self.availabilityUpdatePercentChangeThreshold is not None: - self.availabilityUpdatePercentChangeThreshold.export(outfile, level, namespace_, name_='availabilityUpdatePercentChangeThreshold', pretty_print=pretty_print) - if self.availabilityUpdatePowerChangeThreshold is not None: - self.availabilityUpdatePowerChangeThreshold.export(outfile, level, namespace_, name_='availabilityUpdatePowerChangeThreshold', pretty_print=pretty_print) - if self.EndDeviceControlListLink is not None: - self.EndDeviceControlListLink.export(outfile, level, namespace_, name_='EndDeviceControlListLink', pretty_print=pretty_print) - if self.primacy is not None: - self.primacy.export(outfile, level, namespace_, name_='primacy', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DemandResponseProgram'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DemandResponseProgram, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DemandResponseProgram, self).exportLiteralChildren(outfile, level, name_) - if self.ActiveEndDeviceControlListLink is not None: - showIndent(outfile, level) - outfile.write('ActiveEndDeviceControlListLink=model_.ActiveEndDeviceControlListLink(\n') - self.ActiveEndDeviceControlListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.availabilityUpdatePercentChangeThreshold is not None: - showIndent(outfile, level) - outfile.write('availabilityUpdatePercentChangeThreshold=model_.PerCent(\n') - self.availabilityUpdatePercentChangeThreshold.exportLiteral(outfile, level, name_='availabilityUpdatePercentChangeThreshold') - showIndent(outfile, level) - outfile.write('),\n') - if self.availabilityUpdatePowerChangeThreshold is not None: - showIndent(outfile, level) - outfile.write('availabilityUpdatePowerChangeThreshold=model_.ActivePower(\n') - self.availabilityUpdatePowerChangeThreshold.exportLiteral(outfile, level, name_='availabilityUpdatePowerChangeThreshold') - showIndent(outfile, level) - outfile.write('),\n') - if self.EndDeviceControlListLink is not None: - showIndent(outfile, level) - outfile.write('EndDeviceControlListLink=model_.EndDeviceControlListLink(\n') - self.EndDeviceControlListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.primacy is not None: - showIndent(outfile, level) - outfile.write('primacy=model_.PrimacyType(\n') - self.primacy.exportLiteral(outfile, level, name_='primacy') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DemandResponseProgram, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ActiveEndDeviceControlListLink': - obj_ = ActiveEndDeviceControlListLink.factory() - obj_.build(child_) - self.ActiveEndDeviceControlListLink = obj_ - obj_.original_tagname_ = 'ActiveEndDeviceControlListLink' - elif nodeName_ == 'availabilityUpdatePercentChangeThreshold': - obj_ = PerCent.factory() - obj_.build(child_) - self.availabilityUpdatePercentChangeThreshold = obj_ - obj_.original_tagname_ = 'availabilityUpdatePercentChangeThreshold' - elif nodeName_ == 'availabilityUpdatePowerChangeThreshold': - obj_ = ActivePower.factory() - obj_.build(child_) - self.availabilityUpdatePowerChangeThreshold = obj_ - obj_.original_tagname_ = 'availabilityUpdatePowerChangeThreshold' - elif nodeName_ == 'EndDeviceControlListLink': - obj_ = EndDeviceControlListLink.factory() - obj_.build(child_) - self.EndDeviceControlListLink = obj_ - obj_.original_tagname_ = 'EndDeviceControlListLink' - elif nodeName_ == 'primacy': - obj_ = PrimacyType.factory() - obj_.build(child_) - self.primacy = obj_ - obj_.original_tagname_ = 'primacy' - super(DemandResponseProgram, self).buildChildren(child_, node, nodeName_, True) -# end class DemandResponseProgram - - -class FileStatus(Resource): - """This object provides status of device file load and activation - operations.""" - subclass = None - superclass = Resource - def __init__(self, activateTime=None, FileLink=None, loadPercent=None, nextRequestAttempt=None, request503Count=None, requestFailCount=None, status=None, statusTime=None): - self.original_tagname_ = None - super(FileStatus, self).__init__() - self.activateTime = activateTime - self.FileLink = FileLink - self.loadPercent = loadPercent - self.nextRequestAttempt = nextRequestAttempt - self.request503Count = request503Count - self.requestFailCount = requestFailCount - self.status = status - self.statusTime = statusTime - def factory(*args_, **kwargs_): - if FileStatus.subclass: - return FileStatus.subclass(*args_, **kwargs_) - else: - return FileStatus(*args_, **kwargs_) - factory = staticmethod(factory) - def get_activateTime(self): return self.activateTime - def set_activateTime(self, activateTime): self.activateTime = activateTime - def get_FileLink(self): return self.FileLink - def set_FileLink(self, FileLink): self.FileLink = FileLink - def get_loadPercent(self): return self.loadPercent - def set_loadPercent(self, loadPercent): self.loadPercent = loadPercent - def get_nextRequestAttempt(self): return self.nextRequestAttempt - def set_nextRequestAttempt(self, nextRequestAttempt): self.nextRequestAttempt = nextRequestAttempt - def get_request503Count(self): return self.request503Count - def set_request503Count(self, request503Count): self.request503Count = request503Count - def get_requestFailCount(self): return self.requestFailCount - def set_requestFailCount(self, requestFailCount): self.requestFailCount = requestFailCount - def get_status(self): return self.status - def set_status(self, status): self.status = status - def get_statusTime(self): return self.statusTime - def set_statusTime(self, statusTime): self.statusTime = statusTime - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.activateTime is not None or - self.FileLink is not None or - self.loadPercent is not None or - self.nextRequestAttempt is not None or - self.request503Count is not None or - self.requestFailCount is not None or - self.status is not None or - self.statusTime is not None or - super(FileStatus, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FileStatus', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FileStatus') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FileStatus', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FileStatus'): - super(FileStatus, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FileStatus') - def exportChildren(self, outfile, level, namespace_='', name_='FileStatus', fromsubclass_=False, pretty_print=True): - super(FileStatus, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.activateTime is not None: - self.activateTime.export(outfile, level, namespace_, name_='activateTime', pretty_print=pretty_print) - if self.FileLink is not None: - self.FileLink.export(outfile, level, namespace_, name_='FileLink', pretty_print=pretty_print) - if self.loadPercent is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sloadPercent>%s%s' % (namespace_, self.gds_format_integer(self.loadPercent, input_name='loadPercent'), namespace_, eol_)) - if self.nextRequestAttempt is not None: - self.nextRequestAttempt.export(outfile, level, namespace_, name_='nextRequestAttempt', pretty_print=pretty_print) - if self.request503Count is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srequest503Count>%s%s' % (namespace_, self.gds_format_integer(self.request503Count, input_name='request503Count'), namespace_, eol_)) - if self.requestFailCount is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srequestFailCount>%s%s' % (namespace_, self.gds_format_integer(self.requestFailCount, input_name='requestFailCount'), namespace_, eol_)) - if self.status is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sstatus>%s%s' % (namespace_, self.gds_format_integer(self.status, input_name='status'), namespace_, eol_)) - if self.statusTime is not None: - self.statusTime.export(outfile, level, namespace_, name_='statusTime', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FileStatus'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FileStatus, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FileStatus, self).exportLiteralChildren(outfile, level, name_) - if self.activateTime is not None: - showIndent(outfile, level) - outfile.write('activateTime=model_.TimeType(\n') - self.activateTime.exportLiteral(outfile, level, name_='activateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.FileLink is not None: - showIndent(outfile, level) - outfile.write('FileLink=model_.FileLink(\n') - self.FileLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.loadPercent is not None: - showIndent(outfile, level) - outfile.write('loadPercent=%d,\n' % self.loadPercent) - if self.nextRequestAttempt is not None: - showIndent(outfile, level) - outfile.write('nextRequestAttempt=model_.TimeType(\n') - self.nextRequestAttempt.exportLiteral(outfile, level, name_='nextRequestAttempt') - showIndent(outfile, level) - outfile.write('),\n') - if self.request503Count is not None: - showIndent(outfile, level) - outfile.write('request503Count=%d,\n' % self.request503Count) - if self.requestFailCount is not None: - showIndent(outfile, level) - outfile.write('requestFailCount=%d,\n' % self.requestFailCount) - if self.status is not None: - showIndent(outfile, level) - outfile.write('status=%d,\n' % self.status) - if self.statusTime is not None: - showIndent(outfile, level) - outfile.write('statusTime=model_.TimeType(\n') - self.statusTime.exportLiteral(outfile, level, name_='statusTime') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FileStatus, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'activateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.activateTime = obj_ - obj_.original_tagname_ = 'activateTime' - elif nodeName_ == 'FileLink': - obj_ = FileLink.factory() - obj_.build(child_) - self.FileLink = obj_ - obj_.original_tagname_ = 'FileLink' - elif nodeName_ == 'loadPercent': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'loadPercent') - self.loadPercent = ival_ - self.validate_UInt8(self.loadPercent) # validate type UInt8 - elif nodeName_ == 'nextRequestAttempt': - obj_ = TimeType.factory() - obj_.build(child_) - self.nextRequestAttempt = obj_ - obj_.original_tagname_ = 'nextRequestAttempt' - elif nodeName_ == 'request503Count': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'request503Count') - self.request503Count = ival_ - self.validate_UInt16(self.request503Count) # validate type UInt16 - elif nodeName_ == 'requestFailCount': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'requestFailCount') - self.requestFailCount = ival_ - self.validate_UInt16(self.requestFailCount) # validate type UInt16 - elif nodeName_ == 'status': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'status') - self.status = ival_ - self.validate_UInt8(self.status) # validate type UInt8 - elif nodeName_ == 'statusTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.statusTime = obj_ - obj_.original_tagname_ = 'statusTime' - super(FileStatus, self).buildChildren(child_, node, nodeName_, True) -# end class FileStatus - - -class FileList(List): - """A List element to hold File objects.""" - subclass = None - superclass = List - def __init__(self, File=None): - self.original_tagname_ = None - super(FileList, self).__init__() - if File is None: - self.File = [] - else: - self.File = File - def factory(*args_, **kwargs_): - if FileList.subclass: - return FileList.subclass(*args_, **kwargs_) - else: - return FileList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_File(self): return self.File - def set_File(self, File): self.File = File - def add_File(self, value): self.File.append(value) - def insert_File_at(self, index, value): self.File.insert(index, value) - def replace_File_at(self, index, value): self.File[index] = value - def hasContent_(self): - if ( - self.File or - super(FileList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FileList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FileList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FileList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FileList'): - super(FileList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FileList') - def exportChildren(self, outfile, level, namespace_='', name_='FileList', fromsubclass_=False, pretty_print=True): - super(FileList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for File_ in self.File: - File_.export(outfile, level, namespace_, name_='File', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FileList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FileList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FileList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('File=[\n') - level += 1 - for File_ in self.File: - showIndent(outfile, level) - outfile.write('model_.File(\n') - File_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FileList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'File': - obj_ = File.factory() - obj_.build(child_) - self.File.append(obj_) - obj_.original_tagname_ = 'File' - super(FileList, self).buildChildren(child_, node, nodeName_, True) -# end class FileList - - -class File(Resource): - """This resource contains various meta-data describing a file's - characteristics. The meta-data provides general file information - and also is used to support filtered queries of file lists""" - subclass = None - superclass = Resource - def __init__(self, activateTime=None, fileURI=None, lFDI=None, mfHwVer=None, mfID=None, mfModel=None, mfSerNum=None, mfVer=None, size=None, type_=None): - self.original_tagname_ = None - super(File, self).__init__() - self.activateTime = activateTime - self.fileURI = fileURI - self.lFDI = lFDI - self.mfHwVer = mfHwVer - self.mfID = mfID - self.mfModel = mfModel - self.mfSerNum = mfSerNum - self.mfVer = mfVer - self.size = size - self.type_ = type_ - def factory(*args_, **kwargs_): - if File.subclass: - return File.subclass(*args_, **kwargs_) - else: - return File(*args_, **kwargs_) - factory = staticmethod(factory) - def get_activateTime(self): return self.activateTime - def set_activateTime(self, activateTime): self.activateTime = activateTime - def get_fileURI(self): return self.fileURI - def set_fileURI(self, fileURI): self.fileURI = fileURI - def get_lFDI(self): return self.lFDI - def set_lFDI(self, lFDI): self.lFDI = lFDI - def get_mfHwVer(self): return self.mfHwVer - def set_mfHwVer(self, mfHwVer): self.mfHwVer = mfHwVer - def get_mfID(self): return self.mfID - def set_mfID(self, mfID): self.mfID = mfID - def get_mfModel(self): return self.mfModel - def set_mfModel(self, mfModel): self.mfModel = mfModel - def get_mfSerNum(self): return self.mfSerNum - def set_mfSerNum(self, mfSerNum): self.mfSerNum = mfSerNum - def get_mfVer(self): return self.mfVer - def set_mfVer(self, mfVer): self.mfVer = mfVer - def get_size(self): return self.size - def set_size(self, size): self.size = size - def get_type(self): return self.type_ - def set_type(self, type_): self.type_ = type_ - def validate_HexBinary160(self, value): - # Validate type HexBinary160, a restriction on xs:hexBinary. - pass - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def validate_String16(self, value): - # Validate type String16, a restriction on xs:string. - pass - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def validate_HexBinary16(self, value): - # Validate type HexBinary16, a restriction on xs:hexBinary. - pass - def hasContent_(self): - if ( - self.activateTime is not None or - self.fileURI is not None or - self.lFDI is not None or - self.mfHwVer is not None or - self.mfID is not None or - self.mfModel is not None or - self.mfSerNum is not None or - self.mfVer is not None or - self.size is not None or - self.type_ is not None or - super(File, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='File', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='File') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='File', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='File'): - super(File, self).exportAttributes(outfile, level, already_processed, namespace_, name_='File') - def exportChildren(self, outfile, level, namespace_='', name_='File', fromsubclass_=False, pretty_print=True): - super(File, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.activateTime is not None: - self.activateTime.export(outfile, level, namespace_, name_='activateTime', pretty_print=pretty_print) - if self.fileURI is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sfileURI>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.fileURI).encode(ExternalEncoding), input_name='fileURI'), namespace_, eol_)) - if self.lFDI is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slFDI>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.lFDI).encode(ExternalEncoding), input_name='lFDI'), namespace_, eol_)) - if self.mfHwVer is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smfHwVer>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.mfHwVer).encode(ExternalEncoding), input_name='mfHwVer'), namespace_, eol_)) - if self.mfID is not None: - self.mfID.export(outfile, level, namespace_, name_='mfID', pretty_print=pretty_print) - if self.mfModel is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smfModel>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.mfModel).encode(ExternalEncoding), input_name='mfModel'), namespace_, eol_)) - if self.mfSerNum is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smfSerNum>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.mfSerNum).encode(ExternalEncoding), input_name='mfSerNum'), namespace_, eol_)) - if self.mfVer is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smfVer>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.mfVer).encode(ExternalEncoding), input_name='mfVer'), namespace_, eol_)) - if self.size is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssize>%s%s' % (namespace_, self.gds_format_integer(self.size, input_name='size'), namespace_, eol_)) - if self.type_ is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%stype>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.type_).encode(ExternalEncoding), input_name='type'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='File'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(File, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(File, self).exportLiteralChildren(outfile, level, name_) - if self.activateTime is not None: - showIndent(outfile, level) - outfile.write('activateTime=model_.TimeType(\n') - self.activateTime.exportLiteral(outfile, level, name_='activateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.fileURI is not None: - showIndent(outfile, level) - outfile.write('fileURI=%s,\n' % quote_python(self.fileURI).encode(ExternalEncoding)) - if self.lFDI is not None: - showIndent(outfile, level) - outfile.write('lFDI=%s,\n' % quote_python(self.lFDI).encode(ExternalEncoding)) - if self.mfHwVer is not None: - showIndent(outfile, level) - outfile.write('mfHwVer=%s,\n' % quote_python(self.mfHwVer).encode(ExternalEncoding)) - if self.mfID is not None: - showIndent(outfile, level) - outfile.write('mfID=model_.PENType(\n') - self.mfID.exportLiteral(outfile, level, name_='mfID') - showIndent(outfile, level) - outfile.write('),\n') - if self.mfModel is not None: - showIndent(outfile, level) - outfile.write('mfModel=%s,\n' % quote_python(self.mfModel).encode(ExternalEncoding)) - if self.mfSerNum is not None: - showIndent(outfile, level) - outfile.write('mfSerNum=%s,\n' % quote_python(self.mfSerNum).encode(ExternalEncoding)) - if self.mfVer is not None: - showIndent(outfile, level) - outfile.write('mfVer=%s,\n' % quote_python(self.mfVer).encode(ExternalEncoding)) - if self.size is not None: - showIndent(outfile, level) - outfile.write('size=%d,\n' % self.size) - if self.type_ is not None: - showIndent(outfile, level) - outfile.write('type_=%s,\n' % quote_python(self.type_).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(File, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'activateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.activateTime = obj_ - obj_.original_tagname_ = 'activateTime' - elif nodeName_ == 'fileURI': - fileURI_ = child_.text - fileURI_ = self.gds_validate_string(fileURI_, node, 'fileURI') - self.fileURI = fileURI_ - elif nodeName_ == 'lFDI': - lFDI_ = child_.text - lFDI_ = self.gds_validate_string(lFDI_, node, 'lFDI') - self.lFDI = lFDI_ - self.validate_HexBinary160(self.lFDI) # validate type HexBinary160 - elif nodeName_ == 'mfHwVer': - mfHwVer_ = child_.text - mfHwVer_ = self.gds_validate_string(mfHwVer_, node, 'mfHwVer') - self.mfHwVer = mfHwVer_ - self.validate_String32(self.mfHwVer) # validate type String32 - elif nodeName_ == 'mfID': - obj_ = PENType.factory() - obj_.build(child_) - self.mfID = obj_ - obj_.original_tagname_ = 'mfID' - elif nodeName_ == 'mfModel': - mfModel_ = child_.text - mfModel_ = self.gds_validate_string(mfModel_, node, 'mfModel') - self.mfModel = mfModel_ - self.validate_String32(self.mfModel) # validate type String32 - elif nodeName_ == 'mfSerNum': - mfSerNum_ = child_.text - mfSerNum_ = self.gds_validate_string(mfSerNum_, node, 'mfSerNum') - self.mfSerNum = mfSerNum_ - self.validate_String32(self.mfSerNum) # validate type String32 - elif nodeName_ == 'mfVer': - mfVer_ = child_.text - mfVer_ = self.gds_validate_string(mfVer_, node, 'mfVer') - self.mfVer = mfVer_ - self.validate_String16(self.mfVer) # validate type String16 - elif nodeName_ == 'size': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'size') - self.size = ival_ - self.validate_UInt32(self.size) # validate type UInt32 - elif nodeName_ == 'type': - type_ = child_.text - type_ = self.gds_validate_string(type_, node, 'type') - self.type_ = type_ - self.validate_HexBinary16(self.type_) # validate type HexBinary16 - super(File, self).buildChildren(child_, node, nodeName_, True) -# end class File - - -class PriceResponseCfgList(List): - """A List element to hold PriceResponseCfg objects.""" - subclass = None - superclass = List - def __init__(self, PriceResponseCfg=None): - self.original_tagname_ = None - super(PriceResponseCfgList, self).__init__() - if PriceResponseCfg is None: - self.PriceResponseCfg = [] - else: - self.PriceResponseCfg = PriceResponseCfg - def factory(*args_, **kwargs_): - if PriceResponseCfgList.subclass: - return PriceResponseCfgList.subclass(*args_, **kwargs_) - else: - return PriceResponseCfgList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_PriceResponseCfg(self): return self.PriceResponseCfg - def set_PriceResponseCfg(self, PriceResponseCfg): self.PriceResponseCfg = PriceResponseCfg - def add_PriceResponseCfg(self, value): self.PriceResponseCfg.append(value) - def insert_PriceResponseCfg_at(self, index, value): self.PriceResponseCfg.insert(index, value) - def replace_PriceResponseCfg_at(self, index, value): self.PriceResponseCfg[index] = value - def hasContent_(self): - if ( - self.PriceResponseCfg or - super(PriceResponseCfgList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PriceResponseCfgList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PriceResponseCfgList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PriceResponseCfgList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PriceResponseCfgList'): - super(PriceResponseCfgList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PriceResponseCfgList') - def exportChildren(self, outfile, level, namespace_='', name_='PriceResponseCfgList', fromsubclass_=False, pretty_print=True): - super(PriceResponseCfgList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for PriceResponseCfg_ in self.PriceResponseCfg: - PriceResponseCfg_.export(outfile, level, namespace_, name_='PriceResponseCfg', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='PriceResponseCfgList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PriceResponseCfgList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PriceResponseCfgList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('PriceResponseCfg=[\n') - level += 1 - for PriceResponseCfg_ in self.PriceResponseCfg: - showIndent(outfile, level) - outfile.write('model_.PriceResponseCfg(\n') - PriceResponseCfg_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PriceResponseCfgList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'PriceResponseCfg': - obj_ = PriceResponseCfg.factory() - obj_.build(child_) - self.PriceResponseCfg.append(obj_) - obj_.original_tagname_ = 'PriceResponseCfg' - super(PriceResponseCfgList, self).buildChildren(child_, node, nodeName_, True) -# end class PriceResponseCfgList - - -class PriceResponseCfg(Resource): - """Configuration data that specifies how price responsive devices - SHOULD respond to price changes while acting upon a given - RateComponent.""" - subclass = None - superclass = Resource - def __init__(self, consumeThreshold=None, maxReductionThreshold=None, RateComponentLink=None): - self.original_tagname_ = None - super(PriceResponseCfg, self).__init__() - self.consumeThreshold = consumeThreshold - self.maxReductionThreshold = maxReductionThreshold - self.RateComponentLink = RateComponentLink - def factory(*args_, **kwargs_): - if PriceResponseCfg.subclass: - return PriceResponseCfg.subclass(*args_, **kwargs_) - else: - return PriceResponseCfg(*args_, **kwargs_) - factory = staticmethod(factory) - def get_consumeThreshold(self): return self.consumeThreshold - def set_consumeThreshold(self, consumeThreshold): self.consumeThreshold = consumeThreshold - def get_maxReductionThreshold(self): return self.maxReductionThreshold - def set_maxReductionThreshold(self, maxReductionThreshold): self.maxReductionThreshold = maxReductionThreshold - def get_RateComponentLink(self): return self.RateComponentLink - def set_RateComponentLink(self, RateComponentLink): self.RateComponentLink = RateComponentLink - def validate_Int32(self, value): - # Validate type Int32, a restriction on xs:int. - pass - def hasContent_(self): - if ( - self.consumeThreshold is not None or - self.maxReductionThreshold is not None or - self.RateComponentLink is not None or - super(PriceResponseCfg, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PriceResponseCfg', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PriceResponseCfg') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PriceResponseCfg', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PriceResponseCfg'): - super(PriceResponseCfg, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PriceResponseCfg') - def exportChildren(self, outfile, level, namespace_='', name_='PriceResponseCfg', fromsubclass_=False, pretty_print=True): - super(PriceResponseCfg, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.consumeThreshold is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sconsumeThreshold>%s%s' % (namespace_, self.gds_format_integer(self.consumeThreshold, input_name='consumeThreshold'), namespace_, eol_)) - if self.maxReductionThreshold is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smaxReductionThreshold>%s%s' % (namespace_, self.gds_format_integer(self.maxReductionThreshold, input_name='maxReductionThreshold'), namespace_, eol_)) - if self.RateComponentLink is not None: - self.RateComponentLink.export(outfile, level, namespace_, name_='RateComponentLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='PriceResponseCfg'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PriceResponseCfg, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PriceResponseCfg, self).exportLiteralChildren(outfile, level, name_) - if self.consumeThreshold is not None: - showIndent(outfile, level) - outfile.write('consumeThreshold=%d,\n' % self.consumeThreshold) - if self.maxReductionThreshold is not None: - showIndent(outfile, level) - outfile.write('maxReductionThreshold=%d,\n' % self.maxReductionThreshold) - if self.RateComponentLink is not None: - showIndent(outfile, level) - outfile.write('RateComponentLink=model_.RateComponentLink(\n') - self.RateComponentLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PriceResponseCfg, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'consumeThreshold': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'consumeThreshold') - self.consumeThreshold = ival_ - self.validate_Int32(self.consumeThreshold) # validate type Int32 - elif nodeName_ == 'maxReductionThreshold': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'maxReductionThreshold') - self.maxReductionThreshold = ival_ - self.validate_Int32(self.maxReductionThreshold) # validate type Int32 - elif nodeName_ == 'RateComponentLink': - obj_ = RateComponentLink.factory() - obj_.build(child_) - self.RateComponentLink = obj_ - obj_.original_tagname_ = 'RateComponentLink' - super(PriceResponseCfg, self).buildChildren(child_, node, nodeName_, True) -# end class PriceResponseCfg - - -class Configuration(SubscribableResource): - """This resource contains various settings to control the operation of - the device""" - subclass = None - superclass = SubscribableResource - def __init__(self, currentLocale=None, PowerConfiguration=None, PriceResponseCfgListLink=None, TimeConfiguration=None, userDeviceName=None): - self.original_tagname_ = None - super(Configuration, self).__init__() - self.currentLocale = currentLocale - self.PowerConfiguration = PowerConfiguration - self.PriceResponseCfgListLink = PriceResponseCfgListLink - self.TimeConfiguration = TimeConfiguration - self.userDeviceName = userDeviceName - def factory(*args_, **kwargs_): - if Configuration.subclass: - return Configuration.subclass(*args_, **kwargs_) - else: - return Configuration(*args_, **kwargs_) - factory = staticmethod(factory) - def get_currentLocale(self): return self.currentLocale - def set_currentLocale(self, currentLocale): self.currentLocale = currentLocale - def get_PowerConfiguration(self): return self.PowerConfiguration - def set_PowerConfiguration(self, PowerConfiguration): self.PowerConfiguration = PowerConfiguration - def get_PriceResponseCfgListLink(self): return self.PriceResponseCfgListLink - def set_PriceResponseCfgListLink(self, PriceResponseCfgListLink): self.PriceResponseCfgListLink = PriceResponseCfgListLink - def get_TimeConfiguration(self): return self.TimeConfiguration - def set_TimeConfiguration(self, TimeConfiguration): self.TimeConfiguration = TimeConfiguration - def get_userDeviceName(self): return self.userDeviceName - def set_userDeviceName(self, userDeviceName): self.userDeviceName = userDeviceName - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.currentLocale is not None or - self.PowerConfiguration is not None or - self.PriceResponseCfgListLink is not None or - self.TimeConfiguration is not None or - self.userDeviceName is not None or - super(Configuration, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Configuration', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Configuration') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Configuration', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Configuration'): - super(Configuration, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Configuration') - def exportChildren(self, outfile, level, namespace_='', name_='Configuration', fromsubclass_=False, pretty_print=True): - super(Configuration, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.currentLocale is not None: - self.currentLocale.export(outfile, level, namespace_, name_='currentLocale', pretty_print=pretty_print) - if self.PowerConfiguration is not None: - self.PowerConfiguration.export(outfile, level, namespace_, name_='PowerConfiguration', pretty_print=pretty_print) - if self.PriceResponseCfgListLink is not None: - self.PriceResponseCfgListLink.export(outfile, level, namespace_, name_='PriceResponseCfgListLink', pretty_print=pretty_print) - if self.TimeConfiguration is not None: - self.TimeConfiguration.export(outfile, level, namespace_, name_='TimeConfiguration', pretty_print=pretty_print) - if self.userDeviceName is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%suserDeviceName>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.userDeviceName).encode(ExternalEncoding), input_name='userDeviceName'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Configuration'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Configuration, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Configuration, self).exportLiteralChildren(outfile, level, name_) - if self.currentLocale is not None: - showIndent(outfile, level) - outfile.write('currentLocale=model_.LocaleType(\n') - self.currentLocale.exportLiteral(outfile, level, name_='currentLocale') - showIndent(outfile, level) - outfile.write('),\n') - if self.PowerConfiguration is not None: - showIndent(outfile, level) - outfile.write('PowerConfiguration=model_.PowerConfiguration(\n') - self.PowerConfiguration.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.PriceResponseCfgListLink is not None: - showIndent(outfile, level) - outfile.write('PriceResponseCfgListLink=model_.PriceResponseCfgListLink(\n') - self.PriceResponseCfgListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.TimeConfiguration is not None: - showIndent(outfile, level) - outfile.write('TimeConfiguration=model_.TimeConfiguration(\n') - self.TimeConfiguration.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.userDeviceName is not None: - showIndent(outfile, level) - outfile.write('userDeviceName=%s,\n' % quote_python(self.userDeviceName).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Configuration, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'currentLocale': - obj_ = LocaleType.factory() - obj_.build(child_) - self.currentLocale = obj_ - obj_.original_tagname_ = 'currentLocale' - elif nodeName_ == 'PowerConfiguration': - obj_ = PowerConfiguration.factory() - obj_.build(child_) - self.PowerConfiguration = obj_ - obj_.original_tagname_ = 'PowerConfiguration' - elif nodeName_ == 'PriceResponseCfgListLink': - obj_ = PriceResponseCfgListLink.factory() - obj_.build(child_) - self.PriceResponseCfgListLink = obj_ - obj_.original_tagname_ = 'PriceResponseCfgListLink' - elif nodeName_ == 'TimeConfiguration': - obj_ = TimeConfiguration.factory() - obj_.build(child_) - self.TimeConfiguration = obj_ - obj_.original_tagname_ = 'TimeConfiguration' - elif nodeName_ == 'userDeviceName': - userDeviceName_ = child_.text - userDeviceName_ = self.gds_validate_string(userDeviceName_, node, 'userDeviceName') - self.userDeviceName = userDeviceName_ - self.validate_String32(self.userDeviceName) # validate type String32 - super(Configuration, self).buildChildren(child_, node, nodeName_, True) -# end class Configuration - - -class LogEventList(SubscribableList): - """A List element to hold LogEvent objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, LogEvent=None): - self.original_tagname_ = None - super(LogEventList, self).__init__() - if LogEvent is None: - self.LogEvent = [] - else: - self.LogEvent = LogEvent - def factory(*args_, **kwargs_): - if LogEventList.subclass: - return LogEventList.subclass(*args_, **kwargs_) - else: - return LogEventList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_LogEvent(self): return self.LogEvent - def set_LogEvent(self, LogEvent): self.LogEvent = LogEvent - def add_LogEvent(self, value): self.LogEvent.append(value) - def insert_LogEvent_at(self, index, value): self.LogEvent.insert(index, value) - def replace_LogEvent_at(self, index, value): self.LogEvent[index] = value - def hasContent_(self): - if ( - self.LogEvent or - super(LogEventList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LogEventList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LogEventList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LogEventList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LogEventList'): - super(LogEventList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='LogEventList') - def exportChildren(self, outfile, level, namespace_='', name_='LogEventList', fromsubclass_=False, pretty_print=True): - super(LogEventList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for LogEvent_ in self.LogEvent: - LogEvent_.export(outfile, level, namespace_, name_='LogEvent', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='LogEventList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(LogEventList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(LogEventList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('LogEvent=[\n') - level += 1 - for LogEvent_ in self.LogEvent: - showIndent(outfile, level) - outfile.write('model_.LogEvent(\n') - LogEvent_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(LogEventList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'LogEvent': - obj_ = LogEvent.factory() - obj_.build(child_) - self.LogEvent.append(obj_) - obj_.original_tagname_ = 'LogEvent' - super(LogEventList, self).buildChildren(child_, node, nodeName_, True) -# end class LogEventList - - -class LogEvent(Resource): - """A time stamped instance of a significant event detected by the - device.""" - subclass = None - superclass = Resource - def __init__(self, createdDateTime=None, extendedData=None, functionSet=None, logEventCode=None, logEventID=None, logEventPEN=None, profileID=None): - self.original_tagname_ = None - super(LogEvent, self).__init__() - self.createdDateTime = createdDateTime - self.extendedData = extendedData - self.functionSet = functionSet - self.logEventCode = logEventCode - self.logEventID = logEventID - self.logEventPEN = logEventPEN - self.profileID = profileID - def factory(*args_, **kwargs_): - if LogEvent.subclass: - return LogEvent.subclass(*args_, **kwargs_) - else: - return LogEvent(*args_, **kwargs_) - factory = staticmethod(factory) - def get_createdDateTime(self): return self.createdDateTime - def set_createdDateTime(self, createdDateTime): self.createdDateTime = createdDateTime - def get_extendedData(self): return self.extendedData - def set_extendedData(self, extendedData): self.extendedData = extendedData - def get_functionSet(self): return self.functionSet - def set_functionSet(self, functionSet): self.functionSet = functionSet - def get_logEventCode(self): return self.logEventCode - def set_logEventCode(self, logEventCode): self.logEventCode = logEventCode - def get_logEventID(self): return self.logEventID - def set_logEventID(self, logEventID): self.logEventID = logEventID - def get_logEventPEN(self): return self.logEventPEN - def set_logEventPEN(self, logEventPEN): self.logEventPEN = logEventPEN - def get_profileID(self): return self.profileID - def set_profileID(self, profileID): self.profileID = profileID - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.createdDateTime is not None or - self.extendedData is not None or - self.functionSet is not None or - self.logEventCode is not None or - self.logEventID is not None or - self.logEventPEN is not None or - self.profileID is not None or - super(LogEvent, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LogEvent', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LogEvent') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LogEvent', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LogEvent'): - super(LogEvent, self).exportAttributes(outfile, level, already_processed, namespace_, name_='LogEvent') - def exportChildren(self, outfile, level, namespace_='', name_='LogEvent', fromsubclass_=False, pretty_print=True): - super(LogEvent, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.createdDateTime is not None: - self.createdDateTime.export(outfile, level, namespace_, name_='createdDateTime', pretty_print=pretty_print) - if self.extendedData is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sextendedData>%s%s' % (namespace_, self.gds_format_integer(self.extendedData, input_name='extendedData'), namespace_, eol_)) - if self.functionSet is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sfunctionSet>%s%s' % (namespace_, self.gds_format_integer(self.functionSet, input_name='functionSet'), namespace_, eol_)) - if self.logEventCode is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slogEventCode>%s%s' % (namespace_, self.gds_format_integer(self.logEventCode, input_name='logEventCode'), namespace_, eol_)) - if self.logEventID is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slogEventID>%s%s' % (namespace_, self.gds_format_integer(self.logEventID, input_name='logEventID'), namespace_, eol_)) - if self.logEventPEN is not None: - self.logEventPEN.export(outfile, level, namespace_, name_='logEventPEN', pretty_print=pretty_print) - if self.profileID is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sprofileID>%s%s' % (namespace_, self.gds_format_integer(self.profileID, input_name='profileID'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='LogEvent'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(LogEvent, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(LogEvent, self).exportLiteralChildren(outfile, level, name_) - if self.createdDateTime is not None: - showIndent(outfile, level) - outfile.write('createdDateTime=model_.TimeType(\n') - self.createdDateTime.exportLiteral(outfile, level, name_='createdDateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.extendedData is not None: - showIndent(outfile, level) - outfile.write('extendedData=%d,\n' % self.extendedData) - if self.functionSet is not None: - showIndent(outfile, level) - outfile.write('functionSet=%d,\n' % self.functionSet) - if self.logEventCode is not None: - showIndent(outfile, level) - outfile.write('logEventCode=%d,\n' % self.logEventCode) - if self.logEventID is not None: - showIndent(outfile, level) - outfile.write('logEventID=%d,\n' % self.logEventID) - if self.logEventPEN is not None: - showIndent(outfile, level) - outfile.write('logEventPEN=model_.PENType(\n') - self.logEventPEN.exportLiteral(outfile, level, name_='logEventPEN') - showIndent(outfile, level) - outfile.write('),\n') - if self.profileID is not None: - showIndent(outfile, level) - outfile.write('profileID=%d,\n' % self.profileID) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(LogEvent, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'createdDateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.createdDateTime = obj_ - obj_.original_tagname_ = 'createdDateTime' - elif nodeName_ == 'extendedData': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'extendedData') - self.extendedData = ival_ - self.validate_UInt32(self.extendedData) # validate type UInt32 - elif nodeName_ == 'functionSet': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'functionSet') - self.functionSet = ival_ - self.validate_UInt8(self.functionSet) # validate type UInt8 - elif nodeName_ == 'logEventCode': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'logEventCode') - self.logEventCode = ival_ - self.validate_UInt8(self.logEventCode) # validate type UInt8 - elif nodeName_ == 'logEventID': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'logEventID') - self.logEventID = ival_ - self.validate_UInt16(self.logEventID) # validate type UInt16 - elif nodeName_ == 'logEventPEN': - obj_ = PENType.factory() - obj_.build(child_) - self.logEventPEN = obj_ - obj_.original_tagname_ = 'logEventPEN' - elif nodeName_ == 'profileID': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'profileID') - self.profileID = ival_ - self.validate_UInt8(self.profileID) # validate type UInt8 - super(LogEvent, self).buildChildren(child_, node, nodeName_, True) -# end class LogEvent - - -class RPLSourceRoutesList(List): - """List or RPL source routes if the hosting device is the DODAGroot""" - subclass = None - superclass = List - def __init__(self, RPLSourceRoutes=None): - self.original_tagname_ = None - super(RPLSourceRoutesList, self).__init__() - if RPLSourceRoutes is None: - self.RPLSourceRoutes = [] - else: - self.RPLSourceRoutes = RPLSourceRoutes - def factory(*args_, **kwargs_): - if RPLSourceRoutesList.subclass: - return RPLSourceRoutesList.subclass(*args_, **kwargs_) - else: - return RPLSourceRoutesList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_RPLSourceRoutes(self): return self.RPLSourceRoutes - def set_RPLSourceRoutes(self, RPLSourceRoutes): self.RPLSourceRoutes = RPLSourceRoutes - def add_RPLSourceRoutes(self, value): self.RPLSourceRoutes.append(value) - def insert_RPLSourceRoutes_at(self, index, value): self.RPLSourceRoutes.insert(index, value) - def replace_RPLSourceRoutes_at(self, index, value): self.RPLSourceRoutes[index] = value - def hasContent_(self): - if ( - self.RPLSourceRoutes or - super(RPLSourceRoutesList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RPLSourceRoutesList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RPLSourceRoutesList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RPLSourceRoutesList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RPLSourceRoutesList'): - super(RPLSourceRoutesList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RPLSourceRoutesList') - def exportChildren(self, outfile, level, namespace_='', name_='RPLSourceRoutesList', fromsubclass_=False, pretty_print=True): - super(RPLSourceRoutesList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for RPLSourceRoutes_ in self.RPLSourceRoutes: - RPLSourceRoutes_.export(outfile, level, namespace_, name_='RPLSourceRoutes', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='RPLSourceRoutesList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RPLSourceRoutesList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RPLSourceRoutesList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('RPLSourceRoutes=[\n') - level += 1 - for RPLSourceRoutes_ in self.RPLSourceRoutes: - showIndent(outfile, level) - outfile.write('model_.RPLSourceRoutes(\n') - RPLSourceRoutes_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RPLSourceRoutesList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'RPLSourceRoutes': - obj_ = RPLSourceRoutes.factory() - obj_.build(child_) - self.RPLSourceRoutes.append(obj_) - obj_.original_tagname_ = 'RPLSourceRoutes' - super(RPLSourceRoutesList, self).buildChildren(child_, node, nodeName_, True) -# end class RPLSourceRoutesList - - -class RPLSourceRoutes(Resource): - """A RPL source routes object.""" - subclass = None - superclass = Resource - def __init__(self, DestAddress=None, SourceRoute=None): - self.original_tagname_ = None - super(RPLSourceRoutes, self).__init__() - self.DestAddress = DestAddress - self.SourceRoute = SourceRoute - def factory(*args_, **kwargs_): - if RPLSourceRoutes.subclass: - return RPLSourceRoutes.subclass(*args_, **kwargs_) - else: - return RPLSourceRoutes(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DestAddress(self): return self.DestAddress - def set_DestAddress(self, DestAddress): self.DestAddress = DestAddress - def get_SourceRoute(self): return self.SourceRoute - def set_SourceRoute(self, SourceRoute): self.SourceRoute = SourceRoute - def validate_HexBinary128(self, value): - # Validate type HexBinary128, a restriction on xs:hexBinary. - pass - def hasContent_(self): - if ( - self.DestAddress is not None or - self.SourceRoute is not None or - super(RPLSourceRoutes, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RPLSourceRoutes', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RPLSourceRoutes') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RPLSourceRoutes', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RPLSourceRoutes'): - super(RPLSourceRoutes, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RPLSourceRoutes') - def exportChildren(self, outfile, level, namespace_='', name_='RPLSourceRoutes', fromsubclass_=False, pretty_print=True): - super(RPLSourceRoutes, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.DestAddress is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sDestAddress>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.DestAddress).encode(ExternalEncoding), input_name='DestAddress'), namespace_, eol_)) - if self.SourceRoute is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sSourceRoute>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.SourceRoute).encode(ExternalEncoding), input_name='SourceRoute'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='RPLSourceRoutes'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RPLSourceRoutes, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RPLSourceRoutes, self).exportLiteralChildren(outfile, level, name_) - if self.DestAddress is not None: - showIndent(outfile, level) - outfile.write('DestAddress=%s,\n' % quote_python(self.DestAddress).encode(ExternalEncoding)) - if self.SourceRoute is not None: - showIndent(outfile, level) - outfile.write('SourceRoute=%s,\n' % quote_python(self.SourceRoute).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RPLSourceRoutes, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DestAddress': - DestAddress_ = child_.text - DestAddress_ = self.gds_validate_string(DestAddress_, node, 'DestAddress') - self.DestAddress = DestAddress_ - self.validate_HexBinary128(self.DestAddress) # validate type HexBinary128 - elif nodeName_ == 'SourceRoute': - SourceRoute_ = child_.text - SourceRoute_ = self.gds_validate_string(SourceRoute_, node, 'SourceRoute') - self.SourceRoute = SourceRoute_ - self.validate_HexBinary128(self.SourceRoute) # validate type HexBinary128 - super(RPLSourceRoutes, self).buildChildren(child_, node, nodeName_, True) -# end class RPLSourceRoutes - - -class RPLInstanceList(List): - """List of RPLInstances associated with the IPinterface.""" - subclass = None - superclass = List - def __init__(self, RPLInstance=None): - self.original_tagname_ = None - super(RPLInstanceList, self).__init__() - if RPLInstance is None: - self.RPLInstance = [] - else: - self.RPLInstance = RPLInstance - def factory(*args_, **kwargs_): - if RPLInstanceList.subclass: - return RPLInstanceList.subclass(*args_, **kwargs_) - else: - return RPLInstanceList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_RPLInstance(self): return self.RPLInstance - def set_RPLInstance(self, RPLInstance): self.RPLInstance = RPLInstance - def add_RPLInstance(self, value): self.RPLInstance.append(value) - def insert_RPLInstance_at(self, index, value): self.RPLInstance.insert(index, value) - def replace_RPLInstance_at(self, index, value): self.RPLInstance[index] = value - def hasContent_(self): - if ( - self.RPLInstance or - super(RPLInstanceList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RPLInstanceList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RPLInstanceList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RPLInstanceList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RPLInstanceList'): - super(RPLInstanceList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RPLInstanceList') - def exportChildren(self, outfile, level, namespace_='', name_='RPLInstanceList', fromsubclass_=False, pretty_print=True): - super(RPLInstanceList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for RPLInstance_ in self.RPLInstance: - RPLInstance_.export(outfile, level, namespace_, name_='RPLInstance', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='RPLInstanceList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RPLInstanceList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RPLInstanceList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('RPLInstance=[\n') - level += 1 - for RPLInstance_ in self.RPLInstance: - showIndent(outfile, level) - outfile.write('model_.RPLInstance(\n') - RPLInstance_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RPLInstanceList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'RPLInstance': - obj_ = RPLInstance.factory() - obj_.build(child_) - self.RPLInstance.append(obj_) - obj_.original_tagname_ = 'RPLInstance' - super(RPLInstanceList, self).buildChildren(child_, node, nodeName_, True) -# end class RPLInstanceList - - -class RPLInstance(Resource): - """Specific RPLInstance resource. This resource may be thought of as - network status information for a specific RPL instance - associated with IPInterface.""" - subclass = None - superclass = Resource - def __init__(self, DODAGid=None, DODAGroot=None, flags=None, groundedFlag=None, MOP=None, PRF=None, rank=None, RPLInstanceID=None, RPLSourceRoutesListLink=None, versionNumber=None): - self.original_tagname_ = None - super(RPLInstance, self).__init__() - self.DODAGid = DODAGid - self.DODAGroot = DODAGroot - self.flags = flags - self.groundedFlag = groundedFlag - self.MOP = MOP - self.PRF = PRF - self.rank = rank - self.RPLInstanceID = RPLInstanceID - self.RPLSourceRoutesListLink = RPLSourceRoutesListLink - self.versionNumber = versionNumber - def factory(*args_, **kwargs_): - if RPLInstance.subclass: - return RPLInstance.subclass(*args_, **kwargs_) - else: - return RPLInstance(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DODAGid(self): return self.DODAGid - def set_DODAGid(self, DODAGid): self.DODAGid = DODAGid - def get_DODAGroot(self): return self.DODAGroot - def set_DODAGroot(self, DODAGroot): self.DODAGroot = DODAGroot - def get_flags(self): return self.flags - def set_flags(self, flags): self.flags = flags - def get_groundedFlag(self): return self.groundedFlag - def set_groundedFlag(self, groundedFlag): self.groundedFlag = groundedFlag - def get_MOP(self): return self.MOP - def set_MOP(self, MOP): self.MOP = MOP - def get_PRF(self): return self.PRF - def set_PRF(self, PRF): self.PRF = PRF - def get_rank(self): return self.rank - def set_rank(self, rank): self.rank = rank - def get_RPLInstanceID(self): return self.RPLInstanceID - def set_RPLInstanceID(self, RPLInstanceID): self.RPLInstanceID = RPLInstanceID - def get_RPLSourceRoutesListLink(self): return self.RPLSourceRoutesListLink - def set_RPLSourceRoutesListLink(self, RPLSourceRoutesListLink): self.RPLSourceRoutesListLink = RPLSourceRoutesListLink - def get_versionNumber(self): return self.versionNumber - def set_versionNumber(self, versionNumber): self.versionNumber = versionNumber - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.DODAGid is not None or - self.DODAGroot is not None or - self.flags is not None or - self.groundedFlag is not None or - self.MOP is not None or - self.PRF is not None or - self.rank is not None or - self.RPLInstanceID is not None or - self.RPLSourceRoutesListLink is not None or - self.versionNumber is not None or - super(RPLInstance, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='RPLInstance', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='RPLInstance') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='RPLInstance', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='RPLInstance'): - super(RPLInstance, self).exportAttributes(outfile, level, already_processed, namespace_, name_='RPLInstance') - def exportChildren(self, outfile, level, namespace_='', name_='RPLInstance', fromsubclass_=False, pretty_print=True): - super(RPLInstance, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.DODAGid is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sDODAGid>%s%s' % (namespace_, self.gds_format_integer(self.DODAGid, input_name='DODAGid'), namespace_, eol_)) - if self.DODAGroot is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sDODAGroot>%s%s' % (namespace_, self.gds_format_boolean(self.DODAGroot, input_name='DODAGroot'), namespace_, eol_)) - if self.flags is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sflags>%s%s' % (namespace_, self.gds_format_integer(self.flags, input_name='flags'), namespace_, eol_)) - if self.groundedFlag is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sgroundedFlag>%s%s' % (namespace_, self.gds_format_boolean(self.groundedFlag, input_name='groundedFlag'), namespace_, eol_)) - if self.MOP is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sMOP>%s%s' % (namespace_, self.gds_format_integer(self.MOP, input_name='MOP'), namespace_, eol_)) - if self.PRF is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sPRF>%s%s' % (namespace_, self.gds_format_integer(self.PRF, input_name='PRF'), namespace_, eol_)) - if self.rank is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%srank>%s%s' % (namespace_, self.gds_format_integer(self.rank, input_name='rank'), namespace_, eol_)) - if self.RPLInstanceID is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sRPLInstanceID>%s%s' % (namespace_, self.gds_format_integer(self.RPLInstanceID, input_name='RPLInstanceID'), namespace_, eol_)) - if self.RPLSourceRoutesListLink is not None: - self.RPLSourceRoutesListLink.export(outfile, level, namespace_, name_='RPLSourceRoutesListLink', pretty_print=pretty_print) - if self.versionNumber is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sversionNumber>%s%s' % (namespace_, self.gds_format_integer(self.versionNumber, input_name='versionNumber'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='RPLInstance'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(RPLInstance, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(RPLInstance, self).exportLiteralChildren(outfile, level, name_) - if self.DODAGid is not None: - showIndent(outfile, level) - outfile.write('DODAGid=%d,\n' % self.DODAGid) - if self.DODAGroot is not None: - showIndent(outfile, level) - outfile.write('DODAGroot=%s,\n' % self.DODAGroot) - if self.flags is not None: - showIndent(outfile, level) - outfile.write('flags=%d,\n' % self.flags) - if self.groundedFlag is not None: - showIndent(outfile, level) - outfile.write('groundedFlag=%s,\n' % self.groundedFlag) - if self.MOP is not None: - showIndent(outfile, level) - outfile.write('MOP=%d,\n' % self.MOP) - if self.PRF is not None: - showIndent(outfile, level) - outfile.write('PRF=%d,\n' % self.PRF) - if self.rank is not None: - showIndent(outfile, level) - outfile.write('rank=%d,\n' % self.rank) - if self.RPLInstanceID is not None: - showIndent(outfile, level) - outfile.write('RPLInstanceID=%d,\n' % self.RPLInstanceID) - if self.RPLSourceRoutesListLink is not None: - showIndent(outfile, level) - outfile.write('RPLSourceRoutesListLink=model_.RPLSourceRoutesListLink(\n') - self.RPLSourceRoutesListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.versionNumber is not None: - showIndent(outfile, level) - outfile.write('versionNumber=%d,\n' % self.versionNumber) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(RPLInstance, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DODAGid': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'DODAGid') - self.DODAGid = ival_ - self.validate_UInt8(self.DODAGid) # validate type UInt8 - elif nodeName_ == 'DODAGroot': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'DODAGroot') - self.DODAGroot = ival_ - elif nodeName_ == 'flags': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'flags') - self.flags = ival_ - self.validate_UInt8(self.flags) # validate type UInt8 - elif nodeName_ == 'groundedFlag': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'groundedFlag') - self.groundedFlag = ival_ - elif nodeName_ == 'MOP': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'MOP') - self.MOP = ival_ - self.validate_UInt8(self.MOP) # validate type UInt8 - elif nodeName_ == 'PRF': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'PRF') - self.PRF = ival_ - self.validate_UInt8(self.PRF) # validate type UInt8 - elif nodeName_ == 'rank': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'rank') - self.rank = ival_ - self.validate_UInt16(self.rank) # validate type UInt16 - elif nodeName_ == 'RPLInstanceID': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'RPLInstanceID') - self.RPLInstanceID = ival_ - self.validate_UInt8(self.RPLInstanceID) # validate type UInt8 - elif nodeName_ == 'RPLSourceRoutesListLink': - obj_ = RPLSourceRoutesListLink.factory() - obj_.build(child_) - self.RPLSourceRoutesListLink = obj_ - obj_.original_tagname_ = 'RPLSourceRoutesListLink' - elif nodeName_ == 'versionNumber': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'versionNumber') - self.versionNumber = ival_ - self.validate_UInt8(self.versionNumber) # validate type UInt8 - super(RPLInstance, self).buildChildren(child_, node, nodeName_, True) -# end class RPLInstance - - -class NeighborList(List): - """List of 15.4 neighbors.""" - subclass = None - superclass = List - def __init__(self, Neighbor=None): - self.original_tagname_ = None - super(NeighborList, self).__init__() - if Neighbor is None: - self.Neighbor = [] - else: - self.Neighbor = Neighbor - def factory(*args_, **kwargs_): - if NeighborList.subclass: - return NeighborList.subclass(*args_, **kwargs_) - else: - return NeighborList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Neighbor(self): return self.Neighbor - def set_Neighbor(self, Neighbor): self.Neighbor = Neighbor - def add_Neighbor(self, value): self.Neighbor.append(value) - def insert_Neighbor_at(self, index, value): self.Neighbor.insert(index, value) - def replace_Neighbor_at(self, index, value): self.Neighbor[index] = value - def hasContent_(self): - if ( - self.Neighbor or - super(NeighborList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='NeighborList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='NeighborList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='NeighborList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='NeighborList'): - super(NeighborList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='NeighborList') - def exportChildren(self, outfile, level, namespace_='', name_='NeighborList', fromsubclass_=False, pretty_print=True): - super(NeighborList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for Neighbor_ in self.Neighbor: - Neighbor_.export(outfile, level, namespace_, name_='Neighbor', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='NeighborList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(NeighborList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(NeighborList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('Neighbor=[\n') - level += 1 - for Neighbor_ in self.Neighbor: - showIndent(outfile, level) - outfile.write('model_.Neighbor(\n') - Neighbor_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(NeighborList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Neighbor': - obj_ = Neighbor.factory() - obj_.build(child_) - self.Neighbor.append(obj_) - obj_.original_tagname_ = 'Neighbor' - super(NeighborList, self).buildChildren(child_, node, nodeName_, True) -# end class NeighborList - - -class Neighbor(Resource): - """Contains 802.15.4 link layer specific attributes.""" - subclass = None - superclass = Resource - def __init__(self, isChild=None, linkQuality=None, shortAddress=None): - self.original_tagname_ = None - super(Neighbor, self).__init__() - self.isChild = isChild - self.linkQuality = linkQuality - self.shortAddress = shortAddress - def factory(*args_, **kwargs_): - if Neighbor.subclass: - return Neighbor.subclass(*args_, **kwargs_) - else: - return Neighbor(*args_, **kwargs_) - factory = staticmethod(factory) - def get_isChild(self): return self.isChild - def set_isChild(self, isChild): self.isChild = isChild - def get_linkQuality(self): return self.linkQuality - def set_linkQuality(self, linkQuality): self.linkQuality = linkQuality - def get_shortAddress(self): return self.shortAddress - def set_shortAddress(self, shortAddress): self.shortAddress = shortAddress - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.isChild is not None or - self.linkQuality is not None or - self.shortAddress is not None or - super(Neighbor, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Neighbor', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Neighbor') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Neighbor', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Neighbor'): - super(Neighbor, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Neighbor') - def exportChildren(self, outfile, level, namespace_='', name_='Neighbor', fromsubclass_=False, pretty_print=True): - super(Neighbor, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.isChild is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sisChild>%s%s' % (namespace_, self.gds_format_boolean(self.isChild, input_name='isChild'), namespace_, eol_)) - if self.linkQuality is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slinkQuality>%s%s' % (namespace_, self.gds_format_integer(self.linkQuality, input_name='linkQuality'), namespace_, eol_)) - if self.shortAddress is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sshortAddress>%s%s' % (namespace_, self.gds_format_integer(self.shortAddress, input_name='shortAddress'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Neighbor'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Neighbor, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Neighbor, self).exportLiteralChildren(outfile, level, name_) - if self.isChild is not None: - showIndent(outfile, level) - outfile.write('isChild=%s,\n' % self.isChild) - if self.linkQuality is not None: - showIndent(outfile, level) - outfile.write('linkQuality=%d,\n' % self.linkQuality) - if self.shortAddress is not None: - showIndent(outfile, level) - outfile.write('shortAddress=%d,\n' % self.shortAddress) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Neighbor, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'isChild': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'isChild') - self.isChild = ival_ - elif nodeName_ == 'linkQuality': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'linkQuality') - self.linkQuality = ival_ - self.validate_UInt8(self.linkQuality) # validate type UInt8 - elif nodeName_ == 'shortAddress': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'shortAddress') - self.shortAddress = ival_ - self.validate_UInt16(self.shortAddress) # validate type UInt16 - super(Neighbor, self).buildChildren(child_, node, nodeName_, True) -# end class Neighbor - - -class LLInterfaceList(List): - """List of LLInterface instances.""" - subclass = None - superclass = List - def __init__(self, LLInterface=None): - self.original_tagname_ = None - super(LLInterfaceList, self).__init__() - if LLInterface is None: - self.LLInterface = [] - else: - self.LLInterface = LLInterface - def factory(*args_, **kwargs_): - if LLInterfaceList.subclass: - return LLInterfaceList.subclass(*args_, **kwargs_) - else: - return LLInterfaceList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_LLInterface(self): return self.LLInterface - def set_LLInterface(self, LLInterface): self.LLInterface = LLInterface - def add_LLInterface(self, value): self.LLInterface.append(value) - def insert_LLInterface_at(self, index, value): self.LLInterface.insert(index, value) - def replace_LLInterface_at(self, index, value): self.LLInterface[index] = value - def hasContent_(self): - if ( - self.LLInterface or - super(LLInterfaceList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LLInterfaceList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LLInterfaceList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LLInterfaceList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LLInterfaceList'): - super(LLInterfaceList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='LLInterfaceList') - def exportChildren(self, outfile, level, namespace_='', name_='LLInterfaceList', fromsubclass_=False, pretty_print=True): - super(LLInterfaceList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for LLInterface_ in self.LLInterface: - LLInterface_.export(outfile, level, namespace_, name_='LLInterface', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='LLInterfaceList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(LLInterfaceList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(LLInterfaceList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('LLInterface=[\n') - level += 1 - for LLInterface_ in self.LLInterface: - showIndent(outfile, level) - outfile.write('model_.LLInterface(\n') - LLInterface_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(LLInterfaceList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'LLInterface': - obj_ = LLInterface.factory() - obj_.build(child_) - self.LLInterface.append(obj_) - obj_.original_tagname_ = 'LLInterface' - super(LLInterfaceList, self).buildChildren(child_, node, nodeName_, True) -# end class LLInterfaceList - - -class LLInterface(Resource): - """A link-layer interface object.""" - subclass = None - superclass = Resource - def __init__(self, CRCerrors=None, EUI64=None, IEEE_802_15_4=None, linkLayerType=None, LLAckNotRx=None, LLCSMAFail=None, LLFramesDropRx=None, LLFramesDropTx=None, LLFramesRx=None, LLFramesTx=None, LLMediaAccessFail=None, LLOctetsRx=None, LLOctetsTx=None, LLRetryCount=None, LLSecurityErrorRx=None, loWPAN=None): - self.original_tagname_ = None - super(LLInterface, self).__init__() - self.CRCerrors = CRCerrors - self.EUI64 = EUI64 - self.IEEE_802_15_4 = IEEE_802_15_4 - self.linkLayerType = linkLayerType - self.LLAckNotRx = LLAckNotRx - self.LLCSMAFail = LLCSMAFail - self.LLFramesDropRx = LLFramesDropRx - self.LLFramesDropTx = LLFramesDropTx - self.LLFramesRx = LLFramesRx - self.LLFramesTx = LLFramesTx - self.LLMediaAccessFail = LLMediaAccessFail - self.LLOctetsRx = LLOctetsRx - self.LLOctetsTx = LLOctetsTx - self.LLRetryCount = LLRetryCount - self.LLSecurityErrorRx = LLSecurityErrorRx - self.loWPAN = loWPAN - def factory(*args_, **kwargs_): - if LLInterface.subclass: - return LLInterface.subclass(*args_, **kwargs_) - else: - return LLInterface(*args_, **kwargs_) - factory = staticmethod(factory) - def get_CRCerrors(self): return self.CRCerrors - def set_CRCerrors(self, CRCerrors): self.CRCerrors = CRCerrors - def get_EUI64(self): return self.EUI64 - def set_EUI64(self, EUI64): self.EUI64 = EUI64 - def get_IEEE_802_15_4(self): return self.IEEE_802_15_4 - def set_IEEE_802_15_4(self, IEEE_802_15_4): self.IEEE_802_15_4 = IEEE_802_15_4 - def get_linkLayerType(self): return self.linkLayerType - def set_linkLayerType(self, linkLayerType): self.linkLayerType = linkLayerType - def get_LLAckNotRx(self): return self.LLAckNotRx - def set_LLAckNotRx(self, LLAckNotRx): self.LLAckNotRx = LLAckNotRx - def get_LLCSMAFail(self): return self.LLCSMAFail - def set_LLCSMAFail(self, LLCSMAFail): self.LLCSMAFail = LLCSMAFail - def get_LLFramesDropRx(self): return self.LLFramesDropRx - def set_LLFramesDropRx(self, LLFramesDropRx): self.LLFramesDropRx = LLFramesDropRx - def get_LLFramesDropTx(self): return self.LLFramesDropTx - def set_LLFramesDropTx(self, LLFramesDropTx): self.LLFramesDropTx = LLFramesDropTx - def get_LLFramesRx(self): return self.LLFramesRx - def set_LLFramesRx(self, LLFramesRx): self.LLFramesRx = LLFramesRx - def get_LLFramesTx(self): return self.LLFramesTx - def set_LLFramesTx(self, LLFramesTx): self.LLFramesTx = LLFramesTx - def get_LLMediaAccessFail(self): return self.LLMediaAccessFail - def set_LLMediaAccessFail(self, LLMediaAccessFail): self.LLMediaAccessFail = LLMediaAccessFail - def get_LLOctetsRx(self): return self.LLOctetsRx - def set_LLOctetsRx(self, LLOctetsRx): self.LLOctetsRx = LLOctetsRx - def get_LLOctetsTx(self): return self.LLOctetsTx - def set_LLOctetsTx(self, LLOctetsTx): self.LLOctetsTx = LLOctetsTx - def get_LLRetryCount(self): return self.LLRetryCount - def set_LLRetryCount(self, LLRetryCount): self.LLRetryCount = LLRetryCount - def get_LLSecurityErrorRx(self): return self.LLSecurityErrorRx - def set_LLSecurityErrorRx(self, LLSecurityErrorRx): self.LLSecurityErrorRx = LLSecurityErrorRx - def get_loWPAN(self): return self.loWPAN - def set_loWPAN(self, loWPAN): self.loWPAN = loWPAN - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def validate_HexBinary64(self, value): - # Validate type HexBinary64, a restriction on xs:hexBinary. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.CRCerrors is not None or - self.EUI64 is not None or - self.IEEE_802_15_4 is not None or - self.linkLayerType is not None or - self.LLAckNotRx is not None or - self.LLCSMAFail is not None or - self.LLFramesDropRx is not None or - self.LLFramesDropTx is not None or - self.LLFramesRx is not None or - self.LLFramesTx is not None or - self.LLMediaAccessFail is not None or - self.LLOctetsRx is not None or - self.LLOctetsTx is not None or - self.LLRetryCount is not None or - self.LLSecurityErrorRx is not None or - self.loWPAN is not None or - super(LLInterface, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='LLInterface', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='LLInterface') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='LLInterface', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='LLInterface'): - super(LLInterface, self).exportAttributes(outfile, level, already_processed, namespace_, name_='LLInterface') - def exportChildren(self, outfile, level, namespace_='', name_='LLInterface', fromsubclass_=False, pretty_print=True): - super(LLInterface, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.CRCerrors is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sCRCerrors>%s%s' % (namespace_, self.gds_format_integer(self.CRCerrors, input_name='CRCerrors'), namespace_, eol_)) - if self.EUI64 is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sEUI64>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.EUI64).encode(ExternalEncoding), input_name='EUI64'), namespace_, eol_)) - if self.IEEE_802_15_4 is not None: - self.IEEE_802_15_4.export(outfile, level, namespace_, name_='IEEE_802_15_4', pretty_print=pretty_print) - if self.linkLayerType is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slinkLayerType>%s%s' % (namespace_, self.gds_format_integer(self.linkLayerType, input_name='linkLayerType'), namespace_, eol_)) - if self.LLAckNotRx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLAckNotRx>%s%s' % (namespace_, self.gds_format_integer(self.LLAckNotRx, input_name='LLAckNotRx'), namespace_, eol_)) - if self.LLCSMAFail is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLCSMAFail>%s%s' % (namespace_, self.gds_format_integer(self.LLCSMAFail, input_name='LLCSMAFail'), namespace_, eol_)) - if self.LLFramesDropRx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLFramesDropRx>%s%s' % (namespace_, self.gds_format_integer(self.LLFramesDropRx, input_name='LLFramesDropRx'), namespace_, eol_)) - if self.LLFramesDropTx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLFramesDropTx>%s%s' % (namespace_, self.gds_format_integer(self.LLFramesDropTx, input_name='LLFramesDropTx'), namespace_, eol_)) - if self.LLFramesRx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLFramesRx>%s%s' % (namespace_, self.gds_format_integer(self.LLFramesRx, input_name='LLFramesRx'), namespace_, eol_)) - if self.LLFramesTx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLFramesTx>%s%s' % (namespace_, self.gds_format_integer(self.LLFramesTx, input_name='LLFramesTx'), namespace_, eol_)) - if self.LLMediaAccessFail is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLMediaAccessFail>%s%s' % (namespace_, self.gds_format_integer(self.LLMediaAccessFail, input_name='LLMediaAccessFail'), namespace_, eol_)) - if self.LLOctetsRx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLOctetsRx>%s%s' % (namespace_, self.gds_format_integer(self.LLOctetsRx, input_name='LLOctetsRx'), namespace_, eol_)) - if self.LLOctetsTx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLOctetsTx>%s%s' % (namespace_, self.gds_format_integer(self.LLOctetsTx, input_name='LLOctetsTx'), namespace_, eol_)) - if self.LLRetryCount is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLRetryCount>%s%s' % (namespace_, self.gds_format_integer(self.LLRetryCount, input_name='LLRetryCount'), namespace_, eol_)) - if self.LLSecurityErrorRx is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sLLSecurityErrorRx>%s%s' % (namespace_, self.gds_format_integer(self.LLSecurityErrorRx, input_name='LLSecurityErrorRx'), namespace_, eol_)) - if self.loWPAN is not None: - self.loWPAN.export(outfile, level, namespace_, name_='loWPAN', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='LLInterface'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(LLInterface, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(LLInterface, self).exportLiteralChildren(outfile, level, name_) - if self.CRCerrors is not None: - showIndent(outfile, level) - outfile.write('CRCerrors=%d,\n' % self.CRCerrors) - if self.EUI64 is not None: - showIndent(outfile, level) - outfile.write('EUI64=%s,\n' % quote_python(self.EUI64).encode(ExternalEncoding)) - if self.IEEE_802_15_4 is not None: - showIndent(outfile, level) - outfile.write('IEEE_802_15_4=model_.IEEE_802_15_4(\n') - self.IEEE_802_15_4.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.linkLayerType is not None: - showIndent(outfile, level) - outfile.write('linkLayerType=%d,\n' % self.linkLayerType) - if self.LLAckNotRx is not None: - showIndent(outfile, level) - outfile.write('LLAckNotRx=%d,\n' % self.LLAckNotRx) - if self.LLCSMAFail is not None: - showIndent(outfile, level) - outfile.write('LLCSMAFail=%d,\n' % self.LLCSMAFail) - if self.LLFramesDropRx is not None: - showIndent(outfile, level) - outfile.write('LLFramesDropRx=%d,\n' % self.LLFramesDropRx) - if self.LLFramesDropTx is not None: - showIndent(outfile, level) - outfile.write('LLFramesDropTx=%d,\n' % self.LLFramesDropTx) - if self.LLFramesRx is not None: - showIndent(outfile, level) - outfile.write('LLFramesRx=%d,\n' % self.LLFramesRx) - if self.LLFramesTx is not None: - showIndent(outfile, level) - outfile.write('LLFramesTx=%d,\n' % self.LLFramesTx) - if self.LLMediaAccessFail is not None: - showIndent(outfile, level) - outfile.write('LLMediaAccessFail=%d,\n' % self.LLMediaAccessFail) - if self.LLOctetsRx is not None: - showIndent(outfile, level) - outfile.write('LLOctetsRx=%d,\n' % self.LLOctetsRx) - if self.LLOctetsTx is not None: - showIndent(outfile, level) - outfile.write('LLOctetsTx=%d,\n' % self.LLOctetsTx) - if self.LLRetryCount is not None: - showIndent(outfile, level) - outfile.write('LLRetryCount=%d,\n' % self.LLRetryCount) - if self.LLSecurityErrorRx is not None: - showIndent(outfile, level) - outfile.write('LLSecurityErrorRx=%d,\n' % self.LLSecurityErrorRx) - if self.loWPAN is not None: - showIndent(outfile, level) - outfile.write('loWPAN=model_.loWPAN(\n') - self.loWPAN.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(LLInterface, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'CRCerrors': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'CRCerrors') - self.CRCerrors = ival_ - self.validate_UInt32(self.CRCerrors) # validate type UInt32 - elif nodeName_ == 'EUI64': - EUI64_ = child_.text - EUI64_ = self.gds_validate_string(EUI64_, node, 'EUI64') - self.EUI64 = EUI64_ - self.validate_HexBinary64(self.EUI64) # validate type HexBinary64 - elif nodeName_ == 'IEEE_802_15_4': - obj_ = IEEE_802_15_4.factory() - obj_.build(child_) - self.IEEE_802_15_4 = obj_ - obj_.original_tagname_ = 'IEEE_802_15_4' - elif nodeName_ == 'linkLayerType': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'linkLayerType') - self.linkLayerType = ival_ - self.validate_UInt8(self.linkLayerType) # validate type UInt8 - elif nodeName_ == 'LLAckNotRx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLAckNotRx') - self.LLAckNotRx = ival_ - self.validate_UInt32(self.LLAckNotRx) # validate type UInt32 - elif nodeName_ == 'LLCSMAFail': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLCSMAFail') - self.LLCSMAFail = ival_ - self.validate_UInt32(self.LLCSMAFail) # validate type UInt32 - elif nodeName_ == 'LLFramesDropRx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLFramesDropRx') - self.LLFramesDropRx = ival_ - self.validate_UInt32(self.LLFramesDropRx) # validate type UInt32 - elif nodeName_ == 'LLFramesDropTx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLFramesDropTx') - self.LLFramesDropTx = ival_ - self.validate_UInt32(self.LLFramesDropTx) # validate type UInt32 - elif nodeName_ == 'LLFramesRx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLFramesRx') - self.LLFramesRx = ival_ - self.validate_UInt32(self.LLFramesRx) # validate type UInt32 - elif nodeName_ == 'LLFramesTx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLFramesTx') - self.LLFramesTx = ival_ - self.validate_UInt32(self.LLFramesTx) # validate type UInt32 - elif nodeName_ == 'LLMediaAccessFail': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLMediaAccessFail') - self.LLMediaAccessFail = ival_ - self.validate_UInt32(self.LLMediaAccessFail) # validate type UInt32 - elif nodeName_ == 'LLOctetsRx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLOctetsRx') - self.LLOctetsRx = ival_ - self.validate_UInt32(self.LLOctetsRx) # validate type UInt32 - elif nodeName_ == 'LLOctetsTx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLOctetsTx') - self.LLOctetsTx = ival_ - self.validate_UInt32(self.LLOctetsTx) # validate type UInt32 - elif nodeName_ == 'LLRetryCount': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLRetryCount') - self.LLRetryCount = ival_ - self.validate_UInt32(self.LLRetryCount) # validate type UInt32 - elif nodeName_ == 'LLSecurityErrorRx': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'LLSecurityErrorRx') - self.LLSecurityErrorRx = ival_ - self.validate_UInt32(self.LLSecurityErrorRx) # validate type UInt32 - elif nodeName_ == 'loWPAN': - obj_ = loWPAN.factory() - obj_.build(child_) - self.loWPAN = obj_ - obj_.original_tagname_ = 'loWPAN' - super(LLInterface, self).buildChildren(child_, node, nodeName_, True) -# end class LLInterface - - -class IPInterfaceList(List): - """List of IPInterface instances.""" - subclass = None - superclass = List - def __init__(self, IPInterface=None): - self.original_tagname_ = None - super(IPInterfaceList, self).__init__() - if IPInterface is None: - self.IPInterface = [] - else: - self.IPInterface = IPInterface - def factory(*args_, **kwargs_): - if IPInterfaceList.subclass: - return IPInterfaceList.subclass(*args_, **kwargs_) - else: - return IPInterfaceList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_IPInterface(self): return self.IPInterface - def set_IPInterface(self, IPInterface): self.IPInterface = IPInterface - def add_IPInterface(self, value): self.IPInterface.append(value) - def insert_IPInterface_at(self, index, value): self.IPInterface.insert(index, value) - def replace_IPInterface_at(self, index, value): self.IPInterface[index] = value - def hasContent_(self): - if ( - self.IPInterface or - super(IPInterfaceList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='IPInterfaceList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='IPInterfaceList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='IPInterfaceList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='IPInterfaceList'): - super(IPInterfaceList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='IPInterfaceList') - def exportChildren(self, outfile, level, namespace_='', name_='IPInterfaceList', fromsubclass_=False, pretty_print=True): - super(IPInterfaceList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for IPInterface_ in self.IPInterface: - IPInterface_.export(outfile, level, namespace_, name_='IPInterface', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='IPInterfaceList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(IPInterfaceList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(IPInterfaceList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('IPInterface=[\n') - level += 1 - for IPInterface_ in self.IPInterface: - showIndent(outfile, level) - outfile.write('model_.IPInterface(\n') - IPInterface_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(IPInterfaceList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'IPInterface': - obj_ = IPInterface.factory() - obj_.build(child_) - self.IPInterface.append(obj_) - obj_.original_tagname_ = 'IPInterface' - super(IPInterfaceList, self).buildChildren(child_, node, nodeName_, True) -# end class IPInterfaceList - - -class IPInterface(Resource): - """Specific IPInterface resource. This resource may be thought of as - network status information for a specific network (IP) layer - interface.""" - subclass = None - superclass = Resource - def __init__(self, ifDescr=None, ifHighSpeed=None, ifInBroadcastPkts=None, ifIndex=None, ifInDiscards=None, ifInErrors=None, ifInMulticastPkts=None, ifInOctets=None, ifInUcastPkts=None, ifInUnknownProtos=None, ifMtu=None, ifName=None, ifOperStatus=None, ifOutBroadcastPkts=None, ifOutDiscards=None, ifOutErrors=None, ifOutMulticastPkts=None, ifOutOctets=None, ifOutUcastPkts=None, ifPromiscuousMode=None, ifSpeed=None, ifType=None, IPAddrListLink=None, lastResetTime=None, lastUpdatedTime=None, LLInterfaceListLink=None): - self.original_tagname_ = None - super(IPInterface, self).__init__() - self.ifDescr = ifDescr - self.ifHighSpeed = ifHighSpeed - self.ifInBroadcastPkts = ifInBroadcastPkts - self.ifIndex = ifIndex - self.ifInDiscards = ifInDiscards - self.ifInErrors = ifInErrors - self.ifInMulticastPkts = ifInMulticastPkts - self.ifInOctets = ifInOctets - self.ifInUcastPkts = ifInUcastPkts - self.ifInUnknownProtos = ifInUnknownProtos - self.ifMtu = ifMtu - self.ifName = ifName - self.ifOperStatus = ifOperStatus - self.ifOutBroadcastPkts = ifOutBroadcastPkts - self.ifOutDiscards = ifOutDiscards - self.ifOutErrors = ifOutErrors - self.ifOutMulticastPkts = ifOutMulticastPkts - self.ifOutOctets = ifOutOctets - self.ifOutUcastPkts = ifOutUcastPkts - self.ifPromiscuousMode = ifPromiscuousMode - self.ifSpeed = ifSpeed - self.ifType = ifType - self.IPAddrListLink = IPAddrListLink - self.lastResetTime = lastResetTime - self.lastUpdatedTime = lastUpdatedTime - self.LLInterfaceListLink = LLInterfaceListLink - def factory(*args_, **kwargs_): - if IPInterface.subclass: - return IPInterface.subclass(*args_, **kwargs_) - else: - return IPInterface(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ifDescr(self): return self.ifDescr - def set_ifDescr(self, ifDescr): self.ifDescr = ifDescr - def get_ifHighSpeed(self): return self.ifHighSpeed - def set_ifHighSpeed(self, ifHighSpeed): self.ifHighSpeed = ifHighSpeed - def get_ifInBroadcastPkts(self): return self.ifInBroadcastPkts - def set_ifInBroadcastPkts(self, ifInBroadcastPkts): self.ifInBroadcastPkts = ifInBroadcastPkts - def get_ifIndex(self): return self.ifIndex - def set_ifIndex(self, ifIndex): self.ifIndex = ifIndex - def get_ifInDiscards(self): return self.ifInDiscards - def set_ifInDiscards(self, ifInDiscards): self.ifInDiscards = ifInDiscards - def get_ifInErrors(self): return self.ifInErrors - def set_ifInErrors(self, ifInErrors): self.ifInErrors = ifInErrors - def get_ifInMulticastPkts(self): return self.ifInMulticastPkts - def set_ifInMulticastPkts(self, ifInMulticastPkts): self.ifInMulticastPkts = ifInMulticastPkts - def get_ifInOctets(self): return self.ifInOctets - def set_ifInOctets(self, ifInOctets): self.ifInOctets = ifInOctets - def get_ifInUcastPkts(self): return self.ifInUcastPkts - def set_ifInUcastPkts(self, ifInUcastPkts): self.ifInUcastPkts = ifInUcastPkts - def get_ifInUnknownProtos(self): return self.ifInUnknownProtos - def set_ifInUnknownProtos(self, ifInUnknownProtos): self.ifInUnknownProtos = ifInUnknownProtos - def get_ifMtu(self): return self.ifMtu - def set_ifMtu(self, ifMtu): self.ifMtu = ifMtu - def get_ifName(self): return self.ifName - def set_ifName(self, ifName): self.ifName = ifName - def get_ifOperStatus(self): return self.ifOperStatus - def set_ifOperStatus(self, ifOperStatus): self.ifOperStatus = ifOperStatus - def get_ifOutBroadcastPkts(self): return self.ifOutBroadcastPkts - def set_ifOutBroadcastPkts(self, ifOutBroadcastPkts): self.ifOutBroadcastPkts = ifOutBroadcastPkts - def get_ifOutDiscards(self): return self.ifOutDiscards - def set_ifOutDiscards(self, ifOutDiscards): self.ifOutDiscards = ifOutDiscards - def get_ifOutErrors(self): return self.ifOutErrors - def set_ifOutErrors(self, ifOutErrors): self.ifOutErrors = ifOutErrors - def get_ifOutMulticastPkts(self): return self.ifOutMulticastPkts - def set_ifOutMulticastPkts(self, ifOutMulticastPkts): self.ifOutMulticastPkts = ifOutMulticastPkts - def get_ifOutOctets(self): return self.ifOutOctets - def set_ifOutOctets(self, ifOutOctets): self.ifOutOctets = ifOutOctets - def get_ifOutUcastPkts(self): return self.ifOutUcastPkts - def set_ifOutUcastPkts(self, ifOutUcastPkts): self.ifOutUcastPkts = ifOutUcastPkts - def get_ifPromiscuousMode(self): return self.ifPromiscuousMode - def set_ifPromiscuousMode(self, ifPromiscuousMode): self.ifPromiscuousMode = ifPromiscuousMode - def get_ifSpeed(self): return self.ifSpeed - def set_ifSpeed(self, ifSpeed): self.ifSpeed = ifSpeed - def get_ifType(self): return self.ifType - def set_ifType(self, ifType): self.ifType = ifType - def get_IPAddrListLink(self): return self.IPAddrListLink - def set_IPAddrListLink(self, IPAddrListLink): self.IPAddrListLink = IPAddrListLink - def get_lastResetTime(self): return self.lastResetTime - def set_lastResetTime(self, lastResetTime): self.lastResetTime = lastResetTime - def get_lastUpdatedTime(self): return self.lastUpdatedTime - def set_lastUpdatedTime(self, lastUpdatedTime): self.lastUpdatedTime = lastUpdatedTime - def get_LLInterfaceListLink(self): return self.LLInterfaceListLink - def set_LLInterfaceListLink(self, LLInterfaceListLink): self.LLInterfaceListLink = LLInterfaceListLink - def validate_String192(self, value): - # Validate type String192, a restriction on xs:string. - pass - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def validate_String16(self, value): - # Validate type String16, a restriction on xs:string. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def validate_Int64(self, value): - # Validate type Int64, a restriction on xs:long. - pass - def hasContent_(self): - if ( - self.ifDescr is not None or - self.ifHighSpeed is not None or - self.ifInBroadcastPkts is not None or - self.ifIndex is not None or - self.ifInDiscards is not None or - self.ifInErrors is not None or - self.ifInMulticastPkts is not None or - self.ifInOctets is not None or - self.ifInUcastPkts is not None or - self.ifInUnknownProtos is not None or - self.ifMtu is not None or - self.ifName is not None or - self.ifOperStatus is not None or - self.ifOutBroadcastPkts is not None or - self.ifOutDiscards is not None or - self.ifOutErrors is not None or - self.ifOutMulticastPkts is not None or - self.ifOutOctets is not None or - self.ifOutUcastPkts is not None or - self.ifPromiscuousMode is not None or - self.ifSpeed is not None or - self.ifType is not None or - self.IPAddrListLink is not None or - self.lastResetTime is not None or - self.lastUpdatedTime is not None or - self.LLInterfaceListLink is not None or - super(IPInterface, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='IPInterface', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='IPInterface') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='IPInterface', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='IPInterface'): - super(IPInterface, self).exportAttributes(outfile, level, already_processed, namespace_, name_='IPInterface') - def exportChildren(self, outfile, level, namespace_='', name_='IPInterface', fromsubclass_=False, pretty_print=True): - super(IPInterface, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ifDescr is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifDescr>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.ifDescr).encode(ExternalEncoding), input_name='ifDescr'), namespace_, eol_)) - if self.ifHighSpeed is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifHighSpeed>%s%s' % (namespace_, self.gds_format_integer(self.ifHighSpeed, input_name='ifHighSpeed'), namespace_, eol_)) - if self.ifInBroadcastPkts is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifInBroadcastPkts>%s%s' % (namespace_, self.gds_format_integer(self.ifInBroadcastPkts, input_name='ifInBroadcastPkts'), namespace_, eol_)) - if self.ifIndex is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifIndex>%s%s' % (namespace_, self.gds_format_integer(self.ifIndex, input_name='ifIndex'), namespace_, eol_)) - if self.ifInDiscards is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifInDiscards>%s%s' % (namespace_, self.gds_format_integer(self.ifInDiscards, input_name='ifInDiscards'), namespace_, eol_)) - if self.ifInErrors is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifInErrors>%s%s' % (namespace_, self.gds_format_integer(self.ifInErrors, input_name='ifInErrors'), namespace_, eol_)) - if self.ifInMulticastPkts is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifInMulticastPkts>%s%s' % (namespace_, self.gds_format_integer(self.ifInMulticastPkts, input_name='ifInMulticastPkts'), namespace_, eol_)) - if self.ifInOctets is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifInOctets>%s%s' % (namespace_, self.gds_format_integer(self.ifInOctets, input_name='ifInOctets'), namespace_, eol_)) - if self.ifInUcastPkts is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifInUcastPkts>%s%s' % (namespace_, self.gds_format_integer(self.ifInUcastPkts, input_name='ifInUcastPkts'), namespace_, eol_)) - if self.ifInUnknownProtos is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifInUnknownProtos>%s%s' % (namespace_, self.gds_format_integer(self.ifInUnknownProtos, input_name='ifInUnknownProtos'), namespace_, eol_)) - if self.ifMtu is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifMtu>%s%s' % (namespace_, self.gds_format_integer(self.ifMtu, input_name='ifMtu'), namespace_, eol_)) - if self.ifName is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifName>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.ifName).encode(ExternalEncoding), input_name='ifName'), namespace_, eol_)) - if self.ifOperStatus is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifOperStatus>%s%s' % (namespace_, self.gds_format_integer(self.ifOperStatus, input_name='ifOperStatus'), namespace_, eol_)) - if self.ifOutBroadcastPkts is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifOutBroadcastPkts>%s%s' % (namespace_, self.gds_format_integer(self.ifOutBroadcastPkts, input_name='ifOutBroadcastPkts'), namespace_, eol_)) - if self.ifOutDiscards is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifOutDiscards>%s%s' % (namespace_, self.gds_format_integer(self.ifOutDiscards, input_name='ifOutDiscards'), namespace_, eol_)) - if self.ifOutErrors is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifOutErrors>%s%s' % (namespace_, self.gds_format_integer(self.ifOutErrors, input_name='ifOutErrors'), namespace_, eol_)) - if self.ifOutMulticastPkts is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifOutMulticastPkts>%s%s' % (namespace_, self.gds_format_integer(self.ifOutMulticastPkts, input_name='ifOutMulticastPkts'), namespace_, eol_)) - if self.ifOutOctets is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifOutOctets>%s%s' % (namespace_, self.gds_format_integer(self.ifOutOctets, input_name='ifOutOctets'), namespace_, eol_)) - if self.ifOutUcastPkts is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifOutUcastPkts>%s%s' % (namespace_, self.gds_format_integer(self.ifOutUcastPkts, input_name='ifOutUcastPkts'), namespace_, eol_)) - if self.ifPromiscuousMode is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifPromiscuousMode>%s%s' % (namespace_, self.gds_format_boolean(self.ifPromiscuousMode, input_name='ifPromiscuousMode'), namespace_, eol_)) - if self.ifSpeed is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifSpeed>%s%s' % (namespace_, self.gds_format_integer(self.ifSpeed, input_name='ifSpeed'), namespace_, eol_)) - if self.ifType is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sifType>%s%s' % (namespace_, self.gds_format_integer(self.ifType, input_name='ifType'), namespace_, eol_)) - if self.IPAddrListLink is not None: - self.IPAddrListLink.export(outfile, level, namespace_, name_='IPAddrListLink', pretty_print=pretty_print) - if self.lastResetTime is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slastResetTime>%s%s' % (namespace_, self.gds_format_integer(self.lastResetTime, input_name='lastResetTime'), namespace_, eol_)) - if self.lastUpdatedTime is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slastUpdatedTime>%s%s' % (namespace_, self.gds_format_integer(self.lastUpdatedTime, input_name='lastUpdatedTime'), namespace_, eol_)) - if self.LLInterfaceListLink is not None: - self.LLInterfaceListLink.export(outfile, level, namespace_, name_='LLInterfaceListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='IPInterface'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(IPInterface, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(IPInterface, self).exportLiteralChildren(outfile, level, name_) - if self.ifDescr is not None: - showIndent(outfile, level) - outfile.write('ifDescr=%s,\n' % quote_python(self.ifDescr).encode(ExternalEncoding)) - if self.ifHighSpeed is not None: - showIndent(outfile, level) - outfile.write('ifHighSpeed=%d,\n' % self.ifHighSpeed) - if self.ifInBroadcastPkts is not None: - showIndent(outfile, level) - outfile.write('ifInBroadcastPkts=%d,\n' % self.ifInBroadcastPkts) - if self.ifIndex is not None: - showIndent(outfile, level) - outfile.write('ifIndex=%d,\n' % self.ifIndex) - if self.ifInDiscards is not None: - showIndent(outfile, level) - outfile.write('ifInDiscards=%d,\n' % self.ifInDiscards) - if self.ifInErrors is not None: - showIndent(outfile, level) - outfile.write('ifInErrors=%d,\n' % self.ifInErrors) - if self.ifInMulticastPkts is not None: - showIndent(outfile, level) - outfile.write('ifInMulticastPkts=%d,\n' % self.ifInMulticastPkts) - if self.ifInOctets is not None: - showIndent(outfile, level) - outfile.write('ifInOctets=%d,\n' % self.ifInOctets) - if self.ifInUcastPkts is not None: - showIndent(outfile, level) - outfile.write('ifInUcastPkts=%d,\n' % self.ifInUcastPkts) - if self.ifInUnknownProtos is not None: - showIndent(outfile, level) - outfile.write('ifInUnknownProtos=%d,\n' % self.ifInUnknownProtos) - if self.ifMtu is not None: - showIndent(outfile, level) - outfile.write('ifMtu=%d,\n' % self.ifMtu) - if self.ifName is not None: - showIndent(outfile, level) - outfile.write('ifName=%s,\n' % quote_python(self.ifName).encode(ExternalEncoding)) - if self.ifOperStatus is not None: - showIndent(outfile, level) - outfile.write('ifOperStatus=%d,\n' % self.ifOperStatus) - if self.ifOutBroadcastPkts is not None: - showIndent(outfile, level) - outfile.write('ifOutBroadcastPkts=%d,\n' % self.ifOutBroadcastPkts) - if self.ifOutDiscards is not None: - showIndent(outfile, level) - outfile.write('ifOutDiscards=%d,\n' % self.ifOutDiscards) - if self.ifOutErrors is not None: - showIndent(outfile, level) - outfile.write('ifOutErrors=%d,\n' % self.ifOutErrors) - if self.ifOutMulticastPkts is not None: - showIndent(outfile, level) - outfile.write('ifOutMulticastPkts=%d,\n' % self.ifOutMulticastPkts) - if self.ifOutOctets is not None: - showIndent(outfile, level) - outfile.write('ifOutOctets=%d,\n' % self.ifOutOctets) - if self.ifOutUcastPkts is not None: - showIndent(outfile, level) - outfile.write('ifOutUcastPkts=%d,\n' % self.ifOutUcastPkts) - if self.ifPromiscuousMode is not None: - showIndent(outfile, level) - outfile.write('ifPromiscuousMode=%s,\n' % self.ifPromiscuousMode) - if self.ifSpeed is not None: - showIndent(outfile, level) - outfile.write('ifSpeed=%d,\n' % self.ifSpeed) - if self.ifType is not None: - showIndent(outfile, level) - outfile.write('ifType=%d,\n' % self.ifType) - if self.IPAddrListLink is not None: - showIndent(outfile, level) - outfile.write('IPAddrListLink=model_.IPAddrListLink(\n') - self.IPAddrListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.lastResetTime is not None: - showIndent(outfile, level) - outfile.write('lastResetTime=%d,\n' % self.lastResetTime) - if self.lastUpdatedTime is not None: - showIndent(outfile, level) - outfile.write('lastUpdatedTime=%d,\n' % self.lastUpdatedTime) - if self.LLInterfaceListLink is not None: - showIndent(outfile, level) - outfile.write('LLInterfaceListLink=model_.LLInterfaceListLink(\n') - self.LLInterfaceListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(IPInterface, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ifDescr': - ifDescr_ = child_.text - ifDescr_ = self.gds_validate_string(ifDescr_, node, 'ifDescr') - self.ifDescr = ifDescr_ - self.validate_String192(self.ifDescr) # validate type String192 - elif nodeName_ == 'ifHighSpeed': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifHighSpeed') - self.ifHighSpeed = ival_ - self.validate_UInt32(self.ifHighSpeed) # validate type UInt32 - elif nodeName_ == 'ifInBroadcastPkts': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifInBroadcastPkts') - self.ifInBroadcastPkts = ival_ - self.validate_UInt32(self.ifInBroadcastPkts) # validate type UInt32 - elif nodeName_ == 'ifIndex': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifIndex') - self.ifIndex = ival_ - self.validate_UInt32(self.ifIndex) # validate type UInt32 - elif nodeName_ == 'ifInDiscards': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifInDiscards') - self.ifInDiscards = ival_ - self.validate_UInt32(self.ifInDiscards) # validate type UInt32 - elif nodeName_ == 'ifInErrors': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifInErrors') - self.ifInErrors = ival_ - self.validate_UInt32(self.ifInErrors) # validate type UInt32 - elif nodeName_ == 'ifInMulticastPkts': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifInMulticastPkts') - self.ifInMulticastPkts = ival_ - self.validate_UInt32(self.ifInMulticastPkts) # validate type UInt32 - elif nodeName_ == 'ifInOctets': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifInOctets') - self.ifInOctets = ival_ - self.validate_UInt32(self.ifInOctets) # validate type UInt32 - elif nodeName_ == 'ifInUcastPkts': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifInUcastPkts') - self.ifInUcastPkts = ival_ - self.validate_UInt32(self.ifInUcastPkts) # validate type UInt32 - elif nodeName_ == 'ifInUnknownProtos': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifInUnknownProtos') - self.ifInUnknownProtos = ival_ - self.validate_UInt32(self.ifInUnknownProtos) # validate type UInt32 - elif nodeName_ == 'ifMtu': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifMtu') - self.ifMtu = ival_ - self.validate_UInt32(self.ifMtu) # validate type UInt32 - elif nodeName_ == 'ifName': - ifName_ = child_.text - ifName_ = self.gds_validate_string(ifName_, node, 'ifName') - self.ifName = ifName_ - self.validate_String16(self.ifName) # validate type String16 - elif nodeName_ == 'ifOperStatus': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifOperStatus') - self.ifOperStatus = ival_ - self.validate_UInt8(self.ifOperStatus) # validate type UInt8 - elif nodeName_ == 'ifOutBroadcastPkts': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifOutBroadcastPkts') - self.ifOutBroadcastPkts = ival_ - self.validate_UInt32(self.ifOutBroadcastPkts) # validate type UInt32 - elif nodeName_ == 'ifOutDiscards': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifOutDiscards') - self.ifOutDiscards = ival_ - self.validate_UInt32(self.ifOutDiscards) # validate type UInt32 - elif nodeName_ == 'ifOutErrors': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifOutErrors') - self.ifOutErrors = ival_ - self.validate_UInt32(self.ifOutErrors) # validate type UInt32 - elif nodeName_ == 'ifOutMulticastPkts': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifOutMulticastPkts') - self.ifOutMulticastPkts = ival_ - self.validate_UInt32(self.ifOutMulticastPkts) # validate type UInt32 - elif nodeName_ == 'ifOutOctets': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifOutOctets') - self.ifOutOctets = ival_ - self.validate_UInt32(self.ifOutOctets) # validate type UInt32 - elif nodeName_ == 'ifOutUcastPkts': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifOutUcastPkts') - self.ifOutUcastPkts = ival_ - self.validate_UInt32(self.ifOutUcastPkts) # validate type UInt32 - elif nodeName_ == 'ifPromiscuousMode': - sval_ = child_.text - if sval_ in ('true', '1'): - ival_ = True - elif sval_ in ('false', '0'): - ival_ = False - else: - raise_parse_error(child_, 'requires boolean') - ival_ = self.gds_validate_boolean(ival_, node, 'ifPromiscuousMode') - self.ifPromiscuousMode = ival_ - elif nodeName_ == 'ifSpeed': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifSpeed') - self.ifSpeed = ival_ - self.validate_UInt32(self.ifSpeed) # validate type UInt32 - elif nodeName_ == 'ifType': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'ifType') - self.ifType = ival_ - self.validate_UInt16(self.ifType) # validate type UInt16 - elif nodeName_ == 'IPAddrListLink': - obj_ = IPAddrListLink.factory() - obj_.build(child_) - self.IPAddrListLink = obj_ - obj_.original_tagname_ = 'IPAddrListLink' - elif nodeName_ == 'lastResetTime': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'lastResetTime') - self.lastResetTime = ival_ - self.validate_Int64(self.lastResetTime) # validate type Int64 - elif nodeName_ == 'lastUpdatedTime': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'lastUpdatedTime') - self.lastUpdatedTime = ival_ - self.validate_Int64(self.lastUpdatedTime) # validate type Int64 - elif nodeName_ == 'LLInterfaceListLink': - obj_ = LLInterfaceListLink.factory() - obj_.build(child_) - self.LLInterfaceListLink = obj_ - obj_.original_tagname_ = 'LLInterfaceListLink' - super(IPInterface, self).buildChildren(child_, node, nodeName_, True) -# end class IPInterface - - -class IPAddrList(List): - """List of IPAddr instances.""" - subclass = None - superclass = List - def __init__(self, IPAddr=None): - self.original_tagname_ = None - super(IPAddrList, self).__init__() - if IPAddr is None: - self.IPAddr = [] - else: - self.IPAddr = IPAddr - def factory(*args_, **kwargs_): - if IPAddrList.subclass: - return IPAddrList.subclass(*args_, **kwargs_) - else: - return IPAddrList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_IPAddr(self): return self.IPAddr - def set_IPAddr(self, IPAddr): self.IPAddr = IPAddr - def add_IPAddr(self, value): self.IPAddr.append(value) - def insert_IPAddr_at(self, index, value): self.IPAddr.insert(index, value) - def replace_IPAddr_at(self, index, value): self.IPAddr[index] = value - def hasContent_(self): - if ( - self.IPAddr or - super(IPAddrList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='IPAddrList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='IPAddrList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='IPAddrList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='IPAddrList'): - super(IPAddrList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='IPAddrList') - def exportChildren(self, outfile, level, namespace_='', name_='IPAddrList', fromsubclass_=False, pretty_print=True): - super(IPAddrList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for IPAddr_ in self.IPAddr: - IPAddr_.export(outfile, level, namespace_, name_='IPAddr', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='IPAddrList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(IPAddrList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(IPAddrList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('IPAddr=[\n') - level += 1 - for IPAddr_ in self.IPAddr: - showIndent(outfile, level) - outfile.write('model_.IPAddr(\n') - IPAddr_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(IPAddrList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'IPAddr': - obj_ = IPAddr.factory() - obj_.build(child_) - self.IPAddr.append(obj_) - obj_.original_tagname_ = 'IPAddr' - super(IPAddrList, self).buildChildren(child_, node, nodeName_, True) -# end class IPAddrList - - -class IPAddr(Resource): - """An Internet Protocol address object.""" - subclass = None - superclass = Resource - def __init__(self, address=None, RPLInstanceListLink=None): - self.original_tagname_ = None - super(IPAddr, self).__init__() - self.address = address - self.RPLInstanceListLink = RPLInstanceListLink - def factory(*args_, **kwargs_): - if IPAddr.subclass: - return IPAddr.subclass(*args_, **kwargs_) - else: - return IPAddr(*args_, **kwargs_) - factory = staticmethod(factory) - def get_address(self): return self.address - def set_address(self, address): self.address = address - def get_RPLInstanceListLink(self): return self.RPLInstanceListLink - def set_RPLInstanceListLink(self, RPLInstanceListLink): self.RPLInstanceListLink = RPLInstanceListLink - def validate_HexBinary128(self, value): - # Validate type HexBinary128, a restriction on xs:hexBinary. - pass - def hasContent_(self): - if ( - self.address is not None or - self.RPLInstanceListLink is not None or - super(IPAddr, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='IPAddr', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='IPAddr') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='IPAddr', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='IPAddr'): - super(IPAddr, self).exportAttributes(outfile, level, already_processed, namespace_, name_='IPAddr') - def exportChildren(self, outfile, level, namespace_='', name_='IPAddr', fromsubclass_=False, pretty_print=True): - super(IPAddr, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.address is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%saddress>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.address).encode(ExternalEncoding), input_name='address'), namespace_, eol_)) - if self.RPLInstanceListLink is not None: - self.RPLInstanceListLink.export(outfile, level, namespace_, name_='RPLInstanceListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='IPAddr'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(IPAddr, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(IPAddr, self).exportLiteralChildren(outfile, level, name_) - if self.address is not None: - showIndent(outfile, level) - outfile.write('address=%s,\n' % quote_python(self.address).encode(ExternalEncoding)) - if self.RPLInstanceListLink is not None: - showIndent(outfile, level) - outfile.write('RPLInstanceListLink=model_.RPLInstanceListLink(\n') - self.RPLInstanceListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(IPAddr, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'address': - address_ = child_.text - address_ = self.gds_validate_string(address_, node, 'address') - self.address = address_ - self.validate_HexBinary128(self.address) # validate type HexBinary128 - elif nodeName_ == 'RPLInstanceListLink': - obj_ = RPLInstanceListLink.factory() - obj_.build(child_) - self.RPLInstanceListLink = obj_ - obj_.original_tagname_ = 'RPLInstanceListLink' - super(IPAddr, self).buildChildren(child_, node, nodeName_, True) -# end class IPAddr - - -class PowerStatus(Resource): - """Contains the status of the device's power sources""" - subclass = None - superclass = Resource - def __init__(self, batteryStatus=None, changedTime=None, currentPowerSource=None, estimatedChargeRemaining=None, estimatedTimeRemaining=None, PEVInfo=None, sessionTimeOnBattery=None, totalTimeOnBattery=None): - self.original_tagname_ = None - super(PowerStatus, self).__init__() - self.batteryStatus = batteryStatus - self.changedTime = changedTime - self.currentPowerSource = currentPowerSource - self.estimatedChargeRemaining = estimatedChargeRemaining - self.estimatedTimeRemaining = estimatedTimeRemaining - self.PEVInfo = PEVInfo - self.sessionTimeOnBattery = sessionTimeOnBattery - self.totalTimeOnBattery = totalTimeOnBattery - def factory(*args_, **kwargs_): - if PowerStatus.subclass: - return PowerStatus.subclass(*args_, **kwargs_) - else: - return PowerStatus(*args_, **kwargs_) - factory = staticmethod(factory) - def get_batteryStatus(self): return self.batteryStatus - def set_batteryStatus(self, batteryStatus): self.batteryStatus = batteryStatus - def get_changedTime(self): return self.changedTime - def set_changedTime(self, changedTime): self.changedTime = changedTime - def get_currentPowerSource(self): return self.currentPowerSource - def set_currentPowerSource(self, currentPowerSource): self.currentPowerSource = currentPowerSource - def get_estimatedChargeRemaining(self): return self.estimatedChargeRemaining - def set_estimatedChargeRemaining(self, estimatedChargeRemaining): self.estimatedChargeRemaining = estimatedChargeRemaining - def get_estimatedTimeRemaining(self): return self.estimatedTimeRemaining - def set_estimatedTimeRemaining(self, estimatedTimeRemaining): self.estimatedTimeRemaining = estimatedTimeRemaining - def get_PEVInfo(self): return self.PEVInfo - def set_PEVInfo(self, PEVInfo): self.PEVInfo = PEVInfo - def get_sessionTimeOnBattery(self): return self.sessionTimeOnBattery - def set_sessionTimeOnBattery(self, sessionTimeOnBattery): self.sessionTimeOnBattery = sessionTimeOnBattery - def get_totalTimeOnBattery(self): return self.totalTimeOnBattery - def set_totalTimeOnBattery(self, totalTimeOnBattery): self.totalTimeOnBattery = totalTimeOnBattery - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def hasContent_(self): - if ( - self.batteryStatus is not None or - self.changedTime is not None or - self.currentPowerSource is not None or - self.estimatedChargeRemaining is not None or - self.estimatedTimeRemaining is not None or - self.PEVInfo is not None or - self.sessionTimeOnBattery is not None or - self.totalTimeOnBattery is not None or - super(PowerStatus, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PowerStatus', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PowerStatus') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PowerStatus', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PowerStatus'): - super(PowerStatus, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PowerStatus') - def exportChildren(self, outfile, level, namespace_='', name_='PowerStatus', fromsubclass_=False, pretty_print=True): - super(PowerStatus, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.batteryStatus is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sbatteryStatus>%s%s' % (namespace_, self.gds_format_integer(self.batteryStatus, input_name='batteryStatus'), namespace_, eol_)) - if self.changedTime is not None: - self.changedTime.export(outfile, level, namespace_, name_='changedTime', pretty_print=pretty_print) - if self.currentPowerSource is not None: - self.currentPowerSource.export(outfile, level, namespace_, name_='currentPowerSource', pretty_print=pretty_print) - if self.estimatedChargeRemaining is not None: - self.estimatedChargeRemaining.export(outfile, level, namespace_, name_='estimatedChargeRemaining', pretty_print=pretty_print) - if self.estimatedTimeRemaining is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sestimatedTimeRemaining>%s%s' % (namespace_, self.gds_format_integer(self.estimatedTimeRemaining, input_name='estimatedTimeRemaining'), namespace_, eol_)) - if self.PEVInfo is not None: - self.PEVInfo.export(outfile, level, namespace_, name_='PEVInfo', pretty_print=pretty_print) - if self.sessionTimeOnBattery is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssessionTimeOnBattery>%s%s' % (namespace_, self.gds_format_integer(self.sessionTimeOnBattery, input_name='sessionTimeOnBattery'), namespace_, eol_)) - if self.totalTimeOnBattery is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%stotalTimeOnBattery>%s%s' % (namespace_, self.gds_format_integer(self.totalTimeOnBattery, input_name='totalTimeOnBattery'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='PowerStatus'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PowerStatus, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PowerStatus, self).exportLiteralChildren(outfile, level, name_) - if self.batteryStatus is not None: - showIndent(outfile, level) - outfile.write('batteryStatus=%d,\n' % self.batteryStatus) - if self.changedTime is not None: - showIndent(outfile, level) - outfile.write('changedTime=model_.TimeType(\n') - self.changedTime.exportLiteral(outfile, level, name_='changedTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.currentPowerSource is not None: - showIndent(outfile, level) - outfile.write('currentPowerSource=model_.PowerSourceType(\n') - self.currentPowerSource.exportLiteral(outfile, level, name_='currentPowerSource') - showIndent(outfile, level) - outfile.write('),\n') - if self.estimatedChargeRemaining is not None: - showIndent(outfile, level) - outfile.write('estimatedChargeRemaining=model_.PerCent(\n') - self.estimatedChargeRemaining.exportLiteral(outfile, level, name_='estimatedChargeRemaining') - showIndent(outfile, level) - outfile.write('),\n') - if self.estimatedTimeRemaining is not None: - showIndent(outfile, level) - outfile.write('estimatedTimeRemaining=%d,\n' % self.estimatedTimeRemaining) - if self.PEVInfo is not None: - showIndent(outfile, level) - outfile.write('PEVInfo=model_.PEVInfo(\n') - self.PEVInfo.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.sessionTimeOnBattery is not None: - showIndent(outfile, level) - outfile.write('sessionTimeOnBattery=%d,\n' % self.sessionTimeOnBattery) - if self.totalTimeOnBattery is not None: - showIndent(outfile, level) - outfile.write('totalTimeOnBattery=%d,\n' % self.totalTimeOnBattery) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PowerStatus, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'batteryStatus': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'batteryStatus') - self.batteryStatus = ival_ - self.validate_UInt8(self.batteryStatus) # validate type UInt8 - elif nodeName_ == 'changedTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.changedTime = obj_ - obj_.original_tagname_ = 'changedTime' - elif nodeName_ == 'currentPowerSource': - obj_ = PowerSourceType.factory() - obj_.build(child_) - self.currentPowerSource = obj_ - obj_.original_tagname_ = 'currentPowerSource' - elif nodeName_ == 'estimatedChargeRemaining': - obj_ = PerCent.factory() - obj_.build(child_) - self.estimatedChargeRemaining = obj_ - obj_.original_tagname_ = 'estimatedChargeRemaining' - elif nodeName_ == 'estimatedTimeRemaining': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'estimatedTimeRemaining') - self.estimatedTimeRemaining = ival_ - self.validate_UInt32(self.estimatedTimeRemaining) # validate type UInt32 - elif nodeName_ == 'PEVInfo': - obj_ = PEVInfo.factory() - obj_.build(child_) - self.PEVInfo = obj_ - obj_.original_tagname_ = 'PEVInfo' - elif nodeName_ == 'sessionTimeOnBattery': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'sessionTimeOnBattery') - self.sessionTimeOnBattery = ival_ - self.validate_UInt32(self.sessionTimeOnBattery) # validate type UInt32 - elif nodeName_ == 'totalTimeOnBattery': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'totalTimeOnBattery') - self.totalTimeOnBattery = ival_ - self.validate_UInt32(self.totalTimeOnBattery) # validate type UInt32 - super(PowerStatus, self).buildChildren(child_, node, nodeName_, True) -# end class PowerStatus - - -class SupportedLocaleList(List): - """A List element to hold SupportedLocale objects.""" - subclass = None - superclass = List - def __init__(self, SupportedLocale=None): - self.original_tagname_ = None - super(SupportedLocaleList, self).__init__() - if SupportedLocale is None: - self.SupportedLocale = [] - else: - self.SupportedLocale = SupportedLocale - def factory(*args_, **kwargs_): - if SupportedLocaleList.subclass: - return SupportedLocaleList.subclass(*args_, **kwargs_) - else: - return SupportedLocaleList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_SupportedLocale(self): return self.SupportedLocale - def set_SupportedLocale(self, SupportedLocale): self.SupportedLocale = SupportedLocale - def add_SupportedLocale(self, value): self.SupportedLocale.append(value) - def insert_SupportedLocale_at(self, index, value): self.SupportedLocale.insert(index, value) - def replace_SupportedLocale_at(self, index, value): self.SupportedLocale[index] = value - def hasContent_(self): - if ( - self.SupportedLocale or - super(SupportedLocaleList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SupportedLocaleList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SupportedLocaleList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SupportedLocaleList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SupportedLocaleList'): - super(SupportedLocaleList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SupportedLocaleList') - def exportChildren(self, outfile, level, namespace_='', name_='SupportedLocaleList', fromsubclass_=False, pretty_print=True): - super(SupportedLocaleList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for SupportedLocale_ in self.SupportedLocale: - SupportedLocale_.export(outfile, level, namespace_, name_='SupportedLocale', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='SupportedLocaleList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SupportedLocaleList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SupportedLocaleList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('SupportedLocale=[\n') - level += 1 - for SupportedLocale_ in self.SupportedLocale: - showIndent(outfile, level) - outfile.write('model_.SupportedLocale(\n') - SupportedLocale_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SupportedLocaleList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'SupportedLocale': - obj_ = SupportedLocale.factory() - obj_.build(child_) - self.SupportedLocale.append(obj_) - obj_.original_tagname_ = 'SupportedLocale' - super(SupportedLocaleList, self).buildChildren(child_, node, nodeName_, True) -# end class SupportedLocaleList - - -class SupportedLocale(Resource): - """Specifies a locale that is supported""" - subclass = None - superclass = Resource - def __init__(self, locale=None): - self.original_tagname_ = None - super(SupportedLocale, self).__init__() - self.locale = locale - def factory(*args_, **kwargs_): - if SupportedLocale.subclass: - return SupportedLocale.subclass(*args_, **kwargs_) - else: - return SupportedLocale(*args_, **kwargs_) - factory = staticmethod(factory) - def get_locale(self): return self.locale - def set_locale(self, locale): self.locale = locale - def hasContent_(self): - if ( - self.locale is not None or - super(SupportedLocale, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SupportedLocale', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SupportedLocale') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SupportedLocale', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SupportedLocale'): - super(SupportedLocale, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SupportedLocale') - def exportChildren(self, outfile, level, namespace_='', name_='SupportedLocale', fromsubclass_=False, pretty_print=True): - super(SupportedLocale, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.locale is not None: - self.locale.export(outfile, level, namespace_, name_='locale', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='SupportedLocale'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SupportedLocale, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SupportedLocale, self).exportLiteralChildren(outfile, level, name_) - if self.locale is not None: - showIndent(outfile, level) - outfile.write('locale=model_.LocaleType(\n') - self.locale.exportLiteral(outfile, level, name_='locale') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SupportedLocale, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'locale': - obj_ = LocaleType.factory() - obj_.build(child_) - self.locale = obj_ - obj_.original_tagname_ = 'locale' - super(SupportedLocale, self).buildChildren(child_, node, nodeName_, True) -# end class SupportedLocale - - -class DeviceInformation(Resource): - """Contains identification and other information about the device that - changes very infrequently, typically only when updates are - applied, if ever.""" - subclass = None - superclass = Resource - def __init__(self, DRLCCapabilities=None, functionsImplemented=None, lFDI=None, mfDate=None, mfHwVer=None, mfID=None, mfInfo=None, mfModel=None, mfSerNum=None, primaryPower=None, secondaryPower=None, SupportedLocaleListLink=None, swActTime=None, swVer=None): - self.original_tagname_ = None - super(DeviceInformation, self).__init__() - self.DRLCCapabilities = DRLCCapabilities - self.functionsImplemented = functionsImplemented - self.lFDI = lFDI - self.mfDate = mfDate - self.mfHwVer = mfHwVer - self.mfID = mfID - self.mfInfo = mfInfo - self.mfModel = mfModel - self.mfSerNum = mfSerNum - self.primaryPower = primaryPower - self.secondaryPower = secondaryPower - self.SupportedLocaleListLink = SupportedLocaleListLink - self.swActTime = swActTime - self.swVer = swVer - def factory(*args_, **kwargs_): - if DeviceInformation.subclass: - return DeviceInformation.subclass(*args_, **kwargs_) - else: - return DeviceInformation(*args_, **kwargs_) - factory = staticmethod(factory) - def get_DRLCCapabilities(self): return self.DRLCCapabilities - def set_DRLCCapabilities(self, DRLCCapabilities): self.DRLCCapabilities = DRLCCapabilities - def get_functionsImplemented(self): return self.functionsImplemented - def set_functionsImplemented(self, functionsImplemented): self.functionsImplemented = functionsImplemented - def get_lFDI(self): return self.lFDI - def set_lFDI(self, lFDI): self.lFDI = lFDI - def get_mfDate(self): return self.mfDate - def set_mfDate(self, mfDate): self.mfDate = mfDate - def get_mfHwVer(self): return self.mfHwVer - def set_mfHwVer(self, mfHwVer): self.mfHwVer = mfHwVer - def get_mfID(self): return self.mfID - def set_mfID(self, mfID): self.mfID = mfID - def get_mfInfo(self): return self.mfInfo - def set_mfInfo(self, mfInfo): self.mfInfo = mfInfo - def get_mfModel(self): return self.mfModel - def set_mfModel(self, mfModel): self.mfModel = mfModel - def get_mfSerNum(self): return self.mfSerNum - def set_mfSerNum(self, mfSerNum): self.mfSerNum = mfSerNum - def get_primaryPower(self): return self.primaryPower - def set_primaryPower(self, primaryPower): self.primaryPower = primaryPower - def get_secondaryPower(self): return self.secondaryPower - def set_secondaryPower(self, secondaryPower): self.secondaryPower = secondaryPower - def get_SupportedLocaleListLink(self): return self.SupportedLocaleListLink - def set_SupportedLocaleListLink(self, SupportedLocaleListLink): self.SupportedLocaleListLink = SupportedLocaleListLink - def get_swActTime(self): return self.swActTime - def set_swActTime(self, swActTime): self.swActTime = swActTime - def get_swVer(self): return self.swVer - def set_swVer(self, swVer): self.swVer = swVer - def validate_HexBinary64(self, value): - # Validate type HexBinary64, a restriction on xs:hexBinary. - pass - def validate_HexBinary160(self, value): - # Validate type HexBinary160, a restriction on xs:hexBinary. - pass - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def hasContent_(self): - if ( - self.DRLCCapabilities is not None or - self.functionsImplemented is not None or - self.lFDI is not None or - self.mfDate is not None or - self.mfHwVer is not None or - self.mfID is not None or - self.mfInfo is not None or - self.mfModel is not None or - self.mfSerNum is not None or - self.primaryPower is not None or - self.secondaryPower is not None or - self.SupportedLocaleListLink is not None or - self.swActTime is not None or - self.swVer is not None or - super(DeviceInformation, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DeviceInformation', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceInformation') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DeviceInformation', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DeviceInformation'): - super(DeviceInformation, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceInformation') - def exportChildren(self, outfile, level, namespace_='', name_='DeviceInformation', fromsubclass_=False, pretty_print=True): - super(DeviceInformation, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.DRLCCapabilities is not None: - self.DRLCCapabilities.export(outfile, level, namespace_, name_='DRLCCapabilities', pretty_print=pretty_print) - if self.functionsImplemented is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sfunctionsImplemented>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.functionsImplemented).encode(ExternalEncoding), input_name='functionsImplemented'), namespace_, eol_)) - if self.lFDI is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slFDI>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.lFDI).encode(ExternalEncoding), input_name='lFDI'), namespace_, eol_)) - if self.mfDate is not None: - self.mfDate.export(outfile, level, namespace_, name_='mfDate', pretty_print=pretty_print) - if self.mfHwVer is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smfHwVer>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.mfHwVer).encode(ExternalEncoding), input_name='mfHwVer'), namespace_, eol_)) - if self.mfID is not None: - self.mfID.export(outfile, level, namespace_, name_='mfID', pretty_print=pretty_print) - if self.mfInfo is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smfInfo>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.mfInfo).encode(ExternalEncoding), input_name='mfInfo'), namespace_, eol_)) - if self.mfModel is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smfModel>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.mfModel).encode(ExternalEncoding), input_name='mfModel'), namespace_, eol_)) - if self.mfSerNum is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%smfSerNum>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.mfSerNum).encode(ExternalEncoding), input_name='mfSerNum'), namespace_, eol_)) - if self.primaryPower is not None: - self.primaryPower.export(outfile, level, namespace_, name_='primaryPower', pretty_print=pretty_print) - if self.secondaryPower is not None: - self.secondaryPower.export(outfile, level, namespace_, name_='secondaryPower', pretty_print=pretty_print) - if self.SupportedLocaleListLink is not None: - self.SupportedLocaleListLink.export(outfile, level, namespace_, name_='SupportedLocaleListLink', pretty_print=pretty_print) - if self.swActTime is not None: - self.swActTime.export(outfile, level, namespace_, name_='swActTime', pretty_print=pretty_print) - if self.swVer is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sswVer>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.swVer).encode(ExternalEncoding), input_name='swVer'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='DeviceInformation'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DeviceInformation, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DeviceInformation, self).exportLiteralChildren(outfile, level, name_) - if self.DRLCCapabilities is not None: - showIndent(outfile, level) - outfile.write('DRLCCapabilities=model_.DRLCCapabilities(\n') - self.DRLCCapabilities.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.functionsImplemented is not None: - showIndent(outfile, level) - outfile.write('functionsImplemented=%s,\n' % quote_python(self.functionsImplemented).encode(ExternalEncoding)) - if self.lFDI is not None: - showIndent(outfile, level) - outfile.write('lFDI=%s,\n' % quote_python(self.lFDI).encode(ExternalEncoding)) - if self.mfDate is not None: - showIndent(outfile, level) - outfile.write('mfDate=model_.TimeType(\n') - self.mfDate.exportLiteral(outfile, level, name_='mfDate') - showIndent(outfile, level) - outfile.write('),\n') - if self.mfHwVer is not None: - showIndent(outfile, level) - outfile.write('mfHwVer=%s,\n' % quote_python(self.mfHwVer).encode(ExternalEncoding)) - if self.mfID is not None: - showIndent(outfile, level) - outfile.write('mfID=model_.PENType(\n') - self.mfID.exportLiteral(outfile, level, name_='mfID') - showIndent(outfile, level) - outfile.write('),\n') - if self.mfInfo is not None: - showIndent(outfile, level) - outfile.write('mfInfo=%s,\n' % quote_python(self.mfInfo).encode(ExternalEncoding)) - if self.mfModel is not None: - showIndent(outfile, level) - outfile.write('mfModel=%s,\n' % quote_python(self.mfModel).encode(ExternalEncoding)) - if self.mfSerNum is not None: - showIndent(outfile, level) - outfile.write('mfSerNum=%s,\n' % quote_python(self.mfSerNum).encode(ExternalEncoding)) - if self.primaryPower is not None: - showIndent(outfile, level) - outfile.write('primaryPower=model_.PowerSourceType(\n') - self.primaryPower.exportLiteral(outfile, level, name_='primaryPower') - showIndent(outfile, level) - outfile.write('),\n') - if self.secondaryPower is not None: - showIndent(outfile, level) - outfile.write('secondaryPower=model_.PowerSourceType(\n') - self.secondaryPower.exportLiteral(outfile, level, name_='secondaryPower') - showIndent(outfile, level) - outfile.write('),\n') - if self.SupportedLocaleListLink is not None: - showIndent(outfile, level) - outfile.write('SupportedLocaleListLink=model_.SupportedLocaleListLink(\n') - self.SupportedLocaleListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.swActTime is not None: - showIndent(outfile, level) - outfile.write('swActTime=model_.TimeType(\n') - self.swActTime.exportLiteral(outfile, level, name_='swActTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.swVer is not None: - showIndent(outfile, level) - outfile.write('swVer=%s,\n' % quote_python(self.swVer).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DeviceInformation, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'DRLCCapabilities': - obj_ = DRLCCapabilities.factory() - obj_.build(child_) - self.DRLCCapabilities = obj_ - obj_.original_tagname_ = 'DRLCCapabilities' - elif nodeName_ == 'functionsImplemented': - functionsImplemented_ = child_.text - functionsImplemented_ = self.gds_validate_string(functionsImplemented_, node, 'functionsImplemented') - self.functionsImplemented = functionsImplemented_ - self.validate_HexBinary64(self.functionsImplemented) # validate type HexBinary64 - elif nodeName_ == 'lFDI': - lFDI_ = child_.text - lFDI_ = self.gds_validate_string(lFDI_, node, 'lFDI') - self.lFDI = lFDI_ - self.validate_HexBinary160(self.lFDI) # validate type HexBinary160 - elif nodeName_ == 'mfDate': - obj_ = TimeType.factory() - obj_.build(child_) - self.mfDate = obj_ - obj_.original_tagname_ = 'mfDate' - elif nodeName_ == 'mfHwVer': - mfHwVer_ = child_.text - mfHwVer_ = self.gds_validate_string(mfHwVer_, node, 'mfHwVer') - self.mfHwVer = mfHwVer_ - self.validate_String32(self.mfHwVer) # validate type String32 - elif nodeName_ == 'mfID': - obj_ = PENType.factory() - obj_.build(child_) - self.mfID = obj_ - obj_.original_tagname_ = 'mfID' - elif nodeName_ == 'mfInfo': - mfInfo_ = child_.text - mfInfo_ = self.gds_validate_string(mfInfo_, node, 'mfInfo') - self.mfInfo = mfInfo_ - self.validate_String32(self.mfInfo) # validate type String32 - elif nodeName_ == 'mfModel': - mfModel_ = child_.text - mfModel_ = self.gds_validate_string(mfModel_, node, 'mfModel') - self.mfModel = mfModel_ - self.validate_String32(self.mfModel) # validate type String32 - elif nodeName_ == 'mfSerNum': - mfSerNum_ = child_.text - mfSerNum_ = self.gds_validate_string(mfSerNum_, node, 'mfSerNum') - self.mfSerNum = mfSerNum_ - self.validate_String32(self.mfSerNum) # validate type String32 - elif nodeName_ == 'primaryPower': - obj_ = PowerSourceType.factory() - obj_.build(child_) - self.primaryPower = obj_ - obj_.original_tagname_ = 'primaryPower' - elif nodeName_ == 'secondaryPower': - obj_ = PowerSourceType.factory() - obj_.build(child_) - self.secondaryPower = obj_ - obj_.original_tagname_ = 'secondaryPower' - elif nodeName_ == 'SupportedLocaleListLink': - obj_ = SupportedLocaleListLink.factory() - obj_.build(child_) - self.SupportedLocaleListLink = obj_ - obj_.original_tagname_ = 'SupportedLocaleListLink' - elif nodeName_ == 'swActTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.swActTime = obj_ - obj_.original_tagname_ = 'swActTime' - elif nodeName_ == 'swVer': - swVer_ = child_.text - swVer_ = self.gds_validate_string(swVer_, node, 'swVer') - self.swVer = swVer_ - self.validate_String32(self.swVer) # validate type String32 - super(DeviceInformation, self).buildChildren(child_, node, nodeName_, True) -# end class DeviceInformation - - -class Time(Resource): - """Contains the representation of time, constantly updated.""" - subclass = None - superclass = Resource - def __init__(self, currentTime=None, dstEndTime=None, dstOffset=None, dstStartTime=None, localTime=None, quality=None, tzOffset=None): - self.original_tagname_ = None - super(Time, self).__init__() - self.currentTime = currentTime - self.dstEndTime = dstEndTime - self.dstOffset = dstOffset - self.dstStartTime = dstStartTime - self.localTime = localTime - self.quality = quality - self.tzOffset = tzOffset - def factory(*args_, **kwargs_): - if Time.subclass: - return Time.subclass(*args_, **kwargs_) - else: - return Time(*args_, **kwargs_) - factory = staticmethod(factory) - def get_currentTime(self): return self.currentTime - def set_currentTime(self, currentTime): self.currentTime = currentTime - def get_dstEndTime(self): return self.dstEndTime - def set_dstEndTime(self, dstEndTime): self.dstEndTime = dstEndTime - def get_dstOffset(self): return self.dstOffset - def set_dstOffset(self, dstOffset): self.dstOffset = dstOffset - def get_dstStartTime(self): return self.dstStartTime - def set_dstStartTime(self, dstStartTime): self.dstStartTime = dstStartTime - def get_localTime(self): return self.localTime - def set_localTime(self, localTime): self.localTime = localTime - def get_quality(self): return self.quality - def set_quality(self, quality): self.quality = quality - def get_tzOffset(self): return self.tzOffset - def set_tzOffset(self, tzOffset): self.tzOffset = tzOffset - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.currentTime is not None or - self.dstEndTime is not None or - self.dstOffset is not None or - self.dstStartTime is not None or - self.localTime is not None or - self.quality is not None or - self.tzOffset is not None or - super(Time, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Time', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Time') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Time', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Time'): - super(Time, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Time') - def exportChildren(self, outfile, level, namespace_='', name_='Time', fromsubclass_=False, pretty_print=True): - super(Time, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.currentTime is not None: - self.currentTime.export(outfile, level, namespace_, name_='currentTime', pretty_print=pretty_print) - if self.dstEndTime is not None: - self.dstEndTime.export(outfile, level, namespace_, name_='dstEndTime', pretty_print=pretty_print) - if self.dstOffset is not None: - self.dstOffset.export(outfile, level, namespace_, name_='dstOffset', pretty_print=pretty_print) - if self.dstStartTime is not None: - self.dstStartTime.export(outfile, level, namespace_, name_='dstStartTime', pretty_print=pretty_print) - if self.localTime is not None: - self.localTime.export(outfile, level, namespace_, name_='localTime', pretty_print=pretty_print) - if self.quality is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%squality>%s%s' % (namespace_, self.gds_format_integer(self.quality, input_name='quality'), namespace_, eol_)) - if self.tzOffset is not None: - self.tzOffset.export(outfile, level, namespace_, name_='tzOffset', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='Time'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Time, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Time, self).exportLiteralChildren(outfile, level, name_) - if self.currentTime is not None: - showIndent(outfile, level) - outfile.write('currentTime=model_.TimeType(\n') - self.currentTime.exportLiteral(outfile, level, name_='currentTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.dstEndTime is not None: - showIndent(outfile, level) - outfile.write('dstEndTime=model_.TimeType(\n') - self.dstEndTime.exportLiteral(outfile, level, name_='dstEndTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.dstOffset is not None: - showIndent(outfile, level) - outfile.write('dstOffset=model_.TimeOffsetType(\n') - self.dstOffset.exportLiteral(outfile, level, name_='dstOffset') - showIndent(outfile, level) - outfile.write('),\n') - if self.dstStartTime is not None: - showIndent(outfile, level) - outfile.write('dstStartTime=model_.TimeType(\n') - self.dstStartTime.exportLiteral(outfile, level, name_='dstStartTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.localTime is not None: - showIndent(outfile, level) - outfile.write('localTime=model_.TimeType(\n') - self.localTime.exportLiteral(outfile, level, name_='localTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.quality is not None: - showIndent(outfile, level) - outfile.write('quality=%d,\n' % self.quality) - if self.tzOffset is not None: - showIndent(outfile, level) - outfile.write('tzOffset=model_.TimeOffsetType(\n') - self.tzOffset.exportLiteral(outfile, level, name_='tzOffset') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Time, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'currentTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.currentTime = obj_ - obj_.original_tagname_ = 'currentTime' - elif nodeName_ == 'dstEndTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dstEndTime = obj_ - obj_.original_tagname_ = 'dstEndTime' - elif nodeName_ == 'dstOffset': - obj_ = TimeOffsetType.factory() - obj_.build(child_) - self.dstOffset = obj_ - obj_.original_tagname_ = 'dstOffset' - elif nodeName_ == 'dstStartTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.dstStartTime = obj_ - obj_.original_tagname_ = 'dstStartTime' - elif nodeName_ == 'localTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.localTime = obj_ - obj_.original_tagname_ = 'localTime' - elif nodeName_ == 'quality': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'quality') - self.quality = ival_ - self.validate_UInt8(self.quality) # validate type UInt8 - elif nodeName_ == 'tzOffset': - obj_ = TimeOffsetType.factory() - obj_.build(child_) - self.tzOffset = obj_ - obj_.original_tagname_ = 'tzOffset' - super(Time, self).buildChildren(child_, node, nodeName_, True) -# end class Time - - -class ResponseSetList(List): - """A List element to hold ResponseSet objects.""" - subclass = None - superclass = List - def __init__(self, ResponseSet=None): - self.original_tagname_ = None - super(ResponseSetList, self).__init__() - if ResponseSet is None: - self.ResponseSet = [] - else: - self.ResponseSet = ResponseSet - def factory(*args_, **kwargs_): - if ResponseSetList.subclass: - return ResponseSetList.subclass(*args_, **kwargs_) - else: - return ResponseSetList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ResponseSet(self): return self.ResponseSet - def set_ResponseSet(self, ResponseSet): self.ResponseSet = ResponseSet - def add_ResponseSet(self, value): self.ResponseSet.append(value) - def insert_ResponseSet_at(self, index, value): self.ResponseSet.insert(index, value) - def replace_ResponseSet_at(self, index, value): self.ResponseSet[index] = value - def hasContent_(self): - if ( - self.ResponseSet or - super(ResponseSetList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ResponseSetList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseSetList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ResponseSetList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ResponseSetList'): - super(ResponseSetList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseSetList') - def exportChildren(self, outfile, level, namespace_='', name_='ResponseSetList', fromsubclass_=False, pretty_print=True): - super(ResponseSetList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for ResponseSet_ in self.ResponseSet: - ResponseSet_.export(outfile, level, namespace_, name_='ResponseSet', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ResponseSetList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ResponseSetList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ResponseSetList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('ResponseSet=[\n') - level += 1 - for ResponseSet_ in self.ResponseSet: - showIndent(outfile, level) - outfile.write('model_.ResponseSet(\n') - ResponseSet_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ResponseSetList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ResponseSet': - obj_ = ResponseSet.factory() - obj_.build(child_) - self.ResponseSet.append(obj_) - obj_.original_tagname_ = 'ResponseSet' - super(ResponseSetList, self).buildChildren(child_, node, nodeName_, True) -# end class ResponseSetList - - -class ResponseSet(IdentifiedObject): - """A container for a ResponseList.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, ResponseListLink=None): - self.original_tagname_ = None - super(ResponseSet, self).__init__() - self.ResponseListLink = ResponseListLink - def factory(*args_, **kwargs_): - if ResponseSet.subclass: - return ResponseSet.subclass(*args_, **kwargs_) - else: - return ResponseSet(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ResponseListLink(self): return self.ResponseListLink - def set_ResponseListLink(self, ResponseListLink): self.ResponseListLink = ResponseListLink - def hasContent_(self): - if ( - self.ResponseListLink is not None or - super(ResponseSet, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ResponseSet', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseSet') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ResponseSet', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ResponseSet'): - super(ResponseSet, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseSet') - def exportChildren(self, outfile, level, namespace_='', name_='ResponseSet', fromsubclass_=False, pretty_print=True): - super(ResponseSet, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ResponseListLink is not None: - self.ResponseListLink.export(outfile, level, namespace_, name_='ResponseListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ResponseSet'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ResponseSet, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ResponseSet, self).exportLiteralChildren(outfile, level, name_) - if self.ResponseListLink is not None: - showIndent(outfile, level) - outfile.write('ResponseListLink=model_.ResponseListLink(\n') - self.ResponseListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ResponseSet, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ResponseListLink': - obj_ = ResponseListLink.factory() - obj_.build(child_) - self.ResponseListLink = obj_ - obj_.original_tagname_ = 'ResponseListLink' - super(ResponseSet, self).buildChildren(child_, node, nodeName_, True) -# end class ResponseSet - - -class ResponseList(List): - """A List element to hold Response objects.""" - subclass = None - superclass = List - def __init__(self, Response=None): - self.original_tagname_ = None - super(ResponseList, self).__init__() - if Response is None: - self.Response = [] - else: - self.Response = Response - def factory(*args_, **kwargs_): - if ResponseList.subclass: - return ResponseList.subclass(*args_, **kwargs_) - else: - return ResponseList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Response(self): return self.Response - def set_Response(self, Response): self.Response = Response - def add_Response(self, value): self.Response.append(value) - def insert_Response_at(self, index, value): self.Response.insert(index, value) - def replace_Response_at(self, index, value): self.Response[index] = value - def hasContent_(self): - if ( - self.Response or - super(ResponseList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ResponseList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ResponseList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ResponseList'): - super(ResponseList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ResponseList') - def exportChildren(self, outfile, level, namespace_='', name_='ResponseList', fromsubclass_=False, pretty_print=True): - super(ResponseList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for Response_ in self.Response: - Response_.export(outfile, level, namespace_, name_='Response', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ResponseList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ResponseList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ResponseList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('Response=[\n') - level += 1 - for Response_ in self.Response: - showIndent(outfile, level) - outfile.write('model_.Response(\n') - Response_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ResponseList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Response': - class_obj_ = self.get_class_obj_(child_, Response) - obj_ = class_obj_.factory() - obj_.build(child_) - self.Response.append(obj_) - obj_.original_tagname_ = 'Response' - super(ResponseList, self).buildChildren(child_, node, nodeName_, True) -# end class ResponseList - - -class Response(Resource): - """The Response object is the generic response data repository for - functions which do not have additional specific data (e.g. DRLC - has additional data fields (SetPoint) where Price and Text event - do not).""" - subclass = None - superclass = Resource - def __init__(self, createdDateTime=None, endDeviceLFDI=None, status=None, subject=None): - self.original_tagname_ = None - super(Response, self).__init__() - self.createdDateTime = createdDateTime - self.endDeviceLFDI = endDeviceLFDI - self.status = status - self.subject = subject - def factory(*args_, **kwargs_): - if Response.subclass: - return Response.subclass(*args_, **kwargs_) - else: - return Response(*args_, **kwargs_) - factory = staticmethod(factory) - def get_createdDateTime(self): return self.createdDateTime - def set_createdDateTime(self, createdDateTime): self.createdDateTime = createdDateTime - def get_endDeviceLFDI(self): return self.endDeviceLFDI - def set_endDeviceLFDI(self, endDeviceLFDI): self.endDeviceLFDI = endDeviceLFDI - def get_status(self): return self.status - def set_status(self, status): self.status = status - def get_subject(self): return self.subject - def set_subject(self, subject): self.subject = subject - def validate_HexBinary160(self, value): - # Validate type HexBinary160, a restriction on xs:hexBinary. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.createdDateTime is not None or - self.endDeviceLFDI is not None or - self.status is not None or - self.subject is not None or - super(Response, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Response', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Response') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Response', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Response'): - super(Response, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Response') - def exportChildren(self, outfile, level, namespace_='', name_='Response', fromsubclass_=False, pretty_print=True): - super(Response, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.createdDateTime is not None: - self.createdDateTime.export(outfile, level, namespace_, name_='createdDateTime', pretty_print=pretty_print) - if self.endDeviceLFDI is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sendDeviceLFDI>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.endDeviceLFDI).encode(ExternalEncoding), input_name='endDeviceLFDI'), namespace_, eol_)) - if self.status is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sstatus>%s%s' % (namespace_, self.gds_format_integer(self.status, input_name='status'), namespace_, eol_)) - if self.subject is not None: - self.subject.export(outfile, level, namespace_, name_='subject', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='Response'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Response, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Response, self).exportLiteralChildren(outfile, level, name_) - if self.createdDateTime is not None: - showIndent(outfile, level) - outfile.write('createdDateTime=model_.TimeType(\n') - self.createdDateTime.exportLiteral(outfile, level, name_='createdDateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.endDeviceLFDI is not None: - showIndent(outfile, level) - outfile.write('endDeviceLFDI=%s,\n' % quote_python(self.endDeviceLFDI).encode(ExternalEncoding)) - if self.status is not None: - showIndent(outfile, level) - outfile.write('status=%d,\n' % self.status) - if self.subject is not None: - showIndent(outfile, level) - outfile.write('subject=model_.mRIDType(\n') - self.subject.exportLiteral(outfile, level, name_='subject') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Response, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'createdDateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.createdDateTime = obj_ - obj_.original_tagname_ = 'createdDateTime' - elif nodeName_ == 'endDeviceLFDI': - endDeviceLFDI_ = child_.text - endDeviceLFDI_ = self.gds_validate_string(endDeviceLFDI_, node, 'endDeviceLFDI') - self.endDeviceLFDI = endDeviceLFDI_ - self.validate_HexBinary160(self.endDeviceLFDI) # validate type HexBinary160 - elif nodeName_ == 'status': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'status') - self.status = ival_ - self.validate_UInt8(self.status) # validate type UInt8 - elif nodeName_ == 'subject': - obj_ = mRIDType.factory() - obj_.build(child_) - self.subject = obj_ - obj_.original_tagname_ = 'subject' - super(Response, self).buildChildren(child_, node, nodeName_, True) -# end class Response - - -class PriceResponse(Response): - """A response related to a price message.""" - subclass = None - superclass = Response - def __init__(self): - self.original_tagname_ = None - super(PriceResponse, self).__init__() - def factory(*args_, **kwargs_): - if PriceResponse.subclass: - return PriceResponse.subclass(*args_, **kwargs_) - else: - return PriceResponse(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(PriceResponse, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='PriceResponse', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='PriceResponse') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='PriceResponse', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='PriceResponse'): - super(PriceResponse, self).exportAttributes(outfile, level, already_processed, namespace_, name_='PriceResponse') - def exportChildren(self, outfile, level, namespace_='', name_='PriceResponse', fromsubclass_=False, pretty_print=True): - super(PriceResponse, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='PriceResponse'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(PriceResponse, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(PriceResponse, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(PriceResponse, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(PriceResponse, self).buildChildren(child_, node, nodeName_, True) - pass -# end class PriceResponse - - -class DrResponse(Response): - """A response to a Demand Response Load Control (EndDeviceControl) - message.""" - subclass = None - superclass = Response - def __init__(self, ApplianceLoadReduction=None, AppliedTargetReduction=None, DutyCycle=None, Offset=None, overrideDuration=None, SetPoint=None): - self.original_tagname_ = None - super(DrResponse, self).__init__() - self.ApplianceLoadReduction = ApplianceLoadReduction - self.AppliedTargetReduction = AppliedTargetReduction - self.DutyCycle = DutyCycle - self.Offset = Offset - self.overrideDuration = overrideDuration - self.SetPoint = SetPoint - def factory(*args_, **kwargs_): - if DrResponse.subclass: - return DrResponse.subclass(*args_, **kwargs_) - else: - return DrResponse(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ApplianceLoadReduction(self): return self.ApplianceLoadReduction - def set_ApplianceLoadReduction(self, ApplianceLoadReduction): self.ApplianceLoadReduction = ApplianceLoadReduction - def get_AppliedTargetReduction(self): return self.AppliedTargetReduction - def set_AppliedTargetReduction(self, AppliedTargetReduction): self.AppliedTargetReduction = AppliedTargetReduction - def get_DutyCycle(self): return self.DutyCycle - def set_DutyCycle(self, DutyCycle): self.DutyCycle = DutyCycle - def get_Offset(self): return self.Offset - def set_Offset(self, Offset): self.Offset = Offset - def get_overrideDuration(self): return self.overrideDuration - def set_overrideDuration(self, overrideDuration): self.overrideDuration = overrideDuration - def get_SetPoint(self): return self.SetPoint - def set_SetPoint(self, SetPoint): self.SetPoint = SetPoint - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.ApplianceLoadReduction is not None or - self.AppliedTargetReduction is not None or - self.DutyCycle is not None or - self.Offset is not None or - self.overrideDuration is not None or - self.SetPoint is not None or - super(DrResponse, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DrResponse', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DrResponse') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DrResponse', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DrResponse'): - super(DrResponse, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DrResponse') - def exportChildren(self, outfile, level, namespace_='', name_='DrResponse', fromsubclass_=False, pretty_print=True): - super(DrResponse, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ApplianceLoadReduction is not None: - self.ApplianceLoadReduction.export(outfile, level, namespace_, name_='ApplianceLoadReduction', pretty_print=pretty_print) - if self.AppliedTargetReduction is not None: - self.AppliedTargetReduction.export(outfile, level, namespace_, name_='AppliedTargetReduction', pretty_print=pretty_print) - if self.DutyCycle is not None: - self.DutyCycle.export(outfile, level, namespace_, name_='DutyCycle', pretty_print=pretty_print) - if self.Offset is not None: - self.Offset.export(outfile, level, namespace_, name_='Offset', pretty_print=pretty_print) - if self.overrideDuration is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%soverrideDuration>%s%s' % (namespace_, self.gds_format_integer(self.overrideDuration, input_name='overrideDuration'), namespace_, eol_)) - if self.SetPoint is not None: - self.SetPoint.export(outfile, level, namespace_, name_='SetPoint', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DrResponse'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DrResponse, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DrResponse, self).exportLiteralChildren(outfile, level, name_) - if self.ApplianceLoadReduction is not None: - showIndent(outfile, level) - outfile.write('ApplianceLoadReduction=model_.ApplianceLoadReduction(\n') - self.ApplianceLoadReduction.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.AppliedTargetReduction is not None: - showIndent(outfile, level) - outfile.write('AppliedTargetReduction=model_.AppliedTargetReduction(\n') - self.AppliedTargetReduction.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DutyCycle is not None: - showIndent(outfile, level) - outfile.write('DutyCycle=model_.DutyCycle(\n') - self.DutyCycle.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.Offset is not None: - showIndent(outfile, level) - outfile.write('Offset=model_.Offset(\n') - self.Offset.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.overrideDuration is not None: - showIndent(outfile, level) - outfile.write('overrideDuration=%d,\n' % self.overrideDuration) - if self.SetPoint is not None: - showIndent(outfile, level) - outfile.write('SetPoint=model_.SetPoint(\n') - self.SetPoint.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DrResponse, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ApplianceLoadReduction': - obj_ = ApplianceLoadReduction.factory() - obj_.build(child_) - self.ApplianceLoadReduction = obj_ - obj_.original_tagname_ = 'ApplianceLoadReduction' - elif nodeName_ == 'AppliedTargetReduction': - obj_ = AppliedTargetReduction.factory() - obj_.build(child_) - self.AppliedTargetReduction = obj_ - obj_.original_tagname_ = 'AppliedTargetReduction' - elif nodeName_ == 'DutyCycle': - obj_ = DutyCycle.factory() - obj_.build(child_) - self.DutyCycle = obj_ - obj_.original_tagname_ = 'DutyCycle' - elif nodeName_ == 'Offset': - obj_ = Offset.factory() - obj_.build(child_) - self.Offset = obj_ - obj_.original_tagname_ = 'Offset' - elif nodeName_ == 'overrideDuration': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'overrideDuration') - self.overrideDuration = ival_ - self.validate_UInt16(self.overrideDuration) # validate type UInt16 - elif nodeName_ == 'SetPoint': - obj_ = SetPoint.factory() - obj_.build(child_) - self.SetPoint = obj_ - obj_.original_tagname_ = 'SetPoint' - super(DrResponse, self).buildChildren(child_, node, nodeName_, True) -# end class DrResponse - - -class NotificationList(List): - """A List element to hold Notification objects.""" - subclass = None - superclass = List - def __init__(self, Notification=None): - self.original_tagname_ = None - super(NotificationList, self).__init__() - if Notification is None: - self.Notification = [] - else: - self.Notification = Notification - def factory(*args_, **kwargs_): - if NotificationList.subclass: - return NotificationList.subclass(*args_, **kwargs_) - else: - return NotificationList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Notification(self): return self.Notification - def set_Notification(self, Notification): self.Notification = Notification - def add_Notification(self, value): self.Notification.append(value) - def insert_Notification_at(self, index, value): self.Notification.insert(index, value) - def replace_Notification_at(self, index, value): self.Notification[index] = value - def hasContent_(self): - if ( - self.Notification or - super(NotificationList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='NotificationList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='NotificationList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='NotificationList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='NotificationList'): - super(NotificationList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='NotificationList') - def exportChildren(self, outfile, level, namespace_='', name_='NotificationList', fromsubclass_=False, pretty_print=True): - super(NotificationList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for Notification_ in self.Notification: - Notification_.export(outfile, level, namespace_, name_='Notification', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='NotificationList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(NotificationList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(NotificationList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('Notification=[\n') - level += 1 - for Notification_ in self.Notification: - showIndent(outfile, level) - outfile.write('model_.Notification(\n') - Notification_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(NotificationList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Notification': - obj_ = Notification.factory() - obj_.build(child_) - self.Notification.append(obj_) - obj_.original_tagname_ = 'Notification' - super(NotificationList, self).buildChildren(child_, node, nodeName_, True) -# end class NotificationList - - -class SubscriptionList(List): - """A List element to hold Subscription objects.""" - subclass = None - superclass = List - def __init__(self, Subscription=None): - self.original_tagname_ = None - super(SubscriptionList, self).__init__() - if Subscription is None: - self.Subscription = [] - else: - self.Subscription = Subscription - def factory(*args_, **kwargs_): - if SubscriptionList.subclass: - return SubscriptionList.subclass(*args_, **kwargs_) - else: - return SubscriptionList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Subscription(self): return self.Subscription - def set_Subscription(self, Subscription): self.Subscription = Subscription - def add_Subscription(self, value): self.Subscription.append(value) - def insert_Subscription_at(self, index, value): self.Subscription.insert(index, value) - def replace_Subscription_at(self, index, value): self.Subscription[index] = value - def hasContent_(self): - if ( - self.Subscription or - super(SubscriptionList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SubscriptionList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SubscriptionList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SubscriptionList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SubscriptionList'): - super(SubscriptionList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SubscriptionList') - def exportChildren(self, outfile, level, namespace_='', name_='SubscriptionList', fromsubclass_=False, pretty_print=True): - super(SubscriptionList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for Subscription_ in self.Subscription: - Subscription_.export(outfile, level, namespace_, name_='Subscription', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='SubscriptionList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SubscriptionList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SubscriptionList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('Subscription=[\n') - level += 1 - for Subscription_ in self.Subscription: - showIndent(outfile, level) - outfile.write('model_.Subscription(\n') - Subscription_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SubscriptionList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Subscription': - obj_ = Subscription.factory() - obj_.build(child_) - self.Subscription.append(obj_) - obj_.original_tagname_ = 'Subscription' - super(SubscriptionList, self).buildChildren(child_, node, nodeName_, True) -# end class SubscriptionList - - -class SubscriptionBase(Resource): - """Holds the information related to a client subscription to receive - updates to a resource automatically. The actual resources may be - passed in the Notification by specifying a specific xsi:type for - the Resource and passing the full representation.""" - subclass = None - superclass = Resource - def __init__(self, subscribedResource=None): - self.original_tagname_ = None - super(SubscriptionBase, self).__init__() - self.subscribedResource = subscribedResource - def factory(*args_, **kwargs_): - if SubscriptionBase.subclass: - return SubscriptionBase.subclass(*args_, **kwargs_) - else: - return SubscriptionBase(*args_, **kwargs_) - factory = staticmethod(factory) - def get_subscribedResource(self): return self.subscribedResource - def set_subscribedResource(self, subscribedResource): self.subscribedResource = subscribedResource - def hasContent_(self): - if ( - self.subscribedResource is not None or - super(SubscriptionBase, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SubscriptionBase', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SubscriptionBase') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SubscriptionBase', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SubscriptionBase'): - super(SubscriptionBase, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SubscriptionBase') - def exportChildren(self, outfile, level, namespace_='', name_='SubscriptionBase', fromsubclass_=False, pretty_print=True): - super(SubscriptionBase, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.subscribedResource is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssubscribedResource>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.subscribedResource).encode(ExternalEncoding), input_name='subscribedResource'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='SubscriptionBase'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SubscriptionBase, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SubscriptionBase, self).exportLiteralChildren(outfile, level, name_) - if self.subscribedResource is not None: - showIndent(outfile, level) - outfile.write('subscribedResource=%s,\n' % quote_python(self.subscribedResource).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SubscriptionBase, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'subscribedResource': - subscribedResource_ = child_.text - subscribedResource_ = self.gds_validate_string(subscribedResource_, node, 'subscribedResource') - self.subscribedResource = subscribedResource_ - super(SubscriptionBase, self).buildChildren(child_, node, nodeName_, True) -# end class SubscriptionBase - - -class FunctionSetAssignmentsList(SubscribableList): - """A List element to hold FunctionSetAssignments objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, FunctionSetAssignments=None): - self.original_tagname_ = None - super(FunctionSetAssignmentsList, self).__init__() - if FunctionSetAssignments is None: - self.FunctionSetAssignments = [] - else: - self.FunctionSetAssignments = FunctionSetAssignments - def factory(*args_, **kwargs_): - if FunctionSetAssignmentsList.subclass: - return FunctionSetAssignmentsList.subclass(*args_, **kwargs_) - else: - return FunctionSetAssignmentsList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_FunctionSetAssignments(self): return self.FunctionSetAssignments - def set_FunctionSetAssignments(self, FunctionSetAssignments): self.FunctionSetAssignments = FunctionSetAssignments - def add_FunctionSetAssignments(self, value): self.FunctionSetAssignments.append(value) - def insert_FunctionSetAssignments_at(self, index, value): self.FunctionSetAssignments.insert(index, value) - def replace_FunctionSetAssignments_at(self, index, value): self.FunctionSetAssignments[index] = value - def hasContent_(self): - if ( - self.FunctionSetAssignments or - super(FunctionSetAssignmentsList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FunctionSetAssignmentsList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FunctionSetAssignmentsList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FunctionSetAssignmentsList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FunctionSetAssignmentsList'): - super(FunctionSetAssignmentsList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FunctionSetAssignmentsList') - def exportChildren(self, outfile, level, namespace_='', name_='FunctionSetAssignmentsList', fromsubclass_=False, pretty_print=True): - super(FunctionSetAssignmentsList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for FunctionSetAssignments_ in self.FunctionSetAssignments: - FunctionSetAssignments_.export(outfile, level, namespace_, name_='FunctionSetAssignments', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FunctionSetAssignmentsList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FunctionSetAssignmentsList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FunctionSetAssignmentsList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('FunctionSetAssignments=[\n') - level += 1 - for FunctionSetAssignments_ in self.FunctionSetAssignments: - showIndent(outfile, level) - outfile.write('model_.FunctionSetAssignments(\n') - FunctionSetAssignments_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FunctionSetAssignmentsList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'FunctionSetAssignments': - obj_ = FunctionSetAssignments.factory() - obj_.build(child_) - self.FunctionSetAssignments.append(obj_) - obj_.original_tagname_ = 'FunctionSetAssignments' - super(FunctionSetAssignmentsList, self).buildChildren(child_, node, nodeName_, True) -# end class FunctionSetAssignmentsList - - -class FunctionSetAssignmentsBase(Resource): - """Defines a collection of function set instances that are to be used - by one or more devices as indicated by the EndDevice object(s) - of the server.""" - subclass = None - superclass = Resource - def __init__(self, CustomerAccountListLink=None, DemandResponseProgramListLink=None, DERProgramListLink=None, FileListLink=None, MessagingProgramListLink=None, PrepaymentListLink=None, ResponseSetListLink=None, TariffProfileListLink=None, TimeLink=None, UsagePointListLink=None): - self.original_tagname_ = None - super(FunctionSetAssignmentsBase, self).__init__() - self.CustomerAccountListLink = CustomerAccountListLink - self.DemandResponseProgramListLink = DemandResponseProgramListLink - self.DERProgramListLink = DERProgramListLink - self.FileListLink = FileListLink - self.MessagingProgramListLink = MessagingProgramListLink - self.PrepaymentListLink = PrepaymentListLink - self.ResponseSetListLink = ResponseSetListLink - self.TariffProfileListLink = TariffProfileListLink - self.TimeLink = TimeLink - self.UsagePointListLink = UsagePointListLink - def factory(*args_, **kwargs_): - if FunctionSetAssignmentsBase.subclass: - return FunctionSetAssignmentsBase.subclass(*args_, **kwargs_) - else: - return FunctionSetAssignmentsBase(*args_, **kwargs_) - factory = staticmethod(factory) - def get_CustomerAccountListLink(self): return self.CustomerAccountListLink - def set_CustomerAccountListLink(self, CustomerAccountListLink): self.CustomerAccountListLink = CustomerAccountListLink - def get_DemandResponseProgramListLink(self): return self.DemandResponseProgramListLink - def set_DemandResponseProgramListLink(self, DemandResponseProgramListLink): self.DemandResponseProgramListLink = DemandResponseProgramListLink - def get_DERProgramListLink(self): return self.DERProgramListLink - def set_DERProgramListLink(self, DERProgramListLink): self.DERProgramListLink = DERProgramListLink - def get_FileListLink(self): return self.FileListLink - def set_FileListLink(self, FileListLink): self.FileListLink = FileListLink - def get_MessagingProgramListLink(self): return self.MessagingProgramListLink - def set_MessagingProgramListLink(self, MessagingProgramListLink): self.MessagingProgramListLink = MessagingProgramListLink - def get_PrepaymentListLink(self): return self.PrepaymentListLink - def set_PrepaymentListLink(self, PrepaymentListLink): self.PrepaymentListLink = PrepaymentListLink - def get_ResponseSetListLink(self): return self.ResponseSetListLink - def set_ResponseSetListLink(self, ResponseSetListLink): self.ResponseSetListLink = ResponseSetListLink - def get_TariffProfileListLink(self): return self.TariffProfileListLink - def set_TariffProfileListLink(self, TariffProfileListLink): self.TariffProfileListLink = TariffProfileListLink - def get_TimeLink(self): return self.TimeLink - def set_TimeLink(self, TimeLink): self.TimeLink = TimeLink - def get_UsagePointListLink(self): return self.UsagePointListLink - def set_UsagePointListLink(self, UsagePointListLink): self.UsagePointListLink = UsagePointListLink - def hasContent_(self): - if ( - self.CustomerAccountListLink is not None or - self.DemandResponseProgramListLink is not None or - self.DERProgramListLink is not None or - self.FileListLink is not None or - self.MessagingProgramListLink is not None or - self.PrepaymentListLink is not None or - self.ResponseSetListLink is not None or - self.TariffProfileListLink is not None or - self.TimeLink is not None or - self.UsagePointListLink is not None or - super(FunctionSetAssignmentsBase, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FunctionSetAssignmentsBase', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FunctionSetAssignmentsBase') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FunctionSetAssignmentsBase', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FunctionSetAssignmentsBase'): - super(FunctionSetAssignmentsBase, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FunctionSetAssignmentsBase') - def exportChildren(self, outfile, level, namespace_='', name_='FunctionSetAssignmentsBase', fromsubclass_=False, pretty_print=True): - super(FunctionSetAssignmentsBase, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.CustomerAccountListLink is not None: - self.CustomerAccountListLink.export(outfile, level, namespace_, name_='CustomerAccountListLink', pretty_print=pretty_print) - if self.DemandResponseProgramListLink is not None: - self.DemandResponseProgramListLink.export(outfile, level, namespace_, name_='DemandResponseProgramListLink', pretty_print=pretty_print) - if self.DERProgramListLink is not None: - self.DERProgramListLink.export(outfile, level, namespace_, name_='DERProgramListLink', pretty_print=pretty_print) - if self.FileListLink is not None: - self.FileListLink.export(outfile, level, namespace_, name_='FileListLink', pretty_print=pretty_print) - if self.MessagingProgramListLink is not None: - self.MessagingProgramListLink.export(outfile, level, namespace_, name_='MessagingProgramListLink', pretty_print=pretty_print) - if self.PrepaymentListLink is not None: - self.PrepaymentListLink.export(outfile, level, namespace_, name_='PrepaymentListLink', pretty_print=pretty_print) - if self.ResponseSetListLink is not None: - self.ResponseSetListLink.export(outfile, level, namespace_, name_='ResponseSetListLink', pretty_print=pretty_print) - if self.TariffProfileListLink is not None: - self.TariffProfileListLink.export(outfile, level, namespace_, name_='TariffProfileListLink', pretty_print=pretty_print) - if self.TimeLink is not None: - self.TimeLink.export(outfile, level, namespace_, name_='TimeLink', pretty_print=pretty_print) - if self.UsagePointListLink is not None: - self.UsagePointListLink.export(outfile, level, namespace_, name_='UsagePointListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FunctionSetAssignmentsBase'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(FunctionSetAssignmentsBase, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FunctionSetAssignmentsBase, self).exportLiteralChildren(outfile, level, name_) - if self.CustomerAccountListLink is not None: - showIndent(outfile, level) - outfile.write('CustomerAccountListLink=model_.CustomerAccountListLink(\n') - self.CustomerAccountListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DemandResponseProgramListLink is not None: - showIndent(outfile, level) - outfile.write('DemandResponseProgramListLink=model_.DemandResponseProgramListLink(\n') - self.DemandResponseProgramListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DERProgramListLink is not None: - showIndent(outfile, level) - outfile.write('DERProgramListLink=model_.DERProgramListLink(\n') - self.DERProgramListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.FileListLink is not None: - showIndent(outfile, level) - outfile.write('FileListLink=model_.FileListLink(\n') - self.FileListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.MessagingProgramListLink is not None: - showIndent(outfile, level) - outfile.write('MessagingProgramListLink=model_.MessagingProgramListLink(\n') - self.MessagingProgramListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.PrepaymentListLink is not None: - showIndent(outfile, level) - outfile.write('PrepaymentListLink=model_.PrepaymentListLink(\n') - self.PrepaymentListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ResponseSetListLink is not None: - showIndent(outfile, level) - outfile.write('ResponseSetListLink=model_.ResponseSetListLink(\n') - self.ResponseSetListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.TariffProfileListLink is not None: - showIndent(outfile, level) - outfile.write('TariffProfileListLink=model_.TariffProfileListLink(\n') - self.TariffProfileListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.TimeLink is not None: - showIndent(outfile, level) - outfile.write('TimeLink=model_.TimeLink(\n') - self.TimeLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.UsagePointListLink is not None: - showIndent(outfile, level) - outfile.write('UsagePointListLink=model_.UsagePointListLink(\n') - self.UsagePointListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(FunctionSetAssignmentsBase, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'CustomerAccountListLink': - obj_ = CustomerAccountListLink.factory() - obj_.build(child_) - self.CustomerAccountListLink = obj_ - obj_.original_tagname_ = 'CustomerAccountListLink' - elif nodeName_ == 'DemandResponseProgramListLink': - obj_ = DemandResponseProgramListLink.factory() - obj_.build(child_) - self.DemandResponseProgramListLink = obj_ - obj_.original_tagname_ = 'DemandResponseProgramListLink' - elif nodeName_ == 'DERProgramListLink': - obj_ = DERProgramListLink.factory() - obj_.build(child_) - self.DERProgramListLink = obj_ - obj_.original_tagname_ = 'DERProgramListLink' - elif nodeName_ == 'FileListLink': - obj_ = FileListLink.factory() - obj_.build(child_) - self.FileListLink = obj_ - obj_.original_tagname_ = 'FileListLink' - elif nodeName_ == 'MessagingProgramListLink': - obj_ = MessagingProgramListLink.factory() - obj_.build(child_) - self.MessagingProgramListLink = obj_ - obj_.original_tagname_ = 'MessagingProgramListLink' - elif nodeName_ == 'PrepaymentListLink': - obj_ = PrepaymentListLink.factory() - obj_.build(child_) - self.PrepaymentListLink = obj_ - obj_.original_tagname_ = 'PrepaymentListLink' - elif nodeName_ == 'ResponseSetListLink': - obj_ = ResponseSetListLink.factory() - obj_.build(child_) - self.ResponseSetListLink = obj_ - obj_.original_tagname_ = 'ResponseSetListLink' - elif nodeName_ == 'TariffProfileListLink': - obj_ = TariffProfileListLink.factory() - obj_.build(child_) - self.TariffProfileListLink = obj_ - obj_.original_tagname_ = 'TariffProfileListLink' - elif nodeName_ == 'TimeLink': - obj_ = TimeLink.factory() - obj_.build(child_) - self.TimeLink = obj_ - obj_.original_tagname_ = 'TimeLink' - elif nodeName_ == 'UsagePointListLink': - obj_ = UsagePointListLink.factory() - obj_.build(child_) - self.UsagePointListLink = obj_ - obj_.original_tagname_ = 'UsagePointListLink' - super(FunctionSetAssignmentsBase, self).buildChildren(child_, node, nodeName_, True) -# end class FunctionSetAssignmentsBase - - -class Registration(Resource): - """Registration represents an authorization to access the resources on - a host.""" - subclass = None - superclass = Resource - def __init__(self, dateTimeRegistered=None, pIN=None): - self.original_tagname_ = None - super(Registration, self).__init__() - self.dateTimeRegistered = dateTimeRegistered - self.pIN = pIN - def factory(*args_, **kwargs_): - if Registration.subclass: - return Registration.subclass(*args_, **kwargs_) - else: - return Registration(*args_, **kwargs_) - factory = staticmethod(factory) - def get_dateTimeRegistered(self): return self.dateTimeRegistered - def set_dateTimeRegistered(self, dateTimeRegistered): self.dateTimeRegistered = dateTimeRegistered - def get_pIN(self): return self.pIN - def set_pIN(self, pIN): self.pIN = pIN - def hasContent_(self): - if ( - self.dateTimeRegistered is not None or - self.pIN is not None or - super(Registration, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Registration', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Registration') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Registration', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Registration'): - super(Registration, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Registration') - def exportChildren(self, outfile, level, namespace_='', name_='Registration', fromsubclass_=False, pretty_print=True): - super(Registration, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.dateTimeRegistered is not None: - self.dateTimeRegistered.export(outfile, level, namespace_, name_='dateTimeRegistered', pretty_print=pretty_print) - if self.pIN is not None: - self.pIN.export(outfile, level, namespace_, name_='pIN', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='Registration'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Registration, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Registration, self).exportLiteralChildren(outfile, level, name_) - if self.dateTimeRegistered is not None: - showIndent(outfile, level) - outfile.write('dateTimeRegistered=model_.TimeType(\n') - self.dateTimeRegistered.exportLiteral(outfile, level, name_='dateTimeRegistered') - showIndent(outfile, level) - outfile.write('),\n') - if self.pIN is not None: - showIndent(outfile, level) - outfile.write('pIN=model_.PINType(\n') - self.pIN.exportLiteral(outfile, level, name_='pIN') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Registration, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'dateTimeRegistered': - obj_ = TimeType.factory() - obj_.build(child_) - self.dateTimeRegistered = obj_ - obj_.original_tagname_ = 'dateTimeRegistered' - elif nodeName_ == 'pIN': - obj_ = PINType.factory() - obj_.build(child_) - self.pIN = obj_ - obj_.original_tagname_ = 'pIN' - super(Registration, self).buildChildren(child_, node, nodeName_, True) -# end class Registration - - -class EndDeviceList(SubscribableList): - """A List element to hold EndDevice objects.""" - subclass = None - superclass = SubscribableList - def __init__(self, EndDevice=None): - self.original_tagname_ = None - super(EndDeviceList, self).__init__() - if EndDevice is None: - self.EndDevice = [] - else: - self.EndDevice = EndDevice - def factory(*args_, **kwargs_): - if EndDeviceList.subclass: - return EndDeviceList.subclass(*args_, **kwargs_) - else: - return EndDeviceList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_EndDevice(self): return self.EndDevice - def set_EndDevice(self, EndDevice): self.EndDevice = EndDevice - def add_EndDevice(self, value): self.EndDevice.append(value) - def insert_EndDevice_at(self, index, value): self.EndDevice.insert(index, value) - def replace_EndDevice_at(self, index, value): self.EndDevice[index] = value - def hasContent_(self): - if ( - self.EndDevice or - super(EndDeviceList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EndDeviceList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EndDeviceList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EndDeviceList'): - super(EndDeviceList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='EndDeviceList') - def exportChildren(self, outfile, level, namespace_='', name_='EndDeviceList', fromsubclass_=False, pretty_print=True): - super(EndDeviceList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for EndDevice_ in self.EndDevice: - EndDevice_.export(outfile, level, namespace_, name_='EndDevice', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='EndDeviceList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(EndDeviceList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(EndDeviceList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('EndDevice=[\n') - level += 1 - for EndDevice_ in self.EndDevice: - showIndent(outfile, level) - outfile.write('model_.EndDevice(\n') - EndDevice_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(EndDeviceList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'EndDevice': - obj_ = EndDevice.factory() - obj_.build(child_) - self.EndDevice.append(obj_) - obj_.original_tagname_ = 'EndDevice' - super(EndDeviceList, self).buildChildren(child_, node, nodeName_, True) -# end class EndDeviceList - - -class DeviceStatus(Resource): - """Status of device""" - subclass = None - superclass = Resource - def __init__(self, changedTime=None, onCount=None, opState=None, opTime=None, Temperature=None, TimeLink=None): - self.original_tagname_ = None - super(DeviceStatus, self).__init__() - self.changedTime = changedTime - self.onCount = onCount - self.opState = opState - self.opTime = opTime - if Temperature is None: - self.Temperature = [] - else: - self.Temperature = Temperature - self.TimeLink = TimeLink - def factory(*args_, **kwargs_): - if DeviceStatus.subclass: - return DeviceStatus.subclass(*args_, **kwargs_) - else: - return DeviceStatus(*args_, **kwargs_) - factory = staticmethod(factory) - def get_changedTime(self): return self.changedTime - def set_changedTime(self, changedTime): self.changedTime = changedTime - def get_onCount(self): return self.onCount - def set_onCount(self, onCount): self.onCount = onCount - def get_opState(self): return self.opState - def set_opState(self, opState): self.opState = opState - def get_opTime(self): return self.opTime - def set_opTime(self, opTime): self.opTime = opTime - def get_Temperature(self): return self.Temperature - def set_Temperature(self, Temperature): self.Temperature = Temperature - def add_Temperature(self, value): self.Temperature.append(value) - def insert_Temperature_at(self, index, value): self.Temperature.insert(index, value) - def replace_Temperature_at(self, index, value): self.Temperature[index] = value - def get_TimeLink(self): return self.TimeLink - def set_TimeLink(self, TimeLink): self.TimeLink = TimeLink - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_UInt32(self, value): - # Validate type UInt32, a restriction on xs:unsignedInt. - pass - def hasContent_(self): - if ( - self.changedTime is not None or - self.onCount is not None or - self.opState is not None or - self.opTime is not None or - self.Temperature or - self.TimeLink is not None or - super(DeviceStatus, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DeviceStatus', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceStatus') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DeviceStatus', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DeviceStatus'): - super(DeviceStatus, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceStatus') - def exportChildren(self, outfile, level, namespace_='', name_='DeviceStatus', fromsubclass_=False, pretty_print=True): - super(DeviceStatus, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.changedTime is not None: - self.changedTime.export(outfile, level, namespace_, name_='changedTime', pretty_print=pretty_print) - if self.onCount is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sonCount>%s%s' % (namespace_, self.gds_format_integer(self.onCount, input_name='onCount'), namespace_, eol_)) - if self.opState is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sopState>%s%s' % (namespace_, self.gds_format_integer(self.opState, input_name='opState'), namespace_, eol_)) - if self.opTime is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sopTime>%s%s' % (namespace_, self.gds_format_integer(self.opTime, input_name='opTime'), namespace_, eol_)) - for Temperature_ in self.Temperature: - Temperature_.export(outfile, level, namespace_, name_='Temperature', pretty_print=pretty_print) - if self.TimeLink is not None: - self.TimeLink.export(outfile, level, namespace_, name_='TimeLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DeviceStatus'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DeviceStatus, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DeviceStatus, self).exportLiteralChildren(outfile, level, name_) - if self.changedTime is not None: - showIndent(outfile, level) - outfile.write('changedTime=model_.TimeType(\n') - self.changedTime.exportLiteral(outfile, level, name_='changedTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.onCount is not None: - showIndent(outfile, level) - outfile.write('onCount=%d,\n' % self.onCount) - if self.opState is not None: - showIndent(outfile, level) - outfile.write('opState=%d,\n' % self.opState) - if self.opTime is not None: - showIndent(outfile, level) - outfile.write('opTime=%d,\n' % self.opTime) - showIndent(outfile, level) - outfile.write('Temperature=[\n') - level += 1 - for Temperature_ in self.Temperature: - showIndent(outfile, level) - outfile.write('model_.Temperature(\n') - Temperature_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - if self.TimeLink is not None: - showIndent(outfile, level) - outfile.write('TimeLink=model_.TimeLink(\n') - self.TimeLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DeviceStatus, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'changedTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.changedTime = obj_ - obj_.original_tagname_ = 'changedTime' - elif nodeName_ == 'onCount': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'onCount') - self.onCount = ival_ - self.validate_UInt16(self.onCount) # validate type UInt16 - elif nodeName_ == 'opState': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'opState') - self.opState = ival_ - self.validate_UInt8(self.opState) # validate type UInt8 - elif nodeName_ == 'opTime': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'opTime') - self.opTime = ival_ - self.validate_UInt32(self.opTime) # validate type UInt32 - elif nodeName_ == 'Temperature': - obj_ = Temperature.factory() - obj_.build(child_) - self.Temperature.append(obj_) - obj_.original_tagname_ = 'Temperature' - elif nodeName_ == 'TimeLink': - obj_ = TimeLink.factory() - obj_.build(child_) - self.TimeLink = obj_ - obj_.original_tagname_ = 'TimeLink' - super(DeviceStatus, self).buildChildren(child_, node, nodeName_, True) -# end class DeviceStatus - - -class AbstractDevice(SubscribableResource): - """The EndDevice providing the resources available within the - DeviceCapabilities.""" - subclass = None - superclass = SubscribableResource - def __init__(self, ConfigurationLink=None, DERListLink=None, DeviceInformationLink=None, DeviceStatusLink=None, FileStatusLink=None, IPInterfaceListLink=None, LoadShedAvailabilityLink=None, loadShedDeviceCategory=None, LogEventListLink=None, PowerStatusLink=None, sFDI=None): - self.original_tagname_ = None - super(AbstractDevice, self).__init__() - self.ConfigurationLink = ConfigurationLink - self.DERListLink = DERListLink - self.DeviceInformationLink = DeviceInformationLink - self.DeviceStatusLink = DeviceStatusLink - self.FileStatusLink = FileStatusLink - self.IPInterfaceListLink = IPInterfaceListLink - self.LoadShedAvailabilityLink = LoadShedAvailabilityLink - self.loadShedDeviceCategory = loadShedDeviceCategory - self.LogEventListLink = LogEventListLink - self.PowerStatusLink = PowerStatusLink - self.sFDI = sFDI - def factory(*args_, **kwargs_): - if AbstractDevice.subclass: - return AbstractDevice.subclass(*args_, **kwargs_) - else: - return AbstractDevice(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ConfigurationLink(self): return self.ConfigurationLink - def set_ConfigurationLink(self, ConfigurationLink): self.ConfigurationLink = ConfigurationLink - def get_DERListLink(self): return self.DERListLink - def set_DERListLink(self, DERListLink): self.DERListLink = DERListLink - def get_DeviceInformationLink(self): return self.DeviceInformationLink - def set_DeviceInformationLink(self, DeviceInformationLink): self.DeviceInformationLink = DeviceInformationLink - def get_DeviceStatusLink(self): return self.DeviceStatusLink - def set_DeviceStatusLink(self, DeviceStatusLink): self.DeviceStatusLink = DeviceStatusLink - def get_FileStatusLink(self): return self.FileStatusLink - def set_FileStatusLink(self, FileStatusLink): self.FileStatusLink = FileStatusLink - def get_IPInterfaceListLink(self): return self.IPInterfaceListLink - def set_IPInterfaceListLink(self, IPInterfaceListLink): self.IPInterfaceListLink = IPInterfaceListLink - def get_LoadShedAvailabilityLink(self): return self.LoadShedAvailabilityLink - def set_LoadShedAvailabilityLink(self, LoadShedAvailabilityLink): self.LoadShedAvailabilityLink = LoadShedAvailabilityLink - def get_loadShedDeviceCategory(self): return self.loadShedDeviceCategory - def set_loadShedDeviceCategory(self, loadShedDeviceCategory): self.loadShedDeviceCategory = loadShedDeviceCategory - def get_LogEventListLink(self): return self.LogEventListLink - def set_LogEventListLink(self, LogEventListLink): self.LogEventListLink = LogEventListLink - def get_PowerStatusLink(self): return self.PowerStatusLink - def set_PowerStatusLink(self, PowerStatusLink): self.PowerStatusLink = PowerStatusLink - def get_sFDI(self): return self.sFDI - def set_sFDI(self, sFDI): self.sFDI = sFDI - def hasContent_(self): - if ( - self.ConfigurationLink is not None or - self.DERListLink is not None or - self.DeviceInformationLink is not None or - self.DeviceStatusLink is not None or - self.FileStatusLink is not None or - self.IPInterfaceListLink is not None or - self.LoadShedAvailabilityLink is not None or - self.loadShedDeviceCategory is not None or - self.LogEventListLink is not None or - self.PowerStatusLink is not None or - self.sFDI is not None or - super(AbstractDevice, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='AbstractDevice', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='AbstractDevice') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='AbstractDevice', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='AbstractDevice'): - super(AbstractDevice, self).exportAttributes(outfile, level, already_processed, namespace_, name_='AbstractDevice') - def exportChildren(self, outfile, level, namespace_='', name_='AbstractDevice', fromsubclass_=False, pretty_print=True): - super(AbstractDevice, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ConfigurationLink is not None: - self.ConfigurationLink.export(outfile, level, namespace_, name_='ConfigurationLink', pretty_print=pretty_print) - if self.DERListLink is not None: - self.DERListLink.export(outfile, level, namespace_, name_='DERListLink', pretty_print=pretty_print) - if self.DeviceInformationLink is not None: - self.DeviceInformationLink.export(outfile, level, namespace_, name_='DeviceInformationLink', pretty_print=pretty_print) - if self.DeviceStatusLink is not None: - self.DeviceStatusLink.export(outfile, level, namespace_, name_='DeviceStatusLink', pretty_print=pretty_print) - if self.FileStatusLink is not None: - self.FileStatusLink.export(outfile, level, namespace_, name_='FileStatusLink', pretty_print=pretty_print) - if self.IPInterfaceListLink is not None: - self.IPInterfaceListLink.export(outfile, level, namespace_, name_='IPInterfaceListLink', pretty_print=pretty_print) - if self.LoadShedAvailabilityLink is not None: - self.LoadShedAvailabilityLink.export(outfile, level, namespace_, name_='LoadShedAvailabilityLink', pretty_print=pretty_print) - if self.loadShedDeviceCategory is not None: - self.loadShedDeviceCategory.export(outfile, level, namespace_, name_='loadShedDeviceCategory', pretty_print=pretty_print) - if self.LogEventListLink is not None: - self.LogEventListLink.export(outfile, level, namespace_, name_='LogEventListLink', pretty_print=pretty_print) - if self.PowerStatusLink is not None: - self.PowerStatusLink.export(outfile, level, namespace_, name_='PowerStatusLink', pretty_print=pretty_print) - if self.sFDI is not None: - self.sFDI.export(outfile, level, namespace_, name_='sFDI', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='AbstractDevice'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(AbstractDevice, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(AbstractDevice, self).exportLiteralChildren(outfile, level, name_) - if self.ConfigurationLink is not None: - showIndent(outfile, level) - outfile.write('ConfigurationLink=model_.ConfigurationLink(\n') - self.ConfigurationLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DERListLink is not None: - showIndent(outfile, level) - outfile.write('DERListLink=model_.DERListLink(\n') - self.DERListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DeviceInformationLink is not None: - showIndent(outfile, level) - outfile.write('DeviceInformationLink=model_.DeviceInformationLink(\n') - self.DeviceInformationLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.DeviceStatusLink is not None: - showIndent(outfile, level) - outfile.write('DeviceStatusLink=model_.DeviceStatusLink(\n') - self.DeviceStatusLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.FileStatusLink is not None: - showIndent(outfile, level) - outfile.write('FileStatusLink=model_.FileStatusLink(\n') - self.FileStatusLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.IPInterfaceListLink is not None: - showIndent(outfile, level) - outfile.write('IPInterfaceListLink=model_.IPInterfaceListLink(\n') - self.IPInterfaceListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.LoadShedAvailabilityLink is not None: - showIndent(outfile, level) - outfile.write('LoadShedAvailabilityLink=model_.LoadShedAvailabilityLink(\n') - self.LoadShedAvailabilityLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.loadShedDeviceCategory is not None: - showIndent(outfile, level) - outfile.write('loadShedDeviceCategory=model_.DeviceCategoryType(\n') - self.loadShedDeviceCategory.exportLiteral(outfile, level, name_='loadShedDeviceCategory') - showIndent(outfile, level) - outfile.write('),\n') - if self.LogEventListLink is not None: - showIndent(outfile, level) - outfile.write('LogEventListLink=model_.LogEventListLink(\n') - self.LogEventListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.PowerStatusLink is not None: - showIndent(outfile, level) - outfile.write('PowerStatusLink=model_.PowerStatusLink(\n') - self.PowerStatusLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.sFDI is not None: - showIndent(outfile, level) - outfile.write('sFDI=model_.SFDIType(\n') - self.sFDI.exportLiteral(outfile, level, name_='sFDI') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(AbstractDevice, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ConfigurationLink': - obj_ = ConfigurationLink.factory() - obj_.build(child_) - self.ConfigurationLink = obj_ - obj_.original_tagname_ = 'ConfigurationLink' - elif nodeName_ == 'DERListLink': - obj_ = DERListLink.factory() - obj_.build(child_) - self.DERListLink = obj_ - obj_.original_tagname_ = 'DERListLink' - elif nodeName_ == 'DeviceInformationLink': - obj_ = DeviceInformationLink.factory() - obj_.build(child_) - self.DeviceInformationLink = obj_ - obj_.original_tagname_ = 'DeviceInformationLink' - elif nodeName_ == 'DeviceStatusLink': - obj_ = DeviceStatusLink.factory() - obj_.build(child_) - self.DeviceStatusLink = obj_ - obj_.original_tagname_ = 'DeviceStatusLink' - elif nodeName_ == 'FileStatusLink': - obj_ = FileStatusLink.factory() - obj_.build(child_) - self.FileStatusLink = obj_ - obj_.original_tagname_ = 'FileStatusLink' - elif nodeName_ == 'IPInterfaceListLink': - obj_ = IPInterfaceListLink.factory() - obj_.build(child_) - self.IPInterfaceListLink = obj_ - obj_.original_tagname_ = 'IPInterfaceListLink' - elif nodeName_ == 'LoadShedAvailabilityLink': - obj_ = LoadShedAvailabilityLink.factory() - obj_.build(child_) - self.LoadShedAvailabilityLink = obj_ - obj_.original_tagname_ = 'LoadShedAvailabilityLink' - elif nodeName_ == 'loadShedDeviceCategory': - obj_ = DeviceCategoryType.factory() - obj_.build(child_) - self.loadShedDeviceCategory = obj_ - obj_.original_tagname_ = 'loadShedDeviceCategory' - elif nodeName_ == 'LogEventListLink': - obj_ = LogEventListLink.factory() - obj_.build(child_) - self.LogEventListLink = obj_ - obj_.original_tagname_ = 'LogEventListLink' - elif nodeName_ == 'PowerStatusLink': - obj_ = PowerStatusLink.factory() - obj_.build(child_) - self.PowerStatusLink = obj_ - obj_.original_tagname_ = 'PowerStatusLink' - elif nodeName_ == 'sFDI': - obj_ = SFDIType.factory() - obj_.build(child_) - self.sFDI = obj_ - obj_.original_tagname_ = 'sFDI' - super(AbstractDevice, self).buildChildren(child_, node, nodeName_, True) -# end class AbstractDevice - - -class DeviceCapability(FunctionSetAssignmentsBase): - """Returned by the URI provided by DNS-SD, to allow clients to find the - URIs to the resources in which they are interested.""" - subclass = None - superclass = FunctionSetAssignmentsBase - def __init__(self, EndDeviceListLink=None, MirrorUsagePointListLink=None, SelfDeviceLink=None): - self.original_tagname_ = None - super(DeviceCapability, self).__init__() - self.EndDeviceListLink = EndDeviceListLink - self.MirrorUsagePointListLink = MirrorUsagePointListLink - self.SelfDeviceLink = SelfDeviceLink - def factory(*args_, **kwargs_): - if DeviceCapability.subclass: - return DeviceCapability.subclass(*args_, **kwargs_) - else: - return DeviceCapability(*args_, **kwargs_) - factory = staticmethod(factory) - def get_EndDeviceListLink(self): return self.EndDeviceListLink - def set_EndDeviceListLink(self, EndDeviceListLink): self.EndDeviceListLink = EndDeviceListLink - def get_MirrorUsagePointListLink(self): return self.MirrorUsagePointListLink - def set_MirrorUsagePointListLink(self, MirrorUsagePointListLink): self.MirrorUsagePointListLink = MirrorUsagePointListLink - def get_SelfDeviceLink(self): return self.SelfDeviceLink - def set_SelfDeviceLink(self, SelfDeviceLink): self.SelfDeviceLink = SelfDeviceLink - def hasContent_(self): - if ( - self.EndDeviceListLink is not None or - self.MirrorUsagePointListLink is not None or - self.SelfDeviceLink is not None or - super(DeviceCapability, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='DeviceCapability', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceCapability') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='DeviceCapability', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='DeviceCapability'): - super(DeviceCapability, self).exportAttributes(outfile, level, already_processed, namespace_, name_='DeviceCapability') - def exportChildren(self, outfile, level, namespace_='', name_='DeviceCapability', fromsubclass_=False, pretty_print=True): - super(DeviceCapability, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.EndDeviceListLink is not None: - self.EndDeviceListLink.export(outfile, level, namespace_, name_='EndDeviceListLink', pretty_print=pretty_print) - if self.MirrorUsagePointListLink is not None: - self.MirrorUsagePointListLink.export(outfile, level, namespace_, name_='MirrorUsagePointListLink', pretty_print=pretty_print) - if self.SelfDeviceLink is not None: - self.SelfDeviceLink.export(outfile, level, namespace_, name_='SelfDeviceLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='DeviceCapability'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(DeviceCapability, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(DeviceCapability, self).exportLiteralChildren(outfile, level, name_) - if self.EndDeviceListLink is not None: - showIndent(outfile, level) - outfile.write('EndDeviceListLink=model_.EndDeviceListLink(\n') - self.EndDeviceListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.MirrorUsagePointListLink is not None: - showIndent(outfile, level) - outfile.write('MirrorUsagePointListLink=model_.MirrorUsagePointListLink(\n') - self.MirrorUsagePointListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.SelfDeviceLink is not None: - showIndent(outfile, level) - outfile.write('SelfDeviceLink=model_.SelfDeviceLink(\n') - self.SelfDeviceLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(DeviceCapability, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'EndDeviceListLink': - obj_ = EndDeviceListLink.factory() - obj_.build(child_) - self.EndDeviceListLink = obj_ - obj_.original_tagname_ = 'EndDeviceListLink' - elif nodeName_ == 'MirrorUsagePointListLink': - obj_ = MirrorUsagePointListLink.factory() - obj_.build(child_) - self.MirrorUsagePointListLink = obj_ - obj_.original_tagname_ = 'MirrorUsagePointListLink' - elif nodeName_ == 'SelfDeviceLink': - obj_ = SelfDeviceLink.factory() - obj_.build(child_) - self.SelfDeviceLink = obj_ - obj_.original_tagname_ = 'SelfDeviceLink' - super(DeviceCapability, self).buildChildren(child_, node, nodeName_, True) -# end class DeviceCapability - - -class UsagePointBase(IdentifiedObject): - """Logical point on a network at which consumption or production is - either physically measured (e.g. metered) or estimated (e.g. - unmetered street lights). A container for associating - ReadingType, Readings and ReadingSets.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, roleFlags=None, serviceCategoryKind=None, status=None): - self.original_tagname_ = None - super(UsagePointBase, self).__init__() - self.roleFlags = roleFlags - self.serviceCategoryKind = serviceCategoryKind - self.status = status - def factory(*args_, **kwargs_): - if UsagePointBase.subclass: - return UsagePointBase.subclass(*args_, **kwargs_) - else: - return UsagePointBase(*args_, **kwargs_) - factory = staticmethod(factory) - def get_roleFlags(self): return self.roleFlags - def set_roleFlags(self, roleFlags): self.roleFlags = roleFlags - def get_serviceCategoryKind(self): return self.serviceCategoryKind - def set_serviceCategoryKind(self, serviceCategoryKind): self.serviceCategoryKind = serviceCategoryKind - def get_status(self): return self.status - def set_status(self, status): self.status = status - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.roleFlags is not None or - self.serviceCategoryKind is not None or - self.status is not None or - super(UsagePointBase, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UsagePointBase', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePointBase') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='UsagePointBase', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UsagePointBase'): - super(UsagePointBase, self).exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePointBase') - def exportChildren(self, outfile, level, namespace_='', name_='UsagePointBase', fromsubclass_=False, pretty_print=True): - super(UsagePointBase, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.roleFlags is not None: - self.roleFlags.export(outfile, level, namespace_, name_='roleFlags', pretty_print=pretty_print) - if self.serviceCategoryKind is not None: - self.serviceCategoryKind.export(outfile, level, namespace_, name_='serviceCategoryKind', pretty_print=pretty_print) - if self.status is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sstatus>%s%s' % (namespace_, self.gds_format_integer(self.status, input_name='status'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='UsagePointBase'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(UsagePointBase, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(UsagePointBase, self).exportLiteralChildren(outfile, level, name_) - if self.roleFlags is not None: - showIndent(outfile, level) - outfile.write('roleFlags=model_.RoleFlagsType(\n') - self.roleFlags.exportLiteral(outfile, level, name_='roleFlags') - showIndent(outfile, level) - outfile.write('),\n') - if self.serviceCategoryKind is not None: - showIndent(outfile, level) - outfile.write('serviceCategoryKind=model_.ServiceKind(\n') - self.serviceCategoryKind.exportLiteral(outfile, level, name_='serviceCategoryKind') - showIndent(outfile, level) - outfile.write('),\n') - if self.status is not None: - showIndent(outfile, level) - outfile.write('status=%d,\n' % self.status) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(UsagePointBase, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'roleFlags': - obj_ = RoleFlagsType.factory() - obj_.build(child_) - self.roleFlags = obj_ - obj_.original_tagname_ = 'roleFlags' - elif nodeName_ == 'serviceCategoryKind': - obj_ = ServiceKind.factory() - obj_.build(child_) - self.serviceCategoryKind = obj_ - obj_.original_tagname_ = 'serviceCategoryKind' - elif nodeName_ == 'status': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'status') - self.status = ival_ - self.validate_UInt8(self.status) # validate type UInt8 - super(UsagePointBase, self).buildChildren(child_, node, nodeName_, True) -# end class UsagePointBase - - -class ReadingSetBase(IdentifiedObject): - """A set of Readings of the ReadingType indicated by the parent - MeterReading. ReadingBase is abstract, used to define the - elements common to ReadingSet and IntervalBlock.""" - subclass = None - superclass = IdentifiedObject - def __init__(self, timePeriod=None): - self.original_tagname_ = None - super(ReadingSetBase, self).__init__() - self.timePeriod = timePeriod - def factory(*args_, **kwargs_): - if ReadingSetBase.subclass: - return ReadingSetBase.subclass(*args_, **kwargs_) - else: - return ReadingSetBase(*args_, **kwargs_) - factory = staticmethod(factory) - def get_timePeriod(self): return self.timePeriod - def set_timePeriod(self, timePeriod): self.timePeriod = timePeriod - def hasContent_(self): - if ( - self.timePeriod is not None or - super(ReadingSetBase, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingSetBase', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingSetBase') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingSetBase', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingSetBase'): - super(ReadingSetBase, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingSetBase') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingSetBase', fromsubclass_=False, pretty_print=True): - super(ReadingSetBase, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.timePeriod is not None: - self.timePeriod.export(outfile, level, namespace_, name_='timePeriod', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ReadingSetBase'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingSetBase, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingSetBase, self).exportLiteralChildren(outfile, level, name_) - if self.timePeriod is not None: - showIndent(outfile, level) - outfile.write('timePeriod=model_.DateTimeInterval(\n') - self.timePeriod.exportLiteral(outfile, level, name_='timePeriod') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingSetBase, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'timePeriod': - obj_ = DateTimeInterval.factory() - obj_.build(child_) - self.timePeriod = obj_ - obj_.original_tagname_ = 'timePeriod' - super(ReadingSetBase, self).buildChildren(child_, node, nodeName_, True) -# end class ReadingSetBase - - -class MirrorUsagePointList(List): - """A List of MirrorUsagePoint instances.""" - subclass = None - superclass = List - def __init__(self, MirrorUsagePoint=None): - self.original_tagname_ = None - super(MirrorUsagePointList, self).__init__() - if MirrorUsagePoint is None: - self.MirrorUsagePoint = [] - else: - self.MirrorUsagePoint = MirrorUsagePoint - def factory(*args_, **kwargs_): - if MirrorUsagePointList.subclass: - return MirrorUsagePointList.subclass(*args_, **kwargs_) - else: - return MirrorUsagePointList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_MirrorUsagePoint(self): return self.MirrorUsagePoint - def set_MirrorUsagePoint(self, MirrorUsagePoint): self.MirrorUsagePoint = MirrorUsagePoint - def add_MirrorUsagePoint(self, value): self.MirrorUsagePoint.append(value) - def insert_MirrorUsagePoint_at(self, index, value): self.MirrorUsagePoint.insert(index, value) - def replace_MirrorUsagePoint_at(self, index, value): self.MirrorUsagePoint[index] = value - def hasContent_(self): - if ( - self.MirrorUsagePoint or - super(MirrorUsagePointList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MirrorUsagePointList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorUsagePointList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MirrorUsagePointList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MirrorUsagePointList'): - super(MirrorUsagePointList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorUsagePointList') - def exportChildren(self, outfile, level, namespace_='', name_='MirrorUsagePointList', fromsubclass_=False, pretty_print=True): - super(MirrorUsagePointList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for MirrorUsagePoint_ in self.MirrorUsagePoint: - MirrorUsagePoint_.export(outfile, level, namespace_, name_='MirrorUsagePoint', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MirrorUsagePointList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MirrorUsagePointList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MirrorUsagePointList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('MirrorUsagePoint=[\n') - level += 1 - for MirrorUsagePoint_ in self.MirrorUsagePoint: - showIndent(outfile, level) - outfile.write('model_.MirrorUsagePoint(\n') - MirrorUsagePoint_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MirrorUsagePointList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'MirrorUsagePoint': - obj_ = MirrorUsagePoint.factory() - obj_.build(child_) - self.MirrorUsagePoint.append(obj_) - obj_.original_tagname_ = 'MirrorUsagePoint' - super(MirrorUsagePointList, self).buildChildren(child_, node, nodeName_, True) -# end class MirrorUsagePointList - - -class MirrorUsagePoint(UsagePointBase): - """A parallel to UsagePoint to support mirroring""" - subclass = None - superclass = UsagePointBase - def __init__(self, deviceLFDI=None, MirrorMeterReading=None): - self.original_tagname_ = None - super(MirrorUsagePoint, self).__init__() - self.deviceLFDI = deviceLFDI - if MirrorMeterReading is None: - self.MirrorMeterReading = [] - else: - self.MirrorMeterReading = MirrorMeterReading - def factory(*args_, **kwargs_): - if MirrorUsagePoint.subclass: - return MirrorUsagePoint.subclass(*args_, **kwargs_) - else: - return MirrorUsagePoint(*args_, **kwargs_) - factory = staticmethod(factory) - def get_deviceLFDI(self): return self.deviceLFDI - def set_deviceLFDI(self, deviceLFDI): self.deviceLFDI = deviceLFDI - def get_MirrorMeterReading(self): return self.MirrorMeterReading - def set_MirrorMeterReading(self, MirrorMeterReading): self.MirrorMeterReading = MirrorMeterReading - def add_MirrorMeterReading(self, value): self.MirrorMeterReading.append(value) - def insert_MirrorMeterReading_at(self, index, value): self.MirrorMeterReading.insert(index, value) - def replace_MirrorMeterReading_at(self, index, value): self.MirrorMeterReading[index] = value - def validate_HexBinary160(self, value): - # Validate type HexBinary160, a restriction on xs:hexBinary. - pass - def hasContent_(self): - if ( - self.deviceLFDI is not None or - self.MirrorMeterReading or - super(MirrorUsagePoint, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MirrorUsagePoint', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorUsagePoint') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MirrorUsagePoint', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MirrorUsagePoint'): - super(MirrorUsagePoint, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorUsagePoint') - def exportChildren(self, outfile, level, namespace_='', name_='MirrorUsagePoint', fromsubclass_=False, pretty_print=True): - super(MirrorUsagePoint, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.deviceLFDI is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdeviceLFDI>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.deviceLFDI).encode(ExternalEncoding), input_name='deviceLFDI'), namespace_, eol_)) - for MirrorMeterReading_ in self.MirrorMeterReading: - MirrorMeterReading_.export(outfile, level, namespace_, name_='MirrorMeterReading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MirrorUsagePoint'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MirrorUsagePoint, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MirrorUsagePoint, self).exportLiteralChildren(outfile, level, name_) - if self.deviceLFDI is not None: - showIndent(outfile, level) - outfile.write('deviceLFDI=%s,\n' % quote_python(self.deviceLFDI).encode(ExternalEncoding)) - showIndent(outfile, level) - outfile.write('MirrorMeterReading=[\n') - level += 1 - for MirrorMeterReading_ in self.MirrorMeterReading: - showIndent(outfile, level) - outfile.write('model_.MirrorMeterReading(\n') - MirrorMeterReading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MirrorUsagePoint, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'deviceLFDI': - deviceLFDI_ = child_.text - deviceLFDI_ = self.gds_validate_string(deviceLFDI_, node, 'deviceLFDI') - self.deviceLFDI = deviceLFDI_ - self.validate_HexBinary160(self.deviceLFDI) # validate type HexBinary160 - elif nodeName_ == 'MirrorMeterReading': - obj_ = MirrorMeterReading.factory() - obj_.build(child_) - self.MirrorMeterReading.append(obj_) - obj_.original_tagname_ = 'MirrorMeterReading' - super(MirrorUsagePoint, self).buildChildren(child_, node, nodeName_, True) -# end class MirrorUsagePoint - - -class MirrorReadingSet(ReadingSetBase): - """A set of Readings of the ReadingType indicated by the parent - MeterReading.""" - subclass = None - superclass = ReadingSetBase - def __init__(self, Reading=None): - self.original_tagname_ = None - super(MirrorReadingSet, self).__init__() - if Reading is None: - self.Reading = [] - else: - self.Reading = Reading - def factory(*args_, **kwargs_): - if MirrorReadingSet.subclass: - return MirrorReadingSet.subclass(*args_, **kwargs_) - else: - return MirrorReadingSet(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Reading(self): return self.Reading - def set_Reading(self, Reading): self.Reading = Reading - def add_Reading(self, value): self.Reading.append(value) - def insert_Reading_at(self, index, value): self.Reading.insert(index, value) - def replace_Reading_at(self, index, value): self.Reading[index] = value - def hasContent_(self): - if ( - self.Reading or - super(MirrorReadingSet, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MirrorReadingSet', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorReadingSet') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MirrorReadingSet', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MirrorReadingSet'): - super(MirrorReadingSet, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorReadingSet') - def exportChildren(self, outfile, level, namespace_='', name_='MirrorReadingSet', fromsubclass_=False, pretty_print=True): - super(MirrorReadingSet, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for Reading_ in self.Reading: - Reading_.export(outfile, level, namespace_, name_='Reading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MirrorReadingSet'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MirrorReadingSet, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MirrorReadingSet, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('Reading=[\n') - level += 1 - for Reading_ in self.Reading: - showIndent(outfile, level) - outfile.write('model_.Reading(\n') - Reading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MirrorReadingSet, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Reading': - obj_ = Reading.factory() - obj_.build(child_) - self.Reading.append(obj_) - obj_.original_tagname_ = 'Reading' - super(MirrorReadingSet, self).buildChildren(child_, node, nodeName_, True) -# end class MirrorReadingSet - - -class MeterReadingBase(IdentifiedObject): - """A container for associating ReadingType, Readings and ReadingSets.""" - subclass = None - superclass = IdentifiedObject - def __init__(self): - self.original_tagname_ = None - super(MeterReadingBase, self).__init__() - def factory(*args_, **kwargs_): - if MeterReadingBase.subclass: - return MeterReadingBase.subclass(*args_, **kwargs_) - else: - return MeterReadingBase(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(MeterReadingBase, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MeterReadingBase', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReadingBase') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MeterReadingBase', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MeterReadingBase'): - super(MeterReadingBase, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReadingBase') - def exportChildren(self, outfile, level, namespace_='', name_='MeterReadingBase', fromsubclass_=False, pretty_print=True): - super(MeterReadingBase, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='MeterReadingBase'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MeterReadingBase, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MeterReadingBase, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MeterReadingBase, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(MeterReadingBase, self).buildChildren(child_, node, nodeName_, True) - pass -# end class MeterReadingBase - - -class MirrorMeterReadingList(List): - """A List of MirrorMeterReading instances.""" - subclass = None - superclass = List - def __init__(self, MirrorMeterReading=None): - self.original_tagname_ = None - super(MirrorMeterReadingList, self).__init__() - if MirrorMeterReading is None: - self.MirrorMeterReading = [] - else: - self.MirrorMeterReading = MirrorMeterReading - def factory(*args_, **kwargs_): - if MirrorMeterReadingList.subclass: - return MirrorMeterReadingList.subclass(*args_, **kwargs_) - else: - return MirrorMeterReadingList(*args_, **kwargs_) - factory = staticmethod(factory) - def get_MirrorMeterReading(self): return self.MirrorMeterReading - def set_MirrorMeterReading(self, MirrorMeterReading): self.MirrorMeterReading = MirrorMeterReading - def add_MirrorMeterReading(self, value): self.MirrorMeterReading.append(value) - def insert_MirrorMeterReading_at(self, index, value): self.MirrorMeterReading.insert(index, value) - def replace_MirrorMeterReading_at(self, index, value): self.MirrorMeterReading[index] = value - def hasContent_(self): - if ( - self.MirrorMeterReading or - super(MirrorMeterReadingList, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MirrorMeterReadingList', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorMeterReadingList') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MirrorMeterReadingList', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MirrorMeterReadingList'): - super(MirrorMeterReadingList, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorMeterReadingList') - def exportChildren(self, outfile, level, namespace_='', name_='MirrorMeterReadingList', fromsubclass_=False, pretty_print=True): - super(MirrorMeterReadingList, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - for MirrorMeterReading_ in self.MirrorMeterReading: - MirrorMeterReading_.export(outfile, level, namespace_, name_='MirrorMeterReading', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MirrorMeterReadingList'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MirrorMeterReadingList, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MirrorMeterReadingList, self).exportLiteralChildren(outfile, level, name_) - showIndent(outfile, level) - outfile.write('MirrorMeterReading=[\n') - level += 1 - for MirrorMeterReading_ in self.MirrorMeterReading: - showIndent(outfile, level) - outfile.write('model_.MirrorMeterReading(\n') - MirrorMeterReading_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MirrorMeterReadingList, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'MirrorMeterReading': - obj_ = MirrorMeterReading.factory() - obj_.build(child_) - self.MirrorMeterReading.append(obj_) - obj_.original_tagname_ = 'MirrorMeterReading' - super(MirrorMeterReadingList, self).buildChildren(child_, node, nodeName_, True) -# end class MirrorMeterReadingList - - -class MirrorMeterReading(MeterReadingBase): - """Mimic of MeterReading used for managing mirrors.""" - subclass = None - superclass = MeterReadingBase - def __init__(self, lastUpdateTime=None, MirrorReadingSet=None, nextUpdateTime=None, Reading=None, ReadingType=None): - self.original_tagname_ = None - super(MirrorMeterReading, self).__init__() - self.lastUpdateTime = lastUpdateTime - if MirrorReadingSet is None: - self.MirrorReadingSet = [] - else: - self.MirrorReadingSet = MirrorReadingSet - self.nextUpdateTime = nextUpdateTime - self.Reading = Reading - self.ReadingType = ReadingType - def factory(*args_, **kwargs_): - if MirrorMeterReading.subclass: - return MirrorMeterReading.subclass(*args_, **kwargs_) - else: - return MirrorMeterReading(*args_, **kwargs_) - factory = staticmethod(factory) - def get_lastUpdateTime(self): return self.lastUpdateTime - def set_lastUpdateTime(self, lastUpdateTime): self.lastUpdateTime = lastUpdateTime - def get_MirrorReadingSet(self): return self.MirrorReadingSet - def set_MirrorReadingSet(self, MirrorReadingSet): self.MirrorReadingSet = MirrorReadingSet - def add_MirrorReadingSet(self, value): self.MirrorReadingSet.append(value) - def insert_MirrorReadingSet_at(self, index, value): self.MirrorReadingSet.insert(index, value) - def replace_MirrorReadingSet_at(self, index, value): self.MirrorReadingSet[index] = value - def get_nextUpdateTime(self): return self.nextUpdateTime - def set_nextUpdateTime(self, nextUpdateTime): self.nextUpdateTime = nextUpdateTime - def get_Reading(self): return self.Reading - def set_Reading(self, Reading): self.Reading = Reading - def get_ReadingType(self): return self.ReadingType - def set_ReadingType(self, ReadingType): self.ReadingType = ReadingType - def hasContent_(self): - if ( - self.lastUpdateTime is not None or - self.MirrorReadingSet or - self.nextUpdateTime is not None or - self.Reading is not None or - self.ReadingType is not None or - super(MirrorMeterReading, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MirrorMeterReading', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorMeterReading') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MirrorMeterReading', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MirrorMeterReading'): - super(MirrorMeterReading, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MirrorMeterReading') - def exportChildren(self, outfile, level, namespace_='', name_='MirrorMeterReading', fromsubclass_=False, pretty_print=True): - super(MirrorMeterReading, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.lastUpdateTime is not None: - self.lastUpdateTime.export(outfile, level, namespace_, name_='lastUpdateTime', pretty_print=pretty_print) - for MirrorReadingSet_ in self.MirrorReadingSet: - MirrorReadingSet_.export(outfile, level, namespace_, name_='MirrorReadingSet', pretty_print=pretty_print) - if self.nextUpdateTime is not None: - self.nextUpdateTime.export(outfile, level, namespace_, name_='nextUpdateTime', pretty_print=pretty_print) - if self.Reading is not None: - self.Reading.export(outfile, level, namespace_, name_='Reading', pretty_print=pretty_print) - if self.ReadingType is not None: - self.ReadingType.export(outfile, level, namespace_, name_='ReadingType', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MirrorMeterReading'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MirrorMeterReading, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MirrorMeterReading, self).exportLiteralChildren(outfile, level, name_) - if self.lastUpdateTime is not None: - showIndent(outfile, level) - outfile.write('lastUpdateTime=model_.TimeType(\n') - self.lastUpdateTime.exportLiteral(outfile, level, name_='lastUpdateTime') - showIndent(outfile, level) - outfile.write('),\n') - showIndent(outfile, level) - outfile.write('MirrorReadingSet=[\n') - level += 1 - for MirrorReadingSet_ in self.MirrorReadingSet: - showIndent(outfile, level) - outfile.write('model_.MirrorReadingSet(\n') - MirrorReadingSet_.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - level -= 1 - showIndent(outfile, level) - outfile.write('],\n') - if self.nextUpdateTime is not None: - showIndent(outfile, level) - outfile.write('nextUpdateTime=model_.TimeType(\n') - self.nextUpdateTime.exportLiteral(outfile, level, name_='nextUpdateTime') - showIndent(outfile, level) - outfile.write('),\n') - if self.Reading is not None: - showIndent(outfile, level) - outfile.write('Reading=model_.Reading(\n') - self.Reading.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ReadingType is not None: - showIndent(outfile, level) - outfile.write('ReadingType=model_.ReadingType(\n') - self.ReadingType.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MirrorMeterReading, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'lastUpdateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.lastUpdateTime = obj_ - obj_.original_tagname_ = 'lastUpdateTime' - elif nodeName_ == 'MirrorReadingSet': - obj_ = MirrorReadingSet.factory() - obj_.build(child_) - self.MirrorReadingSet.append(obj_) - obj_.original_tagname_ = 'MirrorReadingSet' - elif nodeName_ == 'nextUpdateTime': - obj_ = TimeType.factory() - obj_.build(child_) - self.nextUpdateTime = obj_ - obj_.original_tagname_ = 'nextUpdateTime' - elif nodeName_ == 'Reading': - obj_ = Reading.factory() - obj_.build(child_) - self.Reading = obj_ - obj_.original_tagname_ = 'Reading' - elif nodeName_ == 'ReadingType': - obj_ = ReadingType.factory() - obj_.build(child_) - self.ReadingType = obj_ - obj_.original_tagname_ = 'ReadingType' - super(MirrorMeterReading, self).buildChildren(child_, node, nodeName_, True) -# end class MirrorMeterReading - - -class BillingReadingSet(ReadingSetBase): - """Time sequence of readings of the same reading type.""" - subclass = None - superclass = ReadingSetBase - def __init__(self, BillingReadingListLink=None): - self.original_tagname_ = None - super(BillingReadingSet, self).__init__() - self.BillingReadingListLink = BillingReadingListLink - def factory(*args_, **kwargs_): - if BillingReadingSet.subclass: - return BillingReadingSet.subclass(*args_, **kwargs_) - else: - return BillingReadingSet(*args_, **kwargs_) - factory = staticmethod(factory) - def get_BillingReadingListLink(self): return self.BillingReadingListLink - def set_BillingReadingListLink(self, BillingReadingListLink): self.BillingReadingListLink = BillingReadingListLink - def hasContent_(self): - if ( - self.BillingReadingListLink is not None or - super(BillingReadingSet, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingReadingSet', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingSet') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingReadingSet', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingReadingSet'): - super(BillingReadingSet, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingReadingSet') - def exportChildren(self, outfile, level, namespace_='', name_='BillingReadingSet', fromsubclass_=False, pretty_print=True): - super(BillingReadingSet, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.BillingReadingListLink is not None: - self.BillingReadingListLink.export(outfile, level, namespace_, name_='BillingReadingListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='BillingReadingSet'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingReadingSet, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingReadingSet, self).exportLiteralChildren(outfile, level, name_) - if self.BillingReadingListLink is not None: - showIndent(outfile, level) - outfile.write('BillingReadingListLink=model_.BillingReadingListLink(\n') - self.BillingReadingListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingReadingSet, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'BillingReadingListLink': - obj_ = BillingReadingListLink.factory() - obj_.build(child_) - self.BillingReadingListLink = obj_ - obj_.original_tagname_ = 'BillingReadingListLink' - super(BillingReadingSet, self).buildChildren(child_, node, nodeName_, True) -# end class BillingReadingSet - - -class BillingMeterReadingBase(MeterReadingBase): - """Contains historical, target, and projection readings of various - types, possibly associated with charges.""" - subclass = None - superclass = MeterReadingBase - def __init__(self, BillingReadingSetListLink=None, ReadingTypeLink=None): - self.original_tagname_ = None - super(BillingMeterReadingBase, self).__init__() - self.BillingReadingSetListLink = BillingReadingSetListLink - self.ReadingTypeLink = ReadingTypeLink - def factory(*args_, **kwargs_): - if BillingMeterReadingBase.subclass: - return BillingMeterReadingBase.subclass(*args_, **kwargs_) - else: - return BillingMeterReadingBase(*args_, **kwargs_) - factory = staticmethod(factory) - def get_BillingReadingSetListLink(self): return self.BillingReadingSetListLink - def set_BillingReadingSetListLink(self, BillingReadingSetListLink): self.BillingReadingSetListLink = BillingReadingSetListLink - def get_ReadingTypeLink(self): return self.ReadingTypeLink - def set_ReadingTypeLink(self, ReadingTypeLink): self.ReadingTypeLink = ReadingTypeLink - def hasContent_(self): - if ( - self.BillingReadingSetListLink is not None or - self.ReadingTypeLink is not None or - super(BillingMeterReadingBase, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='BillingMeterReadingBase', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='BillingMeterReadingBase') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='BillingMeterReadingBase', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='BillingMeterReadingBase'): - super(BillingMeterReadingBase, self).exportAttributes(outfile, level, already_processed, namespace_, name_='BillingMeterReadingBase') - def exportChildren(self, outfile, level, namespace_='', name_='BillingMeterReadingBase', fromsubclass_=False, pretty_print=True): - super(BillingMeterReadingBase, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.BillingReadingSetListLink is not None: - self.BillingReadingSetListLink.export(outfile, level, namespace_, name_='BillingReadingSetListLink', pretty_print=pretty_print) - if self.ReadingTypeLink is not None: - self.ReadingTypeLink.export(outfile, level, namespace_, name_='ReadingTypeLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='BillingMeterReadingBase'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(BillingMeterReadingBase, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(BillingMeterReadingBase, self).exportLiteralChildren(outfile, level, name_) - if self.BillingReadingSetListLink is not None: - showIndent(outfile, level) - outfile.write('BillingReadingSetListLink=model_.BillingReadingSetListLink(\n') - self.BillingReadingSetListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ReadingTypeLink is not None: - showIndent(outfile, level) - outfile.write('ReadingTypeLink=model_.ReadingTypeLink(\n') - self.ReadingTypeLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(BillingMeterReadingBase, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'BillingReadingSetListLink': - obj_ = BillingReadingSetListLink.factory() - obj_.build(child_) - self.BillingReadingSetListLink = obj_ - obj_.original_tagname_ = 'BillingReadingSetListLink' - elif nodeName_ == 'ReadingTypeLink': - obj_ = ReadingTypeLink.factory() - obj_.build(child_) - self.ReadingTypeLink = obj_ - obj_.original_tagname_ = 'ReadingTypeLink' - super(BillingMeterReadingBase, self).buildChildren(child_, node, nodeName_, True) -# end class BillingMeterReadingBase - - -class UsagePoint(UsagePointBase): - """Logical point on a network at which consumption or production is - either physically measured (e.g. metered) or estimated (e.g. - unmetered street lights).""" - subclass = None - superclass = UsagePointBase - def __init__(self, MeterReadingListLink=None): - self.original_tagname_ = None - super(UsagePoint, self).__init__() - self.MeterReadingListLink = MeterReadingListLink - def factory(*args_, **kwargs_): - if UsagePoint.subclass: - return UsagePoint.subclass(*args_, **kwargs_) - else: - return UsagePoint(*args_, **kwargs_) - factory = staticmethod(factory) - def get_MeterReadingListLink(self): return self.MeterReadingListLink - def set_MeterReadingListLink(self, MeterReadingListLink): self.MeterReadingListLink = MeterReadingListLink - def hasContent_(self): - if ( - self.MeterReadingListLink is not None or - super(UsagePoint, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='UsagePoint', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePoint') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='UsagePoint', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='UsagePoint'): - super(UsagePoint, self).exportAttributes(outfile, level, already_processed, namespace_, name_='UsagePoint') - def exportChildren(self, outfile, level, namespace_='', name_='UsagePoint', fromsubclass_=False, pretty_print=True): - super(UsagePoint, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.MeterReadingListLink is not None: - self.MeterReadingListLink.export(outfile, level, namespace_, name_='MeterReadingListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='UsagePoint'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(UsagePoint, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(UsagePoint, self).exportLiteralChildren(outfile, level, name_) - if self.MeterReadingListLink is not None: - showIndent(outfile, level) - outfile.write('MeterReadingListLink=model_.MeterReadingListLink(\n') - self.MeterReadingListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(UsagePoint, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'MeterReadingListLink': - obj_ = MeterReadingListLink.factory() - obj_.build(child_) - self.MeterReadingListLink = obj_ - obj_.original_tagname_ = 'MeterReadingListLink' - super(UsagePoint, self).buildChildren(child_, node, nodeName_, True) -# end class UsagePoint - - -class ReadingSet(ReadingSetBase): - """A set of Readings of the ReadingType indicated by the parent - MeterReading.""" - subclass = None - superclass = ReadingSetBase - def __init__(self, ReadingListLink=None): - self.original_tagname_ = None - super(ReadingSet, self).__init__() - self.ReadingListLink = ReadingListLink - def factory(*args_, **kwargs_): - if ReadingSet.subclass: - return ReadingSet.subclass(*args_, **kwargs_) - else: - return ReadingSet(*args_, **kwargs_) - factory = staticmethod(factory) - def get_ReadingListLink(self): return self.ReadingListLink - def set_ReadingListLink(self, ReadingListLink): self.ReadingListLink = ReadingListLink - def hasContent_(self): - if ( - self.ReadingListLink is not None or - super(ReadingSet, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ReadingSet', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingSet') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ReadingSet', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ReadingSet'): - super(ReadingSet, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ReadingSet') - def exportChildren(self, outfile, level, namespace_='', name_='ReadingSet', fromsubclass_=False, pretty_print=True): - super(ReadingSet, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.ReadingListLink is not None: - self.ReadingListLink.export(outfile, level, namespace_, name_='ReadingListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='ReadingSet'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ReadingSet, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ReadingSet, self).exportLiteralChildren(outfile, level, name_) - if self.ReadingListLink is not None: - showIndent(outfile, level) - outfile.write('ReadingListLink=model_.ReadingListLink(\n') - self.ReadingListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ReadingSet, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'ReadingListLink': - obj_ = ReadingListLink.factory() - obj_.build(child_) - self.ReadingListLink = obj_ - obj_.original_tagname_ = 'ReadingListLink' - super(ReadingSet, self).buildChildren(child_, node, nodeName_, True) -# end class ReadingSet - - -class MeterReading(MeterReadingBase): - """Set of values obtained from the meter.""" - subclass = None - superclass = MeterReadingBase - def __init__(self, RateComponentListLink=None, ReadingLink=None, ReadingSetListLink=None, ReadingTypeLink=None): - self.original_tagname_ = None - super(MeterReading, self).__init__() - self.RateComponentListLink = RateComponentListLink - self.ReadingLink = ReadingLink - self.ReadingSetListLink = ReadingSetListLink - self.ReadingTypeLink = ReadingTypeLink - def factory(*args_, **kwargs_): - if MeterReading.subclass: - return MeterReading.subclass(*args_, **kwargs_) - else: - return MeterReading(*args_, **kwargs_) - factory = staticmethod(factory) - def get_RateComponentListLink(self): return self.RateComponentListLink - def set_RateComponentListLink(self, RateComponentListLink): self.RateComponentListLink = RateComponentListLink - def get_ReadingLink(self): return self.ReadingLink - def set_ReadingLink(self, ReadingLink): self.ReadingLink = ReadingLink - def get_ReadingSetListLink(self): return self.ReadingSetListLink - def set_ReadingSetListLink(self, ReadingSetListLink): self.ReadingSetListLink = ReadingSetListLink - def get_ReadingTypeLink(self): return self.ReadingTypeLink - def set_ReadingTypeLink(self, ReadingTypeLink): self.ReadingTypeLink = ReadingTypeLink - def hasContent_(self): - if ( - self.RateComponentListLink is not None or - self.ReadingLink is not None or - self.ReadingSetListLink is not None or - self.ReadingTypeLink is not None or - super(MeterReading, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='MeterReading', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReading') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='MeterReading', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='MeterReading'): - super(MeterReading, self).exportAttributes(outfile, level, already_processed, namespace_, name_='MeterReading') - def exportChildren(self, outfile, level, namespace_='', name_='MeterReading', fromsubclass_=False, pretty_print=True): - super(MeterReading, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.RateComponentListLink is not None: - self.RateComponentListLink.export(outfile, level, namespace_, name_='RateComponentListLink', pretty_print=pretty_print) - if self.ReadingLink is not None: - self.ReadingLink.export(outfile, level, namespace_, name_='ReadingLink', pretty_print=pretty_print) - if self.ReadingSetListLink is not None: - self.ReadingSetListLink.export(outfile, level, namespace_, name_='ReadingSetListLink', pretty_print=pretty_print) - if self.ReadingTypeLink is not None: - self.ReadingTypeLink.export(outfile, level, namespace_, name_='ReadingTypeLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='MeterReading'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(MeterReading, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(MeterReading, self).exportLiteralChildren(outfile, level, name_) - if self.RateComponentListLink is not None: - showIndent(outfile, level) - outfile.write('RateComponentListLink=model_.RateComponentListLink(\n') - self.RateComponentListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ReadingLink is not None: - showIndent(outfile, level) - outfile.write('ReadingLink=model_.ReadingLink(\n') - self.ReadingLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ReadingSetListLink is not None: - showIndent(outfile, level) - outfile.write('ReadingSetListLink=model_.ReadingSetListLink(\n') - self.ReadingSetListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.ReadingTypeLink is not None: - showIndent(outfile, level) - outfile.write('ReadingTypeLink=model_.ReadingTypeLink(\n') - self.ReadingTypeLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(MeterReading, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'RateComponentListLink': - obj_ = RateComponentListLink.factory() - obj_.build(child_) - self.RateComponentListLink = obj_ - obj_.original_tagname_ = 'RateComponentListLink' - elif nodeName_ == 'ReadingLink': - obj_ = ReadingLink.factory() - obj_.build(child_) - self.ReadingLink = obj_ - obj_.original_tagname_ = 'ReadingLink' - elif nodeName_ == 'ReadingSetListLink': - obj_ = ReadingSetListLink.factory() - obj_.build(child_) - self.ReadingSetListLink = obj_ - obj_.original_tagname_ = 'ReadingSetListLink' - elif nodeName_ == 'ReadingTypeLink': - obj_ = ReadingTypeLink.factory() - obj_.build(child_) - self.ReadingTypeLink = obj_ - obj_.original_tagname_ = 'ReadingTypeLink' - super(MeterReading, self).buildChildren(child_, node, nodeName_, True) -# end class MeterReading - - -class TextResponse(Response): - """A response to a text message""" - subclass = None - superclass = Response - def __init__(self): - self.original_tagname_ = None - super(TextResponse, self).__init__() - def factory(*args_, **kwargs_): - if TextResponse.subclass: - return TextResponse.subclass(*args_, **kwargs_) - else: - return TextResponse(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(TextResponse, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TextResponse', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TextResponse') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TextResponse', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TextResponse'): - super(TextResponse, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TextResponse') - def exportChildren(self, outfile, level, namespace_='', name_='TextResponse', fromsubclass_=False, pretty_print=True): - super(TextResponse, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='TextResponse'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TextResponse, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TextResponse, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TextResponse, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(TextResponse, self).buildChildren(child_, node, nodeName_, True) - pass -# end class TextResponse - - -class Notification(SubscriptionBase): - """Holds the information related to a client subscription to receive - updates to a resource automatically. The actual resources may be - passed in the Notification by specifying a specific xsi:type for - the Resource and passing the full representation.""" - subclass = None - superclass = SubscriptionBase - def __init__(self, newResourceURI=None, Resource=None, status=None, subscriptionURI=None): - self.original_tagname_ = None - super(Notification, self).__init__() - self.newResourceURI = newResourceURI - self.Resource = Resource - self.status = status - self.subscriptionURI = subscriptionURI - def factory(*args_, **kwargs_): - if Notification.subclass: - return Notification.subclass(*args_, **kwargs_) - else: - return Notification(*args_, **kwargs_) - factory = staticmethod(factory) - def get_newResourceURI(self): return self.newResourceURI - def set_newResourceURI(self, newResourceURI): self.newResourceURI = newResourceURI - def get_Resource(self): return self.Resource - def set_Resource(self, Resource): self.Resource = Resource - def get_status(self): return self.status - def set_status(self, status): self.status = status - def get_subscriptionURI(self): return self.subscriptionURI - def set_subscriptionURI(self, subscriptionURI): self.subscriptionURI = subscriptionURI - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def hasContent_(self): - if ( - self.newResourceURI is not None or - self.Resource is not None or - self.status is not None or - self.subscriptionURI is not None or - super(Notification, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Notification', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Notification') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Notification', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Notification'): - super(Notification, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Notification') - def exportChildren(self, outfile, level, namespace_='', name_='Notification', fromsubclass_=False, pretty_print=True): - super(Notification, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.newResourceURI is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%snewResourceURI>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.newResourceURI).encode(ExternalEncoding), input_name='newResourceURI'), namespace_, eol_)) - if self.Resource is not None: - self.Resource.export(outfile, level, namespace_, name_='Resource', pretty_print=pretty_print) - if self.status is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sstatus>%s%s' % (namespace_, self.gds_format_integer(self.status, input_name='status'), namespace_, eol_)) - if self.subscriptionURI is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%ssubscriptionURI>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.subscriptionURI).encode(ExternalEncoding), input_name='subscriptionURI'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Notification'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Notification, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Notification, self).exportLiteralChildren(outfile, level, name_) - if self.newResourceURI is not None: - showIndent(outfile, level) - outfile.write('newResourceURI=%s,\n' % quote_python(self.newResourceURI).encode(ExternalEncoding)) - if self.Resource is not None: - showIndent(outfile, level) - outfile.write('Resource=model_.Resource(\n') - self.Resource.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.status is not None: - showIndent(outfile, level) - outfile.write('status=%d,\n' % self.status) - if self.subscriptionURI is not None: - showIndent(outfile, level) - outfile.write('subscriptionURI=%s,\n' % quote_python(self.subscriptionURI).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Notification, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'newResourceURI': - newResourceURI_ = child_.text - newResourceURI_ = self.gds_validate_string(newResourceURI_, node, 'newResourceURI') - self.newResourceURI = newResourceURI_ - elif nodeName_ == 'Resource': - class_obj_ = self.get_class_obj_(child_, Resource) - obj_ = class_obj_.factory() - obj_.build(child_) - self.Resource = obj_ - obj_.original_tagname_ = 'Resource' - elif nodeName_ == 'status': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'status') - self.status = ival_ - self.validate_UInt8(self.status) # validate type UInt8 - elif nodeName_ == 'subscriptionURI': - subscriptionURI_ = child_.text - subscriptionURI_ = self.gds_validate_string(subscriptionURI_, node, 'subscriptionURI') - self.subscriptionURI = subscriptionURI_ - super(Notification, self).buildChildren(child_, node, nodeName_, True) -# end class Notification - - -class Subscription(SubscriptionBase): - """Holds the information related to a client subscription to receive - updates to a resource automatically.""" - subclass = None - superclass = SubscriptionBase - def __init__(self, Condition=None, encoding=None, level=None, limit=None, notificationURI=None): - self.original_tagname_ = None - super(Subscription, self).__init__() - self.Condition = Condition - self.encoding = encoding - self.level = level - self.limit = limit - self.notificationURI = notificationURI - def factory(*args_, **kwargs_): - if Subscription.subclass: - return Subscription.subclass(*args_, **kwargs_) - else: - return Subscription(*args_, **kwargs_) - factory = staticmethod(factory) - def get_Condition(self): return self.Condition - def set_Condition(self, Condition): self.Condition = Condition - def get_encoding(self): return self.encoding - def set_encoding(self, encoding): self.encoding = encoding - def get_level(self): return self.level - def set_level(self, level): self.level = level - def get_limit(self): return self.limit - def set_limit(self, limit): self.limit = limit - def get_notificationURI(self): return self.notificationURI - def set_notificationURI(self, notificationURI): self.notificationURI = notificationURI - def validate_UInt8(self, value): - # Validate type UInt8, a restriction on xs:unsignedByte. - pass - def validate_String16(self, value): - # Validate type String16, a restriction on xs:string. - pass - def validate_UInt16(self, value): - # Validate type UInt16, a restriction on xs:unsignedShort. - pass - def hasContent_(self): - if ( - self.Condition is not None or - self.encoding is not None or - self.level is not None or - self.limit is not None or - self.notificationURI is not None or - super(Subscription, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='Subscription', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='Subscription') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='Subscription', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='Subscription'): - super(Subscription, self).exportAttributes(outfile, level, already_processed, namespace_, name_='Subscription') - def exportChildren(self, outfile, level, namespace_='', name_='Subscription', fromsubclass_=False, pretty_print=True): - super(Subscription, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.Condition is not None: - self.Condition.export(outfile, level, namespace_, name_='Condition', pretty_print=pretty_print) - if self.encoding is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sencoding>%s%s' % (namespace_, self.gds_format_integer(self.encoding, input_name='encoding'), namespace_, eol_)) - if self.level is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slevel>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.level).encode(ExternalEncoding), input_name='level'), namespace_, eol_)) - if self.limit is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%slimit>%s%s' % (namespace_, self.gds_format_integer(self.limit, input_name='limit'), namespace_, eol_)) - if self.notificationURI is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%snotificationURI>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.notificationURI).encode(ExternalEncoding), input_name='notificationURI'), namespace_, eol_)) - def exportLiteral(self, outfile, level, name_='Subscription'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(Subscription, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(Subscription, self).exportLiteralChildren(outfile, level, name_) - if self.Condition is not None: - showIndent(outfile, level) - outfile.write('Condition=model_.Condition(\n') - self.Condition.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.encoding is not None: - showIndent(outfile, level) - outfile.write('encoding=%d,\n' % self.encoding) - if self.level is not None: - showIndent(outfile, level) - outfile.write('level=%s,\n' % quote_python(self.level).encode(ExternalEncoding)) - if self.limit is not None: - showIndent(outfile, level) - outfile.write('limit=%d,\n' % self.limit) - if self.notificationURI is not None: - showIndent(outfile, level) - outfile.write('notificationURI=%s,\n' % quote_python(self.notificationURI).encode(ExternalEncoding)) - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(Subscription, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'Condition': - obj_ = Condition.factory() - obj_.build(child_) - self.Condition = obj_ - obj_.original_tagname_ = 'Condition' - elif nodeName_ == 'encoding': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'encoding') - self.encoding = ival_ - self.validate_UInt8(self.encoding) # validate type UInt8 - elif nodeName_ == 'level': - level_ = child_.text - level_ = self.gds_validate_string(level_, node, 'level') - self.level = level_ - self.validate_String16(self.level) # validate type String16 - elif nodeName_ == 'limit': - sval_ = child_.text - try: - ival_ = int(sval_) - except (TypeError, ValueError) as exp: - raise_parse_error(child_, 'requires integer: %s' % exp) - ival_ = self.gds_validate_integer(ival_, node, 'limit') - self.limit = ival_ - self.validate_UInt16(self.limit) # validate type UInt16 - elif nodeName_ == 'notificationURI': - notificationURI_ = child_.text - notificationURI_ = self.gds_validate_string(notificationURI_, node, 'notificationURI') - self.notificationURI = notificationURI_ - super(Subscription, self).buildChildren(child_, node, nodeName_, True) -# end class Subscription - - -class FunctionSetAssignments(FunctionSetAssignmentsBase): - """Provides an identifiable, subscribable collection of resources for a - particular device to consume.Indicates whether or not - subscriptions are supported for this resource, and whether or - not conditional (thresholds) are supported. If not specified, is - "not subscribable" (0).""" - subclass = None - superclass = FunctionSetAssignmentsBase - def __init__(self, subscribable='0', mRID=None, description=None, version=None): - self.original_tagname_ = None - super(FunctionSetAssignments, self).__init__() - self.subscribable = _cast(None, subscribable) - self.mRID = mRID - self.description = description - self.version = version - def factory(*args_, **kwargs_): - if FunctionSetAssignments.subclass: - return FunctionSetAssignments.subclass(*args_, **kwargs_) - else: - return FunctionSetAssignments(*args_, **kwargs_) - factory = staticmethod(factory) - def get_mRID(self): return self.mRID - def set_mRID(self, mRID): self.mRID = mRID - def get_description(self): return self.description - def set_description(self, description): self.description = description - def get_version(self): return self.version - def set_version(self, version): self.version = version - def get_subscribable(self): return self.subscribable - def set_subscribable(self, subscribable): self.subscribable = subscribable - def validate_String32(self, value): - # Validate type String32, a restriction on xs:string. - pass - def validate_SubscribableType(self, value): - # Validate type SubscribableType, a restriction on UInt8. - pass - def hasContent_(self): - if ( - self.mRID is not None or - self.description is not None or - self.version is not None or - super(FunctionSetAssignments, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='FunctionSetAssignments', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='FunctionSetAssignments') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='FunctionSetAssignments', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='FunctionSetAssignments'): - super(FunctionSetAssignments, self).exportAttributes(outfile, level, already_processed, namespace_, name_='FunctionSetAssignments') - if self.subscribable is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - outfile.write(' subscribable=%s' % (quote_attrib(self.subscribable), )) - def exportChildren(self, outfile, level, namespace_='', name_='FunctionSetAssignments', fromsubclass_=False, pretty_print=True): - super(FunctionSetAssignments, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.mRID is not None: - self.mRID.export(outfile, level, namespace_, name_='mRID', pretty_print=pretty_print) - if self.description is not None: - showIndent(outfile, level, pretty_print) - outfile.write('<%sdescription>%s%s' % (namespace_, self.gds_format_string(quote_xml(self.description).encode(ExternalEncoding), input_name='description'), namespace_, eol_)) - if self.version is not None: - self.version.export(outfile, level, namespace_, name_='version', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='FunctionSetAssignments'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - if self.subscribable is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - showIndent(outfile, level) - outfile.write('subscribable=%d,\n' % (self.subscribable,)) - super(FunctionSetAssignments, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(FunctionSetAssignments, self).exportLiteralChildren(outfile, level, name_) - if self.mRID is not None: - showIndent(outfile, level) - outfile.write('mRID=model_.mRIDType(\n') - self.mRID.exportLiteral(outfile, level, name_='mRID') - showIndent(outfile, level) - outfile.write('),\n') - if self.description is not None: - showIndent(outfile, level) - outfile.write('description=%s,\n' % quote_python(self.description).encode(ExternalEncoding)) - if self.version is not None: - showIndent(outfile, level) - outfile.write('version=model_.VersionType(\n') - self.version.exportLiteral(outfile, level, name_='version') - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - value = find_attr_value_('subscribable', node) - if value is not None and 'subscribable' not in already_processed: - already_processed.add('subscribable') - self.subscribable = value - self.validate_SubscribableType(self.subscribable) # validate type SubscribableType - super(FunctionSetAssignments, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'mRID': - obj_ = mRIDType.factory() - obj_.build(child_) - self.mRID = obj_ - obj_.original_tagname_ = 'mRID' - elif nodeName_ == 'description': - description_ = child_.text - description_ = self.gds_validate_string(description_, node, 'description') - self.description = description_ - self.validate_String32(self.description) # validate type String32 - elif nodeName_ == 'version': - obj_ = VersionType.factory() - obj_.build(child_) - self.version = obj_ - obj_.original_tagname_ = 'version' - super(FunctionSetAssignments, self).buildChildren(child_, node, nodeName_, True) -# end class FunctionSetAssignments - - -class SelfDevice(AbstractDevice): - """The EndDevice providing the resources available within the - DeviceCapabilities.""" - subclass = None - superclass = AbstractDevice - def __init__(self): - self.original_tagname_ = None - super(SelfDevice, self).__init__() - def factory(*args_, **kwargs_): - if SelfDevice.subclass: - return SelfDevice.subclass(*args_, **kwargs_) - else: - return SelfDevice(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(SelfDevice, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='SelfDevice', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='SelfDevice') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='SelfDevice', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='SelfDevice'): - super(SelfDevice, self).exportAttributes(outfile, level, already_processed, namespace_, name_='SelfDevice') - def exportChildren(self, outfile, level, namespace_='', name_='SelfDevice', fromsubclass_=False, pretty_print=True): - super(SelfDevice, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='SelfDevice'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(SelfDevice, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(SelfDevice, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(SelfDevice, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(SelfDevice, self).buildChildren(child_, node, nodeName_, True) - pass -# end class SelfDevice - - -class EndDevice(AbstractDevice): - """Asset container that performs one or more end device functions. - Contains information about individual devices in the network.""" - subclass = None - superclass = AbstractDevice - def __init__(self, FlowReservationRequestListLink=None, FlowReservationResponseListLink=None, FunctionSetAssignmentsListLink=None, RegistrationLink=None, SubscriptionListLink=None): - self.original_tagname_ = None - super(EndDevice, self).__init__() - self.FlowReservationRequestListLink = FlowReservationRequestListLink - self.FlowReservationResponseListLink = FlowReservationResponseListLink - self.FunctionSetAssignmentsListLink = FunctionSetAssignmentsListLink - self.RegistrationLink = RegistrationLink - self.SubscriptionListLink = SubscriptionListLink - def factory(*args_, **kwargs_): - if EndDevice.subclass: - return EndDevice.subclass(*args_, **kwargs_) - else: - return EndDevice(*args_, **kwargs_) - factory = staticmethod(factory) - def get_FlowReservationRequestListLink(self): return self.FlowReservationRequestListLink - def set_FlowReservationRequestListLink(self, FlowReservationRequestListLink): self.FlowReservationRequestListLink = FlowReservationRequestListLink - def get_FlowReservationResponseListLink(self): return self.FlowReservationResponseListLink - def set_FlowReservationResponseListLink(self, FlowReservationResponseListLink): self.FlowReservationResponseListLink = FlowReservationResponseListLink - def get_FunctionSetAssignmentsListLink(self): return self.FunctionSetAssignmentsListLink - def set_FunctionSetAssignmentsListLink(self, FunctionSetAssignmentsListLink): self.FunctionSetAssignmentsListLink = FunctionSetAssignmentsListLink - def get_RegistrationLink(self): return self.RegistrationLink - def set_RegistrationLink(self, RegistrationLink): self.RegistrationLink = RegistrationLink - def get_SubscriptionListLink(self): return self.SubscriptionListLink - def set_SubscriptionListLink(self, SubscriptionListLink): self.SubscriptionListLink = SubscriptionListLink - def hasContent_(self): - if ( - self.FlowReservationRequestListLink is not None or - self.FlowReservationResponseListLink is not None or - self.FunctionSetAssignmentsListLink is not None or - self.RegistrationLink is not None or - self.SubscriptionListLink is not None or - super(EndDevice, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='EndDevice', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='EndDevice') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='EndDevice', pretty_print=pretty_print) - showIndent(outfile, level, pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='EndDevice'): - super(EndDevice, self).exportAttributes(outfile, level, already_processed, namespace_, name_='EndDevice') - def exportChildren(self, outfile, level, namespace_='', name_='EndDevice', fromsubclass_=False, pretty_print=True): - super(EndDevice, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.FlowReservationRequestListLink is not None: - self.FlowReservationRequestListLink.export(outfile, level, namespace_, name_='FlowReservationRequestListLink', pretty_print=pretty_print) - if self.FlowReservationResponseListLink is not None: - self.FlowReservationResponseListLink.export(outfile, level, namespace_, name_='FlowReservationResponseListLink', pretty_print=pretty_print) - if self.FunctionSetAssignmentsListLink is not None: - self.FunctionSetAssignmentsListLink.export(outfile, level, namespace_, name_='FunctionSetAssignmentsListLink', pretty_print=pretty_print) - if self.RegistrationLink is not None: - self.RegistrationLink.export(outfile, level, namespace_, name_='RegistrationLink', pretty_print=pretty_print) - if self.SubscriptionListLink is not None: - self.SubscriptionListLink.export(outfile, level, namespace_, name_='SubscriptionListLink', pretty_print=pretty_print) - def exportLiteral(self, outfile, level, name_='EndDevice'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(EndDevice, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(EndDevice, self).exportLiteralChildren(outfile, level, name_) - if self.FlowReservationRequestListLink is not None: - showIndent(outfile, level) - outfile.write('FlowReservationRequestListLink=model_.FlowReservationRequestListLink(\n') - self.FlowReservationRequestListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.FlowReservationResponseListLink is not None: - showIndent(outfile, level) - outfile.write('FlowReservationResponseListLink=model_.FlowReservationResponseListLink(\n') - self.FlowReservationResponseListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.FunctionSetAssignmentsListLink is not None: - showIndent(outfile, level) - outfile.write('FunctionSetAssignmentsListLink=model_.FunctionSetAssignmentsListLink(\n') - self.FunctionSetAssignmentsListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.RegistrationLink is not None: - showIndent(outfile, level) - outfile.write('RegistrationLink=model_.RegistrationLink(\n') - self.RegistrationLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - if self.SubscriptionListLink is not None: - showIndent(outfile, level) - outfile.write('SubscriptionListLink=model_.SubscriptionListLink(\n') - self.SubscriptionListLink.exportLiteral(outfile, level) - showIndent(outfile, level) - outfile.write('),\n') - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(EndDevice, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - if nodeName_ == 'FlowReservationRequestListLink': - obj_ = FlowReservationRequestListLink.factory() - obj_.build(child_) - self.FlowReservationRequestListLink = obj_ - obj_.original_tagname_ = 'FlowReservationRequestListLink' - elif nodeName_ == 'FlowReservationResponseListLink': - obj_ = FlowReservationResponseListLink.factory() - obj_.build(child_) - self.FlowReservationResponseListLink = obj_ - obj_.original_tagname_ = 'FlowReservationResponseListLink' - elif nodeName_ == 'FunctionSetAssignmentsListLink': - obj_ = FunctionSetAssignmentsListLink.factory() - obj_.build(child_) - self.FunctionSetAssignmentsListLink = obj_ - obj_.original_tagname_ = 'FunctionSetAssignmentsListLink' - elif nodeName_ == 'RegistrationLink': - obj_ = RegistrationLink.factory() - obj_.build(child_) - self.RegistrationLink = obj_ - obj_.original_tagname_ = 'RegistrationLink' - elif nodeName_ == 'SubscriptionListLink': - obj_ = SubscriptionListLink.factory() - obj_.build(child_) - self.SubscriptionListLink = obj_ - obj_.original_tagname_ = 'SubscriptionListLink' - super(EndDevice, self).buildChildren(child_, node, nodeName_, True) -# end class EndDevice - - -class TargetReading(BillingMeterReadingBase): - """Contains readings that specify a target or goal, such as a - consumption target, to which billing incentives or other - contractual ramifications may be associated.""" - subclass = None - superclass = BillingMeterReadingBase - def __init__(self): - self.original_tagname_ = None - super(TargetReading, self).__init__() - def factory(*args_, **kwargs_): - if TargetReading.subclass: - return TargetReading.subclass(*args_, **kwargs_) - else: - return TargetReading(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(TargetReading, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='TargetReading', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='TargetReading') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='TargetReading', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='TargetReading'): - super(TargetReading, self).exportAttributes(outfile, level, already_processed, namespace_, name_='TargetReading') - def exportChildren(self, outfile, level, namespace_='', name_='TargetReading', fromsubclass_=False, pretty_print=True): - super(TargetReading, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='TargetReading'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(TargetReading, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(TargetReading, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(TargetReading, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(TargetReading, self).buildChildren(child_, node, nodeName_, True) - pass -# end class TargetReading - - -class ProjectionReading(BillingMeterReadingBase): - """Contains values that forecast a future reading for the time or - interval specified.""" - subclass = None - superclass = BillingMeterReadingBase - def __init__(self): - self.original_tagname_ = None - super(ProjectionReading, self).__init__() - def factory(*args_, **kwargs_): - if ProjectionReading.subclass: - return ProjectionReading.subclass(*args_, **kwargs_) - else: - return ProjectionReading(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(ProjectionReading, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='ProjectionReading', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='ProjectionReading') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='ProjectionReading', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='ProjectionReading'): - super(ProjectionReading, self).exportAttributes(outfile, level, already_processed, namespace_, name_='ProjectionReading') - def exportChildren(self, outfile, level, namespace_='', name_='ProjectionReading', fromsubclass_=False, pretty_print=True): - super(ProjectionReading, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='ProjectionReading'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(ProjectionReading, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(ProjectionReading, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(ProjectionReading, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(ProjectionReading, self).buildChildren(child_, node, nodeName_, True) - pass -# end class ProjectionReading - - -class HistoricalReading(BillingMeterReadingBase): - """To be used to present readings that have been processed and possibly - corrected (as allowed, due to missing or incorrect data) by - backend systems. This includes quality codes valid, verified, - estimated, and derived / corrected.""" - subclass = None - superclass = BillingMeterReadingBase - def __init__(self): - self.original_tagname_ = None - super(HistoricalReading, self).__init__() - def factory(*args_, **kwargs_): - if HistoricalReading.subclass: - return HistoricalReading.subclass(*args_, **kwargs_) - else: - return HistoricalReading(*args_, **kwargs_) - factory = staticmethod(factory) - def hasContent_(self): - if ( - super(HistoricalReading, self).hasContent_() - ): - return True - else: - return False - def export(self, outfile, level, namespace_='', name_='HistoricalReading', namespacedef_='', pretty_print=True): - if pretty_print: - eol_ = '\n' - else: - eol_ = '' - if self.original_tagname_ is not None: - name_ = self.original_tagname_ - showIndent(outfile, level, pretty_print) - outfile.write('<%s%s%s' % (namespace_, name_, namespacedef_ and ' ' + namespacedef_ or '', )) - already_processed = set() - self.exportAttributes(outfile, level, already_processed, namespace_, name_='HistoricalReading') - if self.hasContent_(): - outfile.write('>%s' % (eol_, )) - self.exportChildren(outfile, level + 1, namespace_='', name_='HistoricalReading', pretty_print=pretty_print) - outfile.write('%s' % (namespace_, name_, eol_)) - else: - outfile.write('/>%s' % (eol_, )) - def exportAttributes(self, outfile, level, already_processed, namespace_='', name_='HistoricalReading'): - super(HistoricalReading, self).exportAttributes(outfile, level, already_processed, namespace_, name_='HistoricalReading') - def exportChildren(self, outfile, level, namespace_='', name_='HistoricalReading', fromsubclass_=False, pretty_print=True): - super(HistoricalReading, self).exportChildren(outfile, level, namespace_, name_, True, pretty_print=pretty_print) - pass - def exportLiteral(self, outfile, level, name_='HistoricalReading'): - level += 1 - already_processed = set() - self.exportLiteralAttributes(outfile, level, already_processed, name_) - if self.hasContent_(): - self.exportLiteralChildren(outfile, level, name_) - def exportLiteralAttributes(self, outfile, level, already_processed, name_): - super(HistoricalReading, self).exportLiteralAttributes(outfile, level, already_processed, name_) - def exportLiteralChildren(self, outfile, level, name_): - super(HistoricalReading, self).exportLiteralChildren(outfile, level, name_) - pass - def build(self, node): - already_processed = set() - self.buildAttributes(node, node.attrib, already_processed) - for child in node: - nodeName_ = Tag_pattern_.match(child.tag).groups()[-1] - self.buildChildren(child, node, nodeName_) - return self - def buildAttributes(self, node, attrs, already_processed): - super(HistoricalReading, self).buildAttributes(node, attrs, already_processed) - def buildChildren(self, child_, node, nodeName_, fromsubclass_=False): - super(HistoricalReading, self).buildChildren(child_, node, nodeName_, True) - pass -# end class HistoricalReading - - -GDSClassesMapping = { - 'energyRequested': SignedRealEnergy, - 'rtgA': CurrentRMS, - 'setVRefOfs': VoltageRMS, - 'availableCredit': AccountingUnit, - 'secondaryPower': PowerSourceType, - 'rtgW': ActivePower, - 'primaryPower': PowerSourceType, - 'creditStatus': CreditStatusType, - 'opModVoltWatt': DERCurveLink, - 'pricePowerOfTenMultiplier': PowerOfTenMultiplierType, - 'opModVoltVAr': DERCurveLink, - 'maxForwardPower': ActivePower, - 'localControlModeStatus': LocalControlModeStatusType, - 'dstStartRule': DstRuleType, - 'xMultiplier': PowerOfTenMultiplierType, - 'lowEmergencyCreditWarningLevel': AccountingUnit, - 'sheddablePercent': PerCent, - 'flowRateEndLimit': UnitValueType, - 'accumulationBehaviour': AccumulationBehaviourType, - 'yMultiplier': PowerOfTenMultiplierType, - 'uom': UomType, - 'touTier': TOUType, - 'refType': DERUnitRefType, - 'activateTime': TimeType, - 'opModFixedW': PerCent, - 'lowerLimit': DERCurveLink, - 'rtgMinPF': UnsignedFixedPointType, - 'setMinPFNeg': FixedPointType, - 'swActTime': TimeType, - 'reservePercent': PerCent, - 'flowDirection': FlowDirectionType, - 'setMaxDischargeRate': ActivePower, - 'costKind': CostKindType, - 'serviceStatus': ServiceStatusType, - 'rtgVArNeg': ReactivePower, - 'timeChargingStatusPEV': TimeType, - 'curveType': DERCurveType, - 'monetaryUnit': CurrencyCode, - 'energyRequestNow': RealEnergy, - 'estimatedChargeRemaining': PerCent, - 'dateTime': TimeType, - 'genConnectStatus': ConnectStatusType, - 'prepayMode': PrepayModeType, - 'timeChargeIsNeeded': TimeType, - 'upperLimit': DERCurveLink, - 'powerOfTenMultiplier': PowerOfTenMultiplierType, - 'lastUpdateTime': TimeType, - 'locale': LocaleType, - 'serviceCategoryKind': ServiceKind, - 'opModHVRT': CurvePairType, - 'serviceChange': ServiceChange, - 'value': PerCent, - 'logEventPEN': PENType, - 'timePeriod': DateTimeInterval, - 'subject': mRIDType, - 'sFDI': SFDIType, - 'flowRateStartLimit': UnitValueType, - 'chargingPowerNow': ActivePower, - 'version': VersionType, - 'mfID': PENType, - 'creditExpiryLevel': AccountingUnit, - 'setMaxVArNeg': ReactivePower, - 'multiplier': PowerOfTenMultiplierType, - 'randomizeStart': OneHourRangeType, - 'setMinPF': UnsignedFixedPointType, - 'rtgMaxChargeRate': ActivePower, - 'availabilityUpdatePercentChangeThreshold': PerCent, - 'dstEndTime': TimeType, - 'deviceCategory': DeviceCategoryType, - 'dateTimeRegistered': TimeType, - 'rtgAh': AmpereHour, - 'manufacturerStatus': ManufacturerStatusType, - 'statusTimeStamp': TimeType, - 'opModWattPF': DERCurveLink, - 'conversionFactor': UnitValueType, - 'mfDate': TimeType, - 'statWAvail': ActivePower, - 'currentPowerSource': PowerSourceType, - 'modesSupported': DERControlType, - 'opModFixedPF': FixedPowerFactor, - 'energyAvailable': RealEnergy, - 'sheddablePower': ActivePower, - 'changedTime': TimeType, - 'unit': UomType, - 'intervalRequested': DateTimeInterval, - 'start': TimeType, - 'consumptionBlock': ConsumptionBlockType, - 'setMaxW': ActivePower, - 'priority': PriorityType, - 'setMaxVA': ApparentPower, - 'creditTypeInUse': CreditTypeType, - 'dstEndRule': DstRuleType, - 'rtgVA': ApparentPower, - 'type': DERType, - 'potentiallySupersededTime': TimeType, - 'powerRequested': ActivePower, - 'rtgVAr': ReactivePower, - 'rtgWh': WattHour, - 'setMaxChargeRate': ActivePower, - 'stateOfChargeStatus': StateOfChargeStatusType, - 'emergencyCredit': AccountingUnit, - 'dstStartTime': TimeType, - 'updatedTime': TimeType, - 'kind': ChargeKind, - 'energyUnit': RealEnergy, - 'dstOffset': TimeOffsetType, - 'batteryInstallTime': TimeType, - 'creationTime': TimeType, - 'lowCreditWarningLevel': AccountingUnit, - 'availabilityUpdatePowerChangeThreshold': ActivePower, - 'powerAvailable': ActivePower, - 'inverterStatus': InverterStatusType, - 'statusTime': TimeType, - 'nextUpdateTime': TimeType, - 'primacy': PrimacyType, - 'tzOffset': TimeOffsetType, - 'nextRequestAttempt': TimeType, - 'newStatus': ServiceStatusType, - 'creditType': CreditTypeType, - 'roleFlags': RoleFlagsType, - 'effectiveTime': TimeType, - 'readingTime': TimeType, - 'loadShedDeviceCategory': DeviceCategoryType, - 'creditAmount': AccountingUnit, - 'setMaxVAr': ReactivePower, - 'currency': CurrencyCode, - 'setVRef': VoltageRMS, - 'currentLocale': LocaleType, - 'mRID': mRIDType, - 'targetStateOfCharge': PerCent, - 'maxDemand': ActivePower, - 'opModLVRT': CurvePairType, - 'storConnectStatus': ConnectStatusType, - 'opModFixedVAr': FixedVAr, - 'storageModeStatus': StorageModeStatusType, - 'rtgMinPFNeg': FixedPointType, - 'pIN': PINType, - 'emergencyCreditStatus': CreditStatusType, - 'randomizeDuration': OneHourRangeType, - 'yRefType': DERUnitRefType, - 'opModFixedFlow': SignedPerCent, - 'statVArAvail': ReactivePower, - 'startTime': TimeType, - 'phase': PhaseCode, - 'rtgMaxDischargeRate': ActivePower, - 'calorificValue': UnitValueType, - 'localTime': TimeType, - 'commodity': CommodityType, - 'currentTime': TimeType, - 'createdDateTime': TimeType, - 'dataQualifier': DataQualifierType, - 'interval': DateTimeInterval, - 'averageEnergy': RealEnergy, - 'operationalModeStatus': OperationalModeStatusType, - 'creditTypeChange': CreditTypeChange, - 'reserveChargePercent': PerCent, - 'opModFreqWatt': DERCurveLink, - 'newType': CreditTypeType, -} - - -USAGE_TEXT = """ -Usage: python .py [ -s ] -""" - - -def usage(): - print(USAGE_TEXT) - sys.exit(1) - - -def get_root_tag(node): - tag = Tag_pattern_.match(node.tag).groups()[-1] - rootClass = GDSClassesMapping.get(tag) - if rootClass is None: - rootClass = globals().get(tag) - return tag, rootClass - - -def parse(inFileName, silence=False): - doc = parsexml_(inFileName) - rootNode = doc.getroot() - rootTag, rootClass = get_root_tag(rootNode) - if rootClass is None: - rootTag = 'DeviceCapability' - rootClass = DeviceCapability - rootObj = rootClass.factory() - rootObj.build(rootNode) - # Enable Python to collect the space used by the DOM. - doc = None - if not silence: - sys.stdout.write('\n') - rootObj.export( - sys.stdout, 0, name_=rootTag, - namespacedef_='', - pretty_print=True) - return rootObj - - -def parseEtree(inFileName, silence=False): - doc = parsexml_(inFileName) - rootNode = doc.getroot() - rootTag, rootClass = get_root_tag(rootNode) - if rootClass is None: - rootTag = 'DeviceCapability' - rootClass = DeviceCapability - rootObj = rootClass.factory() - rootObj.build(rootNode) - # Enable Python to collect the space used by the DOM. - doc = None - mapping = {} - rootElement = rootObj.to_etree(None, name_=rootTag, mapping_=mapping) - reverse_mapping = rootObj.gds_reverse_node_mapping(mapping) - if not silence: - content = etree_.tostring( - rootElement, pretty_print=True, - xml_declaration=True, encoding="utf-8") - sys.stdout.write(content) - sys.stdout.write('\n') - return rootObj, rootElement, mapping, reverse_mapping - - -def parseString(inString, silence=False): - from io import StringIO - doc = parsexml_(StringIO(inString)) - rootNode = doc.getroot() - rootTag, rootClass = get_root_tag(rootNode) - if rootClass is None: - rootTag = 'DeviceCapability' - rootClass = DeviceCapability - rootObj = rootClass.factory() - rootObj.build(rootNode) - # Enable Python to collect the space used by the DOM. - doc = None - if not silence: - sys.stdout.write('\n') - rootObj.export( - sys.stdout, 0, name_=rootTag, - namespacedef_='') - return rootObj - - -def parseLiteral(inFileName, silence=False): - doc = parsexml_(inFileName) - rootNode = doc.getroot() - rootTag, rootClass = get_root_tag(rootNode) - if rootClass is None: - rootTag = 'DeviceCapability' - rootClass = DeviceCapability - rootObj = rootClass.factory() - rootObj.build(rootNode) - # Enable Python to collect the space used by the DOM. - doc = None - if not silence: - sys.stdout.write('#from xsd_models import *\n\n') - sys.stdout.write('import xsd_models as model_\n\n') - sys.stdout.write('rootObj = model_.rootClass(\n') - rootObj.exportLiteral(sys.stdout, 0, name_=rootTag) - sys.stdout.write(')\n') - return rootObj - - -def main(): - args = sys.argv[1:] - if len(args) == 1: - parse(args[0]) - else: - usage() - - -if __name__ == '__main__': - #import pdb; pdb.set_trace() - main() - - -__all__ = [ - "AbstractDevice", - "AbstractFlowReservation", - "AccountBalance", - "AccountBalanceLink", - "AccountingUnit", - "AccumulationBehaviourType", - "ActiveBillingPeriodListLink", - "ActiveCreditRegisterListLink", - "ActiveDERControlListLink", - "ActiveEndDeviceControlListLink", - "ActiveFlowReservationListLink", - "ActivePower", - "ActiveProjectionReadingListLink", - "ActiveSupplyInterruptionOverrideListLink", - "ActiveTargetReadingListLink", - "ActiveTextMessageListLink", - "ActiveTimeTariffIntervalListLink", - "AmpereHour", - "ApparentPower", - "ApplianceLoadReduction", - "ApplianceLoadReductionType", - "AppliedTargetReduction", - "AssociatedDERProgramListLink", - "AssociatedUsagePointLink", - "BillingMeterReadingBase", - "BillingPeriod", - "BillingPeriodList", - "BillingPeriodListLink", - "BillingReading", - "BillingReadingList", - "BillingReadingListLink", - "BillingReadingSet", - "BillingReadingSetList", - "BillingReadingSetListLink", - "Charge", - "ChargeKind", - "CommodityType", - "Condition", - "Configuration", - "ConfigurationLink", - "ConnectStatusType", - "ConsumptionBlockType", - "ConsumptionTariffInterval", - "ConsumptionTariffIntervalList", - "ConsumptionTariffIntervalListLink", - "CostKindType", - "CreditRegister", - "CreditRegisterList", - "CreditRegisterListLink", - "CreditStatusType", - "CreditTypeChange", - "CreditTypeType", - "CurrencyCode", - "CurrentDERProgramLink", - "CurrentRMS", - "CurveData", - "CurvePairType", - "CustomerAccount", - "CustomerAccountLink", - "CustomerAccountList", - "CustomerAccountListLink", - "CustomerAgreement", - "CustomerAgreementList", - "CustomerAgreementListLink", - "DER", - "DERAvailability", - "DERAvailabilityLink", - "DERCapability", - "DERCapabilityLink", - "DERControl", - "DERControlBase", - "DERControlList", - "DERControlListLink", - "DERControlType", - "DERCurve", - "DERCurveLink", - "DERCurveList", - "DERCurveListLink", - "DERCurveType", - "DERLink", - "DERList", - "DERListLink", - "DERProgram", - "DERProgramLink", - "DERProgramList", - "DERProgramListLink", - "DERSettings", - "DERSettingsLink", - "DERStatus", - "DERStatusLink", - "DERType", - "DERUnitRefType", - "DRLCCapabilities", - "DataQualifierType", - "DateTimeInterval", - "DefaultDERControl", - "DefaultDERControlLink", - "DemandResponseProgram", - "DemandResponseProgramLink", - "DemandResponseProgramList", - "DemandResponseProgramListLink", - "DeviceCapability", - "DeviceCapabilityLink", - "DeviceCategoryType", - "DeviceInformation", - "DeviceInformationLink", - "DeviceStatus", - "DeviceStatusLink", - "DrResponse", - "DstRuleType", - "DutyCycle", - "EndDevice", - "EndDeviceControl", - "EndDeviceControlList", - "EndDeviceControlListLink", - "EndDeviceLink", - "EndDeviceList", - "EndDeviceListLink", - "EnvironmentalCost", - "Error", - "Event", - "EventStatus", - "File", - "FileLink", - "FileList", - "FileListLink", - "FileStatus", - "FileStatusLink", - "FixedPointType", - "FixedPowerFactor", - "FixedVAr", - "FlowDirectionType", - "FlowReservationRequest", - "FlowReservationRequestList", - "FlowReservationRequestListLink", - "FlowReservationResponse", - "FlowReservationResponseList", - "FlowReservationResponseListLink", - "FunctionSetAssignments", - "FunctionSetAssignmentsBase", - "FunctionSetAssignmentsList", - "FunctionSetAssignmentsListLink", - "HistoricalReading", - "HistoricalReadingList", - "HistoricalReadingListLink", - "IEEE_802_15_4", - "IPAddr", - "IPAddrList", - "IPAddrListLink", - "IPInterface", - "IPInterfaceList", - "IPInterfaceListLink", - "IdentifiedObject", - "InverterStatusType", - "KindType", - "LLInterface", - "LLInterfaceList", - "LLInterfaceListLink", - "Link", - "List", - "ListLink", - "LoadShedAvailability", - "LoadShedAvailabilityLink", - "LocalControlModeStatusType", - "LocaleType", - "LogEvent", - "LogEventList", - "LogEventListLink", - "ManufacturerStatusType", - "MessagingProgram", - "MessagingProgramList", - "MessagingProgramListLink", - "MeterReading", - "MeterReadingBase", - "MeterReadingLink", - "MeterReadingList", - "MeterReadingListLink", - "MirrorMeterReading", - "MirrorMeterReadingList", - "MirrorReadingSet", - "MirrorUsagePoint", - "MirrorUsagePointList", - "MirrorUsagePointListLink", - "Neighbor", - "NeighborList", - "NeighborListLink", - "Notification", - "NotificationList", - "NotificationListLink", - "Offset", - "OneHourRangeType", - "OperationalModeStatusType", - "PENType", - "PEVInfo", - "PINType", - "PerCent", - "PhaseCode", - "PowerConfiguration", - "PowerOfTenMultiplierType", - "PowerSourceType", - "PowerStatus", - "PowerStatusLink", - "PrepayModeType", - "PrepayOperationStatus", - "PrepayOperationStatusLink", - "Prepayment", - "PrepaymentLink", - "PrepaymentList", - "PrepaymentListLink", - "PriceResponse", - "PriceResponseCfg", - "PriceResponseCfgList", - "PriceResponseCfgListLink", - "PrimacyType", - "PriorityType", - "ProjectionReading", - "ProjectionReadingList", - "ProjectionReadingListLink", - "RPLInstance", - "RPLInstanceList", - "RPLInstanceListLink", - "RPLSourceRoutes", - "RPLSourceRoutesList", - "RPLSourceRoutesListLink", - "RandomizableEvent", - "RateComponent", - "RateComponentLink", - "RateComponentList", - "RateComponentListLink", - "ReactivePower", - "Reading", - "ReadingBase", - "ReadingLink", - "ReadingList", - "ReadingListLink", - "ReadingSet", - "ReadingSetBase", - "ReadingSetList", - "ReadingSetListLink", - "ReadingType", - "ReadingTypeLink", - "RealEnergy", - "Registration", - "RegistrationLink", - "RequestStatus", - "Resource", - "RespondableIdentifiedObject", - "RespondableResource", - "RespondableSubscribableIdentifiedObject", - "Response", - "ResponseList", - "ResponseListLink", - "ResponseSet", - "ResponseSetList", - "ResponseSetListLink", - "RoleFlagsType", - "SFDIType", - "SelfDevice", - "SelfDeviceLink", - "ServiceChange", - "ServiceKind", - "ServiceStatusType", - "ServiceSupplier", - "ServiceSupplierLink", - "ServiceSupplierList", - "SetPoint", - "SignedPerCent", - "SignedRealEnergy", - "StateOfChargeStatusType", - "StorageModeStatusType", - "SubscribableIdentifiedObject", - "SubscribableList", - "SubscribableResource", - "Subscription", - "SubscriptionBase", - "SubscriptionList", - "SubscriptionListLink", - "SupplyInterruptionOverride", - "SupplyInterruptionOverrideList", - "SupplyInterruptionOverrideListLink", - "SupportedLocale", - "SupportedLocaleList", - "SupportedLocaleListLink", - "TOUType", - "TargetReading", - "TargetReadingList", - "TargetReadingListLink", - "TargetReduction", - "TariffProfile", - "TariffProfileLink", - "TariffProfileList", - "TariffProfileListLink", - "Temperature", - "TextMessage", - "TextMessageList", - "TextMessageListLink", - "TextResponse", - "Time", - "TimeConfiguration", - "TimeLink", - "TimeOffsetType", - "TimeTariffInterval", - "TimeTariffIntervalList", - "TimeTariffIntervalListLink", - "TimeType", - "UnitType", - "UnitValueType", - "UnsignedFixedPointType", - "UomType", - "UsagePoint", - "UsagePointBase", - "UsagePointLink", - "UsagePointList", - "UsagePointListLink", - "VersionType", - "VoltageRMS", - "WattHour", - "loWPAN", - "mRIDType" -] diff --git a/services/core/IEEE2030_5Agent/README.md b/services/core/IEEE2030_5Agent/README.md deleted file mode 100644 index 62792c4b82..0000000000 --- a/services/core/IEEE2030_5Agent/README.md +++ /dev/null @@ -1,37 +0,0 @@ -# IEEE2030_5 Agent -Agent that handles IEEE 2030.5 communication. -IEEE2030_5Agent uses the VOLTTRON web service to communicate with IEEE 2030.5 end devices. -End device configuration is outlined in the agent config file. - -IEEE 2030.5 data is exposed via get_point(), get_points() and set_point() calls. -A IEEE 2030.5 device driver (IEEE2030_5.py under PlatformDriverAgent) can be configured, -which gets and sets data by sending RPCs to this agent. - -For further information about this subsystem, please see the VOLTTRON -IEEE 2030.5 DER Support specification, which is located in VOLTTRON readthedocs -under specifications/IEEE2030_5_agent.html. - -## Configuration - -``` {.python} -{ - "devices": [ - { - "sfdi": "097935300833", - "lfdi": "247bd68e3378fe57ba604e3c8bdf9e3f78a3d743", - "load_shed_device_category": "0200", - "pin_code": "130178" - }, - { - "sfdi": "111576577659", - "lfdi": "2990c58a59935a7d5838c952b1a453c967341a07", - "load_shed_device_category": "0200", - "pin_code": "130178" - } - ], - "IEEE2030_5_server_sfdi": "413707194130", - "IEEE2030_5_server_lfdi": "29834592834729384728374562039847629", - "load_shed_device_category": "0020", - "timezone": "America/Los_Angeles" -} -``` diff --git a/services/core/IEEE2030_5Agent/config b/services/core/IEEE2030_5Agent/config deleted file mode 100644 index ba7fef49ba..0000000000 --- a/services/core/IEEE2030_5Agent/config +++ /dev/null @@ -1,20 +0,0 @@ -{ - "devices": [ - { - "sfdi": "097935300833", - "lfdi": "247bd68e3378fe57ba604e3c8bdf9e3f78a3d743", - "load_shed_device_category": "0200", - "pin_code": "130178" - }, - { - "sfdi": "111576577659", - "lfdi": "2990c58a59935a7d5838c952b1a453c967341a07", - "load_shed_device_category": "0200", - "pin_code": "130178" - } - ], - "IEEE2030_5_server_sfdi": "413707194130", - "IEEE2030_5_server_lfdi": "29834592834729384728374562039847629", - "load_shed_device_category": "0020", - "timezone": "America/Los_Angeles" -} diff --git a/services/core/IEEE2030_5Agent/conftest.py b/services/core/IEEE2030_5Agent/conftest.py deleted file mode 100644 index 8559470457..0000000000 --- a/services/core/IEEE2030_5Agent/conftest.py +++ /dev/null @@ -1,6 +0,0 @@ -import sys - -from volttrontesting.fixtures.volttron_platform_fixtures import * - -# Add system path of the agent's directory -sys.path.insert(0, os.path.abspath(os.path.dirname(__file__))) \ No newline at end of file diff --git a/services/core/IEEE2030_5Agent/setup.py b/services/core/IEEE2030_5Agent/setup.py deleted file mode 100644 index cc64769bff..0000000000 --- a/services/core/IEEE2030_5Agent/setup.py +++ /dev/null @@ -1,72 +0,0 @@ -# -*- coding: utf-8 -*- {{{ -# vim: set fenc=utf-8 ft=python sw=4 ts=4 sts=4 et: -# -# Copyright 2020, Battelle Memorial Institute. -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. -# -# This material was prepared as an account of work sponsored by an agency of -# the United States Government. Neither the United States Government nor the -# United States Department of Energy, nor Battelle, nor any of their -# employees, nor any jurisdiction or organization that has cooperated in the -# development of these materials, makes any warranty, express or -# implied, or assumes any legal liability or responsibility for the accuracy, -# completeness, or usefulness or any information, apparatus, product, -# software, or process disclosed, or represents that its use would not infringe -# privately owned rights. Reference herein to any specific commercial product, -# process, or service by trade name, trademark, manufacturer, or otherwise -# does not necessarily constitute or imply its endorsement, recommendation, or -# favoring by the United States Government or any agency thereof, or -# Battelle Memorial Institute. The views and opinions of authors expressed -# herein do not necessarily state or reflect those of the -# United States Government or any agency thereof. -# -# PACIFIC NORTHWEST NATIONAL LABORATORY operated by -# BATTELLE for the UNITED STATES DEPARTMENT OF ENERGY -# under Contract DE-AC05-76RL01830 -# }}} - -from os import path -from setuptools import setup, find_packages - -MAIN_MODULE = 'agent' - -# Find the agent package that contains the main module -packages = find_packages('.') -agent_package = '' -for package in find_packages(): - # Because there could be other packages such as tests - if path.isfile(package + '/' + MAIN_MODULE + '.py') is True: - agent_package = package -if not agent_package: - raise RuntimeError('None of the packages under {dir} contain the file ' - '{main_module}'.format(main_module=MAIN_MODULE + '.py', - dir=path.abspath('.'))) - -# Find the version number from the main module -agent_module = agent_package + '.' + MAIN_MODULE -_temp = __import__(agent_module, globals(), locals(), ['__version__'], 0) -__version__ = _temp.__version__ - -# Setup -setup( - name=agent_package + 'agent', - version=__version__, - install_requires=['volttron'], - packages=packages, - entry_points={ - 'setuptools.installation': [ - 'eggsecutable = ' + agent_module + ':main', - ] - } -) diff --git a/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/IEEE2030_5drivertest.config b/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/IEEE2030_5drivertest.config deleted file mode 100644 index 7fd4f416c8..0000000000 --- a/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/IEEE2030_5drivertest.config +++ /dev/null @@ -1,3 +0,0 @@ -{ - "agentid": "IEEE2030_5drivertest" -} diff --git a/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/__init__.py b/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/__init__.py deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/setup.py b/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/setup.py deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/test_agent/__init__.py b/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/test_agent/__init__.py deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/test_agent/agent.py b/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/test_agent/agent.py deleted file mode 100644 index 6f23f157e7..0000000000 --- a/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/test_agent/agent.py +++ /dev/null @@ -1,449 +0,0 @@ -# -*- coding: utf-8 -*- {{{ -# vim: set fenc=utf-8 ft=python sw=4 ts=4 sts=4 et: -# -# Copyright 2020, Battelle Memorial Institute. -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. -# -# This material was prepared as an account of work sponsored by an agency of -# the United States Government. Neither the United States Government nor the -# United States Department of Energy, nor Battelle, nor any of their -# employees, nor any jurisdiction or organization that has cooperated in the -# development of these materials, makes any warranty, express or -# implied, or assumes any legal liability or responsibility for the accuracy, -# completeness, or usefulness or any information, apparatus, product, -# software, or process disclosed, or represents that its use would not infringe -# privately owned rights. Reference herein to any specific commercial product, -# process, or service by trade name, trademark, manufacturer, or otherwise -# does not necessarily constitute or imply its endorsement, recommendation, or -# favoring by the United States Government or any agency thereof, or -# Battelle Memorial Institute. The views and opinions of authors expressed -# herein do not necessarily state or reflect those of the -# United States Government or any agency thereof. -# -# PACIFIC NORTHWEST NATIONAL LABORATORY operated by -# BATTELLE for the UNITED STATES DEPARTMENT OF ENERGY -# under Contract DE-AC05-76RL01830 -# }}} - -import gevent -import logging -import requests -import sys - -from volttron.platform.vip.agent import Agent, Core -from volttron.platform.agent import utils -from volttron.platform.agent.known_identities import PLATFORM_DRIVER - -_log = logging.getLogger(__name__) -utils.setup_logging() - -__version__ = '1.0' - -CYCLE_TIME = 3 # Seconds between sets of get_point/set_point calls - -ALL_POINTS = [ - 'b1_Md', - 'b1_Opt', - 'b1_SN', - 'b1_Vr', - 'b113_A', - 'b113_DCA', - 'b113_DCV', - 'b113_DCW', - 'b113_PF', - 'b113_WH', - 'b120_AhrRtg', - 'b120_ARtg', - 'b120_MaxChaRte', - 'b120_MaxDisChaRte', - 'b120_WHRtg', - 'b120_WRtg', - 'b121_WMax', - 'b122_ActWh', - 'b122_StorConn', - 'b124_WChaMax', - 'b403_Tmp', - 'b404_DCW', - 'b404_DCWh', - 'b802_LocRemCtl', - 'b802_SoC', - 'b802_State'] - -DEVICE_INFORMATION = """ - 0145 - 5509D69F8B353595206AD71B47E27906318EA367 - 1388566800 - MF-HW: 1.0.0 - 37250 - Mf Information - Mf Model - 1234567890 - 2 - 0 - 1416107035 - 9bc8e7b_modified - -""" - -DER_SETTINGS = """ - 55000 - - 1 - 2 - - - 3 - 4 - - - 1 - 1 - - true - 1416307137 -""" - -DER_STATUS = """ - 1416270124 - - 1416270124 - 777 - - - 1416270124 - 777 - - - 1416270124 - 777 - - - 1416270124 - 777 - -""" - -DER_AVAILABILITY = """ - 55036 - 3 - 1416304442 - 10000 - 10000 - - 1 - 1 - -""" - -DER_CAPABILITY = """ - 01 - - 1 - 35 - - - 1 - 33 - - - 1 - 22 - - - 1 - 1 - - - 1 - 1 - - - 1 - 1 - - - 1 - 123 - - 85 -""" - -POWER_STATUS = """ - 0 - 1416266598 - 3 - 1 - 0 - - - 0 - 3000 - - - 0 - 6100 - - - 3 - 7 - - 4337 - 1000 - 1516266598 - 1516266598 - - 2 - 2 -""" - -MUP = """ - 0600006CC8 - Gas Mirroring - 13 - 1 - 1 - 247bd68e3378fe57ba604e3c8bdf9e3f78a3d743 - - 0700006CC8 - Cumulative Reading for Gas - - 125 - - - 9 - 7 - 0 - 1 - 3 - 119 - - - - 0800006CC8 - Interval Readings for Gas - - 4 - 7 - 0 - 1 - 3 - 119 - - - - 0900006CC8 - InstantPackCurrent - - 125 - - - - 0900006CC8 - LineVoltageAvg - - 125 - - - - 0900006CC8 - PhasePowerAvg - - 125 - - - - 1000006CC8 - PhasePFA - - 126 - - - - 1100006CC8 - EnergyIMP - - 127 - - - - 1300006CC8 - InstantPackTemp - - 128 - - - 9 - 7 - 0 - 1 - 3 - 119 - - -""" - -MUP2 = """ - 0600006CC8 - Gas Mirroring - 13 - 1 - 1 - 247bd68e3378fe57ba604e3c8bdf9e3f78a3d743 - - 1200006CC8 - EnergyEXP - - 128 - - -""" - -MMR = """ - 6D6D72099BBDE9156400000000009182 - PhaseCurrentAvg - - - 0 - 2216441 - - 24 - - - 12 - 0 - 12 - 0 - 0 - 0 - 0 - 23 - -""" - -ASSERTED_VALUES = { - 'b1_Md': 'Mf Model', - 'b1_Opt': '247bd68e3378fe57ba604e3c8bdf9e3f78a3d743', - 'b1_SN': '097935300833', - 'b1_Vr': 'MF-HW: 1.0.0', - 'b113_A': '24.0', - 'b113_DCA': '125.0', - 'b113_DCV': '125.0', - 'b113_DCW': '125.0', - 'b113_PF': '126.0', - 'b113_WH': '127.0', - 'b120_AhrRtg': '350.0', - 'b120_ARtg': '330.0', - 'b120_MaxChaRte': '220.0', - 'b120_MaxDisChaRte': '10.0', - 'b120_WHRtg': '1230.0', - 'b120_WRtg': '10.0', - 'b121_WMax': '20.0', - 'b122_ActWh': '128.0', - 'b122_StorConn': '777', - 'b124_WChaMax': '10.0', - 'b403_Tmp': '128000.0', - 'b404_DCW': '3000.0', - 'b404_DCWh': '305.755555556', - 'b802_LocRemCtl': '777', - 'b802_SoC': '7.77', - 'b802_State': '777'} - -TEST_WEB_ADDRESS = 'http://127.0.0.1:8080' -DEFAULT_DRIVER = 'IEEE2030_5_1' - - -class IEEE2030_5DriverTestAgent(Agent): - """ - Test the IEEE 2030.5 driver (not a pytest regression test). - - Load a test data set by posting XML to IEEE2030_5Agent (assumed to be at port 8080 on the local host). - Periodically send get_point for each point on the IEEE 2030.5 driver. - Also send a set_point call to its der_control point, setting a power dispatch value. - - This agent can be installed as follows: - export VIP_SOCKET="ipc://$VOLTTRON_HOME/run/vip.socket" - export IEEE2030_5_TEST_ROOT=$VOLTTRON_ROOT/services/core/IEEE2030_5Agent/tests/IEEE2030_5DriverTestAgent/test_agent - cd $VOLTTRON_ROOT - python scripts/install-agent.py \ - -s $IEEE2030_5_TEST_ROOT \ - -i IEEE2030_5testagent \ - -c $IEEE2030_5_TEST_ROOT/IEEE2030_5drivertest.config \ - -t IEEE2030_5testagent \ - -f - """ - - def __init__(self, **kwargs): - super(IEEE2030_5DriverTestAgent, self).__init__(**kwargs) - self.default_config = {} - self.vip.config.set_default("config", self.default_config) - self.vip.config.subscribe(self.configure, actions=["NEW", "UPDATE"], pattern="config") - - def configure(self, config_name, action, contents): - config = self.default_config.copy() - config.update(contents) - - @Core.receiver('onstart') - def onstart(self, sender, **kwargs): - self.core.spawn(self.send_and_receive_points) - - def send_and_receive_points(self): - self.post_test_data() - while True: - self.set_point('b124_WChaMax', ASSERTED_VALUES['b124_WChaMax']) - for point_name in ALL_POINTS: - expected_value = ASSERTED_VALUES[point_name] - received_value = self.get_point(point_name) - assert received_value == expected_value - gevent.sleep(CYCLE_TIME) - - @staticmethod - def post_test_data(): - """Post XML test data for a IEEE 2030.5 resource to the IEEE2030_5Agent.""" - headers = {'content-type': 'application/sep+xml'} - requests.post('{}/dcap/edev/0/di'.format(TEST_WEB_ADDRESS), data=DEVICE_INFORMATION, headers=headers) - requests.post('{}/dcap/edev/0/der/1/derg'.format(TEST_WEB_ADDRESS), data=DER_SETTINGS, headers=headers) - requests.post('{}/dcap/edev/0/der/1/ders'.format(TEST_WEB_ADDRESS), data=DER_STATUS, headers=headers) - requests.post('{}/dcap/edev/0/der/1/dera'.format(TEST_WEB_ADDRESS), data=DER_AVAILABILITY, headers=headers) - requests.post('{}/dcap/edev/0/der/1/dercap'.format(TEST_WEB_ADDRESS), data=DER_CAPABILITY, headers=headers) - requests.post('{}/dcap/edev/0/ps'.format(TEST_WEB_ADDRESS), data=POWER_STATUS, headers=headers) - requests.post('{}/dcap/mup'.format(TEST_WEB_ADDRESS), data=MUP, headers=headers) - requests.post('{}/dcap/mup/0'.format(TEST_WEB_ADDRESS), data=MUP2, headers=headers) - requests.post('{}/dcap/mup/0'.format(TEST_WEB_ADDRESS), data=MMR, headers=headers) - - def get_point(self, point_name, driver_name=None): - """Issue a get_point RPC call for the named point and return the result.""" - driver = driver_name if driver_name else DEFAULT_DRIVER - response = self.vip.rpc.call(PLATFORM_DRIVER, 'get_point', driver, point_name).get(timeout=10) - _log.debug('{}: Sent get_point for {}, received {}'.format(driver, point_name, response)) - return response - - def set_point(self, point_name, value, driver_name=None): - """Issue a set_point RPC call for the named point and value, and return the result.""" - driver = driver_name if driver_name else DEFAULT_DRIVER - self.vip.rpc.call(PLATFORM_DRIVER, 'set_point', driver, point_name, value) - _log.debug('{}: Sent set_point for {} = {}'.format(driver, point_name, value)) - - -def test_IEEE2030_5_agent(config_path, **kwargs): - return IEEE2030_5DriverTestAgent(**kwargs) - - -def main(): - utils.vip_main(test_IEEE2030_5_agent, identity='IEEE2030_5testagent', version=__version__) - -if __name__ == '__main__': - try: - sys.exit(main()) - except KeyboardInterrupt: - pass diff --git a/services/core/IEEE2030_5Agent/tests/der.dera.PUT.xml b/services/core/IEEE2030_5Agent/tests/der.dera.PUT.xml deleted file mode 100644 index 3875af85ed..0000000000 --- a/services/core/IEEE2030_5Agent/tests/der.dera.PUT.xml +++ /dev/null @@ -1,11 +0,0 @@ - - 55036 - 3 - 1416304442 - 10000 - 10000 - - 1 - 1 - - \ No newline at end of file diff --git a/services/core/IEEE2030_5Agent/tests/der.dercap.PUT.xml b/services/core/IEEE2030_5Agent/tests/der.dercap.PUT.xml deleted file mode 100644 index 49510006fc..0000000000 --- a/services/core/IEEE2030_5Agent/tests/der.dercap.PUT.xml +++ /dev/null @@ -1,32 +0,0 @@ - - 01 - - 1 - 35 - - - 1 - 33 - - - 1 - 22 - - - 1 - 1 - - - 1 - 1 - - - 1 - 1 - - - 1 - 123 - - 85 - diff --git a/services/core/IEEE2030_5Agent/tests/der.derg.PUT.xml b/services/core/IEEE2030_5Agent/tests/der.derg.PUT.xml deleted file mode 100644 index ed10f419df..0000000000 --- a/services/core/IEEE2030_5Agent/tests/der.derg.PUT.xml +++ /dev/null @@ -1,17 +0,0 @@ - - 55000 - - 1 - 2 - - - 3 - 4 - - - 1 - 1 - - true - 1416307137 - \ No newline at end of file diff --git a/services/core/IEEE2030_5Agent/tests/der.ders.PUT.xml b/services/core/IEEE2030_5Agent/tests/der.ders.PUT.xml deleted file mode 100644 index 699d09a611..0000000000 --- a/services/core/IEEE2030_5Agent/tests/der.ders.PUT.xml +++ /dev/null @@ -1,19 +0,0 @@ - - 1416270124 - - 1416270124 - 777 - - - 1416270124 - 777 - - - 1416270124 - 777 - - - 1416270124 - 777 - - diff --git a/services/core/IEEE2030_5Agent/tests/edev.di.PUT.xml b/services/core/IEEE2030_5Agent/tests/edev.di.PUT.xml deleted file mode 100644 index f7472b9806..0000000000 --- a/services/core/IEEE2030_5Agent/tests/edev.di.PUT.xml +++ /dev/null @@ -1,14 +0,0 @@ - - 0145 - 5509D69F8B353595206AD71B47E27906318EA367 - 1388566800 - MF-HW: 1.0.0 - 37250 - Mf Information - Mf Model - 1234567890 - 2 - 0 - 1416107035 - 9bc8e7b_modified - diff --git a/services/core/IEEE2030_5Agent/tests/edev.dstat.PUT.xml b/services/core/IEEE2030_5Agent/tests/edev.dstat.PUT.xml deleted file mode 100644 index a15a50171d..0000000000 --- a/services/core/IEEE2030_5Agent/tests/edev.dstat.PUT.xml +++ /dev/null @@ -1,6 +0,0 @@ - - 1416266460 - 5 - 0 - 0 - \ No newline at end of file diff --git a/services/core/IEEE2030_5Agent/tests/edev.ps.PUT.xml b/services/core/IEEE2030_5Agent/tests/edev.ps.PUT.xml deleted file mode 100644 index fa06647f1d..0000000000 --- a/services/core/IEEE2030_5Agent/tests/edev.ps.PUT.xml +++ /dev/null @@ -1,27 +0,0 @@ - - 0 - 1416266598 - 3 - 1 - 0 - - - 0 - 3000 - - - 0 - 6100 - - - 3 - 7 - - 4337 - 1000 - 1516266598 - 1516266598 - - 2 - 2 - diff --git a/services/core/IEEE2030_5Agent/tests/mup.mmr.PUT.xml b/services/core/IEEE2030_5Agent/tests/mup.mmr.PUT.xml deleted file mode 100644 index c14bed6d8f..0000000000 --- a/services/core/IEEE2030_5Agent/tests/mup.mmr.PUT.xml +++ /dev/null @@ -1,21 +0,0 @@ - - 6D6D72099BBDE9156400000000009182 - PhaseCurrentAvg - - - 0 - 2216441 - - 24 - - - 12 - 0 - 12 - 0 - 0 - 0 - 0 - 23 - - \ No newline at end of file diff --git a/services/core/IEEE2030_5Agent/tests/mup.mup.PUT.xml b/services/core/IEEE2030_5Agent/tests/mup.mup.PUT.xml deleted file mode 100644 index 8c06c88533..0000000000 --- a/services/core/IEEE2030_5Agent/tests/mup.mup.PUT.xml +++ /dev/null @@ -1,85 +0,0 @@ - - 0600006CC8 - Gas Mirroring - 13 - 1 - 1 - 247bd68e3378fe57ba604e3c8bdf9e3f78a3d743 - - 0700006CC8 - Cumulative Reading for Gas - - 125 - - - 9 - 7 - 0 - 1 - 3 - 119 - - - - 0800006CC8 - Interval Readings for Gas - - 4 - 7 - 0 - 1 - 3 - 119 - - - - 0900006CC8 - InstantPackCurrent - - 125 - - - - 0900006CC8 - LineVoltageAvg - - 125 - - - - 0900006CC8 - PhasePowerAvg - - 125 - - - - 1000006CC8 - PhasePFA - - 126 - - - - 1100006CC8 - EnergyIMP - - 127 - - - - 1300006CC8 - InstantPackTemp - - 128 - - - 9 - 7 - 0 - 1 - 3 - 119 - - - \ No newline at end of file diff --git a/services/core/IEEE2030_5Agent/tests/mup.mup2.PUT.xml b/services/core/IEEE2030_5Agent/tests/mup.mup2.PUT.xml deleted file mode 100644 index 7cdd1c5e04..0000000000 --- a/services/core/IEEE2030_5Agent/tests/mup.mup2.PUT.xml +++ /dev/null @@ -1,15 +0,0 @@ - - 0600006CC8 - Gas Mirroring - 13 - 1 - 1 - 247bd68e3378fe57ba604e3c8bdf9e3f78a3d743 - - 1200006CC8 - EnergyEXP - - 128 - - - \ No newline at end of file diff --git a/services/core/IEEE2030_5Agent/tests/test_IEEE2030_5_agent.py b/services/core/IEEE2030_5Agent/tests/test_IEEE2030_5_agent.py deleted file mode 100644 index f1d94b8ce3..0000000000 --- a/services/core/IEEE2030_5Agent/tests/test_IEEE2030_5_agent.py +++ /dev/null @@ -1,291 +0,0 @@ -# -*- coding: utf-8 -*- {{{ -# vim: set fenc=utf-8 ft=python sw=4 ts=4 sts=4 et: -# -# Copyright 2020, Battelle Memorial Institute. -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. -# -# This material was prepared as an account of work sponsored by an agency of -# the United States Government. Neither the United States Government nor the -# United States Department of Energy, nor Battelle, nor any of their -# employees, nor any jurisdiction or organization that has cooperated in the -# development of these materials, makes any warranty, express or -# implied, or assumes any legal liability or responsibility for the accuracy, -# completeness, or usefulness or any information, apparatus, product, -# software, or process disclosed, or represents that its use would not infringe -# privately owned rights. Reference herein to any specific commercial product, -# process, or service by trade name, trademark, manufacturer, or otherwise -# does not necessarily constitute or imply its endorsement, recommendation, or -# favoring by the United States Government or any agency thereof, or -# Battelle Memorial Institute. The views and opinions of authors expressed -# herein do not necessarily state or reflect those of the -# United States Government or any agency thereof. -# -# PACIFIC NORTHWEST NATIONAL LABORATORY operated by -# BATTELLE for the UNITED STATES DEPARTMENT OF ENERGY -# under Contract DE-AC05-76RL01830 -# }}} - -import pytest -import gevent -import requests - -from volttron.platform import get_services_core -from IEEE2030_5.end_device import IEEE2030_5Parser -from volttron.platform.agent.known_identities import PLATFORM_DRIVER - -DRIVER_NAME = 'IEEE2030_5' -DEVICE_ID = "097935300833" - -TEST_IEEE2030_5_CONFIG = { - "devices": [ - { - "sfdi": "097935300833", - "lfdi": "247bd68e3378fe57ba604e3c8bdf9e3f78a3d743", - "load_shed_device_category": "0200", - "pin_code": "130178" - }, - { - "sfdi": "111576577659", - "lfdi": "2990c58a59935a7d5838c952b1a453c967341a07", - "load_shed_device_category": "0200", - "pin_code": "130178" - } - ], - "IEEE2030_5_server_sfdi": "413707194130", - "IEEE2030_5_server_lfdi": "29834592834729384728374562039847629", - "load_shed_device_category": "0020", - "timezone": "America/Los_Angeles" -} - -REGISTRY_CONFIG_STRING = """Volttron Point Name,IEEE2030_5 Resource Name,IEEE2030_5 Field Name,Units,Writable,Default -b1_Md,DeviceInformation,mfModel,NA,FALSE,NA -b1_Opt,DeviceInformation,lFDI,NA,FALSE,NA -b1_SN,DeviceInformation,sFDI,NA,FALSE,NA -b1_Vr,DeviceInformation,mfHwVer,NA,FALSE,NA -b113_A,MirrorMeterReading,PhaseCurrentAvg,A,FALSE,NA -b113_DCA,MirrorMeterReading,InstantPackCurrent,A,FALSE,NA -b113_DCV,MirrorMeterReading,LineVoltageAvg,V,FALSE,NA -b113_DCW,MirrorMeterReading,PhasePowerAvg,W,FALSE,NA -b113_PF,MirrorMeterReading,PhasePFA,%,FALSE,NA -b113_WH,MirrorMeterReading,EnergyIMP,Wh,FALSE,NA -b120_AhrRtg,DERCapability,rtgAh,Ah,FALSE,NA -b120_ARtg,DERCapability,rtgA,A,FALSE,NA -b120_MaxChaRte,DERCapability,rtgMaxChargeRate,W,FALSE,NA -b120_MaxDisChaRte,DERCapability,rtgMaxDischargeRate,W,FALSE,NA -b120_WHRtg,DERCapability,rtgWh,Wh,FALSE,NA -b120_WRtg,DERCapability,rtgW,W,FALSE,NA -b121_WMax,DERSettings,setMaxChargeRate,W,FALSE,NA -b122_ActWh,MirrorMeterReading,EnergyEXP,Wh,FALSE,NA -b122_StorConn,DERStatus,storConnectStatus,NA,FALSE,NA -b124_WChaMax,DERControl,DERControlBase.opModFixedFlow,W,TRUE,NA -b403_Tmp,MirrorMeterReading,InstantPackTemp,C,FALSE,NA -b404_DCW,PowerStatus,PEVInfo.chargingPowerNow,W,FALSE,NA -b404_DCWh,DERAvailability,SOC,Wh,FALSE,NA -b802_LocRemCtl,DERStatus,localControlModeStatus,NA,FALSE,NA -b802_SoC,DERStatus,inverterStatus,%,FALSE,NA -b802_State,DERStatus,stateOfChargeStatus,NA,FALSE,NA""" - -web_address = "" - - -@pytest.fixture(scope="module") -def agent(request, volttron_instance_module_web): - - test_agent = volttron_instance_module_web.build_agent(identity="test_agent") - capabilities = {'edit_config_store': {'identity': PLATFORM_DRIVER}} - volttron_instance_module_web.add_capabilities(test_agent.core.publickey, capabilities) - # Configure a IEEE 2030.5 device in the Platform Driver - test_agent.vip.rpc.call('config.store', 'manage_delete_store', PLATFORM_DRIVER).get(timeout=10) - test_agent.vip.rpc.call('config.store', 'manage_store', PLATFORM_DRIVER, - 'devices/{}'.format(DRIVER_NAME), - """{ - "driver_config": { - "sfdi": "097935300833", - "IEEE2030_5_agent_id": "test_IEEE2030_5agent" - }, - "campus": "campus", - "building": "building", - "unit": "IEEE2030_5", - "driver_type": "IEEE2030_5", - "registry_config": "config://IEEE2030_5.csv", - "interval": 15, - "timezone": "US/Pacific", - "heart_beat_point": "Heartbeat" - }""", - 'json').get(timeout=10) - test_agent.vip.rpc.call('config.store', 'manage_store', PLATFORM_DRIVER, - 'IEEE2030_5.csv', - REGISTRY_CONFIG_STRING, - 'csv').get(timeout=10) - - # Install and start a IEEE2030_5Agent - IEEE2030_5_id = volttron_instance_module_web.install_agent(agent_dir=get_services_core("IEEE2030_5Agent"), - config_file=TEST_IEEE2030_5_CONFIG, - vip_identity='test_IEEE2030_5agent', - start=True) - print('IEEE2030_5 agent id: ', IEEE2030_5_id) - - # Install and start a PlatformDriverAgent - md_id = volttron_instance_module_web.install_agent(agent_dir=get_services_core("PlatformDriverAgent"), - config_file={}, - start=True) - print('platform driver agent id: ', md_id) - - global web_address - web_address = volttron_instance_module_web.bind_web_address - - def stop(): - volttron_instance_module_web.stop_agent(md_id) - volttron_instance_module_web.stop_agent(IEEE2030_5_id) - test_agent.core.stop() - - gevent.sleep(3) # wait for agents and devices to start - - request.addfinalizer(stop) - - return test_agent - - -class TestIEEE2030_5Agent: - """Regression tests for the IEEE 2030.5 Agent.""" - - def test_get_urls(self, agent): - """Test that a requests.get succeeds (200 status) for various URLs.""" - assert requests.get('{}/dcap'.format(web_address)).status_code == 200 - self.IEEE2030_5_http_get('tm') - self.IEEE2030_5_http_get('edev') - self.IEEE2030_5_http_get('sdev') - self.IEEE2030_5_http_get('sdev/di') - self.IEEE2030_5_http_get('sdev/log') - self.IEEE2030_5_http_get('edev/0') - self.IEEE2030_5_http_get('edev/0/reg') - self.IEEE2030_5_http_get('edev/0/fsa') - self.IEEE2030_5_http_get('edev/0/der') - self.IEEE2030_5_http_get('edev/0/der/1') - - def test_set_di(self, agent): - """Test that DeviceInformation can be fetched after it's been set.""" - assert self.IEEE2030_5_http_get('edev/0/di').mfInfo is None - assert self.get_point(agent, 'b1_Vr') is None - assert self.get_point(agent, 'b1_Md') is None - assert self.IEEE2030_5_http_put('edev/0/di', 'edev.di').status_code == 204 - assert self.IEEE2030_5_http_get('edev/0/di').mfInfo == 'Mf Information' - assert self.get_point(agent, 'b1_Vr') == 'MF-HW: 1.0.0' - assert self.get_point(agent, 'b1_Md') == 'Mf Model' - - def test_set_dstat(self, agent): - """Test that DeviceStatus can be fetched after it's been set.""" - self.IEEE2030_5_http_get('edev/0/dstat') - assert self.IEEE2030_5_http_put('edev/0/dstat', 'edev.dstat').status_code == 204 - assert self.IEEE2030_5_http_get('edev/0/dstat').onCount == 5 - - def test_set_ps(self, agent): - """Test that PowerStatus can be fetched after it's been set.""" - assert self.IEEE2030_5_http_get('edev/0/ps').totalTimeOnBattery is None - assert self.IEEE2030_5_http_put('edev/0/ps', 'edev.ps').status_code == 204 - assert self.IEEE2030_5_http_get('edev/0/ps').totalTimeOnBattery == 2 - - def test_get_derc(self, agent): - """Test that DERControl can be used to dispatch a power setting.""" - self.IEEE2030_5_http_get('edev/0/derc/1') - self.set_point(agent, 'b124_WChaMax', 30) - # The next assert would fail -- DERControlBase.opModFixedFlow returns None - # assert self.get_point(agent, 'b124_WChaMax') == 30 - - def test_set_dercap(self, agent): - """Test that DERCapability can be fetched after it's been set.""" - assert self.IEEE2030_5_http_get('edev/0/der/1/dercap').type_ is None - assert self.IEEE2030_5_http_put('edev/0/der/1/dercap', 'der.dercap').status_code == 204 - assert self.IEEE2030_5_http_get('edev/0/der/1/dercap').type_.get_valueOf_() == '85' - - def test_set_derg(self, agent): - """Test that DERSettings can be fetched after it's been set.""" - assert self.IEEE2030_5_http_get('edev/0/der/1/derg').setGradW is None - assert self.get_point(agent, 'b121_WMax') is None - assert self.IEEE2030_5_http_put('edev/0/der/1/derg', 'der.derg').status_code == 204 - assert self.IEEE2030_5_http_get('edev/0/der/1/derg').setGradW == 55000 - assert self.get_point(agent, 'b121_WMax') == 20.0 - - def test_set_dera(self, agent): - """Test that DERAvailability can be fetched after it's been set.""" - assert self.IEEE2030_5_http_get('edev/0/der/1/dera').maxChargeDuration is None - assert self.get_point(agent, 'b404_DCWh') is None - assert self.IEEE2030_5_http_put('edev/0/der/1/dera', 'der.dera').status_code == 204 - assert self.IEEE2030_5_http_get('edev/0/der/1/dera').maxChargeDuration == 3 - assert self.get_point(agent, 'b404_DCWh') == 305.7555555555556 - - def test_set_ders(self, agent): - """Test that DERStatus can be fetched after it's been set.""" - assert self.IEEE2030_5_http_get('edev/0/der/1/ders').stateOfChargeStatus is None - assert self.get_point(agent, 'b802_State') is None - assert self.get_point(agent, 'b802_LocRemCtl') is None - assert self.get_point(agent, 'b802_SoC') is None - assert self.get_point(agent, 'b122_StorConn') is None - assert self.IEEE2030_5_http_put('edev/0/der/1/ders', 'der.ders').status_code == 204 - assert self.IEEE2030_5_http_get('edev/0/der/1/ders').stateOfChargeStatus.value.get_valueOf_() == '777' - assert self.get_point(agent, 'b802_State') == 7.77 - assert self.get_point(agent, 'b802_LocRemCtl') == 777 - assert self.get_point(agent, 'b802_SoC') == 777 - assert self.get_point(agent, 'b122_StorConn') == 777 - - def test_mup(self, agent): - """Test that metrics can be fetched from a MirrorUsagePoint.""" - self.IEEE2030_5_http_get('mup') - assert self.IEEE2030_5_http_put('mup', 'mup.mup').status_code == 201 - assert self.IEEE2030_5_http_get('mup').MirrorUsagePoint[0].description == 'Gas Mirroring' - self.IEEE2030_5_http_put('mup/0', 'mup.mmr') - self.IEEE2030_5_http_get('mup') - assert self.get_point(agent, 'b113_A') == 24.0 - assert self.get_point(agent, 'b122_ActWh') is None - self.IEEE2030_5_http_put('mup/0', 'mup.mup2') - assert self.get_point(agent, 'b122_ActWh') == 128 - - @staticmethod - def get_point(agent, point_name): - """Ask IEEE2030_5Agent for a point value for a IEEE 2030.5 resource.""" - return agent.vip.rpc.call('test_IEEE2030_5agent', 'get_point', DEVICE_ID, point_name).get(timeout=10) - - @staticmethod - def set_point(agent, point_name, value): - """Use IEEE2030_5Agent to set a point value for a IEEE 2030.5 resource.""" - return agent.vip.rpc.call('test_IEEE2030_5agent', 'set_point', DEVICE_ID, point_name, value).get(timeout=10) - - @staticmethod - def IEEE2030_5_http_get(IEEE2030_5_resource_name): - """ - Issue a web request to GET data for a IEEE 2030.5 resource. - - :param IEEE2030_5_resource_name: The distinguishing part of the name of the IEEE 2030.5 resource as it appears - in the URL. - :return: XML - """ - r = requests.get('{}/dcap/{}'.format(web_address, IEEE2030_5_resource_name)) - assert r.status_code == 200 - return IEEE2030_5Parser.parse(r.text.encode('ascii', 'ignore')) - - @staticmethod - def IEEE2030_5_http_put(IEEE2030_5_resource_name, IEEE2030_5_filename): - """ - Issue a web request to PUT data for a IEEE 2030.5 resource, using the contents of an XML file. - - @param IEEE2030_5_resource_name: The distinguishing part of the name of the IEEE 2030.5 resource as it appears - in the URL. - @param IEEE2030_5_filename: The distinguishing part of the IEEE 2030.5 sample data file name. - """ - url = '{}/dcap/{}'.format(web_address, IEEE2030_5_resource_name) - headers = {'content-type': 'application/IEEE2030_5+xml'} - return requests.post(url, - data=open(get_services_core("IEEE2030_5Agent/tests/{}.PUT.xml").format(IEEE2030_5_filename), - 'rb'), - headers=headers) diff --git a/services/core/IEEE2030_5Agent/tests/test_IEEE2030_5_driver.py b/services/core/IEEE2030_5Agent/tests/test_IEEE2030_5_driver.py deleted file mode 100644 index 40e76206ac..0000000000 --- a/services/core/IEEE2030_5Agent/tests/test_IEEE2030_5_driver.py +++ /dev/null @@ -1,232 +0,0 @@ -# -*- coding: utf-8 -*- {{{ -# vim: set fenc=utf-8 ft=python sw=4 ts=4 sts=4 et: -# -# Copyright 2020, Battelle Memorial Institute. -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. -# -# This material was prepared as an account of work sponsored by an agency of -# the United States Government. Neither the United States Government nor the -# United States Department of Energy, nor Battelle, nor any of their -# employees, nor any jurisdiction or organization that has cooperated in the -# development of these materials, makes any warranty, express or -# implied, or assumes any legal liability or responsibility for the accuracy, -# completeness, or usefulness or any information, apparatus, product, -# software, or process disclosed, or represents that its use would not infringe -# privately owned rights. Reference herein to any specific commercial product, -# process, or service by trade name, trademark, manufacturer, or otherwise -# does not necessarily constitute or imply its endorsement, recommendation, or -# favoring by the United States Government or any agency thereof, or -# Battelle Memorial Institute. The views and opinions of authors expressed -# herein do not necessarily state or reflect those of the -# United States Government or any agency thereof. -# -# PACIFIC NORTHWEST NATIONAL LABORATORY operated by -# BATTELLE for the UNITED STATES DEPARTMENT OF ENERGY -# under Contract DE-AC05-76RL01830 -# }}} - -import time -import pytest -import gevent -import requests - -from volttron.platform import get_services_core - -DRIVER_NAME = 'IEEE2030_5' -DEVICE_ID = "097935300833" - -TEST_CONFIG = { - "devices": [ - { - "sfdi": "097935300833", - "lfdi": "247bd68e3378fe57ba604e3c8bdf9e3f78a3d743", - "load_shed_device_category": "0200", - "pin_code": "130178" - }, - { - "sfdi": "111576577659", - "lfdi": "2990c58a59935a7d5838c952b1a453c967341a07", - "load_shed_device_category": "0200", - "pin_code": "130178" - } - ], - "IEEE2030_5_server_sfdi": "413707194130", - "IEEE2030_5_server_lfdi": "29834592834729384728374562039847629", - "load_shed_device_category": "0020", - "timezone": "America/Los_Angeles" -} - -REGISTRY_CONFIG_STRING = """Volttron Point Name,IEEE2030_5 Resource Name,IEEE2030_5 Field Name,Units,Writable,Default -b1_Md,DeviceInformation,mfModel,NA,FALSE,NA -b1_Opt,DeviceInformation,lFDI,NA,FALSE,NA -b1_SN,DeviceInformation,sFDI,NA,FALSE,NA -b1_Vr,DeviceInformation,mfHwVer,NA,FALSE,NA -b113_A,MirrorMeterReading,PhaseCurrentAvg,NA,FALSE,NA -b113_DCA,MirrorMeterReading,InstantPackCurrent,A,FALSE,NA -b113_DCV,MirrorMeterReading,LineVoltageAvg,V,FALSE,NA -b113_DCW,MirrorMeterReading,PhasePowerAvg,W,FALSE,NA -b113_PF,MirrorMeterReading,PhasePFA,%,FALSE,NA -b113_WH,MirrorMeterReading,EnergyIMP,Wh,FALSE,NA -b120_AhrRtg,DERCapability,rtgAh,Ah,FALSE,NA -b120_ARtg,DERCapability,rtgA,A,FALSE,NA -b120_MaxChaRte,DERCapability,rtgMaxChargeRate,W,FALSE,NA -b120_MaxDisChaRte,DERCapability,rtgMaxDischargeRate,W,FALSE,NA -b120_WHRtg,DERCapability,rtgWh,Wh,FALSE,NA -b120_WRtg,DERCapability,rtgW,W,FALSE,NA -b121_WMax,DERSettings,setMaxChargeRate,W,FALSE,NA -b122_ActWh,MirrorMeterReading,EnergyEXP,Wh,FALSE,NA -b122_StorConn,DERStatus,storConnectStatus,NA,FALSE,NA -b124_WChaMax,DERControl,DERControlBase.opModFixedFlow,W,TRUE,NA -b403_Tmp,MirrorMeterReading,InstantPackTemp,C,FALSE,NA -b404_DCW,PowerStatus,PEVInfo.chargingPowerNow,W,FALSE,NA -b404_DCWh,DERAvailability,SOC,Wh,FALSE,NA -b802_LocRemCtl,DERStatus,localControlModeStatus,NA,FALSE,NA -b802_SoC,DERStatus,inverterStatus,%,FALSE,NA -b802_State,DERStatus,stateOfChargeStatus,NA,FALSE,NA""" - -ASSERTED_VALUES = { - 'b1_Md': 'Mf Model', - 'b1_SN': '097935300833', - 'b1_Vr': 'MF-HW: 1.0.0', - 'b113_A': '24.0', - 'b113_DCA': '125.0', - 'b113_DCV': '125.0', - 'b113_DCW': '125.0', - 'b113_PF': '126.0', - 'b113_WH': '127.0', - 'b120_AhrRtg': '350.0', - 'b120_ARtg': '330.0', - 'b120_MaxChaRte': '220.0', - 'b120_MaxDisChaRte': '10.0', - 'b120_WHRtg': '1230.0', - 'b120_WRtg': '10.0', - 'b121_WMax': '20.0', - 'b122_ActWh': '128.0', - 'b122_StorConn': '777', - 'b124_WChaMax': '10.0', - 'b403_Tmp': '128000.0', - 'b404_DCW': '3000.0', - 'b404_DCWh': '305.755555556', - 'b802_LocRemCtl': '777', - 'b802_SoC': '777', - 'b802_State': '7.77'} - -web_address = "" - - -@pytest.fixture(scope="module") -def agent(request, volttron_instance_module_web): - test_agent = volttron_instance_module_web.build_agent() - - # Configure a IEEE 2030.5 device in the Platform Driver - test_agent.vip.rpc.call('config.store', 'manage_delete_store', 'platform.driver').get(timeout=10) - test_agent.vip.rpc.call('config.store', 'manage_store', 'platform.driver', - 'devices/{}'.format(DRIVER_NAME), - """{ - "driver_config": { - "sfdi": "097935300833", - "IEEE2030_5_agent_id": "test_IEEE2030_5agent" - }, - "campus": "campus", - "building": "building", - "unit": "IEEE2030_5", - "driver_type": "IEEE2030_5", - "registry_config": "config://IEEE2030_5.csv", - "interval": 15, - "timezone": "US/Pacific", - "heart_beat_point": "Heartbeat" - }""", - 'json').get(timeout=10) - test_agent.vip.rpc.call('config.store', 'manage_store', 'platform.driver', - 'IEEE2030_5.csv', - REGISTRY_CONFIG_STRING, - 'csv').get(timeout=10) - - # Install and start a PlatformDriverAgent - md_id = volttron_instance_module_web.install_agent(agent_dir=get_services_core("PlatformDriverAgent"), - config_file={}, - start=True) - print('platform driver agent id: ', md_id) - - # Install and start a IEEE2030_5Agent - IEEE2030_5_id = volttron_instance_module_web.install_agent(agent_dir=get_services_core("IEEE2030_5Agent"), - config_file=TEST_CONFIG, - vip_identity='test_IEEE2030_5agent', - start=True) - print('IEEE 2030.5 agent id: ', IEEE2030_5_id) - - global web_address - web_address = volttron_instance_module_web.bind_web_address - - def stop(): - volttron_instance_module_web.stop_agent(md_id) - volttron_instance_module_web.stop_agent(IEEE2030_5_id) - test_agent.core.stop() - - gevent.sleep(10) # wait for agents and devices to start - - request.addfinalizer(stop) - - return test_agent - - -class TestIEEE2030_5Driver: - """Regression tests for the IEEE 2030.5 driver.""" - - def test_all_points(self, agent): - self.put_IEEE2030_5_data('edev/0/di', 'edev.di') # device_information - self.put_IEEE2030_5_data('edev/0/der/1/derg', 'der.derg') # der_settings - self.put_IEEE2030_5_data('edev/0/der/1/ders', 'der.ders') # der_status - self.put_IEEE2030_5_data('edev/0/der/1/dera', 'der.dera') # der_availability - self.put_IEEE2030_5_data('edev/0/der/1/dercap', 'der.dercap') # der_capabililty - self.put_IEEE2030_5_data('edev/0/ps', 'edev.ps') # power_status - self.put_IEEE2030_5_data('mup', 'mup.mup') # mup - self.put_IEEE2030_5_data('mup/0', 'mup.mup2') # mup (update) - self.put_IEEE2030_5_data('mup/0', 'mup.mmr') # mmr - - # Wait a few seconds to allow the HTTP requests to be processed (asynchronously?) - time.sleep(5) - - # Set the one settable point, the dispatched power value, and test that it comes back on a get_point - dispatch_point_name = 'b124_WChaMax' - dispatched_value = ASSERTED_VALUES[dispatch_point_name] - self.set_point(agent, dispatch_point_name, dispatched_value) - assert self.get_point(agent, dispatch_point_name) == dispatched_value - - # Test that each point has the test value that was posted to it - for point_name, expected_value in ASSERTED_VALUES.items(): - assert self.get_point(agent, point_name) == expected_value - - @staticmethod - def get_point(test_agent, point_name): - return test_agent.vip.rpc.call('platform.driver', 'get_point', DRIVER_NAME, point_name).get(timeout=10) - - @staticmethod - def set_point(test_agent, point_name, value): - return test_agent.vip.rpc.call('platform.driver', 'set_point', DRIVER_NAME, point_name, value).get(timeout=10) - - @staticmethod - def put_IEEE2030_5_data(IEEE2030_5_resource_name, IEEE2030_5_filename): - """ - PUT data for a IEEE 2030.5 resource, using the contents of an XML file in the current directory. - - @param IEEE2030_5_resource_name: The distinguishing part of the name of the IEEE 2030.5 resource as it appears - in the URL. - @param IEEE2030_5_filename: The distinguishing part of the IEEE 2030.5 sample data file name. - """ - url = '{}/dcap/{}'.format(web_address, IEEE2030_5_resource_name) - headers = {'content-type': 'application/sep+xml'} - requests.post(url, - data=open(get_services_core("IEEE2030_5Agent/tests/{}.PUT.xml".format(IEEE2030_5_filename)), 'rb'), - headers=headers) From c7d8956cdc2d14dd7d5113e97996e61f007354d7 Mon Sep 17 00:00:00 2001 From: Craig <3979063+craig8@users.noreply.github.com> Date: Wed, 19 Apr 2023 12:11:43 -0700 Subject: [PATCH 22/53] Update requirements_demo.txt added xsdata as requirement --- services/core/IEEE_2030_5/requirements_demo.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/services/core/IEEE_2030_5/requirements_demo.txt b/services/core/IEEE_2030_5/requirements_demo.txt index 86815f8db5..68d5ef09a7 100644 --- a/services/core/IEEE_2030_5/requirements_demo.txt +++ b/services/core/IEEE_2030_5/requirements_demo.txt @@ -1,3 +1,4 @@ pvlib nicegui -requests \ No newline at end of file +requests +xsdata From d8b76fa35de1bc44445f15935b8fd9d902df5224 Mon Sep 17 00:00:00 2001 From: Craig <3979063+craig8@users.noreply.github.com> Date: Wed, 19 Apr 2023 12:13:34 -0700 Subject: [PATCH 23/53] Update requirements_demo.txt Add other requirements to the requirements_demo --- services/core/IEEE_2030_5/requirements_demo.txt | 2 ++ 1 file changed, 2 insertions(+) diff --git a/services/core/IEEE_2030_5/requirements_demo.txt b/services/core/IEEE_2030_5/requirements_demo.txt index 68d5ef09a7..f7fd363301 100644 --- a/services/core/IEEE_2030_5/requirements_demo.txt +++ b/services/core/IEEE_2030_5/requirements_demo.txt @@ -2,3 +2,5 @@ pvlib nicegui requests xsdata +xsdata[cli] +blinker From a413d6ae948ffcdf36ed2c961e56eb38fe53dd69 Mon Sep 17 00:00:00 2001 From: Craig <3979063+craig8@users.noreply.github.com> Date: Wed, 19 Apr 2023 12:19:04 -0700 Subject: [PATCH 24/53] Update requirements_demo.txt Remove xsdata cli --- services/core/IEEE_2030_5/requirements_demo.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/services/core/IEEE_2030_5/requirements_demo.txt b/services/core/IEEE_2030_5/requirements_demo.txt index f7fd363301..c039ef0fef 100644 --- a/services/core/IEEE_2030_5/requirements_demo.txt +++ b/services/core/IEEE_2030_5/requirements_demo.txt @@ -2,5 +2,4 @@ pvlib nicegui requests xsdata -xsdata[cli] blinker From 3b39c14cc5ee127e1cd1f8d5246a2d0e62611bb3 Mon Sep 17 00:00:00 2001 From: Craig <3979063+craig8@users.noreply.github.com> Date: Wed, 19 Apr 2023 12:19:34 -0700 Subject: [PATCH 25/53] Update requirements.txt Removed xsdata cli from requirements --- services/core/IEEE_2030_5/requirements.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/services/core/IEEE_2030_5/requirements.txt b/services/core/IEEE_2030_5/requirements.txt index 212a0cebb1..6e0cbfbc31 100644 --- a/services/core/IEEE_2030_5/requirements.txt +++ b/services/core/IEEE_2030_5/requirements.txt @@ -1,3 +1,2 @@ xsdata -xsdata[cli] blinker From 06998f0c085c8abaec032e0eb9db6670157f15ec Mon Sep 17 00:00:00 2001 From: Chandrika Date: Wed, 19 Apr 2023 12:41:24 -0700 Subject: [PATCH 26/53] Update AGENT_DEMO.md --- services/core/IEEE_2030_5/AGENT_DEMO.md | 19 +------------------ 1 file changed, 1 insertion(+), 18 deletions(-) diff --git a/services/core/IEEE_2030_5/AGENT_DEMO.md b/services/core/IEEE_2030_5/AGENT_DEMO.md index 26499fdcbe..2217bf7365 100644 --- a/services/core/IEEE_2030_5/AGENT_DEMO.md +++ b/services/core/IEEE_2030_5/AGENT_DEMO.md @@ -65,28 +65,11 @@ For this demo, start a VOLTTRON default instance from the command line. The fol ```bash > cd $VOLTTRON_ROOT > source env/bin/activate - (volttron)> cd service/core/IEEE_2030_5 + (volttron)> cd services/core/IEEE_2030_5 (volttron)> pip install -r requirements_demo.txt ... ``` -1. Create an agent keypair for the 2030.5 agent to use (only needed for demo in real mode installing the agent would create this). - - ```bash - (volttron)> vctl keypair > demo/keypair.json - (volttron)> cat demo/keypair.json - { - "public": "YrRnX1ifv5hkctAtNsLMut1j3qr7dPf0gppvwH_53wE", - "secret": "C55SSFUKAM38dXZKjMSolRvFVfILbSTF9JkUQWlP8II" - } - ``` - -1. Add the publickey to VOLTTRON auth mechanism - - ```bash - (volttron)> vctl auth add --credentials "YrRnX1ifv5hkctAtNsLMut1j3qr7dPf0gppvwH_53wE" --user_id inverter1 - ``` - 1. Run the webgui.py script using the python interpretor. This should open a webpage allowing one to test the functionality of the 2030.5 agent. By default it will open at . ```bash From 04f5157536eda1313567d27328c7e4725a25b332 Mon Sep 17 00:00:00 2001 From: Chandrika Date: Wed, 19 Apr 2023 12:59:06 -0700 Subject: [PATCH 27/53] included env for run_command --- services/core/IEEE_2030_5/demo/webgui.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index 133ca2a516..a153080753 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -190,7 +190,8 @@ async def run_command(command: LabeledCommand) -> None: process = await asyncio.create_subprocess_exec( *shlex.split(command.command), stdout=asyncio.subprocess.PIPE, stderr=asyncio.subprocess.STDOUT, - cwd=command.working_dir + cwd=command.working_dir, + env=dict(os.environ) ) add_my_task(process) From 0a08fe7e91a3f0fd0110b78845e702c5dbed1813 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Mon, 24 Apr 2023 12:45:27 -0700 Subject: [PATCH 28/53] Update sequence diagram --- services/core/IEEE_2030_5/README.md | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/services/core/IEEE_2030_5/README.md b/services/core/IEEE_2030_5/README.md index 50176867dc..eca8959d84 100644 --- a/services/core/IEEE_2030_5/README.md +++ b/services/core/IEEE_2030_5/README.md @@ -7,14 +7,16 @@ The following diagram illistrates the data flow for the 2030.5 agent from the Pl ```mermaid sequenceDiagram + Agent->>Client: Creates Client Client->>Server: Creates MirrorUsagePoints Server-->>Client: 201 OK - Client->>PlatformDriverAgent: Subscribes to Device Data - PlatformDriverAgent->>Client: Publishes Device Data + Agent->>PlatformDriverAgent: Subscribes to Device Data + PlatformDriverAgent->>Agent: Publishes Device Data + Agent->>Client: Update Data Client->>Server: Posts MeterReadings(Device Data) Server-->>Client: 201 OK Client->>Server: Polls for active DERControls - Client->>PlatformDriverAgent: Publishes Event Controls + Agent->>PlatformDriverAgent: Publishes Event Controls ``` To better visualize how this works please try out the [Agent Demo](AGENT_DEMO.md). From 0ec64a2ef5332c0930bf4c70b4987ca512521f60 Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Fri, 28 Apr 2023 08:37:05 -0700 Subject: [PATCH 29/53] Reformat code files using yapf --- .../core/IEEE_2030_5/demo/inverter_runner.py | 53 ++-- services/core/IEEE_2030_5/demo/webgui.py | 126 ++++---- .../core/IEEE_2030_5/ieee_2030_5/__init__.py | 5 +- .../core/IEEE_2030_5/ieee_2030_5/agent.py | 106 ++++--- .../core/IEEE_2030_5/ieee_2030_5/client.py | 287 ++++++++---------- services/core/IEEE_2030_5/setup.py | 21 +- 6 files changed, 280 insertions(+), 318 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/inverter_runner.py b/services/core/IEEE_2030_5/demo/inverter_runner.py index 670933139e..62666744ae 100644 --- a/services/core/IEEE_2030_5/demo/inverter_runner.py +++ b/services/core/IEEE_2030_5/demo/inverter_runner.py @@ -32,27 +32,30 @@ # secretkey: str # serverkey: str = None + class MyInverterAgent(Agent): + def __init__(self, **kwargs): super().__init__(**kwargs) - + self._points = {} self._points['pf'] = 0.99 self._generator = None - + @RPC.export def set_point(self, point, value): self._generator = None self._points[point] = value - + @RPC.export def get_point(self, point): return self._points.get(point) - + @property def reset(self): return self._generator is not None - + + def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Generator: # PV module sandia_modules = pvlib.pvsystem.retrieve_sam('SandiaMod') @@ -73,16 +76,13 @@ def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Genera weather_path = Path(__file__).parent.joinpath("weather.txt") if weather_path.exists(): header = [ - "time(UTC)", "temp_air", "relative_humidity", "ghi", "dni", "dhi", - "IR(h)", "wind_speed", "wind_direction", "pressure" + "time(UTC)", "temp_air", "relative_humidity", "ghi", "dni", "dhi", "IR(h)", + "wind_speed", "wind_direction", "pressure" ] weather = pd.read_csv(weather_path) else: - weather = pvlib.iotools.get_pvgis_tmy(latitude, - longitude, - map_variables=True)[0] + weather = pvlib.iotools.get_pvgis_tmy(latitude, longitude, map_variables=True)[0] result = weather.to_csv(weather_path, header=True) - total_solar_radiance = weather['ghi'] # assumed that the total solar radiance is equal to ghi(global horizontal irradiance) @@ -106,13 +106,13 @@ def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Genera i_x=dc['i_x'], i_xx=dc['i_xx'], v_oc=dc['v_oc'], - i_sc=dc['i_sc'], - s_ac=p_ac, + i_sc=dc['i_sc'], + s_ac=p_ac, v_ac=v_ac, i_ac=i_ac) print(json.dumps(results)) yield results - # single phase circuit calculation + # single phase circuit calculation @dataclass @@ -136,28 +136,28 @@ def frombus(message: List) -> AllPoints: for k, v in message[0].items(): points.add(name=k, value=v, meta=message[1].get(k)) - return points + return points if __name__ == '__main__': logging.basicConfig(level=logging.DEBUG) logging.getLogger('volttron.platform.vip.agent.core').setLevel(logging.WARNING) - + from pathlib import Path # Impersonate the platform driver which is going to publish all messages # to the bus. agent = build_agent(identity='platform.driver', agent_class=MyInverterAgent) - + control_path = Path('inverter.ctl') - + while True: - + gen = run_inverter() topic_to_publish = "devices/inverter1/all" pf = 0.99 - + for inv in gen: points = AllPoints() @@ -165,20 +165,17 @@ def frombus(message: List) -> AllPoints: points.add(k, v) # publish agent.vip.pubsub.publish(peer="pubsub", - topic=f"{topic_to_publish}", - message=points.forbus()) + topic=f"{topic_to_publish}", + message=points.forbus()) gevent.sleep(10) - + if control_path.exists(): data = control_path.open().read() try: obj = json.loads(data) except json.decoder.JSONDecodeError: obj = dict(pf=0.99) - + pf = obj.get('pf', 0.99) - - - - + agent.core.stop() \ No newline at end of file diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index a153080753..9576c0a1ec 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -36,6 +36,7 @@ session.cert = (str(tlsdir.joinpath("certs/admin.pem")), str(tlsdir.joinpath("private/admin.pem"))) session.verify = str(tlsdir.joinpath("certs/ca.pem")) + def get_url(endpoint, not_admin: bool = False) -> str: if endpoint.startswith('/'): endpoint = endpoint[1:] @@ -43,7 +44,8 @@ def get_url(endpoint, not_admin: bool = False) -> str: return f"https://127.0.0.1:8443/{endpoint}" return f"https://127.0.0.1:8443/admin/{endpoint}" -filedirectory = Path(__file__).parent + +filedirectory = Path(__file__).parent pkfile = filedirectory.joinpath("keypair.json") if not pkfile.exists(): print(f"Key file not found in demo directory {pkfile}.") @@ -60,9 +62,11 @@ def get_url(endpoint, not_admin: bool = False) -> str: tasks = [] + def add_my_task(task): tasks.append(task) - + + control_status = "None" derp = "Not Set" inverter_pf = "Not Set" @@ -71,12 +75,14 @@ def add_my_task(task): in_real = False in_reactive = False in_control = False + + def new_agent_output(line: str): global inverter_q, inverter_p, in_real, in_reactive, in_control, control_status - + if '' in line: in_control = True - + if in_control: if "" in line: status_value = int(re.search(r'(.*?)', line).group(1)) @@ -88,33 +94,32 @@ def new_agent_output(line: str): control_status = "Active" else: control_status = "Not Set" - in_control = False - + in_control = False + status.content = updated_markdown() - + if "url: /mup_1" in line: in_reactive = True - + if in_reactive: if line.startswith(""): inverter_q = re.search(r'(.*?)', line).group(1) in_reactive = False status.content = updated_markdown() - + if "url: /mup_1" in line: in_real = True - + if in_real: if line.startswith(""): inverter_p = re.search(r'(.*?)', line).group(1) in_real = False status.content = updated_markdown() - def _change_power_factor(new_pf): global inverter_pf - + current_time = int(time.mktime(datetime.utcnow().timetuple())) ctrl_base = m.DERControlBase(opModConnect=True, opModMaxLimW=9500) @@ -124,7 +129,8 @@ def _change_power_factor(new_pf): ctrl.randomizeDuration = 180 ctrl.randomizeStart = 180 ctrl.DERControlBase.opModFixedW = 500 - ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactorWithExcitation(displacement=int(pf.value)) + ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactorWithExcitation( + displacement=int(pf.value)) posted = dataclass_to_xml(ctrl) utility_log.push(f"Event Posted to Change opModFixedPFInjectW to {pf.value}") @@ -134,43 +140,40 @@ def _change_power_factor(new_pf): pfingect: m.DERControl = xml_to_dataclass(resp.text) inverter_pf = pfingect.DERControlBase.opModFixedPFInjectW.displacement status.content = updated_markdown() - - - - - + def get_control_event_default(): derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) - + time_plus_10 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) derc = m.DERControl(mRID=str(uuid.uuid4()), - description="New DER Control Event", - DERControlBase=derbase, - interval=m.DateTimeInterval(duration=10, start=time_plus_10)) - + description="New DER Control Event", + DERControlBase=derbase, + interval=m.DateTimeInterval(duration=10, start=time_plus_10)) + return dataclass_to_xml(derc) def _setup_event(element): derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) - + time_plus_60 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) derc = m.DERControl(mRID=str(uuid.uuid4()), - description="New DER Control Event", - DERControlBase=derbase, - interval=m.DateTimeInterval(duration=10, start=time_plus_60)) - element.value=dataclass_to_xml(derc) - + description="New DER Control Event", + DERControlBase=derbase, + interval=m.DateTimeInterval(duration=10, start=time_plus_60)) + element.value = dataclass_to_xml(derc) + #background_tasks.running_tasks.clear() - + + async def _exit_background_tasks(): for item in tasks: if isinstance(item, Process): try: - item.kill() # .cancel() + item.kill() # .cancel() except ProcessLookupError: pass else: @@ -178,24 +181,24 @@ async def _exit_background_tasks(): # async for proc, command in tasks: # print(f"Stoping {command.label}") # proc.cancel() - + tasks.clear() agent_log.clear() inverter_log.clear() utility_log.clear() - + + async def run_command(command: LabeledCommand) -> None: '''Run a command in the background and display the output in the pre-created dialog.''' - - process = await asyncio.create_subprocess_exec( - *shlex.split(command.command), - stdout=asyncio.subprocess.PIPE, stderr=asyncio.subprocess.STDOUT, - cwd=command.working_dir, - env=dict(os.environ) - ) - + + process = await asyncio.create_subprocess_exec(*shlex.split(command.command), + stdout=asyncio.subprocess.PIPE, + stderr=asyncio.subprocess.STDOUT, + cwd=command.working_dir, + env=dict(os.environ)) + add_my_task(process) - + # NOTE we need to read the output in chunks, otherwise the process will block output = '' while True: @@ -205,7 +208,7 @@ async def run_command(command: LabeledCommand) -> None: output = new.decode() if command.agent_output: new_agent_output(output.strip()) - + try: jsonparsed = json.loads(output) if command.output_element is not None: @@ -213,10 +216,11 @@ async def run_command(command: LabeledCommand) -> None: except json.decoder.JSONDecodeError: if not command.output_only_json: command.output_element().push(output.strip()) - + # NOTE the content of the markdown element is replaced every time we have new output #result.content = f'```\n{output}\n```' + @dataclass class LabeledCommand: label: str @@ -226,17 +230,18 @@ class LabeledCommand: output_only_json: bool = True agent_output: bool = False + commands = [ - LabeledCommand("Start Inverter", - f'{sys.executable} inverter_runner.py', - lambda: inverter_log), - LabeledCommand("Start Agent", - f"{sys.executable} {py_launch} {agent_py}", - lambda: agent_log, filedirectory.parent, + LabeledCommand("Start Inverter", f'{sys.executable} inverter_runner.py', lambda: inverter_log), + LabeledCommand("Start Agent", + f"{sys.executable} {py_launch} {agent_py}", + lambda: agent_log, + filedirectory.parent, output_only_json=False, agent_output=True) ] + def updated_markdown() -> str: return f"""#### Status Control: {control_status} @@ -245,17 +250,21 @@ def updated_markdown() -> str: Power Factor (pf): {inverter_pf} """ + with ui.column(): # commands = [f'{sys.executable} inverter_runner.py'] with ui.row(): - + for command in commands: - ui.button(command.label, on_click=lambda _, c=command: add_my_task(background_tasks.create(run_command(c)))).props('no-caps') - + ui.button(command.label, + on_click=lambda _, c=command: add_my_task( + background_tasks.create(run_command(c)))).props('no-caps') + pf = ui.select(options=[70, 80, 90], value=70, label="Power Factor").classes('w-32') - ui.button("Change Power Factor", on_click=lambda: _change_power_factor(pf.value)).props('no-caps') + ui.button("Change Power Factor", + on_click=lambda: _change_power_factor(pf.value)).props('no-caps') ui.button("Reset", on_click=_exit_background_tasks).props('no-caps') - + with ui.row(): status = ui.markdown(updated_markdown()) #ui.button("Update Control Time", on_click=lambda: _setup_event(xml_text)).props('no-caps') @@ -271,17 +280,14 @@ def updated_markdown() -> str: with ui.row(): ui.label("Agent Log") agent_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-80') - + with ui.row(): ui.label("Utility Log") utility_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') - - - #atexit.register(_exit_background_tasks) app.on_shutdown(_exit_background_tasks) -# NOTE on windows reload must be disabled to make asyncio.create_subprocess_exec work +# NOTE on windows reload must be disabled to make asyncio.create_subprocess_exec work # (see https://github.com/zauberzeug/nicegui/issues/486) ui.run(reload=platform.system() != "Windows", ) diff --git a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py index 602b20dbcf..9b59a6477c 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py @@ -26,7 +26,7 @@ def serialize_dataclass(obj) -> str: """ if not is_dataclass(obj): raise ValueError("Invalid object, must be a dataclass object.") - + return __serializer__.render(obj, ns_map=__ns_map__) @@ -63,5 +63,6 @@ def frombus(message: List) -> AllPoints: points.add(name=k, value=v, meta=message[1].get(k)) return points - + + import ieee_2030_5.models as models diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index f31802f81a..06e9fb966d 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -24,7 +24,7 @@ from ieee_2030_5 import AllPoints from ieee_2030_5.client import IEEE_2030_5_Client -try: # for modular +try: # for modular from volttron import utils from volttron.client.messaging.health import STATUS_GOOD from volttron.client.vip.agent import RPC, Agent, Core, PubSub @@ -69,20 +69,22 @@ def __init__(self, config_path: str, **kwargs): self._der_capabilities_info = config.get("DERCapability") self._der_settings_info = config.get("DERSettings") self._der_status_info = config.get("DERStatus") - self._default_config = {"subscriptions": self._subscriptions, - "MirrorUsagePointList": self._mirror_usage_point_list } + self._default_config = { + "subscriptions": self._subscriptions, + "MirrorUsagePointList": self._mirror_usage_point_list + } self._server_usage_points: m.UsagePointList self._client = IEEE_2030_5_Client(cafile=self._cacertfile, - server_hostname=self._server_hostname, - keyfile=self._keyfile, - certfile=self._certfile, - server_ssl_port=self._server_ssl_port, - pin=self._pin) - - # Hook up events so we can respond to them appropriately + server_hostname=self._server_hostname, + keyfile=self._keyfile, + certfile=self._certfile, + server_ssl_port=self._server_ssl_port, + pin=self._pin) + + # Hook up events so we can respond to them appropriately self._client.der_control_event_started(self._control_event_started) self._client.der_control_event_ended(self._control_event_ended) - + self._client.start() _log.info(self._client.enddevice) assert self._client.enddevice @@ -91,41 +93,38 @@ def __init__(self, config_path: str, **kwargs): self._mup_readings: Dict[str, m.MirrorMeterReading] = {} self._mup_pollRate: int = 60 self._times_published: Dict[str, int] = {} - - + # Set a default configuration to ensure that self.configure is called immediately to setup # the agent. self.vip.config.set_default("config", self._default_config) # Hook self.configure up to changes to the configuration file "config". - self.vip.config.subscribe(self.configure, - actions=["NEW", "UPDATE"], - pattern="config") - + self.vip.config.subscribe(self.configure, actions=["NEW", "UPDATE"], pattern="config") + @RPC.export def update_der_settings(self, href: str, new_settings: m.DERSettings) -> int: resp = self._client.put_der_settings(href, new_settings) return resp - + @RPC.export def update_der_availability(self, href: str, new_availability: m.DERAvailability) -> int: resp = self._client.put_der_availability(href, new_availability) return resp - + @RPC.export def update_der_status(self, href: str, new_availability: m.DERAvailability) -> int: resp = self._client.put_der_status(href, new_availability) return resp - + @RPC.export def get_der_references(self) -> List[str]: return self._client.get_der_hrefs() - + def _control_event_started(self, sender, **kwargs): _log.debug(f"Control event started {kwargs}") - + def _control_event_ended(self, sender, **kwargs): _log.debug(f"Control event ended {kwargs}") - + def dcap_updated(self, sender): _log.debug(f"Dcap was updated by {sender}") @@ -144,62 +143,59 @@ def configure(self, config_name, action, contents): try: subscriptions = config['subscriptions'] new_usage_points: Dict[str, m.MirrorUsagePoint] = {} - + for mup in config.get("MirrorUsagePointList", []): subscription_point = mup.pop('subscription_point') new_usage_points[mup['mRID']] = m.MirrorUsagePoint(**mup) new_usage_points[mup['mRID']].deviceLFDI = self._client.lfdi new_usage_points[mup['mRID']].MirrorMeterReading = [] - new_usage_points[mup['mRID']].MirrorMeterReading.append(m.MirrorMeterReading(**mup['MirrorMeterReading'])) + new_usage_points[mup['mRID']].MirrorMeterReading.append( + m.MirrorMeterReading(**mup['MirrorMeterReading'])) mup['subscription_point'] = subscription_point - + except ValueError as e: _log.error("ERROR PROCESSING CONFIGURATION: {}".format(e)) return for sub in self._subscriptions: - self.vip.pubsub.unsubscribe(peer="pubsub", - prefix=sub, - callback=self._data_published) + self.vip.pubsub.unsubscribe(peer="pubsub", prefix=sub, callback=self._data_published) self._subscriptions = subscriptions - + self._mup_readings.clear() self._mirror_usage_points.clear() - + ed = self._client.end_device self._mirror_usage_points.update(new_usage_points) server_usage_points = self._client.mirror_usage_point_list() self._mup_pollRate = server_usage_points.pollRate if server_usage_points.pollRate else self._mup_pollRate - + for mup in self._mirror_usage_points.values(): try: - found = next(filter(lambda x: x.mRID == mup.mRID, server_usage_points.MirrorUsagePoint)) + found = next( + filter(lambda x: x.mRID == mup.mRID, server_usage_points.MirrorUsagePoint)) except StopIteration: # TODO Create new usage point location = self._client.create_mirror_usage_point(mup) - mup_reading = m.MirrorMeterReading(mRID=mup.MirrorMeterReading[0].mRID, - href=location, - description=mup.MirrorMeterReading[0].description) - rs = m.MirrorReadingSet(mRID=mup_reading.mRID + "1", - timePeriod=m.DateTimeInterval()) + mup_reading = m.MirrorMeterReading( + mRID=mup.MirrorMeterReading[0].mRID, + href=location, + description=mup.MirrorMeterReading[0].description) + rs = m.MirrorReadingSet(mRID=mup_reading.mRID + "1", + timePeriod=m.DateTimeInterval()) rs.timePeriod.start = int(round(datetime.utcnow().timestamp())) rs.timePeriod.duration = self._mup_pollRate # new mrid is based upon the mirror reading. mup_reading.MirrorReadingSet.append(rs) rs.Reading = [] - + self._mup_readings[mup_reading.mRID] = mup_reading - - + self._server_usage_points = self._client.mirror_usage_point_list() - for sub in self._subscriptions: - self.vip.pubsub.subscribe(peer="pubsub", - prefix=sub, - callback=self._data_published) + self.vip.pubsub.subscribe(peer="pubsub", prefix=sub, callback=self._data_published) def _data_published(self, peer, sender, bus, topic, headers, message): """ @@ -207,11 +203,9 @@ def _data_published(self, peer, sender, bus, topic, headers, message): """ _log.debug("DATA Published") points = AllPoints.frombus(message) - + _log.debug(points) - - - + for index, pt in enumerate(self._mirror_usage_point_list): if pt["subscription_point"] in points.points: reading_mRID = pt["MirrorMeterReading"]['mRID'] @@ -220,20 +214,22 @@ def _data_published(self, peer, sender, bus, topic, headers, message): rs = reading.MirrorReadingSet[rs_index] rs.Reading.append(m.Reading(value=points.points[pt["subscription_point"]])) start = rs.timePeriod.start - if start + self._mup_pollRate * 1000 > int(round(datetime.utcnow().timestamp())): - self._times_published[reading_mRID] = self._times_published.get(reading_mRID, 0) + 1 - rs.mRID = "_".join([reading_mRID, str(self._times_published[reading_mRID])]) + if start + self._mup_pollRate * 1000 > int(round( + datetime.utcnow().timestamp())): + self._times_published[reading_mRID] = self._times_published.get( + reading_mRID, 0) + 1 + rs.mRID = "_".join( + [reading_mRID, str(self._times_published[reading_mRID])]) new_reading_href = self._client.post_mirror_reading(reading) _log.debug(f"New readings available: {new_reading_href}") rs.Reading.clear() rs.timePeriod.start = int(round(datetime.utcnow().timestamp())) rs.timePeriod.duration = self._mup_pollRate - - - + _log.debug(points.__dict__) + def main(): """ Main method called during startup of agent. diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index 627397b050..e7c7f43070 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -24,29 +24,32 @@ TimeType = int + class _TimerThread(threading.Thread): tick = Signal("tick") - + def __init__(self): super().__init__() self._tick = 0 - + @staticmethod def user_readable(timestamp: int): dt = datetime.fromtimestamp(timestamp) return dt.strftime("%m/%d/%Y, %H:%M:%S") - + def run(self) -> None: - + while True: self._tick = int(time.mktime(datetime.utcnow().timetuple())) _TimerThread.tick.send(self._tick) time.sleep(1) - + + TimerThread = _TimerThread() TimerThread.daemon = True TimerThread.start() + class IEEE_2030_5_Client: clients: set[IEEE_2030_5_Client] = set() @@ -71,13 +74,15 @@ def __init__(self, self._pin = pin # We know that these are Path objects now and have a .exists() function based upon above code. - assert cafile.exists(), f"cafile doesn't exist ({cafile})" # type: ignore[attr-defined] - assert keyfile.exists(), f"keyfile doesn't exist ({keyfile})" # type: ignore[attr-defined] - assert certfile.exists(), f"certfile doesn't exist ({certfile})" # type: ignore[attr-defined] + assert cafile.exists(), f"cafile doesn't exist ({cafile})" # type: ignore[attr-defined] + assert keyfile.exists( + ), f"keyfile doesn't exist ({keyfile})" # type: ignore[attr-defined] + assert certfile.exists( + ), f"certfile doesn't exist ({certfile})" # type: ignore[attr-defined] self._ssl_context = ssl.SSLContext(ssl.PROTOCOL_TLS_CLIENT) self._ssl_context.check_hostname = False - self._ssl_context.verify_mode = ssl.CERT_OPTIONAL # ssl.CERT_REQUIRED + self._ssl_context.verify_mode = ssl.CERT_OPTIONAL # ssl.CERT_REQUIRED self._ssl_context.load_verify_locations(cafile=cafile) # Loads client information from the passed cert and key files. For @@ -90,57 +95,54 @@ def __init__(self, self._response_headers: HTTPMessage self._response_status = None self._debug = debug - - - self._mup: m.MirrorUsagePointList = None # type: ignore - self._upt: m.UsagePointList = None # type: ignore - - + + self._mup: m.MirrorUsagePointList = None # type: ignore + self._upt: m.UsagePointList = None # type: ignore + self._dcap_poll_rate: int = 0 self._dcap_timer: Optional[Timer] = None self._disconnect: bool = False - + self._timers: Set[Timer] = set() # Offset between local udt and server udt self._time_offset: int = 0 - + self._end_device_map: Dict[str, m.EndDeviceList] = {} self._end_devices: Dict[str, m.EndDevice] = {} - + self._fsa_map: Dict[str, m.FunctionSetAssignmentsList] = {} self._fsa: Dict[str, m.FunctionSetAssignments] = {} - + self._der_map: Dict[str, m.DERList] = {} self._der: Dict[str, m.DER] = {} - + self._der_program_map: Dict[str, m.DERProgramList] = {} self._der_program: Dict[str, m.DERProgram] = {} - + self._mirror_usage_point_map: Dict[str, m.MirrorUsagePointList] = {} self._mirror_usage_point: Dict[str, m.MirrorUsagePoint] = {} - + self._usage_point_map: Dict[str, m.UsagePointList] = {} self._usage_point: Dict[str, m.UsagePoint] = {} - + self._before_dcap_update_signal = Signal('before-dcap-request') self._after_dcap_update_signal = Signal('before-dcap-request') self._before_client_start_signal = Signal('before-client-start') self._after_client_start_signal = Signal('after-client-start') - + self._der_control_event_started_signal = Signal('der-control-event-started') self._der_control_event_ended_signal = Signal('der-control-event-ended') - + self._before_event_start_signal = Signal('before-event-start') self._after_event_end_signal = Signal('after-event-end') - - - self._dcap_endpoint = device_capabilities_endpoint + + self._dcap_endpoint = device_capabilities_endpoint # Starts a timer # self._update_dcap_tree(device_capabilities_endpoint) IEEE_2030_5_Client.clients.add(self) - + def start(self): """Starts the client connection to the 2030.5 server configured during construction. """ @@ -148,63 +150,62 @@ def start(self): self._update_dcap_tree() self._after_client_start_signal.send(self) TimerThread.tick.connect(self._tick) - + def _tick(self, timestamp): if timestamp % 20 == 0: for derp in self._der_program_map.items(): print(self.__get_request__(f"/derp_0_derc_0")) - + #_log.debug(f"Tick: {timestamp}") - + def der_control_event_started(self, fun: Callable): self._der_control_event_started_signal.connect(fun) - + def der_control_event_ended(self, fun: Callable): - self._der_control_event_ended_signal.connect(fun) - + self._der_control_event_ended_signal.connect(fun) + def before_dcap_update(self, fun: Callable): self._before_dcap_update_signal.connect(fun) - + def after_dcap_update(self, fun: Callable): self._after_dcap_update_signal.connect(fun) - + def after_client_start(self, fun: Callable): self._after_client_start_signal.connect(fun) - + def before_client_start(self, fun: Callable): self._before_client_start_signal.connect(fun) - + @property def server_time(self) -> TimeType: return int(time.mktime(datetime.utcnow().timetuple())) + self._time_offset - @property def _is_ok(self): return self._response_status == 200 - + def get_der_hrefs(self) -> List[str]: return list(self._der.keys()) - + def get_der(self, href: str) -> Optional[m.DER]: return self._der.get(href) - - def put_der_availability(self, der_href: str, new_availability: m.DERAvailability) -> int: + + def put_der_availability(self, der_href: str, new_availability: m.DERAvailability) -> int: resp = self.__put__(der_href, dataclass_to_xml(new_availability)) return resp.status - + def put_der_capability(self, der_href: str, new_capability: m.DERCapability) -> int: resp = self.__put__(der_href, dataclass_to_xml(new_capability)) return resp.status - + def put_der_settings(self, der_href: str, new_settings: m.DERSettings) -> int: resp = self.__put__(der_href, dataclass_to_xml(new_settings)) return resp.status - + def put_der_status(self, der_href: str, new_status: m.DERStatus) -> int: resp = self.__put__(der_href, dataclass_to_xml(new_status)) return resp.status - + def _update_dcap_tree(self, endpoint: Optional[str] = None): """Retrieve the DeviceCapability and downstream link objects. @@ -221,61 +222,58 @@ def _update_dcap_tree(self, endpoint: Optional[str] = None): endpoint = self._dcap_endpoint if not endpoint: raise ValueError("Invalid device_capability_endpoint specified in constructor.") - + self._before_dcap_update_signal.send(self) - + # retrieve device capabilities from the server dcap: m.DeviceCapability = self.__get_request__(endpoint) if not self._is_ok: raise RuntimeError(dcap) - + self._after_dcap_update_signal.send(self) - + # if time is available then grab and create an offset if dcap.TimeLink is not None and dcap.TimeLink.href: _time: m.Time = self.__get_request__(dcap.TimeLink.href) self._time_offset = int(time.mktime(datetime.utcnow().timetuple())) - _time.currentTime - + if dcap.EndDeviceListLink is not None and dcap.EndDeviceListLink.all > 0: - - self._update_list(dcap.EndDeviceListLink.href, "EndDevice", self._end_device_map, self._end_devices) - + + self._update_list(dcap.EndDeviceListLink.href, "EndDevice", self._end_device_map, + self._end_devices) + for ed in self._end_devices.values(): if not self.is_end_device_registered(ed, self._pin): raise ValueError(f"Device is not registered on this server!") - self._update_list(ed.FunctionSetAssignmentsListLink.href, - "FunctionSetAssignments", self._fsa_map, self._fsa) - + self._update_list(ed.FunctionSetAssignmentsListLink.href, "FunctionSetAssignments", + self._fsa_map, self._fsa) + if ed.DERListLink: derlist: m.DERList = self.__get_request__(ed.DERListLink.href) self._der_map[derlist.href] = derlist for index, der in enumerate(derlist.DER): self._der[der.href] = der - + for fsa in self._fsa.values(): if fsa.DERProgramListLink: - self._der_program_map[fsa.DERProgramListLink.href] = self.__get_request__(fsa.DERProgramListLink.href) - - - + self._der_program_map[fsa.DERProgramListLink.href] = self.__get_request__( + fsa.DERProgramListLink.href) + if dcap.MirrorUsagePointListLink is not None and dcap.MirrorUsagePointListLink.href: - self._update_list(dcap.MirrorUsagePointListLink.href, "MirrorUsagePoint", self._mirror_usage_point_map, self._mirror_usage_point) - - + self._update_list(dcap.MirrorUsagePointListLink.href, "MirrorUsagePoint", + self._mirror_usage_point_map, self._mirror_usage_point) + # if dcap.UsagePointListLink is not None and dcap.UsagePointListLink.href: # self._update_list(dcap.UsagePointListLink.href, "UsagePoint", self._usage_point_map, self._usage_point) - - self._dcap = dcap - - + + self._dcap = dcap + def post_log_event(self, end_device: m.EndDevice, log_event: m.LogEvent): if not log_event.createdDateTime: log_event.createdDateTime = self.server_time - - self.request(end_device.LogEventListLink.href, method="POST") - - - + + self.request(end_device.LogEventListLink.href, method="POST") + def _update_list(self, path: str, list_prop: str, outer_map: Dict, inner_map: Dict): """Update mappings using 2030.5 list nomoclature. @@ -293,26 +291,24 @@ def _update_list(self, path: str, list_prop: str, outer_map: Dict, inner_map: Di """ my_response = self.__get_request__(path) - + if not self._is_ok: raise RuntimeError(my_response) - + if my_response is not None: href = getattr(my_response, "href") outer_map[href] = my_response for inner in getattr(my_response, list_prop): href = getattr(inner, "href") inner_map[href] = inner - - + def _get_device_capabilities(self, endpoint: str) -> m.DeviceCapability: dcap: m.DeviceCapability = self.__get_request__(endpoint) if self._response_status != 200: raise RuntimeError(dcap) - + self._dcap = dcap - - + if self._device_cap.pollRate is not None: self._dcap_poll_rate = self._device_cap.pollRate else: @@ -321,19 +317,19 @@ def _get_device_capabilities(self, endpoint: str) -> m.DeviceCapability: _log.debug(f"devcap id {id(self._device_cap)}") _log.debug(threading.currentThread().name) _log.debug(f"DCAP: Poll rate: {self._dcap_poll_rate}") - self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, (self.device_capability, url)) + self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, + (self.device_capability, url)) self._dcap_timer.start() - + return self._device_cap - - + @property def lfdi(self) -> str: cmd = ["openssl", "x509", "-in", str(self._certfile), "-noout", "-fingerprint", "-sha256"] ret_value = subprocess.check_output(cmd, text=True) if "=" in ret_value: ret_value = ret_value.split("=")[1].strip() - + fp = ret_value.replace(":", "") lfdi = fp[:40] return lfdi @@ -343,11 +339,11 @@ def http_conn(self) -> HTTPSConnection: if self._http_conn.sock is None: self._http_conn.connect() return self._http_conn - + @property def enddevices(self) -> m.EndDeviceList: return self._end_devices - + @property def enddevice(self, href: str = "") -> m.EndDevice: """Retrieve a client's end device based upon the href of the end device. @@ -358,24 +354,22 @@ def enddevice(self, href: str = "") -> m.EndDevice: """ if not href: href = list(self._end_devices.keys())[0] - - end_device = self._end_devices.get(href) - + + end_device = self._end_devices.get(href) + return end_device - - + def __hash__(self) -> int: - return self._keyfile.read_text().__hash__() # type: ignore[attr-defined] - - def is_end_device_registered(self, end_device: m.EndDevice, - pin: int) -> bool: + return self._keyfile.read_text().__hash__() # type: ignore[attr-defined] + + def is_end_device_registered(self, end_device: m.EndDevice, pin: int) -> bool: reg = self.registration(end_device) return reg.pIN == pin def new_uuid(self, url: str = "/uuid") -> str: res = self.__get_request__(url) return res - + def get_enddevices(self) -> m.EndDeviceList: return self.__get_request__(self._device_cap.EndDeviceListLink.href) @@ -396,8 +390,7 @@ def self_device(self) -> m.EndDevice: return self.__get_request__(self._device_cap.SelfDeviceLink.href) def function_set_assignment(self) -> m.FunctionSetAssignmentsListLink: - fsa_list = self.__get_request__( - self.end_device().FunctionSetAssignmentsListLink.href) + fsa_list = self.__get_request__(self.end_device().FunctionSetAssignmentsListLink.href) return fsa_list def poll_timer(self, fn, args): @@ -416,9 +409,10 @@ def device_capability(self, url: str = "/dcap") -> m.DeviceCapability: _log.debug(f"devcap id {id(self._device_cap)}") _log.debug(threading.currentThread().name) _log.debug(f"DCAP: Poll rate: {self._dcap_poll_rate}") - self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, (self.device_capability, url)) + self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, + (self.device_capability, url)) self._dcap_timer.start() - + return self._device_cap def time(self) -> m.Time: @@ -428,32 +422,28 @@ def time(self) -> m.Time: def der_program_list(self, device: m.EndDevice) -> m.DERProgramList: fsa: m.FunctionSetAssignments = self.__get_request__( device.FunctionSetAssignmentsListLink.href) - der_programs_list: m.DERProgramList = self.__get_request__( - fsa.DERProgramListLink.href) + der_programs_list: m.DERProgramList = self.__get_request__(fsa.DERProgramListLink.href) return der_programs_list def post_mirror_reading(self, reading: m.MirrorMeterReading) -> str: data = dataclass_to_xml(reading) resp = self.__post__(reading.href, data=data) - + if not int(resp.status) >= 200 and int(resp.status) < 300: _log.error(f"Posting to {reading.href}") _log.error(f"Response status: {resp.status}") _log.error(f"{resp.read().decode('utf-8')}") - - + return resp.headers['Location'] - - + def mirror_usage_point_list(self) -> m.MirrorUsagePointList: mupl = self._mirror_usage_point_map.get(self._dcap.MirrorUsagePointListLink.href) - + return mupl def usage_point_list(self) -> m.UsagePointList: - self._upt = self.__get_request__( - self._device_cap.UsagePointListLink.href) + self._upt = self.__get_request__(self._device_cap.UsagePointListLink.href) return self._upt def registration(self, end_device: m.EndDevice) -> m.Registration: @@ -470,11 +460,7 @@ def disconnect(self): self._dcap_timer.cancel() IEEE_2030_5_Client.clients.remove(self) - def request(self, - endpoint: str, - body: dict = None, - method: str = "GET", - headers: dict = None): + def request(self, endpoint: str, body: dict = None, method: str = "GET", headers: dict = None): if method.upper() == 'GET': return self.__get_request__(endpoint, body, headers=headers) @@ -483,8 +469,7 @@ def request(self, print("Doing post") return self.__post__(endpoint, body, headers=headers) - def create_mirror_usage_point( - self, mirror_usage_point: m.MirrorUsagePoint) -> str: + def create_mirror_usage_point(self, mirror_usage_point: m.MirrorUsagePoint) -> str: """Create a new mirror usage point on the server. Args: @@ -496,68 +481,48 @@ def create_mirror_usage_point( The location of the new usage point href for posting to. """ data = dataclass_to_xml(mirror_usage_point) - resp = self.__post__(self._dcap.MirrorUsagePointListLink.href, - data=data) + resp = self.__post__(self._dcap.MirrorUsagePointListLink.href, data=data) return resp.headers['Location'] - def __put__(self, - url: str, - data: Any, - headers: Optional[Dict[str, str]] = None): + def __put__(self, url: str, data: Any, headers: Optional[Dict[str, str]] = None): if not headers: headers = {'Content-Type': 'text/xml'} - + if self._debug: print(f"----> POST REQUEST") print(f"url: {url} body: {data}") - - self.http_conn.request(method="POST", - headers=headers, - url=url, - body=data) + + self.http_conn.request(method="POST", headers=headers, url=url, body=data) response = self._http_conn.getresponse() - return response - - def __post__(self, - url: str, - data=None, - headers: Optional[Dict[str, str]] = None): + return response + + def __post__(self, url: str, data=None, headers: Optional[Dict[str, str]] = None): if not headers: headers = {'Content-Type': 'text/xml'} - + if self._debug: print(f"----> POST REQUEST") print(f"url: {url} body: {data}") - self.http_conn.request(method="POST", - headers=headers, - url=url, - body=data) + self.http_conn.request(method="POST", headers=headers, url=url, body=data) response = self._http_conn.getresponse() response_data = response.read().decode("utf-8") # response_data = response.read().decode("utf-8") if response_data and self._debug: print(f"<---- POST RESPONSE") - print(f"{response_data}") # toprettyxml()}") - + print(f"{response_data}") # toprettyxml()}") return response def __get_request__(self, url: str, body=None, headers: Optional[Dict] = None): if headers is None: - headers = { - "Connection": "keep-alive", - "keep-alive": "timeout=30, max=1000" - } + headers = {"Connection": "keep-alive", "keep-alive": "timeout=30, max=1000"} if self._debug: print(f"----> GET REQUEST") print(f"url: {url} body: {body}") - self.http_conn.request(method="GET", - url=url, - body=body, - headers=headers) - + self.http_conn.request(method="GET", url=url, body=body, headers=headers) + response = self._http_conn.getresponse() response_data = response.read().decode("utf-8") self._response_headers = response.headers @@ -569,7 +534,7 @@ def __get_request__(self, url: str, body=None, headers: Optional[Dict] = None): resp_xml = xml.dom.minidom.parseString(response_data) if resp_xml and self._debug: print(f"<---- GET RESPONSE") - print(f"{response_data}") # toprettyxml()}") + print(f"{response_data}") # toprettyxml()}") except xsdata.exceptions.ParserError as ex: if self._debug: @@ -614,11 +579,11 @@ def __release_clients__(): headers = {'Connection': 'Keep-Alive', 'Keep-Alive': "max=1000,timeout=30"} h = IEEE_2030_5_Client(cafile=SERVER_CA_CERT, - server_hostname="127.0.0.1", - server_ssl_port=8070, - keyfile=KEY_FILE, - certfile=CERT_FILE, - debug=True) + server_hostname="127.0.0.1", + server_ssl_port=8070, + keyfile=KEY_FILE, + certfile=CERT_FILE, + debug=True) # h2 = IEEE2030_5_Client(cafile=SERVER_CA_CERT, server_hostname="me.com", ssl_port=8000, # keyfile=KEY_FILE, certfile=KEY_FILE) dcap = h.device_capability() diff --git a/services/core/IEEE_2030_5/setup.py b/services/core/IEEE_2030_5/setup.py index cc64769bff..ea0e8136d6 100644 --- a/services/core/IEEE_2030_5/setup.py +++ b/services/core/IEEE_2030_5/setup.py @@ -37,7 +37,8 @@ # }}} from os import path -from setuptools import setup, find_packages + +from setuptools import find_packages, setup MAIN_MODULE = 'agent' @@ -59,14 +60,10 @@ __version__ = _temp.__version__ # Setup -setup( - name=agent_package + 'agent', - version=__version__, - install_requires=['volttron'], - packages=packages, - entry_points={ - 'setuptools.installation': [ - 'eggsecutable = ' + agent_module + ':main', - ] - } -) +setup(name=agent_package + 'agent', + version=__version__, + install_requires=['volttron'], + packages=packages, + entry_points={'setuptools.installation': [ + 'eggsecutable = ' + agent_module + ':main', + ]}) From d295d3c1e10df3641060e3434b254f5f1530875b Mon Sep 17 00:00:00 2001 From: "C. Allwardt" <3979063+craig8@users.noreply.github.com> Date: Wed, 3 May 2023 13:25:07 -0700 Subject: [PATCH 30/53] Updates based on feedback. --- scripts/pycharm-launch.py | 2 +- services/core/IEEE_2030_5/README.md | 16 +- services/core/IEEE_2030_5/demo/server.yml | 1 + services/core/IEEE_2030_5/example.config.yml | 3 + .../core/IEEE_2030_5/ieee_2030_5/agent.py | 26 +-- .../core/IEEE_2030_5/ieee_2030_5/client.py | 169 ++++++++++++------ 6 files changed, 146 insertions(+), 71 deletions(-) diff --git a/scripts/pycharm-launch.py b/scripts/pycharm-launch.py index 02a51a35c7..f203a1b243 100644 --- a/scripts/pycharm-launch.py +++ b/scripts/pycharm-launch.py @@ -106,7 +106,7 @@ def write_required_statement(out=sys.stderr): sys.stderr.write("AGENT_VIP_IDENTITY MUST be set in environment\n") sys.exit(10) -valid_chars = "_.%s%s" % (string.ascii_letters, string.digits) +valid_chars = "_.-%s%s" % (string.ascii_letters, string.digits) for c in agent_identity: if c not in valid_chars: diff --git a/services/core/IEEE_2030_5/README.md b/services/core/IEEE_2030_5/README.md index eca8959d84..e516f98c00 100644 --- a/services/core/IEEE_2030_5/README.md +++ b/services/core/IEEE_2030_5/README.md @@ -11,15 +11,15 @@ The following diagram illistrates the data flow for the 2030.5 agent from the Pl Client->>Server: Creates MirrorUsagePoints Server-->>Client: 201 OK Agent->>PlatformDriverAgent: Subscribes to Device Data - PlatformDriverAgent->>Agent: Publishes Device Data - Agent->>Client: Update Data + PlatformDriverAgent->>Agent: Agent Receives Device Data + Agent->>Client: Update Data in Client Client->>Server: Posts MeterReadings(Device Data) Server-->>Client: 201 OK Client->>Server: Polls for active DERControls Agent->>PlatformDriverAgent: Publishes Event Controls ``` -To better visualize how this works please try out the [Agent Demo](AGENT_DEMO.md). +To see this process in action, please try out the [Agent Demo](AGENT_DEMO.md). ## Agent Config File @@ -40,6 +40,9 @@ certfile: ~/tls/certs/dev1.pem # the pin number is used to verify the server is the correct server pin: 111115 +# Log the request and responses from the server. +log_req_resp: true + # SSL defaults to 443 server_ssl_port: 8443 @@ -51,6 +54,9 @@ MirrorUsagePointList: # # NOTE: The subscription point will be a member of an "all" message from # the PlatformDriverAgent. + # + # NOTE: MRID must be hex digits meaning A-F and numeric values only and the + # mRID for the MirrorUsagePoint and MirrorMeterReading are the same. - subscription_point: p_ac mRID: 5509D69F8B3535950000000000009182 description: DER Inverter Real Power @@ -95,10 +101,10 @@ subscriptions: ## Agent Installation -The 2030.5 agent can be installed using an activated terminal from the root of the volttron git repository: +The 2030.5 agent can be installed and started using an activated terminal from the root of the volttron git repository: ```bash -(volttron)>vctl install service/core/IEEE_2030_5 --agent-config example.config.yml --vip-identity inverter1 +vctl install services/core/IEEE_2030_5 --start --agent-config services/core/IEEE_2030_5/example.config.yml --vip-identity inverter1 ``` ## 2030.5 Protocol diff --git a/services/core/IEEE_2030_5/demo/server.yml b/services/core/IEEE_2030_5/demo/server.yml index fd23623726..2d5da581a8 100644 --- a/services/core/IEEE_2030_5/demo/server.yml +++ b/services/core/IEEE_2030_5/demo/server.yml @@ -27,6 +27,7 @@ generate_admin_cert: True log_event_list_poll_rate: 60 device_capability_poll_rate: 60 +usage_point_post_rate: 60 # derp_poll_rate: 10 # End Device diff --git a/services/core/IEEE_2030_5/example.config.yml b/services/core/IEEE_2030_5/example.config.yml index 5ab7658801..d2a3f656ac 100644 --- a/services/core/IEEE_2030_5/example.config.yml +++ b/services/core/IEEE_2030_5/example.config.yml @@ -6,6 +6,9 @@ server_hostname: 127.0.0.1 # the pin number is used to verify the server is the correct server pin: 111115 +# Log the request and responses from the server. +log_req_resp: true + # SSL defaults to 443 server_ssl_port: 8443 # http port defaults to none diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index 06e9fb966d..acaf08f8fb 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -61,6 +61,7 @@ def __init__(self, config_path: str, **kwargs): self._keyfile = Path(config['keyfile']).expanduser() self._certfile = Path(config['certfile']).expanduser() self._pin = config['pin'] + self._log_req_resp = bool(config.get('log_req_resp', False)) self._subscriptions = config["subscriptions"] self._server_hostname = config["server_hostname"] self._server_ssl_port = config.get("server_ssl_port", 443) @@ -74,18 +75,24 @@ def __init__(self, config_path: str, **kwargs): "MirrorUsagePointList": self._mirror_usage_point_list } self._server_usage_points: m.UsagePointList + self._client = IEEE_2030_5_Client(cafile=self._cacertfile, server_hostname=self._server_hostname, keyfile=self._keyfile, certfile=self._certfile, server_ssl_port=self._server_ssl_port, - pin=self._pin) + pin=self._pin, + log_req_resp=self._log_req_resp) # Hook up events so we can respond to them appropriately self._client.der_control_event_started(self._control_event_started) self._client.der_control_event_ended(self._control_event_ended) - self._client.start() + try: + self._client.start() + except ConnectionRefusedError: + _log.error(f"Could not connect to server {self._server_hostname} agent exiting.") + sys.exit(1) _log.info(self._client.enddevice) assert self._client.enddevice self._point_to_reading_set: Dict[str, str] = {} @@ -201,11 +208,9 @@ def _data_published(self, peer, sender, bus, topic, headers, message): """ Callback triggered by the subscription setup using the topic from the agent's config file """ - _log.debug("DATA Published") + _log.debug(f"DATA Received from {sender}") points = AllPoints.frombus(message) - _log.debug(points) - for index, pt in enumerate(self._mirror_usage_point_list): if pt["subscription_point"] in points.points: reading_mRID = pt["MirrorMeterReading"]['mRID'] @@ -214,21 +219,20 @@ def _data_published(self, peer, sender, bus, topic, headers, message): rs = reading.MirrorReadingSet[rs_index] rs.Reading.append(m.Reading(value=points.points[pt["subscription_point"]])) start = rs.timePeriod.start - if start + self._mup_pollRate * 1000 > int(round( - datetime.utcnow().timestamp())): + if start + self._mup_pollRate < self._client.server_time: self._times_published[reading_mRID] = self._times_published.get( reading_mRID, 0) + 1 rs.mRID = "_".join( [reading_mRID, str(self._times_published[reading_mRID])]) new_reading_href = self._client.post_mirror_reading(reading) - _log.debug(f"New readings available: {new_reading_href}") + _log.info( + f"New readings({len(rs.Reading)}) posted available at: {new_reading_href}" + ) rs.Reading.clear() - rs.timePeriod.start = int(round(datetime.utcnow().timestamp())) + rs.timePeriod.start = self._client.server_time rs.timePeriod.duration = self._mup_pollRate - _log.debug(points.__dict__) - def main(): """ diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index e7c7f43070..718774c3d1 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -7,12 +7,13 @@ import threading import time import xml.dom.minidom +from dataclasses import dataclass, field from datetime import datetime from http.client import HTTPMessage, HTTPSConnection from os import PathLike from pathlib import Path -from threading import Timer -from typing import Any, Callable, Dict, List, Optional, Set, Tuple +from threading import Semaphore, Timer +from typing import Any, Callable, Dict, List, Optional, Set, Tuple, Union from uuid import uuid4 import ieee_2030_5.models as m @@ -21,8 +22,47 @@ from ieee_2030_5 import dataclass_to_xml, xml_to_dataclass _log = logging.getLogger(__name__) +_log_req_resp = logging.getLogger(f"{__name__}.req_resp") TimeType = int +StrPath = Union[str, Path] + + +@dataclass +class TimerSpec: + trigger_after_seconds: int + fn: Callable + args: List = field(default_factory=list) + kwargs: Dict = field(default_factory=dict) + enabled: bool = True + trigger_count: int = 0 + last_trigger_time: int = int(time.mktime(datetime.utcnow().timetuple())) + + def disable(self): + self.enabled = False + + def enable(self): + self.enabled = True + + def reset_count(self): + self.trigger_count = 0 + + def __eq__(self, other: object) -> bool: + if not isinstance(other, TimerSpec): + raise NotImplementedError( + f"Comparison between {self.__class__.__name__} and {type(other)} not implemented") + return self.fn is other.fn + + def trigger(self, current_time: int): + if self.last_trigger_time + self.trigger_after_seconds < current_time: + if self.args and self.kwargs: + self.fn(args=self.args, kwargs=self.kwargs) + elif self.args: + self.fn(args=self.args) + else: + self.fn() + self.trigger_count += 1 + self.last_trigger_time = current_time class _TimerThread(threading.Thread): @@ -55,34 +95,33 @@ class IEEE_2030_5_Client: # noinspection PyUnresolvedReferences def __init__(self, - cafile: PathLike, + cafile: StrPath, server_hostname: str, - keyfile: PathLike, - certfile: PathLike, + keyfile: StrPath, + certfile: StrPath, pin: str, server_ssl_port: Optional[int] = 443, debug: bool = True, - device_capabilities_endpoint: str = "/dcap"): + device_capabilities_endpoint: str = "/dcap", + log_req_resp: bool = True): - cafile = cafile if isinstance(cafile, PathLike) else Path(cafile) - keyfile = keyfile if isinstance(keyfile, PathLike) else Path(keyfile) - certfile = certfile if isinstance(certfile, PathLike) else Path(certfile) + self._cafile: Path = cafile if isinstance(cafile, Path) else Path(cafile) + self._keyfile: Path = keyfile if isinstance(keyfile, Path) else Path(keyfile) + self._certfile: Path = certfile if isinstance(certfile, Path) else Path(certfile) - self._keyfile = keyfile - self._certfile = certfile - self._cafile = cafile self._pin = pin # We know that these are Path objects now and have a .exists() function based upon above code. - assert cafile.exists(), f"cafile doesn't exist ({cafile})" # type: ignore[attr-defined] - assert keyfile.exists( + assert self._cafile.exists( + ), f"cafile doesn't exist ({cafile})" # type: ignore[attr-defined] + assert self._keyfile.exists( ), f"keyfile doesn't exist ({keyfile})" # type: ignore[attr-defined] - assert certfile.exists( + assert self._certfile.exists( ), f"certfile doesn't exist ({certfile})" # type: ignore[attr-defined] self._ssl_context = ssl.SSLContext(ssl.PROTOCOL_TLS_CLIENT) self._ssl_context.check_hostname = False - self._ssl_context.verify_mode = ssl.CERT_OPTIONAL # ssl.CERT_REQUIRED + self._ssl_context.verify_mode = ssl.CERT_REQUIRED self._ssl_context.load_verify_locations(cafile=cafile) # Loads client information from the passed cert and key files. For @@ -95,6 +134,9 @@ def __init__(self, self._response_headers: HTTPMessage self._response_status = None self._debug = debug + self._debug = log_req_resp + if not self._debug: + _log_req_resp.setLevel(logging.WARNING) self._mup: m.MirrorUsagePointList = None # type: ignore self._upt: m.UsagePointList = None # type: ignore @@ -103,7 +145,7 @@ def __init__(self, self._dcap_timer: Optional[Timer] = None self._disconnect: bool = False - self._timers: Set[Timer] = set() + self._timer_specs: Dict[str, TimerSpec] = {} # Offset between local udt and server udt self._time_offset: int = 0 @@ -138,8 +180,8 @@ def __init__(self, self._after_event_end_signal = Signal('after-event-end') self._dcap_endpoint = device_capabilities_endpoint - # Starts a timer - # self._update_dcap_tree(device_capabilities_endpoint) + + self._lock = Semaphore() IEEE_2030_5_Client.clients.add(self) @@ -151,12 +193,16 @@ def start(self): self._after_client_start_signal.send(self) TimerThread.tick.connect(self._tick) - def _tick(self, timestamp): - if timestamp % 20 == 0: - for derp in self._der_program_map.items(): - print(self.__get_request__(f"/derp_0_derc_0")) + def _tick(self, timestamp: int): + """Handles the timer event thread for the client. - #_log.debug(f"Tick: {timestamp}") + :param timestamp: The current timestamp + :type timestamp: int + """ + if self._lock.acquire(blocking=False): + for ts in self._timer_specs.values(): + ts.trigger(timestamp) + self._lock.release() def der_control_event_started(self, fun: Callable): self._der_control_event_started_signal.connect(fun) @@ -178,11 +224,15 @@ def before_client_start(self, fun: Callable): @property def server_time(self) -> TimeType: - return int(time.mktime(datetime.utcnow().timetuple())) + self._time_offset + """Returns the time on the server + + Uses an offset value from the 2030.5 Time function set to determine the + current time on the server. - @property - def _is_ok(self): - return self._response_status == 200 + :return: A calculated server_time including offset from time endpoint + :rtype: TimeType + """ + return int(time.mktime(datetime.utcnow().timetuple())) + self._time_offset def get_der_hrefs(self) -> List[str]: return list(self._der.keys()) @@ -207,16 +257,13 @@ def put_der_status(self, der_href: str, new_status: m.DERStatus) -> int: return resp.status def _update_dcap_tree(self, endpoint: Optional[str] = None): - """Retrieve the DeviceCapability and downstream link objects. - - Currently supports the following: - + """Retrieve device capability - - Args: - - endpoint - /dcap by default but can be passed if there is a different entry point into hte - system. + :param endpoint: _description_, defaults to None + :type endpoint: Optional[str], optional + :raises ValueError: _description_ + :raises RuntimeError: _description_ + :raises ValueError: _description_ """ if not endpoint: endpoint = self._dcap_endpoint @@ -227,11 +274,16 @@ def _update_dcap_tree(self, endpoint: Optional[str] = None): # retrieve device capabilities from the server dcap: m.DeviceCapability = self.__get_request__(endpoint) - if not self._is_ok: + if self._response_status != 200: raise RuntimeError(dcap) self._after_dcap_update_signal.send(self) + if dcap.pollRate is None: + dcap.pollRate = 900 + + self._update_timer_spec("dcap", dcap.pollRate, self._update_dcap_tree) + # if time is available then grab and create an offset if dcap.TimeLink is not None and dcap.TimeLink.href: _time: m.Time = self.__get_request__(dcap.TimeLink.href) @@ -243,6 +295,7 @@ def _update_dcap_tree(self, endpoint: Optional[str] = None): self._end_devices) for ed in self._end_devices.values(): + if not self.is_end_device_registered(ed, self._pin): raise ValueError(f"Device is not registered on this server!") self._update_list(ed.FunctionSetAssignmentsListLink.href, "FunctionSetAssignments", @@ -260,14 +313,29 @@ def _update_dcap_tree(self, endpoint: Optional[str] = None): fsa.DERProgramListLink.href) if dcap.MirrorUsagePointListLink is not None and dcap.MirrorUsagePointListLink.href: + print(self._mirror_usage_point) + print(self._mirror_usage_point_map) + print(id(self._mirror_usage_point)) + print(id(self._mirror_usage_point_map)) self._update_list(dcap.MirrorUsagePointListLink.href, "MirrorUsagePoint", self._mirror_usage_point_map, self._mirror_usage_point) + print(id(self._mirror_usage_point)) + print(id(self._mirror_usage_point_map)) + # for mup in self._mirror_usage_point.values(): + # if mup.postRate is not None: + # self._update_timer_spec(mup.href, mup.postRate, self.m._mi) # if dcap.UsagePointListLink is not None and dcap.UsagePointListLink.href: # self._update_list(dcap.UsagePointListLink.href, "UsagePoint", self._usage_point_map, self._usage_point) self._dcap = dcap + def _update_timer_spec(self, spec_name: str, rate: int, fn: Callable, *args, **kwargs): + ts = self._timer_specs.get(spec_name) + if ts is None: + ts = self._timer_specs[spec_name] = TimerSpec(rate, fn, args, kwargs) + ts.trigger_after_seconds = rate + def post_log_event(self, end_device: m.EndDevice, log_event: m.LogEvent): if not log_event.createdDateTime: log_event.createdDateTime = self.server_time @@ -292,7 +360,7 @@ def _update_list(self, path: str, list_prop: str, outer_map: Dict, inner_map: Di """ my_response = self.__get_request__(path) - if not self._is_ok: + if self._response_status != 200: raise RuntimeError(my_response) if my_response is not None: @@ -460,13 +528,12 @@ def disconnect(self): self._dcap_timer.cancel() IEEE_2030_5_Client.clients.remove(self) - def request(self, endpoint: str, body: dict = None, method: str = "GET", headers: dict = None): + def request(self, endpoint: str, body: dict = {}, method: str = "GET", headers: dict = {}): if method.upper() == 'GET': return self.__get_request__(endpoint, body, headers=headers) if method.upper() == 'POST': - print("Doing post") return self.__post__(endpoint, body, headers=headers) def create_mirror_usage_point(self, mirror_usage_point: m.MirrorUsagePoint) -> str: @@ -489,10 +556,9 @@ def __put__(self, url: str, data: Any, headers: Optional[Dict[str, str]] = None) headers = {'Content-Type': 'text/xml'} if self._debug: - print(f"----> POST REQUEST") - print(f"url: {url} body: {data}") + _log_req_resp.debug(f"----> PUT REQUEST\nurl: {url}\nbody: {data}") - self.http_conn.request(method="POST", headers=headers, url=url, body=data) + self.http_conn.request(method="PUT", headers=headers, url=url, body=data) response = self._http_conn.getresponse() return response @@ -501,16 +567,14 @@ def __post__(self, url: str, data=None, headers: Optional[Dict[str, str]] = None headers = {'Content-Type': 'text/xml'} if self._debug: - print(f"----> POST REQUEST") - print(f"url: {url} body: {data}") + _log_req_resp.debug(f"----> POST REQUEST\nurl: {url}\nbody: {data}") self.http_conn.request(method="POST", headers=headers, url=url, body=data) response = self._http_conn.getresponse() response_data = response.read().decode("utf-8") # response_data = response.read().decode("utf-8") if response_data and self._debug: - print(f"<---- POST RESPONSE") - print(f"{response_data}") # toprettyxml()}") + _log_req_resp.debug(f"<---- POST RESPONSE\n{response_data}") return response @@ -519,8 +583,7 @@ def __get_request__(self, url: str, body=None, headers: Optional[Dict] = None): headers = {"Connection": "keep-alive", "keep-alive": "timeout=30, max=1000"} if self._debug: - print(f"----> GET REQUEST") - print(f"url: {url} body: {body}") + _log_req_resp.debug(f"----> GET REQUEST\nurl: {url}\nbody: {body}") self.http_conn.request(method="GET", url=url, body=body, headers=headers) response = self._http_conn.getresponse() @@ -533,13 +596,11 @@ def __get_request__(self, url: str, body=None, headers: Optional[Dict] = None): response_obj = xml_to_dataclass(response_data) resp_xml = xml.dom.minidom.parseString(response_data) if resp_xml and self._debug: - print(f"<---- GET RESPONSE") - print(f"{response_data}") # toprettyxml()}") + _log_req_resp.debug(f"<---- GET RESPONSE\n{response_data}") # toprettyxml()}") except xsdata.exceptions.ParserError as ex: if self._debug: - print(f"<---- GET RESPONSE") - print(f"{response_data}") + _log_req_resp.debug("<---- GET RESPONSE\n{response_data}") response_obj = response_data return response_obj From 6ff3349e4cb8f5e2da87728aa25ff226eab78630 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 28 Sep 2023 20:39:45 -0700 Subject: [PATCH 31/53] Add test for 2030.5 Agent --- services/core/IEEE_2030_5/conftest.py | 6 + .../IEEE_2030_5/tests/test_20305_agent.py | 128 ++++++++++++++++++ volttrontesting/utils/platformwrapper.py | 33 ++++- 3 files changed, 166 insertions(+), 1 deletion(-) create mode 100644 services/core/IEEE_2030_5/conftest.py create mode 100644 services/core/IEEE_2030_5/tests/test_20305_agent.py diff --git a/services/core/IEEE_2030_5/conftest.py b/services/core/IEEE_2030_5/conftest.py new file mode 100644 index 0000000000..8559470457 --- /dev/null +++ b/services/core/IEEE_2030_5/conftest.py @@ -0,0 +1,6 @@ +import sys + +from volttrontesting.fixtures.volttron_platform_fixtures import * + +# Add system path of the agent's directory +sys.path.insert(0, os.path.abspath(os.path.dirname(__file__))) \ No newline at end of file diff --git a/services/core/IEEE_2030_5/tests/test_20305_agent.py b/services/core/IEEE_2030_5/tests/test_20305_agent.py new file mode 100644 index 0000000000..4a7b265ede --- /dev/null +++ b/services/core/IEEE_2030_5/tests/test_20305_agent.py @@ -0,0 +1,128 @@ +from __future__ import annotations +import json +from pathlib import Path + +import random +from dataclasses import dataclass, field +import time +from typing import Any, Dict, List + +import gevent +import pytest +import yaml + + +from volttron.platform import get_services_core +from volttron.platform.agent.known_identities import CONFIGURATION_STORE, PLATFORM_DRIVER +from volttron.platform.agent.utils import execute_command, is_auth_enabled +from volttron.platform.scheduling import periodic +from volttron.platform.vip.agent import Agent +from volttron.platform.vip.agent.core import Core +from volttron.platform.vip.agent.subsystems.rpc import RPC +from volttrontesting.utils.platformwrapper import PlatformWrapper +from requests import Session + +from ieee_2030_5 import xml_to_dataclass +import ieee_2030_5.models as m + + + + + +@dataclass +class AllPoints: + points: Dict = field(default_factory=dict) + meta: Dict = field(default_factory=dict) + + def add(self, name: str, value: Any, meta: Dict = {}): + self.points[name] = value + self.meta[name] = meta + + def forbus(self) -> List: + return [self.points, self.meta] + + +def test_inverter_agent_starts(volttron_instance: PlatformWrapper): + + vip_identity = "test_inverter" + test_config_file = Path(__file__).parent.joinpath("fixtures/test_config.yml") + test_config_file_data = yaml.safe_load(test_config_file.open("rt").read()) + config_name = test_config_file_data['point_map'][10:] + test_inverter_csv = Path(__file__).parent.joinpath("fixtures/test_inverter.csv") + volttron_instance.config_store_store(vip_identity, config_name, test_inverter_csv, "csv") + + agnt = volttron_instance.install_agent(agent_dir=get_services_core("IEEE_2030_5"), config_file=test_config_file.as_posix(), + start=True, vip_identity=vip_identity) + assert volttron_instance.is_agent_running(agnt) + + request_session = Session() + request_base_uri = f"https://{test_config_file_data['server_hostname']}:{test_config_file_data['server_ssl_port']}" + tls_path = Path(test_config_file_data["certfile"]).expanduser().parent.parent + request_session.cert = (tls_path.joinpath("certs/admin.crt"), tls_path.joinpath("private/admin.pem")) + request_session.verify = Path(test_config_file_data["cacertfile"]).expanduser().as_posix() + + # Note this was originally csv, but dictionaries are easier to deal with. + resp = volttron_instance.config_store_get(vip_identity, config_name) + points = json.loads(resp) + + assert points + + class MyActuator(Agent): + def __init__(self, **kwargs): + super().__init__(**kwargs) + + @RPC.export + def set_point(self, requester_id, topic, value, point=None): + print(f"{self.__class__.__name__} Set point called") + + + @RPC.export + def get_point(self, topic, point=None): + print(f"{self.__class__.__name__} Get point called") + + + class MyPlatformDriver(Agent): + def __init__(self, **kwargs): + super().__init__(**kwargs) + self.running_greenlets: List = [] + self.point_config = points + self.things_i_publish = [x for x in test_config_file_data["subscriptions"]] + self.things_i_published = [] + + self.point_values = {} + + @RPC.export + def set_point(self, path, point_name, value): + print(f"{self.__class__.__name__} Set point called") + + @RPC.export + def get_point(self, path, point_name): + print(f"{self.__class__.__name__} Get point called") + + + def do_a_publish(self): + for p in self.things_i_publish: + self.vip.pubsub.publish(peer="pubsub", + topic=p, + message=self.point_config) + + driver_agent = volttron_instance.build_agent(identity="platform.driver", agent_class=MyPlatformDriver) + actuator_agent = volttron_instance.build_agent(identity="platform.actuator", agent_class=MyActuator) + + def admin_uri(path): + return f"{request_base_uri}/admin/{path}" + + def uri(path): + return f"{request_base_uri}/{path}" + + resp = request_session.get(uri("mup")) + + mup_list: m.MirrorUsagePointList = xml_to_dataclass(resp.text) + + assert isinstance(mup_list, m.MirrorUsagePointList) + assert len(test_config_file_data['MirrorUsagePointList']) == mup_list.all + + resp = request_session.get(uri("upt")) + upt_list: m.UsagePointList = xml_to_dataclass(resp.text) + assert isinstance(upt_list, m.UsagePointList) + assert mup_list.all == upt_list.all \ No newline at end of file diff --git a/volttrontesting/utils/platformwrapper.py b/volttrontesting/utils/platformwrapper.py index 8f90472396..faa95b9b7b 100644 --- a/volttrontesting/utils/platformwrapper.py +++ b/volttrontesting/utils/platformwrapper.py @@ -2,7 +2,7 @@ import logging import os from pathlib import Path -from typing import Optional, Union +from typing import Literal, Optional, Union import uuid from urllib.parse import urlencode @@ -624,6 +624,37 @@ def add_capabilities(self, publickey, capabilities): # auth.update rpc call. So sleeping here instead expecting individual test cases to sleep for long gevent.sleep(2) return True + + file_types = Union[Literal["raw"], Literal["json"], Literal["csv"]] + + def config_store_get(self, vip_identity: str, name: str, file_type: Optional[Literal["raw"]] = None) -> str: + with with_os_environ(self.env): + self.__wait_for_control_connection_to_exit__() + env = self.env.copy() + file_type = None if file_type is None else "--raw" + + cmd = ['volttron-ctl', '--json', 'config', 'get', vip_identity, name] + + if file_type: + cmd.append(file_type) + + res = execute_command(cmd, env=env, logger=_log) + + print(res) + return res + + def config_store_store(self, identity: str, name: str, infile: Path, file_type: file_types = "json"): + with with_os_environ(self.env): + self.__wait_for_control_connection_to_exit__() + env = self.env.copy() + file_type = "--" + file_type + + cmd = ['volttron-ctl', '--json', 'config', 'store', identity, name, infile.absolute().as_posix(), file_type] + + res = execute_command(cmd, env=env, logger=_log) + + print(res) + def add_capability(self, entry, capabilities): if not self.auth_enabled: From 978c209a32d6a6ab6cb661ea7a30d804caa726f3 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 28 Sep 2023 20:40:05 -0700 Subject: [PATCH 32/53] update demo ui requirements. --- services/core/IEEE_2030_5/requirements_demo.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/services/core/IEEE_2030_5/requirements_demo.txt b/services/core/IEEE_2030_5/requirements_demo.txt index c039ef0fef..a42b148c45 100644 --- a/services/core/IEEE_2030_5/requirements_demo.txt +++ b/services/core/IEEE_2030_5/requirements_demo.txt @@ -3,3 +3,4 @@ nicegui requests xsdata blinker +plotly From 11a560d00713452f4df8622b7ad7f7c2b5286eb5 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 28 Sep 2023 20:42:23 -0700 Subject: [PATCH 33/53] Update agent and inverter_runner --- .../core/IEEE_2030_5/demo/inverter_runner.py | 73 +++++--- .../core/IEEE_2030_5/ieee_2030_5/agent.py | 112 ++++++++++- .../core/IEEE_2030_5/ieee_2030_5/client.py | 32 ++-- .../core/IEEE_2030_5/ieee_2030_5/utils.py | 14 ++ services/core/IEEE_2030_5/tests/get_dcap.py | 175 ++++++++++++++++++ .../core/IEEE_2030_5/tests/request_session.py | 56 ++++++ 6 files changed, 415 insertions(+), 47 deletions(-) create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/utils.py create mode 100644 services/core/IEEE_2030_5/tests/get_dcap.py create mode 100644 services/core/IEEE_2030_5/tests/request_session.py diff --git a/services/core/IEEE_2030_5/demo/inverter_runner.py b/services/core/IEEE_2030_5/demo/inverter_runner.py index 62666744ae..e6e7452ca3 100644 --- a/services/core/IEEE_2030_5/demo/inverter_runner.py +++ b/services/core/IEEE_2030_5/demo/inverter_runner.py @@ -14,24 +14,13 @@ import pandas as pd import pvlib import yaml +from volttron.platform.agent.utils import format_timestamp, get_aware_utc_now from volttron.platform.vip.agent import Agent from volttron.platform.vip.agent.subsystems.rpc import RPC from volttron.platform.vip.agent.utils import build_agent -# from typing import List, Optional, Dict -# from threading import Thread -# from threading import Timer - -# from ieee_2030_5.utils import serialize_dataclass - -# @dataclass -# class ZmqCredentials: -# address: str -# publickey: str -# secretkey: str -# serverkey: str = None - +_log = logging.getLogger(__name__) class MyInverterAgent(Agent): @@ -99,8 +88,8 @@ def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Genera # f"p_ac = {p_ac}, s_ac = {s_ac}, q_ac= {q_ac}, PF = {PF}, v_ac = {v_ac}, i_ac = {i_ac}" # ) results = dict(PF=PF, - p_ac=p_ac, - q_ac=q_ac, + INV_REAL_PWR=p_ac, + INV_REAC_PWR=q_ac, v_mp=dc['v_mp'], p_mp=dc['p_mp'], i_x=dc['i_x'], @@ -108,9 +97,12 @@ def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Genera v_oc=dc['v_oc'], i_sc=dc['i_sc'], s_ac=p_ac, - v_ac=v_ac, - i_ac=i_ac) - print(json.dumps(results)) + #v_ac=v_ac, + BAT_SOC=v_ac/p_ac, + i_ac=i_ac, + target_p=p_ac, + INV_OP_STATUS_MODE=3) + _log.info(json.dumps(results)) yield results # single phase circuit calculation @@ -140,7 +132,19 @@ def frombus(message: List) -> AllPoints: if __name__ == '__main__': - logging.basicConfig(level=logging.DEBUG) + import argparse + parser = argparse.ArgumentParser() + + parser.add_argument("output_file", help="File to write to when data arrives on the bus") + opts = parser.parse_args() + + logging.basicConfig(filename="/tmp/inverter_runner.log", + filemode="wt", + level=logging.DEBUG, + force=True + ) + + logging.getLogger('volttron.platform.vip.agent.core').setLevel(logging.WARNING) logging.getLogger('volttron.platform.vip.agent.core').setLevel(logging.WARNING) from pathlib import Path @@ -151,6 +155,8 @@ def frombus(message: List) -> AllPoints: control_path = Path('inverter.ctl') + from volttron.platform.messaging import headers as t_header + while True: gen = run_inverter() @@ -161,21 +167,30 @@ def frombus(message: List) -> AllPoints: for inv in gen: points = AllPoints() + # Loop over points adding them to the allpoints dataclass if + # they are specified. If they have been set on the agent itself + # then use that value instead of the one from the generator. for k, v in inv.items(): - points.add(k, v) + pt_set = agent.get_point(k) + if pt_set is not None: + points.add(k, pt_set) + else: + points.add(k, v) + + ts = format_timestamp(get_aware_utc_now()) + headers = { + t_header.SYNC_TIMESTAMP: ts, + t_header.TIMESTAMP: ts + } + + # publish agent.vip.pubsub.publish(peer="pubsub", topic=f"{topic_to_publish}", + headers=headers, message=points.forbus()) + with open(Path(opts.output_file), '+a') as fp: + fp.write(json.dumps(dict(headers=headers, message=points.forbus()))+"\n") gevent.sleep(10) - if control_path.exists(): - data = control_path.open().read() - try: - obj = json.loads(data) - except json.decoder.JSONDecodeError: - obj = dict(pf=0.99) - - pf = obj.get('pf', 0.99) - agent.core.stop() \ No newline at end of file diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index acaf08f8fb..56139f6c09 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -12,13 +12,14 @@ # License for the specific language governing permissions and limitations # under the License. from __future__ import annotations +from dataclasses import dataclass, field import logging import sys from datetime import datetime from pathlib import Path from pprint import pformat -from typing import Dict, List +from typing import Any, Dict, List import ieee_2030_5.models as m from ieee_2030_5 import AllPoints @@ -45,6 +46,70 @@ # The logger for this agent is _log and can be used throughout this file. _log = logging.getLogger(__name__) +# These items are global for the agent and will periodically be +# sent to the 2030.5 server based upon the post interval. +DER_SETTINGS = m.DERSettings() +DER_CAPABILITIES = m.DERCapability() +# This is used for default control and control events. +DER_CONTROL_BASE = m.DERControlBase() +# Used for sending status message to the 2030.5 server. +DER_STATUS = m.DERStatus() + +@dataclass +class MappedPoint: + + point_on_bus: str + description: str + multiplier: int + mrid: str + writable: bool + parameter_type: str + notes: str + parent_object: object = None + parameter: str = None + value_2030_5: Any = None + changed: bool = False + + def reset_changed(self): + self.changed = False + + def set_value(self, value: Any): + current_value = getattr(self.parent_object, self.parameter) + if value != current_value: + setattr(self.parent_object, self.parameter, value) + self.changed = True + + def __post_init__(self): + params = self.parameter_type.split("::") + + # Only if we have a proper object specifier that we know about + if len(params) == 2: + if params[0] == 'DERSettings': + self.parent_object = DER_SETTINGS + elif params[0] == 'DERCapability': + self.parent_object = DER_CAPABILITIES + elif params[0] == 'DERControlBase': + self.parent_object = DER_CONTROL_BASE + elif params[0] == 'DERStatus': + self.parent_object = DER_STATUS + + assert self.parent_object is not None, f"The parent object type {params[0]} is not known, please check spelling in configuration file." + assert hasattr(self.parent_object, params[1]), f"{params[0]} does not have property {params[1]}, please check spelling in configuration file." + self.parameter = params[1] + + @staticmethod + def build_from_csv(data: Dict[str, str]) -> MappedPoint: + return MappedPoint( + point_on_bus=data['Point Name'], + description=data['Description'], + multiplier=data['Multiplier'], + mrid=data['MRID'], + writable=data['Writeable'], + parameter_type=data['Parameter Type'], + notes=data['Notes'] + ) + + class IEEE_2030_5_Agent(Agent): """ @@ -70,9 +135,12 @@ def __init__(self, config_path: str, **kwargs): self._der_capabilities_info = config.get("DERCapability") self._der_settings_info = config.get("DERSettings") self._der_status_info = config.get("DERStatus") + #self._point_map = config.get("point_map") + self._mapped_points: Dict[str, MappedPoint] = {} self._default_config = { "subscriptions": self._subscriptions, - "MirrorUsagePointList": self._mirror_usage_point_list + "MirrorUsagePointList": self._mirror_usage_point_list, + "point_map": config.get("point_map") } self._server_usage_points: m.UsagePointList @@ -95,6 +163,8 @@ def __init__(self, config_path: str, **kwargs): sys.exit(1) _log.info(self._client.enddevice) assert self._client.enddevice + ed = self._client.enddevice + self._client.get_der_list() self._point_to_reading_set: Dict[str, str] = {} self._mirror_usage_points: Dict[str, m.MirrorUsagePoint] = {} self._mup_readings: Dict[str, m.MirrorMeterReading] = {} @@ -140,12 +210,25 @@ def configure(self, config_name, action, contents): Called after the Agent has connected to the message bus. If a configuration exists at startup this will be called before onstart. - Is called every time the configuration in the store changes. + It is called every time the configuration in the store changes for this agent. """ config = self._default_config.copy() config.update(contents) - _log.debug("Configuring Agent") + if not config.get('point_map'): + raise ValueError("Must have point_map specified in config store or referenced to a config store entry!") + # Only deal with points that have both on bus point and + # a 2030.5 parameter type + for item in config['point_map']: + if item.get('Point Name').strip() and item.get('Parameter Type').strip(): + if 'DERSettings' in item['Parameter Type'] or \ + 'DERCapability' in item['Parameter Type'] or \ + 'DERStatus' in item['Parameter Type']: + point = MappedPoint.build_from_csv(item) + self._mapped_points[point.point_on_bus] = point + self._mapped_points[point.parameter_type] = point + else: + _log.debug(f"Skipping {item['Point Name']} because it does not have a valid Parameter Type") try: subscriptions = config['subscriptions'] @@ -210,6 +293,27 @@ def _data_published(self, peer, sender, bus, topic, headers, message): """ _log.debug(f"DATA Received from {sender}") points = AllPoints.frombus(message) + + publish_object_update = [] + for pt in points.points: + mapped_point = self._mapped_points.get(pt) + if mapped_point: + mapped_point.set_value(points.points[pt]) + # Only if the new value was different than the old value. + if mapped_point.changed: + if mapped_point.parent_object.__class__ not in [o.__class__ for o in publish_object_update]: + publish_object_update.append(mapped_point.parent_object) + + for obj in publish_object_update: + if isinstance(obj, m.DERSettings): + self._client.put_der_settings(obj) + elif isinstance(obj, m.DERCapability): + self._client.put_der_capability(obj) + elif isinstance(obj, m.DERStatus): + self._client.put_der_status(obj) + + for mp in self._mapped_points.values(): + mp.reset_changed() for index, pt in enumerate(self._mirror_usage_point_list): if pt["subscription_point"] in points.points: diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index 718774c3d1..d7f8a4b802 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -1,6 +1,7 @@ from __future__ import annotations import atexit +import http import logging import ssl import subprocess @@ -9,7 +10,7 @@ import xml.dom.minidom from dataclasses import dataclass, field from datetime import datetime -from http.client import HTTPMessage, HTTPSConnection +from http.client import HTTPMessage, HTTPSConnection, CannotSendRequest from os import PathLike from pathlib import Path from threading import Semaphore, Timer @@ -239,21 +240,27 @@ def get_der_hrefs(self) -> List[str]: def get_der(self, href: str) -> Optional[m.DER]: return self._der.get(href) + + def get_der_list(self, href: Optional[str] = None) -> m.DERList: + if href is None: + href = self.enddevice.DERListLink.href + resp = self.__get_request__(href) + return self._der_map.get(href) def put_der_availability(self, der_href: str, new_availability: m.DERAvailability) -> int: resp = self.__put__(der_href, dataclass_to_xml(new_availability)) return resp.status - def put_der_capability(self, der_href: str, new_capability: m.DERCapability) -> int: - resp = self.__put__(der_href, dataclass_to_xml(new_capability)) + def put_der_capability(self, new_capability: m.DERCapability) -> int: + resp = self.__put__(list(self._der.values())[0].DERCapabilityLink, dataclass_to_xml(new_capability)) return resp.status - def put_der_settings(self, der_href: str, new_settings: m.DERSettings) -> int: - resp = self.__put__(der_href, dataclass_to_xml(new_settings)) + def put_der_settings(self, new_settings: m.DERSettings) -> int: + resp = self.__put__(list(self._der.values())[0].DERSettingsLink.href, dataclass_to_xml(new_settings)) return resp.status - def put_der_status(self, der_href: str, new_status: m.DERStatus) -> int: - resp = self.__put__(der_href, dataclass_to_xml(new_status)) + def put_der_status(self, new_status: m.DERStatus) -> int: + resp = self.__put__(list(self._der.values())[0].DERStatusLink.href, dataclass_to_xml(new_status)) return resp.status def _update_dcap_tree(self, endpoint: Optional[str] = None): @@ -293,7 +300,7 @@ def _update_dcap_tree(self, endpoint: Optional[str] = None): self._update_list(dcap.EndDeviceListLink.href, "EndDevice", self._end_device_map, self._end_devices) - + for ed in self._end_devices.values(): if not self.is_end_device_registered(ed, self._pin): @@ -441,10 +448,6 @@ def new_uuid(self, url: str = "/uuid") -> str: def get_enddevices(self) -> m.EndDeviceList: return self.__get_request__(self._device_cap.EndDeviceListLink.href) - # def end_devices(self) -> m.EndDeviceList: - # self._end_devices = self.__get_request__(self._device_cap.EndDeviceListLink.href) - # return self._end_devices - def end_device(self, index: Optional[int] = 0) -> m.EndDevice: if not self._end_devices: self.end_devices() @@ -557,8 +560,9 @@ def __put__(self, url: str, data: Any, headers: Optional[Dict[str, str]] = None) if self._debug: _log_req_resp.debug(f"----> PUT REQUEST\nurl: {url}\nbody: {data}") - + self.http_conn.request(method="PUT", headers=headers, url=url, body=data) + response = self._http_conn.getresponse() return response @@ -568,7 +572,7 @@ def __post__(self, url: str, data=None, headers: Optional[Dict[str, str]] = None if self._debug: _log_req_resp.debug(f"----> POST REQUEST\nurl: {url}\nbody: {data}") - + self.http_conn.request(method="POST", headers=headers, url=url, body=data) response = self._http_conn.getresponse() response_data = response.read().decode("utf-8") diff --git a/services/core/IEEE_2030_5/ieee_2030_5/utils.py b/services/core/IEEE_2030_5/ieee_2030_5/utils.py new file mode 100644 index 0000000000..109c2bbbe4 --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/utils.py @@ -0,0 +1,14 @@ +def is_binary(binary: str) -> bool: + return all([c in '01' for c in str(binary)]) + + +def is_hex(hex: str) -> bool: + return all([c in '0123456789ABCDEFabcdef' for c in hex]) + + +def binary_to_binary_hex(binary: str) -> str: + return hex(int(binary, 2))[2:] + + +def decimal_to_binary_hex(decimal: int) -> str: + return hex(int(decimal))[2:] diff --git a/services/core/IEEE_2030_5/tests/get_dcap.py b/services/core/IEEE_2030_5/tests/get_dcap.py new file mode 100644 index 0000000000..3daa0290cb --- /dev/null +++ b/services/core/IEEE_2030_5/tests/get_dcap.py @@ -0,0 +1,175 @@ +from datetime import datetime +import sys +import os +import time +sys.path.insert(0, os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))) +from dataclasses import asdict +from pprint import pprint +import urllib3 +from request_session import get_as_admin, get_as_device, post_as_admin, post_as_device +import ieee_2030_5.models as m +from ieee_2030_5 import dataclass_to_xml, xml_to_dataclass +urllib3.disable_warnings() + +def print_it(thing: str, obj: object): + print(f"{'='*20} {thing} {'='*20}") + try: + pprint(asdict(obj), indent=4) + except TypeError: + print(f"Type: {type(obj)} was passed and cannot be printed!") + +dcap: m.DeviceCapability = get_as_device("dcap") +print_it("DeviceCapability", dcap) + +tm: m.Time = get_as_device(dcap.TimeLink.href) +print_it("Time", tm) + +edevl: m.EndDeviceList = get_as_device("edev") +print_it("EndDeviceList", edevl) +edev = edevl.EndDevice[0] +print(edev.LogEventListLink.href) + +derl = get_as_device(edev.DERListLink.href) +print_it("DERList", derl) + +der: m.DER = derl.DER[0] +current_program = get_as_device(der.CurrentDERProgramLink.href) +print_it("CurrentDERProgram", current_program) + +config: m.Configuration = get_as_device(edev.ConfigurationLink.href) +print_it("Configuration", config) + +info: m.DeviceInformation = get_as_device(edev.DeviceInformationLink.href) +print_it("DeviceInformation", info) + +status: m.DeviceStatus = get_as_device(edev.DeviceStatusLink.href) +print_it("DeviceStatus", status) + +fsal: m.FunctionSetAssignmentsList = get_as_device(edev.FunctionSetAssignmentsListLink.href) +print_it("FunctionSetAssignmentsList", fsal) +derpl: m.DERProgramList = get_as_device(fsal.FunctionSetAssignments[0].DERProgramListLink.href) +print_it("DERProgramList", derpl) + +derp: m.DERProgram = derpl.DERProgram[0] +derca = get_as_device(derp.ActiveDERControlListLink.href) +print_it("ActiveDERControlList", derca) + + +dderc: m.DefaultDERControl = get_as_device(derp.DefaultDERControlLink.href) +print_it("DefaultDERControl", dderc) + + +dercl: m.DERControlList = get_as_device(derp.DERControlListLink.href) +print_it("DERControlList", dercl) + +curvel = get_as_device(derp.DERCurveListLink.href) +print_it("DERCurveList", curvel) + +mup = m.MirrorUsagePoint() +mup.description = "Test Mirror Usage Point" +mup.deviceLFDI = edev.lFDI +mup.mRID = "5509D69F8B3535950000000000009182" +mup.serviceCategoryKind = 0 +mup.roleFlags = 49 + +mmr = m.MirrorMeterReading() +mmr.description = "Real Power(W) Set" +mmr.mRID = "5509D69F8B3535950000000000009182" + +mrt = m.ReadingType() +mrt.accumulationBehaviour = 12 +mrt.commodity = 1 +mrt.intervalLength = 300 +mrt.powerOfTenMultiplier = 0 +mrt.uom = 38 +mmr.ReadingType = mrt +mup.MirrorMeterReading.append(mmr) + +# Expect +resp = post_as_device("mup", data=dataclass_to_xml(mup)) + +new_mup = get_as_device(resp.headers["Location"]) + +print_it("New Mirror Usage Point", new_mup) + +print("\n\n") + +current_time = int(time.mktime(datetime.utcnow().timetuple())) +new_ctrl = m.DERControl(mRID="b234245afff", DERControlBase=dderc.DERControlBase, description="A new control is going here") +new_ctrl.interval = m.DateTimeInterval(start=current_time + 10, duration=20) +response = post_as_admin(dercl.href, data=dataclass_to_xml(new_ctrl)) + +ctrl_evnt = get_as_device(response.headers['Location']) +print_it("DERControl", ctrl_evnt) + +ctrll = get_as_device(derp.DERControlListLink.href) +print_it("DERControl List", ctrll) + +activel = get_as_device(derp.ActiveDERControlListLink.href) +print_it("ActiveDERControl", activel) + +print(print(f"{'='*20} Sleeping 10 s {'='*20}")) +time.sleep(10) + +activel = get_as_device(derp.ActiveDERControlListLink.href) +print_it("ActiveDERControl", activel) + +print(print(f"{'='*20} Sleeping 30 s {'='*20}")) +time.sleep(30) + +activel = get_as_device(derp.ActiveDERControlListLink.href) +print_it("ActiveDERControl", activel) + + + +# def _change_power_factor(new_pf): +# global inverter_pf + +# current_time = int(time.mktime(datetime.utcnow().timetuple())) + +# ctrl_base = m.DERControlBase(opModConnect=True, opModMaxLimW=9500) +# ctrl = m.DERControl(mRID="ctrl1mrdi", description="A control for the control list") +# ctrl.DERControlBase = ctrl_base +# ctrl.interval = m.DateTimeInterval(start=current_time + 10, duration=20) +# ctrl.randomizeDuration = 180 +# ctrl.randomizeStart = 180 +# ctrl.DERControlBase.opModFixedW = 500 +# ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactorWithExcitation( +# displacement=int(pf.value)) + +# posted = dataclass_to_xml(ctrl) +# _log.debug(f"POST\n{posted}") +# resp = session.post(get_url("derp/0/derc"), data=posted) +# # Post will have a response with the location of the DERControl +# der_control_uri = resp.headers.get('Location') +# _log.debug(f"GET\n{der_control_uri}") +# resp = session.get(der_control_uri, not_admin=True) +# _log.debug(f"{resp.text}") +# # pfingect: m.DERControl = resp.text) +# # inverter_pf = pfingect.DERControlBase.opModFixedPFInjectW.displacement +# # status.content = updated_markdown() + + +# def get_control_event_default(): +# derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) + +# time_plus_10 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) + +# derc = m.DERControl(mRID=str(uuid.uuid4()), +# description="New DER Control Event", +# DERControlBase=derbase, +# interval=m.DateTimeInterval(duration=10, start=time_plus_10)) + +# return dataclass_to_xml(derc) + + +# def _setup_event(element): +# derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) + +# time_plus_60 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) + +# derc = m.DERControl(mRID=str(uuid.uuid4()), +# description="New DER Control Event", +# DERControlBase=derbase, +# interval=m.DateTimeInterval(duration=10, start=time_plus_60)) +# element.value = dataclass_to_xml(derc) \ No newline at end of file diff --git a/services/core/IEEE_2030_5/tests/request_session.py b/services/core/IEEE_2030_5/tests/request_session.py new file mode 100644 index 0000000000..67b29b8f2c --- /dev/null +++ b/services/core/IEEE_2030_5/tests/request_session.py @@ -0,0 +1,56 @@ +from pathlib import Path +from requests import Session +import yaml + +from ieee_2030_5 import xml_to_dataclass + +__test_config_file__ = Path(__file__).parent.joinpath("fixtures/test_config.yml") +__test_config_file_data__ = yaml.safe_load(__test_config_file__.open("rt").read()) + +__request_admin_session__ = Session() +__request_base_uri__ = f"https://{__test_config_file_data__['server_hostname']}:{__test_config_file_data__['server_ssl_port']}" +__tls_path__ = Path(__test_config_file_data__["certfile"]).expanduser().parent.parent +__request_admin_session__.cert = (__tls_path__.joinpath("certs/admin.crt"), __tls_path__.joinpath("private/admin.pem")) +__request_admin_session__.verify = Path(__test_config_file_data__["cacertfile"]).expanduser().as_posix() + +__request_device_session__ = Session() +__request_device_session__.cert = (__tls_path__.joinpath("certs/dev1.crt"), __tls_path__.joinpath("private/dev1.pem")) +__request_device_session__.verify = Path(__test_config_file_data__["cacertfile"]).expanduser().as_posix() + +def __admin_uri__(path: str): + path = path.replace("_", "/") + if path.startswith("/"): + path = path[1:] + return f"{__request_base_uri__}/admin/{path}" + +def __uri__(path: str): + if path.startswith("/"): + path = path[1:] + return f"{__request_base_uri__}/{path}" + +def post_as_admin(path, data): + print(f"POST: {__admin_uri__(path)}") + return __request_admin_session__.post(__admin_uri__(path), data=data) + +def post_as_device(path, data): + print(f"POST: {__uri__(path)}") + return __request_device_session__.post(__uri__(path), data=data) + + +def get_as_admin(path) -> str: + print(f"GET: {__uri__(path)}") + resp = __request_device_session__.get(__admin_uri__(path)) + + if resp.text: + return xml_to_dataclass(resp.text) + else: + resp + +def get_as_device(path) -> str: + print(f"GET: {__uri__(path)}") + resp = __request_device_session__.get(__uri__(path)) + + if resp.text: + return xml_to_dataclass(resp.text) + else: + resp \ No newline at end of file From e9911a47705bafa14eac9bc27f3ada34451bfa3a Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 28 Sep 2023 20:44:41 -0700 Subject: [PATCH 34/53] Update server.yml file for demo --- services/core/IEEE_2030_5/demo/server.yml | 96 ++++++++++++++--------- 1 file changed, 58 insertions(+), 38 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/server.yml b/services/core/IEEE_2030_5/demo/server.yml index 2d5da581a8..7b5dd723bc 100644 --- a/services/core/IEEE_2030_5/demo/server.yml +++ b/services/core/IEEE_2030_5/demo/server.yml @@ -1,8 +1,7 @@ --- server: 127.0.0.1 -# Only include if we need to have dcap be available -# http_port: 8080 -https_port: 8443 +port: 8443 + tls_repository: "~/tls" openssl_cnf: "openssl.cnf" @@ -28,7 +27,13 @@ generate_admin_cert: True log_event_list_poll_rate: 60 device_capability_poll_rate: 60 usage_point_post_rate: 60 -# derp_poll_rate: 10 + +# Reset storage so no memory when server restarts. +cleanse_storage: true + +# Directory containing data files for the platform. +# This directory will be created if it does not exist. +storage_path: data_store # End Device devices: @@ -37,50 +42,65 @@ devices: # DeviceCategoryType from ieee_2030_5.models.device_category deviceCategory: FUEL_CELL pin: 111115 - + fsas: + - fsa1 + - fsa2 + ders: + - der1 programs: - - description: Program 1 + - Program 1 - # nameplate: - # rtgMaxW: 6000 + - id: dev2 + deviceCategory: FUEL_CELL + pin: 111111 + fsas: + - fsa2 ders: - - capabilities: - modesSupported: "1110000000000000" - type: 83 + - der2 + + +fsa: + - description: fsa1 + - description: fsa2 + programs: + - Program 1 + + programs: - description: Program 1 - default_control: Control 1 - curves: - - Curve 1 - primacy: 89 - - # - description: Program 2 - # default_control: Control 2 - # - description: Program 3 - # default_control: Control 2 - -controls: - - description: Control 1 - setESDelay: 30 - base: - opModConnect: True - opModMaxLimW: 9500 - -events: - - control: 0 + DefaultDERControl: + setESDelay: 30 + setGradW: 1000 + + DERControlBase: + opModConnect: true + opModMaxLimW: 9500 + + DERControls: + - description: Control 1 + DERControlBase: + opModConnect: true + opModMaxLimW: 9500 + - description: Control 2 + DERControlBase: + opModConnect: true + opModFixedW: 80 + + + +ders: + - description: der1 + capabilities: + modesSupported: "1110000000000000" + type: 83 + program: Program 1 curves: - description: Curve 1 curveType: opModVoltVar CurveData: - xvalue: 5 - yvalue: 5 + yvalue: 10 + - - description: Curve 2 - curveType: opModFreqWatt - CurveData: - # exitation is only available if yvalue is power factor - - exitation: 10 - xvalue: 5 - yvalue: 5 From f4467ca24228804f557524a6846a4b106af44e33 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 28 Sep 2023 20:46:01 -0700 Subject: [PATCH 35/53] Allow test utils build_agent to have agent_class parameter --- volttrontesting/utils/build_agent.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/volttrontesting/utils/build_agent.py b/volttrontesting/utils/build_agent.py index 7020e0610b..a925d9fc09 100644 --- a/volttrontesting/utils/build_agent.py +++ b/volttrontesting/utils/build_agent.py @@ -3,17 +3,21 @@ import gevent from volttron.platform.keystore import KeyStore +from volttron.platform.vip.agent import Agent from volttrontesting.utils.platformwrapper import PlatformWrapper -def build_agent(platform: PlatformWrapper, identity=None): +def build_agent(platform: PlatformWrapper, identity=None, agent_class=None): """Builds an agent instance with the passed platform as its bus. The agent identity will be set. If the identity is set to None then a random identity will be created. """ + if agent_class is None: + agent_class = Agent + os.environ['VOLTTRON_HOME'] = platform.volttron_home - agent = platform.build_agent(identity) + agent = platform.build_agent(identity, agent_class=agent_class) gevent.sleep(0.1) # switch context for a bit os.environ.pop('VOLTTRON_HOME') return agent From 866d0c12a39866253a78746d4052264d5a2d7599 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 28 Sep 2023 20:46:23 -0700 Subject: [PATCH 36/53] Update demo webui --- services/core/IEEE_2030_5/demo/webgui.py | 941 +++++++++++++++++------ 1 file changed, 687 insertions(+), 254 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index 9576c0a1ec..3f62a08f9c 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -3,6 +3,7 @@ import asyncio import atexit +from collections import deque import json import os import platform @@ -11,15 +12,24 @@ import sys import time import uuid +import urllib3 from asyncio.subprocess import Process -from dataclasses import dataclass -from datetime import datetime, timedelta +from dataclasses import dataclass, field, fields +from datetime import datetime from pathlib import Path -from typing import Any, Optional - +from typing import Dict, List +import logging +import xsdata import yaml +import plotly.graph_objects as go +import plotly.express as px +import pandas as pd +from numbers import Number from volttron.platform import get_volttron_root +from volttron.platform.agent.utils import parse_timestamp_string, process_timestamp + +urllib3.disable_warnings() sys.path.insert(0, str(Path(__file__).parent.parent)) @@ -29,265 +39,688 @@ import requests from nicegui import app, background_tasks, ui -from services.core.IEEE_2030_5.ieee_2030_5 import dataclass_to_xml, xml_to_dataclass - -session = requests.Session() -tlsdir = Path("~/tls").expanduser() -session.cert = (str(tlsdir.joinpath("certs/admin.pem")), str(tlsdir.joinpath("private/admin.pem"))) -session.verify = str(tlsdir.joinpath("certs/ca.pem")) - - -def get_url(endpoint, not_admin: bool = False) -> str: - if endpoint.startswith('/'): - endpoint = endpoint[1:] - if not_admin: - return f"https://127.0.0.1:8443/{endpoint}" - return f"https://127.0.0.1:8443/admin/{endpoint}" - - -filedirectory = Path(__file__).parent -pkfile = filedirectory.joinpath("keypair.json") -if not pkfile.exists(): - print(f"Key file not found in demo directory {pkfile}.") - sys.exit(0) - -pk_data = yaml.safe_load(pkfile.open().read()) - -os.environ['AGENT_PUBLICKEY'] = pk_data['public'] -os.environ['AGENT_SECRETEKY'] = pk_data['secret'] -os.environ['AGENT_VIP_IDENTITY'] = "inverter1" -os.environ['AGENT_CONFIG'] = str(filedirectory.parent.joinpath('example.config.yml')) -agent_py = str(filedirectory.parent.joinpath("ieee_2030_5/agent.py")) -py_launch = str(Path(get_volttron_root()).joinpath("scripts/pycharm-launch.py")) - -tasks = [] - - -def add_my_task(task): - tasks.append(task) - - -control_status = "None" -derp = "Not Set" -inverter_pf = "Not Set" -inverter_p = "Not Set" -inverter_q = "Not Set" -in_real = False -in_reactive = False -in_control = False - - -def new_agent_output(line: str): - global inverter_q, inverter_p, in_real, in_reactive, in_control, control_status - - if '' in line: - in_control = True - - if in_control: - if "" in line: - status_value = int(re.search(r'(.*?)', line).group(1)) - if status_value == -1: - control_status = "Control Complete" - elif status_value == 0: - control_status = "Control Scheduled" - elif status_value == 1: - control_status = "Active" - else: - control_status = "Not Set" - in_control = False - - status.content = updated_markdown() - - if "url: /mup_1" in line: - in_reactive = True - - if in_reactive: - if line.startswith(""): - inverter_q = re.search(r'(.*?)', line).group(1) - in_reactive = False - status.content = updated_markdown() - - if "url: /mup_1" in line: - in_real = True - - if in_real: - if line.startswith(""): - inverter_p = re.search(r'(.*?)', line).group(1) - in_real = False - status.content = updated_markdown() - - -def _change_power_factor(new_pf): - global inverter_pf - - current_time = int(time.mktime(datetime.utcnow().timetuple())) - - ctrl_base = m.DERControlBase(opModConnect=True, opModMaxLimW=9500) - ctrl = m.DERControl(mRID="ctrl1mrdi", description="A control for the control list") - ctrl.DERControlBase = ctrl_base - ctrl.interval = m.DateTimeInterval(start=current_time + 10, duration=20) - ctrl.randomizeDuration = 180 - ctrl.randomizeStart = 180 - ctrl.DERControlBase.opModFixedW = 500 - ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactorWithExcitation( - displacement=int(pf.value)) - - posted = dataclass_to_xml(ctrl) - utility_log.push(f"Event Posted to Change opModFixedPFInjectW to {pf.value}") - utility_log.push(posted) - resp = session.post(get_url("derp/0/derc"), data=posted) - resp = session.get(get_url(resp.headers.get('Location'), not_admin=True)) - pfingect: m.DERControl = xml_to_dataclass(resp.text) - inverter_pf = pfingect.DERControlBase.opModFixedPFInjectW.displacement - status.content = updated_markdown() - - -def get_control_event_default(): - derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) - - time_plus_10 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) - - derc = m.DERControl(mRID=str(uuid.uuid4()), - description="New DER Control Event", - DERControlBase=derbase, - interval=m.DateTimeInterval(duration=10, start=time_plus_10)) - - return dataclass_to_xml(derc) - - -def _setup_event(element): - derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) - - time_plus_60 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) - - derc = m.DERControl(mRID=str(uuid.uuid4()), - description="New DER Control Event", - DERControlBase=derbase, - interval=m.DateTimeInterval(duration=10, start=time_plus_60)) - element.value = dataclass_to_xml(derc) - - #background_tasks.running_tasks.clear() - - -async def _exit_background_tasks(): - for item in tasks: - if isinstance(item, Process): - try: - item.kill() # .cancel() - except ProcessLookupError: - pass - else: - item.cancel() - # async for proc, command in tasks: - # print(f"Stoping {command.label}") - # proc.cancel() - - tasks.clear() - agent_log.clear() - inverter_log.clear() - utility_log.clear() - - -async def run_command(command: LabeledCommand) -> None: - '''Run a command in the background and display the output in the pre-created dialog.''' - - process = await asyncio.create_subprocess_exec(*shlex.split(command.command), - stdout=asyncio.subprocess.PIPE, - stderr=asyncio.subprocess.STDOUT, - cwd=command.working_dir, - env=dict(os.environ)) - - add_my_task(process) - - # NOTE we need to read the output in chunks, otherwise the process will block - output = '' - while True: - new = await process.stdout.readline() - if not new: - break - output = new.decode() - if command.agent_output: - new_agent_output(output.strip()) - - try: - jsonparsed = json.loads(output) - if command.output_element is not None: - command.output_element().push(output.strip()) - except json.decoder.JSONDecodeError: - if not command.output_only_json: - command.output_element().push(output.strip()) - - # NOTE the content of the markdown element is replaced every time we have new output - #result.content = f'```\n{output}\n```' +from ieee_2030_5 import dataclass_to_xml, xml_to_dataclass +logging.getLogger("urllib3.connectionpool").setLevel(logging.INFO) +_log = logging.getLogger(__name__) @dataclass -class LabeledCommand: - label: str - command: str - output_element: Any - working_dir: str = str(Path(__file__).parent) - output_only_json: bool = True - agent_output: bool = False - - -commands = [ - LabeledCommand("Start Inverter", f'{sys.executable} inverter_runner.py', lambda: inverter_log), - LabeledCommand("Start Agent", - f"{sys.executable} {py_launch} {agent_py}", - lambda: agent_log, - filedirectory.parent, - output_only_json=False, - agent_output=True) -] - - -def updated_markdown() -> str: - return f"""#### Status - Control: {control_status} - Real Power (p): {inverter_p} - Reactive Power (q): {inverter_q} - Power Factor (pf): {inverter_pf} - """ - - -with ui.column(): - # commands = [f'{sys.executable} inverter_runner.py'] +class Configuration: + agent_2030_5_identity: str = "ed1" + volttron_home: str = Path("~/.volttron").expanduser().as_posix() + ieee_server: str = "https://127.0.0.1:8443" + ieee_client_pk: str = Path("~/tls/private/dev1.pem").expanduser().as_posix() + ieee_client_cert: str = Path("~/tls/certs/dev1.crt").expanduser().as_posix() + ieee_ca: str = Path("~/tls/certs/ca.crt").expanduser().as_posix() + +@dataclass +class WatchFileState: + path: str + exists: bool = False + interval: int = 1 + in_routing: bool = False + + def remove(self): + Path(self.path).unlink(missing_ok=True) + + + def check_file(self) -> bool: + return Path(self.path).exists() + +@dataclass +class PlottedData: + series_labels: List[str] = field(default_factory=list) + series_ts: List[datetime] = field(default_factory=list) + series_values: Dict[str, List[float]] = field(default_factory=dict) + + def df(self) -> pd.DataFrame: + data = {"ts": self.series_ts.copy()} + data.update(self.series_values) + + my_df = pd.DataFrame(data) + my_df.set_index(['ts']) + return my_df + + + # def add_publish(self, ts, published): + + # self.series_ts.append(ts) + + # if len(self.series_ts) > 10: + # self.series_ts.pop() + + # for k in published[0]: + # if k not in self.series_labels: + # self.series_labels.append(k) + # self.series_values[k] = [] + + # self.series_values[k].append(published[0][k]) + # if len(self.series_values[k]) > 10: + # self.series_values[k].pop() + + # if self.series_ts: + # plot_figure.refresh() + +# Data from the platform driver is plotted here. +#data_plot = PlottedData() +# Configuration parameters from the config page +config = Configuration() +# Temp storage for changes on the config page +config_working = Configuration() + +# A session for talking with the 2030.5 server +session = requests.Session() +# A file to watch for updates to output from the agent connected to volttron +# the "watch_devices_to_file.py" output. +watch_file = WatchFileState(sys.argv[1], interval=3) +program_list = [] + +admin_session = requests.Session() +client_session = requests.Session() + +def update_sessions(): + tlsdir = Path(config.ieee_client_cert).parent.parent + admin_session.cert = (str(tlsdir.joinpath("certs/admin.crt")), str(tlsdir.joinpath("private/admin.pem"))) + client_session.cert = (config.ieee_client_cert, config.ieee_client_pk) + admin_session.verify = config.ieee_ca + client_session.verify = config.ieee_ca + +def get_from_server(context: str, admin_request=False, deserialize=False): + if admin_request: + session = admin_session + else: + session = client_session + + if admin_request: + response = session.get(config.ieee_server + f"/admin/{context}") + else: + response = session.get(config.ieee_server + f"/{context}") + + if deserialize: + return xml_to_dataclass(response.text) + return response.text + +def admin_uri(path: str): + path = path.replace("_", "/") + if path.startswith("/"): + path = path[1:] + return f"{config.ieee_server}/admin/{path}" + +def __uri__(path: str): + if path.startswith("/"): + path = path[1:] + return f"{config.ieee_server}/{path}" + +def post_as_admin(path, data): + print(f"POST: {admin_uri(path)}") + assert admin_session.cert + return admin_session.post(admin_uri(path), data=data) + +def put_as_admin(path, data): + print(f"PUT: {admin_uri(path)}") + assert admin_session.cert + return admin_session.put(admin_uri(path), data=data) + +def post_as_device(path, data): + print(f"POST: {__uri__(path)}") + return client_session.post(__uri__(path), data=data) + + +def save_config(): + paths_needed = ('volttron_home', 'ieee_client_pk', 'ieee_client_cert', 'ieee_ca') + path_text = ('VOLTTRON home', 'Client PK', 'Client Cert', 'CA') + paths_unavailable = [] + + for index, p in enumerate(paths_needed): + if not Path(getattr(config_working, p)).exists(): + paths_unavailable.append(path_text[index]) + + if paths_unavailable: + ui.notify(f"Missing: {';'.join(paths_unavailable)}", type="warning", position='center') + else: + for fld in fields(config): + setattr(config, fld.name, getattr(config_working, fld.name)) + + update_sessions() + + ui.notify("Configuration Updated") + +def reset_config(): + for fld in fields(config): + setattr(config_working, fld.name, getattr(config, fld.name)) + +cards = [] + + +update_sessions() +dcap: m.DeviceCapability = get_from_server("dcap", deserialize=True) +edl: m.EndDeviceList = get_from_server(dcap.EndDeviceListLink.href, deserialize=True) +edev = edl.EndDevice[0] +ders: m.DERList = get_from_server(edev.DERListLink.href, deserialize=True) +der = ders.DER[0] +program: m.DERProgram = get_from_server(der.CurrentDERProgramLink.href, deserialize=True) + +def noneable_int_change(obj: object, prop: str, value): + if value.sender.value == "" or value.sender.value is None: + setattr(obj, prop, None) + else: + try: + num = int(value.sender.value) + setattr(obj, prop, num) + except ValueError: + ... + +@ui.refreshable +def render_der_default_control_tab(): + default: m.DefaultDERControl = get_from_server(program.DefaultDERControlLink.href, deserialize=True) + with ui.row(): + with ui.column(): + ui.label("DER Default Control").style("font-size: 200%;") + ui.label("Section 10.10 Distributed Energy Resources function set from 20305-2018 IEEE standard.") + + with ui.row().classes("pt-10"): + with ui.column().classes("pr-20"): + esdelay_input = ui.input("setESDelay (hundredth of a second)", + on_change=lambda e: noneable_int_change(default, "setESDelay", e)) \ + .bind_value_from(default, "setESDelay").classes("w-96") + #.bind_value_from(default, "setESDelay").classes("w-96") + setESHighFreq = ui.input("setESHighFreq (hundredth of a hertz)", + on_change=lambda e: noneable_int_change(default, "setESHighFreq", e)) \ + .bind_value_from(default, "setESHighFreq").classes("w-96") + setESHighVolt = ui.input("setESHighVolt (hundredth of a volt)", + on_change=lambda e: noneable_int_change(default, "setESHighVolt", e)) \ + .bind_value_from(default, "setESHighVolt").classes("w-96") + setESLowFreq = ui.input("setESLowFreq (hundredth of a hertz)", + on_change=lambda e: noneable_int_change(default, "setESHighVolt", e)) \ + .bind_value_from(default, "setESLowFreq").classes("w-96") + setESLowVolt = ui.input("setESLowVolt (hundredth of a volt)", + on_change=lambda e: noneable_int_change(default, "setESLowFreq", e)) \ + .bind_value_from(default, "setESLowVolt").classes("w-96") + with ui.column(): + setESRampTms = ui.input("setESRampTms (hundredth of a second)", + on_change=lambda e: noneable_int_change(default, "setESRampTms", e)) \ + .bind_value_from(default, "setESRampTms").classes("w-96") + setESRandomDelay = ui.input("setESRandomDelay (hundredth of a second)", + on_change=lambda e: noneable_int_change(default, "setESRandomDelay", e)) \ + .bind_value_from(default, "setESRandomDelay").classes("w-96") + setGradW = ui.input("setGradW (hundredth of a watt)", + on_change=lambda e: noneable_int_change(default, "setGradW", e)) \ + .bind_value_from(default, "setGradW").classes("w-96") + setSoftGradW = ui.input("setSoftGradW (hundredth of a watt)", + on_change=lambda e: noneable_int_change(default, "setSoftGradW", e)) \ + .bind_value_from(default, "setSoftGradW").classes("w-96") + + def store_default_der_control(): + try: + put_as_admin(program.DefaultDERControlLink.href, dataclass_to_xml(default)) + ui.notify("Default DER Control Updated") + except xsdata.exceptions.ParserError as ex: + ui.notify(ex.message, type='negative') + + with ui.row().classes("pt-10"): + with ui.column(): + ui.button("Save", on_click=lambda: store_default_der_control()) + + +@ui.refreshable +def render_der_control_list_tab(): + control_list: m.DERControlList = get_from_server(program.DERControlListLink.href, deserialize=True) + active_listl: m.DERControlList = get_from_server(program.ActiveDERControlListLink.href, deserialize=True) + curve_list: m.DERCurveList = get_from_server(program.DERCurveListLink.href, deserialize=True) + default: m.DefaultDERControl = get_from_server(program.DefaultDERControlLink.href, deserialize=True) + + with ui.row(): + with ui.column(): + ui.label("DER Control List").style("font-size: 200%;") + ui.label("Section 10.10 Distributed Energy Resources function set from 20305-2018 IEEE standard.") + + columns = [ + {'name': 'time', 'label': 'Event Time', 'field': 'time', 'required': True}, + {'name': 'duration', 'label': 'Event Duration', 'field': 'duration', 'required': True}, + {'name': 'status', 'label': 'Event Status', 'field': 'status', 'required': True} + + ] + + def status_to_string(status: int): + if status == 0: + return "Scheduled" + elif status == 1: + return "Active" + elif status == 2: + return "Cancelled" + elif status == 3: + return "Supersceded" + else: + return "Unknown" + control_list_rows = [] + for ctrl in control_list.DERControl: + if ctrl.interval: + row = { + 'time': ctrl.interval.start, + 'duration': ctrl.interval.duration, + 'status': status_to_string(ctrl.EventStatus.currentStatus) + } + control_list_rows.append(row) + with ui.row(): + with ui.column(): + ui.label("Active Controls").style("font-size: 150%") - for command in commands: - ui.button(command.label, - on_click=lambda _, c=command: add_my_task( - background_tasks.create(run_command(c)))).props('no-caps') + with ui.row(): + with ui.column(): + ui.table(columns=columns, rows=control_list_rows) + + with ui.row(): + with ui.column(): + ui.label("Scheduled Controls").style("font-size: 150%") - pf = ui.select(options=[70, 80, 90], value=70, label="Power Factor").classes('w-32') - ui.button("Change Power Factor", - on_click=lambda: _change_power_factor(pf.value)).props('no-caps') - ui.button("Reset", on_click=_exit_background_tasks).props('no-caps') + with ui.row(): + with ui.column(): + ui.label("Insert table here!") + + with ui.row(): + with ui.column(): + ui.label("Completed Controls").style("font-size: 150%") with ui.row(): - status = ui.markdown(updated_markdown()) - #ui.button("Update Control Time", on_click=lambda: _setup_event(xml_text)).props('no-caps') - #ui.button("Send Control", on_click=lambda: _send_control_event()).props('no-caps') - # with ui.row(): - # xml_text = ui.textarea(label="xml", value=get_control_event_default()).props('rows=20').props('cols=120').classes('w-full, h-80') + with ui.column(): + ui.label("Insert table here!") + +@ui.refreshable +def render_new_der_control_tab(): + with ui.row(): - ui.label("Inverter Log") - inverter_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') - # with ui.row(): - # ui.label("Proxy Log") - # proxy_log = ui.log().props('cols=120').classes('w-full h-80') + with ui.column(): + ui.label("DER Control Entry").style("font-size: 200%;") + ui.label("Section 10.10 Distributed Energy Resources function set from 20305-2018 IEEE standard.") + + with ui.row().classes("pt-5"): + with ui.column(): + ui.label(f"DERProgram {der.CurrentDERProgramLink.href}").style("font-size: 150%") + + new_control = m.DERControl(EventStatus=m.EventStatus()) + der_base = m.DERControlBase() + def submit_new_control(): + new_control.DERControlBase = der_base + ui.notify("Doing good stuff but not much here!") + render_der_control_list_tab.refresh() + + def combine_datetime(): + print(from_date.value) with ui.row(): - ui.label("Agent Log") - agent_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-80') - + with ui.column(): + from_date = ui.input("Event Start", value=datetime.now(), + on_change=lambda: combine_datetime()).classes("w-96") + duration = ui.number("Duration", min=0) \ + .bind_value_from(new_control.EventStatus, "duration") + + disable_curves = True + with ui.row(): - ui.label("Utility Log") - utility_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') - -#atexit.register(_exit_background_tasks) -app.on_shutdown(_exit_background_tasks) + with ui.column().classes("pr-10"): + ui.label("DERControlBase") + + opModConnect = ui.checkbox("opModConnect") \ + .bind_value(der_base, "opModConnect") + opModEnergize = ui.checkbox("opModEnergize") \ + .bind_value(der_base, "opModEnergize") + opModFixedPFAbsorbW = ui.input("opModFixedPFAbsorbW", + on_change=lambda e: noneable_int_change(der_base, "opModFixedPFAbsorbW", e)) \ + .bind_value_from(der_base, "opModFixedPFAbsorbW") + opModFixedPFInjectW = ui.input("opModFixedPFInjectW", + on_change=lambda e: noneable_int_change(der_base, "opModFixedPFInjectW", e)) \ + .bind_value_from(der_base, "opModFixedPFInjectW") + + with ui.column().classes("pr-10"): + opModFixedVar = ui.input("opModFixedVar", + on_change=lambda e: noneable_int_change(der_base, "opModFixedVar", e)) \ + .bind_value_from(der_base, "opModFixedVar") + opModFixedW = ui.input("opModFixedW", + on_change=lambda e: noneable_int_change(der_base, "opModFixedW", e)) \ + .bind_value_from(der_base, "opModFixedW") + opModFreqDroop = ui.input("opModFreqDroop", + on_change=lambda e: noneable_int_change(der_base, "opModFreqDroop", e)) \ + .bind_value_from(der_base, "opModFreqDroop") + opModMaxLimW = ui.input("opModMaxLimW", + on_change=lambda e: noneable_int_change(der_base, "opModMaxLimW", e)) \ + .bind_value_from(der_base, "opModMaxLimW") + + with ui.column().classes("pr-10"): + opModTargetVar = ui.input("opModTargetVar", + on_change=lambda e: noneable_int_change(der_base, "opModTargetVar", e)) \ + .bind_value_from(der_base, "opModTargetVar") + opModTargetW = ui.input("opModTargetW", + on_change=lambda e: noneable_int_change(der_base, "opModTargetW", e)) \ + .bind_value_from(der_base, "opModTargetW") + opModVoltVar = ui.input("opModVoltVar", + on_change=lambda e: noneable_int_change(der_base, "opModVoltVar", e)) \ + .bind_value_from(der_base, "opModVoltVar") + opModWattPF = ui.input("opModWattPF", + on_change=lambda e: noneable_int_change(der_base, "opModWattPF", e)) \ + .bind_value_from(der_base, "opModWattPF") + rampTms: ui.input("rampTms", + on_change=lambda e: noneable_int_change(der_base, "rampTms", e)) \ + .bind_value_from(der_base, "rampTms") + + with ui.row().classes("pt-10"): + with ui.column().classes("pr-20"): + ui.label("Curve Selection") + ui.label("TODO") + + with ui.row().classes("pt-20"): + with ui.column(): + ui.button("Sumbit Control", on_click=lambda: submit_new_control()) + +with ui.tabs().classes('w-full') as tabs: + configuration_tab = ui.tab("configuration", "Configuration") + der_default_control_tab = ui.tab("derdefaultcontrol", "DER Default Control") + new_der_control_tab = ui.tab("newdercontrol", "New DER Control") + der_control_list_tab = ui.tab("dercontrollist", "DER Control List") + results_tab = ui.tab("results", "Results") +line_plot = None +with ui.tab_panels(tabs, value=configuration_tab).classes("w-full"): + with ui.tab_panel(configuration_tab): + with ui.row(): + with ui.column(): + ui.input("2030.5 Identity").classes("w-96").bind_value(config_working, "agent_2030_5_identity") + ui.input("VOLTTRON home").classes("w-96").bind_value(config_working, "volttron_home") + ui.input("EndDevice private").classes("w-96").bind_value(config_working, "ieee_client_pk") + ui.input("EndDevice cert").classes("w-96").bind_value(config_working, "ieee_client_cert") + ui.input("CA cert").classes("w-96").bind_value(config_working, "ieee_ca") + + with ui.row().classes("p-10"): + ui.button("Save", on_click=lambda: save_config()) + ui.button("Reset", on_click=lambda: reset_config()) + + with ui.tab_panel(new_der_control_tab): + render_new_der_control_tab() + + with ui.tab_panel(der_default_control_tab): + render_der_default_control_tab() + + with ui.tab_panel(der_control_list_tab): + render_der_control_list_tab() + + +def watch_for_file(): + if not watch_file.in_routing: + watch_file.in_routing = True + if watch_file.check_file(): + with open(watch_file.path) as rd: + for line in rd.read().split("\n"): + if line.strip(): + data = json.loads(line.strip()) + from volttron.platform.messaging.headers import TIMESTAMP + ts = data["headers"][TIMESTAMP] + #data_plot.add_publish(parse_timestamp_string(ts), data['message']) + + watch_file.remove() + watch_file.in_routing = False + + + +logging.basicConfig(level=logging.DEBUG) +#ui.timer(watch_file.interval, watch_for_file) +ui.run(reload=True, show=False) +#ui.run(reload=True, uvicorn_reload_dirs='services/core/IEEE_2030_5/demo') + +# session = requests.Session() +# tlsdir = Path("~/tls").expanduser() +# session.cert = (str(tlsdir.joinpath("certs/admin.pem")), str(tlsdir.joinpath("private/admin.pem"))) +# session.verify = str(tlsdir.joinpath("certs/ca.pem")) + + +# def get_url(endpoint, not_admin: bool = False) -> str: +# if endpoint.startswith('/'): +# endpoint = endpoint[1:] +# if not_admin: +# return f"https://127.0.0.1:8443/{endpoint}" +# return f"https://127.0.0.1:8443/admin/{endpoint}" + + +# filedirectory = Path(__file__).parent +# pkfile = filedirectory.joinpath("keypair.json") +# if not pkfile.exists(): +# print(f"Key file not found in demo directory {pkfile}.") +# sys.exit(0) + +# pk_data = yaml.safe_load(pkfile.open().read()) + +# os.environ['AGENT_PUBLICKEY'] = pk_data['public'] +# os.environ['AGENT_SECRETEKY'] = pk_data['secret'] +# os.environ['AGENT_VIP_IDENTITY'] = "inverter1" +# os.environ['AGENT_CONFIG'] = str(filedirectory.parent.joinpath('example.config.yml')) +# agent_py = str(filedirectory.parent.joinpath("ieee_2030_5/agent.py")) +# py_launch = str(Path(get_volttron_root()).joinpath("scripts/pycharm-launch.py")) + +# tasks = [] + + +# def add_my_task(task): +# tasks.append(task) + + +# control_status = "None" +# derp = "Not Set" +# inverter_pf = "Not Set" +# inverter_p = "Not Set" +# inverter_q = "Not Set" +# in_real = False +# in_reactive = False +# in_control = False + + +# def new_agent_output(line: str): +# global inverter_q, inverter_p, in_real, in_reactive, in_control, control_status + +# if '' in line: +# in_control = True + +# if in_control: +# if "" in line: +# status_value = int(re.search(r'(.*?)', line).group(1)) +# if status_value == -1: +# control_status = "Control Complete" +# elif status_value == 0: +# control_status = "Control Scheduled" +# elif status_value == 1: +# control_status = "Active" +# else: +# control_status = "Not Set" +# in_control = False + +# status.content = updated_markdown() + +# if "url: /mup_1" in line: +# in_reactive = True + +# if in_reactive: +# if line.startswith(""): +# inverter_q = re.search(r'(.*?)', line).group(1) +# in_reactive = False +# status.content = updated_markdown() + +# if "url: /mup_1" in line: +# in_real = True + +# if in_real: +# if line.startswith(""): +# inverter_p = re.search(r'(.*?)', line).group(1) +# in_real = False +# status.content = updated_markdown() + + +# def _change_power_factor(new_pf): +# global inverter_pf + +# current_time = int(time.mktime(datetime.utcnow().timetuple())) -# NOTE on windows reload must be disabled to make asyncio.create_subprocess_exec work -# (see https://github.com/zauberzeug/nicegui/issues/486) -ui.run(reload=platform.system() != "Windows", ) +# ctrl_base = m.DERControlBase(opModConnect=True, opModMaxLimW=9500) +# ctrl = m.DERControl(mRID="ctrl1mrdi", description="A control for the control list") +# ctrl.DERControlBase = ctrl_base +# ctrl.interval = m.DateTimeInterval(start=current_time + 10, duration=20) +# ctrl.randomizeDuration = 180 +# ctrl.randomizeStart = 180 +# ctrl.DERControlBase.opModFixedW = 500 +# ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactorWithExcitation( +# displacement=int(pf.value)) + +# posted = dataclass_to_xml(ctrl) +# utility_log.push(f"Event Posted to Change opModFixedPFInjectW to {pf.value}") +# utility_log.push(posted) +# resp = session.post(get_url("derp/0/derc"), data=posted) +# resp = session.get(get_url(resp.headers.get('Location'), not_admin=True)) +# pfingect: m.DERControl = xml_to_dataclass(resp.text) +# inverter_pf = pfingect.DERControlBase.opModFixedPFInjectW.displacement +# status.content = updated_markdown() + + +# def get_control_event_default(): +# derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) + +# time_plus_10 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) + +# derc = m.DERControl(mRID=str(uuid.uuid4()), +# description="New DER Control Event", +# DERControlBase=derbase, +# interval=m.DateTimeInterval(duration=10, start=time_plus_10)) + +# return dataclass_to_xml(derc) + + +# def _setup_event(element): +# derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) + +# time_plus_60 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) + +# derc = m.DERControl(mRID=str(uuid.uuid4()), +# description="New DER Control Event", +# DERControlBase=derbase, +# interval=m.DateTimeInterval(duration=10, start=time_plus_60)) +# element.value = dataclass_to_xml(derc) + +# #background_tasks.running_tasks.clear() + + +# async def _exit_background_tasks(): +# for item in tasks: +# if isinstance(item, Process): +# try: +# item.kill() # .cancel() +# except ProcessLookupError: +# pass +# else: +# item.cancel() +# # async for proc, command in tasks: +# # print(f"Stoping {command.label}") +# # proc.cancel() + +# tasks.clear() +# agent_log.clear() +# inverter_log.clear() +# utility_log.clear() + + +# async def run_command(command: LabeledCommand) -> None: +# '''Run a command in the background and display the output in the pre-created dialog.''' + +# process = await asyncio.create_subprocess_exec(*shlex.split(command.command), +# stdout=asyncio.subprocess.PIPE, +# stderr=asyncio.subprocess.STDOUT, +# cwd=command.working_dir, +# env=dict(os.environ)) + +# add_my_task(process) + +# # NOTE we need to read the output in chunks, otherwise the process will block +# output = '' +# while True: +# new = await process.stdout.readline() +# if not new: +# break +# output = new.decode() +# if command.agent_output: +# new_agent_output(output.strip()) + +# try: +# jsonparsed = json.loads(output) +# if command.output_element is not None: +# command.output_element().push(output.strip()) +# except json.decoder.JSONDecodeError: +# if not command.output_only_json: +# command.output_element().push(output.strip()) + +# # NOTE the content of the markdown element is replaced every time we have new output +# #result.content = f'```\n{output}\n```' + + +# @dataclass +# class LabeledCommand: +# label: str +# command: str +# output_element: Any +# working_dir: str = str(Path(__file__).parent) +# output_only_json: bool = True +# agent_output: bool = False + + +# commands = [ +# LabeledCommand("Start Inverter", f'{sys.executable} inverter_runner.py', lambda: inverter_log), +# LabeledCommand("Start Agent", +# f"{sys.executable} {py_launch} {agent_py}", +# lambda: agent_log, +# filedirectory.parent, +# output_only_json=False, +# agent_output=True) +# ] + + +# def updated_markdown() -> str: +# return f"""#### Status +# Control: {control_status} +# Real Power (p): {inverter_p} +# Reactive Power (q): {inverter_q} +# Power Factor (pf): {inverter_pf} +# """ + + +# with ui.column(): +# # commands = [f'{sys.executable} inverter_runner.py'] +# with ui.row(): + +# for command in commands: +# ui.button(command.label, +# on_click=lambda _, c=command: add_my_task( +# background_tasks.create(run_command(c)))).props('no-caps') + +# pf = ui.select(options=[70, 80, 90], value=70, label="Power Factor").classes('w-32') +# ui.button("Change Power Factor", +# on_click=lambda: _change_power_factor(pf.value)).props('no-caps') +# ui.button("Reset", on_click=_exit_background_tasks).props('no-caps') + +# with ui.row(): +# status = ui.markdown(updated_markdown()) +# #ui.button("Update Control Time", on_click=lambda: _setup_event(xml_text)).props('no-caps') +# #ui.button("Send Control", on_click=lambda: _send_control_event()).props('no-caps') +# # with ui.row(): +# # xml_text = ui.textarea(label="xml", value=get_control_event_default()).props('rows=20').props('cols=120').classes('w-full, h-80') +# with ui.row(): +# ui.label("Inverter Log") +# inverter_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') +# # with ui.row(): +# # ui.label("Proxy Log") +# # proxy_log = ui.log().props('cols=120').classes('w-full h-80') +# with ui.row(): +# ui.label("Agent Log") +# agent_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-80') + +# with ui.row(): +# ui.label("Utility Log") +# utility_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') + +# #atexit.register(_exit_background_tasks) +# app.on_shutdown(_exit_background_tasks) + +# # NOTE on windows reload must be disabled to make asyncio.create_subprocess_exec work +# # (see https://github.com/zauberzeug/nicegui/issues/486) +# ui.run(reload=platform.system() != "Windows", ) From 3b7d13f65591c9fe744a2fc94f9abbd11fa637c4 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 28 Sep 2023 20:46:58 -0700 Subject: [PATCH 37/53] Add test fixtures for testing --- .../tests/fixtures/test_config.yml | 84 +++++++++++++++++++ .../tests/fixtures/test_inverter.csv | 8 ++ 2 files changed, 92 insertions(+) create mode 100644 services/core/IEEE_2030_5/tests/fixtures/test_config.yml create mode 100644 services/core/IEEE_2030_5/tests/fixtures/test_inverter.csv diff --git a/services/core/IEEE_2030_5/tests/fixtures/test_config.yml b/services/core/IEEE_2030_5/tests/fixtures/test_config.yml new file mode 100644 index 0000000000..cb6f5c4689 --- /dev/null +++ b/services/core/IEEE_2030_5/tests/fixtures/test_config.yml @@ -0,0 +1,84 @@ +# required parameters +cacertfile: ~/tls/certs/ca.crt +keyfile: ~/tls/private/dev1.pem +certfile: ~/tls/certs/dev1.crt +server_hostname: 127.0.0.1 +# the pin number is used to verify the server is the correct server +pin: 111115 + +# Log the request and responses from the server. +log_req_resp: true + +# SSL defaults to 443 +server_ssl_port: 8443 +# http port defaults to none +#server_http_port: 8080 + +MirrorUsagePointList: + # MirrorMeterReading based on Table E.2 IEEE Std 2030.5-18 + # note the mRID in the MirrorMeterReading is the same that is in the + # MirrorUsagePoint. + - subscription_point: p_ac + mRID: 5509D69F8B3535950000000000009182 + description: DER Inverter Real Power + roleFlags: 49 + serviceCategoryKind: 0 + status: 0 + MirrorMeterReading: + mRID: 5509D69F8B3535950000000000009182 + description: Real Power(W) Set + ReadingType: + accumulationBehavior: 12 + commodity: 1 + dataQualifier: 2 + intervalLength: 300 + powerOfTenMultiplier: 0 + uom: 38 + - subscription_point: q_ac + mRID: 5509D69F8B3535950000000000009184 + description: DER Inverter Reactive Power + roleFlags: 49 + serviceCategoryKind: 0 + status: 0 + MirrorMeterReading: + mRID: 5509D69F8B3535950000000000009184 + description: Reactive Power(VAr) Set + ReadingType: + accumulationBehavior: 12 + commodity: 1 + dataQualifier: 2 + intervalLength: 300 + powerOfTenMultiplier: 0 + uom: 38 + +# publishes on the following subscriptions will +# be available to create and POST readings to the +# 2030.5 server. +subscriptions: + - devices/inverter1/all + +# Nameplate ratings for this der client will be put to the +# server during startup of the system. +DERCapability: + # modesSupported is a HexBinary31 representation of DERControlType + # See Figure B.34 DER info types for information + # conversion in python is as follows + # "{0:08b}".format(int("500040", 16)) + # '10100000000000001000000' # This is a bitmask + # to generate HexBinary + # hex(int('10100000000000001000000', 2)) + # 0x500040 + modesSupported: 500040 + rtgMaxW: + multiplier: 0 + value: 0 + type: 0 + +DERSettings: + modesEnabled: 100000 + setGradW: 0 + setMaxW: + multiplier: 0 + value: 0 + +point_map: config:///inverter_sample.csv \ No newline at end of file diff --git a/services/core/IEEE_2030_5/tests/fixtures/test_inverter.csv b/services/core/IEEE_2030_5/tests/fixtures/test_inverter.csv new file mode 100644 index 0000000000..34ce513301 --- /dev/null +++ b/services/core/IEEE_2030_5/tests/fixtures/test_inverter.csv @@ -0,0 +1,8 @@ +Point Name,Description,Multiplier,MRID,Writeable,Parameter Type,Notes +INV_REAL_PWR,Inverter Real Power,,,,ActivePower,2030.5 is in Watts +INV_REAC_PWR,Inverter Reactive Power,,,,ReactivePower,2030.5 is in vars +BESS_SETOP_REQ,Energy Storage Set Point,,,True,, +INV_OPER_STATE,Inverter Operating State,,,True,DERControlBase::opModFixedW, +INV_REAL_PWR_REQ,Power Request Topic,,,,ActivePower, +BAT_SOC,,,,True,DERStatus::stateOfChargeStatus, +target_p,Target Real Power,,,True,DERControlBase::opModTargetW, From 5c61426320d9cae32df50a07eff0981a57216519 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 28 Sep 2023 20:49:41 -0700 Subject: [PATCH 38/53] Update example config for agent --- services/core/IEEE_2030_5/example.config.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/services/core/IEEE_2030_5/example.config.yml b/services/core/IEEE_2030_5/example.config.yml index d2a3f656ac..cb6f5c4689 100644 --- a/services/core/IEEE_2030_5/example.config.yml +++ b/services/core/IEEE_2030_5/example.config.yml @@ -1,7 +1,7 @@ # required parameters -cacertfile: ~/tls/certs/ca.pem +cacertfile: ~/tls/certs/ca.crt keyfile: ~/tls/private/dev1.pem -certfile: ~/tls/certs/dev1.pem +certfile: ~/tls/certs/dev1.crt server_hostname: 127.0.0.1 # the pin number is used to verify the server is the correct server pin: 111115 @@ -80,3 +80,5 @@ DERSettings: setMaxW: multiplier: 0 value: 0 + +point_map: config:///inverter_sample.csv \ No newline at end of file From cbe54bd22a397606eb744ff70b3d5052f9d5a44f Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Tue, 3 Oct 2023 15:41:11 -0700 Subject: [PATCH 39/53] Updates for agent and client. --- services/core/IEEE_2030_5/demo/server.yml | 6 +- services/core/IEEE_2030_5/demo/webgui.py | 108 ++++- .../core/IEEE_2030_5/ieee_2030_5/__init__.py | 3 + .../core/IEEE_2030_5/ieee_2030_5/agent.py | 330 ++++++++++++- .../core/IEEE_2030_5/ieee_2030_5/client.py | 68 +-- .../ieee_2030_5/models/__init__.py | 458 ++++++------------ .../ieee_2030_5/models/device_category.py | 63 --- .../IEEE_2030_5/ieee_2030_5/models/enums.py | 129 +++++ 8 files changed, 728 insertions(+), 437 deletions(-) delete mode 100644 services/core/IEEE_2030_5/ieee_2030_5/models/device_category.py create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/models/enums.py diff --git a/services/core/IEEE_2030_5/demo/server.yml b/services/core/IEEE_2030_5/demo/server.yml index 7b5dd723bc..e754929414 100644 --- a/services/core/IEEE_2030_5/demo/server.yml +++ b/services/core/IEEE_2030_5/demo/server.yml @@ -91,9 +91,9 @@ programs: ders: - description: der1 - capabilities: - modesSupported: "1110000000000000" - type: 83 + program: Program 1 + + - description: der2 program: Program 1 curves: diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index 3f62a08f9c..7e625bb2db 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -112,7 +112,7 @@ def df(self) -> pd.DataFrame: session = requests.Session() # A file to watch for updates to output from the agent connected to volttron # the "watch_devices_to_file.py" output. -watch_file = WatchFileState(sys.argv[1], interval=3) +#watch_file = WatchFileState(sys.argv[1], interval=3) program_list = [] admin_session = requests.Session() @@ -200,6 +200,16 @@ def reset_config(): der = ders.DER[0] program: m.DERProgram = get_from_server(der.CurrentDERProgramLink.href, deserialize=True) +# def update_from_server(): +# dcap: m.DeviceCapability = get_from_server("dcap", deserialize=True) +# edl: m.EndDeviceList = get_from_server(dcap.EndDeviceListLink.href, deserialize=True) +# edev = edl.EndDevice[0] +# ders: m.DERList = get_from_server(edev.DERListLink.href, deserialize=True) +# der = ders.DER[0] +# program: m.DERProgram = get_from_server(der.CurrentDERProgramLink.href, deserialize=True) + + + def noneable_int_change(obj: object, prop: str, value): if value.sender.value == "" or value.sender.value is None: setattr(obj, prop, None) @@ -261,6 +271,77 @@ def store_default_der_control(): with ui.column(): ui.button("Save", on_click=lambda: store_default_der_control()) +@ui.refreshable +def render_der_status_tab(): + + def do_refresh(): + render_der_status_tab.refresh() + ui.notify("Refreshed") + + settings: m.DERSettings = get_from_server(der.DERSettingsLink.href, deserialize=True) + status: m.DERStatus = get_from_server(der.DERStatusLink.href, deserialize=True) + capabilities: m.DERCapability = get_from_server(der.DERCapabilityLink.href, deserialize=True) + with ui.row(): + with ui.label("DER Status").style("font-size: 200%;"): + ui.button(icon="refresh", color="white", + on_click=lambda: do_refresh()).style("margin:5px; padding: 5px;") + # ui.icon("refresh", size="sm").style("cursor: pointer; vertical-align: center; padding-left: 5px;") \ + # .on_click(lambda: render_der_status_tab.refresh()) + with ui.row(): + with ui.column(): + ui.label("Section 10.10.4.4 DER info resources from 20305-2018 IEEE standard.") + + columns = [ + {'name': 'key', 'label': 'Key', 'field': 'key', 'required': True}, + {'name': 'value', 'label': 'Value', 'field': 'value', 'required': True} + ] + + rows = [] + + for fld in fields(status): + if getattr(status, fld.name): + rows.append(dict(key=fld.name, value=str(getattr(status, fld.name)))) + + with ui.row(): + with ui.column(): + ui.label("DER Status").style("font-size: 150%;") + + with ui.row(): + with ui.column(): + ui.table(columns=columns, rows=rows) + + + rows = [] + + for fld in fields(settings): + if getattr(settings, fld.name): + rows.append(dict(key=fld.name, value=getattr(settings, fld.name))) + + with ui.row(): + with ui.column(): + ui.label("DER Settings").style("font-size: 150%;") + + with ui.row(): + with ui.column(): + ui.table(columns=columns, rows=rows) + + + rows = [] + + for fld in fields(capabilities): + if getattr(capabilities, fld.name): + rows.append(dict(key=fld.name, value=getattr(capabilities, fld.name))) + + with ui.row(): + with ui.column(): + ui.label("DER Capabilities").style("font-size: 150%;") + + with ui.row(): + with ui.column(): + ui.table(columns=columns, rows=rows) + + + @ui.refreshable def render_der_control_list_tab(): @@ -416,6 +497,7 @@ def combine_datetime(): der_default_control_tab = ui.tab("derdefaultcontrol", "DER Default Control") new_der_control_tab = ui.tab("newdercontrol", "New DER Control") der_control_list_tab = ui.tab("dercontrollist", "DER Control List") + der_status_tab = ui.tab("derstatus", "DER Status") results_tab = ui.tab("results", "Results") line_plot = None with ui.tab_panels(tabs, value=configuration_tab).classes("w-full"): @@ -441,27 +523,15 @@ def combine_datetime(): with ui.tab_panel(der_control_list_tab): render_der_control_list_tab() - -def watch_for_file(): - if not watch_file.in_routing: - watch_file.in_routing = True - if watch_file.check_file(): - with open(watch_file.path) as rd: - for line in rd.read().split("\n"): - if line.strip(): - data = json.loads(line.strip()) - from volttron.platform.messaging.headers import TIMESTAMP - ts = data["headers"][TIMESTAMP] - #data_plot.add_publish(parse_timestamp_string(ts), data['message']) - - watch_file.remove() - watch_file.in_routing = False - - + with ui.tab_panel(der_status_tab): + render_der_status_tab() + logging.basicConfig(level=logging.DEBUG) + +# ui.timer(10, update_from_server) #ui.timer(watch_file.interval, watch_for_file) -ui.run(reload=True, show=False) +ui.run(reload=True, show=False, uvicorn_reload_dirs='services/core/IEEE_2030_5/demo') #ui.run(reload=True, uvicorn_reload_dirs='services/core/IEEE_2030_5/demo') # session = requests.Session() diff --git a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py index 9b59a6477c..9f66806ed7 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/__init__.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/__init__.py @@ -49,6 +49,9 @@ class AllPoints: def add(self, name: str, value: Any, meta: Dict = {}): self.points[name] = value self.meta[name] = meta + + def get(self, name: str) -> Any: + return self.points[name] def forbus(self) -> List: return [self.points, self.meta] diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index 56139f6c09..329f7c0c56 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -57,6 +57,17 @@ @dataclass class MappedPoint: + """The MappedPoint class models the mapping points. + + The MappedPoint class allows mapping of points from/to the platform.driver and + 2030.5 objects. + + Only points that have point_on_bus and parameter_type will be mapped. + + The format of the parameter_type is :: where object is one of + DERSettings, DERCapability, DERControlBase, or DERStatus. The property must be + a valid property of the object. + """ point_on_bus: str description: str @@ -100,13 +111,13 @@ def __post_init__(self): @staticmethod def build_from_csv(data: Dict[str, str]) -> MappedPoint: return MappedPoint( - point_on_bus=data['Point Name'], - description=data['Description'], - multiplier=data['Multiplier'], - mrid=data['MRID'], - writable=data['Writeable'], - parameter_type=data['Parameter Type'], - notes=data['Notes'] + point_on_bus=data['Point Name'].strip(), + description=data['Description'].strip(), + multiplier=data['Multiplier'].strip(), + mrid=data['MRID'].strip(), + writable=data['Writeable'].strip(), + parameter_type=data['Parameter Type'].strip(), + notes=data['Notes'].strip() ) @@ -155,6 +166,13 @@ def __init__(self, config_path: str, **kwargs): # Hook up events so we can respond to them appropriately self._client.der_control_event_started(self._control_event_started) self._client.der_control_event_ended(self._control_event_ended) + self._client.der_active_controls_changed(self._active_controls_changed) + self._client.der_default_control_changed(self._default_control_changed) + + self._last_settings = m.DERSettings() + self._last_capabilities = m.DERCapability() + self._last_status = m.DERStatus() + try: self._client.start() @@ -196,6 +214,18 @@ def update_der_status(self, href: str, new_availability: m.DERAvailability) -> i def get_der_references(self) -> List[str]: return self._client.get_der_hrefs() + def _active_controls_changed(self, active: m.DERControlList): + if not isinstance(active, m.DERControlList): + _log.error("Invalid instance passed to active control changed") + return + _log.debug(active) + + def _default_control_changed(self, default_control: m.DefaultDERControl): + if not isinstance(default_control, m.DefaultDERControl): + _log.error("Invalid instance of default control") + return + _log.debug(default_control) + def _control_event_started(self, sender, **kwargs): _log.debug(f"Control event started {kwargs}") @@ -226,7 +256,7 @@ def configure(self, config_name, action, contents): 'DERStatus' in item['Parameter Type']: point = MappedPoint.build_from_csv(item) self._mapped_points[point.point_on_bus] = point - self._mapped_points[point.parameter_type] = point + # self._mapped_points[point.parameter_type] = point else: _log.debug(f"Skipping {item['Point Name']} because it does not have a valid Parameter Type") @@ -287,6 +317,253 @@ def configure(self, config_name, action, contents): for sub in self._subscriptions: self.vip.pubsub.subscribe(peer="pubsub", prefix=sub, callback=self._data_published) + def _cast_multipler(self, value: str) -> int: + try: + return int(value) + except ValueError: + _log.warning(f"Casting multiplier to int failed: {value}") + return 1 + + def _set_correct_value(self, value: Any) -> Any: + value_of_instance = value.value + if isinstance(value_of_instance, type(value)): + value_of_instance.value = value_of_instance.value.value + return value_of_instance + + def _transform_settings(self, points: List[MappedPoint]) -> m.DERSettings: + """Update a DERSettings object so that it is correctly formatted to send to the server. + + The point has a parent_object property that must be a DERSettings object. Each setting + that requires a transition from a single element to a complex element is handled here. + + :param point: The point that is being updated. + :return: The updated DERSettings object. + :rtype: m.DERSettings + :raises AssertionError: If the parent_object is not a DERSettings object. + """ + # all of the settings are in the same envelope so we use the same + # server time for all of them. + server_time = self._client.server_time + settings = None + + for point in points: + assert isinstance(point.parent_object, m.DERSettings), f"Parent object is not a DERSettings object: {p.parent_object}" + + settings: m.DERSettings = point.parent_object + + # Transform point values into their correct object types. + if point.parameter == 'setMaxA': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxA = m.CurrentRMS(multiplier=point.multiplier, value=settings.setMaxA) + + if point.parameter == 'setMaxAh': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxAh = m.AmpereHour(multiplier=point.multiplier, value=settings.setMaxAh) + + if point.parameter == 'setMaxChargeRateVA': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxChargeRateVA = m.ApparentPower(multiplier=point.multiplier, value=settings.setMaxChargeRateVA) + + if point.parameter == 'setMaxChargeRateW': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxChargeRateW = m.ActivePower(multiplier=point.multiplier, value=settings.setMaxChargeRateW) + + if point.parameter == 'setMaxDischargeRateVA': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxDischargeRateVA = m.ApparentPower(multiplier=point.multiplier, value=settings.setMaxDischargeRateVA) + + if point.parameter == 'setMaxDischargeRateW': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxDischargeRateW = m.ActivePower(multiplier=point.multiplier, value=settings.setMaxDischargeRateW) + + if point.parameter == 'setMaxV': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxV = m.VoltageRMS(multiplier=point.multiplier, value=settings.setMaxV) + + if point.parameter == 'setMaxVA': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxVA = m.ApparentPower(multiplier=point.multiplier, value=settings.setMaxVA) + + if point.parameter == 'setMaxVar': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxVar = m.ReactivePower(multiplier=point.multiplier, value=settings.setMaxVar) + + if point.parameter == 'setMaxVarNeg': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxVarNeg = m.ReactivePower(multiplier=point.multiplier, value=settings.setMaxVarNeg) + + if point.parameter == 'setMaxW': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxW = m.ActivePower(multiplier=point.multiplier, value=settings.setMaxW) + + if point.parameter == 'setMaxWh': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMaxWh = m.WattHour(multiplier=point.multiplier, value=settings.setMaxWh) + + if point.parameter == 'setMinPFOverExcited': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMinPFOverExcited = m.PowerFactor(multiplier=point.multiplier, value=settings.setMinPFOverExcited) + + if point.parameter == 'setMinPFUnderExcited': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMinPFUnderExcited = m.PowerFactor(multiplier=point.multiplier, value=settings.setMinPFUnderExcited) + + if point.parameter == 'setMinV': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setMinV = m.VoltageRMS(multiplier=point.multiplier, value=settings.setMinV) + + if point.parameter == 'setSoftGradW': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setSoftGradW = m.ActivePower(multiplier=point.multiplier, value=settings.setSoftGradW) + + if point.parameter == 'setVNom': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setVNom = m.VoltageRMS(multiplier=point.multiplier, value=settings.setVNom) + + if point.parameter == 'setVRef': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setVRef = m.VoltageRMS(multiplier=point.multiplier, value=settings.setVRef) + + if point.parameter == 'setVRefOfs': + point.multiplier = self._cast_multipler(point.multiplier) + settings.setVRefOfs = m.VoltageRMS(multiplier=point.multiplier, value=settings.setVRefOfs) + settings.updatedTime = server_time + + return settings + + def _transform_status(self, points: List[MappedPoint]) -> m.DERStatus: + """Update a derstatus object so that it is correctly formatted to send to the server. + + The point has a parent_object property that must be a DERStatus object. Each setting + that requires a transition from a single element to a complex element is handled here. + + :param point: The point that is being updated. + :return: The updated DERStatus object. + :rtype: m.DERStatus + :raises AssertionError: If the parent_object is not a DERStatus object. + """ + + server_time = self._client.server_time + status = None + + for point in points: + assert isinstance(point.parent_object, m.DERStatus), f"Parent object is not a DERStatus object: {p.parent_object}" + + status: m.DERStatus = point.parent_object + + if point.parameter == 'genConnectStatus': + status.genConnectStatus = m.ConnectStatusType(dateTime=server_time, value=status.genConnectStatus) + + if point.parameter == 'inverterStatus': + status.inverterStatus = m.InverterStatusType(dateTime=server_time, value=status.inverterStatus) + + if point.parameter == 'localControlModeStatus': + status.localControlModeStatus = m.LocalControlModeStatusType(dateTime=server_time, value=status.localControlModeStatus) + + if point.parameter == 'manufacturerStatus': + status.manufacturerStatus = m.ManufacturerStatusType(dateTime=server_time, value=status.manufacturerStatus) + + if point.parameter == 'operationalModeStatus': + status.operationalModeStatus = m.OperationalModeStatusType(dateTime=server_time, value=status.operationalModeStatus) + + if point.parameter == 'stateOfChargeStatus': + status.stateOfChargeStatus = m.StateOfChargeStatusType(dateTime=server_time, value=status.stateOfChargeStatus) + + if point.parameter == 'storageModeStatus': + status.storageModeStatus = m.StorageModeStatusType(dateTime=server_time, value=status.storageModeStatus) + + if point.parameter == 'storConnectStatus': + status.storConnectStatus = m.ConnectStatusType(dateTime=server_time, value=status.storConnectStatus) + + status.readingTime = server_time + return status + + def _transform_capabilities(self, points: List[MappedPoint]) -> m.DERCapability: + """Update a DERCapability object so that it is correctly formatted to send to the server. + + The point has a parent_object property that must be a DERCapability object. Each setting + that requires a transition from a single element to a complex element is handled here. + + :param point: The point that is being updated. + :return: The updated DERCapability object. + :rtype: m.DERCapability + :raises AssertionError: If the parent_object is not a DERCapability object. + """ + + server_time = self._client.server_time + capabilities = None + + for point in points: + + assert isinstance(point.parent_object, m.DERCapability), f"Parent object is not a DERCapability object: {point.parent_object}" + + capabilities: m.DERCapability = point.parent_object + + + if point.parameter == 'rtgMaxA': + capabilities.rtgMaxA = m.CurrentRMS(multiplier=point.multiplier, value=self.rtgMaxA) + + if point.parameter == 'rtgMaxAh': + capabilities.rtgMaxAh = m.AmpereHour(multiplier=point.multiplier, value=self.rtgMaxAh) + + if point.parameter == 'rtgMaxChargeRateVA': + capabilities.rtgMaxChargeRateVA = m.ApparentPower(multiplier=point.multiplier, value=self.rtgMaxChargeRateVA) + + if point.parameter == 'rtgMaxChargeRateW': + capabilities.rtgMaxChargeRateW = m.ActivePower(multiplier=point.multiplier, value=self.rtgMaxChargeRateW) + + if point.parameter == 'rtgMaxV': + capabilities.rtgMaxV = m.VoltageRMS(multiplier=point.multiplier, value=self.rtgMaxV) + + if point.parameter == 'rtgMaxVA': + capabilities.rtgMaxVA = m.ApparentPower(multiplier=point.multiplier, value=self.rtgMaxVA) + + if point.parameter == 'rtgMaxVar': + capabilities.rtgMaxVar = m.ReactivePower(multiplier=point.multiplier, value=self.rtgMaxVar) + + if point.parameter == 'rtgMaxVarNeg': + capabilities.rtgMaxVarNeg = m.ReactivePower(multiplier=point.multiplier, value=self.rtgMaxVarNeg) + + if point.parameter == 'rtgMaxW': + capabilities.rtgMaxW = m.ActivePower(multiplier=point.multiplier, value=self.rtgMaxW) + + if point.parameter == 'rtgMaxWh': + capabilities.rtgMaxWh = m.WattHour(multiplier=point.multiplier, value=self.rtgMaxWh) + + if point.parameter == 'rtgMinPFOverExcited': + capabilities.rtgMinPFOverExcited = m.PowerFactor(multiplier=point.multiplier, value=self.rtgMinPFOverExcited) + + if point.parameter == 'rtgMinPFUnderExcited': + capabilities.rtgMinPFUnderExcited = m.PowerFactor(multiplier=point.multiplier, value=self.rtgMinPFUnderExcited) + + if point.parameter == 'rtgNormalCategory': + capabilities.rtgNormalCategory = m.RtgNormalCategoryType(dateTime=server_time, value=self.rtgNormalCategory) + + if point.parameter == 'rtgOverExcitedPF': + capabilities.rtgOverExcitedPF = m.PowerFactor(multiplier=point.multiplier, value=self.rtgOverExcitedPF) + + if point.parameter == 'rtgOverExcitedW': + capabilities.rtgOverExcitedW = m.ActivePower(multiplier=point.multiplier, value=self.rtgOverExcitedW) + + if point.parameter == 'rtgReactiveSusceptance': + capabilities.rtgReactiveSusceptance = m.ReactiveSusceptance(multiplier=point.multiplier, value=self.rtgReactiveSusceptance) + + if point.parameter == 'rtgUnderExcitedPF': + capabilities.rtgUnderExcitedPF = m.PowerFactor(multiplier=point.multiplier, value=self.rtgUnderExcitedPF) + + if point.parameter == 'rtgUnderExcitedW': + capabilities.rtgUnderExcitedW = m.ActivePower(multiplier=point.multiplier, value=self.rtgUnderExcitedW) + + if point.parameter == 'rtgVNom': + capabilities.rtgVNom = m.VoltageRMS(multiplier=point.multiplier, value=self.rtgVNom) + + if point.parameter == 'type': + capabilities.type = m.DERTypeType(dateTime=server_time, value=self.type) + + return capabilities + + + def _data_published(self, peer, sender, bus, topic, headers, message): """ Callback triggered by the subscription setup using the topic from the agent's config file @@ -294,24 +571,27 @@ def _data_published(self, peer, sender, bus, topic, headers, message): _log.debug(f"DATA Received from {sender}") points = AllPoints.frombus(message) - publish_object_update = [] - for pt in points.points: - mapped_point = self._mapped_points.get(pt) - if mapped_point: - mapped_point.set_value(points.points[pt]) - # Only if the new value was different than the old value. - if mapped_point.changed: - if mapped_point.parent_object.__class__ not in [o.__class__ for o in publish_object_update]: - publish_object_update.append(mapped_point.parent_object) + parent_objects: Dict[type, List[MappedPoint]]= {} + transforms = { + m.DERSettings: (self._transform_settings, self._client.put_der_settings), + m.DERCapability: (self._transform_capabilities, self._client.put_der_capability), + m.DERStatus: (self._transform_status, self._client.put_der_status) + } - for obj in publish_object_update: - if isinstance(obj, m.DERSettings): - self._client.put_der_settings(obj) - elif isinstance(obj, m.DERCapability): - self._client.put_der_capability(obj) - elif isinstance(obj, m.DERStatus): - self._client.put_der_status(obj) - + for obj_type in transforms.keys(): + # Create a list of properties that are for each of the types. + parent_objects[obj_type] = list(filter(lambda x: isinstance(x.parent_object, obj_type), self._mapped_points.values())) + + # Make sure that there is some points to update. + if parent_objects[obj_type]: + list(map(lambda x: x.set_value(points.get(x.point_on_bus)), parent_objects[obj_type])) + + # Do the transform from simple int/floats to complex objects. + sendable = transforms[obj_type][0](parent_objects[obj_type]) + if sendable: + # Send the data to the server. + transforms[obj_type][1](sendable) + for mp in self._mapped_points.values(): mp.reset_changed() diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index d7f8a4b802..afff2fd40b 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -176,11 +176,17 @@ def __init__(self, self._der_control_event_started_signal = Signal('der-control-event-started') self._der_control_event_ended_signal = Signal('der-control-event-ended') + + self._default_control_changed = Signal("default-control-changed") + self._active_controls_changed_signal = Signal("active-controls-changed") self._before_event_start_signal = Signal('before-event-start') self._after_event_end_signal = Signal('after-event-end') self._dcap_endpoint = device_capabilities_endpoint + + self._der_default_control: m.DefaultDERControl = m.DefaultDERControl() + self._der_active_controls: m.DERControlList = m.DERControlList() self._lock = Semaphore() @@ -205,6 +211,12 @@ def _tick(self, timestamp: int): ts.trigger(timestamp) self._lock.release() + def der_active_controls_changed(self, fun: Callable): + self._active_controls_changed_signal.connect(fun) + + def der_default_control_changed(self, fun: Callable): + self._default_control_changed.connect(fun) + def der_control_event_started(self, fun: Callable): self._der_control_event_started_signal.connect(fun) @@ -260,6 +272,10 @@ def put_der_settings(self, new_settings: m.DERSettings) -> int: return resp.status def put_der_status(self, new_status: m.DERStatus) -> int: + if not isinstance(new_status.operationalModeStatus, m.OperationalModeStatusType): + new_status.operationalModeStatus = m.OperationalModeStatusType(self.server_time, + value=new_status.operationalModeStatus) + resp = self.__put__(list(self._der.values())[0].DERStatusLink.href, dataclass_to_xml(new_status)) return resp.status @@ -313,27 +329,38 @@ def _update_dcap_tree(self, endpoint: Optional[str] = None): self._der_map[derlist.href] = derlist for index, der in enumerate(derlist.DER): self._der[der.href] = der + if derlist.DER[0].CurrentDERProgramLink: + program: m.DERProgram = self.__get_request__(derlist.DER[0].CurrentDERProgramLink.href) + active: m.DERControlList = self.__get_request__(program.ActiveDERControlListLink.href) + default = self.__get_request__(program.DefaultDERControlLink.href) + active_is_different = False + if len(active.DERControl) == len(self._der_active_controls.DERControl): + for index, der in enumerate(active.DERControl): + if der != self._der_active_controls.DERControl[index]: + active_is_different = True + break + else: + active_is_different = True + if active_is_different: + self._der_active_controls = active + self._active_controls_changed_signal.send(self._der_active_controls) + + if default != self._der_default_control: + self._der_default_control = default + self._default_control_changed.send(default) + + + for fsa in self._fsa.values(): if fsa.DERProgramListLink: self._der_program_map[fsa.DERProgramListLink.href] = self.__get_request__( fsa.DERProgramListLink.href) - + program = self._der_program_map[fsa.DERProgramListLink.href] + if dcap.MirrorUsagePointListLink is not None and dcap.MirrorUsagePointListLink.href: - print(self._mirror_usage_point) - print(self._mirror_usage_point_map) - print(id(self._mirror_usage_point)) - print(id(self._mirror_usage_point_map)) self._update_list(dcap.MirrorUsagePointListLink.href, "MirrorUsagePoint", self._mirror_usage_point_map, self._mirror_usage_point) - print(id(self._mirror_usage_point)) - print(id(self._mirror_usage_point_map)) - # for mup in self._mirror_usage_point.values(): - # if mup.postRate is not None: - # self._update_timer_spec(mup.href, mup.postRate, self.m._mi) - - # if dcap.UsagePointListLink is not None and dcap.UsagePointListLink.href: - # self._update_list(dcap.UsagePointListLink.href, "UsagePoint", self._usage_point_map, self._usage_point) self._dcap = dcap @@ -389,9 +416,6 @@ def _get_device_capabilities(self, endpoint: str) -> m.DeviceCapability: else: self._dcap_poll_rate = 600 - _log.debug(f"devcap id {id(self._device_cap)}") - _log.debug(threading.currentThread().name) - _log.debug(f"DCAP: Poll rate: {self._dcap_poll_rate}") self._dcap_timer = Timer(self._dcap_poll_rate, self.poll_timer, (self.device_capability, url)) self._dcap_timer.start() @@ -624,17 +648,7 @@ def __release_clients__(): atexit.register(__release_clients__) -# -# ssl_context = ssl.create_default_context(cafile=str(SERVER_CA_CERT)) -# -# -# con = HTTPSConnection("me.com", 8000, -# key_file=str(KEY_FILE), -# cert_file=str(CERT_FILE), -# context=ssl_context) -# con.request("GET", "/dcap") -# print(con.getresponse().read()) -# con.close() + if __name__ == '__main__': SERVER_CA_CERT = Path("~/tls/certs/ca.crt").expanduser().resolve() diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py b/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py index eefbd542b8..f650c386a8 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py @@ -1,303 +1,160 @@ -# Copyright 2022 Battelle Memorial Institute -# -# Licensed under the Apache License, Version 2.0 (the "License"); you may not -# use this file except in compliance with the License. You may obtain a copy -# of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT -# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the -# License for the specific language governing permissions and limitations -# under the License. -from ieee_2030_5.models.device_category import DeviceCategoryType - -from ieee_2030_5.models.sep import ( - AbstractDevice, - AccountBalance, - AccountBalanceLink, - AccountingUnit, - ActiveBillingPeriodListLink, - ActiveCreditRegisterListLink, - ActiveDERControlListLink, - ActiveEndDeviceControlListLink, - ActiveFlowReservationListLink, - ActivePower, - ActiveProjectionReadingListLink, - ActiveSupplyInterruptionOverrideListLink, - ActiveTargetReadingListLink, - ActiveTextMessageListLink, - ActiveTimeTariffIntervalListLink, - AmpereHour, - ApparentPower, - ApplianceLoadReduction, - AppliedTargetReduction, - AssociatedDERProgramListLink, - AssociatedUsagePointLink, - BillingMeterReadingBase, - BillingPeriod, - BillingPeriodList, - BillingPeriodListLink, - BillingReading, - BillingReadingList, - BillingReadingListLink, - BillingReadingSet, - BillingReadingSetList, - BillingReadingSetListLink, - Charge, - Condition, - Configuration, - ConfigurationLink, - ConnectStatusType, - ConsumptionTariffInterval, - ConsumptionTariffIntervalList, - ConsumptionTariffIntervalListLink, - CreditRegister, - CreditRegisterList, - CreditRegisterListLink, - CreditTypeChange, - CurrentDERProgramLink, - CurrentRMS, - CurveData, - CustomerAccount, - CustomerAccountLink, - CustomerAccountList, - CustomerAccountListLink, - CustomerAgreement, - CustomerAgreementList, - CustomerAgreementListLink, - DER, - DERAvailability, - DERAvailabilityLink, - DERCapability, - DERCapabilityLink, - DERControl, - DERControlBase, - DERControlList, - DERControlListLink, - DERControlResponse, - DERCurve, - DERCurveLink, - DERCurveList, - DERCurveListLink, - DERLink, - DERList, - DERListLink, - DERProgram, - DERProgramLink, - DERProgramList, - DERProgramListLink, - DERSettings, - DERSettingsLink, - DERStatus, - DERStatusLink, - DRLCCapabilities, - DateTimeInterval, - DefaultDERControl, - DefaultDERControlLink, - DemandResponseProgram, - DemandResponseProgramLink, - DemandResponseProgramList, - DemandResponseProgramListLink, - DeviceCapability, - DeviceCapabilityLink, - DeviceInformation, - DeviceInformationLink, - DeviceStatus, - DeviceStatusLink, - DrResponse, - DutyCycle, - EndDevice, - EndDeviceControl, - EndDeviceControlList, - EndDeviceControlListLink, - EndDeviceLink, - EndDeviceList, - EndDeviceListLink, - EnvironmentalCost, - Error, - Event, - EventStatus, - File, - FileLink, - FileList, - FileListLink, - FileStatus, - FileStatusLink, - FixedPointType, - FixedVar, - FlowReservationRequest, - FlowReservationRequestList, - FlowReservationRequestListLink, - FlowReservationResponse, - FlowReservationResponseList, - FlowReservationResponseListLink, - FlowReservationResponseResponse, - FreqDroopType, - FunctionSetAssignments, - FunctionSetAssignmentsBase, - FunctionSetAssignmentsList, - FunctionSetAssignmentsListLink, - GPSLocationType, - HistoricalReading, - HistoricalReadingList, - HistoricalReadingListLink, - IEEE_802_15_4, - IPAddr, - IPAddrList, - IPAddrListLink, - IPInterface, - IPInterfaceList, - IPInterfaceListLink, - IdentifiedObject, - InverterStatusType, - LLInterface, - LLInterfaceList, - LLInterfaceListLink, - Link, - List_type, - ListLink, - LoadShedAvailability, - LoadShedAvailabilityList, - LoadShedAvailabilityListLink, - LocalControlModeStatusType, - LogEvent, - LogEventList, - LogEventListLink, - ManufacturerStatusType, - MessagingProgram, - MessagingProgramList, - MessagingProgramListLink, - MeterReading, - MeterReadingBase, - MeterReadingLink, - MeterReadingList, - MeterReadingListLink, - MirrorMeterReading, - MirrorMeterReadingList, - MirrorReadingSet, - MirrorUsagePoint, - MirrorUsagePointList, - MirrorUsagePointListLink, - Neighbor, - NeighborList, - NeighborListLink, - Notification, - NotificationList, - NotificationListLink, - Offset, - OperationalModeStatusType, - PEVInfo, - PowerConfiguration, - PowerFactor, - PowerFactorWithExcitation, - PowerStatus, - PowerStatusLink, - PrepayOperationStatus, - PrepayOperationStatusLink, - Prepayment, - PrepaymentLink, - PrepaymentList, - PrepaymentListLink, - PriceResponse, - PriceResponseCfg, - PriceResponseCfgList, - PriceResponseCfgListLink, - ProjectionReading, - ProjectionReadingList, - ProjectionReadingListLink, - RPLInstance, - RPLInstanceList, - RPLInstanceListLink, - RPLSourceRoutes, - RPLSourceRoutesList, - RPLSourceRoutesListLink, - RandomizableEvent, - RateComponent, - RateComponentLink, - RateComponentList, - RateComponentListLink, - ReactivePower, - ReactiveSusceptance, - Reading, - ReadingBase, - ReadingLink, - ReadingList, - ReadingListLink, - ReadingSet, - ReadingSetBase, - ReadingSetList, - ReadingSetListLink, - ReadingType, - ReadingTypeLink, - RealEnergy, - Registration, - RegistrationLink, - RequestStatus, - Resource, - RespondableIdentifiedObject, - RespondableResource, - RespondableSubscribableIdentifiedObject, - Response, - ResponseList, - ResponseListLink, - ResponseSet, - ResponseSetList, - ResponseSetListLink, - SelfDevice, - SelfDeviceLink, - ServiceChange, - ServiceSupplier, - ServiceSupplierLink, - ServiceSupplierList, - SetPoint, - SignedRealEnergy, - StateOfChargeStatusType, - StorageModeStatusType, - SubscribableIdentifiedObject, - SubscribableList, - SubscribableResource, - Subscription, - SubscriptionBase, - SubscriptionList, - SubscriptionListLink, - SupplyInterruptionOverride, - SupplyInterruptionOverrideList, - SupplyInterruptionOverrideListLink, - SupportedLocale, - SupportedLocaleList, - SupportedLocaleListLink, - TargetReading, - TargetReadingList, - TargetReadingListLink, - TargetReduction, - TariffProfile, - TariffProfileLink, - TariffProfileList, - TariffProfileListLink, - Temperature, - TextMessage, - TextMessageList, - TextMessageListLink, - TextResponse, - Time, - TimeConfiguration, - TimeLink, - TimeTariffInterval, - TimeTariffIntervalList, - TimeTariffIntervalListLink, - UnitValueType, - UnsignedFixedPointType, - UsagePoint, - UsagePointBase, - UsagePointLink, - UsagePointList, - UsagePointListLink, - VoltageRMS, - WattHour, - loWPAN, -) +from ieee_2030_5.models.enums import CurveType, DeviceCategoryType, PrimacyType +from ieee_2030_5.models.sep import (DER, IEEE_802_15_4, AbstractDevice, + AccountBalance, AccountBalanceLink, + AccountingUnit, + ActiveBillingPeriodListLink, + ActiveCreditRegisterListLink, + ActiveDERControlListLink, + ActiveEndDeviceControlListLink, + ActiveFlowReservationListLink, ActivePower, + ActiveProjectionReadingListLink, + ActiveSupplyInterruptionOverrideListLink, + ActiveTargetReadingListLink, + ActiveTextMessageListLink, + ActiveTimeTariffIntervalListLink, + AmpereHour, ApparentPower, + ApplianceLoadReduction, + AppliedTargetReduction, + AssociatedDERProgramListLink, + AssociatedUsagePointLink, + BillingMeterReadingBase, BillingPeriod, + BillingPeriodList, BillingPeriodListLink, + BillingReading, BillingReadingList, + BillingReadingListLink, BillingReadingSet, + BillingReadingSetList, + BillingReadingSetListLink, Charge, + Condition, Configuration, + ConfigurationLink, ConnectStatusType, + ConsumptionTariffInterval, + ConsumptionTariffIntervalList, + ConsumptionTariffIntervalListLink, + CreditRegister, CreditRegisterList, + CreditRegisterListLink, CreditTypeChange, + CurrentDERProgramLink, CurrentRMS, + CurveData, CustomerAccount, + CustomerAccountLink, CustomerAccountList, + CustomerAccountListLink, CustomerAgreement, + CustomerAgreementList, + CustomerAgreementListLink, + DateTimeInterval, DefaultDERControl, + DefaultDERControlLink, + DemandResponseProgram, + DemandResponseProgramLink, + DemandResponseProgramList, + DemandResponseProgramListLink, + DERAvailability, DERAvailabilityLink, + DERCapability, DERCapabilityLink, + DERControl, DERControlBase, DERControlList, + DERControlListLink, DERControlResponse, + DERCurve, DERCurveLink, DERCurveList, + DERCurveListLink, DERLink, DERList, + DERListLink, DERProgram, DERProgramLink, + DERProgramList, DERProgramListLink, + DERSettings, DERSettingsLink, DERStatus, + DERStatusLink, DeviceCapability, + DeviceCapabilityLink, DeviceInformation, + DeviceInformationLink, DeviceStatus, + DeviceStatusLink, DRLCCapabilities, + DrResponse, DutyCycle, EndDevice, + EndDeviceControl, EndDeviceControlList, + EndDeviceControlListLink, EndDeviceLink, + EndDeviceList, EndDeviceListLink, + EnvironmentalCost, Error, Event, + EventStatus, File, FileLink, FileList, + FileListLink, FileStatus, FileStatusLink, + FixedPointType, FixedVar, + FlowReservationRequest, + FlowReservationRequestList, + FlowReservationRequestListLink, + FlowReservationResponse, + FlowReservationResponseList, + FlowReservationResponseListLink, + FlowReservationResponseResponse, + FreqDroopType, FunctionSetAssignments, + FunctionSetAssignmentsBase, + FunctionSetAssignmentsList, + FunctionSetAssignmentsListLink, + GPSLocationType, HistoricalReading, + HistoricalReadingList, + HistoricalReadingListLink, + IdentifiedObject, InverterStatusType, + IPAddr, IPAddrList, IPAddrListLink, + IPInterface, IPInterfaceList, + IPInterfaceListLink, Link, List_type, + ListLink, LLInterface, LLInterfaceList, + LLInterfaceListLink, LoadShedAvailability, + LoadShedAvailabilityList, + LoadShedAvailabilityListLink, + LocalControlModeStatusType, LogEvent, + LogEventList, LogEventListLink, + ManufacturerStatusType, MessagingProgram, + MessagingProgramList, + MessagingProgramListLink, MeterReading, + MeterReadingBase, MeterReadingLink, + MeterReadingList, MeterReadingListLink, + MirrorMeterReading, MirrorMeterReadingList, + MirrorReadingSet, MirrorUsagePoint, + MirrorUsagePointList, + MirrorUsagePointListLink, Neighbor, + NeighborList, NeighborListLink, + Notification, NotificationList, + NotificationListLink, Offset, + OperationalModeStatusType, PEVInfo, + PowerConfiguration, PowerFactor, + PowerFactorWithExcitation, PowerStatus, + PowerStatusLink, Prepayment, + PrepaymentLink, PrepaymentList, + PrepaymentListLink, PrepayOperationStatus, + PrepayOperationStatusLink, PriceResponse, + PriceResponseCfg, PriceResponseCfgList, + PriceResponseCfgListLink, + ProjectionReading, ProjectionReadingList, + ProjectionReadingListLink, + RandomizableEvent, RateComponent, + RateComponentLink, RateComponentList, + RateComponentListLink, ReactivePower, + ReactiveSusceptance, Reading, ReadingBase, + ReadingLink, ReadingList, ReadingListLink, + ReadingSet, ReadingSetBase, ReadingSetList, + ReadingSetListLink, ReadingType, + ReadingTypeLink, RealEnergy, Registration, + RegistrationLink, RequestStatus, Resource, + RespondableIdentifiedObject, + RespondableResource, + RespondableSubscribableIdentifiedObject, + Response, ResponseList, ResponseListLink, + ResponseSet, ResponseSetList, + ResponseSetListLink, RPLInstance, + RPLInstanceList, RPLInstanceListLink, + RPLSourceRoutes, RPLSourceRoutesList, + RPLSourceRoutesListLink, SelfDevice, + SelfDeviceLink, ServiceChange, + ServiceSupplier, ServiceSupplierLink, + ServiceSupplierList, SetPoint, + SignedRealEnergy, StateOfChargeStatusType, + StorageModeStatusType, + SubscribableIdentifiedObject, + SubscribableList, SubscribableResource, + Subscription, SubscriptionBase, + SubscriptionList, SubscriptionListLink, + SupplyInterruptionOverride, + SupplyInterruptionOverrideList, + SupplyInterruptionOverrideListLink, + SupportedLocale, SupportedLocaleList, + SupportedLocaleListLink, TargetReading, + TargetReadingList, TargetReadingListLink, + TargetReduction, TariffProfile, + TariffProfileLink, TariffProfileList, + TariffProfileListLink, Temperature, + TextMessage, TextMessageList, + TextMessageListLink, TextResponse, Time, + TimeConfiguration, TimeLink, + TimeTariffInterval, TimeTariffIntervalList, + TimeTariffIntervalListLink, UnitValueType, + UnsignedFixedPointType, UsagePoint, + UsagePointBase, UsagePointLink, + UsagePointList, UsagePointListLink, + VoltageRMS, WattHour, loWPAN) __all__ = [ "DERFlexibility", @@ -353,6 +210,7 @@ "CurrentDERProgramLink", "CurrentRMS", "CurveData", + "CurveType", "CustomerAccount", "CustomerAccountLink", "CustomerAccountList", diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/device_category.py b/services/core/IEEE_2030_5/ieee_2030_5/models/device_category.py deleted file mode 100644 index 4b8fc3e0b2..0000000000 --- a/services/core/IEEE_2030_5/ieee_2030_5/models/device_category.py +++ /dev/null @@ -1,63 +0,0 @@ -from enum import IntEnum - - -class DeviceCategoryType(IntEnum): - """ - DeviceCategoryType defined from 20305-2018_IIEStandardforSmartEnergyProfileApplicationsProtocol.pdf Appendix - B.2.3.4 Types package - """ - # The Device category types defined. - # Bit positions SHALL be defined as follows: - PROGRAMMABLE_COMMUNICATING_THERMOSTAT = 0 - STRIP_HEATERS = 1 - BASEBOARD_HEATERS = 2 - WATER_HEATER = 3 - POOL_PUMP = 4 - SAUNA = 5 - HOT_TUB = 6 - SMART_APPLIANCE = 7 - IRRIGATION_PUMP = 8 - MANAGED_COMMERCIAL_AND_INDUSTRIAL_LOADS = 9 - SIMPLE_RESIDENTIAL_LOADS = 10 # On/Off loads - EXTERIOR_LIGHTING = 11 - INTERIOR_LIGHTING = 12 - LOAD_CONTROL_SWITCH = 13 - ENERGY_MANAGEMENT_SYSTEM = 14 - SMART_ENERGY_MODULE = 15 - ELECTRIC_VEHICLE = 16 - ELECTRIC_VEHICLE_SUPPLY_EQUIPMENT = 17 - VIRTUAL_OR_MIXED_DER = 18 - RECIPROCATING_ENGINE = 19 # Synchronous Machine - FUEL_CELL = 20 # Battery - PHOTOVOLTAIC_SYSTEM = 21 # Solar - COMBINED_HEAT_AND_POWER = 22 - COMBINED_PV_AND_STORAGE = 23 - OTHER_GENERATION_SYSTEMS = 24 - OTHER_STORAGE_SYSTEMS = 25 - - # Additional here for Aggregator - AGGREGATOR = 99 - OTHER_CLIENT = 100 - - -# 0 - Programmable Communicating Thermostat -# 1 - Strip Heaters -# 2 - Baseboard Heaters -# 3 - Water Heater -# 4 - Pool Pump -# 5 - Sauna -# 6 - Hot tub -# 7 - Smart Appliance -# 8 - Irrigation Pump -# 9 - Managed Commercial and Industrial Loads -# 10 - Simple Residential Loads -# 11 - Exterior Lighting -# 12 - Interior Lighting -# 13 - Electric Vehicle -# 14 - Generation Systems -# 15 - Load Control Switch -# 16 - Smart Inverter -# 17 - EVSE -# 18 - Residential Energy Storage Unit -# 19 - Energy Management System -# 20 - Smart Energy Module diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/enums.py b/services/core/IEEE_2030_5/ieee_2030_5/models/enums.py new file mode 100644 index 0000000000..e14d7c1f5b --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/enums.py @@ -0,0 +1,129 @@ +from enum import IntEnum + + +class PrimacyType(IntEnum): + # Values possible for indication of "Primary" provider: + # 0: In home energy management system + # 1: Contracted premises service provider + # 2: Non-contractual service provider + # 3 - 64: Reserved + # 65 - 191: User-defined + #192 - 255: Reserved + InHomeManagementSystem = 0 + ContractedPremisesServiceProvider = 1 + NonContractualServiceProvider = 2 + + +class DERUnitRefType(IntEnum): + # 0 - N/A + # 1 - %setMaxW + # 2 - %setMaxVar + # 3 - %statVarAvail + # 4 - %setEffectiveV + # 5 - %setMaxChargeRateW + # 6 - %setMaxDischargeRateW + # 7 - %statWAvail + NA = 0 + setMaxW = 1 + setMaxVar = 2 + statVarAvail = 3 + setEffectiveV = 4 + setMaxChargeRateW = 5 + setMaxDischargeRateW = 6 + statWAvail = 7 + +class CurveType(IntEnum): + # 0 - opModFreqWatt (Frequency-Watt Curve Mode) + # 1 - opModHFRTMayTrip (High Frequency Ride Through, May Trip Mode) + # 2 - opModHFRTMustTrip (High Frequency Ride Through, Must Trip Mode) + # 3 - opModHVRTMayTrip (High Voltage Ride Through, May Trip Mode) + # 4 - opModHVRTMomentaryCessation (High Voltage Ride Through, Momentary Cessation + # Mode) + # 5 - opModHVRTMustTrip (High Voltage Ride Through, Must Trip Mode) + # 6 - opModLFRTMayTrip (Low Frequency Ride Through, May Trip Mode) + # 7 - opModLFRTMustTrip (Low Frequency Ride Through, Must Trip Mode) + # 8 - opModLVRTMayTrip (Low Voltage Ride Through, May Trip Mode) + # 9 - opModLVRTMomentaryCessation (Low Voltage Ride Through, Momentary Cessation + # Mode) + # 10 - opModLVRTMustTrip (Low Voltage Ride Through, Must Trip Mode) + # 11 - opModVoltVar (Volt-Var Mode) + # 12 - opModVoltWatt (Volt-Watt Mode) + # 13 - opModWattPF (Watt-PowerFactor Mode) + # 14 - opModWattVar (Watt-Var Mode) + opModFreqWatt = 0 + opModHFRTMayTrip = 1 + opModHFRTMustTrip = 2 + opModHVRTMayTrip = 3 + opModHVRTMomentaryCessation = 4 + opModHVRTMustTrip = 5 + opModLFRTMayTrip = 6 + opModLFRTMustTrip = 7 + opModLVRTMayTrip = 8 + opModLVRTMomentaryCessation = 9 + opModLVRTMustTrip = 10 + opModVoltVar = 11 + opModVoltWatt = 12 + opModWattPF = 13 + opModWattVar = 14 + + +class DeviceCategoryType(IntEnum): + """ + DeviceCategoryType defined from 20305-2018_IIEStandardforSmartEnergyProfileApplicationsProtocol.pdf Appendix + B.2.3.4 Types package + """ + # The Device category types defined. + # Bit positions SHALL be defined as follows: + PROGRAMMABLE_COMMUNICATING_THERMOSTAT = 0 + STRIP_HEATERS = 1 + BASEBOARD_HEATERS = 2 + WATER_HEATER = 3 + POOL_PUMP = 4 + SAUNA = 5 + HOT_TUB = 6 + SMART_APPLIANCE = 7 + IRRIGATION_PUMP = 8 + MANAGED_COMMERCIAL_AND_INDUSTRIAL_LOADS = 9 + SIMPLE_RESIDENTIAL_LOADS = 10 # On/Off loads + EXTERIOR_LIGHTING = 11 + INTERIOR_LIGHTING = 12 + LOAD_CONTROL_SWITCH = 13 + ENERGY_MANAGEMENT_SYSTEM = 14 + SMART_ENERGY_MODULE = 15 + ELECTRIC_VEHICLE = 16 + ELECTRIC_VEHICLE_SUPPLY_EQUIPMENT = 17 + VIRTUAL_OR_MIXED_DER = 18 + RECIPROCATING_ENGINE = 19 # Synchronous Machine + FUEL_CELL = 20 # Battery + PHOTOVOLTAIC_SYSTEM = 21 # Solar + COMBINED_HEAT_AND_POWER = 22 + COMBINED_PV_AND_STORAGE = 23 + OTHER_GENERATION_SYSTEMS = 24 + OTHER_STORAGE_SYSTEMS = 25 + + # Additional here for Aggregator + AGGREGATOR = 99 + OTHER_CLIENT = 100 + + +# 0 - Programmable Communicating Thermostat +# 1 - Strip Heaters +# 2 - Baseboard Heaters +# 3 - Water Heater +# 4 - Pool Pump +# 5 - Sauna +# 6 - Hot tub +# 7 - Smart Appliance +# 8 - Irrigation Pump +# 9 - Managed Commercial and Industrial Loads +# 10 - Simple Residential Loads +# 11 - Exterior Lighting +# 12 - Interior Lighting +# 13 - Electric Vehicle +# 14 - Generation Systems +# 15 - Load Control Switch +# 16 - Smart Inverter +# 17 - EVSE +# 18 - Residential Energy Storage Unit +# 19 - Energy Management System +# 20 - Smart Energy Module From 05ebce10e15603297f72fcc64f8541818f9288e0 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 12 Oct 2023 11:42:32 -0700 Subject: [PATCH 40/53] Fixed some tests for getting and setting events. --- .../core/IEEE_2030_5/ieee_2030_5/agent.py | 136 +++++++++++++++--- .../core/IEEE_2030_5/ieee_2030_5/client.py | 96 +++++++++---- services/core/IEEE_2030_5/tests/get_dcap.py | 40 +++++- services/core/IEEE_2030_5/tests/new_event.py | 49 +++++++ 4 files changed, 269 insertions(+), 52 deletions(-) create mode 100644 services/core/IEEE_2030_5/tests/new_event.py diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index 329f7c0c56..fd62d1ed59 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -12,8 +12,9 @@ # License for the specific language governing permissions and limitations # under the License. from __future__ import annotations -from dataclasses import dataclass, field - +from copy import deepcopy +from dataclasses import dataclass, field, fields +import math import logging import sys from datetime import datetime @@ -43,9 +44,11 @@ # Setup logging so that it runs within the platform utils.setup_logging() +logging.getLogger("ieee_2030_5.client.req_resp").setLevel(logging.INFO) # The logger for this agent is _log and can be used throughout this file. _log = logging.getLogger(__name__) + # These items are global for the agent and will periodically be # sent to the 2030.5 server based upon the post interval. DER_SETTINGS = m.DERSettings() @@ -54,6 +57,9 @@ DER_CONTROL_BASE = m.DERControlBase() # Used for sending status message to the 2030.5 server. DER_STATUS = m.DERStatus() +# Used for sending default control to the 2030.5 server. +DEFAULT_DER_CONTROL = m.DefaultDERControl() +DEFAULT_DER_CONTROL.DERControlBase = DER_CONTROL_BASE @dataclass class MappedPoint: @@ -73,7 +79,7 @@ class MappedPoint: description: str multiplier: int mrid: str - writable: bool + offset: int parameter_type: str notes: str parent_object: object = None @@ -103,6 +109,8 @@ def __post_init__(self): self.parent_object = DER_CONTROL_BASE elif params[0] == 'DERStatus': self.parent_object = DER_STATUS + elif params[0] == 'DefaultDERControl': + self.parent_object = DEFAULT_DER_CONTROL assert self.parent_object is not None, f"The parent object type {params[0]} is not known, please check spelling in configuration file." assert hasattr(self.parent_object, params[1]), f"{params[0]} does not have property {params[1]}, please check spelling in configuration file." @@ -115,7 +123,7 @@ def build_from_csv(data: Dict[str, str]) -> MappedPoint: description=data['Description'].strip(), multiplier=data['Multiplier'].strip(), mrid=data['MRID'].strip(), - writable=data['Writeable'].strip(), + offset=data['Offset'].strip(), parameter_type=data['Parameter Type'].strip(), notes=data['Notes'].strip() ) @@ -173,6 +181,10 @@ def __init__(self, config_path: str, **kwargs): self._last_capabilities = m.DERCapability() self._last_status = m.DERStatus() + # These variables represent the current state of the der and + self._active_controls: List[m.DERControl] = [] + self._default_der_control: m.DefaultDERControl = None + self._current_control: m.DERControl = None try: self._client.start() @@ -188,6 +200,8 @@ def __init__(self, config_path: str, **kwargs): self._mup_readings: Dict[str, m.MirrorMeterReading] = {} self._mup_pollRate: int = 60 self._times_published: Dict[str, int] = {} + + # Set a default configuration to ensure that self.configure is called immediately to setup # the agent. @@ -223,17 +237,104 @@ def _active_controls_changed(self, active: m.DERControlList): def _default_control_changed(self, default_control: m.DefaultDERControl): if not isinstance(default_control, m.DefaultDERControl): _log.error("Invalid instance of default control") + raise ValueError(f"Invalid instance of default control was {type(default_control)}") + + if self._current_control is not None: + _log.info("Default config has been overwritten by event.") return - _log.debug(default_control) + _log.info("Sending controls to platform.driver") + + self._default_der_control = default_control + + default_control_points = list(filter(lambda x: 'DefaultDERControl' in x.parameter_type, self._mapped_points.values())) + der_base_points = list(filter(lambda x: 'DERControlBase' in x.parameter_type, self._mapped_points.values())) + + for point in default_control_points: + point_value = getattr(default_control, point.parameter) + + try: + if point_value: + if not isinstance(point_value, (float, int, bool)): + point_value = getattr(point_value, "value") + + if point_value: + self.vip.rpc.call("platform.driver", "set_point", point.point_on_bus, point_value) + except TypeError: + _log.error(f"Error setting point {point.point_on_bus} to {point_value}") + + for point in der_base_points: + + point_value = getattr(default_control.DERControlBase, point.parameter) + + try: + if point_value: + if not isinstance(point_value, (float, int, bool)): + point_value = getattr(point_value, "value") + + if point_value: + self.vip.rpc.call("platform.driver", "set_point", point.point_on_bus, point_value) + except TypeError: + _log.error(f"Error setting point {point.point_on_bus} to {point_value}") + + + def _control_event_started(self, sender): + _log.debug(f"{'='*50}Control event started\n{sender}") + if not isinstance(sender, m.DERControl): + _log.error("Invalid control event passed to event_started") + raise ValueError(f"Invalid type passed to event_started {type(sender)} instead of {type(m.DERControl)}") + + self._current_control = sender + der_control: m.DERControl = sender + # We override some of the base controls with the event controls + der_control_base: m.DERControlBase = None + if self._default_der_control is not None and self._default_der_control.DERControlBase is not None: + der_control_base = deepcopy(self._default_der_control.DERControlBase) + + if der_control_base: + # Overwrite all of the base controls with the controls from the event. + for fld in fields(m.DERControlBase): + setattr(der_control_base, fld.name, getattr(der_control.DERControlBase, fld.name)) + else: + der_control_base = der_control.DERControlBase + + # Retrieve mapped points that we can report on to the platform driver. + # Note this is a DERControlBase prefix in the parameter_type field. + der_base_points = list(filter(lambda x: 'DERControlBase' in x.parameter_type, self._mapped_points.values())) + + for point in der_base_points: + + point_value = getattr(der_control_base, point.parameter) + + try: + if point_value: + # if not isinstance(point_value, (float, int, bool)): + # point_value = getattr(point_value, "value") + + # These are the point types that have a multiplyer assigned to them. + if isinstance(point_value, (m.VoltageRMS, m.ApparentPower, m.PowerFactor, m.CurrentRMS, + m.ActivePower, m.WattHour, m.ReactivePower, m.FixedPointType)): + if isinstance(point_value, m.PowerFactor): + point_value = point_value.displacement * math.pow(10, -point_value.multiplier) + else: + point_value = point_value.value * math.pow(10, -point_value.multiplier) + elif isinstance(point_value, m.FixedVar): + ... + + elif isinstance(point_value, m.DERCurveLink): + ... + + if point_value: + _log.debug(f"Setting point: {point.point_on_bus} to {point_value}") + self.vip.rpc.call("platform.driver", "set_point", point.point_on_bus, point_value) + except TypeError: + _log.error(f"Error setting point {point.point_on_bus} to {point_value}") + - def _control_event_started(self, sender, **kwargs): - _log.debug(f"Control event started {kwargs}") - - def _control_event_ended(self, sender, **kwargs): - _log.debug(f"Control event ended {kwargs}") - def dcap_updated(self, sender): - _log.debug(f"Dcap was updated by {sender}") + def _control_event_ended(self, sender): + _log.debug(f"{'='*50}Control event ended\n{sender}") + self._current_control = None + def configure(self, config_name, action, contents): """ @@ -253,7 +354,10 @@ def configure(self, config_name, action, contents): if item.get('Point Name').strip() and item.get('Parameter Type').strip(): if 'DERSettings' in item['Parameter Type'] or \ 'DERCapability' in item['Parameter Type'] or \ - 'DERStatus' in item['Parameter Type']: + 'DERStatus' in item['Parameter Type'] or \ + 'DERControlBase' in item['Parameter Type'] or \ + 'DefaultDERControl' in item['Parameter Type']: + point = MappedPoint.build_from_csv(item) self._mapped_points[point.point_on_bus] = point # self._mapped_points[point.parameter_type] = point @@ -323,12 +427,6 @@ def _cast_multipler(self, value: str) -> int: except ValueError: _log.warning(f"Casting multiplier to int failed: {value}") return 1 - - def _set_correct_value(self, value: Any) -> Any: - value_of_instance = value.value - if isinstance(value_of_instance, type(value)): - value_of_instance.value = value_of_instance.value.value - return value_of_instance def _transform_settings(self, points: List[MappedPoint]) -> m.DERSettings: """Update a DERSettings object so that it is correctly formatted to send to the server. diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index afff2fd40b..6b7712f906 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -16,6 +16,7 @@ from threading import Semaphore, Timer from typing import Any, Callable, Dict, List, Optional, Set, Tuple, Union from uuid import uuid4 +import gevent import ieee_2030_5.models as m import xsdata @@ -66,7 +67,7 @@ def trigger(self, current_time: int): self.last_trigger_time = current_time -class _TimerThread(threading.Thread): +class _TimerThread(gevent.Greenlet): tick = Signal("tick") def __init__(self): @@ -278,7 +279,59 @@ def put_der_status(self, new_status: m.DERStatus) -> int: resp = self.__put__(list(self._der.values())[0].DERStatusLink.href, dataclass_to_xml(new_status)) return resp.status - + + def _send_control_events(self, der_program_href: str): + # Need to check this every 10 seconds for updates to conttrols + program: m.DERProgram = self.__get_request__(der_program_href) + + active: m.DERControlList = self.__get_request__(program.ActiveDERControlListLink.href) + default = self.__get_request__(program.DefaultDERControlLink.href) + active_is_different = False + + to_add = [] + for newderctl in active.DERControl: + found = False + for existingctl in self._der_active_controls.DERControl: + if existingctl.mRID == newderctl.mRID: + found = True + if existingctl == newderctl: + _log.debug(f"Currently in event {newderctl.mRID}") + else: + _log.debug("TODO ->>>>>>>>>>>>>>>>>>>>>>>>>>> Existing mRID should superscede????") + break + if not found: + to_add.append(newderctl) + + for ctrl in to_add: + self._der_control_event_started_signal.send(ctrl) + + to_remove = [] + for existingctl in self._der_active_controls.DERControl: + found = False + for newctrl in active.DERControl: + if newctrl.mRID == existingctl.mRID: + found = True + break + if not found: + to_remove.append(existingctl) + + i = len(self._der_active_controls.DERControl) + while i > 0: + i -= 1 + if self._der_active_controls.DERControl[i] in to_remove: + self._der_control_event_ended_signal.send(self._der_active_controls.DERControl[i]) + self._der_active_controls.DERControl.pop(i) + + self._der_active_controls = active + + if default != self._der_default_control: + self._der_default_control = default + _log.debug("Default control changed....") + self._default_control_changed.send(default) + + # TODO un hard code 30 second server update. + self._update_timer_spec("der_control_event", 5, fn=lambda: self._send_control_events(der_program_href)) + def _update_dcap_tree(self, endpoint: Optional[str] = None): """Retrieve device capability @@ -329,29 +382,10 @@ def _update_dcap_tree(self, endpoint: Optional[str] = None): self._der_map[derlist.href] = derlist for index, der in enumerate(derlist.DER): self._der[der.href] = der - if derlist.DER[0].CurrentDERProgramLink: - program: m.DERProgram = self.__get_request__(derlist.DER[0].CurrentDERProgramLink.href) - active: m.DERControlList = self.__get_request__(program.ActiveDERControlListLink.href) - default = self.__get_request__(program.DefaultDERControlLink.href) - active_is_different = False - if len(active.DERControl) == len(self._der_active_controls.DERControl): - for index, der in enumerate(active.DERControl): - if der != self._der_active_controls.DERControl[index]: - active_is_different = True - break - else: - active_is_different = True - if active_is_different: - self._der_active_controls = active - self._active_controls_changed_signal.send(self._der_active_controls) - - if default != self._der_default_control: - self._der_default_control = default - self._default_control_changed.send(default) + if derlist.DER[0].CurrentDERProgramLink: + self._send_control_events(derlist.DER[0].CurrentDERProgramLink.href) - - for fsa in self._fsa.values(): if fsa.DERProgramListLink: self._der_program_map[fsa.DERProgramListLink.href] = self.__get_request__( @@ -584,8 +618,13 @@ def __put__(self, url: str, data: Any, headers: Optional[Dict[str, str]] = None) if self._debug: _log_req_resp.debug(f"----> PUT REQUEST\nurl: {url}\nbody: {data}") - - self.http_conn.request(method="PUT", headers=headers, url=url, body=data) + + try: + self.http_conn.request(method="PUT", headers=headers, url=url, body=data) + except http.client.CannotSendRequest as ex: + self.http_conn.close() + _log.debug("Reconnecting to server") + self.http_conn.request(method="PUT", headers=headers, url=url, body=data) response = self._http_conn.getresponse() return response @@ -612,7 +651,12 @@ def __get_request__(self, url: str, body=None, headers: Optional[Dict] = None): if self._debug: _log_req_resp.debug(f"----> GET REQUEST\nurl: {url}\nbody: {body}") - self.http_conn.request(method="GET", url=url, body=body, headers=headers) + try: + self.http_conn.request(method="GET", url=url, body=body, headers=headers) + except http.client.CannotSendRequest as ex: + self.http_conn.close() + _log.debug("Reconnecting to server") + self.http_conn.request(method="GET", url=url, body=body, headers=headers) response = self._http_conn.getresponse() response_data = response.read().decode("utf-8") diff --git a/services/core/IEEE_2030_5/tests/get_dcap.py b/services/core/IEEE_2030_5/tests/get_dcap.py index 3daa0290cb..dbdfe6853f 100644 --- a/services/core/IEEE_2030_5/tests/get_dcap.py +++ b/services/core/IEEE_2030_5/tests/get_dcap.py @@ -91,12 +91,13 @@ def print_it(thing: str, obj: object): new_mup = get_as_device(resp.headers["Location"]) print_it("New Mirror Usage Point", new_mup) - print("\n\n") - +input("Press Enter to continue...") +#while True: current_time = int(time.mktime(datetime.utcnow().timetuple())) +print(f"Time is: {current_time}") new_ctrl = m.DERControl(mRID="b234245afff", DERControlBase=dderc.DERControlBase, description="A new control is going here") -new_ctrl.interval = m.DateTimeInterval(start=current_time + 10, duration=20) +new_ctrl.interval = m.DateTimeInterval(start=current_time + 5, duration=10) response = post_as_admin(dercl.href, data=dataclass_to_xml(new_ctrl)) ctrl_evnt = get_as_device(response.headers['Location']) @@ -108,18 +109,43 @@ def print_it(thing: str, obj: object): activel = get_as_device(derp.ActiveDERControlListLink.href) print_it("ActiveDERControl", activel) -print(print(f"{'='*20} Sleeping 10 s {'='*20}")) -time.sleep(10) +print("Waiting for activation of control on server...") +print(print(f"{'='*20} Sleeping 6 s {'='*20}")) +time.sleep(6) activel = get_as_device(derp.ActiveDERControlListLink.href) print_it("ActiveDERControl", activel) -print(print(f"{'='*20} Sleeping 30 s {'='*20}")) -time.sleep(30) +print("Waiting for deactivation of control on server...") +print(print(f"{'='*20} Sleeping 20 s {'='*20}")) +time.sleep(20) activel = get_as_device(derp.ActiveDERControlListLink.href) print_it("ActiveDERControl", activel) +# ctrl_str = """ +# +# Control 1 +# {'opModConnect': True, 'opModMaxLimW': 9500} +# +# +# Control 2 +# {'opModConnect': True, 'opModFixedW': 80} +# +# +# 94E46E50F4964762B94E6C24AA350CA2 +# +# 60 +# 1696592892 +# +# +# true +# 9500 +# +# +# """ + + # def _change_power_factor(new_pf): diff --git a/services/core/IEEE_2030_5/tests/new_event.py b/services/core/IEEE_2030_5/tests/new_event.py new file mode 100644 index 0000000000..f070cd9b4b --- /dev/null +++ b/services/core/IEEE_2030_5/tests/new_event.py @@ -0,0 +1,49 @@ +from datetime import datetime +import sys +import os +import time +import uuid +sys.path.insert(0, os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))) +from dataclasses import asdict +from pprint import pprint +import urllib3 +from request_session import get_as_admin, get_as_device, post_as_admin, post_as_device +import ieee_2030_5.models as m +from ieee_2030_5 import dataclass_to_xml, xml_to_dataclass +urllib3.disable_warnings() + +def print_it(thing: str, obj: object): + print(f"{'='*20} {thing} {'='*20}") + try: + pprint(asdict(obj), indent=4) + except TypeError: + print(f"Type: {type(obj)} was passed and cannot be printed!") + +dcap: m.DeviceCapability = get_as_device("dcap") +print_it("DeviceCapability", dcap) + +edevl: m.EndDeviceList = get_as_device("edev") +print_it("EndDeviceList", edevl) + +edev = edevl.EndDevice[0] +derl = get_as_device(edev.DERListLink.href) +print_it("DERList", derl) + +der: m.DER = derl.DER[0] +current_program = get_as_device(der.CurrentDERProgramLink.href) +print_it("CurrentDERProgram", current_program) + +dderc: m.DefaultDERControl = get_as_device(current_program.DefaultDERControlLink.href) +print_it("DefaultDERControl", dderc) + +dercl: m.DERControlList = get_as_device(current_program.DERControlListLink.href) +print_it("DERControlList", dercl) + +current_time = int(time.mktime(datetime.utcnow().timetuple())) +print(f"Time is: {current_time}") +mrid = str(uuid.uuid4()).replace('-', '') +new_ctrl = m.DERControl(mRID=mrid, DERControlBase=dderc.DERControlBase, description="A new control is going here") +new_ctrl.interval = m.DateTimeInterval(start=current_time + 5, duration=30) +new_ctrl.DERControlBase.opModTargetW = m.ActivePower(3, 2000) +print_it("New Control is", new_ctrl) +response = post_as_admin(dercl.href, data=dataclass_to_xml(new_ctrl)) From a1c03eda7d1d4651290a18f6d667e352c3ddc714 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 12 Oct 2023 22:46:12 -0700 Subject: [PATCH 41/53] update example config and requirements for the demo --- services/core/IEEE_2030_5/example.config.yml | 2 ++ services/core/IEEE_2030_5/requirements_demo.txt | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/services/core/IEEE_2030_5/example.config.yml b/services/core/IEEE_2030_5/example.config.yml index cb6f5c4689..77451a3331 100644 --- a/services/core/IEEE_2030_5/example.config.yml +++ b/services/core/IEEE_2030_5/example.config.yml @@ -13,6 +13,8 @@ log_req_resp: true server_ssl_port: 8443 # http port defaults to none #server_http_port: 8080 +# Number of seconds to poll for new default der settings. +default_der_control_poll: 60 MirrorUsagePointList: # MirrorMeterReading based on Table E.2 IEEE Std 2030.5-18 diff --git a/services/core/IEEE_2030_5/requirements_demo.txt b/services/core/IEEE_2030_5/requirements_demo.txt index a42b148c45..bd134eacc6 100644 --- a/services/core/IEEE_2030_5/requirements_demo.txt +++ b/services/core/IEEE_2030_5/requirements_demo.txt @@ -1,6 +1,6 @@ pvlib nicegui requests -xsdata +xsdata>=23.8 blinker plotly From ed408f908c7ac33e80f0aa46083fc96462110153 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 12 Oct 2023 22:46:30 -0700 Subject: [PATCH 42/53] Update demo server --- services/core/IEEE_2030_5/demo/server.yml | 15 ++------------- 1 file changed, 2 insertions(+), 13 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/server.yml b/services/core/IEEE_2030_5/demo/server.yml index e754929414..e57df4fe93 100644 --- a/services/core/IEEE_2030_5/demo/server.yml +++ b/services/core/IEEE_2030_5/demo/server.yml @@ -75,19 +75,8 @@ programs: DERControlBase: opModConnect: true - opModMaxLimW: 9500 - - DERControls: - - description: Control 1 - DERControlBase: - opModConnect: true - opModMaxLimW: 9500 - - description: Control 2 - DERControlBase: - opModConnect: true - opModFixedW: 80 - - + opModEnergize: true + ders: - description: der1 From a16546b2d6b9928bae984c37c0567d901d87e8ac Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 12 Oct 2023 22:47:00 -0700 Subject: [PATCH 43/53] Send proper value to server --- services/core/IEEE_2030_5/demo/webgui.py | 719 +++++++++++------------ 1 file changed, 334 insertions(+), 385 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index 7e625bb2db..ebb0d4dae4 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -1,23 +1,22 @@ #!/usr/bin/env python3 from __future__ import annotations -import asyncio -import atexit -from collections import deque -import json +import calendar +from copy import deepcopy + import os -import platform +from parser import ParserError + import re -import shlex + import sys import time import uuid import urllib3 -from asyncio.subprocess import Process from dataclasses import dataclass, field, fields -from datetime import datetime +from datetime import datetime, timedelta from pathlib import Path -from typing import Dict, List +from typing import Any, Callable, Dict, List, TypeVar import logging import xsdata import yaml @@ -25,13 +24,14 @@ import plotly.express as px import pandas as pd from numbers import Number +import re from volttron.platform import get_volttron_root from volttron.platform.agent.utils import parse_timestamp_string, process_timestamp urllib3.disable_warnings() -sys.path.insert(0, str(Path(__file__).parent.parent)) +sys.path.insert(0, str(Path(__file__).absolute().parent.parent.as_posix())) import subprocess @@ -44,6 +44,14 @@ logging.getLogger("urllib3.connectionpool").setLevel(logging.INFO) _log = logging.getLogger(__name__) +def uuid_2030_5() -> str: + return str(uuid.uuid4()).replace('-', '').upper() + +def datetime_from_utc_to_local(utc_datetime): + now_timestamp = time.time() + offset = datetime.fromtimestamp(now_timestamp) - datetime.utcfromtimestamp(now_timestamp) + return utc_datetime + offset + @dataclass class Configuration: agent_2030_5_identity: str = "ed1" @@ -80,29 +88,7 @@ def df(self) -> pd.DataFrame: my_df = pd.DataFrame(data) my_df.set_index(['ts']) return my_df - - # def add_publish(self, ts, published): - - # self.series_ts.append(ts) - - # if len(self.series_ts) > 10: - # self.series_ts.pop() - - # for k in published[0]: - # if k not in self.series_labels: - # self.series_labels.append(k) - # self.series_values[k] = [] - - # self.series_values[k].append(published[0][k]) - # if len(self.series_values[k]) > 10: - # self.series_values[k].pop() - - # if self.series_ts: - # plot_figure.refresh() - -# Data from the platform driver is plotted here. -#data_plot = PlottedData() # Configuration parameters from the config page config = Configuration() # Temp storage for changes on the config page @@ -118,7 +104,78 @@ def df(self) -> pd.DataFrame: admin_session = requests.Session() client_session = requests.Session() +S = TypeVar('S') +T = TypeVar('T') + +class PropertyWrapper: + """The PropertyWrapper class handles binding on behalf of the parent object. + + The class handles the binding from/to and formatting/applying when sending the + object to the parent. + """ + + def __init__(self, backing_obj: T, parent_obj: S, parent_property: str, + formatters: Dict[str, Callable] = None, applyers: Dict[str, Callable] = None): + # The sub object that we need to provide for + self.backing_obj = backing_obj + # The parent object this property is wrapping + self.parent_obj = parent_obj + # The property this object is wrapping on the parent_obj + self.parent_property = parent_property + + if formatters is None: + formatters = {} + + if applyers is None: + applyers = {} + + self.formatters = formatters + self.appliers = applyers + # Transfer the values from the parent to the backing object + if self.parent_obj.__dict__[self.parent_property] is not None: + if isinstance(self.backing_obj, (m.VoltageRMS, m.ApparentPower, m.CurrentRMS, + m.ActivePower, m.FixedVar, m.FixedPointType, + m.ReactivePower, m.AmpereHour, m.WattHour)): + self.backing_obj.__dict__["value"] = self.parent_obj.__dict__[self.parent_property] + + _log.debug(f"Creating Property Wrapper for parent {type(parent_obj)} with backing object {type(backing_obj)} on property {parent_property}") + + def __setattr__(self, key: str, value: Any): + if key in ("backing_obj", "parent_obj", "parent_property", "formatters", "appliers"): + self.__dict__[key] = value + else: + if key in self.formatters: + self.backing_obj.__dict__[key] = self.formatters[key](value) + else: + _log.debug(f"Setting on {type(self.backing_obj)} {key} -> {value}") + self.backing_obj.__dict__[key] = value + + def __getattr__(self, key: str) -> Any: + if key in ("data_obj", "parent_obj", "parent_property", "formatters", "appliers"): + return self.__dict__[key] + else: + return self.backing_obj.__dict__[key] + + def apply_to_parent(self): + other_obj = deepcopy(self.backing_obj) + for field in fields(other_obj): + if field.name in self.appliers: + _log.debug(f"Converting from {other_obj.__dict__[field.name]} to {self.appliers[field.name](other_obj.__dict__[field.name])}") + other_obj.__dict__[field.name] = self.appliers[field.name](other_obj.__dict__[field.name]) + + if self.should_be_none(): + setattr(self.parent_obj, self.parent_property, None) + else: + setattr(self.parent_obj, self.parent_property, other_obj) + + def should_be_none(self) -> bool: + for fld in fields(self.backing_obj): + if getattr(self.backing_obj, fld.name): + return False + return True + def update_sessions(): + """Update the admin and client sessions with the current configuration.""" tlsdir = Path(config.ieee_client_cert).parent.parent admin_session.cert = (str(tlsdir.joinpath("certs/admin.crt")), str(tlsdir.joinpath("private/admin.pem"))) client_session.cert = (config.ieee_client_cert, config.ieee_client_pk) @@ -191,6 +248,14 @@ def reset_config(): cards = [] + +def convert_datetime_to_int(dt: datetime) -> int: + """Converts datetime to epoch time in gmt + + :param dt: Datetime object + :return: Integer epoch time + """ + return int(calendar.timegm(dt.timetuple())) update_sessions() dcap: m.DeviceCapability = get_from_server("dcap", deserialize=True) @@ -211,59 +276,139 @@ def reset_config(): def noneable_int_change(obj: object, prop: str, value): - if value.sender.value == "" or value.sender.value is None: - setattr(obj, prop, None) - else: - try: - num = int(value.sender.value) - setattr(obj, prop, num) - except ValueError: - ... + try: + num = int(value.sender.value) + setattr(obj, prop, num) + except (ValueError, TypeError): + ... @ui.refreshable def render_der_default_control_tab(): + def do_refresh(): + render_der_default_control_tab.refresh() + ui.notify("Refreshed") default: m.DefaultDERControl = get_from_server(program.DefaultDERControlLink.href, deserialize=True) + der_base: m.DERControlBase = default.DERControlBase + if der_base is None: + der_base = m.DERControlBase() + default.DERControlBase = der_base + + wrappers: List[PropertyWrapper] = [] + with ui.row(): with ui.column(): - ui.label("DER Default Control").style("font-size: 200%;") + with ui.label("DER Default Control").style("font-size: 200%;"): + ui.button(icon="refresh", color="white", + on_click=lambda: do_refresh()).style("margin:5px; padding: 5px;") ui.label("Section 10.10 Distributed Energy Resources function set from 20305-2018 IEEE standard.") with ui.row().classes("pt-10"): with ui.column().classes("pr-20"): - esdelay_input = ui.input("setESDelay (hundredth of a second)", + ui.input("setESDelay (hundredth of a second)", on_change=lambda e: noneable_int_change(default, "setESDelay", e)) \ .bind_value_from(default, "setESDelay").classes("w-96") #.bind_value_from(default, "setESDelay").classes("w-96") - setESHighFreq = ui.input("setESHighFreq (hundredth of a hertz)", + ui.input("setESHighFreq (hundredth of a hertz)", on_change=lambda e: noneable_int_change(default, "setESHighFreq", e)) \ .bind_value_from(default, "setESHighFreq").classes("w-96") - setESHighVolt = ui.input("setESHighVolt (hundredth of a volt)", + ui.input("setESHighVolt (hundredth of a volt)", on_change=lambda e: noneable_int_change(default, "setESHighVolt", e)) \ .bind_value_from(default, "setESHighVolt").classes("w-96") - setESLowFreq = ui.input("setESLowFreq (hundredth of a hertz)", + ui.input("setESLowFreq (hundredth of a hertz)", on_change=lambda e: noneable_int_change(default, "setESHighVolt", e)) \ .bind_value_from(default, "setESLowFreq").classes("w-96") - setESLowVolt = ui.input("setESLowVolt (hundredth of a volt)", + ui.input("setESLowVolt (hundredth of a volt)", on_change=lambda e: noneable_int_change(default, "setESLowFreq", e)) \ .bind_value_from(default, "setESLowVolt").classes("w-96") with ui.column(): - setESRampTms = ui.input("setESRampTms (hundredth of a second)", + ui.input("setESRampTms (hundredth of a second)", on_change=lambda e: noneable_int_change(default, "setESRampTms", e)) \ .bind_value_from(default, "setESRampTms").classes("w-96") - setESRandomDelay = ui.input("setESRandomDelay (hundredth of a second)", + ui.input("setESRandomDelay (hundredth of a second)", on_change=lambda e: noneable_int_change(default, "setESRandomDelay", e)) \ .bind_value_from(default, "setESRandomDelay").classes("w-96") - setGradW = ui.input("setGradW (hundredth of a watt)", + ui.input("setGradW (hundredth of a watt)", on_change=lambda e: noneable_int_change(default, "setGradW", e)) \ .bind_value_from(default, "setGradW").classes("w-96") - setSoftGradW = ui.input("setSoftGradW (hundredth of a watt)", + ui.input("setSoftGradW (hundredth of a watt)", on_change=lambda e: noneable_int_change(default, "setSoftGradW", e)) \ .bind_value_from(default, "setSoftGradW").classes("w-96") + with ui.row().style("margin-top:15px"): + ui.label("DER Control Base").style("font-size: 150%;") + + with ui.row(): + with ui.column(): + ui.checkbox("opModConnect", value=True).bind_value(der_base, "opModConnect") + ui.checkbox("opModEnergize", value=True).bind_value(der_base, "opModEnergize") + + ui.label("Power Factor Absorb Watts").style("font-size: 125%;") + opModFixedPFAbsorbW_wrapper = PropertyWrapper(m.PowerFactorWithExcitation(), der_base, "opModFixedPFAbsorbW") + wrappers.append(opModFixedPFAbsorbW_wrapper) + ui.input("displacement", on_change=lambda e: noneable_int_change(opModFixedPFAbsorbW_wrapper, "displacement", e)) \ + .bind_value_from(opModFixedPFAbsorbW_wrapper, "displacement") + ui.checkbox("excitation", value=False).bind_value(opModFixedPFAbsorbW_wrapper, "excitation") + + ui.label("Power Factor Inject Watts").style("font-size: 125%;") + opModFixedPFInjectW_wrapper = PropertyWrapper(m.PowerFactorWithExcitation(), der_base, "opModFixedPFInjectW") + wrappers.append(opModFixedPFInjectW_wrapper) + ui.input("displacement", on_change=lambda e: noneable_int_change(opModFixedPFInjectW_wrapper, "displacement", e)) \ + .bind_value_from(opModFixedPFInjectW_wrapper, "displacement") + ui.checkbox("excitation", value=False).bind_value(opModFixedPFInjectW_wrapper, "excitation") + + + with ui.column().classes("pr-10"): + fixedVar_wrapper = PropertyWrapper(m.FixedVar(), der_base, "opModFixedVar") + wrappers.append(fixedVar_wrapper) + ui.input("opModFixedVar", on_change=lambda e: noneable_int_change(fixedVar_wrapper, "value", e)) \ + .bind_value_from(fixedVar_wrapper, "value") + + fixedWatt_wrapper = PropertyWrapper(m.FixedVar(), der_base, "opModFixedVar") + wrappers.append(fixedWatt_wrapper) + ui.input("opModFixedW", on_change=lambda e: noneable_int_change(fixedWatt_wrapper, "value", e)) \ + .bind_value_from(fixedWatt_wrapper, "value") + + # freqDroop_wrapper = Wrapper(m.FreqDroopType(), der_base, "openLoopTms") + # wrappers.append(freqDroop_wrapper) + # opModFreqDroop = ui.input("opModFreqDroop", + # on_change=lambda e: noneable_int_change(freqDroop_wrapper, "openLoopTms", e)) \ + # .bind_value_from(freqDroop_wrapper, "openLoopTms") + + ui.input("opModMaxLimW", on_change=lambda e: noneable_int_change(der_base, "opModMaxLimW", e)) \ + .bind_value_from(der_base, "opModMaxLimW") + + with ui.column().classes("pr-10"): + opModTargetVar_wrapper = PropertyWrapper(m.ReactivePower(), der_base, "opModTargetVar") + wrappers.append(opModTargetVar_wrapper) + ui.input("opModTargetVar", on_change=lambda e: noneable_int_change(opModTargetVar_wrapper, "value", e)) \ + .bind_value_from(opModTargetVar_wrapper, "value") + + opModTargetW_wrapper = PropertyWrapper(m.ActivePower(), der_base, "opModTargetW") + wrappers.append(opModTargetW_wrapper) + ui.input("opModTargetW", on_change=lambda e: noneable_int_change(opModTargetW_wrapper, "value", e)) \ + .bind_value_from(opModTargetW_wrapper, "value") + + # opModVoltVar = ui.input("opModVoltVar", + # on_change=lambda e: noneable_int_change(der_base, "opModVoltVar", e)) \ + # .bind_value_from(der_base, "opModVoltVar") + # opModWattPF = ui.input("opModWattPF", + # on_change=lambda e: noneable_int_change(der_base, "opModWattPF", e)) \ + # .bind_value_from(der_base, "opModWattPF") + ui.input("rampTms", on_change=lambda e: noneable_int_change(der_base, "rampTms", e)) \ + .bind_value_from(der_base, "rampTms") + # render_default_control(der_base) + def store_default_der_control(): try: - put_as_admin(program.DefaultDERControlLink.href, dataclass_to_xml(default)) + _log.debug(der_base) + _log.debug(default) + for wrapper in wrappers: + wrapper.apply_to_parent() + base_payload = dataclass_to_xml(der_base) + payload = dataclass_to_xml(default) + put_as_admin(program.DefaultDERControlLink.href, payload) ui.notify("Default DER Control Updated") + render_der_default_control_tab.refresh() except xsdata.exceptions.ParserError as ex: ui.notify(ex.message, type='negative') @@ -345,16 +490,20 @@ def do_refresh(): @ui.refreshable def render_der_control_list_tab(): - control_list: m.DERControlList = get_from_server(program.DERControlListLink.href, deserialize=True) - active_listl: m.DERControlList = get_from_server(program.ActiveDERControlListLink.href, deserialize=True) - curve_list: m.DERCurveList = get_from_server(program.DERCurveListLink.href, deserialize=True) - default: m.DefaultDERControl = get_from_server(program.DefaultDERControlLink.href, deserialize=True) + def do_refresh(): + render_der_control_list_tab.refresh() + ui.notify("Refreshed") + + control_list: m.DERControlList = get_from_server(program.DERControlListLink.href, deserialize=True) + active_list: m.DERControlList = get_from_server(program.ActiveDERControlListLink.href, deserialize=True) with ui.row(): with ui.column(): - ui.label("DER Control List").style("font-size: 200%;") + with ui.label("DER Control List").style("font-size: 200%;"): + ui.button(icon="refresh", color="white", + on_click=lambda: do_refresh()).style("margin:5px; padding: 5px;") ui.label("Section 10.10 Distributed Energy Resources function set from 20305-2018 IEEE standard.") - + columns = [ {'name': 'time', 'label': 'Event Time', 'field': 'time', 'required': True}, {'name': 'duration', 'label': 'Event Duration', 'field': 'duration', 'required': True}, @@ -373,15 +522,24 @@ def status_to_string(status: int): return "Supersceded" else: return "Unknown" - control_list_rows = [] - for ctrl in control_list.DERControl: - if ctrl.interval: - row = { - 'time': ctrl.interval.start, - 'duration': ctrl.interval.duration, - 'status': status_to_string(ctrl.EventStatus.currentStatus) - } - control_list_rows.append(row) + + def build_list_rows(ctrl_list: m.DERControlList, filter_status: int = None): + control_list_rows = [] + for ctrl in control_list.DERControl: + if ctrl.interval: + if ctrl.EventStatus is None and ctrl.interval.start and ctrl.interval.duration: + ctrl.EventStatus = m.EventStatus(currentStatus=0) # Scheduled. + local_dt = datetime_from_utc_to_local(datetime.utcfromtimestamp(ctrl.interval.start)) + + row = { + 'time': ctrl.interval.start, + 'duration': ctrl.interval.duration, + 'status': status_to_string(ctrl.EventStatus.currentStatus) + } + + if filter_status is None or ctrl.EventStatus.currentStatus == filter_status: + control_list_rows.append(row) + return control_list_rows with ui.row(): with ui.column(): @@ -389,7 +547,7 @@ def status_to_string(status: int): with ui.row(): with ui.column(): - ui.table(columns=columns, rows=control_list_rows) + ui.table(columns=columns, rows=build_list_rows(active_list, 1)) with ui.row(): with ui.column(): @@ -397,90 +555,139 @@ def status_to_string(status: int): with ui.row(): with ui.column(): - ui.label("Insert table here!") - + ui.table(columns=columns, rows=build_list_rows(control_list, 0)) + with ui.row(): with ui.column(): ui.label("Completed Controls").style("font-size: 150%") with ui.row(): with ui.column(): - ui.label("Insert table here!") + ui.table(columns=columns, rows=build_list_rows(control_list, 5)) + @ui.refreshable def render_new_der_control_tab(): - + # Need to start with the default control base before overwriting values from the new + # base control. + default: m.DefaultDERControl = get_from_server(program.DefaultDERControlLink.href, deserialize=True) + der_base: m.DERControlBase = default.DERControlBase + wrappers: List[PropertyWrapper] = [] + if der_base is None: + der_base = m.DERControlBase() + default.DERControlBase = der_base + + def do_refresh(): + render_new_der_control_tab.refresh() + ui.notify("Refreshed") + with ui.row(): with ui.column(): - ui.label("DER Control Entry").style("font-size: 200%;") + with ui.label("DER Control Entry").style("font-size: 200%;"): + ui.button(icon="refresh", color="white", + on_click=lambda: do_refresh()).style("margin:5px; padding: 5px;") ui.label("Section 10.10 Distributed Energy Resources function set from 20305-2018 IEEE standard.") with ui.row().classes("pt-5"): with ui.column(): ui.label(f"DERProgram {der.CurrentDERProgramLink.href}").style("font-size: 150%") - new_control = m.DERControl(EventStatus=m.EventStatus()) - der_base = m.DERControlBase() + + new_control = m.DERControl(mRID=uuid_2030_5()) def submit_new_control(): + for wrapper in wrappers: + if not wrapper.should_be_none(): + wrapper.apply_to_parent() + new_control.DERControlBase = der_base - ui.notify("Doing good stuff but not much here!") + #new_ctrl = m.DERControl(mRID="b234245afff", DERControlBase=dderc.DERControlBase, description="A new control is going here") + #new_control.interval = m.DateTimeInterval(start=current_time + 10, duration=20) + _log.debug(dataclass_to_xml(new_control)) + response = post_as_admin(program.DERControlListLink.href, data=dataclass_to_xml(new_control)) + render_der_control_list_tab.refresh() + ui.notify("New Control Complete") + render_new_der_control_tab.refresh() - def combine_datetime(): - print(from_date.value) + def set_date(obj, prop, e): + try: + dt = parse_timestamp_string(e.value) + setattr(obj, prop, e.value) + except ParserError: + _log.debug(f"Invalid datetime specified: {e.value}") + with ui.row(): with ui.column(): - from_date = ui.input("Event Start", value=datetime.now(), - on_change=lambda: combine_datetime()).classes("w-96") - duration = ui.number("Duration", min=0) \ - .bind_value_from(new_control.EventStatus, "duration") - - disable_curves = True - + interval_wrapper = PropertyWrapper(m.DateTimeInterval(duration=60, start=datetime.now() + timedelta(seconds=120)), + new_control, "interval", formatters=dict(start=parse_timestamp_string), + applyers=dict(start=convert_datetime_to_int)) + wrappers.append(interval_wrapper) + from_date = ui.input("Event Start", value=getattr(interval_wrapper, "start"), + on_change=lambda e: set_date(interval_wrapper, "start", e)) \ + .classes("w-96") + duration = ui.number("Duration", min=0, value=getattr(interval_wrapper, "duration")) \ + .bind_value_from(interval_wrapper, "duration") + with ui.row(): with ui.column().classes("pr-10"): - ui.label("DERControlBase") - opModConnect = ui.checkbox("opModConnect") \ - .bind_value(der_base, "opModConnect") - opModEnergize = ui.checkbox("opModEnergize") \ - .bind_value(der_base, "opModEnergize") - opModFixedPFAbsorbW = ui.input("opModFixedPFAbsorbW", - on_change=lambda e: noneable_int_change(der_base, "opModFixedPFAbsorbW", e)) \ - .bind_value_from(der_base, "opModFixedPFAbsorbW") - opModFixedPFInjectW = ui.input("opModFixedPFInjectW", - on_change=lambda e: noneable_int_change(der_base, "opModFixedPFInjectW", e)) \ - .bind_value_from(der_base, "opModFixedPFInjectW") + ui.input("MRID").bind_value(new_control, "mRID").classes("w-96") + + ui.checkbox("opModConnect", value=True).bind_value(der_base, "opModConnect") + ui.checkbox("opModEnergize", value=True).bind_value(der_base, "opModEnergize") + + ui.label("Power Factor Absorb Watts").style("font-size: 125%;") + opModFixedPFAbsorbW_wrapper = PropertyWrapper(m.PowerFactorWithExcitation(), der_base, "opModFixedPFAbsorbW") + wrappers.append(opModFixedPFAbsorbW_wrapper) + ui.input("displacement", on_change=lambda e: noneable_int_change(opModFixedPFAbsorbW_wrapper, "displacement", e)) \ + .bind_value_from(opModFixedPFAbsorbW_wrapper, "displacement") + ui.checkbox("excitation", value=False).bind_value(opModFixedPFAbsorbW_wrapper, "excitation") + + ui.label("Power Factor Inject Watts").style("font-size: 125%;") + opModFixedPFInjectW_wrapper = PropertyWrapper(m.PowerFactorWithExcitation(), der_base, "opModFixedPFInjectW") + wrappers.append(opModFixedPFInjectW_wrapper) + ui.input("displacement", on_change=lambda e: noneable_int_change(opModFixedPFInjectW_wrapper, "displacement", e)) \ + .bind_value_from(opModFixedPFInjectW_wrapper, "displacement") + ui.checkbox("excitation", value=False).bind_value(opModFixedPFInjectW_wrapper, "excitation") + with ui.column().classes("pr-10"): - opModFixedVar = ui.input("opModFixedVar", - on_change=lambda e: noneable_int_change(der_base, "opModFixedVar", e)) \ - .bind_value_from(der_base, "opModFixedVar") - opModFixedW = ui.input("opModFixedW", - on_change=lambda e: noneable_int_change(der_base, "opModFixedW", e)) \ + fixedVar_wrapper = PropertyWrapper(m.FixedVar(), der_base, "opModFixedVar") + wrappers.append(fixedVar_wrapper) + ui.input("opModFixedVar", on_change=lambda e: noneable_int_change(fixedVar_wrapper, "value", e)) \ + .bind_value_from(fixedVar_wrapper, "value") + + # Note this is not using PropertyWrapper because it is defined as an int in the xsd. + ui.input("opModFixedW", on_change=lambda e: noneable_int_change(der_base, "opModFixedW", e)) \ .bind_value_from(der_base, "opModFixedW") - opModFreqDroop = ui.input("opModFreqDroop", - on_change=lambda e: noneable_int_change(der_base, "opModFreqDroop", e)) \ - .bind_value_from(der_base, "opModFreqDroop") - opModMaxLimW = ui.input("opModMaxLimW", - on_change=lambda e: noneable_int_change(der_base, "opModMaxLimW", e)) \ + + # freqDroop_wrapper = Wrapper(m.FreqDroopType(), der_base, "openLoopTms") + # wrappers.append(freqDroop_wrapper) + # opModFreqDroop = ui.input("opModFreqDroop", + # on_change=lambda e: noneable_int_change(freqDroop_wrapper, "openLoopTms", e)) \ + # .bind_value_from(freqDroop_wrapper, "openLoopTms") + + ui.input("opModMaxLimW", on_change=lambda e: noneable_int_change(der_base, "opModMaxLimW", e)) \ .bind_value_from(der_base, "opModMaxLimW") with ui.column().classes("pr-10"): - opModTargetVar = ui.input("opModTargetVar", - on_change=lambda e: noneable_int_change(der_base, "opModTargetVar", e)) \ - .bind_value_from(der_base, "opModTargetVar") - opModTargetW = ui.input("opModTargetW", - on_change=lambda e: noneable_int_change(der_base, "opModTargetW", e)) \ - .bind_value_from(der_base, "opModTargetW") - opModVoltVar = ui.input("opModVoltVar", - on_change=lambda e: noneable_int_change(der_base, "opModVoltVar", e)) \ - .bind_value_from(der_base, "opModVoltVar") - opModWattPF = ui.input("opModWattPF", - on_change=lambda e: noneable_int_change(der_base, "opModWattPF", e)) \ - .bind_value_from(der_base, "opModWattPF") - rampTms: ui.input("rampTms", - on_change=lambda e: noneable_int_change(der_base, "rampTms", e)) \ + opModTargetVar_wrapper = PropertyWrapper(m.ReactivePower(), der_base, "opModTargetVar") + wrappers.append(opModTargetVar_wrapper) + ui.input("opModTargetVar", on_change=lambda e: noneable_int_change(opModTargetVar_wrapper, "value", e)) \ + .bind_value_from(opModTargetVar_wrapper, "value") + + opModTargetW_wrapper = PropertyWrapper(m.ActivePower(), der_base, "opModTargetW") + wrappers.append(opModTargetW_wrapper) + ui.input("opModTargetW", on_change=lambda e: noneable_int_change(opModTargetW_wrapper, "value", e)) \ + .bind_value_from(opModTargetW_wrapper, "value") + + # opModVoltVar = ui.input("opModVoltVar", + # on_change=lambda e: noneable_int_change(der_base, "opModVoltVar", e)) \ + # .bind_value_from(der_base, "opModVoltVar") + # opModWattPF = ui.input("opModWattPF", + # on_change=lambda e: noneable_int_change(der_base, "opModWattPF", e)) \ + # .bind_value_from(der_base, "opModWattPF") + ui.input("rampTms", on_change=lambda e: noneable_int_change(der_base, "rampTms", e)) \ .bind_value_from(der_base, "rampTms") with ui.row().classes("pt-10"): @@ -491,7 +698,10 @@ def combine_datetime(): with ui.row().classes("pt-20"): with ui.column(): ui.button("Sumbit Control", on_click=lambda: submit_new_control()) - +with ui.header(): + current_time_label = ui.label("Current Time") + ui.timer(1.0, lambda: current_time_label.set_text( + f"Local Time: {datetime.now().isoformat()} Epoche: {convert_datetime_to_int(datetime.utcnow())}")) with ui.tabs().classes('w-full') as tabs: configuration_tab = ui.tab("configuration", "Configuration") der_default_control_tab = ui.tab("derdefaultcontrol", "DER Default Control") @@ -522,6 +732,8 @@ def combine_datetime(): with ui.tab_panel(der_control_list_tab): render_der_control_list_tab() + ui.timer(30, lambda: render_der_control_list_tab.refresh()) + # ui.timer(10, lambda: render_der_default_control_tab.refresh()) with ui.tab_panel(der_status_tab): render_der_status_tab() @@ -529,268 +741,5 @@ def combine_datetime(): logging.basicConfig(level=logging.DEBUG) -# ui.timer(10, update_from_server) -#ui.timer(watch_file.interval, watch_for_file) -ui.run(reload=True, show=False, uvicorn_reload_dirs='services/core/IEEE_2030_5/demo') -#ui.run(reload=True, uvicorn_reload_dirs='services/core/IEEE_2030_5/demo') - -# session = requests.Session() -# tlsdir = Path("~/tls").expanduser() -# session.cert = (str(tlsdir.joinpath("certs/admin.pem")), str(tlsdir.joinpath("private/admin.pem"))) -# session.verify = str(tlsdir.joinpath("certs/ca.pem")) - - -# def get_url(endpoint, not_admin: bool = False) -> str: -# if endpoint.startswith('/'): -# endpoint = endpoint[1:] -# if not_admin: -# return f"https://127.0.0.1:8443/{endpoint}" -# return f"https://127.0.0.1:8443/admin/{endpoint}" - - -# filedirectory = Path(__file__).parent -# pkfile = filedirectory.joinpath("keypair.json") -# if not pkfile.exists(): -# print(f"Key file not found in demo directory {pkfile}.") -# sys.exit(0) - -# pk_data = yaml.safe_load(pkfile.open().read()) - -# os.environ['AGENT_PUBLICKEY'] = pk_data['public'] -# os.environ['AGENT_SECRETEKY'] = pk_data['secret'] -# os.environ['AGENT_VIP_IDENTITY'] = "inverter1" -# os.environ['AGENT_CONFIG'] = str(filedirectory.parent.joinpath('example.config.yml')) -# agent_py = str(filedirectory.parent.joinpath("ieee_2030_5/agent.py")) -# py_launch = str(Path(get_volttron_root()).joinpath("scripts/pycharm-launch.py")) - -# tasks = [] - - -# def add_my_task(task): -# tasks.append(task) - - -# control_status = "None" -# derp = "Not Set" -# inverter_pf = "Not Set" -# inverter_p = "Not Set" -# inverter_q = "Not Set" -# in_real = False -# in_reactive = False -# in_control = False - - -# def new_agent_output(line: str): -# global inverter_q, inverter_p, in_real, in_reactive, in_control, control_status - -# if '' in line: -# in_control = True - -# if in_control: -# if "" in line: -# status_value = int(re.search(r'(.*?)', line).group(1)) -# if status_value == -1: -# control_status = "Control Complete" -# elif status_value == 0: -# control_status = "Control Scheduled" -# elif status_value == 1: -# control_status = "Active" -# else: -# control_status = "Not Set" -# in_control = False - -# status.content = updated_markdown() - -# if "url: /mup_1" in line: -# in_reactive = True - -# if in_reactive: -# if line.startswith(""): -# inverter_q = re.search(r'(.*?)', line).group(1) -# in_reactive = False -# status.content = updated_markdown() - -# if "url: /mup_1" in line: -# in_real = True - -# if in_real: -# if line.startswith(""): -# inverter_p = re.search(r'(.*?)', line).group(1) -# in_real = False -# status.content = updated_markdown() - - -# def _change_power_factor(new_pf): -# global inverter_pf - -# current_time = int(time.mktime(datetime.utcnow().timetuple())) - -# ctrl_base = m.DERControlBase(opModConnect=True, opModMaxLimW=9500) -# ctrl = m.DERControl(mRID="ctrl1mrdi", description="A control for the control list") -# ctrl.DERControlBase = ctrl_base -# ctrl.interval = m.DateTimeInterval(start=current_time + 10, duration=20) -# ctrl.randomizeDuration = 180 -# ctrl.randomizeStart = 180 -# ctrl.DERControlBase.opModFixedW = 500 -# ctrl.DERControlBase.opModFixedPFInjectW = m.PowerFactorWithExcitation( -# displacement=int(pf.value)) - -# posted = dataclass_to_xml(ctrl) -# utility_log.push(f"Event Posted to Change opModFixedPFInjectW to {pf.value}") -# utility_log.push(posted) -# resp = session.post(get_url("derp/0/derc"), data=posted) -# resp = session.get(get_url(resp.headers.get('Location'), not_admin=True)) -# pfingect: m.DERControl = xml_to_dataclass(resp.text) -# inverter_pf = pfingect.DERControlBase.opModFixedPFInjectW.displacement -# status.content = updated_markdown() - - -# def get_control_event_default(): -# derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) - -# time_plus_10 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) - -# derc = m.DERControl(mRID=str(uuid.uuid4()), -# description="New DER Control Event", -# DERControlBase=derbase, -# interval=m.DateTimeInterval(duration=10, start=time_plus_10)) - -# return dataclass_to_xml(derc) - - -# def _setup_event(element): -# derbase = m.DERControlBase(opModConnect=True, opModEnergize=False, opModFixedPFInjectW=80) - -# time_plus_60 = int(time.mktime((datetime.utcnow() + timedelta(seconds=60)).timetuple())) - -# derc = m.DERControl(mRID=str(uuid.uuid4()), -# description="New DER Control Event", -# DERControlBase=derbase, -# interval=m.DateTimeInterval(duration=10, start=time_plus_60)) -# element.value = dataclass_to_xml(derc) - -# #background_tasks.running_tasks.clear() - - -# async def _exit_background_tasks(): -# for item in tasks: -# if isinstance(item, Process): -# try: -# item.kill() # .cancel() -# except ProcessLookupError: -# pass -# else: -# item.cancel() -# # async for proc, command in tasks: -# # print(f"Stoping {command.label}") -# # proc.cancel() - -# tasks.clear() -# agent_log.clear() -# inverter_log.clear() -# utility_log.clear() - - -# async def run_command(command: LabeledCommand) -> None: -# '''Run a command in the background and display the output in the pre-created dialog.''' - -# process = await asyncio.create_subprocess_exec(*shlex.split(command.command), -# stdout=asyncio.subprocess.PIPE, -# stderr=asyncio.subprocess.STDOUT, -# cwd=command.working_dir, -# env=dict(os.environ)) - -# add_my_task(process) - -# # NOTE we need to read the output in chunks, otherwise the process will block -# output = '' -# while True: -# new = await process.stdout.readline() -# if not new: -# break -# output = new.decode() -# if command.agent_output: -# new_agent_output(output.strip()) - -# try: -# jsonparsed = json.loads(output) -# if command.output_element is not None: -# command.output_element().push(output.strip()) -# except json.decoder.JSONDecodeError: -# if not command.output_only_json: -# command.output_element().push(output.strip()) - -# # NOTE the content of the markdown element is replaced every time we have new output -# #result.content = f'```\n{output}\n```' - - -# @dataclass -# class LabeledCommand: -# label: str -# command: str -# output_element: Any -# working_dir: str = str(Path(__file__).parent) -# output_only_json: bool = True -# agent_output: bool = False - - -# commands = [ -# LabeledCommand("Start Inverter", f'{sys.executable} inverter_runner.py', lambda: inverter_log), -# LabeledCommand("Start Agent", -# f"{sys.executable} {py_launch} {agent_py}", -# lambda: agent_log, -# filedirectory.parent, -# output_only_json=False, -# agent_output=True) -# ] - - -# def updated_markdown() -> str: -# return f"""#### Status -# Control: {control_status} -# Real Power (p): {inverter_p} -# Reactive Power (q): {inverter_q} -# Power Factor (pf): {inverter_pf} -# """ - - -# with ui.column(): -# # commands = [f'{sys.executable} inverter_runner.py'] -# with ui.row(): - -# for command in commands: -# ui.button(command.label, -# on_click=lambda _, c=command: add_my_task( -# background_tasks.create(run_command(c)))).props('no-caps') - -# pf = ui.select(options=[70, 80, 90], value=70, label="Power Factor").classes('w-32') -# ui.button("Change Power Factor", -# on_click=lambda: _change_power_factor(pf.value)).props('no-caps') -# ui.button("Reset", on_click=_exit_background_tasks).props('no-caps') - -# with ui.row(): -# status = ui.markdown(updated_markdown()) -# #ui.button("Update Control Time", on_click=lambda: _setup_event(xml_text)).props('no-caps') -# #ui.button("Send Control", on_click=lambda: _send_control_event()).props('no-caps') -# # with ui.row(): -# # xml_text = ui.textarea(label="xml", value=get_control_event_default()).props('rows=20').props('cols=120').classes('w-full, h-80') -# with ui.row(): -# ui.label("Inverter Log") -# inverter_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') -# # with ui.row(): -# # ui.label("Proxy Log") -# # proxy_log = ui.log().props('cols=120').classes('w-full h-80') -# with ui.row(): -# ui.label("Agent Log") -# agent_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-80') - -# with ui.row(): -# ui.label("Utility Log") -# utility_log = ui.log(max_lines=2000).props('cols=120').classes('w-full h-20') - -# #atexit.register(_exit_background_tasks) -# app.on_shutdown(_exit_background_tasks) - -# # NOTE on windows reload must be disabled to make asyncio.create_subprocess_exec work -# # (see https://github.com/zauberzeug/nicegui/issues/486) -# ui.run(reload=platform.system() != "Windows", ) +excludes = '.*, .py[cod], .sw.*, ~*,*.git,' +ui.run(reload=True, show=False, uvicorn_reload_excludes=excludes) From 7c5cbea2901c578e2ba6336e881172ccba37fd0f Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Thu, 12 Oct 2023 22:48:12 -0700 Subject: [PATCH 44/53] Update models and client --- .../core/IEEE_2030_5/ieee_2030_5/agent.py | 22 +- .../core/IEEE_2030_5/ieee_2030_5/client.py | 18 +- .../IEEE_2030_5/ieee_2030_5/models/Config.py | 313 + .../ieee_2030_5/models/__init__.py | 237 +- .../IEEE_2030_5/ieee_2030_5/models/sep.py | 7760 +++++++---------- 5 files changed, 3545 insertions(+), 4805 deletions(-) create mode 100644 services/core/IEEE_2030_5/ieee_2030_5/models/Config.py diff --git a/services/core/IEEE_2030_5/ieee_2030_5/agent.py b/services/core/IEEE_2030_5/ieee_2030_5/agent.py index fd62d1ed59..7cede973c7 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/agent.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/agent.py @@ -159,7 +159,8 @@ def __init__(self, config_path: str, **kwargs): self._default_config = { "subscriptions": self._subscriptions, "MirrorUsagePointList": self._mirror_usage_point_list, - "point_map": config.get("point_map") + "point_map": config.get("point_map"), + "default_der_control_poll": int(config.get('default_der_control_poll', 60)) } self._server_usage_points: m.UsagePointList @@ -171,12 +172,13 @@ def __init__(self, config_path: str, **kwargs): pin=self._pin, log_req_resp=self._log_req_resp) - # Hook up events so we can respond to them appropriately + # Hook events up to the client so that we can send the correct information on to + # the platform driver. self._client.der_control_event_started(self._control_event_started) self._client.der_control_event_ended(self._control_event_ended) - self._client.der_active_controls_changed(self._active_controls_changed) self._client.der_default_control_changed(self._default_control_changed) + # These objects are constructed from the platform driver's publishes self._last_settings = m.DERSettings() self._last_capabilities = m.DERCapability() self._last_status = m.DERStatus() @@ -187,7 +189,7 @@ def __init__(self, config_path: str, **kwargs): self._current_control: m.DERControl = None try: - self._client.start() + self._client.start(config=self._default_config) except ConnectionRefusedError: _log.error(f"Could not connect to server {self._server_hostname} agent exiting.") sys.exit(1) @@ -201,8 +203,6 @@ def __init__(self, config_path: str, **kwargs): self._mup_pollRate: int = 60 self._times_published: Dict[str, int] = {} - - # Set a default configuration to ensure that self.configure is called immediately to setup # the agent. self.vip.config.set_default("config", self._default_config) @@ -277,12 +277,13 @@ def _default_control_changed(self, default_control: m.DefaultDERControl): _log.error(f"Error setting point {point.point_on_bus} to {point_value}") - def _control_event_started(self, sender): + def _control_event_started(self, sender: m.DERControl): _log.debug(f"{'='*50}Control event started\n{sender}") if not isinstance(sender, m.DERControl): _log.error("Invalid control event passed to event_started") raise ValueError(f"Invalid type passed to event_started {type(sender)} instead of {type(m.DERControl)}") + self._current_control = sender der_control: m.DERControl = sender # We override some of the base controls with the event controls @@ -307,9 +308,6 @@ def _control_event_started(self, sender): try: if point_value: - # if not isinstance(point_value, (float, int, bool)): - # point_value = getattr(point_value, "value") - # These are the point types that have a multiplyer assigned to them. if isinstance(point_value, (m.VoltageRMS, m.ApparentPower, m.PowerFactor, m.CurrentRMS, m.ActivePower, m.WattHour, m.ReactivePower, m.FixedPointType)): @@ -322,6 +320,8 @@ def _control_event_started(self, sender): elif isinstance(point_value, m.DERCurveLink): ... + elif isinstance(point_value, bool): + point_value = 1 if point_value else 0 if point_value: _log.debug(f"Setting point: {point.point_on_bus} to {point_value}") @@ -331,7 +331,7 @@ def _control_event_started(self, sender): - def _control_event_ended(self, sender): + def _control_event_ended(self, sender: m.DERControl): _log.debug(f"{'='*50}Control event ended\n{sender}") self._current_control = None diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index 6b7712f906..57d47acad2 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -179,23 +179,21 @@ def __init__(self, self._der_control_event_ended_signal = Signal('der-control-event-ended') self._default_control_changed = Signal("default-control-changed") - self._active_controls_changed_signal = Signal("active-controls-changed") - - self._before_event_start_signal = Signal('before-event-start') - self._after_event_end_signal = Signal('after-event-end') - + self._dcap_endpoint = device_capabilities_endpoint self._der_default_control: m.DefaultDERControl = m.DefaultDERControl() self._der_active_controls: m.DERControlList = m.DERControlList() + self._config: Dict[str, Any] = {} self._lock = Semaphore() IEEE_2030_5_Client.clients.add(self) - def start(self): + def start(self, config: Dict[str, Any]): """Starts the client connection to the 2030.5 server configured during construction. """ + self._config = config self._before_client_start_signal.send(self) self._update_dcap_tree() self._after_client_start_signal.send(self) @@ -212,9 +210,6 @@ def _tick(self, timestamp: int): ts.trigger(timestamp) self._lock.release() - def der_active_controls_changed(self, fun: Callable): - self._active_controls_changed_signal.connect(fun) - def der_default_control_changed(self, fun: Callable): self._default_control_changed.connect(fun) @@ -329,8 +324,9 @@ def _send_control_events(self, der_program_href: str): _log.debug("Default control changed....") self._default_control_changed.send(default) - # TODO un hard code 30 second server update. - self._update_timer_spec("der_control_event", 5, fn=lambda: self._send_control_events(der_program_href)) + # Poll every 60 if default otherwise use setting in config file. + refresh_time = self._config.get("default_der_control_poll", 60) + self._update_timer_spec("der_control_event", refresh_time, fn=lambda: self._send_control_events(der_program_href)) def _update_dcap_tree(self, endpoint: Optional[str] = None): """Retrieve device capability diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/Config.py b/services/core/IEEE_2030_5/ieee_2030_5/models/Config.py new file mode 100644 index 0000000000..7e7f36ec93 --- /dev/null +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/Config.py @@ -0,0 +1,313 @@ +from __future__ import annotations +from dataclasses import dataclass, field +from typing import List, Optional + +__NAMESPACE__ = "http://pypi.org/project/xsdata" + + +@dataclass +class TypeName: + + class Meta: + name = "ClassName" + namespace = "http://pypi.org/project/xsdata" + + case: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + safePrefix: Optional[str] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + + +@dataclass +class CompoundFields: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + defaultName: Optional[str] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + forceDefaultName: Optional[bool] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + value: Optional[bool] = field(default=None, metadata={ + "required": True, + }) + + +@dataclass +class ConstantName: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + case: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + safePrefix: Optional[str] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + + +@dataclass +class FieldName: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + case: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + safePrefix: Optional[str] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + + +@dataclass +class Format: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + repr: Optional[bool] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + eq: Optional[bool] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + order: Optional[bool] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + unsafeHash: Optional[bool] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + frozen: Optional[bool] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + slots: Optional[bool] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + kwOnly: Optional[bool] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + value: str = field(default="", metadata={ + "required": True, + }) + + +@dataclass +class ModuleName: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + case: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + safePrefix: Optional[str] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + + +@dataclass +class PackageName: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + case: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + safePrefix: Optional[str] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + + +@dataclass +class Substitution: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + type_value: Optional[str] = field(default=None, + metadata={ + "name": "type", + "type": "Attribute", + "required": True, + }) + search: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + replace: Optional[str] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + + +@dataclass +class Conventions: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + ClassName: Optional[TypeName] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + FieldName: Optional[FieldName] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + ConstantName: Optional[ConstantName] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + ModuleName: Optional[ModuleName] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + PackageName: Optional[PackageName] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + + +@dataclass +class Output: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + maxLineLength: Optional[int] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + Package: Optional[str] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + Format: Optional[Format] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + Structure: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + DocstringStyle: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + FilterStrategy: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + RelativeImports: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + CompoundFields: Optional[CompoundFields] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + PostponedAnnotations: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + UnnestClasses: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + IgnorePatterns: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + + +@dataclass +class Substitutions: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + Substitution: List[Substitution] = field(default_factory=list, + metadata={ + "type": "Element", + "min_occurs": 1, + }) + + +@dataclass +class Config: + + class Meta: + namespace = "http://pypi.org/project/xsdata" + + version: Optional[float] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) + Output: Optional[Output] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + Conventions: Optional[Conventions] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + Substitutions: Optional[Substitutions] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py b/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py index f650c386a8..7ba95466fc 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/__init__.py @@ -1,165 +1,84 @@ from ieee_2030_5.models.enums import CurveType, DeviceCategoryType, PrimacyType -from ieee_2030_5.models.sep import (DER, IEEE_802_15_4, AbstractDevice, - AccountBalance, AccountBalanceLink, - AccountingUnit, - ActiveBillingPeriodListLink, - ActiveCreditRegisterListLink, - ActiveDERControlListLink, - ActiveEndDeviceControlListLink, - ActiveFlowReservationListLink, ActivePower, - ActiveProjectionReadingListLink, - ActiveSupplyInterruptionOverrideListLink, - ActiveTargetReadingListLink, - ActiveTextMessageListLink, - ActiveTimeTariffIntervalListLink, - AmpereHour, ApparentPower, - ApplianceLoadReduction, - AppliedTargetReduction, - AssociatedDERProgramListLink, - AssociatedUsagePointLink, - BillingMeterReadingBase, BillingPeriod, - BillingPeriodList, BillingPeriodListLink, - BillingReading, BillingReadingList, - BillingReadingListLink, BillingReadingSet, - BillingReadingSetList, - BillingReadingSetListLink, Charge, - Condition, Configuration, - ConfigurationLink, ConnectStatusType, - ConsumptionTariffInterval, - ConsumptionTariffIntervalList, - ConsumptionTariffIntervalListLink, - CreditRegister, CreditRegisterList, - CreditRegisterListLink, CreditTypeChange, - CurrentDERProgramLink, CurrentRMS, - CurveData, CustomerAccount, - CustomerAccountLink, CustomerAccountList, - CustomerAccountListLink, CustomerAgreement, - CustomerAgreementList, - CustomerAgreementListLink, - DateTimeInterval, DefaultDERControl, - DefaultDERControlLink, - DemandResponseProgram, - DemandResponseProgramLink, - DemandResponseProgramList, - DemandResponseProgramListLink, - DERAvailability, DERAvailabilityLink, - DERCapability, DERCapabilityLink, - DERControl, DERControlBase, DERControlList, - DERControlListLink, DERControlResponse, - DERCurve, DERCurveLink, DERCurveList, - DERCurveListLink, DERLink, DERList, - DERListLink, DERProgram, DERProgramLink, - DERProgramList, DERProgramListLink, - DERSettings, DERSettingsLink, DERStatus, - DERStatusLink, DeviceCapability, - DeviceCapabilityLink, DeviceInformation, - DeviceInformationLink, DeviceStatus, - DeviceStatusLink, DRLCCapabilities, - DrResponse, DutyCycle, EndDevice, - EndDeviceControl, EndDeviceControlList, - EndDeviceControlListLink, EndDeviceLink, - EndDeviceList, EndDeviceListLink, - EnvironmentalCost, Error, Event, - EventStatus, File, FileLink, FileList, - FileListLink, FileStatus, FileStatusLink, - FixedPointType, FixedVar, - FlowReservationRequest, - FlowReservationRequestList, - FlowReservationRequestListLink, - FlowReservationResponse, - FlowReservationResponseList, - FlowReservationResponseListLink, - FlowReservationResponseResponse, - FreqDroopType, FunctionSetAssignments, - FunctionSetAssignmentsBase, - FunctionSetAssignmentsList, - FunctionSetAssignmentsListLink, - GPSLocationType, HistoricalReading, - HistoricalReadingList, - HistoricalReadingListLink, - IdentifiedObject, InverterStatusType, - IPAddr, IPAddrList, IPAddrListLink, - IPInterface, IPInterfaceList, - IPInterfaceListLink, Link, List_type, - ListLink, LLInterface, LLInterfaceList, - LLInterfaceListLink, LoadShedAvailability, - LoadShedAvailabilityList, - LoadShedAvailabilityListLink, - LocalControlModeStatusType, LogEvent, - LogEventList, LogEventListLink, - ManufacturerStatusType, MessagingProgram, - MessagingProgramList, - MessagingProgramListLink, MeterReading, - MeterReadingBase, MeterReadingLink, - MeterReadingList, MeterReadingListLink, - MirrorMeterReading, MirrorMeterReadingList, - MirrorReadingSet, MirrorUsagePoint, - MirrorUsagePointList, - MirrorUsagePointListLink, Neighbor, - NeighborList, NeighborListLink, - Notification, NotificationList, - NotificationListLink, Offset, - OperationalModeStatusType, PEVInfo, - PowerConfiguration, PowerFactor, - PowerFactorWithExcitation, PowerStatus, - PowerStatusLink, Prepayment, - PrepaymentLink, PrepaymentList, - PrepaymentListLink, PrepayOperationStatus, - PrepayOperationStatusLink, PriceResponse, - PriceResponseCfg, PriceResponseCfgList, - PriceResponseCfgListLink, - ProjectionReading, ProjectionReadingList, - ProjectionReadingListLink, - RandomizableEvent, RateComponent, - RateComponentLink, RateComponentList, - RateComponentListLink, ReactivePower, - ReactiveSusceptance, Reading, ReadingBase, - ReadingLink, ReadingList, ReadingListLink, - ReadingSet, ReadingSetBase, ReadingSetList, - ReadingSetListLink, ReadingType, - ReadingTypeLink, RealEnergy, Registration, - RegistrationLink, RequestStatus, Resource, - RespondableIdentifiedObject, - RespondableResource, - RespondableSubscribableIdentifiedObject, - Response, ResponseList, ResponseListLink, - ResponseSet, ResponseSetList, - ResponseSetListLink, RPLInstance, - RPLInstanceList, RPLInstanceListLink, - RPLSourceRoutes, RPLSourceRoutesList, - RPLSourceRoutesListLink, SelfDevice, - SelfDeviceLink, ServiceChange, - ServiceSupplier, ServiceSupplierLink, - ServiceSupplierList, SetPoint, - SignedRealEnergy, StateOfChargeStatusType, - StorageModeStatusType, - SubscribableIdentifiedObject, - SubscribableList, SubscribableResource, - Subscription, SubscriptionBase, - SubscriptionList, SubscriptionListLink, - SupplyInterruptionOverride, - SupplyInterruptionOverrideList, - SupplyInterruptionOverrideListLink, - SupportedLocale, SupportedLocaleList, - SupportedLocaleListLink, TargetReading, - TargetReadingList, TargetReadingListLink, - TargetReduction, TariffProfile, - TariffProfileLink, TariffProfileList, - TariffProfileListLink, Temperature, - TextMessage, TextMessageList, - TextMessageListLink, TextResponse, Time, - TimeConfiguration, TimeLink, - TimeTariffInterval, TimeTariffIntervalList, - TimeTariffIntervalListLink, UnitValueType, - UnsignedFixedPointType, UsagePoint, - UsagePointBase, UsagePointLink, - UsagePointList, UsagePointListLink, - VoltageRMS, WattHour, loWPAN) +from ieee_2030_5.models.Config import ( + TypeName, + CompoundFields, + Config, + ConstantName, + Conventions, + FieldName, + Format, + ModuleName, + Output, + PackageName, + Substitution, + Substitutions, +) +from ieee_2030_5.models.enums import CurveType, DeviceCategoryType, PrimacyType +from ieee_2030_5.models.sep import ( + DER, IEEE_802_15_4, AbstractDevice, AccountBalance, AccountBalanceLink, AccountingUnit, + ActiveBillingPeriodListLink, ActiveCreditRegisterListLink, ActiveDERControlListLink, + ActiveEndDeviceControlListLink, ActiveFlowReservationListLink, ActivePower, + ActiveProjectionReadingListLink, ActiveSupplyInterruptionOverrideListLink, + ActiveTargetReadingListLink, ActiveTextMessageListLink, ActiveTimeTariffIntervalListLink, + AmpereHour, ApparentPower, ApplianceLoadReduction, AppliedTargetReduction, + AssociatedDERProgramListLink, AssociatedUsagePointLink, BillingMeterReadingBase, BillingPeriod, + BillingPeriodList, BillingPeriodListLink, BillingReading, BillingReadingList, + BillingReadingListLink, BillingReadingSet, BillingReadingSetList, BillingReadingSetListLink, + Charge, Condition, Configuration, ConfigurationLink, ConnectStatusType, + ConsumptionTariffInterval, ConsumptionTariffIntervalList, ConsumptionTariffIntervalListLink, + CreditRegister, CreditRegisterList, CreditRegisterListLink, CreditTypeChange, + CurrentDERProgramLink, CurrentRMS, CurveData, CustomerAccount, CustomerAccountLink, + CustomerAccountList, CustomerAccountListLink, CustomerAgreement, CustomerAgreementList, + CustomerAgreementListLink, DateTimeInterval, DefaultDERControl, DefaultDERControlLink, + DemandResponseProgram, DemandResponseProgramLink, DemandResponseProgramList, + DemandResponseProgramListLink, DERAvailability, DERAvailabilityLink, DERCapability, + DERCapabilityLink, DERControl, DERControlBase, DERControlList, DERControlListLink, + DERControlResponse, DERCurve, DERCurveLink, DERCurveList, DERCurveListLink, DERLink, DERList, + DERListLink, DERProgram, DERProgramLink, DERProgramList, DERProgramListLink, DERSettings, + DERSettingsLink, DERStatus, DERStatusLink, DeviceCapability, DeviceCapabilityLink, + DeviceInformation, DeviceInformationLink, DeviceStatus, DeviceStatusLink, DRLCCapabilities, + DrResponse, DutyCycle, EndDevice, EndDeviceControl, EndDeviceControlList, + EndDeviceControlListLink, EndDeviceLink, EndDeviceList, EndDeviceListLink, EnvironmentalCost, + Error, Event, EventStatus, File, FileLink, FileList, FileListLink, FileStatus, FileStatusLink, + FixedPointType, FixedVar, FlowReservationRequest, FlowReservationRequestList, + FlowReservationRequestListLink, FlowReservationResponse, FlowReservationResponseList, + FlowReservationResponseListLink, FlowReservationResponseResponse, FreqDroopType, + FunctionSetAssignments, FunctionSetAssignmentsBase, FunctionSetAssignmentsList, + FunctionSetAssignmentsListLink, GPSLocationType, HistoricalReading, HistoricalReadingList, + HistoricalReadingListLink, IdentifiedObject, InverterStatusType, IPAddr, IPAddrList, + IPAddrListLink, IPInterface, IPInterfaceList, IPInterfaceListLink, Link, List_type, ListLink, + LLInterface, LLInterfaceList, LLInterfaceListLink, LoadShedAvailability, + LoadShedAvailabilityList, LoadShedAvailabilityListLink, LocalControlModeStatusType, LogEvent, + LogEventList, LogEventListLink, ManufacturerStatusType, MessagingProgram, MessagingProgramList, + MessagingProgramListLink, MeterReading, MeterReadingBase, MeterReadingLink, MeterReadingList, + MeterReadingListLink, MirrorMeterReading, MirrorMeterReadingList, MirrorReadingSet, + MirrorUsagePoint, MirrorUsagePointList, MirrorUsagePointListLink, Neighbor, NeighborList, + NeighborListLink, Notification, NotificationList, NotificationListLink, Offset, + OperationalModeStatusType, PEVInfo, PowerConfiguration, PowerFactor, PowerFactorWithExcitation, + PowerStatus, PowerStatusLink, Prepayment, PrepaymentLink, PrepaymentList, PrepaymentListLink, + PrepayOperationStatus, PrepayOperationStatusLink, PriceResponse, PriceResponseCfg, + PriceResponseCfgList, PriceResponseCfgListLink, ProjectionReading, ProjectionReadingList, + ProjectionReadingListLink, RandomizableEvent, RateComponent, RateComponentLink, + RateComponentList, RateComponentListLink, ReactivePower, ReactiveSusceptance, Reading, + ReadingBase, ReadingLink, ReadingList, ReadingListLink, ReadingSet, ReadingSetBase, + ReadingSetList, ReadingSetListLink, ReadingType, ReadingTypeLink, RealEnergy, Registration, + RegistrationLink, RequestStatus, Resource, RespondableIdentifiedObject, RespondableResource, + RespondableSubscribableIdentifiedObject, Response, ResponseList, ResponseListLink, ResponseSet, + ResponseSetList, ResponseSetListLink, RPLInstance, RPLInstanceList, RPLInstanceListLink, + RPLSourceRoutes, RPLSourceRoutesList, RPLSourceRoutesListLink, SelfDevice, SelfDeviceLink, + ServiceChange, ServiceSupplier, ServiceSupplierLink, ServiceSupplierList, SetPoint, + SignedRealEnergy, StateOfChargeStatusType, StorageModeStatusType, SubscribableIdentifiedObject, + SubscribableList, SubscribableResource, Subscription, SubscriptionBase, SubscriptionList, + SubscriptionListLink, SupplyInterruptionOverride, SupplyInterruptionOverrideList, + SupplyInterruptionOverrideListLink, SupportedLocale, SupportedLocaleList, + SupportedLocaleListLink, TargetReading, TargetReadingList, TargetReadingListLink, + TargetReduction, TariffProfile, TariffProfileLink, TariffProfileList, TariffProfileListLink, + Temperature, TextMessage, TextMessageList, TextMessageListLink, TextResponse, Time, + TimeConfiguration, TimeLink, TimeTariffInterval, TimeTariffIntervalList, + TimeTariffIntervalListLink, UnitValueType, UnsignedFixedPointType, UsagePoint, UsagePointBase, + UsagePointLink, UsagePointList, UsagePointListLink, VoltageRMS, WattHour, loWPAN) __all__ = [ - "DERFlexibility", - "DERForecast", - "DERForecastLink", "ForecastNumericType", "ForecastParameter", "ForecastParameterSet", diff --git a/services/core/IEEE_2030_5/ieee_2030_5/models/sep.py b/services/core/IEEE_2030_5/ieee_2030_5/models/sep.py index 68fe7fc6da..b125f4a89e 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/models/sep.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/models/sep.py @@ -17,23 +17,19 @@ class ActivePower: :ivar multiplier: Specifies exponent for uom. :ivar value: Value in watts (uom 38) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -44,23 +40,19 @@ class AmpereHour: :ivar multiplier: Specifies exponent of uom. :ivar value: Value in ampere-hours (uom 106) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -72,23 +64,19 @@ class ApparentPower: :ivar multiplier: Specifies exponent of uom. :ivar value: Value in volt-amperes (uom 61) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -102,16 +90,14 @@ class ApplianceLoadReduction: :ivar type: Indicates the type of appliance load reduction requested. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - type: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + type: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -124,23 +110,18 @@ class AppliedTargetReduction: :ivar value: Indicates the requested amount of the relevant commodity to be reduced. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - type: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + type: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -161,29 +142,22 @@ class Charge: :ivar kind: The type (kind) of charge. :ivar value: A monetary charge. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - description: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 20, - } - ) - kind: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + description: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 20, + }) + kind: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -196,34 +170,29 @@ class Condition: :ivar lowerThreshold: The value of the lower threshold :ivar upperThreshold: The value of the upper threshold """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - attributeIdentifier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - lowerThreshold: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "min_inclusive": -140737488355328, - "max_inclusive": 140737488355328, - } - ) - upperThreshold: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "min_inclusive": -140737488355328, - "max_inclusive": 140737488355328, - } - ) + attributeIdentifier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + lowerThreshold: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + }) + upperThreshold: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + }) @dataclass @@ -240,25 +209,21 @@ class ConnectStatusType: :ivar dateTime: The date and time at which the state applied. :ivar value: The value indicating the state. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 1, - "format": "base16", - } - ) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 1, + "format": "base16", + }) @dataclass @@ -270,23 +235,19 @@ class CreditTypeChange: specified by startTime :ivar startTime: The date/time when the change is to take effect. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - newType: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - startTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + newType: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + startTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -297,23 +258,19 @@ class CurrentRMS: :ivar multiplier: Specifies exponent of value. :ivar value: Value in amperes RMS (uom 5) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -336,29 +293,21 @@ class CurveData: value. If yvalue is not Power Factor, the excitation field SHALL NOT be present. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - excitation: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - } - ) - xvalue: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - yvalue: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + excitation: Optional[bool] = field(default=None, metadata={ + "type": "Element", + }) + xvalue: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + yvalue: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -369,23 +318,18 @@ class DateTimeInterval: :ivar duration: Duration of the interval, in seconds. :ivar start: Date and time of the start of the interval. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - duration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - start: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + duration: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + start: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -407,16 +351,15 @@ class DutyCycle: present indicates that this field has not been used by the end device. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - normalValue: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + normalValue: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -462,37 +405,28 @@ class EnvironmentalCost: values from different service providres or from the same service provider. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - amount: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - costKind: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - costLevel: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - numCostLevels: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + amount: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + costKind: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + costLevel: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + numCostLevels: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -509,22 +443,18 @@ class Error: subscription field not supported 4 - Maximum request frequency exceeded All other values reserved """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - maxRetryDuration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - reasonCode: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + maxRetryDuration: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + reasonCode: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -595,43 +525,31 @@ class EventStatus: :ivar reason: The Reason attribute allows a Service provider to provide a textual explanation of the status. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - currentStatus: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - potentiallySuperseded: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - potentiallySupersededTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - reason: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 192, - } - ) + currentStatus: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + potentiallySuperseded: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + potentiallySupersededTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + reason: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 192, + }) @dataclass @@ -643,23 +561,19 @@ class FixedPointType: :ivar multiplier: Specifies exponent of uom. :ivar value: Dimensionless value """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -672,23 +586,18 @@ class FixedVar: :ivar value: Specify a signed setpoint for reactive power in % (see 'refType' for context). """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - refType: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + refType: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -712,44 +621,31 @@ class FreqDroopType: second. Resolution is 1/100 sec. A value of 0 is used to mean no limit. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dBOF: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - dBUF: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - kOF: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - kUF: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - openLoopTms: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + dBOF: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + dBUF: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + kOF: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + kUF: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + openLoopTms: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -762,25 +658,22 @@ class GPSLocationType: :ivar lon: Specifies the longitude from Greenwich Meridian. -180 (west) to +180 (east) in decimal degrees. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - lat: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) - lon: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) + lat: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) + lon: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) @dataclass @@ -803,23 +696,18 @@ class InverterStatusType: :ivar dateTime: The date and time at which the state applied. :ivar value: The value indicating the state. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -829,16 +717,14 @@ class Link: :ivar href: A URI reference. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - href: Optional[str] = field( - default=None, - metadata={ - "type": "Attribute", - "required": True, - } - ) + href: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) @dataclass @@ -850,23 +736,18 @@ class LocalControlModeStatusType: :ivar dateTime: The date and time at which the state applied. :ivar value: The value indicating the state. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -877,24 +758,20 @@ class ManufacturerStatusType: :ivar dateTime: The date and time at which the state applied. :ivar value: The value indicating the state. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 6, - } - ) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 6, + }) @dataclass @@ -930,27 +807,20 @@ class Offset: from the normal setting, or if loadShiftForward is true, then the value should be added to the normal setting. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - coolingOffset: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - heatingOffset: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - loadAdjustmentPercentageOffset: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + coolingOffset: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + heatingOffset: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + loadAdjustmentPercentageOffset: Optional[int] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -966,23 +836,18 @@ class OperationalModeStatusType: :ivar dateTime: The date and time at which the state applied. :ivar value: The value indicating the state. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -996,21 +861,16 @@ class PowerConfiguration: BatteryStatus "low" is indicated and the PS_LOW_BATTERY is raised. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - batteryInstallTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - lowChargeThreshold: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + batteryInstallTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + lowChargeThreshold: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -1024,23 +884,20 @@ class PowerFactor: displacement of 950 and a multiplier of -3. :ivar multiplier: Specifies exponent of 'displacement'. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - displacement: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + displacement: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1058,30 +915,25 @@ class PowerFactorWithExcitation: excited). :ivar multiplier: Specifies exponent of 'displacement'. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - displacement: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - excitation: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + displacement: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + excitation: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1094,23 +946,19 @@ class ReactivePower: :ivar multiplier: Specifies exponent of uom. :ivar value: Value in volt-amperes reactive (var) (uom 63) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1121,23 +969,19 @@ class ReactiveSusceptance: :ivar multiplier: Specifies exponent of uom. :ivar value: Value in siemens (uom 53) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1148,24 +992,21 @@ class RealEnergy: :ivar multiplier: Multiplier for 'unit'. :ivar value: Value of the energy in Watt-hours. (uom 72) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_inclusive": 281474976710655, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_inclusive": 281474976710655, + }) @dataclass @@ -1181,23 +1022,19 @@ class RequestStatus: :ivar requestStatus: Field representing the request status type. 0 = Requested 1 = Cancelled All other values reserved. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - requestStatus: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + requestStatus: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1209,15 +1046,13 @@ class Resource: :ivar href: A reference to the resource address (URI). Required in a response to a GET, ignored otherwise. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - href: Optional[str] = field( - default=None, - metadata={ - "type": "Attribute", - } - ) + href: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + }) @dataclass @@ -1229,23 +1064,20 @@ class ServiceChange: specified by startTime :ivar startTime: The date/time when the change is to take effect. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - newStatus: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - startTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + newStatus: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + startTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1265,21 +1097,16 @@ class SetPoint: temperature set point in degrees Celsius / 100. (Hundredths of a degree C) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - coolingSetpoint: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - heatingSetpoint: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + coolingSetpoint: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + heatingSetpoint: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -1290,25 +1117,22 @@ class SignedRealEnergy: :ivar multiplier: Multiplier for 'unit'. :ivar value: Value of the energy in Watt-hours. (uom 72) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "min_inclusive": -140737488355328, - "max_inclusive": 140737488355328, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + }) @dataclass @@ -1319,23 +1143,18 @@ class StateOfChargeStatusType: :ivar dateTime: The date and time at which the state applied. :ivar value: The value indicating the state. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1348,23 +1167,18 @@ class StorageModeStatusType: :ivar dateTime: The date and time at which the state applied. :ivar value: The value indicating the state. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + dateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1382,23 +1196,18 @@ class TargetReduction: :ivar value: Indicates the requested amount of the relevant commodity to be reduced. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - type: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + type: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1411,30 +1220,23 @@ class Temperature: Enclosure 1 - Transformer 2 - HeatSink :ivar value: Value in Degrees Celsius (uom 23). """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - subject: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + subject: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1453,41 +1255,33 @@ class TimeConfiguration: :ivar tzOffset: Local time zone offset from UTCTime. Does not include any daylight savings time offsets. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dstEndRule: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 4, - "format": "base16", - } - ) - dstOffset: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - dstStartRule: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 4, - "format": "base16", - } - ) - tzOffset: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + dstEndRule: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + }) + dstOffset: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + dstStartRule: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + }) + tzOffset: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1500,30 +1294,23 @@ class UnitValueType: :ivar unit: Unit in symbol :ivar value: Value in units specified """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - unit: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + unit: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1535,23 +1322,19 @@ class UnsignedFixedPointType: :ivar multiplier: Specifies exponent of uom. :ivar value: Dimensionless value """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1562,23 +1345,19 @@ class VoltageRMS: :ivar multiplier: Specifies exponent of uom. :ivar value: Value in volts RMS (uom 29) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1589,23 +1368,19 @@ class WattHour: :ivar multiplier: Specifies exponent of uom. :ivar value: Value in watt-hours (uom 72) """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1619,42 +1394,31 @@ class loWPAN: :ivar packetsTx: Number of packets transmitted :ivar rxFragError: Number of errors receiving fragments """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - octetsRx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - octetsTx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - packetsRx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - packetsTx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - rxFragError: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + octetsRx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + octetsTx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + packetsRx: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + packetsTx: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + rxFragError: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1662,6 +1426,7 @@ class AccountBalanceLink(Link): """ SHALL contain a Link to an instance of AccountBalance. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -1677,36 +1442,27 @@ class AccountingUnit: :ivar multiplier: Multiplier for the 'energyUnit' or 'monetaryUnit'. :ivar value: Value of the monetary aspect """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - energyUnit: Optional[RealEnergy] = field( - default=None, - metadata={ - "type": "Element", - } - ) - monetaryUnit: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - multiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + energyUnit: Optional[RealEnergy] = field(default=None, metadata={ + "type": "Element", + }) + monetaryUnit: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + multiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + value: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -1715,6 +1471,7 @@ class AssociatedUsagePointLink(Link): If present, this is the submeter that monitors the DER output. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -1738,38 +1495,30 @@ class BillingPeriod(Resource): :ivar statusTimeStamp: The date / time of the last update of this resource. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - billLastPeriod: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "min_inclusive": -140737488355328, - "max_inclusive": 140737488355328, - } - ) - billToDate: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "min_inclusive": -140737488355328, - "max_inclusive": 140737488355328, - } - ) - interval: Optional[DateTimeInterval] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - statusTimeStamp: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + billLastPeriod: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + }) + billToDate: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + }) + interval: Optional[DateTimeInterval] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + statusTimeStamp: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -1777,6 +1526,7 @@ class ConfigurationLink(Link): """ SHALL contain a Link to an instance of Configuration. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -1812,36 +1562,28 @@ class ConsumptionTariffInterval(Resource): ConsumptionTariffInterval.startValue elements SHALL be greater than the previous one. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - consumptionBlock: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - EnvironmentalCost: List[EnvironmentalCost] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - price: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - startValue: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_inclusive": 281474976710655, - } - ) + consumptionBlock: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + EnvironmentalCost: List[EnvironmentalCost] = field(default_factory=list, + metadata={ + "type": "Element", + }) + price: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + startValue: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_inclusive": 281474976710655, + }) @dataclass @@ -1851,6 +1593,7 @@ class CurrentDERProgramLink(Link): If present, this is the DERProgram containing the currently active DERControl. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -1860,6 +1603,7 @@ class CustomerAccountLink(Link): """ SHALL contain a Link to an instance of CustomerAccount. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -1869,6 +1613,7 @@ class DERAvailabilityLink(Link): """ SHALL contain a Link to an instance of DERAvailability. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -1937,164 +1682,98 @@ class DERCapability(Resource): :ivar rtgVNom: AC voltage nominal rating. :ivar type: Type of DER; see DERType object """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - modesSupported: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 4, - "format": "base16", - } - ) - rtgAbnormalCategory: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxA: Optional[CurrentRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxAh: Optional[AmpereHour] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxChargeRateVA: Optional[ApparentPower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxChargeRateW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxDischargeRateVA: Optional[ApparentPower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxDischargeRateW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxV: Optional[VoltageRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxVA: Optional[ApparentPower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxVar: Optional[ReactivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxVarNeg: Optional[ReactivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMaxW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - rtgMaxWh: Optional[WattHour] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMinPFOverExcited: Optional[PowerFactor] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMinPFUnderExcited: Optional[PowerFactor] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgMinV: Optional[VoltageRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgNormalCategory: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgOverExcitedPF: Optional[PowerFactor] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgOverExcitedW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgReactiveSusceptance: Optional[ReactiveSusceptance] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgUnderExcitedPF: Optional[PowerFactor] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgUnderExcitedW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rtgVNom: Optional[VoltageRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - type: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + modesSupported: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + }) + rtgAbnormalCategory: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + rtgMaxA: Optional[CurrentRMS] = field(default=None, metadata={ + "type": "Element", + }) + rtgMaxAh: Optional[AmpereHour] = field(default=None, metadata={ + "type": "Element", + }) + rtgMaxChargeRateVA: Optional[ApparentPower] = field(default=None, + metadata={ + "type": "Element", + }) + rtgMaxChargeRateW: Optional[ActivePower] = field(default=None, metadata={ + "type": "Element", + }) + rtgMaxDischargeRateVA: Optional[ApparentPower] = field(default=None, + metadata={ + "type": "Element", + }) + rtgMaxDischargeRateW: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + }) + rtgMaxV: Optional[VoltageRMS] = field(default=None, metadata={ + "type": "Element", + }) + rtgMaxVA: Optional[ApparentPower] = field(default=None, metadata={ + "type": "Element", + }) + rtgMaxVar: Optional[ReactivePower] = field(default=None, metadata={ + "type": "Element", + }) + rtgMaxVarNeg: Optional[ReactivePower] = field(default=None, metadata={ + "type": "Element", + }) + rtgMaxW: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + rtgMaxWh: Optional[WattHour] = field(default=None, metadata={ + "type": "Element", + }) + rtgMinPFOverExcited: Optional[PowerFactor] = field(default=None, + metadata={ + "type": "Element", + }) + rtgMinPFUnderExcited: Optional[PowerFactor] = field(default=None, + metadata={ + "type": "Element", + }) + rtgMinV: Optional[VoltageRMS] = field(default=None, metadata={ + "type": "Element", + }) + rtgNormalCategory: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + rtgOverExcitedPF: Optional[PowerFactor] = field(default=None, metadata={ + "type": "Element", + }) + rtgOverExcitedW: Optional[ActivePower] = field(default=None, metadata={ + "type": "Element", + }) + rtgReactiveSusceptance: Optional[ReactiveSusceptance] = field(default=None, + metadata={ + "type": "Element", + }) + rtgUnderExcitedPF: Optional[PowerFactor] = field(default=None, metadata={ + "type": "Element", + }) + rtgUnderExcitedW: Optional[ActivePower] = field(default=None, metadata={ + "type": "Element", + }) + rtgVNom: Optional[VoltageRMS] = field(default=None, metadata={ + "type": "Element", + }) + type: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -2102,6 +1781,7 @@ class DERCapabilityLink(Link): """ SHALL contain a Link to an instance of DERCapability. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2111,6 +1791,7 @@ class DERCurveLink(Link): """ SHALL contain a Link to an instance of DERCurve. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2120,6 +1801,7 @@ class DERLink(Link): """ SHALL contain a Link to an instance of DER. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2129,6 +1811,7 @@ class DERProgramLink(Link): """ SHALL contain a Link to an instance of DERProgram. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2138,6 +1821,7 @@ class DERSettingsLink(Link): """ SHALL contain a Link to an instance of DERSettings. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2147,6 +1831,7 @@ class DERStatusLink(Link): """ SHALL contain a Link to an instance of DERStatus. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2175,32 +1860,27 @@ class DRLCCapabilities: 17 - Temperature offset 18 - Duty cycle 19 - Load adjustment percentage 20 - Appliance load reduction 21-31 - Reserved """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - averageEnergy: Optional[RealEnergy] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - maxDemand: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - optionsImplemented: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 4, - "format": "base16", - } - ) + averageEnergy: Optional[RealEnergy] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + maxDemand: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + optionsImplemented: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + }) @dataclass @@ -2210,6 +1890,7 @@ class DefaultDERControlLink(Link): This is the default mode of the DER which MAY be overridden by DERControl events. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2219,6 +1900,7 @@ class DemandResponseProgramLink(Link): """ SHALL contain a Link to an instance of DemandResponseProgram. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2228,6 +1910,7 @@ class DeviceCapabilityLink(Link): """ SHALL contain a Link to an instance of DeviceCapability. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2237,6 +1920,7 @@ class DeviceInformationLink(Link): """ SHALL contain a Link to an instance of DeviceInformation. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2246,6 +1930,7 @@ class DeviceStatusLink(Link): """ SHALL contain a Link to an instance of DeviceStatus. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2255,6 +1940,7 @@ class EndDeviceLink(Link): """ SHALL contain a Link to an instance of EndDevice. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2302,83 +1988,58 @@ class File(Resource): Credential 02 = Configuration 03 = Log 04–7FFF = reserved 8000-FFFF = Manufacturer defined """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - activateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - fileURI: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - lFDI: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 20, - "format": "base16", - } - ) - mfHwVer: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - mfID: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - mfModel: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) - mfSerNum: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - mfVer: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - } - ) - size: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - type: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 2, - "format": "base16", - } - ) + activateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + fileURI: Optional[str] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + lFDI: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 20, + "format": "base16", + }) + mfHwVer: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 32, + }) + mfID: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + mfModel: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) + mfSerNum: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 32, + }) + mfVer: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + }) + size: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + type: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 2, + "format": "base16", + }) @dataclass @@ -2388,6 +2049,7 @@ class FileLink(Link): In the case of file status 0, this element MUST be omitted. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2397,6 +2059,7 @@ class FileStatusLink(Link): """ SHALL contain a Link to an instance of FileStatus. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2413,31 +2076,25 @@ class IdentifiedObject(Resource): :ivar version: Contains the version number of the object. See the type definition for details. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - mRID: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) - description: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - version: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + mRID: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) + description: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 32, + }) + version: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -2451,24 +2108,20 @@ class List_type(Resource): :ivar results: Indicates the number of items in this page of results. """ + class Meta: name = "List" namespace = "urn:ieee:std:2030.5:ns" - all: Optional[int] = field( - default=None, - metadata={ - "type": "Attribute", - "required": True, - } - ) - results: Optional[int] = field( - default=None, - metadata={ - "type": "Attribute", - "required": True, - } - ) + all: Optional[int] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + results: Optional[int] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) @dataclass @@ -2482,15 +2135,13 @@ class ListLink(Link): is a remote or absolute URI, as the server may be unaware of changes to the value. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - all: Optional[int] = field( - default=None, - metadata={ - "type": "Attribute", - } - ) + all: Optional[int] = field(default=None, metadata={ + "type": "Attribute", + }) @dataclass @@ -2537,64 +2188,47 @@ class LogEvent(Resource): Home Automation 4 Building Automation All other values are reserved. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - createdDateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - details: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - extendedData: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - functionSet: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - logEventCode: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - logEventID: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - logEventPEN: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - profileID: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + createdDateTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + details: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 32, + }) + extendedData: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + functionSet: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + logEventCode: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + logEventID: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + logEventPEN: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + profileID: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -2602,6 +2236,7 @@ class MeterReadingLink(Link): """ SHALL contain a Link to an instance of MeterReading. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2615,30 +2250,24 @@ class Neighbor(Resource): :ivar linkQuality: The quality of the link, as defined by 802.15.4 :ivar shortAddress: As defined by IEEE 802.15.4 """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - isChild: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - linkQuality: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - shortAddress: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + isChild: Optional[bool] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + linkQuality: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + shortAddress: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -2684,58 +2313,45 @@ class PEVInfo: :ivar timeChargingStatusPEV: This is the time that the parameters are updated, except for changes to TCIN. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - chargingPowerNow: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - energyRequestNow: Optional[RealEnergy] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - maxForwardPower: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - minimumChargingDuration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - targetStateOfCharge: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - timeChargeIsNeeded: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - timeChargingStatusPEV: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + chargingPowerNow: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + energyRequestNow: Optional[RealEnergy] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + maxForwardPower: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + minimumChargingDuration: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + targetStateOfCharge: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + timeChargeIsNeeded: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + timeChargingStatusPEV: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -2743,6 +2359,7 @@ class PowerStatusLink(Link): """ SHALL contain a Link to an instance of PowerStatus. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2766,34 +2383,25 @@ class PrepayOperationStatus(Resource): connected or disconnected, or armed for connection or disconnection. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - creditTypeChange: Optional[CreditTypeChange] = field( - default=None, - metadata={ - "type": "Element", - } - ) - creditTypeInUse: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - serviceChange: Optional[ServiceChange] = field( - default=None, - metadata={ - "type": "Element", - } - ) - serviceStatus: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + creditTypeChange: Optional[CreditTypeChange] = field(default=None, + metadata={ + "type": "Element", + }) + creditTypeInUse: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + serviceChange: Optional[ServiceChange] = field(default=None, metadata={ + "type": "Element", + }) + serviceStatus: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -2801,6 +2409,7 @@ class PrepayOperationStatusLink(Link): """ SHALL contain a Link to an instance of PrepayOperationStatus. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2810,6 +2419,7 @@ class PrepaymentLink(Link): """ SHALL contain a Link to an instance of Prepayment. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2822,27 +2432,24 @@ class RPLSourceRoutes(Resource): :ivar DestAddress: See [RFC 6554]. :ivar SourceRoute: See [RFC 6554]. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DestAddress: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) - SourceRoute: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) + DestAddress: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) + SourceRoute: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) @dataclass @@ -2850,6 +2457,7 @@ class RateComponentLink(Link): """ SHALL contain a Link to an instance of RateComponent. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -2886,43 +2494,31 @@ class ReadingBase(Resource): If not specified, is assumed to be "0 - N/A". :ivar value: Value in units specified by ReadingType """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - consumptionBlock: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - qualityFlags: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 2, - "format": "base16", - } - ) - timePeriod: Optional[DateTimeInterval] = field( - default=None, - metadata={ - "type": "Element", - } - ) - touTier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - value: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "min_inclusive": -140737488355328, - "max_inclusive": 140737488355328, - } - ) + consumptionBlock: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + qualityFlags: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 2, + "format": "base16", + }) + timePeriod: Optional[DateTimeInterval] = field(default=None, metadata={ + "type": "Element", + }) + touTier: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + value: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "min_inclusive": -140737488355328, + "max_inclusive": 140737488355328, + }) @dataclass @@ -2930,6 +2526,7 @@ class ReadingLink(Link): """ A Link to a Reading. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3001,112 +2598,63 @@ class ReadingType(Resource): :ivar uom: Indicates the measurement type for the units of measure for the readings of this type. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - accumulationBehaviour: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - calorificValue: Optional[UnitValueType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - commodity: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - conversionFactor: Optional[UnitValueType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - dataQualifier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - flowDirection: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - intervalLength: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - kind: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - maxNumberOfIntervals: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - numberOfConsumptionBlocks: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - numberOfTouTiers: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - phase: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - powerOfTenMultiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - subIntervalLength: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - supplyLimit: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "max_inclusive": 281474976710655, - } - ) - tieredConsumptionBlocks: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - } - ) - uom: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + accumulationBehaviour: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + calorificValue: Optional[UnitValueType] = field(default=None, metadata={ + "type": "Element", + }) + commodity: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + conversionFactor: Optional[UnitValueType] = field(default=None, metadata={ + "type": "Element", + }) + dataQualifier: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + flowDirection: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + intervalLength: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + kind: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + maxNumberOfIntervals: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + numberOfConsumptionBlocks: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + numberOfTouTiers: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + phase: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + powerOfTenMultiplier: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + subIntervalLength: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + supplyLimit: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "max_inclusive": 281474976710655, + }) + tieredConsumptionBlocks: Optional[bool] = field(default=None, metadata={ + "type": "Element", + }) + uom: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -3114,6 +2662,7 @@ class ReadingTypeLink(Link): """ SHALL contain a Link to an instance of ReadingType. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3135,29 +2684,22 @@ class Registration(Resource): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - dateTimeRegistered: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - pIN: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + dateTimeRegistered: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + pIN: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -3165,6 +2707,7 @@ class RegistrationLink(Link): """ SHALL contain a Link to an instance of Registration. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3193,23 +2736,19 @@ class RespondableResource(Resource): response. 2 - End user / customer response is required. All other values reserved. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - replyTo: Optional[str] = field( - default=None, - metadata={ - "type": "Attribute", - } - ) - responseRequired: bytes = field( - default=b"\x00", - metadata={ - "type": "Attribute", - "max_length": 1, - "format": "base16", - } - ) + replyTo: Optional[str] = field(default=None, metadata={ + "type": "Attribute", + }) + responseRequired: bytes = field(default=b"\x00", + metadata={ + "type": "Attribute", + "max_length": 1, + "format": "base16", + }) @dataclass @@ -3241,39 +2780,30 @@ class Response(Resource): response with the originating event. It is populated with the mRID of the original object. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - createdDateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - endDeviceLFDI: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 20, - "format": "base16", - } - ) - status: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - subject: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) + createdDateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + endDeviceLFDI: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 20, + "format": "base16", + }) + status: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + subject: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) @dataclass @@ -3281,6 +2811,7 @@ class SelfDeviceLink(Link): """ SHALL contain a Link to an instance of SelfDevice. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3290,6 +2821,7 @@ class ServiceSupplierLink(Link): """ SHALL contain a Link to an instance of ServiceSupplier. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3304,15 +2836,13 @@ class SubscribableResource(Resource): (thresholds) are supported. If not specified, is "not subscribable" (0). """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - subscribable: int = field( - default=0, - metadata={ - "type": "Attribute", - } - ) + subscribable: int = field(default=0, metadata={ + "type": "Attribute", + }) @dataclass @@ -3329,16 +2859,15 @@ class SubscriptionBase(Resource): subscribing to list resources. Should a query string parameter be specified, servers SHALL ignore them. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - subscribedResource: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + subscribedResource: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -3350,23 +2879,20 @@ class SupplyInterruptionOverride(Resource): :ivar interval: Interval defines the period of time during which supply should not be interrupted. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - description: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - interval: Optional[DateTimeInterval] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + description: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 32, + }) + interval: Optional[DateTimeInterval] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -3376,17 +2902,16 @@ class SupportedLocale(Resource): :ivar locale: The code for a locale that is supported """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - locale: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 42, - } - ) + locale: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 42, + }) @dataclass @@ -3394,6 +2919,7 @@ class TariffProfileLink(Link): """ SHALL contain a Link to an instance of TariffProfile. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3433,63 +2959,44 @@ class Time(Resource): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - currentTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - dstEndTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - dstOffset: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - dstStartTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - localTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - quality: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - tzOffset: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + currentTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + dstEndTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + dstOffset: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + dstStartTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + localTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + quality: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + tzOffset: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -3497,6 +3004,7 @@ class TimeLink(Link): """ SHALL contain a Link to an instance of Time. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3506,6 +3014,7 @@ class UsagePointLink(Link): """ SHALL contain a Link to an instance of UsagePoint. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3537,34 +3046,24 @@ class AccountBalance(Resource): whether the present value of emergencyCredit is considered OK, low, exhausted, or negative. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - availableCredit: Optional[AccountingUnit] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - creditStatus: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - emergencyCredit: Optional[AccountingUnit] = field( - default=None, - metadata={ - "type": "Element", - } - ) - emergencyCreditStatus: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + availableCredit: Optional[AccountingUnit] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + creditStatus: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + emergencyCredit: Optional[AccountingUnit] = field(default=None, metadata={ + "type": "Element", + }) + emergencyCreditStatus: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -3572,6 +3071,7 @@ class ActiveBillingPeriodListLink(ListLink): """ SHALL contain a Link to a List of active BillingPeriod instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3581,6 +3081,7 @@ class ActiveCreditRegisterListLink(ListLink): """ SHALL contain a Link to a List of active CreditRegister instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3590,6 +3091,7 @@ class ActiveDERControlListLink(ListLink): """ SHALL contain a Link to a List of active DERControl instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3599,6 +3101,7 @@ class ActiveEndDeviceControlListLink(ListLink): """ SHALL contain a Link to a List of active EndDeviceControl instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3608,6 +3111,7 @@ class ActiveFlowReservationListLink(ListLink): """ SHALL contain a Link to a List of active FlowReservation instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3617,6 +3121,7 @@ class ActiveProjectionReadingListLink(ListLink): """ SHALL contain a Link to a List of active ProjectionReading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3627,6 +3132,7 @@ class ActiveSupplyInterruptionOverrideListLink(ListLink): SHALL contain a Link to a List of active SupplyInterruptionOverride instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3636,6 +3142,7 @@ class ActiveTargetReadingListLink(ListLink): """ SHALL contain a Link to a List of active TargetReading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3645,6 +3152,7 @@ class ActiveTextMessageListLink(ListLink): """ SHALL contain a Link to a List of active TextMessage instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3654,6 +3162,7 @@ class ActiveTimeTariffIntervalListLink(ListLink): """ SHALL contain a Link to a List of active TimeTariffInterval instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3664,6 +3173,7 @@ class AssociatedDERProgramListLink(ListLink): SHALL contain a Link to a List of DERPrograms having the DERControl(s) for this DER. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3673,6 +3183,7 @@ class BillingPeriodListLink(ListLink): """ SHALL contain a Link to a List of BillingPeriod instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3688,15 +3199,13 @@ class BillingReading(ReadingBase): min, 30 min, or 60 min. However, consumption aggregations can also be represented with this class. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Charge: List[Charge] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + Charge: List[Charge] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -3704,6 +3213,7 @@ class BillingReadingListLink(ListLink): """ SHALL contain a Link to a List of BillingReading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3713,6 +3223,7 @@ class BillingReadingSetListLink(ListLink): """ SHALL contain a Link to a List of BillingReadingSet instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3722,15 +3233,14 @@ class ConsumptionTariffIntervalList(List_type): """ A List element to hold ConsumptionTariffInterval objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ConsumptionTariffInterval: List[ConsumptionTariffInterval] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + ConsumptionTariffInterval: List[ConsumptionTariffInterval] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -3738,6 +3248,7 @@ class ConsumptionTariffIntervalListLink(ListLink): """ SHALL contain a Link to a List of ConsumptionTariffInterval instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3768,37 +3279,29 @@ class CreditRegister(IdentifiedObject): field is left as vendor specific implementation or will be defined by one or more other standards. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - creditAmount: Optional[AccountingUnit] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - creditType: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - effectiveTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - token: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) + creditAmount: Optional[AccountingUnit] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + creditType: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + effectiveTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + token: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) @dataclass @@ -3806,6 +3309,7 @@ class CreditRegisterListLink(ListLink): """ SHALL contain a Link to a List of CreditRegister instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3815,6 +3319,7 @@ class CustomerAccountListLink(ListLink): """ SHALL contain a Link to a List of CustomerAccount instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3824,6 +3329,7 @@ class CustomerAgreementListLink(ListLink): """ SHALL contain a Link to a List of CustomerAgreement instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -3848,52 +3354,33 @@ class DERAvailability(SubscribableResource): Represents the lesser of received or delivered reactive power. :ivar statWAvail: Estimated reserve active power, in watts. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - availabilityDuration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - maxChargeDuration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - readingTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - reserveChargePercent: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - reservePercent: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - statVarAvail: Optional[ReactivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - statWAvail: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) + availabilityDuration: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + maxChargeDuration: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + readingTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + reserveChargePercent: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + reservePercent: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + statVarAvail: Optional[ReactivePower] = field(default=None, metadata={ + "type": "Element", + }) + statWAvail: Optional[ActivePower] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -4110,165 +3597,92 @@ class DERControlBase: setting(s) to the new mode setting(s). If absent, use default ramp rate (setGradW). Resolution is 1/100 sec. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - opModConnect: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModEnergize: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModFixedPFAbsorbW: Optional[PowerFactorWithExcitation] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModFixedPFInjectW: Optional[PowerFactorWithExcitation] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModFixedVar: Optional[FixedVar] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModFixedW: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModFreqDroop: Optional[FreqDroopType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModFreqWatt: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModHFRTMayTrip: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModHFRTMustTrip: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModHVRTMayTrip: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModHVRTMomentaryCessation: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModHVRTMustTrip: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModLFRTMayTrip: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModLFRTMustTrip: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModLVRTMayTrip: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModLVRTMomentaryCessation: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModLVRTMustTrip: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModMaxLimW: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModTargetVar: Optional[ReactivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModTargetW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModVoltVar: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModVoltWatt: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModWattPF: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opModWattVar: Optional[DERCurveLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rampTms: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + opModConnect: Optional[bool] = field(default=None, metadata={ + "type": "Element", + }) + opModEnergize: Optional[bool] = field(default=None, metadata={ + "type": "Element", + }) + opModFixedPFAbsorbW: Optional[PowerFactorWithExcitation] = field(default=None, + metadata={ + "type": "Element", + }) + opModFixedPFInjectW: Optional[PowerFactorWithExcitation] = field(default=None, + metadata={ + "type": "Element", + }) + opModFixedVar: Optional[FixedVar] = field(default=None, metadata={ + "type": "Element", + }) + opModFixedW: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + opModFreqDroop: Optional[FreqDroopType] = field(default=None, metadata={ + "type": "Element", + }) + opModFreqWatt: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModHFRTMayTrip: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModHFRTMustTrip: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModHVRTMayTrip: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModHVRTMomentaryCessation: Optional[DERCurveLink] = field(default=None, + metadata={ + "type": "Element", + }) + opModHVRTMustTrip: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModLFRTMayTrip: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModLFRTMustTrip: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModLVRTMayTrip: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModLVRTMomentaryCessation: Optional[DERCurveLink] = field(default=None, + metadata={ + "type": "Element", + }) + opModLVRTMustTrip: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModMaxLimW: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + opModTargetVar: Optional[ReactivePower] = field(default=None, metadata={ + "type": "Element", + }) + opModTargetW: Optional[ActivePower] = field(default=None, metadata={ + "type": "Element", + }) + opModVoltVar: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModVoltWatt: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModWattPF: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + opModWattVar: Optional[DERCurveLink] = field(default=None, metadata={ + "type": "Element", + }) + rampTms: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -4276,6 +3690,7 @@ class DERControlListLink(ListLink): """ SHALL contain a Link to a List of DERControl instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -4285,6 +3700,7 @@ class DERControlResponse(Response): """ A response to a DERControl. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -4340,94 +3756,61 @@ class DERCurve(IdentifiedObject): :ivar yMultiplier: Exponent for Y-axis value. :ivar yRefType: The Y-axis units context. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - autonomousVRefEnable: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - } - ) - autonomousVRefTimeConstant: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - creationTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - CurveData: List[CurveData] = field( - default_factory=list, - metadata={ - "type": "Element", - "min_occurs": 1, - "max_occurs": 10, - } - ) - curveType: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - openLoopTms: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rampDecTms: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rampIncTms: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - rampPT1Tms: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - vRef: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - xMultiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - yMultiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - yRefType: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + autonomousVRefEnable: Optional[bool] = field(default=None, metadata={ + "type": "Element", + }) + autonomousVRefTimeConstant: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + creationTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + CurveData: List[CurveData] = field(default_factory=list, + metadata={ + "type": "Element", + "min_occurs": 1, + "max_occurs": 10, + }) + curveType: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + openLoopTms: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + rampDecTms: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + rampIncTms: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + rampPT1Tms: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + vRef: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + xMultiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + yMultiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + yRefType: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -4435,6 +3818,7 @@ class DERCurveListLink(ListLink): """ SHALL contain a Link to a List of DERCurve instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -4444,6 +3828,7 @@ class DERListLink(ListLink): """ SHALL contain a Link to a List of DER instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -4453,6 +3838,7 @@ class DERProgramListLink(ListLink): """ SHALL contain a Link to a List of DERProgram instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -4542,188 +3928,110 @@ class DERSettings(SubscribableResource): :ivar updatedTime: Specifies the time at which the DER information was last updated. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - modesEnabled: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 4, - "format": "base16", - } - ) - setESDelay: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESHighFreq: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESHighVolt: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESLowFreq: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESLowVolt: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESRampTms: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESRandomDelay: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setGradW: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - setMaxA: Optional[CurrentRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxAh: Optional[AmpereHour] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxChargeRateVA: Optional[ApparentPower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxChargeRateW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxDischargeRateVA: Optional[ApparentPower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxDischargeRateW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxV: Optional[VoltageRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxVA: Optional[ApparentPower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxVar: Optional[ReactivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxVarNeg: Optional[ReactivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMaxW: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - setMaxWh: Optional[WattHour] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMinPFOverExcited: Optional[PowerFactor] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMinPFUnderExcited: Optional[PowerFactor] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setMinV: Optional[VoltageRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setSoftGradW: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setVNom: Optional[VoltageRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setVRef: Optional[VoltageRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setVRefOfs: Optional[VoltageRMS] = field( - default=None, - metadata={ - "type": "Element", - } - ) - updatedTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + modesEnabled: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 4, + "format": "base16", + }) + setESDelay: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESHighFreq: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESHighVolt: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESLowFreq: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESLowVolt: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESRampTms: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESRandomDelay: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setGradW: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + setMaxA: Optional[CurrentRMS] = field(default=None, metadata={ + "type": "Element", + }) + setMaxAh: Optional[AmpereHour] = field(default=None, metadata={ + "type": "Element", + }) + setMaxChargeRateVA: Optional[ApparentPower] = field(default=None, + metadata={ + "type": "Element", + }) + setMaxChargeRateW: Optional[ActivePower] = field(default=None, metadata={ + "type": "Element", + }) + setMaxDischargeRateVA: Optional[ApparentPower] = field(default=None, + metadata={ + "type": "Element", + }) + setMaxDischargeRateW: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + }) + setMaxV: Optional[VoltageRMS] = field(default=None, metadata={ + "type": "Element", + }) + setMaxVA: Optional[ApparentPower] = field(default=None, metadata={ + "type": "Element", + }) + setMaxVar: Optional[ReactivePower] = field(default=None, metadata={ + "type": "Element", + }) + setMaxVarNeg: Optional[ReactivePower] = field(default=None, metadata={ + "type": "Element", + }) + setMaxW: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + setMaxWh: Optional[WattHour] = field(default=None, metadata={ + "type": "Element", + }) + setMinPFOverExcited: Optional[PowerFactor] = field(default=None, + metadata={ + "type": "Element", + }) + setMinPFUnderExcited: Optional[PowerFactor] = field(default=None, + metadata={ + "type": "Element", + }) + setMinV: Optional[VoltageRMS] = field(default=None, metadata={ + "type": "Element", + }) + setSoftGradW: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setVNom: Optional[VoltageRMS] = field(default=None, metadata={ + "type": "Element", + }) + setVRef: Optional[VoltageRMS] = field(default=None, metadata={ + "type": "Element", + }) + setVRefOfs: Optional[VoltageRMS] = field(default=None, metadata={ + "type": "Element", + }) + updatedTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -4757,72 +4065,53 @@ class DERStatus(SubscribableResource): :ivar storConnectStatus: Connect/status value for storage DER. See ConnectStatusType for values. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - alarmStatus: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 4, - "format": "base16", - } - ) - genConnectStatus: Optional[ConnectStatusType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - inverterStatus: Optional[InverterStatusType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - localControlModeStatus: Optional[LocalControlModeStatusType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - manufacturerStatus: Optional[ManufacturerStatusType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - operationalModeStatus: Optional[OperationalModeStatusType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - readingTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - stateOfChargeStatus: Optional[StateOfChargeStatusType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - storageModeStatus: Optional[StorageModeStatusType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - storConnectStatus: Optional[ConnectStatusType] = field( - default=None, - metadata={ - "type": "Element", - } - ) + alarmStatus: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 4, + "format": "base16", + }) + genConnectStatus: Optional[ConnectStatusType] = field(default=None, + metadata={ + "type": "Element", + }) + inverterStatus: Optional[InverterStatusType] = field(default=None, + metadata={ + "type": "Element", + }) + localControlModeStatus: Optional[LocalControlModeStatusType] = field(default=None, + metadata={ + "type": "Element", + }) + manufacturerStatus: Optional[ManufacturerStatusType] = field(default=None, + metadata={ + "type": "Element", + }) + operationalModeStatus: Optional[OperationalModeStatusType] = field(default=None, + metadata={ + "type": "Element", + }) + readingTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + stateOfChargeStatus: Optional[StateOfChargeStatusType] = field(default=None, + metadata={ + "type": "Element", + }) + storageModeStatus: Optional[StorageModeStatusType] = field(default=None, + metadata={ + "type": "Element", + }) + storConnectStatus: Optional[ConnectStatusType] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -4830,6 +4119,7 @@ class DemandResponseProgramListLink(ListLink): """ SHALL contain a Link to a List of DemandResponseProgram instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -4859,52 +4149,33 @@ class DeviceStatus(Resource): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - changedTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - onCount: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opState: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - opTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - Temperature: List[Temperature] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - TimeLink: Optional[TimeLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + changedTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + onCount: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + opState: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + opTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + Temperature: List[Temperature] = field(default_factory=list, metadata={ + "type": "Element", + }) + TimeLink: Optional[TimeLink] = field(default=None, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -4927,45 +4198,30 @@ class DrResponse(Response): EndDeviceControl.overrideDuration. :ivar SetPoint: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ApplianceLoadReduction: Optional[ApplianceLoadReduction] = field( - default=None, - metadata={ - "type": "Element", - } - ) - AppliedTargetReduction: Optional[AppliedTargetReduction] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DutyCycle: Optional[DutyCycle] = field( - default=None, - metadata={ - "type": "Element", - } - ) - Offset: Optional[Offset] = field( - default=None, - metadata={ - "type": "Element", - } - ) - overrideDuration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - SetPoint: Optional[SetPoint] = field( - default=None, - metadata={ - "type": "Element", - } - ) + ApplianceLoadReduction: Optional[ApplianceLoadReduction] = field(default=None, + metadata={ + "type": "Element", + }) + AppliedTargetReduction: Optional[AppliedTargetReduction] = field(default=None, + metadata={ + "type": "Element", + }) + DutyCycle: Optional[DutyCycle] = field(default=None, metadata={ + "type": "Element", + }) + Offset: Optional[Offset] = field(default=None, metadata={ + "type": "Element", + }) + overrideDuration: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + SetPoint: Optional[SetPoint] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -4973,6 +4229,7 @@ class EndDeviceControlListLink(ListLink): """ SHALL contain a Link to a List of EndDeviceControl instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -4982,6 +4239,7 @@ class EndDeviceListLink(ListLink): """ SHALL contain a Link to a List of EndDevice instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -4998,21 +4256,16 @@ class FileList(List_type): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - File: List[File] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + File: List[File] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -5020,6 +4273,7 @@ class FileListLink(ListLink): """ SHALL contain a Link to a List of File instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5071,69 +4325,48 @@ class FileStatus(Resource): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - activateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - FileLink: Optional[FileLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - loadPercent: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - nextRequestAttempt: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - request503Count: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - requestFailCount: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - status: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - statusTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + activateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + FileLink: Optional[FileLink] = field(default=None, metadata={ + "type": "Element", + }) + loadPercent: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + nextRequestAttempt: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + request503Count: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + requestFailCount: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + status: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + statusTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -5174,50 +4407,38 @@ class FlowReservationRequest(IdentifiedObject): target. :ivar RequestStatus: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - creationTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - durationRequested: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - energyRequested: Optional[SignedRealEnergy] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - intervalRequested: Optional[DateTimeInterval] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - powerRequested: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - RequestStatus: Optional[RequestStatus] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + creationTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + durationRequested: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + energyRequested: Optional[SignedRealEnergy] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + intervalRequested: Optional[DateTimeInterval] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + powerRequested: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + RequestStatus: Optional[RequestStatus] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -5225,6 +4446,7 @@ class FlowReservationRequestListLink(ListLink): """ SHALL contain a Link to a List of FlowReservationRequest instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5234,6 +4456,7 @@ class FlowReservationResponseListLink(ListLink): """ SHALL contain a Link to a List of FlowReservationResponse instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5243,6 +4466,7 @@ class FlowReservationResponseResponse(Response): """ A response to a FlowReservationResponse. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5252,6 +4476,7 @@ class FunctionSetAssignmentsListLink(ListLink): """ SHALL contain a Link to a List of FunctionSetAssignments instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5261,6 +4486,7 @@ class HistoricalReadingListLink(ListLink): """ SHALL contain a Link to a List of HistoricalReading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5270,6 +4496,7 @@ class IPAddrListLink(ListLink): """ SHALL contain a Link to a List of IPAddr instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5279,6 +4506,7 @@ class IPInterfaceListLink(ListLink): """ SHALL contain a Link to a List of IPInterface instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5288,6 +4516,7 @@ class LLInterfaceListLink(ListLink): """ SHALL contain a Link to a List of LLInterface instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5306,33 +4535,23 @@ class LoadShedAvailability(Resource): :ivar sheddablePower: Maximum amount of current operating load that is estimated to be sheddable, in Watts. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - availabilityDuration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DemandResponseProgramLink: Optional[DemandResponseProgramLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - sheddablePercent: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - sheddablePower: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) + availabilityDuration: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + DemandResponseProgramLink: Optional[DemandResponseProgramLink] = field(default=None, + metadata={ + "type": "Element", + }) + sheddablePercent: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + sheddablePower: Optional[ActivePower] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -5340,6 +4559,7 @@ class LoadShedAvailabilityListLink(ListLink): """ SHALL contain a Link to a List of LoadShedAvailability instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5349,6 +4569,7 @@ class LogEventListLink(ListLink): """ SHALL contain a Link to a List of LogEvent instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5358,6 +4579,7 @@ class MessagingProgramListLink(ListLink): """ SHALL contain a Link to a List of MessagingProgram instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5367,6 +4589,7 @@ class MeterReadingBase(IdentifiedObject): """ A container for associating ReadingType, Readings and ReadingSets. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5376,6 +4599,7 @@ class MeterReadingListLink(ListLink): """ SHALL contain a Link to a List of MeterReading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5385,6 +4609,7 @@ class MirrorUsagePointListLink(ListLink): """ SHALL contain a Link to a List of MirrorUsagePoint instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5394,15 +4619,13 @@ class NeighborList(List_type): """ List of 15.4 neighbors. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Neighbor: List[Neighbor] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + Neighbor: List[Neighbor] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -5410,6 +4633,7 @@ class NeighborListLink(ListLink): """ SHALL contain a Link to a List of Neighbor instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5436,35 +4660,25 @@ class Notification(SubscriptionBase): was triggered. This attribute SHALL be a fully-qualified absolute URI, not a relative reference. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - newResourceURI: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - } - ) - Resource: Optional[Resource] = field( - default=None, - metadata={ - "type": "Element", - } - ) - status: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - subscriptionURI: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + newResourceURI: Optional[str] = field(default=None, metadata={ + "type": "Element", + }) + Resource: Optional[Resource] = field(default=None, metadata={ + "type": "Element", + }) + status: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + subscriptionURI: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -5472,6 +4686,7 @@ class NotificationListLink(ListLink): """ SHALL contain a Link to a List of Notification instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5509,66 +4724,43 @@ class PowerStatus(Resource): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - batteryStatus: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - changedTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - currentPowerSource: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - estimatedChargeRemaining: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - estimatedTimeRemaining: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - PEVInfo: Optional[PEVInfo] = field( - default=None, - metadata={ - "type": "Element", - } - ) - sessionTimeOnBattery: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - totalTimeOnBattery: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + batteryStatus: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + changedTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + currentPowerSource: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + estimatedChargeRemaining: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + estimatedTimeRemaining: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + PEVInfo: Optional[PEVInfo] = field(default=None, metadata={ + "type": "Element", + }) + sessionTimeOnBattery: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + totalTimeOnBattery: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -5576,6 +4768,7 @@ class PrepaymentListLink(ListLink): """ SHALL contain a Link to a List of Prepayment instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5585,6 +4778,7 @@ class PriceResponse(Response): """ A response related to a price message. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5604,30 +4798,25 @@ class PriceResponseCfg(Resource): threshold. :ivar RateComponentLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - consumeThreshold: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - maxReductionThreshold: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - RateComponentLink: Optional[RateComponentLink] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + consumeThreshold: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + maxReductionThreshold: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + RateComponentLink: Optional[RateComponentLink] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -5635,6 +4824,7 @@ class PriceResponseCfgListLink(ListLink): """ SHALL contain a Link to a List of PriceResponseCfg instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5644,6 +4834,7 @@ class ProjectionReadingListLink(ListLink): """ SHALL contain a Link to a List of ProjectionReading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5653,6 +4844,7 @@ class RPLInstanceListLink(ListLink): """ SHALL contain a Link to a List of RPLInterface instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5662,15 +4854,14 @@ class RPLSourceRoutesList(List_type): """ List or RPL source routes if the hosting device is the DODAGroot. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - RPLSourceRoutes: List[RPLSourceRoutes] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + RPLSourceRoutes: List[RPLSourceRoutes] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -5678,6 +4869,7 @@ class RPLSourceRoutesListLink(ListLink): """ SHALL contain a Link to a List of RPLSourceRoutes instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5687,6 +4879,7 @@ class RateComponentListLink(ListLink): """ SHALL contain a Link to a List of RateComponent instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5706,23 +4899,19 @@ class Reading(ReadingBase): (thresholds) are supported. If not specified, is "not subscribable" (0). """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - localID: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 2, - "format": "base16", - } - ) - subscribable: int = field( - default=0, - metadata={ - "type": "Attribute", - } - ) + localID: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 2, + "format": "base16", + }) + subscribable: int = field(default=0, metadata={ + "type": "Attribute", + }) @dataclass @@ -5730,6 +4919,7 @@ class ReadingListLink(ListLink): """ SHALL contain a Link to a List of Reading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5745,16 +4935,15 @@ class ReadingSetBase(IdentifiedObject): :ivar timePeriod: Specifies the time range during which the contained readings were taken. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - timePeriod: Optional[DateTimeInterval] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + timePeriod: Optional[DateTimeInterval] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -5762,6 +4951,7 @@ class ReadingSetListLink(ListLink): """ SHALL contain a Link to a List of ReadingSet instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5777,31 +4967,25 @@ class RespondableIdentifiedObject(RespondableResource): :ivar version: Contains the version number of the object. See the type definition for details. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - mRID: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) - description: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - version: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + mRID: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) + description: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 32, + }) + version: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -5819,37 +5003,28 @@ class RespondableSubscribableIdentifiedObject(RespondableResource): (thresholds) are supported. If not specified, is "not subscribable" (0). """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - mRID: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) - description: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - version: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - subscribable: int = field( - default=0, - metadata={ - "type": "Attribute", - } - ) + mRID: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) + description: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 32, + }) + version: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + subscribable: int = field(default=0, metadata={ + "type": "Attribute", + }) @dataclass @@ -5857,15 +5032,13 @@ class ResponseList(List_type): """ A List element to hold Response objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Response: List[Response] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + Response: List[Response] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -5873,6 +5046,7 @@ class ResponseListLink(ListLink): """ SHALL contain a Link to a List of Response instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5882,6 +5056,7 @@ class ResponseSetListLink(ListLink): """ SHALL contain a Link to a List of ResponseSet instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -5896,36 +5071,25 @@ class ServiceSupplier(IdentifiedObject): :ivar providerID: Contains the IANA PEN for the commodity provider. :ivar web: Website URI address for this service supplier. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - email: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - phone: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 20, - } - ) - providerID: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - web: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 42, - } - ) + email: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 32, + }) + phone: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 20, + }) + providerID: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + web: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 42, + }) @dataclass @@ -5939,31 +5103,25 @@ class SubscribableIdentifiedObject(SubscribableResource): :ivar version: Contains the version number of the object. See the type definition for details. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - mRID: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) - description: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - version: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + mRID: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) + description: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 32, + }) + version: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -5976,23 +5134,19 @@ class SubscribableList(SubscribableResource): :ivar results: Indicates the number of items in this page of results. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - all: Optional[int] = field( - default=None, - metadata={ - "type": "Attribute", - "required": True, - } - ) - results: Optional[int] = field( - default=None, - metadata={ - "type": "Attribute", - "required": True, - } - ) + all: Optional[int] = field(default=None, metadata={ + "type": "Attribute", + "required": True, + }) + results: Optional[int] = field(default=None, + metadata={ + "type": "Attribute", + "required": True, + }) @dataclass @@ -6032,44 +5186,32 @@ class Subscription(SubscriptionBase): to, this attribute SHALL be a fully-qualified absolute URI, not a relative reference. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Condition: Optional[Condition] = field( - default=None, - metadata={ - "type": "Element", - } - ) - encoding: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - level: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - } - ) - limit: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - notificationURI: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + Condition: Optional[Condition] = field(default=None, metadata={ + "type": "Element", + }) + encoding: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + level: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + }) + limit: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + notificationURI: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -6077,6 +5219,7 @@ class SubscriptionListLink(ListLink): """ SHALL contain a Link to a List of Subscription instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6086,15 +5229,14 @@ class SupplyInterruptionOverrideList(List_type): """ A List element to hold SupplyInterruptionOverride objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - SupplyInterruptionOverride: List[SupplyInterruptionOverride] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + SupplyInterruptionOverride: List[SupplyInterruptionOverride] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -6102,6 +5244,7 @@ class SupplyInterruptionOverrideListLink(ListLink): """ SHALL contain a Link to a List of SupplyInterruptionOverride instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6111,15 +5254,14 @@ class SupportedLocaleList(List_type): """ A List element to hold SupportedLocale objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - SupportedLocale: List[SupportedLocale] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + SupportedLocale: List[SupportedLocale] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -6127,6 +5269,7 @@ class SupportedLocaleListLink(ListLink): """ SHALL contain a Link to a List of SupportedLocale instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6136,6 +5279,7 @@ class TargetReadingListLink(ListLink): """ SHALL contain a Link to a List of TargetReading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6145,6 +5289,7 @@ class TariffProfileListLink(ListLink): """ SHALL contain a Link to a List of TariffProfile instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6154,6 +5299,7 @@ class TextMessageListLink(ListLink): """ SHALL contain a Link to a List of TextMessage instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6163,6 +5309,7 @@ class TextResponse(Response): """ A response to a text message. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6172,6 +5319,7 @@ class TimeTariffIntervalListLink(ListLink): """ SHALL contain a Link to a List of TimeTariffInterval instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6190,32 +5338,26 @@ class UsagePointBase(IdentifiedObject): :ivar status: Specifies the current status of the service at this usage point. 0 = off 1 = on """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - roleFlags: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 2, - "format": "base16", - } - ) - serviceCategoryKind: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - status: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + roleFlags: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 2, + "format": "base16", + }) + serviceCategoryKind: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + status: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -6223,6 +5365,7 @@ class UsagePointListLink(ListLink): """ SHALL contain a Link to a List of UsagePoint instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -6252,87 +5395,63 @@ class AbstractDevice(SubscribableResource): :ivar sFDI: Short form of device identifier, WITH the checksum digit. See the Security section for additional details. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ConfigurationLink: Optional[ConfigurationLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DERListLink: Optional[DERListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - deviceCategory: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 4, - "format": "base16", - } - ) - DeviceInformationLink: Optional[DeviceInformationLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DeviceStatusLink: Optional[DeviceStatusLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - FileStatusLink: Optional[FileStatusLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - IPInterfaceListLink: Optional[IPInterfaceListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - lFDI: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 20, - "format": "base16", - } - ) - LoadShedAvailabilityListLink: Optional[LoadShedAvailabilityListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LogEventListLink: Optional[LogEventListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - PowerStatusLink: Optional[PowerStatusLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - sFDI: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_inclusive": 281474976710655, - } - ) + ConfigurationLink: Optional[ConfigurationLink] = field(default=None, + metadata={ + "type": "Element", + }) + DERListLink: Optional[DERListLink] = field(default=None, metadata={ + "type": "Element", + }) + deviceCategory: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 4, + "format": "base16", + }) + DeviceInformationLink: Optional[DeviceInformationLink] = field(default=None, + metadata={ + "type": "Element", + }) + DeviceStatusLink: Optional[DeviceStatusLink] = field(default=None, + metadata={ + "type": "Element", + }) + FileStatusLink: Optional[FileStatusLink] = field(default=None, metadata={ + "type": "Element", + }) + IPInterfaceListLink: Optional[IPInterfaceListLink] = field(default=None, + metadata={ + "type": "Element", + }) + lFDI: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 20, + "format": "base16", + }) + LoadShedAvailabilityListLink: Optional[LoadShedAvailabilityListLink] = field(default=None, + metadata={ + "type": + "Element", + }) + LogEventListLink: Optional[LogEventListLink] = field(default=None, + metadata={ + "type": "Element", + }) + PowerStatusLink: Optional[PowerStatusLink] = field(default=None, + metadata={ + "type": "Element", + }) + sFDI: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_inclusive": 281474976710655, + }) @dataclass @@ -6341,21 +5460,18 @@ class BillingMeterReadingBase(MeterReadingBase): Contains historical, target, and projection readings of various types, possibly associated with charges. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - BillingReadingSetListLink: Optional[BillingReadingSetListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ReadingTypeLink: Optional[ReadingTypeLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + BillingReadingSetListLink: Optional[BillingReadingSetListLink] = field(default=None, + metadata={ + "type": "Element", + }) + ReadingTypeLink: Optional[ReadingTypeLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -6363,15 +5479,14 @@ class BillingPeriodList(SubscribableList): """ A List element to hold BillingPeriod objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - BillingPeriod: List[BillingPeriod] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + BillingPeriod: List[BillingPeriod] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -6379,15 +5494,14 @@ class BillingReadingList(List_type): """ A List element to hold BillingReading objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - BillingReading: List[BillingReading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + BillingReading: List[BillingReading] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -6395,15 +5509,14 @@ class BillingReadingSet(ReadingSetBase): """ Time sequence of readings of the same reading type. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - BillingReadingListLink: Optional[BillingReadingListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + BillingReadingListLink: Optional[BillingReadingListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -6425,49 +5538,37 @@ class Configuration(SubscribableResource): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - currentLocale: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 42, - } - ) - PowerConfiguration: Optional[PowerConfiguration] = field( - default=None, - metadata={ - "type": "Element", - } - ) - PriceResponseCfgListLink: Optional[PriceResponseCfgListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - TimeConfiguration: Optional[TimeConfiguration] = field( - default=None, - metadata={ - "type": "Element", - } - ) - userDeviceName: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + currentLocale: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 42, + }) + PowerConfiguration: Optional[PowerConfiguration] = field(default=None, + metadata={ + "type": "Element", + }) + PriceResponseCfgListLink: Optional[PriceResponseCfgListLink] = field(default=None, + metadata={ + "type": "Element", + }) + TimeConfiguration: Optional[TimeConfiguration] = field(default=None, + metadata={ + "type": "Element", + }) + userDeviceName: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -6475,15 +5576,14 @@ class CreditRegisterList(List_type): """ A List element to hold CreditRegister objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - CreditRegister: List[CreditRegister] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + CreditRegister: List[CreditRegister] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -6507,49 +5607,37 @@ class CustomerAccount(IdentifiedObject): multiplier for the prices in this function set. :ivar ServiceSupplierLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - currency: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - customerAccount: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 42, - } - ) - CustomerAgreementListLink: Optional[CustomerAgreementListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - customerName: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 42, - } - ) - pricePowerOfTenMultiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - ServiceSupplierLink: Optional[ServiceSupplierLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + currency: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + customerAccount: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 42, + }) + CustomerAgreementListLink: Optional[CustomerAgreementListLink] = field(default=None, + metadata={ + "type": "Element", + }) + customerName: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 42, + }) + pricePowerOfTenMultiplier: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + ServiceSupplierLink: Optional[ServiceSupplierLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -6576,83 +5664,60 @@ class CustomerAgreement(IdentifiedObject): :ivar TariffProfileLink: :ivar UsagePointLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ActiveBillingPeriodListLink: Optional[ActiveBillingPeriodListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + ActiveBillingPeriodListLink: Optional[ActiveBillingPeriodListLink] = field(default=None, + metadata={ + "type": + "Element", + }) ActiveProjectionReadingListLink: Optional[ActiveProjectionReadingListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ActiveTargetReadingListLink: Optional[ActiveTargetReadingListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - BillingPeriodListLink: Optional[BillingPeriodListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - HistoricalReadingListLink: Optional[HistoricalReadingListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - PrepaymentLink: Optional[PrepaymentLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ProjectionReadingListLink: Optional[ProjectionReadingListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - serviceAccount: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 42, - } - ) - serviceLocation: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 42, - } - ) - TargetReadingListLink: Optional[TargetReadingListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - TariffProfileLink: Optional[TariffProfileLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - UsagePointLink: Optional[UsagePointLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + default=None, metadata={ + "type": "Element", + }) + ActiveTargetReadingListLink: Optional[ActiveTargetReadingListLink] = field(default=None, + metadata={ + "type": + "Element", + }) + BillingPeriodListLink: Optional[BillingPeriodListLink] = field(default=None, + metadata={ + "type": "Element", + }) + HistoricalReadingListLink: Optional[HistoricalReadingListLink] = field(default=None, + metadata={ + "type": "Element", + }) + PrepaymentLink: Optional[PrepaymentLink] = field(default=None, metadata={ + "type": "Element", + }) + ProjectionReadingListLink: Optional[ProjectionReadingListLink] = field(default=None, + metadata={ + "type": "Element", + }) + serviceAccount: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 42, + }) + serviceLocation: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 42, + }) + TargetReadingListLink: Optional[TargetReadingListLink] = field(default=None, + metadata={ + "type": "Element", + }) + TariffProfileLink: Optional[TariffProfileLink] = field(default=None, + metadata={ + "type": "Element", + }) + UsagePointLink: Optional[UsagePointLink] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -6660,51 +5725,38 @@ class DER(SubscribableResource): """ Contains links to DER resources. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - AssociatedDERProgramListLink: Optional[AssociatedDERProgramListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - AssociatedUsagePointLink: Optional[AssociatedUsagePointLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - CurrentDERProgramLink: Optional[CurrentDERProgramLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DERAvailabilityLink: Optional[DERAvailabilityLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DERCapabilityLink: Optional[DERCapabilityLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DERSettingsLink: Optional[DERSettingsLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DERStatusLink: Optional[DERStatusLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + AssociatedDERProgramListLink: Optional[AssociatedDERProgramListLink] = field(default=None, + metadata={ + "type": + "Element", + }) + AssociatedUsagePointLink: Optional[AssociatedUsagePointLink] = field(default=None, + metadata={ + "type": "Element", + }) + CurrentDERProgramLink: Optional[CurrentDERProgramLink] = field(default=None, + metadata={ + "type": "Element", + }) + DERAvailabilityLink: Optional[DERAvailabilityLink] = field(default=None, + metadata={ + "type": "Element", + }) + DERCapabilityLink: Optional[DERCapabilityLink] = field(default=None, + metadata={ + "type": "Element", + }) + DERSettingsLink: Optional[DERSettingsLink] = field(default=None, + metadata={ + "type": "Element", + }) + DERStatusLink: Optional[DERStatusLink] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -6712,15 +5764,13 @@ class DERCurveList(List_type): """ A List element to hold DERCurve objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DERCurve: List[DERCurve] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + DERCurve: List[DERCurve] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -6735,40 +5785,30 @@ class DERProgram(SubscribableIdentifiedObject): :ivar primacy: Indicates the relative primacy of the provider of this Program. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ActiveDERControlListLink: Optional[ActiveDERControlListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DefaultDERControlLink: Optional[DefaultDERControlLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DERControlListLink: Optional[DERControlListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DERCurveListLink: Optional[DERCurveListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - primacy: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + ActiveDERControlListLink: Optional[ActiveDERControlListLink] = field(default=None, + metadata={ + "type": "Element", + }) + DefaultDERControlLink: Optional[DefaultDERControlLink] = field(default=None, + metadata={ + "type": "Element", + }) + DERControlListLink: Optional[DERControlListLink] = field(default=None, + metadata={ + "type": "Element", + }) + DERCurveListLink: Optional[DERCurveListLink] = field(default=None, + metadata={ + "type": "Element", + }) + primacy: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -6821,70 +5861,42 @@ class DefaultDERControl(SubscribableIdentifiedObject): SHALL update the value of the corresponding setting (DERSettings::setSoftGradW). """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DERControlBase: Optional[DERControlBase] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - setESDelay: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESHighFreq: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESHighVolt: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESLowFreq: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESLowVolt: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESRampTms: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setESRandomDelay: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setGradW: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - setSoftGradW: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + DERControlBase: Optional[DERControlBase] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + setESDelay: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESHighFreq: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESHighVolt: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESLowFreq: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESLowVolt: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESRampTms: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setESRandomDelay: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setGradW: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + setSoftGradW: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -6917,40 +5929,31 @@ class DemandResponseProgram(IdentifiedObject): :ivar primacy: Indicates the relative primacy of the provider of this program. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ActiveEndDeviceControlListLink: Optional[ActiveEndDeviceControlListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - availabilityUpdatePercentChangeThreshold: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - availabilityUpdatePowerChangeThreshold: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - } - ) - EndDeviceControlListLink: Optional[EndDeviceControlListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - primacy: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + ActiveEndDeviceControlListLink: Optional[ActiveEndDeviceControlListLink] = field(default=None, + metadata={ + "type": + "Element", + }) + availabilityUpdatePercentChangeThreshold: Optional[int] = field(default=None, + metadata={ + "type": "Element", + }) + availabilityUpdatePowerChangeThreshold: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + }) + EndDeviceControlListLink: Optional[EndDeviceControlListLink] = field(default=None, + metadata={ + "type": "Element", + }) + primacy: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -6989,124 +5992,88 @@ class DeviceInformation(Resource): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DRLCCapabilities: Optional[DRLCCapabilities] = field( - default=None, - metadata={ - "type": "Element", - } - ) - functionsImplemented: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 8, - "format": "base16", - } - ) - gpsLocation: Optional[GPSLocationType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - lFDI: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 20, - "format": "base16", - } - ) - mfDate: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - mfHwVer: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) - mfID: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - mfInfo: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - mfModel: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) - mfSerNum: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) - primaryPower: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - secondaryPower: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - SupportedLocaleListLink: Optional[SupportedLocaleListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - swActTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - swVer: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 32, - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + DRLCCapabilities: Optional[DRLCCapabilities] = field(default=None, + metadata={ + "type": "Element", + }) + functionsImplemented: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 8, + "format": "base16", + }) + gpsLocation: Optional[GPSLocationType] = field(default=None, metadata={ + "type": "Element", + }) + lFDI: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 20, + "format": "base16", + }) + mfDate: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + mfHwVer: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) + mfID: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + mfInfo: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 32, + }) + mfModel: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) + mfSerNum: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) + primaryPower: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + secondaryPower: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + SupportedLocaleListLink: Optional[SupportedLocaleListLink] = field(default=None, + metadata={ + "type": "Element", + }) + swActTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + swVer: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 32, + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -7121,30 +6088,25 @@ class Event(RespondableSubscribableIdentifiedObject): :ivar EventStatus: :ivar interval: The period during which the Event applies. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - creationTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - EventStatus: Optional[EventStatus] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - interval: Optional[DateTimeInterval] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + creationTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + EventStatus: Optional[EventStatus] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + interval: Optional[DateTimeInterval] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -7159,21 +6121,17 @@ class FlowReservationRequestList(List_type): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - FlowReservationRequest: List[FlowReservationRequest] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + FlowReservationRequest: List[FlowReservationRequest] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -7182,69 +6140,49 @@ class FunctionSetAssignmentsBase(Resource): Defines a collection of function set instances that are to be used by one or more devices as indicated by the EndDevice object(s) of the server. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - CustomerAccountListLink: Optional[CustomerAccountListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DemandResponseProgramListLink: Optional[DemandResponseProgramListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - DERProgramListLink: Optional[DERProgramListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - FileListLink: Optional[FileListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - MessagingProgramListLink: Optional[MessagingProgramListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - PrepaymentListLink: Optional[PrepaymentListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ResponseSetListLink: Optional[ResponseSetListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - TariffProfileListLink: Optional[TariffProfileListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - TimeLink: Optional[TimeLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - UsagePointListLink: Optional[UsagePointListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + CustomerAccountListLink: Optional[CustomerAccountListLink] = field(default=None, + metadata={ + "type": "Element", + }) + DemandResponseProgramListLink: Optional[DemandResponseProgramListLink] = field(default=None, + metadata={ + "type": + "Element", + }) + DERProgramListLink: Optional[DERProgramListLink] = field(default=None, + metadata={ + "type": "Element", + }) + FileListLink: Optional[FileListLink] = field(default=None, metadata={ + "type": "Element", + }) + MessagingProgramListLink: Optional[MessagingProgramListLink] = field(default=None, + metadata={ + "type": "Element", + }) + PrepaymentListLink: Optional[PrepaymentListLink] = field(default=None, + metadata={ + "type": "Element", + }) + ResponseSetListLink: Optional[ResponseSetListLink] = field(default=None, + metadata={ + "type": "Element", + }) + TariffProfileListLink: Optional[TariffProfileListLink] = field(default=None, + metadata={ + "type": "Element", + }) + TimeLink: Optional[TimeLink] = field(default=None, metadata={ + "type": "Element", + }) + UsagePointListLink: Optional[UsagePointListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -7256,31 +6194,26 @@ class IEEE_802_15_4: :ivar NeighborListLink: :ivar shortAddress: As defined by IEEE 802.15.4 """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - capabilityInfo: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 1, - "format": "base16", - } - ) - NeighborListLink: Optional[NeighborListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - shortAddress: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + capabilityInfo: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 1, + "format": "base16", + }) + NeighborListLink: Optional[NeighborListLink] = field(default=None, + metadata={ + "type": "Element", + }) + shortAddress: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -7291,24 +6224,21 @@ class IPAddr(Resource): :ivar address: An IP address value. :ivar RPLInstanceListLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - address: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) - RPLInstanceListLink: Optional[RPLInstanceListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + address: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) + RPLInstanceListLink: Optional[RPLInstanceListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -7344,178 +6274,102 @@ class IPInterface(Resource): :ivar ifOutMulticastPkts: Use rules from [RFC 2863]. Can be thought of as Multicast Datagrams Sent. :ivar ifOutOctets: Use rules from [RFC 2863]. Can be thought of as - Bytes Sent. - :ivar ifOutUcastPkts: Use rules from [RFC 2863]. Can be thought of - as Datagrams Sent. - :ivar ifPromiscuousMode: Use rules from [RFC 2863]. - :ivar ifSpeed: Use rules from [RFC 2863]. - :ivar ifType: Use rules and assignments from [RFC 2863]. - :ivar IPAddrListLink: - :ivar lastResetTime: Similar to ifLastChange in [RFC 2863]. - :ivar lastUpdatedTime: The date/time of the reported status. - :ivar LLInterfaceListLink: - """ - class Meta: - namespace = "urn:ieee:std:2030.5:ns" - - ifDescr: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 192, - } - ) - ifHighSpeed: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifInBroadcastPkts: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifIndex: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifInDiscards: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifInErrors: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifInMulticastPkts: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifInOctets: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifInUcastPkts: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifInUnknownProtos: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifMtu: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifName: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 16, - } - ) - ifOperStatus: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifOutBroadcastPkts: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifOutDiscards: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifOutErrors: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifOutMulticastPkts: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifOutOctets: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifOutUcastPkts: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifPromiscuousMode: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifSpeed: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ifType: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - IPAddrListLink: Optional[IPAddrListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - lastResetTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - lastUpdatedTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLInterfaceListLink: Optional[LLInterfaceListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + Bytes Sent. + :ivar ifOutUcastPkts: Use rules from [RFC 2863]. Can be thought of + as Datagrams Sent. + :ivar ifPromiscuousMode: Use rules from [RFC 2863]. + :ivar ifSpeed: Use rules from [RFC 2863]. + :ivar ifType: Use rules and assignments from [RFC 2863]. + :ivar IPAddrListLink: + :ivar lastResetTime: Similar to ifLastChange in [RFC 2863]. + :ivar lastUpdatedTime: The date/time of the reported status. + :ivar LLInterfaceListLink: + """ + + class Meta: + namespace = "urn:ieee:std:2030.5:ns" + + ifDescr: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 192, + }) + ifHighSpeed: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifInBroadcastPkts: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifIndex: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifInDiscards: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifInErrors: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifInMulticastPkts: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifInOctets: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifInUcastPkts: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifInUnknownProtos: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifMtu: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifName: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 16, + }) + ifOperStatus: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifOutBroadcastPkts: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifOutDiscards: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifOutErrors: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifOutMulticastPkts: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifOutOctets: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifOutUcastPkts: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifPromiscuousMode: Optional[bool] = field(default=None, metadata={ + "type": "Element", + }) + ifSpeed: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + ifType: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + IPAddrListLink: Optional[IPAddrListLink] = field(default=None, metadata={ + "type": "Element", + }) + lastResetTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + lastUpdatedTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLInterfaceListLink: Optional[LLInterfaceListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -7530,21 +6384,17 @@ class LoadShedAvailabilityList(List_type): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - LoadShedAvailability: List[LoadShedAvailability] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + LoadShedAvailability: List[LoadShedAvailability] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -7559,21 +6409,16 @@ class LogEventList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - LogEvent: List[LogEvent] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + LogEvent: List[LogEvent] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -7588,36 +6433,28 @@ class MessagingProgram(SubscribableIdentifiedObject): this program. :ivar TextMessageListLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ActiveTextMessageListLink: Optional[ActiveTextMessageListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - locale: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 42, - } - ) - primacy: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - TextMessageListLink: Optional[TextMessageListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + ActiveTextMessageListLink: Optional[ActiveTextMessageListLink] = field(default=None, + metadata={ + "type": "Element", + }) + locale: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 42, + }) + primacy: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + TextMessageListLink: Optional[TextMessageListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -7625,34 +6462,26 @@ class MeterReading(MeterReadingBase): """ Set of values obtained from the meter. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - RateComponentListLink: Optional[RateComponentListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ReadingLink: Optional[ReadingLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ReadingSetListLink: Optional[ReadingSetListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ReadingTypeLink: Optional[ReadingTypeLink] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + RateComponentListLink: Optional[RateComponentListLink] = field(default=None, + metadata={ + "type": "Element", + }) + ReadingLink: Optional[ReadingLink] = field(default=None, metadata={ + "type": "Element", + }) + ReadingSetListLink: Optional[ReadingSetListLink] = field(default=None, + metadata={ + "type": "Element", + }) + ReadingTypeLink: Optional[ReadingTypeLink] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -7660,15 +6489,13 @@ class MirrorReadingSet(ReadingSetBase): """ A set of Readings of the ReadingType indicated by the parent MeterReading. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Reading: List[Reading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + Reading: List[Reading] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -7676,15 +6503,13 @@ class NotificationList(List_type): """ A List element to hold Notification objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Notification: List[Notification] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + Notification: List[Notification] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -7692,15 +6517,14 @@ class PriceResponseCfgList(List_type): """ A List element to hold PriceResponseCfg objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - PriceResponseCfg: List[PriceResponseCfg] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + PriceResponseCfg: List[PriceResponseCfg] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -7721,78 +6545,54 @@ class RPLInstance(Resource): :ivar RPLSourceRoutesListLink: :ivar versionNumber: See [RFC 6550]. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DODAGid: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - DODAGroot: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - flags: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - groundedFlag: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - MOP: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - PRF: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - rank: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - RPLInstanceID: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - RPLSourceRoutesListLink: Optional[RPLSourceRoutesListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - versionNumber: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + DODAGid: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + DODAGroot: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + flags: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + groundedFlag: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + MOP: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + PRF: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + rank: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + RPLInstanceID: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + RPLSourceRoutesListLink: Optional[RPLSourceRoutesListLink] = field(default=None, + metadata={ + "type": "Element", + }) + versionNumber: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -7837,50 +6637,38 @@ class RateComponent(IdentifiedObject): assigned. :ivar TimeTariffIntervalListLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" ActiveTimeTariffIntervalListLink: Optional[ActiveTimeTariffIntervalListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - flowRateEndLimit: Optional[UnitValueType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - flowRateStartLimit: Optional[UnitValueType] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ReadingTypeLink: Optional[ReadingTypeLink] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - roleFlags: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 2, - "format": "base16", - } - ) - TimeTariffIntervalListLink: Optional[TimeTariffIntervalListLink] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + default=None, metadata={ + "type": "Element", + }) + flowRateEndLimit: Optional[UnitValueType] = field(default=None, metadata={ + "type": "Element", + }) + flowRateStartLimit: Optional[UnitValueType] = field(default=None, + metadata={ + "type": "Element", + }) + ReadingTypeLink: Optional[ReadingTypeLink] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + roleFlags: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 2, + "format": "base16", + }) + TimeTariffIntervalListLink: Optional[TimeTariffIntervalListLink] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -7888,15 +6676,13 @@ class ReadingList(SubscribableList): """ A List element to hold Reading objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Reading: List[Reading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + Reading: List[Reading] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -7904,15 +6690,14 @@ class ReadingSet(ReadingSetBase): """ A set of Readings of the ReadingType indicated by the parent MeterReading. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ReadingListLink: Optional[ReadingListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + ReadingListLink: Optional[ReadingListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -7920,15 +6705,14 @@ class ResponseSet(IdentifiedObject): """ A container for a ResponseList. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ResponseListLink: Optional[ResponseListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + ResponseListLink: Optional[ResponseListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -7936,15 +6720,14 @@ class ServiceSupplierList(List_type): """ A List element to hold ServiceSupplier objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ServiceSupplier: List[ServiceSupplier] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + ServiceSupplier: List[ServiceSupplier] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -7959,21 +6742,16 @@ class SubscriptionList(List_type): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Subscription: List[Subscription] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + Subscription: List[Subscription] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -7999,48 +6777,33 @@ class TariffProfile(IdentifiedObject): :ivar serviceCategoryKind: The kind of service provided by this usage point. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - currency: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - pricePowerOfTenMultiplier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - primacy: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - rateCode: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 20, - } - ) - RateComponentListLink: Optional[RateComponentListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - serviceCategoryKind: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + currency: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + pricePowerOfTenMultiplier: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + primacy: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + rateCode: Optional[str] = field(default=None, metadata={ + "type": "Element", + "max_length": 20, + }) + RateComponentListLink: Optional[RateComponentListLink] = field(default=None, + metadata={ + "type": "Element", + }) + serviceCategoryKind: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -8054,23 +6817,20 @@ class UsagePoint(UsagePointBase): SHALL be present when mirroring. :ivar MeterReadingListLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - deviceLFDI: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 20, - "format": "base16", - } - ) - MeterReadingListLink: Optional[MeterReadingListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + deviceLFDI: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 20, + "format": "base16", + }) + MeterReadingListLink: Optional[MeterReadingListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -8078,15 +6838,14 @@ class BillingReadingSetList(SubscribableList): """ A List element to hold BillingReadingSet objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - BillingReadingSet: List[BillingReadingSet] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + BillingReadingSet: List[BillingReadingSet] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -8101,21 +6860,17 @@ class CustomerAccountList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - CustomerAccount: List[CustomerAccount] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + CustomerAccount: List[CustomerAccount] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8123,15 +6878,14 @@ class CustomerAgreementList(SubscribableList): """ A List element to hold CustomerAgreement objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - CustomerAgreement: List[CustomerAgreement] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + CustomerAgreement: List[CustomerAgreement] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -8146,21 +6900,16 @@ class DERList(List_type): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DER: List[DER] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + DER: List[DER] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8175,21 +6924,16 @@ class DERProgramList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DERProgram: List[DERProgram] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + DERProgram: List[DERProgram] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8204,21 +6948,17 @@ class DemandResponseProgramList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DemandResponseProgram: List[DemandResponseProgram] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + DemandResponseProgram: List[DemandResponseProgram] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8236,33 +6976,24 @@ class DeviceCapability(FunctionSetAssignmentsBase): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - EndDeviceListLink: Optional[EndDeviceListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - MirrorUsagePointListLink: Optional[MirrorUsagePointListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - SelfDeviceLink: Optional[SelfDeviceLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + EndDeviceListLink: Optional[EndDeviceListLink] = field(default=None, + metadata={ + "type": "Element", + }) + MirrorUsagePointListLink: Optional[MirrorUsagePointListLink] = field(default=None, + metadata={ + "type": "Element", + }) + SelfDeviceLink: Optional[SelfDeviceLink] = field(default=None, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8289,58 +7020,43 @@ class EndDevice(AbstractDevice): :ivar RegistrationLink: :ivar SubscriptionListLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - changedTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - enabled: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - } - ) - FlowReservationRequestListLink: Optional[FlowReservationRequestListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + changedTime: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + enabled: Optional[bool] = field(default=None, metadata={ + "type": "Element", + }) + FlowReservationRequestListLink: Optional[FlowReservationRequestListLink] = field(default=None, + metadata={ + "type": + "Element", + }) FlowReservationResponseListLink: Optional[FlowReservationResponseListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - FunctionSetAssignmentsListLink: Optional[FunctionSetAssignmentsListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - postRate: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - RegistrationLink: Optional[RegistrationLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - SubscriptionListLink: Optional[SubscriptionListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + default=None, metadata={ + "type": "Element", + }) + FunctionSetAssignmentsListLink: Optional[FunctionSetAssignmentsListLink] = field(default=None, + metadata={ + "type": + "Element", + }) + postRate: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + RegistrationLink: Optional[RegistrationLink] = field(default=None, + metadata={ + "type": "Element", + }) + SubscriptionListLink: Optional[SubscriptionListLink] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -8356,32 +7072,27 @@ class FlowReservationResponse(Event): response with the originating event. It is populated with the mRID of the corresponding FlowReservationRequest object. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - energyAvailable: Optional[SignedRealEnergy] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - powerAvailable: Optional[ActivePower] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - subject: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) + energyAvailable: Optional[SignedRealEnergy] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + powerAvailable: Optional[ActivePower] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + subject: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) @dataclass @@ -8400,37 +7111,28 @@ class FunctionSetAssignments(FunctionSetAssignmentsBase): (thresholds) are supported. If not specified, is "not subscribable" (0). """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - mRID: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 16, - "format": "base16", - } - ) - description: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 32, - } - ) - version: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - subscribable: int = field( - default=0, - metadata={ - "type": "Attribute", - } - ) + mRID: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 16, + "format": "base16", + }) + description: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 32, + }) + version: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + subscribable: int = field(default=0, metadata={ + "type": "Attribute", + }) @dataclass @@ -8442,6 +7144,7 @@ class HistoricalReading(BillingMeterReadingBase): This includes quality codes valid, verified, estimated, and derived / corrected. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -8451,15 +7154,13 @@ class IPAddrList(List_type): """ List of IPAddr instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - IPAddr: List[IPAddr] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + IPAddr: List[IPAddr] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -8474,21 +7175,16 @@ class IPInterfaceList(List_type): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - IPInterface: List[IPInterface] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + IPInterface: List[IPInterface] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8520,110 +7216,66 @@ class LLInterface(Resource): :ivar LLSecurityErrorRx: Number of receive security errors. :ivar loWPAN: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - CRCerrors: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - EUI64: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 8, - "format": "base16", - } - ) - IEEE_802_15_4: Optional[IEEE_802_15_4] = field( - default=None, - metadata={ - "type": "Element", - } - ) - linkLayerType: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - LLAckNotRx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLCSMAFail: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLFramesDropRx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLFramesDropTx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLFramesRx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLFramesTx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLMediaAccessFail: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLOctetsRx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLOctetsTx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLRetryCount: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - LLSecurityErrorRx: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - loWPAN: Optional[loWPAN] = field( - default=None, - metadata={ - "type": "Element", - } - ) + CRCerrors: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + EUI64: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 8, + "format": "base16", + }) + IEEE_802_15_4: Optional[IEEE_802_15_4] = field(default=None, metadata={ + "type": "Element", + }) + linkLayerType: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + LLAckNotRx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLCSMAFail: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLFramesDropRx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLFramesDropTx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLFramesRx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLFramesTx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLMediaAccessFail: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLOctetsRx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLOctetsTx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLRetryCount: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + LLSecurityErrorRx: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + loWPAN: Optional[loWPAN] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -8638,21 +7290,17 @@ class MessagingProgramList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - MessagingProgram: List[MessagingProgram] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + MessagingProgram: List[MessagingProgram] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8660,15 +7308,13 @@ class MeterReadingList(SubscribableList): """ A List element to hold MeterReading objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - MeterReading: List[MeterReading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + MeterReading: List[MeterReading] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -8682,39 +7328,26 @@ class MirrorMeterReading(MeterReadingBase): :ivar Reading: :ivar ReadingType: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - lastUpdateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - MirrorReadingSet: List[MirrorReadingSet] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - nextUpdateTime: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - Reading: Optional[Reading] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ReadingType: Optional[ReadingType] = field( - default=None, - metadata={ - "type": "Element", - } - ) + lastUpdateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + MirrorReadingSet: List[MirrorReadingSet] = field(default_factory=list, + metadata={ + "type": "Element", + }) + nextUpdateTime: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + Reading: Optional[Reading] = field(default=None, metadata={ + "type": "Element", + }) + ReadingType: Optional[ReadingType] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -8754,86 +7387,63 @@ class Prepayment(IdentifiedObject): :ivar UsagePoint: :ivar UsagePointLink: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - AccountBalanceLink: Optional[AccountBalanceLink] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - ActiveCreditRegisterListLink: Optional[ActiveCreditRegisterListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - ActiveSupplyInterruptionOverrideListLink: Optional[ActiveSupplyInterruptionOverrideListLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) - creditExpiryLevel: Optional[AccountingUnit] = field( - default=None, - metadata={ - "type": "Element", - } - ) - CreditRegisterListLink: Optional[CreditRegisterListLink] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - lowCreditWarningLevel: Optional[AccountingUnit] = field( - default=None, - metadata={ - "type": "Element", - } - ) - lowEmergencyCreditWarningLevel: Optional[AccountingUnit] = field( - default=None, - metadata={ - "type": "Element", - } - ) - prepayMode: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - PrepayOperationStatusLink: Optional[PrepayOperationStatusLink] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + AccountBalanceLink: Optional[AccountBalanceLink] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + ActiveCreditRegisterListLink: Optional[ActiveCreditRegisterListLink] = field(default=None, + metadata={ + "type": + "Element", + }) + ActiveSupplyInterruptionOverrideListLink: Optional[ + ActiveSupplyInterruptionOverrideListLink] = field(default=None, + metadata={ + "type": "Element", + }) + creditExpiryLevel: Optional[AccountingUnit] = field(default=None, + metadata={ + "type": "Element", + }) + CreditRegisterListLink: Optional[CreditRegisterListLink] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + lowCreditWarningLevel: Optional[AccountingUnit] = field(default=None, + metadata={ + "type": "Element", + }) + lowEmergencyCreditWarningLevel: Optional[AccountingUnit] = field(default=None, + metadata={ + "type": "Element", + }) + prepayMode: Optional[int] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + PrepayOperationStatusLink: Optional[PrepayOperationStatusLink] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) SupplyInterruptionOverrideListLink: Optional[SupplyInterruptionOverrideListLink] = field( - default=None, - metadata={ + default=None, metadata={ "type": "Element", "required": True, - } - ) - UsagePoint: List[UsagePoint] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - UsagePointLink: Optional[UsagePointLink] = field( - default=None, - metadata={ - "type": "Element", - } - ) + }) + UsagePoint: List[UsagePoint] = field(default_factory=list, metadata={ + "type": "Element", + }) + UsagePointLink: Optional[UsagePointLink] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -8842,6 +7452,7 @@ class ProjectionReading(BillingMeterReadingBase): Contains values that forecast a future reading for the time or interval specified. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -8851,15 +7462,13 @@ class RPLInstanceList(List_type): """ List of RPLInstances associated with the IPinterface. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - RPLInstance: List[RPLInstance] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + RPLInstance: List[RPLInstance] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -8880,21 +7489,16 @@ class RandomizableEvent(Event): Valid range is -3600 to 3600. If not specified, 0 is the default. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - randomizeDuration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - randomizeStart: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + randomizeDuration: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + randomizeStart: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -8902,15 +7506,14 @@ class RateComponentList(List_type): """ A List element to hold RateComponent objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - RateComponent: List[RateComponent] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + RateComponent: List[RateComponent] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -8918,15 +7521,13 @@ class ReadingSetList(SubscribableList): """ A List element to hold ReadingSet objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ReadingSet: List[ReadingSet] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + ReadingSet: List[ReadingSet] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -8941,21 +7542,16 @@ class ResponseSetList(List_type): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ResponseSet: List[ResponseSet] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + ResponseSet: List[ResponseSet] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8970,15 +7566,13 @@ class SelfDevice(AbstractDevice): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -8988,6 +7582,7 @@ class TargetReading(BillingMeterReadingBase): target, to which billing incentives or other contractual ramifications may be associated. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" @@ -9004,21 +7599,17 @@ class TariffProfileList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - TariffProfile: List[TariffProfile] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + TariffProfile: List[TariffProfile] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -9045,30 +7636,24 @@ class TextMessage(Event): choose what method to handle the message (truncation, scrolling, etc.). """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - originator: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 20, - } - ) - priority: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - textMessage: Optional[str] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + originator: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "max_length": 20, + }) + priority: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) + textMessage: Optional[str] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -9083,21 +7668,16 @@ class UsagePointList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - UsagePoint: List[UsagePoint] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + UsagePoint: List[UsagePoint] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -9111,24 +7691,21 @@ class DERControl(RandomizableEvent): events that do not indicate their device category. If not present, all devices SHOULD respond. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DERControlBase: Optional[DERControlBase] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - deviceCategory: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "max_length": 4, - "format": "base16", - } - ) + DERControlBase: Optional[DERControlBase] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + deviceCategory: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "max_length": 4, + "format": "base16", + }) @dataclass @@ -9160,68 +7737,47 @@ class EndDeviceControl(RandomizableEvent): :ivar SetPoint: :ivar TargetReduction: """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ApplianceLoadReduction: Optional[ApplianceLoadReduction] = field( - default=None, - metadata={ - "type": "Element", - } - ) - deviceCategory: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 4, - "format": "base16", - } - ) - drProgramMandatory: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - DutyCycle: Optional[DutyCycle] = field( - default=None, - metadata={ - "type": "Element", - } - ) - loadShiftForward: Optional[bool] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) - Offset: Optional[Offset] = field( - default=None, - metadata={ - "type": "Element", - } - ) - overrideDuration: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) - SetPoint: Optional[SetPoint] = field( - default=None, - metadata={ - "type": "Element", - } - ) - TargetReduction: Optional[TargetReduction] = field( - default=None, - metadata={ - "type": "Element", - } - ) + ApplianceLoadReduction: Optional[ApplianceLoadReduction] = field(default=None, + metadata={ + "type": "Element", + }) + deviceCategory: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 4, + "format": "base16", + }) + drProgramMandatory: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + DutyCycle: Optional[DutyCycle] = field(default=None, metadata={ + "type": "Element", + }) + loadShiftForward: Optional[bool] = field(default=None, + metadata={ + "type": "Element", + "required": True, + }) + Offset: Optional[Offset] = field(default=None, metadata={ + "type": "Element", + }) + overrideDuration: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) + SetPoint: Optional[SetPoint] = field(default=None, metadata={ + "type": "Element", + }) + TargetReduction: Optional[TargetReduction] = field(default=None, + metadata={ + "type": "Element", + }) @dataclass @@ -9236,21 +7792,16 @@ class EndDeviceList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - EndDevice: List[EndDevice] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + EndDevice: List[EndDevice] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -9265,21 +7816,17 @@ class FlowReservationResponseList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - FlowReservationResponse: List[FlowReservationResponse] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + FlowReservationResponse: List[FlowReservationResponse] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -9294,21 +7841,17 @@ class FunctionSetAssignmentsList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - FunctionSetAssignments: List[FunctionSetAssignments] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + FunctionSetAssignments: List[FunctionSetAssignments] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -9316,15 +7859,14 @@ class HistoricalReadingList(List_type): """ A List element to hold HistoricalReading objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - HistoricalReading: List[HistoricalReading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + HistoricalReading: List[HistoricalReading] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -9332,15 +7874,13 @@ class LLInterfaceList(List_type): """ List of LLInterface instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - LLInterface: List[LLInterface] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + LLInterface: List[LLInterface] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -9348,15 +7888,14 @@ class MirrorMeterReadingList(List_type): """ A List of MirrorMeterReading instances. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - MirrorMeterReading: List[MirrorMeterReading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + MirrorMeterReading: List[MirrorMeterReading] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -9371,30 +7910,24 @@ class MirrorUsagePoint(UsagePointBase): when POSTing MirrorUsagePoint. A server MAY add or modify postRate to indicate its preferred posting rate. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - deviceLFDI: Optional[bytes] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - "max_length": 20, - "format": "base16", - } - ) - MirrorMeterReading: List[MirrorMeterReading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - postRate: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - } - ) + deviceLFDI: Optional[bytes] = field(default=None, + metadata={ + "type": "Element", + "required": True, + "max_length": 20, + "format": "base16", + }) + MirrorMeterReading: List[MirrorMeterReading] = field(default_factory=list, + metadata={ + "type": "Element", + }) + postRate: Optional[int] = field(default=None, metadata={ + "type": "Element", + }) @dataclass @@ -9409,21 +7942,16 @@ class PrepaymentList(SubscribableList): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - Prepayment: List[Prepayment] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + Prepayment: List[Prepayment] = field(default_factory=list, metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -9431,15 +7959,14 @@ class ProjectionReadingList(List_type): """ A List element to hold ProjectionReading objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - ProjectionReading: List[ProjectionReading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + ProjectionReading: List[ProjectionReading] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -9447,15 +7974,14 @@ class TargetReadingList(List_type): """ A List element to hold TargetReading objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - TargetReading: List[TargetReading] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + TargetReading: List[TargetReading] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -9463,15 +7989,13 @@ class TextMessageList(SubscribableList): """ A List element to hold TextMessage objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - TextMessage: List[TextMessage] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + TextMessage: List[TextMessage] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -9485,22 +8009,18 @@ class TimeTariffInterval(RandomizableEvent): :ivar touTier: Indicates the time of use tier related to the reading. If not specified, is assumed to be "0 - N/A". """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" ConsumptionTariffIntervalListLink: Optional[ConsumptionTariffIntervalListLink] = field( - default=None, - metadata={ + default=None, metadata={ "type": "Element", - } - ) - touTier: Optional[int] = field( - default=None, - metadata={ - "type": "Element", - "required": True, - } - ) + }) + touTier: Optional[int] = field(default=None, metadata={ + "type": "Element", + "required": True, + }) @dataclass @@ -9508,15 +8028,13 @@ class DERControlList(SubscribableList): """ A List element to hold DERControl objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - DERControl: List[DERControl] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + DERControl: List[DERControl] = field(default_factory=list, metadata={ + "type": "Element", + }) @dataclass @@ -9524,15 +8042,14 @@ class EndDeviceControlList(SubscribableList): """ A List element to hold EndDeviceControl objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - EndDeviceControl: List[EndDeviceControl] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + EndDeviceControl: List[EndDeviceControl] = field(default_factory=list, + metadata={ + "type": "Element", + }) @dataclass @@ -9547,21 +8064,17 @@ class MirrorUsagePointList(List_type): a client poll the resources of this function set every pollRate seconds. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - MirrorUsagePoint: List[MirrorUsagePoint] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) - pollRate: int = field( - default=900, - metadata={ - "type": "Attribute", - } - ) + MirrorUsagePoint: List[MirrorUsagePoint] = field(default_factory=list, + metadata={ + "type": "Element", + }) + pollRate: int = field(default=900, metadata={ + "type": "Attribute", + }) @dataclass @@ -9569,12 +8082,11 @@ class TimeTariffIntervalList(SubscribableList): """ A List element to hold TimeTariffInterval objects. """ + class Meta: namespace = "urn:ieee:std:2030.5:ns" - TimeTariffInterval: List[TimeTariffInterval] = field( - default_factory=list, - metadata={ - "type": "Element", - } - ) + TimeTariffInterval: List[TimeTariffInterval] = field(default_factory=list, + metadata={ + "type": "Element", + }) From 25533339f445514ce767157300964f6a6b111055 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Mon, 16 Oct 2023 11:14:04 -0700 Subject: [PATCH 45/53] Fix problem with time and conversion to gmt. --- services/core/IEEE_2030_5/demo/webgui.py | 32 +++++++++++++++++------- 1 file changed, 23 insertions(+), 9 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index ebb0d4dae4..0602042041 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -248,14 +248,24 @@ def reset_config(): cards = [] +def convert_local_dt_to_utc_timestamp(dt: datetime) -> int: + """Converts a local datetime to a UTC timestamp. -def convert_datetime_to_int(dt: datetime) -> int: - """Converts datetime to epoch time in gmt - - :param dt: Datetime object - :return: Integer epoch time + :param dt: A datetime object in local time. + :type dt: datetime + :return: A UTC timestamp for passing to 2030.5 server. + :rtype: int """ - return int(calendar.timegm(dt.timetuple())) + # Leaving these commented out as a guide to how we got the answer to the issue. + # _log.debug(f"Start with dt: {dt} at {int(dt.timestamp())}") + # _log.debug(f"get date from ts: {datetime.fromtimestamp(int(dt.timestamp()))}") + gmt_date = datetime.utcfromtimestamp(int(dt.timestamp())) + # _log.debug(f"gmtdate {gmt_date} at {int(gmt_date.timestamp())}") + # _log.debug(f"get gmtdate back: {datetime.fromtimestamp(int(gmt_date.timestamp()))}") + + # _log.debug(f"Converting {dt} to epoch time gmtime") + return int(gmt_date.timestamp()) + update_sessions() dcap: m.DeviceCapability = get_from_server("dcap", deserialize=True) @@ -600,6 +610,10 @@ def submit_new_control(): wrapper.apply_to_parent() new_control.DERControlBase = der_base + _log.debug(f"Date Time Sending: {datetime.fromtimestamp(new_control.interval.start)}") + # Need to modify the time to be gmt time rather than in local time. + #new_control.interval.start = convert_datetime_to_int(new_control.interval.start) + #new_ctrl = m.DERControl(mRID="b234245afff", DERControlBase=dderc.DERControlBase, description="A new control is going here") #new_control.interval = m.DateTimeInterval(start=current_time + 10, duration=20) _log.debug(dataclass_to_xml(new_control)) @@ -618,9 +632,9 @@ def set_date(obj, prop, e): with ui.row(): with ui.column(): - interval_wrapper = PropertyWrapper(m.DateTimeInterval(duration=60, start=datetime.now() + timedelta(seconds=120)), + interval_wrapper = PropertyWrapper(m.DateTimeInterval(duration=30, start=datetime.now() + timedelta(seconds=30)), new_control, "interval", formatters=dict(start=parse_timestamp_string), - applyers=dict(start=convert_datetime_to_int)) + applyers=dict(start=convert_local_dt_to_utc_timestamp)) wrappers.append(interval_wrapper) from_date = ui.input("Event Start", value=getattr(interval_wrapper, "start"), on_change=lambda e: set_date(interval_wrapper, "start", e)) \ @@ -701,7 +715,7 @@ def set_date(obj, prop, e): with ui.header(): current_time_label = ui.label("Current Time") ui.timer(1.0, lambda: current_time_label.set_text( - f"Local Time: {datetime.now().isoformat()} Epoche: {convert_datetime_to_int(datetime.utcnow())}")) + f"Local Time: {datetime.now().isoformat()} GMT TS: {convert_local_dt_to_utc_timestamp(datetime.now())}")) with ui.tabs().classes('w-full') as tabs: configuration_tab = ui.tab("configuration", "Configuration") der_default_control_tab = ui.tab("derdefaultcontrol", "DER Default Control") From e4378f2a9fd739060db30ee1b600560eeab8d2b8 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Tue, 17 Oct 2023 11:22:30 -0700 Subject: [PATCH 46/53] Create table for events --- services/core/IEEE_2030_5/demo/webgui.py | 67 ++++++++++++------- .../core/IEEE_2030_5/ieee_2030_5/client.py | 2 +- 2 files changed, 42 insertions(+), 27 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index 0602042041..e492ca067a 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -3,7 +3,7 @@ import calendar from copy import deepcopy - +from pprint import pformat import os from parser import ParserError @@ -137,8 +137,6 @@ def __init__(self, backing_obj: T, parent_obj: S, parent_property: str, m.ActivePower, m.FixedVar, m.FixedPointType, m.ReactivePower, m.AmpereHour, m.WattHour)): self.backing_obj.__dict__["value"] = self.parent_obj.__dict__[self.parent_property] - - _log.debug(f"Creating Property Wrapper for parent {type(parent_obj)} with backing object {type(backing_obj)} on property {parent_property}") def __setattr__(self, key: str, value: Any): if key in ("backing_obj", "parent_obj", "parent_property", "formatters", "appliers"): @@ -506,7 +504,9 @@ def do_refresh(): control_list: m.DERControlList = get_from_server(program.DERControlListLink.href, deserialize=True) - active_list: m.DERControlList = get_from_server(program.ActiveDERControlListLink.href, deserialize=True) + + #active_list: m.DERControlList = get_from_server(program.ActiveDERControlListLink.href, deserialize=True) + with ui.row(): with ui.column(): with ui.label("DER Control List").style("font-size: 200%;"): @@ -517,7 +517,8 @@ def do_refresh(): columns = [ {'name': 'time', 'label': 'Event Time', 'field': 'time', 'required': True}, {'name': 'duration', 'label': 'Event Duration', 'field': 'duration', 'required': True}, - {'name': 'status', 'label': 'Event Status', 'field': 'status', 'required': True} + {'name': 'status', 'label': 'Event Status', 'field': 'status', 'required': True}, + {'name': 'control', 'label': 'Control', 'field': 'control', 'required': True} ] @@ -530,50 +531,64 @@ def status_to_string(status: int): return "Cancelled" elif status == 3: return "Supersceded" + elif status == 5: + return "Completed" else: return "Unknown" - def build_list_rows(ctrl_list: m.DERControlList, filter_status: int = None): - control_list_rows = [] - for ctrl in control_list.DERControl: + def build_list_rows(ctrl_list: m.DERControlList): + control_list_rows = [] + def nonnone(control: m.DERControl): + dct = {} + + for obj, val in control.DERControlBase.__dict__.items(): + if val is not None: + if hasattr(val, "value"): + val = val.value + elif hasattr(val, "displacement"): + val = val.displacement + dct[obj] = val + return pformat(dct) + + for ctrl in ctrl_list.DERControl: if ctrl.interval: if ctrl.EventStatus is None and ctrl.interval.start and ctrl.interval.duration: ctrl.EventStatus = m.EventStatus(currentStatus=0) # Scheduled. local_dt = datetime_from_utc_to_local(datetime.utcfromtimestamp(ctrl.interval.start)) row = { - 'time': ctrl.interval.start, + 'time': local_dt, 'duration': ctrl.interval.duration, - 'status': status_to_string(ctrl.EventStatus.currentStatus) + 'status': status_to_string(ctrl.EventStatus.currentStatus), + 'control': nonnone(ctrl) } - if filter_status is None or ctrl.EventStatus.currentStatus == filter_status: - control_list_rows.append(row) + control_list_rows.append(row) return control_list_rows with ui.row(): with ui.column(): - ui.label("Active Controls").style("font-size: 150%") + ui.label("Control Events").style("font-size: 150%") - with ui.row(): - with ui.column(): - ui.table(columns=columns, rows=build_list_rows(active_list, 1)) + # with ui.row(): + # with ui.column(): + # ui.table(columns=columns, rows=build_list_rows(active_list, 1)) - with ui.row(): - with ui.column(): - ui.label("Scheduled Controls").style("font-size: 150%") + # with ui.row(): + # with ui.column(): + # ui.label("Scheduled Controls").style("font-size: 150%") with ui.row(): with ui.column(): - ui.table(columns=columns, rows=build_list_rows(control_list, 0)) + ui.table(columns=columns, rows=build_list_rows(control_list)) - with ui.row(): - with ui.column(): - ui.label("Completed Controls").style("font-size: 150%") + # with ui.row(): + # with ui.column(): + # ui.label("Completed Controls").style("font-size: 150%") - with ui.row(): - with ui.column(): - ui.table(columns=columns, rows=build_list_rows(control_list, 5)) + # with ui.row(): + # with ui.column(): + # ui.table(columns=columns, rows=build_list_rows(control_list, 5)) @ui.refreshable diff --git a/services/core/IEEE_2030_5/ieee_2030_5/client.py b/services/core/IEEE_2030_5/ieee_2030_5/client.py index 57d47acad2..e77a671580 100644 --- a/services/core/IEEE_2030_5/ieee_2030_5/client.py +++ b/services/core/IEEE_2030_5/ieee_2030_5/client.py @@ -493,7 +493,7 @@ def __hash__(self) -> int: def is_end_device_registered(self, end_device: m.EndDevice, pin: int) -> bool: reg = self.registration(end_device) - return reg.pIN == pin + return reg.pIN == self._pin def new_uuid(self, url: str = "/uuid") -> str: res = self.__get_request__(url) From 544e73f862419ee90d57034552a50e0da5d90b70 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Tue, 17 Oct 2023 11:24:08 -0700 Subject: [PATCH 47/53] Update invert to publish less for testing. --- .../core/IEEE_2030_5/demo/inverter_runner.py | 36 +++++++++++-------- services/core/IEEE_2030_5/demo/server.yml | 10 ++++-- services/core/IEEE_2030_5/tests/new_event.py | 19 +++++++++- 3 files changed, 46 insertions(+), 19 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/inverter_runner.py b/services/core/IEEE_2030_5/demo/inverter_runner.py index e6e7452ca3..a50de5942e 100644 --- a/services/core/IEEE_2030_5/demo/inverter_runner.py +++ b/services/core/IEEE_2030_5/demo/inverter_runner.py @@ -26,19 +26,19 @@ class MyInverterAgent(Agent): def __init__(self, **kwargs): super().__init__(**kwargs) - self._points = {} - self._points['pf'] = 0.99 - self._generator = None @RPC.export def set_point(self, point, value): - self._generator = None + _log.debug(f"Setting {point} to {value}") self._points[point] = value @RPC.export def get_point(self, point): return self._points.get(point) + + def get_all_points(self): + return self._points.keys() @property def reset(self): @@ -90,19 +90,18 @@ def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Genera results = dict(PF=PF, INV_REAL_PWR=p_ac, INV_REAC_PWR=q_ac, - v_mp=dc['v_mp'], - p_mp=dc['p_mp'], - i_x=dc['i_x'], - i_xx=dc['i_xx'], - v_oc=dc['v_oc'], - i_sc=dc['i_sc'], + #v_mp=dc['v_mp'], + #p_mp=dc['p_mp'], + #i_x=dc['i_x'], + #i_xx=dc['i_xx'], + #v_oc=dc['v_oc'], + #i_sc=dc['i_sc'], s_ac=p_ac, #v_ac=v_ac, BAT_SOC=v_ac/p_ac, - i_ac=i_ac, + #i_ac=i_ac, target_p=p_ac, INV_OP_STATUS_MODE=3) - _log.info(json.dumps(results)) yield results # single phase circuit calculation @@ -138,9 +137,7 @@ def frombus(message: List) -> AllPoints: parser.add_argument("output_file", help="File to write to when data arrives on the bus") opts = parser.parse_args() - logging.basicConfig(filename="/tmp/inverter_runner.log", - filemode="wt", - level=logging.DEBUG, + logging.basicConfig(level=logging.DEBUG, force=True ) @@ -167,6 +164,14 @@ def frombus(message: List) -> AllPoints: for inv in gen: points = AllPoints() + agent_points = agent.get_all_points() + + for k in agent_points: + if k in inv: + points.add(k, inv[k]) + else: + points.add(k, agent.get_point(k)) + # Loop over points adding them to the allpoints dataclass if # they are specified. If they have been set on the agent itself # then use that value instead of the one from the generator. @@ -184,6 +189,7 @@ def frombus(message: List) -> AllPoints: } + _log.info(f"Publishing {points.points}") # publish agent.vip.pubsub.publish(peer="pubsub", topic=f"{topic_to_publish}", diff --git a/services/core/IEEE_2030_5/demo/server.yml b/services/core/IEEE_2030_5/demo/server.yml index e57df4fe93..6c667e30fa 100644 --- a/services/core/IEEE_2030_5/demo/server.yml +++ b/services/core/IEEE_2030_5/demo/server.yml @@ -39,8 +39,10 @@ storage_path: data_store devices: # SolarEdge SE6000H HD-Wave SetApp Enabled Inverter - id: dev1 - # DeviceCategoryType from ieee_2030_5.models.device_category - deviceCategory: FUEL_CELL + # DeviceCategoryType from ieee_2030_5.models.DeviceCategoryType + device_categories: + - OTHER_STORAGE_SYSTEMS + - OTHER_GENERATION_SYSTEMS pin: 111115 fsas: - fsa1 @@ -51,7 +53,9 @@ devices: - Program 1 - id: dev2 - deviceCategory: FUEL_CELL + device_categories: + - OTHER_STORAGE_SYSTEMS + - OTHER_GENERATION_SYSTEMS pin: 111111 fsas: - fsa2 diff --git a/services/core/IEEE_2030_5/tests/new_event.py b/services/core/IEEE_2030_5/tests/new_event.py index f070cd9b4b..2b9c35f16c 100644 --- a/services/core/IEEE_2030_5/tests/new_event.py +++ b/services/core/IEEE_2030_5/tests/new_event.py @@ -30,7 +30,7 @@ def print_it(thing: str, obj: object): print_it("DERList", derl) der: m.DER = derl.DER[0] -current_program = get_as_device(der.CurrentDERProgramLink.href) +current_program: m.DERProgram = get_as_device(der.CurrentDERProgramLink.href) print_it("CurrentDERProgram", current_program) dderc: m.DefaultDERControl = get_as_device(current_program.DefaultDERControlLink.href) @@ -46,4 +46,21 @@ def print_it(thing: str, obj: object): new_ctrl.interval = m.DateTimeInterval(start=current_time + 5, duration=30) new_ctrl.DERControlBase.opModTargetW = m.ActivePower(3, 2000) print_it("New Control is", new_ctrl) +print(f"{dataclass_to_xml(new_ctrl)}") response = post_as_admin(dercl.href, data=dataclass_to_xml(new_ctrl)) + +print("Right before controls start") +dercl: m.DERControlList = get_as_device(current_program.DERControlListLink.href) +print_it("DERControlList", dercl) +activectl: m.DERControlList = get_as_device(current_program.ActiveDERControlListLink.href) +print("Should not have an active control.") +print_it("ActiveDERControlList", activectl) +print("Sleeping 10 seconds until control has started") +time.sleep(10) +activectl: m.DERControlList = get_as_device(current_program.ActiveDERControlListLink.href) +print("Active control should have started!") +print_it("ActiveDERControlList", activectl) +time.sleep(35) +activectl: m.DERControlList = get_as_device(current_program.ActiveDERControlListLink.href) +print("Event should be over now") +print_it("ActiveDERControlList", activectl) \ No newline at end of file From dbd4c5c412532a5d3788da80fc2f6ac9b37713f4 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Tue, 17 Oct 2023 11:31:49 -0700 Subject: [PATCH 48/53] reverse sort start date --- services/core/IEEE_2030_5/demo/webgui.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index e492ca067a..ef55abdde3 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -550,7 +550,7 @@ def nonnone(control: m.DERControl): dct[obj] = val return pformat(dct) - for ctrl in ctrl_list.DERControl: + for ctrl in sorted(ctrl_list.DERControl, key=lambda x: x.interval.start, reverse=True): if ctrl.interval: if ctrl.EventStatus is None and ctrl.interval.start and ctrl.interval.duration: ctrl.EventStatus = m.EventStatus(currentStatus=0) # Scheduled. @@ -761,14 +761,14 @@ def set_date(obj, prop, e): with ui.tab_panel(der_control_list_tab): render_der_control_list_tab() - ui.timer(30, lambda: render_der_control_list_tab.refresh()) + ui.timer(10, lambda: render_der_control_list_tab.refresh()) # ui.timer(10, lambda: render_der_default_control_tab.refresh()) with ui.tab_panel(der_status_tab): render_der_status_tab() -logging.basicConfig(level=logging.DEBUG) +logging.basicConfig(level=logging.INFO) excludes = '.*, .py[cod], .sw.*, ~*,*.git,' ui.run(reload=True, show=False, uvicorn_reload_excludes=excludes) From b61be1847bc14a2962e2ead7077bfcf117d02225 Mon Sep 17 00:00:00 2001 From: C <3979063+craig8@users.noreply.github.com> Date: Tue, 17 Oct 2023 11:47:53 -0700 Subject: [PATCH 49/53] Inverter sample now shows % --- .../core/IEEE_2030_5/demo/inverter_runner.py | 2 +- services/core/IEEE_2030_5/demo/webgui.py | 4 -- services/core/IEEE_2030_5/inverter_sample.csv | 66 +++++++++++++++++++ 3 files changed, 67 insertions(+), 5 deletions(-) create mode 100644 services/core/IEEE_2030_5/inverter_sample.csv diff --git a/services/core/IEEE_2030_5/demo/inverter_runner.py b/services/core/IEEE_2030_5/demo/inverter_runner.py index a50de5942e..fec5140175 100644 --- a/services/core/IEEE_2030_5/demo/inverter_runner.py +++ b/services/core/IEEE_2030_5/demo/inverter_runner.py @@ -98,7 +98,7 @@ def run_inverter(timesteps=50, pf=0.99, latitude=32, longitude=-111.0) -> Genera #i_sc=dc['i_sc'], s_ac=p_ac, #v_ac=v_ac, - BAT_SOC=v_ac/p_ac, + BAT_SOC=int(v_ac/p_ac), #i_ac=i_ac, target_p=p_ac, INV_OP_STATUS_MODE=3) diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index ef55abdde3..40f09218ba 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -492,9 +492,6 @@ def do_refresh(): with ui.row(): with ui.column(): ui.table(columns=columns, rows=rows) - - - @ui.refreshable def render_der_control_list_tab(): @@ -762,7 +759,6 @@ def set_date(obj, prop, e): with ui.tab_panel(der_control_list_tab): render_der_control_list_tab() ui.timer(10, lambda: render_der_control_list_tab.refresh()) - # ui.timer(10, lambda: render_der_default_control_tab.refresh()) with ui.tab_panel(der_status_tab): render_der_status_tab() diff --git a/services/core/IEEE_2030_5/inverter_sample.csv b/services/core/IEEE_2030_5/inverter_sample.csv new file mode 100644 index 0000000000..bfe5f41d57 --- /dev/null +++ b/services/core/IEEE_2030_5/inverter_sample.csv @@ -0,0 +1,66 @@ +Point Name,Description,Multiplier,MRID,Offset,Parameter Type,Notes +,,,,,DERCapability::rtgMaxW,DERCapabilities are not generally writable but the corresponding setting is. +,,,,,DERCapability::rtgOverExcitedW, +,,,,,DERCapability::rtgOverExcitedPF, +,,,,,DERCapability::rtgUnderExcitedW, +,,,,,DERCapability::rtgUnderExcitedPF, +,,,,,DERCapability::rtgMaxVA, +,,,,,DERCapability::rtgNormalCategory, +,,,,,DERCapability::rtgAbnormalCategory, +,,,,,DERCapability::rtgMaxVar, +,,,,,DERCapability::rtgMaxVarNeg, +,,,,,DERCapability::rtgMaxChargeRateW, +,,,,,DERCapability::rtgMaxChargeRateVA, +,,,,,DERCapability::rtgVNom, +,,,,,DERCapability::rtgMaxV, +,,,,,DERCapability::rtgMinV, +,,,,,DERCapability::modesSupported, +,,,,,DERCapability::rtgReactiveSusceptance, +,,,,,DERStatus::alarmStatus,"Bitmap Position (0 = over current, 1 over voltage, 2 under voltage, 3 over frequency, 4 under frequency, 5 voltage imbalance, 6 current imbalance, 7 emergency local, 8 emergency remote, 9 low power input, 10 phase rotation)" +,,,,,DERStatus::genConnectStatus,"DER Generator Status (0 = Connected, 1 = Available, 2 = Operating, 3 = Test, 4 = Fault/Error)" +,,,,,DERStatus::inverterStatus,"DER Inverter Status (0 = Connected, 1 = Available, 2 = Operating, 3 = Test, 4 = Fault/Error)" +,,,,,DERStatus::localControlModeStatus,0 = local control 1 = remote control +,,,,,DERStatus::manufacturerStatus,A manufacturer status code string +,,,,,DERStatus::operationalModeStatus,"DER OperationalModeStatus (0 = Not applicable, 1 = Off, 2 = Operational, 3 = Test)" +BAT_SOC,,,,,DERStatus::stateOfChargeStatus,DER StateOfChargeStatus % of charge +,,,,,DERStatus::storageModeStatus,"DER StorageModeStatus (0 = Charging, 1 = Discharging, 2 = Holding)" +,,,,,DERStatus::storConnectStatus,"DER Storage Status (0 = Connected, 1 = Available, 2 = Operating, 3 = Test, 4 = Fault/Error)" +,,,,,DERSettings::setESHighVolt, +,,,,,DERSettings::setESLowVolt, +,,,,,DERSettings::setESHighFreq, +,,,,,DERSettings::setESLowFreq, +,,,,,DERSettings::setESDelay, +,,,,,DERSettings::setESRandomDelay, +,,,,,DERSettings::setESRampTms, +,,,,,DefaultDERControl::setESDelay, +freq_max,,,,,DefaultDERControl::setESHighFreq, +volt_max,,,,,DefaultDERControl::setESHighVolt, +freq_min,,,,,DefaultDERControl::setESLowFreq, +volt_min,,,,,DefaultDERControl::setESLowVolt, +,,,,,DefaultDERControl::setESRampTms, +,,,,,DefaultDERControl::setESRandomDelay, +,,,,,DefaultDERControl::setGradW, +,,,,,DefaultDERControl::setSoftGradW, +connected,,,,,DERControlBase::opModConnect,"True/False Connected = True, Disconnected = False" +energized,,,,,DERControlBase::opModEnergize,"True/False Energized = True, De-Energized = False" +,,,,,DERControlBase::opModFixedPFAbsorbW, +,,,,,DERControlBase::opModFixedPFInjectW, +fixed_var,,,,,DERControlBase::opModFixedVar, +fixed_w,,,,,DERControlBase::opModFixedW, +,,,,,DERControlBase::opModFreqDroop, +,,,,,DERControlBase::opModFreqWatt, +,,,,,DERControlBase::opModHFRTMayTrip, +,,,,,DERControlBase::opModHFRTMustTrip, +,,,,,DERControlBase::opModHVRTMomentaryCessation, +,,,,,DERControlBase::opModHVRTMustTrip, +,,,,,DERControlBase::opModLFRTMayTrip, +,,,,,DERControlBase::opModLVRTMomentaryCessation, +,,,,,DERControlBase::opModLVRTMustTrip, +max_w,,,,,DERControlBase::opModMaxLimW, +,,,,,DERControlBase::opModTargetVar, +target_p,Target Real Power,,,,DERControlBase::opModTargetW, +,,,,,DERControlBase::opModVoltVar, +,,,,,DERControlBase:opModVoltWatt, +,,,,,DERControlBase::opModWattPF, +,,,,,DERControlBase::opModWattVar, +,,,,,DERControlBase::rampTms, From b575ae2a43f65b9ca5ee194a143e34a6bf584aed Mon Sep 17 00:00:00 2001 From: Craig <3979063+craig8@users.noreply.github.com> Date: Tue, 17 Oct 2023 20:14:56 +0000 Subject: [PATCH 50/53] Show the ui when run. --- services/core/IEEE_2030_5/demo/webgui.py | 27 +++++++++++------------- 1 file changed, 12 insertions(+), 15 deletions(-) diff --git a/services/core/IEEE_2030_5/demo/webgui.py b/services/core/IEEE_2030_5/demo/webgui.py index 40f09218ba..43066dfd85 100644 --- a/services/core/IEEE_2030_5/demo/webgui.py +++ b/services/core/IEEE_2030_5/demo/webgui.py @@ -2,29 +2,27 @@ from __future__ import annotations import calendar -from copy import deepcopy -from pprint import pformat +import logging import os -from parser import ParserError - import re - import sys import time import uuid -import urllib3 +from copy import deepcopy from dataclasses import dataclass, field, fields from datetime import datetime, timedelta +from numbers import Number +from parser import ParserError from pathlib import Path +from pprint import pformat from typing import Any, Callable, Dict, List, TypeVar -import logging + +import pandas as pd +import plotly.express as px +import plotly.graph_objects as go +import urllib3 import xsdata import yaml -import plotly.graph_objects as go -import plotly.express as px -import pandas as pd -from numbers import Number -import re from volttron.platform import get_volttron_root from volttron.platform.agent.utils import parse_timestamp_string, process_timestamp @@ -37,9 +35,8 @@ import ieee_2030_5.models as m import requests -from nicegui import app, background_tasks, ui - from ieee_2030_5 import dataclass_to_xml, xml_to_dataclass +from nicegui import app, background_tasks, ui logging.getLogger("urllib3.connectionpool").setLevel(logging.INFO) _log = logging.getLogger(__name__) @@ -767,4 +764,4 @@ def set_date(obj, prop, e): logging.basicConfig(level=logging.INFO) excludes = '.*, .py[cod], .sw.*, ~*,*.git,' -ui.run(reload=True, show=False, uvicorn_reload_excludes=excludes) +ui.run(reload=False, show=True, uvicorn_reload_excludes=excludes) From 8609ac8644fc9effe0840f891f04911238ad2883 Mon Sep 17 00:00:00 2001 From: Craig <3979063+craig8@users.noreply.github.com> Date: Tue, 17 Oct 2023 20:37:33 +0000 Subject: [PATCH 51/53] Update Documentation --- services/core/IEEE_2030_5/AGENT_DEMO.md | 38 ++++++++++++++---- .../IEEE_2030_5/demo/images/configuration.png | Bin 0 -> 39189 bytes .../demo/images/control_active.png | Bin 14284 -> 0 bytes .../demo/images/control_complete.png | Bin 26071 -> 0 bytes .../IEEE_2030_5/demo/images/control_entry.png | Bin 0 -> 59742 bytes .../demo/images/control_list_active.png | Bin 0 -> 16641 bytes .../demo/images/control_list_complete.png | Bin 0 -> 14886 bytes .../demo/images/control_list_no_events.png | Bin 0 -> 27591 bytes .../demo/images/control_list_scheduled.png | Bin 0 -> 33866 bytes .../demo/images/control_scheduled.png | Bin 13992 -> 0 bytes .../demo/images/default_control.png | Bin 0 -> 75494 bytes .../demo/images/initial_conditions.png | Bin 12323 -> 0 bytes .../demo/images/start_agent_and_inverter.png | Bin 13766 -> 0 bytes 13 files changed, 30 insertions(+), 8 deletions(-) create mode 100644 services/core/IEEE_2030_5/demo/images/configuration.png delete mode 100644 services/core/IEEE_2030_5/demo/images/control_active.png delete mode 100644 services/core/IEEE_2030_5/demo/images/control_complete.png create mode 100644 services/core/IEEE_2030_5/demo/images/control_entry.png create mode 100644 services/core/IEEE_2030_5/demo/images/control_list_active.png create mode 100644 services/core/IEEE_2030_5/demo/images/control_list_complete.png create mode 100644 services/core/IEEE_2030_5/demo/images/control_list_no_events.png create mode 100644 services/core/IEEE_2030_5/demo/images/control_list_scheduled.png delete mode 100644 services/core/IEEE_2030_5/demo/images/control_scheduled.png create mode 100644 services/core/IEEE_2030_5/demo/images/default_control.png delete mode 100644 services/core/IEEE_2030_5/demo/images/initial_conditions.png delete mode 100644 services/core/IEEE_2030_5/demo/images/start_agent_and_inverter.png diff --git a/services/core/IEEE_2030_5/AGENT_DEMO.md b/services/core/IEEE_2030_5/AGENT_DEMO.md index 2217bf7365..56dbcbd088 100644 --- a/services/core/IEEE_2030_5/AGENT_DEMO.md +++ b/services/core/IEEE_2030_5/AGENT_DEMO.md @@ -60,6 +60,27 @@ For this demo, start a VOLTTRON default instance from the command line. The fol (volttron)> tail -f volttron.log ``` +1. Open another terminal to install the 2030.5 agent and add it's property map to the configuration store. + + ```bash + > cd $VOLTTRON_ROOT + > source env/bin/activate + (volttron)> vctl install services/core/IEEE_2030_5/ --vip-identity ed1 --agent-config services/core/IEEE_2030_5/example.config.yml + (volttron)> vctl config store ed1 inverter_sample.csv services/core/IEEE_2030_5/inverter_sample.csv --csv + ``` + + Note ed1 is the identity that needs to be in the configuration on the web demo + +1. Open another terminal to run a simulated platform.driver. In this case, an inverter with a connected battery is being simulated. + + ```bash + > cd $VOLTTRON_ROOT + > source env/bin/activate + (volttron)> python services/core/IEEE_2030_5/demo/inverter_runner.py + ``` + + This process will start publishing "all" messages for the inverter to the VOLTTRON message bus. + 1. Open another terminal to start the demo server in. ```bash @@ -78,18 +99,19 @@ For this demo, start a VOLTTRON default instance from the command line. The fol ## The Demo -The initial demo screen. +The demo starts with local time in the top followed by 2030.5's GMT time as a intenger. The integer is how 2030.5 communicates datetimes within the protocol. Five tabs are displayable and are +pictured below: -![Startup Page](./demo/images/initial_conditions.png) +![Configuration Tab](./demo/images/configuration.png) -Clicking on the Start Inverter and Start Agent buttons the status of Real and Reactive power should update based upon what is posted to the MirrorUsagePoints. +![DER Default Control](./demo/images/default_control.png) -![Agent and Inverter Started](./demo/images/start_agent_and_inverter.png) +![New DER Control](./demo/images/control_entry.png) -Changing the power factor to 80 and clicking on the Change Power Factor button (3) will show the scheduling, activating and completion of the event. +![DER Control List - No Events](./demo/images/control_list_no_events.png) -![Scheduling Events Schedule](./demo/images/control_scheduled.png) +![DER Control List - Scheduled](./demo/images/control_list_scheduled.png) -![Scheduling Events Active](./demo/images/control_active.png) +![DER Control List - Active](./demo/images/control_list_active.png) -![Scheduling Events Complete](./demo/images/control_complete.png) +![DER Control List - Complete](./demo/images/control_list_complete.png) diff --git a/services/core/IEEE_2030_5/demo/images/configuration.png b/services/core/IEEE_2030_5/demo/images/configuration.png new file mode 100644 index 0000000000000000000000000000000000000000..ab893c7c6bef642ad44a603a17518725f63f5f1e GIT binary patch literal 39189 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 literal 0 HcmV?d00001 diff --git a/services/core/IEEE_2030_5/demo/images/control_active.png b/services/core/IEEE_2030_5/demo/images/control_active.png deleted file mode 100644 index 541d14cf09f345226677ac08c5fd0f6da5b68c9a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14284 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 literal 0 HcmV?d00001 diff --git a/services/core/IEEE_2030_5/demo/images/control_list_complete.png b/services/core/IEEE_2030_5/demo/images/control_list_complete.png new file mode 100644 index 0000000000000000000000000000000000000000..afaf1f9d9f07d06d0e5c7579912af7c494b0ab69 GIT binary patch literal 14886 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 An*aa+ literal 0 HcmV?d00001 diff --git a/services/core/IEEE_2030_5/demo/images/control_list_no_events.png b/services/core/IEEE_2030_5/demo/images/control_list_no_events.png new file mode 100644 index 0000000000000000000000000000000000000000..2251299a609aef0f11c484f2a6b2ba2736277fa8 GIT binary patch literal 27591 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 z zXyh)FSafiXk|Li$NS9|!4bV2ik2oKsVQEp%5uR_gBM2OSJZf+j$^kPaX@rtBl?{i@Wk$doPom!GGy*#xkFIiY5Ht59z)-1HV2|%6cKmI?Ph3 z4ec&oF$Q>>{xtiV%T_%MrBhNA`h>E$&pB=vWMihbAvwek>LW09BymY^Qd?C$N4)>0 zFOAJ}`S?L`>@dROh=Ds<{jqU!p3 z$Xlb->F;HNpAK(boB6aL`}LSBJ9Q!DrJ`j+rA0QRG(rhT7~MhBTxwRn?9{#ReBrSW zixY;JU+;@#kHSOZZBzNIcAT8Y^x}XIl~NbJLjM`~R&7lGA>=mgV99WUgc~2p(Rrf^u#69-XfTi;y@}J9UpicNQ~9Pq9^`4L2QMWQjwlVv?#* z#^e;?E_ywd*|v^jd#%E?^^0UGpmdQjvl)c&;i5s#6q zHN8~sTbj%>UgNqJ`=@&F`_C>@)d&2Rd=#u%mXcdjZ)*+Uw^Z~dWd%zN2@gOx#rVVp+;}FTyK;_$=v%>v$fc?|y5^?h354&umOCpql(Gdaf#aF}ybXq7vi)fX{=PVdwY9)+1-|7$3LzVEoxlMB5>e|P+82yMO_ zb{uA70u^&?5_(^hb_BTQ%oK8_*_!Yc#6SL6w=xySTbdFf+e+Pkl2P;8)+4`Eqhwr+ zhK&{Rh@PTpvQHBA zVv|lT0~hX3oA9rJD3gtwzbO{GIreqg;_mpXBdWiNg?0_*Yr%8x8&3#P4AgIWSm;{|Me{Ag>;mQQ6)BGVt^d}h8>E@=8IFX)a_J@P#gUnO<=dbNAXT`b^VWC zkr>`9@^SGbuJHPQRQeJv-~Ah(O}-@EkK^WL^Oc5wNEkT!JvZs}T_qU_%iH{2oi{?H zqMrYyyV?T^`1zh@v(IY6`E~%p=YN98{}m`BPB(-$eX;E!##Pn`_e7xVf8jLLdFz8O z$?*S+z8sfZez9ukD1w~M&fZ>C>2!_fvL*)53UXroFEsuFyH0u_0NY=Do<^fc3Lds+ zS_Qbm&cC0Zq7V(lO^KXJwQ3d;nlE-9llrTS{xX+fznkhBBJp1jVen>U<5C!*n#i|0 zlmp?q_!IpI5OTB?Wg=nKo@!-Kjgw`p4I|wnKjd!|v0)coICnuf^FBKQwiX=ABJlC& zdufO|+EX#`?k8>O_9!dO>QdB%l#|)hNAE6IYjWyxff;w)HswK6>4dLiMMZy?wmGaWL4hIN4H4_t|`l zs$ZA1EL_OEwqi+vD~{>==gDTP8=9J>Lj)mtrJuIb9e*tCzd;PzT3f65D@zM$s-QDV zHI{3<+!LsglNqsqi8uJ^57c)GB{nhA!Uolje)gXvmiuKMV(+m49*JpwpR>=9@QTlK zg#juw>dmByE4LFpcAw|P6)zQ7x~v3`pHr>q%Sqk`2{6sT9v@k}Qu0GmU|G61e>cED zwi4~%jwH5kiRvQXVDsbhL|^XiIi#uXDVYo^)izX8IG)oq*uRL36gSS8YBoNWIo%Oj{y!sw9Y+=1FZ^rK#;ITk( ziVL@bidq7d&<{0WjYL1Y=l}RR*ZzLRdYWL^4MpRzcBU0bX z@AD@P1$DdasIzR9yVz4Q6;e1*rTeOmkxch4c}J@Do2BI_k(^NDb}U%=JfE^Cuun;JtYtRWU8bn3?he?Y-LvAhEJpHkIK$M z!4|hdv^l5o%V}zZj>_K+BnilOj0poMBp6@U45J&67if=%A7_>#JByP$&y+QvTS|j! zH82N!c_uz$+c?Pln9e_S8(HQDxN#rBpux=Umv_h@`f^H-0G*;G(uNbavI$aYIvLKY2Yl zH}lJAXA%dsi)_Ds%WF!9L+X?o#^HgV0~v+Mw(akGY!=KP4Nd$A%21R}18kbKx9}nx z7UQz()45-;`C`)tz-C^y8vTt@DeFU?wTreln+0kd1Pn%PA1Et7h=hF_;a=}|6=Y-- zTz-q(Nzq{0U`y&VeyIBI|->;Z{3Ddlnb?0yJZd% z96mUXBpdeu2DaBteL`>Jl0EhnH%PlzKM>LCec&8(&9rVy)3}gFX67_NjbJL3P+Kd( zaiF+{41Qc|j6r;2$-)u~?-*+6_1lV6oTp#!vEs%sN>^&gXyYFI$mB|xUcs&oY%&5;=L zPaMW-_Etr1upP@tNvE?<&(uPjhWqz4<1b3=vD1Yf9=Y8Q`3iN&j~2?{|>pggV?z?dbfb<&<%A`7H`avb$FeM2mV^&#oPy zuZNJ^AJ0Bw34=T7b0mt%EAw{gYG<~jCw~Xs5G0FmF+jJ!Iv+1&apSlDUH9evvz69E z>0I~J9Zw#moU3szI*!!jB_61c+QcP;E{QtS<9-sJlEIy6vFqwcje@(WN}ro@#486m zi!wv@B#ZR_0Ea$sO^@$Xd9df%@^6dh@NXYXbsWgYQ-x31zYet6FSeIr9DI42@h@8s z<)h>2SFfz&cQ)!5X`H4q8YZqbUT{?yV}U^MSdlSj&)RnmKMvp zVz!p1k$Id!it6H5neBj8Zs@eFnE+g5($}>$G<4c3Y>5Zn^rNaDM^{)r})S$&cl zjIGL|-J9R3Uhyy2^w+{}Y?s;rj{TGl?0(T@x$0z|#?I__fFPf|76i0&)O9Hel|1)o zLV9jgv+&iG~yQi zgcfC!oX;gGy|X>-QbInC&?2Sf<|rR`jD>?TrcBp5 z72icTvdU7F6d2p)e9-zc3sc+b7!D4c%=S>;xiT}{uyyaNWrj3IWEIu8imMJ&SH@e^ z6m2$jRG*M!kDzBxE=a*O8-2<%xVF3dE`+^;LuHMkM_vK2MxFj1>ZJ(y{2O4+F}Jvi z+tPKrDHG4=DDvZxhT_EY1a7BAljkpk8ACujlaV$q`l0CVJJc>nF&6c$CS<@?$nAzM z#cd8XKJXxPUx+V5+@5RjkLs$ebE0KYGxgR#5uU%O9Y?l!2#+%897rWn<`m(IMPGOf z8hcjyp>@$u`|I!J(b=!xki6UMDh+BZTaSybX3;bAfIPesijfh{eNjh{kCCrj*P4lo zE2|9^Y%z0Z!6PAw2{Fn!Risncx@U(fj z@Fyr%v1e`|>y^#1BIvi*M0QLRVbiuYck{M`xBO*-e##Y&=tJh2udfdE$cn0p{Dz)! zTM0CrcQw_=X#&?Jt>h?#mctGPhwMcgNO6YU@WVijU82S3z1+ZyC zJdf71@yAZ2{|#^iLwcWAfJAjFCNP?r`+5Gt-p^r)3H{rii7GGIUU1g>>AkuN5QL~b zIXq^06#CFIlP`wM)s}j+M)Ro4xi^$EGchYvLGb~hC&NfZy3TcSTEMw-=JP{}`@5($ zB@k$$A&a^#geM)feH2*a0qY&5s+v`({SPs9LsO20yz^5nsmZ zTg?QBgmt23rG@oBkSrPCGl%@q<-3PF8~@M*5THBgKQZzsm9|_f&|3#|o`@^~pyVX| zv0t`fcZbOGWnK0>=d-oiNKnp9))zby8AF2!9>#~{zh5c&lRYaEjLSYNEVWcWObe}n zvi)#P95Ah{evTjJlI_F*a6!OF@1c*3hP9nzqMhBDZCb|>Sx79@oaod-*SVv%%w>IZ zv1&CpZrK{3GWa`2Dd(|_K#9;DbN5`M551w(DTduo zkvHDcjGA_He3`zHQaHfL0V(LcwcF@V#!(N$qjyh6N0~TX<+)nbYN!i`pXqAzp`S}J zq#CIQ;ff7&R-oFL&tBa)iP&G^CCuM<_{lx_9?`GYaGiZnNxNl-d!#Xu7P2tvskMjv zS?GE?Jlx+se~+iLOSZ&mnm??=?c3YDgeeK%)!OY(P=Ah+l2U@)R={z5-|PE1^FlWy zG5_aoPG9lAo$BhNWGgj8J|9q|(3{qLH*NVaCRmOnzeqDxrubR_*z?sX>9+;H<=RA$ zVwHoDQp-FKi@wdEUD_5dR~j$P2(s|vj=A-nfH_?lmP2N9z~*C zY(s643E$28(I#+K8>IW7W>jHJ(&nnRnrSIc-ehGB(=xd^}gMA?C zb6id~WWnWz%FC9m@4@Gq5@$`K8riAM`#_5DI`2{2@;<UFlY}`ITHluMKtvdW z8k2KGl+V!H>jyP6O{rEo>j_cr58V|;6Qg%)8*@vTLqT`-Zyv2&72~wt$3JKXPdxSz zcM^?o`o(@L&6~^wCZt!j+rgt#E z`Ntt8Tf!yy&N2^AC*27P?qu=kW9G~x%MTc8s97vCTjW^k!3wWx);qtI|54mmM@7}X z?IMnXqJUB&QX<_$N{R@Gl!QTpFmy=g5QB8e44u-QLrWta;?M{qIW*FZXAi#bIlp!O zIcuHuo$t&ad#%0qv!A`6zMt#9u6usWwm&_Rve8ydUz*wY)QNY=qv+6p-zTuFCSwgQ`$*u-PbbVh~ z`_HGAK`V0O{ci^9cJl%@ecTW6p3%~u;Vhr;t1{q@$k)C>*g=ig<6en@2m4z)JN2iZ zO6nr7m)+m~ouONRepI2=4T^3NkA_UE}cWoymk@`6j~(rS5s-A)z$mQs4N zc#YpSeHZe^JNwI*(@vzKFebZBM`!X>X+M%pP0V7KrooFehuc!TjxjrY(&;3;I!#;F z)4&AdKoWKp-IxOyw)LGi)-uzSJw4a=FMHTQkrg;u7c zukWCz+v5ug-<{FPvo)4lZSV5NxKxrns&;OVJy`3ofzx$c!vhv43eUdWmYac|z4W$h z{n;hu(YEU)Bxg?$W~DFe2g>U{)YI{BG=s?jcsEvF zO6Zf|D-LBu>M0P5!_7vP+~~T-(VW@i47t?mycRy%DLbmEIb(xAAWQ{wUU1rjil@|izWR2&8 zSoPBaNinZc_b+}Ungf+QTV;EuV(Rh~HyRDw#LTy(y=@n(zX@y2_PCFoJvslJyVLTy z%!!sDjbj|Lz_P-G@`Br-x)x{g2AnE9$6}hBg_Jp!-4?#avCI2Nq4iZ(mds;b0EvuRjl;Qh5m0zVd+KPX=Y4{^3vA#6jp z7iXx}PnJ-zPz3_}rnGm}sZ;JH)Y7QW4vopX(`Eeemc})4N;z-DtLyRhrsAS?ZdP&$ zmJT?PKeYx!HmosTJvrg0`jEwS1)^t1KPZzzuGPne^h*kGz)j<_KHSV$tIAMZ>wNLY z_$75Ld%fplC=(d~gBnx=t$p(-vIlVw&nuwdTnG7rPUk)zkg6=^ z3iJlNYyY)sSJYELH5Fq~wJhPt8)sr{_9sd)xv&-sZR6lfcL@@}3OG^{qUO48{}>;~ z6wx)LB}bpI>#`AYDNlMvB%3qhlS2yhm?pGn2lgR?_A_IQGRZwO!jH{>ZNic-*{e67s|7m~ocB(!g( z8pVpuPt?!)K1e`QOu~SAp_L?bSsiBS04~T#=V8s}90A4fF$gNDQ_T1d7>vRUde5uW zKblJj2hw4moS?Ugq^lKSZ(kFpiI0J}u*jbnKY7qO1nKuFT}k!pwut;$PClY@T-11b z^A=3Y`H?g2r%Dcblst^?rL8vPJ@;Nwe-%Cc6f473Zs2MeV%ILwaaQLf+d$=*nQL-Y z9DFKUu`s9D6f)<&yjyVy!cgY@^SpjtuAUL!OIcT=i$GI|Ipb{%3eL}c=lrB6E(F{( zoa8avw!0S?DN52y&Z28Qo%7ifA zU*){h(~*!pfl6dS-$-zW%A2Hx#JL%wvk*3QJ_kr94o%r1!f)#X9pd{|uP6b$9j7I> zoD)W8KN6l{@Brd33o@#S%pxWpkWfW0T$!Bx7|;7D}k^a2&C?8DKQJVWqhaI*+e zqLF2v{iJg6g!55isN{{wFlG=I%baN6W6gMp66C0SH{z5sa;BTs+$q7$RtXZ!ni zSpW1cd+!FyZ+Is+bj$sXW(CH?SP@n34ZiJ>KfjjAl%1)1-aaHVj)W{OJk<&r#d-~J ztf;Xx5U|T@>X~~94ReH5^2o3}x=hn(g7B|!Q5JxbLNEOUKWy(p?eTfB8>Y51j>8R4 zxX!qnmR5N7E4p=PP-xpfFJZl~oyw)+9XEc35Sfr5DOKQE{Ia*=@_OZANU-$L2arN# z0j9I~HKiA?DwC|0(iX4bkz%Mf6Fg~PpItz zDQM)*73&R0VRX}N!WIPZvEfKgD*HbFhjRsLVi{;9mzKVv{5+l|C(hI46x)=Yao1?b z^mF2kw9na#yL2_&zRXuT_v!Y*dmy1@;}OaP~R06@mT;4r81^S``D zlT>cpJr7bZvtn`2xF14BYkI04*dskGYm+v#;b|IU9YDt;@K$2=kZ9wF<&gZ&E*O}- zfZ~YwY)(pl)Jf@ivqk?K_UlEg$Ip#0n*=&DdmnMu@kxHEC{i37O_gKE3>woW>#uY{ zc^v)S#|v}I#xt(s@6bQ*V(UbEs2U%(L;(9nWWo^`f+OC6bX|7)8DGlj$DfW< zdf=ZwJUu)lwnEVTw%p}ABtG^mu_S6`1NrJ_IJ)Y+8Y0R%FH0J7k##4*Cb6~KwY9c* z4WCCn9C~KOCydP&=v55(MGVx90Tn0VQURyjWGXLN-z%$mNw{08tZ4@nWl}ZiIc&lV zcJI2he8xODt2xYSf^=U#bdX}Afbk`<;Va4~(+Hv|qpmTe-tJ0F%Q0>y>&ZIqP3{LZ z%aoZ&MY-atQdlb4vhOCr13w&Ky=OSuU4pl8r7whT+y?KDAp27yXYC|i>=gqv?(E-v zD91lnG1d!iRPlcSjM>s_9nPx=y1C?Wq2r(8nd|h-1B2^}jR=D-Tmk;(H8HHP3 zmR%CUmfM>Pz4c58<+dlbCBxsE)B%Hg zB>qmK(cCsu5div+2NCujuV&;YRrGnB*F4NX`|&tIt%TXOrGvp(U!4!9(HY3MqTB|r5i}t%LM>pU8YWbdNP*BqReKFnZE&=M{eeU9gjEs$}%|&0`r3_xg^yoiX8G-FWksRMh7+9N^`*S{E zU%F}RaYHI45lYbrrG@T_A83m0qI-x5*VC()U4^)nlB8d6ZFL9yT4xgYp;XU=t=OVq z!h2Uk0;i1n-}N%ynhXRGMDGF-^Q!&s0KUseP6|*@>(Y8@b0-i=)7gjd%oZS<5LPP^ zfAR|=-?GZd`#@jE6)6+@50)qpApsjf$xrFbVzaVp`*5C) z6lmWvhe<~%;*e|9FC3o@w=Q8_wt)IvQ&aQvkmMhot=Yy<2p1qa4#ncbUf%%(*c8ry#)Ro6F>uZA-$ZU|0AsXe&{+M3FCnqTso7-cwG_yQ zU%=R?GsEUVabv3M>=IarooN8($vNs8w4*38)rp!7pn+N;xyL1R&zw{5V^0KiiC6kR zOMDos%B`_Qo3sGs$NeY4=E8+K(Bu5@N<$6zDPckDV>`ehXB{vgVf4DhUL4S2O zk?y;1D>ub%WUTGa+POhooEBxdGsk991VkFk80EYNs_)zff-%@%oI1IX1K%Vvm1~I} z1o)gjDFd;$U=~$uK(x*#Q34<}^(LyyRt}))Y*=Aw24zgxKuziMv-C2XtLU&j)-if#eNXD&W;Ku;3z1&%8K6XgGx zxu^=U1_k7B5vj;roG?Nu@1aAz z=ieCfCG0VRp)oQE5@PhTvB9|_#{_kVHL{L30DDcrF1qbhLV~M3k}S)1yOy-HZjb8u{AtZAa24uC z>o?Zbb*iXgBdJDf7+qd+60qk8%>gB`rag>)Zuqh@V!evlxb{1<-%yz$M1Pi8AQA4O?z4Vp9NUw&>p_u1c}ovBo9|KOtq7mf#m6A19)H74z6$rfte1xO%{Tztw=(U-5##`xju__$(L-$76 znNk(V91apSxMWuI^>q2idA+AUH&~$Fyb7*y|K?waF+3}W{raWTwi>kiw*JR&u0q?S zp*X59iF?tyGztWJ;JRj&fQX^4c_jbnQAIyB+snC^y!RQa38^6F>&olM)XoqMF1*#e z6*q^kvxI6T+f%(iIM2d^PLDDKKlGSMQu~sD7{GDF0^z%M$GZeu!7>A(`F(jE6>CcC zwNLiC0<&!YWc3HyY4w63pqB5UcXMl;y?$ny>v$a(hMg6r)b|u^Mbs7*HsKKvYT{Xbv%R;|?`+aW&vg1y@(^C0iR|Uf_1Cpt zkf>Q5*IiqMrO!QU*tsjVzbtZBN#Tw*$5%Uno$&4k$HZr{Y5Av^*W))ehN z%*m`v{GjGsW+CiRyuenSTI{Mg6l^am4OwDji)`b9d+XDT8FKc8v7faWEg$E1B-?30 zn|aNfMA`NpTDR>KCsXpK3R9sYJrT)kBZGpQF<3FFFJ^j})~Z zNPxLAb7pU!DK;)4(*mXeWg|YWlX4*7%^nk1WtWtEU5ZXT8BAZ^`yCIxuP)4Q8(})C zy$@=sUTE7wOkNiB(+Vzm8@zhur24?nw3_7T-Lw;26P=@!N*M#I>ta%_7q&XBN#hB3 zqLG1Sa3&lJVg~LyO7->lr(Mgt$U7kAh!k<8Ioiw0>;958buiDx;Wlr=xMolP*VWn@G@Pb94gBn z-ZL`!i}m@&rIySLGH<(8U19iE1JZW=NHOa(8$RyFiTJXoM$3USY4zL~g!UGUKF#|g zdDI5GOkR!Tp1n6zrp7i;1eA}ArBdP(5fNm@zq0C0Y?c*GA2^xJ4hT>A@}lZ^Iv&OH z|1_9+MLaSjx0*-vU66LTDsz3!DqkTpg;h5pxUPlqfXy4SGOXsJ7c1%Ps+AL1? z%l4^LYX%w1MBZ^HMIGFRm3i54_V$1N%mS=O3STZ8I}X|{r z`2w)3b)nv@Cu-im1*xcMnBJ99)z84qCGdzrfEv2@s6MOx$BU45^Y?H%SICHtrCNyL z>DTT_lZPkfO!gePkf}w!M95&Df}Y!xjzW6F%N@A}n0e`OjO<%9EPAs>I=*T(m zV`Vecf=GrW5&Ygms)w6Kw{9PxB_KefbD9a|E>od;ZvdX%2rcSQT>O8m}a3(cKT zgNb3IF)RK~&vCo)#v+zAx7ftn2Fa*gAaw`9T0wNzib+cvS z<91uRmqO*<%I$(5H0mM~JE$ycYqsOTv0=65qu6Bl!+5RQ(X(aLaMyh}`ayHn^YL<_ zSV6`TT8H=yX8JMB(a3R=fjXEX5L3CzUb%)Ou6lw5*Jut!t=nr9H>jCmqna=uU+Go zs7^|hPhux%pmc}y*n}NaiQS-dw|{YSz=a7NH2AF~%`v`&4DvxAsi`hx7m;dTI=JB~mF^avG^CCgd)Cc* zT0eTdzC)q?uC}iFoy53mB=hG)<$KR(b7|R zb&{y=zPBRQ`{sp_Nb4)>P0IEb){Nx&|7Xf!S%&|mcH)HnRp>pZNG#1AOOphQf2#p3 zyL95D%ow=#-)*e^-B>3C+$0Cs8j*QDrE6MM>#{X%Cnv=Z!LC$0boK%S48 zKWc-2vh?&TK=LP>l{9IS`B;Y-nDwopv^XMUe=~x>(%HT-_>=MyYtFqK{`8(Z6r62G zof!GF0sscV_9o&b)(wErgztB!Q%gA20bwBe=Na4?c^=K0jE?Kq%JQ%b-I@U6L(@dJlD0D?-OR zpE4Lhufk!)+Q$Q_6Irp2#m|3-$Z2t-k9rvV?QnQEW zF42Tg3z1~HT9f&vym8wOGzY%tLkfu7Meki4LCU{HlerSeNMpQvYqwtUXX;BfxlDc1 zA$pi*_YoZrAJ$z^b5wRyB-TMWw1eGpSoU%|!(4gHuq@CC3HsAr|zoK;VN3wcjU`i#l=&{KXnjnD2$ zs?LiC<#uK@Sjh0li6$jlltn#mBwNUhRq^W6CFHqwRIfN&Afi9iH(!&84Nm;^Z;eYT}}?Y9=_}<^T5EEn*NLmDURqy>J6M z{P*}teeo}qg?*lnG0pV&YRS8y>W6qgibyu|`}@qq!(V+UZY&v<6k(D+3p6%E+pq$* zE)Z?+1gPDNxkI8?-idTP8tC|#;P!`|6Gr~^bY&_xitn)&hf@cR5f1wsG;|e06YVKH@pC)+M>es1Krkd?Y?`U&YNM<8&LG<=a1c` zl)27BS^bT_Zup9fEuUAdAeX{>Ofc1Nql25|<762flj9(VEoF-O_GqBG-T-yySft;n zU(QuWFB8V{&J=Rof<)*#&XK@a8fEcyl4Dy>??49+)Ne@Xi6q|el?XPw4|3o5#yG9~ zu)6vou21pb!L#8hl|E<_(vF^LTM{Y!GPyd&DD}|v3I0eOHDZn;ZWBFbE~yn&UfEM; zqbtHk2e%c@9lwlEjI7~M_vcM;xpW%95AoFi{w3r@`Z}N>ObzOgPo%5mXY_CPQfj{U zx+~nLfB+YMiE0Ozneu3L8uiq970`7n1m1?hfB^O<-dP^vHzCW`doB;+B=UuM7!l62-`PTCbIU$TX36G; z*1bgpLmMEke;)F0N`!iaG<&O(%mQFU{l!XAKj?1eu^V+kP@KZ(0c=g8J8UZ^OPino-~F>Db{V z0n~|GYjK~|%}Y6pdw#6)PF_r;>w@`R4W5V0sgvWZ2w#nj)(CPC5XLMkYI#MQz;pyP zSolrokBxAo#ob&{JasY3_-)h13Vu5=(FmVvT>nKKNxyRiBn7$vehX(B_X;POsDq`O zJh~7!S8f6rDZb_6Opgdza9RrfT7jZ(iI1Jms0_moE&;@Z>u*(=-iA@_fv5Hphn?R0 z(zfE_yyyIT1MfC$rC2;a;zFeVPs;-w93f} z(tMWkzhg$#FNi$>cC`J`mTsNbMZGwH!HH6B_Eo8jH|d_a0yApMAOr>S&A8tFP9Mrh zL?af31>&$FNkx-@Dd|7bZm!=0TwkJa0KFojl|TUM?tBfl-C2+A9RvV?;blT=50|ho zRtZ!Ls0#y3#VYI>9w8KQ4rnX7H>Ycs)AW&*%xQfj($b=*JI^v#YhO%uFM`t*CXZ5tVzkH2vP*k&0a z|7K=Y>6pYcH`)B=b71yu2k^x#mhS?&fRsGJ6Np!64~Rjqp)xmd{IIBG>VKe;sifDj z9U-MJhX9w6^v0=~rcnB-HY)&X9^?Yr_b%WCA`?g;ckMHq=HLf_`r|t_02;nNPrrBj zx3{{X;fSNypNKzIgyH>6(Le{97jo(7=4 zvx&D@yBzpU699D#{QjRr@AaYi^4t3Yy_;)$`4fs8gze0L>Jpy~|FT#AMEu3Ij{kLq z^u@JL*a`=HuOM!G;LH^}Sb^xm&snf%EZANOh*{`av1k7z{KPMnPIucKPzM3`o<&A6 z0{5i0vAazGhrG87YKgg7{hK8) zo_8D2Gi4b#?pFXOHeXWE(bnis{o$PXEGb)`f3klrmHy$^&_x~We5X*dI_=Mz{)P8a zT*no`a|V@>+>JlaGFszv$^6sH-cb*sKpp*ZKj*=L`<*IsKq z&$CWauGyIH{o(Kr+qP}nYjO3m-L`Ez?YC|FCinaAq-Q7^+knzv-$dA%U))yFb7W3> zu*3fXl+#o5Ekj__`UR!j96h z$X^M&`(62|*KbMzW+jay=cACZ_afOg$?t8GLrWUrgz&e4Q=BNB@uoQ?*dInuo7ju7 zF{o?houT>{q;|sQ*OEC-o)Y^J!pRntwp{lg2 zU$yI&#ZdmR1#&M*J|ta{Jx-+z&!Iy*rhqL`zGqq*)Q4H| zz-QAYLP~p4$hbjpI8UCm!V->_j5V{{@HXa2tKM6ql9d?p^=y@9x*|)(d8$bsoZYEX zNnsjO8k0ny$HJPr8~*un-G=OOeJhA|7)A9TX7?^&ed{#}g+M*W0b6?bCQ z^_fQT=Tclpls(iLxrp*0t$VTEYLu0PDNMg4Pd_^DV=>z->z8I>sEsV>;oJOz9iNHe zOf^xyP>u%Z(kI7p;&n;zxEFH%@)9I{jOI-7;93$6z4{`F{#b#k9 zE&iQTUk2H$cX0e>mkMlWcMO6?kBSxzh9d%np#h9X(fQhQ$IGBpk+mqlpni?u8$vA5CFe{F0FPwXz)UYA( z4{rnX7ks8}j;gOt1N-A|T`?gPDBsui9P~+p-gGDKPQUI!UpY3643xkTQy=9HQk%U` zvMO1*#Ho#9T<8Aem1waJBDrpoM>MUqcwHNB#BBp>ho|PE#Vu5-t%igDgrpIxGoG z_}N-zZ>Q^)e^Qe9ViGL_=L6_||8SUA1uNs5(BJcQqfGqBrBjawnS%kF>bQC`w-XHm zCeNQ$)^~Z986cL3f^GYIC7fww`yQEjgGZ&SC}@{vSG{pyic#(kYgjbWr`DngiUqY1 zKJLw3ZxS`7catYL0A-;lol_M!F9{XZNOt(mwdLs&l4wu0VAr4@!PC>}$zvkyHgLR^`_LLi%}b!awYpL!*=dUR~UO;?{|n5IBez z6;TC`I0?&@S*)Bak~DFBmxdySBiM_1m5mciNw>g~Li=#PX*?;$IGC_UCBdr=OAZ_NWTQ*Vli&N$!)gtNOd3Y>B>Byp(7w9# zA3t#l58UO%&B)orb#St;H zjJUj5h=8hPStOY&c{Yg3?Ve0OYx;!)IAzBugQSh4N}o7=F+Z%NQXbRn$$UHDTUeXR zb>-{DiH30$Xg482hkwbDzR~D)0kkPvDmQDN@bTFAu;?ba{`RLMj@X89}V3Vy~ z@U4C=M9#=9mUk&4H74uqLta+XZ06pu9AuMQG9u-EDbv#}ITKyAOuVqQ=q+e?6Z&QM z(^@avbKadlkH6=9@yD5`1SanIJF%&L9Qg=O zU+g+Q0Gd*>r*+u;XXKmC5>8_`G9Uz1gzM;sWRAv+oW|$!L1~^4wu5S#z-vq(uV9;n zJ#e|w)pyMC>hIK<)x{}$iSnYA%jaRoPFU-g1$?;ysi1=z)|vF*t3R}=G2eSO;!|j~ zUVzP-LlBQOwQ9+lw|x4;fv6CTFa*QwnxKORYv;+ zM@2Ch7OP;2A#9It_>Pxfjig_-*yh*%tNyF>!-3-&xk@!QSDwAlmc_$|l-1v>7`uyZ z(S$0O=;hR@?iljpc#fi^y};9_R#9YqU9czMi3*EArSjVCSqMq8pnGLboCaw&pX!@? z<;iwkiq21r3M5pvILxyvC#wxxM&&~iYlb+9ON{RBm@%DeIw(9lg!@0CXGfLHO&Jtk za>sZ)qFUhI9+2R7XJRn@mHY{&&~iM9c$wnB5K)<5RIYq+L62r+M_QFuW*M#S*0FCH z7*D@2GGkBYZI&khV=W+pdzZBP=QRwf4z_$hoAC5`O$MgEk)EjSKg3}r6N4q2G`7BS z1N-2f8qyLd)Ejyq>KP?xLwRfRjU2JszwM9sNAJ~2t=(n;rD)Sk12@~;=8Yb6ZR`{d zOIPtqlrP2HjC$VOO%`RI5gj{2CYy1LbC6HZ@0Ban*HB=A;URt?y@yN9fdmvlEq9Je zg`^JXi>zu;fKE8WK5QgLnmsvlRwmM#g?LR&tf#hFE5{$@n6tYO<%quub^-R#pH<@@z8chLId# zYk2VA30=&Gg8=(in6g>;@1Jkws#aT|XU%{sR8Ne`Cf(y{aDTO^;P8|6YCE|@DW7rx z`Uxb8114ZS@V6aq$a=;jdpTPd;EPofWo;>avY1GQKwr}tq6y%O4w6{^VQqXzyn-!~ z+Tb&(TCo{%+J5}elJ|0ScMj5%+4gFrvBBTOZ>&wZO|aIz%9>QQgN&Ga`Y zF}QUAZG8OpBI@PFY^I7nbN_kM+FdobXZX(HQBzkOW>R=nz$Tq31oH@y+T@dH(4y-H&*=HUpJ`|*0A`#REwd>YQ#!MOj6PAA0a`PDGH)*vk)*!?jn3$ib9lh zOdIPOavxVsB%NZx<{pmY8z(3ZoHM~cgcB1Pq~)oS=Jg)uaBgdEc$amqSbyssNgft* zh4+(MNy7f~TSq>8Lv&&=-jlQUk2n0JB^p$;4fnmV)b==jK`#-!ALSFY~sb>vw1v{|Ch{Opj#w1c8xW5;x&z(c(_v^m|v7 zssW3v&}=CB3Ji1H&qO8&6mWje+4n{Z!-j?@pR(tS&d#AtAR+7VDE#!2zeLm0!NoN+ zG4zd|H zTiEO(APh__j-;=B$X-%YXgL7Zl7`S);r)3V#ig>iQLhGG))-FL1rys+9HuTt%e${hx3KLFqdgDJNY=ydiYcv|#f4rt!vM$$fc(FD` z+?Ui-&k$N_Z-Mf!4SxzYh%bvJ9SA*Dqu|;yX1h*^o9Rqzo=fVreA3dW%lQC^?S8;) zj!0M2V4NT?{L337zG8H(FYg6(S2w|{YM=f6?4|K_jV z7uz!Nf9-9%wvFQO_wI>beNO(p`}29wfxmZu_yzlwqx`zmYR})z5 zyhIY@Z_N1t5zx6rL!Wlb6L`gT;I=(3!Ej3S0g>`?d@0Fk(=$S(k?YYFRv{% zG#DC2&ORNhzumg`$@B~uw}Qx`6O}jISgAw@~IN+rbIxFx%3eY z?Zi((7Ue0uftzcem&rV$1pVAJ(MX?ltX$t2gNtoms?)oN|%9&XjC!L~#x0;Wb#5=TXu38yeZ&f1Mx0F;YLs8@v1Ihh_ zEfEU?1&aqDePGBT`gG<5H!Ws7d2F$t-@SSr-SG0L!fKVj10b!-iZpe_EhX^Iv$N%L z{B)IZgQGNccE4-t^wasFY6slNsRIIR$8nS$>FJwSztQS_!A7S#OGBRyW`4ZnxBk+M z3lxMIq)VRZM4X8*%0HCvDqp1K@up+)_yGeCGrp;9_SCrcsc>&wKv(^n(C-eNhO^i1 zy0qQZjE3%{_n$RXdxc0aeBiq|TTnI<1tjDfLj=3XQ24N*zQ>L1#%s1LhAJCZql;g* z|6tD(~OawimcJsJG;xOrM6YM*JEFBzisDl8NpOeojS!YIExMGljDLnTfw#JO-Q~!5`Y21&`55Wqts4VGwxhmzczIE(y;BY_yKs+Ye97sTFTuc7fcp&!kVTAFJGuv-jbRf zIQJI|v>9+iYL%N9{>6zwXIS>s)KsXDSCiBrxp*T!-UzL0G1P8D3!m4o7-m-)B?zZ5 zO_a~K4#QxFlN8n4afT6Xgkp7Ef?blJi8UH`w{~BGN3gh?N@d8LFL%Z{>@MDo!E?-j zE!Axzknk=xbUW#qjGRr2$*ljSjhOoKC{m_;5H6AL662Dyqkk?@abSJ9bw4x9gkDi+ zqt{o&F6F)E?q%FhitaU?>n!K?i|JhXbXQM!4Lv$4sU@uzE?N!D70^VVKkN6t&K|-M zyv5CgU^vU@2_Xh9pl}?D_(xXRc*ZPPT)Z^^r?$XVQFt#CVJ`>Iev@KC`o-BGY`oUu z_jVOzGa_VQPBP8f%q65{ZboxCAC^=ask8j6xqvkIe-_P!A z*n7q1uckc1ao6>@O#h-$ouh*~M%|eX`}Y=Oxc=*UK$!GN5^2$IjD6x-w$w{^1) zC?Jz8&_DwpVb}A=!6p^nCNZw-O3fauiN>&viPR(@Tljntg_PPsqHq!g{UHygflTO| zSc|7p`_r~d&Q7E+sUSD2HuK2bn1$2G9=z|6iq!UMa1Bt7_TQ#XezBFlwE~WYzR1ph zF`qKQ2qVLRSIFGFrIFN`!9hEwd9~{A!J7}Z zdMld9zwE!q-KW-BApc|hOXTPGJ4M9)#vz|y^WU;ln)-#p4cZPOG~ zXZ>3Vuhy1sx$SoiW9esdcPFlVlwVz=L1P$%;;2$~seFZ*zycQPQ6%~0Gh&Z0)m$s= z6BKtOU!O$q;{1lUxClA8A#)8kxmwE%77dHf@1^fErc@RWVE}tr@oX*QbEmL5W$MuM z+{W?*x1rSA<=dZ3zMVW{Raj>LaR>@?#?4ZLP@eSlvWdL-UPfNerI|vmrV8fqIc2^} z$d!~&=B52_k;M=>OGQ@3hAm{e`zncO(R3L2_(SI1jQb8MdN@P78VmA?+h?_9h6}1P ziZqYt(vG;F-m)Y4lmJ{xF`VjDJYM+u*qTkk6b1P?cy;I^lJgIr;F%`lD!o64^Dleu`YUiR{O#ri1N9U4ysQn#f zTSHzHF6FKDhIgj2|JsP0vVXM9pLtPk7w!`P2^Wy&T+5vV7Y#;}Phxx5EHbw?aa%Q{ zhdjz9%ACyh$>9#29xaXqNrDpH(C1PQ!MV4}h|1GbRUhNZPK2L4%Y@OLv zSI9(JJGzNYDlD#XuqEx!F6_3*BPz?Sjr_RUp7SIhSD5XxRo=R}VuidqD4gG4DzVjS zQu>UVY^{n77cItD1EBHG%OLIqRqjzL;;xeN zZSsr;m6m+-${zSy4B38y&aek@lffplHH~ZfdXS{MJlpT$nYetf=Ee;tz>$G@@mkK$G-NPPiGzPb+wh#FG%j!Yi%rXDYD8a`ySxIDU0q8p5xw}pHHo}0$%vHg zzO{6T@q~cf%aqrx-8;9X_YIz1k+Myx$mF?h6?UlfWF;w3aoDpw>2P9x(DnPyo^c;- z*zNm`#^d(KH__rmtJ%;i1#4fPLypA zk)pVdJkXN}nn2Cy(kSin?zW@Yn)LO39ms~Duy?pvGr`gmfW3dA-|$PV@>680dFEXXB51 z50HKxT9HgTLMwPKt{Y<)SoZILmx>j$)>gR|`I8&I^P9Sx)rkry_D}iOf~5(!zh3Q; zoP_0c)m~J9_;Je{GsFyFYu~?3L+>1A`1VFK(B$QQ_NzVb!{d{T@5y`7Yc3(43SUo2 zlj*HGk+qqUO6ab=;$~!+~PKfXeJcnWNd(p0NV-E4~cR_|}FQ9dV$=0UA*oJyI>Y5z0t*?5x&2`*7$ z-g}pHSp1Qu@To^yWY{h+(;jMaAUIg+wzifQJ74R@mB?>wBwT=82_OYjU)U0t!o(f? z628grnX7a+5OxD9p@37eKSQ_Hpq$#IgnCkDdsA=n_+sREOTv_#>hVi~l!0WLorx{y zBiNA1}h0hh5RIIg!afEp4FN3e&D5H{=lU3H#PDYK#Tlab=6BTCs zjm`y=#8vNUGxb5EYsTk?A;|B!)U!FhtVaZZeXekBO>QMw@k(${#bToV2K~M8Kw(RbfEQwJ^@-mn7!u zd~j2t$K#Mm{(06bv#|C-<#>tO&w>5)Esr%KtD>9i@t-HkF7nrp$q z8^Jp`_g$J!VH*co6BcxPM{4?7{Up*_5INph$*y|Gc+9P-jp|3TPa`)i`**yRTrKS6 zrH79GJ)zZ#2B9M`CW>e=XO+0N!x3>_xa0hgmH8&c7i3XDoA+P4XkdL-t=P&kZ8-m% zcv&{=yNP@19|Kdikw*5x916HJ;f72CC$EtBJg}gZ9Oo2v6v7W3AeyshYSr&8MHNXS zcjEi5%E}&lc0c%%Q{brXg&$3I&ctO_`u11PHGiE}(YiFTDgG}f9+enL+PsyQuB;R3lEh3j32Ne}Xcuxk8RW%X zLA}v*3kpw)b6sIeA6U<&7{ExmDy)i0`fec%?;N~40JGi z5Ljl6J-mnPp8b-%C>*c-*wzFm^wL-E=>}>pI1svVj12pQ_c3+E2Hu9i{M?XT_voEq;7{7UT%|?7& zd*7z6^FDCR%+GWU?Vkr|sK{yV^Z#YqM8^?@-azK11K?}e;CQbIoFVpk+XKljFSx^> z19@*4mw~-&7f(+D_e3?LT@d&nx4!5?j@2+^rkHqIl-gRx8_JI>k=n)FgwooX?R1;k zVJKZnm*A{}xpacGEK7hIuxreVLoGP z>E3$oyY@mBHCS#s4Wv5w>}iN)P&nubYhO*zPT8klqER{7m|Q<)jiZYyzu$NbDe-^JdyBbXx|YbnJabT8hD3(TH&qy;LzRZmCYpgzmUfnGlY+f+)Xxtez zNNoq}3@)e8`-B?A zla4jKZ(xo-y|G%gCR$jNBA=LTjBU(gO?*x&>FmYi&Y!u0GcN(B&6aN+%_AMA@R#{$bn7eO(abLtWQtSE73Sb}o$zKuT8_2%dk9GOh^Y<$9 zPX}fG4wko?+g-}vv6&2B-){WmzUP~yuT&uikwNc$xYqRO0Uwt}YF0OV zvR_KxMNgrY15>m}H)t{jN|m(0aBH~|dPQVQqgGVzJb_m|Jlj_c=3zc?jLt8d1IG^z2)R4K4MJxv%R*djvY@ON2uShWYE=o@_I$;hPjU1G32k zC<3tJ5fSWCqTj$S#y*|DmsPEX=Ah~X7;C*TtMV&}mG-X^U!IghMAA>(-|y&axZuT> zea!^L9G{97e?#N5rdjAIIaIata5uy_;ntOdm8$8mDVw7EqIb~=>BUO0wG5;9a~3wG z+#&Bf%8FUgJL5}2tafoVZ?4_BM)Yzz7NT=tlocJ1v$mhSerL6SX>!*{ zVu&|95{=>@*bYSFO=I)-b z7NMWpu?F`)Z~yCq-4ur#@+%hBxUuG#rTiy#b#?IF?@e z3_1)cu1nwzI_n$d^`P&=(zNX{<-WhX{7Vp0ma@sedHk-fnFw@%1W2SDKE^m^@zeZ# zNrIGu(l_1O6mPmaH?*sVR=qxsmyG_c zf$cw;i7)KUh;C9cYv23+hLo`k2>A5juIBiyR>Fn$km8;kk+)(%IuznC59e)w-t0GB z|NY5m+@H6BbiVQZOB0K|mVFG{nBXpVQ+%d5%(`u#HKmJU=F(#OOXmor;=q&3vf4{r z#1)83o6na|Wtz|3GWY;hnyb9L&vX^Z&O)n;yG3Qsv?stbHV5M9eD zw=M#BQ?oSPM{nrE%QaFTJfO`ewzUM}Jz{VgC>yK8Gi*D9s_@RejNQghtvPjrw_WO| zzYD#?&wgXd#<z6Avvn^cQW2$R3QlU;` z;U_`-g#umI3mQ&t{bx;%dmkV^PK>B-o^Q+k_{0o*E9&jI&twt(H=h#s%3S_gEuBi; zFYp=DD8X-+Qv1VOfBsv${B`w&3nItyqnO ztQvI!>TIC(z79UCk+i)Wd2R2>%dLC0QXUv$8_oW4!C9IlN$(!ieq5IC63|c)dG#ldj zHknwd`$()E+mbJboVx-sS=V*5I=H_OGI88Mo9eaaK!eDVyQI+X`97_0oW0mY})_U)v%%#xDxlVx8(YKnGgXX`0P* zz~5r^(^^p`-tUnMX4_$eVa81c!Ds$TC^wAKkLqhi5yQhSixwh@@-wqEnd$`Qft%&W zySa|oS$?GMl$9w=za9c>1@vnZUzgWhhv!P`=+ynm0?d07?i>1za*jX8w(y=pqkH@9Pu83 zQJubwj*n(o}RUOLu;Vm+l!K5o|M31C6_o#rSs4K6dr7F-unbS&FZo!+V{BjuHUloZF^z* zP}3W5xgm}v>ekH;OAJXa&YHu^SJo3*guZ7n z=_=*_>Ws--%D{MP2I$MEEAnE55@n=A;)0I}a|Yh5$;2z+Rid~QYX>8#z|fU#fd1pu z(>>jJekPQGvMA1gZ(Fzbm+Y~+r_-I@ea)HF94&j0-s~BVxDcCp_So;a`BK`$m*zQe z(9+^{(Em)9;P>%q^0+G2@if+G}AP z$D8TM-b3RCYC7ujh0zUy%>m7?&9Y-Pi=X(Y+Ufn{vDT!;O)tl&yMTw{2eNboEpxiL z+17hQ5v*>?K(GwR^oFtrlVi8&Q!-d$#Y-VEG0D7}*8yojisiuii75g`+c9FWxi;xrXl!f zw{ya`5dg_16{K!2N5{zf^tZUMK71~0;Si(+^NU8)%xUuOzX#{n2b4wWx}&_yn9vA2 z!CLhx`AJpQzVoTM+(Ye`PH`2c%Qd7Ax6h@FoIB85h#cH&-Dj#ZRb-{A*!k3YuZr_> zq*k#uy*l!&x2KwAQ8a4+8DyyQj)}-{LK?Hye1iJquibNEgS;939s3U`{Og_;MV_$C zz^&@%9ghcSnGYEm)_PLCt8uQ)_j8Wo^=nHtuly7YT`HPCtdy%^!zZrb!d|N%YsJW@ zAughiVGjck5D$0D%GBjT8+(6Qg%+t*H>LD1?1-s+z|mK=hm^hn%bR%KsJ+$?LwK0O zYpxcsj{oiVlmTj1MLm|~OaetgrMpwl<(%o!*68Mxj(P{6|LgcWs-p`H>j~Az_-I~% z1tD~Q%TfHE#z9j&?fdZ;rYC8|iv4M%InwcRsW%*%D56|FVgTcl>`#G&tCr1si0HzN zXGj}=%l87Qe|o32ahz%}_Iv#?ibKso(l}l^5#r?FsddNjk-8JLg z^I)$2){B;tQ0=S7SH6G9cOx-2X_?tijP_rpo^#nVgR85qH z1{}01I!v4gF(BIeEv9~|+1IG-<*|^P9Z%;58XU#Cp132QIAx+!7Z=^gNOfurrL{z1 z(XOs8K<8wtlh4xeR_Q9uw$`ilUwUTsWnN<6)ITr&^#zb(WB{~h63)ILM*i?m=Hz83 zjhJTqMHLkOm5g1J-HWXmeSm#ojb=o8qwqB^=g1qaC-yok1|-plj`r7TlSjPkkYdtx zbAuI{y>?L8h9$<4ioH1bTNj zT)t7e9pj@`qY&dWHQ-RWi_j)b+#P2+3c6G?1&LK*t_Lg2xaQv^|C2F4%Q}YLc+0MB zWpoVVdhM#>LP8EI_PZ_mY3f=Y+!$#a97zaPbjR2%W9vlC-QXgv?g%a@F`x`nJ2c+) zpvYI^PJ7He^goY!QJThAbz2pM?)|S*XZ}9gHuW{n|9^T^C4C)0DwR?=4B`}ZYm>?x z$t(8l0|owrsej!i)dF8k>RyOj8aK&(yD6;=ni30G#MbDqV4^@u;sz>oUeo>)PyAZ` zwX24lIebb-C0XL?Uu@fI_fT+Y|35+WnG z*0ua!IIXvO-M=vN>feuOl!^ac`?DOnd2KHwB-DI;N;rl3rxCfYjZC7RnI?oslpg;tD2lNHoFy9lIsDs{o&L!a zw*CLQKry6YdbC8-J*0_DfQi1`aiHomVX;r^Sgx5uIY)vZzO3$bQpdn(%1)Q@2IkKv zLTKr8!$Ec?b(*@!uLEJWkN~PqOA}-_OEssm`Ghe1^kxf(gZwJ^$Y9yyc<;H7TCkR3b&E6aL z1DFl*UzvzsFGQck(zEU*UjoH9Yjf%XuFlX4tesAR5E9dB|1`kLO?mfHNT53-C**=? z?D2x$)VS!w-N(5yy|JJ=t-9h+I<{4u zcl0?+tY+_49Xl(@tlEykrvpDdD$o6eaQdfPTbYbnt!{1vD3lJH%Zy{Z5w1Slqr~{I z!zw>Z{9;*J4w<=|_}a$9FH%~GGNB)we;D&J*)g!bC^+5!(nR&GZgFC$>q$|UQTXRLDF}JwOH1XCuwX-ru5S6)b7i@NX{g%Jli%P6_jfNX96IeDX zFW5_2*TC2)MTRKf3JJqOT!zb3w%McbHFl}x=3yS+DY5mr*GB}*Cdyyg(1?X`t~GCW z%7=Ri6Zd{nFmheuZMX(oOpFzD;aoGPvU~zWmL3P8J)K_+ab3O21yNXJhkLJy9+1a9 z#lP4X@#-kgs{DlkwlC-^XRWylS7C8HTCI?Kn(GF);(p20eD2=G;S9A9jzJK83Tllv zDFd~4Ki(T%@T@j)dVSl<3Y&j*0eV=^cV(r_^R~v+8EF<~IW^~+b>kMVP8Q&8KmT!v z6Q|A1p^a<`paQ`ah9|H&5kGM{r5)0=Dt@nj@K#jaEx>q9CD}8+RUWGS zso%_gKhbF{9?NTZI`SPsxj$aU4^I1#r1Lf{C`AnTL(tGdZ4@6HbN`&=+Zn`bHNV=PO-O%*^0rMEY$OOV~&OOP*nz`Bp+3~9fj!<=ALx}Up; zkTbxXp%F?CC`|xhG6o@$=Thl0=JV##mp-!JF3nVT?R#>SS1oDs9jZF1hl#CQ5OloO zoYPD_f*8)YTGO7Yj=4$Ghe^K_;ydNsT}K!q7o)jph zv-W4QNKVsdJ`x)?Cl+3K#}BP&Hks^d|19%Y0Qi~MYGSWwH#lwx{3xe`w`I=5)8WngL448m+=fKaLvKO7Q+bt`b=qs?`!+^OmJQu7k+-K5)JG!XD zabK!#B?$wmH36N0&^lWMx{g;TSTs=on4>s)3p9vMBxBpLpHFncC_xuL%=d;i*(xx}&TZ+|onO>+tOcLNt)WSd*to7PY8GwyWx1TadEa4ox?o*vPcTa&%sb$V17>4{WgB zj`K-RM*w;EyK;F)On)A%>S;ixq2Rob96TWXyCAa7&Q$4I}^+G3a|v`*Y_#TEkti(@p-3YrjJ?Sl8faxQ>%~g zuSLq299O^db8B{-LTSCs6@=B)XF+iVhw+XrYl_-6^oBx|NeQkgw1ELH65j=OUkl zXKqU)GspNhdC#B({5nX~RypL`Hjp?_qj^~66e2`H9Cag1W}neRq`HZo@dUI9u`+Fc*)Z1j*^vwrqm*iE};hnqXe{$Y2wUSWF;hMb$|%>7RDBE zV$=wM=7@*gov#6hfo4{n<;S;{Lc>T!n##(kQG*3bGm(1;LaTG(m84IxabcaG&T&p+ z>@@kt*(S|WZ7j^lPdU9YewN``As*$JywCy!B(@VGI!q7ROms5ynm8ZNPG`pUaXwD~ zccq*$CI{jJ3;CQ~EAX3a@N?o&Rbad699sH@lS$9L-51Kq+fmiGK5iNlC6B+^O_1;& z&Yu{aZkJ;W@Y~ji{fxM~z5$*6UiMTk5zTEbF|5yByN?A227Z0T*H*SNKGKeVpXvY! z+)nX|c5~1bf=|_$uZ@--P%y^k57|7*6qA;IDQ}v*eHQ)<_CWI4&m>=2`kf*)eFYPO z|JZ_hU^(+Dr07Ztcf6_$b6F*_Oi|YqPzgCqNvw)W@+|Rp9)n$pJ)+l7caKScDMF9X z+@i2xTh#cNlqkD#)o)=%(|25>ox{iC$ItBfn(lo!B9y=8qJ)si=NI&2p6*fM1HVu4 zoCopjnB$F#ADgWkQjv%i%mQa%&Sau|=}wQ@>4lxN!V|X-kbQ>kUNxJpHOLdkoTL0G zN+^o8`*`x!1zf1Ql>5Y2nwc=Csk*PR3DGweA~Gbt?K8t*Pgp!namc`w@YqMG)@RNl zhJhqPE~kInJ2i@VtVYOShI(ac-Dp>OmR-2mtb3Tr7>VdCf`4+KWNQsDsq^r`P+=mj zj;2m%0Gw}}8qB8`iAUpU$adg5qG00*Np%`%bCq|8CAZ2xak!GyG3`4SuCo#jWX^1w z_P%1<#d!)2dPMgm^$l0N;$Rl~%7F*iW!S1lk}QuL8B&H>?g~!b?bxIN4xrZd8%nv2QnJ;S(+_$ZYfc&D`7!p2{0Fakh&A;f5f z6gS2zYQyC0uki#sGzu{98$3NI{!LTsc8C*jL_pI2fyW zm-2(Jj^h`YMJE0?{-dtk)UG}hoqAbr&-D9|aX$vjt!V4cN$t1`{>1`$>-d$m*pUcp zGZWW%O4j;E{3h=6oLRXPZSn$SWN5Tr|ogrZUc2>~eyC6xEz%rpPz z!~5}B?|RpI@`aVfNwUvA_qosB*Z$qtrk{41`H?tZ^b9FF6p+k5jJa@`CPf>3Cy-w0 zxLV1~lg6>SOVh`+#ZaLSEuWIA-H4y|6)g_?nvAqGxNp*Q?+~_`{Cy`r070 zqbqEBD=&JK_#3fuEJCfNMrV=>*mw+(wh7Xo*VE+j>ZO+|+2ZErZLk+;I_2Ww$T{a5 z1!exlS3yceX+Fc4K|$c6eYg(SkI7F}>DWK;&E=YThOG-6nm3Ct*zqNcatmv3T&v(Z z@reZJ@YP;28g;$@2~o*{=KNJV3^9DQ-gG@t^h?6qb3c$NUD3WDSto5vr}X;jr$otV zy)lZLzZQ(ctCrjY2|CDWF^bmf*erwKvh!fd&XQ>W4*99>@Z662%ag~Pzp;jXNiMnB z@43~Wf%u}_DU&R&83VucWo@KFIic?5ko)DNeJriw498vN@bQ;IbssfzBV39^N=b2q zqR(486EUEmFt03U$6x>IgeIhxJFbcq*vSFFf+Xf%EGMy?`=Bf64ec~gx?SvyPpo!_>kWp6vCPVHRSa4 z0jbeD_EFCzUT{z57p#}6v4(|?hLNh*OF`n*@Pl4VoxN-3{E(V;6A`?vLDUwdUN7r> zK6y~64^4KSoJ7-97B9Bk+e@mSOUt#);gL13Aob_!9u>f4pRKVmbVWy@gbQR=AM|ds zRix}qb6#nZ2dIc-y-7drF0DS% z3|exWcT$j%>?L+P&Xb#3?9MacgF0n}+m=*XU7u{#QEuU|!}kk}9wnK|ulR>rOUph~ z!`_?LAK>~H!{bgnHcpJUMsDqME7ysdVMFB)N_S58;dL|$Xn|AhRu?}hp`eK?PF*I!$S9l?(rJdjKmP1O9RO&_{i_ku+BaO zM7q$I)4X09he_pFJ@{JGeiDN-{5>~R%mt`bW*k4p$yS%e)4AF9SBen75hB12WiqWM&FB5H|r}bt1j?yoc)m_sCBUan(RVNjHsk+|UKdS65O2M)> zy5lkt6nlkqQk*b8k2kt9Qs+`oS|dI1)MkeqN^dBb z9VuyblTH%LkuVRR@icb@7n@w(Tz=~i{z-Rw4s6?3e;?)$@65Lr3UXB8YqqgeU^(E_ zhIf7pdKjA|daKL%$(b)X4)YYI=&LR}GY~qa(xC`V z-2SpCPz{#{F!<_Jw00=fWOZcj{2^x&&TG?!teov@;b@@f)dr7{ujcCPD!Zq7vnl%R z+Tsds7$r^rkqeH&2wU+8R5jZzLT06yoGqx|8=W%8@@_I93DobG(vW)8aj(*T8oxf7F@qPRls`6$7oxTDg#10+IAAL41nn z;$@wI7EGuvbjErB&ke60ML>Ld+T1ctYMt^U?7WeuX)Ung@_A7?TB|`< z7@nw5PINE?X|$auWV?^xWPfsAdYmCUi!=&GYO(S{1?Q>e_n;lc;0ZUyrglF(YK zaC)6!l@VRQK{dC>_VmhWGTu@JW&M;f4|ca!U=(vNrlH%ob~DNr{IpBhAX_^XLz{XX zmh{(lII_<~RH`Buu~i+q=GKT#vwb0uKk-X?D^2Ag_50P|B4vJ?3Ir1n9r(4bh@sppYqT=YcI%VaA(5qjA9pq2zm^jJFNN28hy2fK#?z1-UurMH zZ&dhr37|Im-i5e!5l8=S3J(wLc7}_Gt))r#=XH@&{AbTTG>sxdJ6e0=4l0&nyt|6& zO>;V}{V+Up(9rit+Fq{!uSemR^+9N~?&-AG(Rqyrb77pRjQ%cZ1NLmze9`@k2NpB3 z2;{X&v~M%#Y$|2yfY)=hgn0{W^TzE0{?Z4ftQ@(gz_fZ(0813l^52UH9-bfPFX;e< znC&fkUS{5_>t!2K-!?NK9@i>CQfzofF3|)!4C=J^`Hk366O)gcajbnVwen8)zgAxS z&jV63oBHInXD{pP6UDK&SvtWp8J>)$1d6&kc52#1+!9bey z%IMJr)~1r?qTPq4C)I<@PRk9!7QQ|}Vt5;0@VUU0lDZNk_`&&%mhO79m^mCGF!73= zXIpQNH~%rPhN2>%^d@BCA!Z2Rd~vRAT_^_R=Jye4DAQv;`;^LuJD!Ft|BSjgdAu6= zBvb5Mk)Q6&_?@Wdx!=(aBid4ITSNoGnm4L2)2-z@t+N9=57bxv2L!(*i}mdx4K zOCN`;d#*Gx%Y3{#j-_J^bKkeWGCCd7YRL_>!a2+Vg)epRwhSESz4(DW%vo#?kA4u^ z*cKDEG)}VZQKℜ7{fJFuQrpx?LHlfE;~<2$)2l888$ZSn4aTVjBnQ`u_o;6!-EbP&s(f&Zt{_wC za{A0a!SmQY34#v&cz%QrRef0`X&w7cMH#TvlF5}ke9*_PZixQY#bdYJV!K8(CNTm^ z6FtpSU?vy6u_xR2kyX8mZ=BXdO_WB-gktZf?JPrKhn{ zLd?DP6lud&cI4bBLzq2vl$RWoHb=I1OMmUKIX$F+C6_alMerWPJCo0_4h$iCPDa11 zO29AwxML8*V4deJ!e#Nx>oMje=yoMS0GwD6UM^QddIuaxoP%Ei1L_xd(YHiqnZ#7Ota?i%)v8!Pa_Qyw?~MapPS(= zCMT#=H@P$`m~Sgw57SaW0|?9xe-?i?K%4|Pc0=s-K?B;BUw=gRJD!Pp*XH$oziALz zp)I+@y0yP6Jfy#S2$qe+3+8JTt?-AERevfQJUo}eQlU9i(X9IUORUbVW`H~Drw3cQ zW(ke{I_`e~qY=cQZNZ}-*qtt}*4ZloE9V>Kk&w%uorp-^RNi&Q&~Uo0-3OhCig*u? z@BLL99WP&Ns*A?aH?d2^Zpg^=TEbB5I_j{I zPh5qa6g3YAf|8aSTJh?&*6p}YD0F^0q4j&HB!Axx#+SSfdq@^n{b>Hekm!5~KNY(R76ctxLrpQ|Qj8sSo4V;_}08B;bS z4#ioxEb;PlTCZi zo2>O4fwfD&{&T;?+66@C+Y16VAIj=FAi1HWU5H*U8|Mz-bIYC?&>0kSzrt3gDm_MzN1ThYJ9JJD@^56dR zS1a=x4^NwyesumfzU-iY@mjy`W-9gUzy4B7e?F%OLBuV8;klFvhvtaKtN zl-1N+b_`s49=NkX|4(CnJBMNA{_}YZJa6bFrpVyhDV|%Fv^2<3-h9gL_981GXXlUB zgr8nKnt`h}w+M&W)LVoTF^6sgXW>GN&fgTvdq;w=-zeBSPGqmAt`d&2&-O@Iu&F(c z`oHqrI!#N0u*qg@&QWsF_4LS}S>REx=MA!Dzo#B1_g5fy*#fL!d&YSEyY8kvmxOh* zeS2TzGpCf{AjMG1bkNuw2T14GPeciGw(n6gdJ=#d9y;$G!}D^sGQ&Y3gtYnF-Y-Q% z2IRDZ!zdK^WOKLxLi*<+C&-qok{Xg z@9li?4ByW136CKUTs!9-?0&tnjJcdr)};6ZE6L4#klkNaF}5zlM;kv}=HsnP^+b$X zTHD7nzVYXeJqTXZ%V+uM#FOBSx&YP<8<)j8oR%Yw-U3E`T=OK<>o62ZQSm}p@`G^$ z02jXHDr)XmE)WKiR}`JpZxHP{Eov^;**^R@z`aVlw#Kl)8XxFm5OU0yO>g>NuX>OIzw`g`@B+6p-nx(FTHtT3AWgG%n4GzSY<}>w~ zEgy@JEw$!SN&fdgap~}hmt56}JtruCgEx?|PP>Qjg$ypOw(=r-<*56H^o)mje7BrY zpG2g(jC%^fNNaxNzIJ9X*V{N*bbj={!FIMJ%1Kdd<(sCnO_@JHHAKkOQbbr%uHXcl z8O6ONO|<*y71|E9%sOI&q^0d?w32}rht;#B5b7)VG62-P9v13iU4dXrkvr_TGAnD- z;}+Y@-uP21Yi%;-s08%(HnHa$U`BG+pgBV3(~LVCzL+BowvK9xvO(I;DZkd^3Q|(UzG)VPblird){oYf%%vnN!;<2Kx7D3@FPFhjaswtfez1PxtlME89-;F9FdBHj zDMf%&KSy)x2+)ODGJ$wjt)`M5vS38iBRa6Uad z91Kp%6OzJ0YT2yePAhC0m33z%xwpLn&gksl{iv2N5p=GEY|YCBB#4+hga=#|DD>v1 zd1nQQQOz_vQ1(F{p5xI|)#;U|?LFuC_335<9E&k-Qw2o0A5|r3T}D63ROPFr3(VLx z90`k80<1=XeDw7rFh5g4g%-cNVh73#>QC7>GUd9ucmfqY8KX`XwTfL&2Ge{cw4Fi0 zpCaDONX<+Yg80Oq&sQ~t+CV;c)d^J9%qQHkIO*2 zjj#>-Nyea%Y0|E;L;*EM0cD@TJ6xJznQ>wWtzqf15WRC^;CAe5V*{g{0}@35`T^C~ zx>IS~gz2MBb03Pw3(NLNzdu+a1wnGq z(&GX|aZ;bt6+L7<+!R5 ztYAGL;}6^9xAqs$2EO$hpQs4dA36y16Pxaj)D31#Y|x*Qz1Q|Q!M7a-ISa0`JxbVO zI8*V}tWQ2F$ntU$52GJO1YI0xS65W`E~6+i311cx+^}V__(b{nszP3+Q>i{jfr)jC z{`5(POu;$cc z6$KO4+~)Tw`%qf@A8<#1Dh8(2oW-LiuXx*!$Gg*mKdgOFvNIc%uu-6Oo1kE}{!+tG z%S=;W?40w-dH6%qlbYDtX_7Oyy3hrXmMSk+#%yYqU*PAovZi)!`_QKP1DKvdR6Z{AGao_4p;N+gQjvdY3fBqm@d_|KAZUz?iUYu* zn+Ox-p|skb&khLyBuSmF(N`6P=9L2rUf8KSS{Na>Tf4Zuvm26_7u(Z=Cc-Wdw&yGA zc(KVhQkA)(k_6}zHw0H0qvEngC2KpZ~G*M z*DjRH`8_Qam>vrK-m~$nR-~=Zmdna~nz0guJ($$zUw`pBr$>7&3S!@~@pXGI-(OOQ z&acI5EQPK?lV09 zSr+Bu5j$G&ISae*DxDhLkv_M>A!p8SiehqndCA04*Sf(NZMROlgpU#>W3=LHrL3{& zIEC^a0oyV7OwXape0^MPFfj46q35%OwZ`vtj2$TMX3dWcrrim;qg)FX0b#*5A7>={ z^a7(1x15j?)n%VBIZ3}`Pcegf$-{sV=>}`Kc;#_`^<4evM+G(+X`q+>-q3vQLixl1 zE7`BHW`#SXP7If%Cn6#byNauKJBt)|jYW#@$e&G^>Cm+Mej0cbs;bXuOr$yw^O+SF z4=2RvbuatTw_kKn*rQqY3D&3x`5=!}dPXR!j-7IR{5YViJOYUTnY@}eeF1ge{uxEo zs-xA!Cye53Qg%A6*Y*Y426ukDPEj#5Ms*`ptPwHbf{8RqM?Z{(fOM5(AxczaM{AXR zTIgOS?4a0l-$Z+1s}}N)L)S?W3!R$|n>ACZA70_`QDZ=?K@dnB$CVxU=0ab>fhzjL zV=Vj|yvUAa@eYd@=&Y6e&%?aDAP=wt_QF{{+n@|DW8A&y?G&)Ali7?M6JH)R6y%#E zV{0*UWlLQbb~O5{-lng>mk7CTVDMqR$W+4j@M%}US{SmW!KcQRb2Ka6#wGxLC7{NN zE@&Qq$Z@C50k1jdaAfZ$kuF6Y(IOGr$`{zeWj6z`qdbu_H?gvd`t;~EZoAgnK8^@n6-(LSsmt;KN z?Ei>!0Z`qqceBQ{xl`foW?x+hA4CQ8{uxI7oEv2W81c_R)&HhTr*;7bk zPig%<&-!24A;*ETF_foneD_ecH+eE--yR@aD$5R&>UBUh)>TF*%GG*H3U{U=3nHww z*Sg;%cQ3~g1+Lt28`y4q#VFMFxo178X!b{WQoU>{^JsoL(m;VY`WHX5*U-LR?U#p> z<-^@D$X|rtVn2qgRe}^+9uLOB`gRgv(}QnMGb=nmsJjkl7rMg%HF88APnp{3=uy`Y zah6aiX#zxKVDK%SubJd(-+bIMyL9l)2Dez>???yLC)KGX!-5~pCnz_xGIs0N8rf== zTk3>ZGW_nwA7@I6G8gm1i;TQ>QSF9$ZW@tTjC6fEMJl(AN1-Ydlz0 zy75Iq)?9O2xEP+QAkC})-b_pVLL)ZEWiCX(PwSkDBzEm}>!@z9Q?K?!&t!WjFFvg+ z9A>SFm@(y#4((ft*&W17mX997tC_~(ubXawc5v>Kj{8LN+iT6Flyli*iGk&=a zt0{ruW3%f#-!Xw1R%~8*q56ko0wvHXmM3f`;=!4Fw_B~f0-s$Re?CpvC?2-(;o4#%`Gl`+;^cER zA-3akC2X#QUj>-k3AjhL*4QewsB3ZNmX@1dL-3Oi<~4FH0E({Qa;4`2v|QF%jvia_ z*{{{|tVR8=^I#`xLq9$?Y}eM+amcsqBkscJ?mR^bi=FV3eYJI|%-Yi7Y)o5UWvsH} zm$#dP&t5yKVCzp5E-G)SW}-D$nm>qm7n@bQkjfE~>NBJL2)X%3y~64p^;i%R3mN?& zPxt~pBNOcJSXI2U{zb9H76s9CsfTthd6#`&n|oR|f!y>xmN52)ktt$EK6lh=Z`7ck zyx8;hp+L7)Mve5HT;Cn69(PE$1&E9(ATo;EK7ZtHnH>L_Xhs%Hau^Am%z>{Lp-|P! zAiBwc_(&@kP1Sc_!Xl&id>F+3h$d(qb*Aawtf61oU6Wfam&-pIzUuOWoZixP|C~}` zfK$5*%c|ENBN*Zx!c0zXtHI-yDeeHkcKa@62 zUu&CM(#@yHPiTX^zxT;Y+`E@bELI%*M8yn#>Hu`$Bf?937`VHGVOlfMWv*48e~fQ% zWRt-|yZ-?kMJB{q`<(l|y@>DW;e%2jY|sZ?&DQ?#+A9LFE%PgDw#v0Km(4;2)6XSW zDNQN^!5y`UifcOVNezL}v@5L>B9bM0h#fUPk(EWK+-K}pkv3e17bSrLe~D>ya7?Nb zhZZ|t@sr#Q<3KEPU^f>|$!{%x7ENAk`J{Q=75n>|=XU+s=(+NxaJTlD&B!zvOVDqZ^Y3CWcjks~@oSIcO=-j-Bv3206-R|tf{xud* zbyym}nMz-zr!NB3-CKD5vA=KB+L(NjWmZuBDZAki3B07?tA+hKKnVb&3@Guo`u6Dw znJos%nQe8JGfakU_+P{)J=CG97{B_l@AB=Ilvz!6F{67M18)z1ja}Mq?-j*sm?DN; zFrQPe7J1rNEIhsOUL4rKM#6?*+%{VZ%ZGJ1-xa)zonGJ#;M(BbuTdx}MgY!zR%Nti z+$NsEOEp3oT#kgaZHcKAjS0KLmgXV-VKrq|;!tHwOU4vkc8yUC6!E%plEZ4>0lKV) zgu+2gOW~Bv?l+l`C0vGxRPI>WixAk>eVMA4UhT`FhxiA_Rk7k(n7{%HT0^n^t+WWF z6|f@@Hj|_m9^(wcIXSp`EpA@m2V2C!g11n#42)A2K_$XLIwB=6DXjJizJSd;W_XuG zTf&sql(#hQWO>mW?7o=Gxs6l%7DsgRQ++1aUblBxs|<4fC~E6HKsEOeK$9V8HR3@$ z@xs^(R!fHPiHE`S23*;mW#Rm`I`_;|f^G>XICqSR6F2OiF=KLU!KBD_IPQVX=^Cbh zjPt@&9R&P+?VYZ*cjU8DIP;FubPH6=0l%2Vd+(w)QmvWsN}7sRV%G%g%|t|?*C;Lm z5&RW0<%~~32$LD82N%VXmTnX=FMH5dp)?k+9^miwCHNq@-K)wQ4|mgIU6}SCACq9; z$zhj`u-^66POG9c(9Di*KZvUd!G~^}#`$xgy{$b4?$`PQT>9}A|z>Oz8jCs$as5FjMgb|K88o<0c0ETLL4yIhvGYqRDpF0LY#Mt6m6 z{cu_vo(P27G^g7}$79c3oe6qV?vm{l0Bs`ijfz>mL1dQuNpE}HCT+4CaP0bL_I z18ybfHPoTIiOK|R2KwkE+xk6?An1+PvB2{Eo>10GImpa=r8b=tJD_JyHNWT1WVC5x zi}|-pdR2@A13D90U{m*HZk{j1qg5^5wvc)k58_5U_FF-bGM}f?4E+S$D_%dS2doub zrfyUWY=bk%JzH1WgC(A~WRFfKCTYp{l2V52*Vmu8OMF{7Fjg~-Xivc`rDLlv$QTPH z_LPEr%-X*02nr_H+a)DQ3{Fw~xY-ChW-ayJ@Ob*iNG4IGexlhFxp`;;6@<2SWiQCA zjnu>MJTs<-w^bSGQAKy-R$0TZBcCju#vg zROG`^<|vitY9PCbDMqN7l(%>7ZA~-Kt9Rvk!05K^Kch-1`gF$AuC>v1V+`UlU=DE= zucg{*fr?hm<%=7m<4!|=C_-~3jBvj5pPP#BscPDAPbQmMkZq=yxrH?6Do_ zME1l=gv_nFXiocD4*1E(yip!Mmi%U;-PL}O+Up-+c6sJWF@X=U(0bbd`XvOFhCVHv z4vy48KT3@zLJQp-rLryUXChzI(k>DcUM=DZ_#{f{0lrz@RIR6FNXI`;9>n~@$F;js zj7+=Na3L-5*0-Q9TtA-^f6-cM*n(`Lu`sDmy|-14(&uAB5+*xTlYc)eu8%Le-g z^}gyDh8@>p5U)+>Q2ymFLRd!2>W=Wb57)|$Fd2*P-Sjr}sXZc-DV})pkQnPRg3cPe z5UjRM1DabXnwC0?l|WWFY=W)c9>KBm4<+8iYqD%^IMA#kW1S5qz}3903)!j44rk^# zP37&w#hkZ?@~>>wh_&A*w$1{Yle+4~a=xwJhYX1|jq7-}8nw2uVSF%c*%`ZfQha6X zgl5EL=9W}~n#mwk&ahD&snHwwDMg_F+eNG@ z4vf_P?C85{y@I>PFn^&x4S$83da`k>)bHLDTXxa8K62ttteDo?5T$s(_Km59MIbCX z{JtDQX$E3+;>f_*f-_|)!vj`iRpxyZD5K7hg z0p5X2TQW%|6QS-mpS;!RtOU&da^pYcW?O9SyIh=n{y}g{mff8um)ApS(&pT?ws9OU z2<2+(DiyQct zWk2=`Xx~@+Nc6@`eqWg@@4?J*?H+@g+JwoFvR<5JbyT14U^ao3)GM~untJ~@t{sw} z*;{!~9wyJ+xuJ?P*L}Ib^iJNVLf#4 z%gs&_tVZNcfq>}dGD4>}W~>de z*d#i5Sk87g)ID}B@XepJsp!Qq``DC27b+|B$ zb?Ax+yWXMR9k~+elG@=m_=|7zBiuzlM=2Td)jqes4)Fa2N0pX$Z{O|7Pd*&$ji-EX z9zpxU>w%;$%bBNl1Wl#2=CFb{`kyHJP<~8qfd>JUhFWXTPdi$RY&FI@By&kc$XzcJ zG|q6w9=frh%1ziwMg3Cso0*&e%ZU91V{IF?@zp=GCA2NdAu=%e4ZG!9txU(KWM+@^ z5anbAW!Qha>r5!lt+1}&v-T-NmIJXEKo|_fDquqOcj~yjW(y6NTOjmZY}@@zgiyZW z+TellnRLsY9~$R5(k-(ul#0R-`Et@#eB`V;9#B?$@xF;pmdy`)-lD#$>aURuRm^xb zrATd@n6X%R^H%fl`snm(o3M-oM%LTQ@%4c2d8F-u71sNN`tDPgo^t&x);15g| z_E{F#ku^2moqe~F=KSxEw9h`4AE|W%K)4c^g|zq2r&-6}vC+kE?hzcejrAeSE&e7Aud`oeWun zeC~*9N`6+$eOCQN9nnU1>yO9!Q%3x1<$iIe3Vp4S&5TUkUfr<9f3D#f{be&Rvf^;> zZ1{j_Docswb#eF@CgqF0RD zj>)eW4PG(#R<`8@>tLgtTiCV=m6_pJY`*glX*d;nCzOpC#nBcFE&}s;misB@kYT9@Vp= zT;5GtrrprDG%+4QUFD{_*XPdQK(;i)GC_}F4CX3_`zvh(+~wg&Sj*d4AKH$Rb-CBe1%6pEB z&o=I=xS0SOdD!q3Ixc{{g}KzO-bpjxk1B!ZzStIzX~(FK?Q@`fZ&#S^N{Un)jDKi8 zs~g;fitA%Y*Uc^#B6@9#@HOqDsz83Akf*x1K~t5vh5Kg$UCoc!3{Cmd`ih5T^0%3P zK|fEit}~-*DR4`ykquP98)ksJp=WA4cB~FfJjku<{-H)t+a#JNzEoNX7eadP`eteQ ztFisGS-5geoRE3f=+V>=Hd8%bP6I8MXq-Ct)3_<2TwZ zZ36;|cdOaDr)CFUMc<_a{}{__?f3{xOq3VT01k)$2>!HU)O&yEPum5rhUCYkv^fRs z_hv?;ZChVGj8;aUSVVSx?g-sqK0g1OJV)$F<=Bz||LBVsaLPnB@oSgpKkGI>y(}*6 zxs>d!;{5;mjuz#@_}A^^zY{n=6`%@MYd@iW^Cn=vi2Aw5z?GkjPOO6nV~_Mbhr@cP%^xSl^5B%Ygu6YM>1hfOslTrkW6a2*#~OupaZ zc-+9iZTCu><%QbCUX7n@{mEVZ!%YGB(CGK$d&rh?4!|mH&I^#?dyrDJlvVNPWMsW$rH%2< zY~+qX&}ybIda?tr@ZT`3zrHD@JN(9|eCxo=sC@U&d2Tx7|Ll%3c&kOWZv&1aW-I^m`}aUmH}|4a8KAaq-@A4jN&E8R71Q=C+sHgU z3`Oq}{C79!?-zb2AL#egA&aldrCbDjR4$bRz}n^APiMq$E3NVw{O7=Lhk~`vh?^<_ zIAtc#!x(^k3keGNZ!Lg|5)K3KTDc$quSGk){kLgNjVJa4*; qgnsV|{Cxe-lKKB@zxMHs9c_r!!#^$JE7kV;)lk>uM)9?~PyP?g-Q8jU literal 0 HcmV?d00001 diff --git a/services/core/IEEE_2030_5/demo/images/control_scheduled.png b/services/core/IEEE_2030_5/demo/images/control_scheduled.png deleted file mode 100644 index c17603ccd61c10afe8bbe4a99880c7aa28f0bf6e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13992 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 MsyZrV$~NKu0}(7|GXMYp diff --git a/services/core/IEEE_2030_5/demo/images/default_control.png b/services/core/IEEE_2030_5/demo/images/default_control.png new file mode 100644 index 0000000000000000000000000000000000000000..7f90dfeb95963ffd199ad678c0e69cab6c657b8d GIT binary patch literal 75494 zcmeFYcUV(d*Ea5qGs8Fvj4&e|W|U%s2tw#&EC@(bktPTN0#YL#0wj;a2qH~-2?V7| zmtF&-G^r6n45JCu$MhHoMvCR8C&-?%HkMFy_>pHpMob2p#&faU?d#!ujJN}l1 zk>F2~KOH%8M9{?e`kf<3z6TyTagWqSIn;* zIZ~f;{Ltll{`s-T#`Zx+jtKRB`g}78e*KVtQ6$*VF4zj}5gg_c=zhc~(B0iX=n**B z$@)kBPk3=A*RR|SciQ4`8fB)VH&`T;R!`;gyn{Pya-+ids~Xl7KGwHeKP;M=XB4g9 z(3nazTDvQr)NZJ5X7-D}^hLM0v-02M&e?*m3Ble^W(&{>LPMr5?mpw`iUl!sBar>o>uM)@Fa5`n zQ*x=^OFY))-^W1T(|Gg$YI8|Z#mraoKikBr2DrGQ|FfSwy{MQXQ1HKQm(%ut&m*a-#*dLw5XOMf?$lcF{^)-XS>uJQoVk2+ z%P#n2yqKqyfdi&(t)FQHVUmMQRS!QnN-h@!zm_DF5vnNAONHC#x;xhcKCaO=zy@2{ zrF(DL#5p|51Fr|)jx0Uzu>bKP>v0oCM@oZpC6TR{P!=K7g2#Bo&05_?C9Jf#5wiwU%H6=Qob^-W3FM5SQI1ysFx#QsuTq_Vya6ADT3E{HtC_MPeoKZE=r*Y*AoLo9>jtCC!gVRn?I zh0$zce6OnSZfNjI=4>O~#t_{hE}fFyJtp-(Mm*r%*QW#oamWNTJq{9ps*@mG?2V12LXR$RPyTjfiO-&E^NJnh<5*=XkFgt!{)Wpn>_A%VE6az}7Ha2CvMD73-9{oW zc`P=SC@W&c?8EkiHzA4kPN26CbiW49^l;ur^(4+t zqUD1P_AeFucID2@n&mn=QeGEIOW358qv@7ND^9eU{sG4~|6(oA9WSMrPa#lHlCQbzU%1#bUHuEe8-lUP7*pkQ?P@j+J2SEd`uz3UkWxK7z55 z7F*X3SFb}-zWWeKnT>xL=)Avm*}C1e0BfTxcdU>bNWjxqSlF)fN?3(+*788u-LVVN zImvWUa5j`OM*B8BAw+MT8sJ{RtYEIAqv?!6opK9m3EwJUtlXzMXS#2JQHF~)Nh9Z> z)S6(^`*rf);BEqJ8?|<$rY5ci`fs<3iFHfe1_&R}AAg*G%CezDixvzDxhAIC{<>MU zNddyv)S9xrJ%HFi&1?v)P-l1L0 zfl3w>9$mqlpKLi^l)W0w%1(VGi&W78_r`qpIBTvtP7rJau*EP&P|{LSlshd+-XP>< zIFpXkw@K-txnKSt=t`W9pSJY15ya@G$XZ(VKu_!Q9Vj?@zKzUm&}9r`h_43OChb=a zPcPB-9fuAxQC}iQ!TZRsatxy zlz8RH0W~98--gq<{kul~#-@VU!3gtjIB|{yF2yvWNNaMmo%3$MCF*`c$kp-+#P%UQ zE@U#;MH@nbY|j$}@T&owGj*jHQlB|Y+eqq^<&g1;=#-5;7PBG;;Bi4VG- zc{@jJtvLl&x?XXs`8Km3dw{9lM zwi1?&F_$f7%5B1(-cqbXdbED;o+1}5%*y@##Gr6nDkEg7L%c_jS(JTIfA>K5T1dp2 zWikLVYP8hLqCb@_XN77?n>qvkz5dwM*e&&~>(`aKg+TF3w5!wM&|Da*2l?2?x5o$_ zsf3k?;$p$rEd{NOT|?WV%}&dn{ZPnqUt9>_T(vs{ZOF(^iVQa+HTh53y__@l0dCuwqpARLH~|gi&q6F6Pqi znx`crc@V#u<`!Vxav1mH3?;G-nYkTVxd5xAw;ukNyCqng`_9B`N*+#p+}3=*&DGIVjqAF}I~Khcg#$uEsB;I=$47@l^-Wrt79|)`MD1#X!bRL#`5%X?~k8%9Tt&LRoZwz4>m{E{Cmpr(`{@Yc)iJ`;dF^2jzuKFpCVlpku z;Gjq-Parp|quTkyfUvIh_q)bV;0<)g>_W^A3=NvOyY7*L`>7@3KRm&u+SQd>suN(# zn5;-Y5&~{D_Fir6HYhM)FKyXJw91$|8|>YHe5}x{(n2`BmYh?q+dcM%5fB?Yn{=?; zH&j$&hTQ?(d`El;=}@r(L8AkG?PKxt-m-E+OegZ};N!hgFS}oNx4J7;ei(}R(MgXw z#mCNBlhD2qXD7=+Ec+62HYK~z&rZpZRS^@26pH2eLNC=Y!&QGghI0#uf+OP_{0qY_jMN8@pzO9qIkHppBXOGq8%Cj(X%u_x zU_QY-Md>W_)dA&+U2XMvEM%7fb$l%vB*^xZQ66er7jHD*(Mrtqjv!P;H{4O&9WcZL z9pseu-zX$=$t;0Qz~`T&Cx zM40H>wQ!HmXCePH9Qn!ZS5Y_;6$`GZl^p3>E%jey8i37#i;SC;HBBX~iREG1cPn0L zbMniyD?A`g@44q>vk~an-+uIK`sBRLs#nQH<(}5v1KINrZ-Y>8oW`9?01p8yJ7Z&7 zQ3c|LB9NNhCOs_jS4iT`)B5`1p`IA!VgBfzmj_C@hId<*ljL*}$@Nao+K6q|ZIFa6 zE$W>bgjDI}yiYp{E-NRI`SHWYCr*^+dX$uO<{bZ!rLxk7Cn;Xccc{45Y`s(D3!JlH zL%FWsDxpJG*IX}KdaRp_>s)CYh#$LX!1>z&`Q5S^wecamC;%Rv=$~lV9%11DtVVad zjv)8V?fJVg0;H9TfX3p_$6Kbol$$a6z?SvBX~0OYnr@P6)hx1;8(CQY zcT(Z@wElVg7}iuC0$8>acT#HE{L6@piX^3qK+<3R zoy1qMglowu+?u+Cw7lzRQ_TaEL?YtPR%C`Ogxb4a;t_rPU}q$zV{zO}ecB2$5;MT; zkW9V)oS>N1it<#2B9l$;Bw4y@Af-zYlz4p75K-q!*Tx#qJ#j(oR1s9_@Pp}tdqsXr z(d=fLy8f#wmb#M0U=*VNu|1^qrErhl>mD}plTrdrS++`n%MhN$}K%9&1p^sSx^Wh+Kee!xWAnC$6PyNo(z69+>~ z=xxw=@v`5#slC|sZb6*EwRfrsnpJzY7G3iWJi79RIon9jmQg!9SzK3W9JhBJwq)9< z&B8^%HUAw6{W?%-;6`l>xl`o5#c;m3OO%_~S9truGF3CZrMK1F?#sz19lnI1fM8NOK+LX`Ls{|Ir|dy&yv z1Xz@n1W2C8ALKek)6x(Vjh7Md*QjF9BLNea@Q`B)mF=wi()3brF^ zTBDb+uwSl&VU8QhbEdbDaB>}z6R{l87(p9OTemEUJirIB)rb08`aJY{TDskJAZLNo zN9%uzA3HF|Pj~HQ3-qfY4^Irfz6~~Xezxw{!d&OQ4OnT(o-792iq_7UcY|8|#6tQm z$4PCrVm=vsT+!UfHF|vw+a*m*qXEO_h&sZcO*) z(OSm>3T@Hi)~7`5Qn-pZu7MfgL=Dvwt>4H3-uCNgtZP=fO(j0%$DgNLh=w6EJ!{&Q zFKS#|8?m0Uk-A7nxtCX)3wp#y?)qzvO>~S+MgnnO37mk{j@L!o?nB2jo-ZTCdsJ@t z^#0ARmBJjKwc%hR3djr6^yPxYhM9uToXlB{L`uq2J*h5>nRJMy|su4trK5 zKZ6{iI}xPlh?^ z{}Iemf}ly7{O3b4G2Z;^|DuC^WnV6q#Jjm#eQ7Y+r&@pRO9QW!oVkoI4b%h7d~bef zkf)^xRQS@sTv`eHaz8p7>2I8jh+&UNw zK4>_&dtUBLsW9m9lK%e37%xnVA6<)35a!ge^8CW2DF8Xe|F)CT-O1g8;|@Laq2a5k zMw`ora;i=eJWdafsSW};!?-<%0G?@HZf?ckU?a)^&h6n*cvXavwv0?QtI!PUkIsiH zVgl&X`(dLgUVgZ4{b+(N&VNh}W#(dJ<4EB#28b*ntCWzyP#SQgv9#fn zGp3BPnBH`W9At&2bK$r)Cz9+v>NX%B6xqA8yD?1NX&-2 zOJgBIgEGQd;W5lUU0R}s6uPKT1xegwa$AMY4Vj-jt!JYZNIkITi zymEM;HjfJ9qKMQ&UKC{csn~(rMOh``@ssySm3Y~X$^nQ$>=Hd%k$i}OVC+`hETHD^&XnXIr4?D2rRamGP?EHPy z3j)#Ma49@!$7-7C4}uaZ-1Z}@uIbkwo)wKw414>%*c8vRm`w_cMPctnv<= zc|Ot05quXaH(5S%H1d4Gyg=&qMO}s6>ab@*4Tx zve2>^dy$K@G#5C!R#zORL+t9kk^(HG3tbv7h=hdLB?W11K7P@Ze-pF)egvTaBzU4zq4q-9`U`#@`$|le43>#^ z5s3RByhTU_q-96B-0EL7te**Vp1HuJnd_q0E6V7>5GCNeaL-<5-3e&;dr|d6-2uG# z&x0|~#GIq*v7ROk6Iuf!fF4JsTquPJ1wZzE*u^8m*tku%s}*`SOA&+u`firng~69) z0ej*2B+abguH({{to(-;1}kC&gl9%_<_ZDn9tOiqeoLw+zAR^vc(p%j%f2 zJ_l-TsAUO}5Uc@KLdbB3yG&!PJ)xRi){wLSw#e7IU5ICm3qyBeXfPg*7lzco>>L~5 zq~y{M8IBulf$jE-l{@neX6eBa*bu3Q7;(?VwiAS)f!^63F8!?rTGUc6wVOi*&lUpQ zwJn>w5LCC`Bu%WA9c-=R*)yMJ71H@Z#;=27n@>pEEpX65G3aI;l5ww`bfNFy-Z^6{sf?Dti!M{n_gf^0q%bO zhR@B|G2R1PojOSn#5UP9C&~P^ej~td{!(VBp(Ov@&1Zj>GgZlO;8zu5UlYBkyKAyhQ(x=Gw6-|aqgG|K# z6{|XUq)6IEw(&!7^=X%DDO!;80lt2cO05}q87LKwE3u5;w2E;*k)qGALtc~zbRdqq zVyDi;H*UP0wgIa`wY$8ck_%|h6mFZn(@OifWOdr`5GmG(39YdR=1Mkerdm5id zQ^OX4v!%5+^BpR}HbIvF>k|6$_T_7=><|?2XTm@ZvyG$Jw^K%+XhO_+<^Xxlo4~mi z*y=#i$j(ReA`Yf-NV{iJ*2RyEb0wVG|1*yw_2S##29P5=9u;ysI}Onw0- zq1x73By0ksXYP7%$KK3Y;3ZW6qM)tE`7W^Gl*?6bKZR_QKlK~Bvo5IXL-#WyLqkI! zPdGC!KEDy@cw(TRXWMfy{pz|??#77JG4l@f(>K@ju0jK(Mp8AM+J3_}`^h%re7J++4Of}I zFc#?ZTH6BoJ=aWFGwmb3rClW?Gr{l4d(msvN|03!tsGR-%4wkjFh@vc{@tDT!RI9#WpK@NrnWCdV^$@a|~d+LKMA**p+OKga%|xfG24Nc|AHoS*G}w^wl>0g`mwfAfi_?u0|!51vkP zS1+q>>8J}z`L)6INq zALX|dbUVjZFCsA*lxZjQk3U^<FGnF!t@*O#0Hg9v>uFQ3$Shk zeRO2N;C;7o-R0z?G*?&9Lr^mQR^lLe{1Ei#07IA3WhKyhMO3eptA1TJc{aSjk%Yfc7O`Ky2h8`|9jK7`U5-^N+bb|VWJrR0^Ds?!=L}#It zU6aH;FvL7{%Wbjk!oMQaW!U)6`tg2V z2R56Nuh;aZ^B4l$u}jIezE+97#V7Uy{#@>ZvB5lLegY9h-^b5b$CIC|YSITnN0}0J zdZ(VC_H=|VAPwBYF@b}j!%g9T{V-y&Q~V3nfsDxeiWF-}>A?F^BCLLpScl^dm2W`b zgVx`MtB<#5o>j>@=8sE6x#_HZ?>U-IJgG`K>((yK>Q{c-gYW!q?YEOZCmETt0RaWGgT$ASu0f^?sR}b=vu0YmHNsE+9B(GMM1!7D{oBC2 zw-APwO2%{-d)_^lY#reHW5Cv^D4d@Gv3Ww7%WNDEs_&nTzhA2-tKlV8t~b86M!1Z? z4U)(7jsi9{#qim^#R#hVZ;Y+^%NtkT>xti(58Pd{^JMMPgGJqyvq77>mcA{1LH9S$ z+s;^~-^Q=f5!tXQsOY|C@4gUjOf@M`LL7jw?acRkoF9N!%STB7-sERIEfE_6r1|N+ zQ?h*X84bK(&*(WyKw`Ub9c~WG-Ie3jTWq;5c6h%No}fKT^lT3_JFV)dD3}{+PpArr z9@uGFQ)#tIo6bn`%XP;aRUEPiRsCPlpZsC1W@F;k%4zVF@^e;=^QYO(r_FtQmw7{o z`YhJd>df!iFj>K)>%E6L{>@Qq>LI;_pJ0^=`I!ehW7A#2pn3hak|AdEdE8 zlZJQm9-FNV#={QEVU_8*i$6)D>PrUYTQfA5YU8zR)&>RfGr^1Z z+nn7S=x-?3TszyT6GEq$AufuPf zD{fo3slWohMZ0xOguj{g!R+bWUt^pSXM`GB3?#ckiX~g0gP?yyY+=Y`69m z0-@Wk0qspzAKQGkx|rE(dKZ)()VuyRA=XBrUg8*LZ)}UBvx!{l0$GfV#Ef^gz(k|3 zT@76yP!5sUwDWeoECpT7qgHx71lT`c4aJYdtdtt1XU=`cR%Qd(F6vS6feVId|B4Nh z)?LZzQ&oidK=^sZ?`ekjMK$jyhiQx0(<&e4cNuwh={<9bxsUpOtxLQ0#e<}vEB2oQ zw`$L_-uCmbTBoVYgJ``cVx%NIAm;`&O20te&r&|xILol;(dVEoa95iEt37(vS75>? zCFGvPnQ^l3@!e}~_AO-`#l)NYnWS?qpcc8|u0_Ac8DBg&MP3%9a?4^^R9vYx_uVIG z9)@_>udH3!J#$6d!fUZ(xc>gyVBOENrqa%VX1bet)dO^iW30V7DbSyN2~Ui-vT*Ja z_A_$;oAgh-Sjn#|r;}wf<%QbCOP^f3lb+Dgwfu9^FDkNLf9#O7#3CZjX!q<3?{+Dx zIA+7=O0K|$6tbs~V#MV>!?Vbg9FW+s<0bTutK^)hlmzF2c*0P9)I}vUKB!EtD2n!S z#WnLrbk|d0lg1GYKbq_FQ2$mUyTkoZ%D?SZEvoCA4^z)RvVs$5)eEgkv%4?|hOADG zkZhg>yKW&5=s))Y=#FH@eobxrkNw@Q9zE3N>FaONxxHad_&WrH_CQd=cez(w>!dw@ zPxe6l%Q62JyfeM^C7^2}`emW<7BWO165@YT*Iy^!W6#r!5t&#N(q6b#hqj0xtE>+5 ztpY#A1=61cui9zUU1LusQ>(lz$z}pYVOiukrAM4#T8WOYumZY$x5yd3K6sHnQCY`l_FLzdCut&{ri z_nn}l%lmzAjDOOIcl#BYo3kF)O)Y>xrDHZYbLtkdi&+wdtumD1zN6u^?*UN!{`GIm ziCVZd#}De@6NJN?z)ohzm34>f<+{GCbgjNq)eW8qHQv0B3oL*u%4k2{orZm^eJ)(o{bR8};VLT=&;77?M z0FrhGmbm_xyS#-2tUccRlAOxF&N*bH_D~Z%hfUkvq*W$~$diKS%Lap~1EJ90E!@sg zc2g4&Ke7z{Fi(SW=lb|$W-fQLj_Z93D4UOJoGAL{Nki(9;c+VQ6Y`K0D5qTUtWQ*6 zv%99DA@Ju6S37_477qz;SWuI`!8J{w0DUq3#F>B-ybc^^F2cddd_tDIvdCv4F=CJu>yKPxNUxI^J zVX&;8MW;l+h*lLl_EN2WsN0bbEUyT{`a@pQaaux#l$VOC7G~*gmy;-m;kL=2h`#+U za=5Lc>>m-v{*%S$$_!8cPFb4zY+AQevP!FQ;yu#*#32WkUsogsT3Zhv4#?bloWB-6 z5}y%vp;XFk?qOd1OQDL9#m~^idEzk4`sS(I z^|OQV&*<~+_t)~00eU|AxU6r{<0L(iv`;alfl;z_1wqRFY^!Gm+wh`Qw@lrs&kI%6 zv)B_oe-T=#8Ereo*%S917elVhpLN4-oDY#8+|@1^DXWFV*U%S^u2)5jCFR;@2h2#h z=b=PUdD8cjspSWbA4*2F&Bp9fs!@9FR-0<$5S?kv17C1C+ThYLSLE)AS*v(f%7vq( z(3-mW|Fg>sB?@zITw+}E>wh^E|5r}omzDni z9E5vTa?t(dj@ZxDD;-^a9jj?`_#s|EF6xcS?Qz@B(@@aPH@15kskaiZV$cUrv zu2z%J4fifVJkuNx$zT|qPe-OE%YhJ|Sg5H_<%1fNK3c9A^&vLncSu0qKfmJ_-X@=4 zpS%R|p7cpuJssa~m1_3zQ_r_fMf!g(xdnUhDFH9Ty%NP^{jE4?r^Q)>cgB;3>!>l~ zFAYjA$MA!U3nKC62%jP4kKnG|0k70QN={@vRl5!RTA?ejH}gd#C8J8)+o7Y(IFpg< z4KE0GH^5`r&d_$=P=%3w(X5A_&(}AX;5Rl;mNC`^Eam`x=Po^~(L~Wede$CjZoeLF7fp%YeM|``Kg!W3Q@#0ZA6xS&xYW{Afd(Z-8 zsJ4lME%w@e$kR35J>)hudo5TIYNHlR>4#66{LWuEIugbmc=g?MMSXJoSbMH|^cbUw zm|rcsIhO;Bb`8_n*>{9p*Ko+6D-n<%dKd2X;nNz$S2MRCG@`$8e`S_2M)*?K4EE5j z5rMn=c0B^?sGXl}%8DOT8=pro^xONe(SH1sGGKW@SgjvwsMpqjkj-2V{tq*2yKQwaX>?tSLC8v6jTGd%iVFz z%30(*fX&?rK7=B~;RjQ}n~OMAe*TQz)6W)iMrxZ+<7=$%)Uf8CmB(rDmv!3_tmS5l zzY(7xK-}ms@=Tt_CcLz|W0gJDNe;A|k#8{LsW!xP;6JFjAcM5H3Sz`S;J2iNYs1yEg3}lD#b3g#<`o>bo|MnB{b8 zUC%tRsZqB3vbk+~F8eLw>7cZ_!Zkv2+0lN82WAdB{Uo@lxo8Ghugx3{ZuSF@4L7O! zbv!a!2qG=7uqvs-^7f1C4^%J4N$*8aF1c1uoJeh9 z112x@esc})Q4I7KlKWOd#=RM89)I}c%-Nu3uK?}6kKa4A%GPX#b}wKn19TaV8ebF) zler`sUkC5DwW*{D#M#N0&nVZo&$JdXM;E1sditq$;p2q63sLjj;MHmFkJLuuP6$Ro zUoB1~Tq!cXti7FhMMenOcQz8cdf0m$b#jST;d_wTZo~x0;|=cBG#2?*70y);i@JA( z+43SC(A|UV-c#7a%lDeiQa?J(FjQBK7eqrYH7k(2TPp|czOR!tVFMBfCH}?^!(?^S zA7@SiE){VJgh^kg9;wh0;``S^GdRb*?jjzGLN+xj_TM8s^}tA~(o_Asm^J7GTnTpr z@s!Zd-QHH`tUB@ zk>89**aCaBIq#b}vS9PpElv57Sa+l$U{Q0Cbom5i+~2qp`ay1{^;G=Wleaqe1}+12 zYjG-jo*_V{#}-q*dhlHOpZ2cQ;^_mgj%nR09KWKZ$Egp=_w%t5qgY;6V)w?4@{2=^ zax~+#f=E*8!~0Fj7qQ7US#u9NNeUX}D%k8~U}ia(JA}Lz@9_0CyuKBIpAm7kU-9-; zSGd|hp>$|Mj;i!+r3=JC5|W@*p)ve-z@&vAKZZI9Cduj*H!f#!>f^^)>g>m$Zw?<~ zj-C>OjAx;>sG{)WL-f>mGF|{Z&Q-<|1d&_kt9UaGD;Sa(KV{2`Cp_7z7wQyhRx!-u zZI44KXzFt@l^TE7Anu1+Y}CNEZNy}o+&^eSD&TLQN+K|wUr(Mg2eb@zgH*~4x-ZB$ zZeoUQ&(%ll4@0$~U|0}%c;V`vU%;NPqibUV!z+I`e$10mI>sS3DGK^fi67TE?h^NG z?{C6rTKtD-Q6`Nh!6VUgZ>sDBp0Z-RJYn~GF_Yekz~bzk4S658JL#9c+Pgg^vHjO* z`}ivUVrYI1Ny&N;A3wJ4FwxkD(}w4zw{XO}&PCt;^9`S_<+6IccpAEsGf@!3473(r z6mEL<8Z{6h8$YH(swnp>sP=HZT&8h;Xd!J%{+|_UhPrm82Im~kbw(c#(y@1SZDg%o zu}`b;;p_Lbvy&Y=-S_<#uEkH89|xR0UlvfN1SANPw;W^9n)SJKMSU3&_-$$86*Ln?;z6oD5|Tc!>Ng#aizM8Nc>uLoeK{WqAGY1YGoRct@N(EGU|YDl`! z&cV3yE72gP5Qr%cSWpCd3YYlN!>ZI;4KRUoi|MyhjH)yyTmMpq)Y3gAAj!dnO)ack@5w^VNp~HVN9~UK>O2kr@5h>!iKY3Os;Si5L}Po% zQB*-AcJECxTFXxq&T>1UGreTCz>DPU0u0`~xfrtwVW}1L|A4wCbJHTF3YIAAsUZS4 zswIO*uu}tV>h!d zd0*^3%U^i-IGmaK_x=38rQ}P>LfugVZeSG4`hDSke>+uKDNrXZA zXs97o)>5LM((+LCbJ!GDjy^?IV&e>F`!;s@P9#5=6{s7InCsfzcx>;HQq~)`ZH@uS z9_!(YJ<7`*M8H(y`{`82f}0Mt200$owbwU;X)`j&5>#wZmHRo8kE5#}f3<$YjJS^z z_Au1~!G)aCYlO>g8`PzPJ6!JQK|8|7R;-n(ehl~Vs2H0BlL~2L7iT`_C~YmUYnOlfe75% zq^C3JO+LIfM;4pB?m7A7ZAad{Loh&!oYFa7&rMSvn}QMcGC7 zA8^Pe@gp{)!GQ!uNlbB|xV>wG&k2R-4!-AI*7PT)L^@qtd1IL6D=A?GM~^!+W>2f< znFtuvtFo~JO%=R>y`VG8HzuhIX9V?i29;*k<+hozKJgVPV4_l1Wm|*UAA1)k^&&n6 zNBfW4fdz8$?R*d>x{K?FRplJKZ}-B#MszEC_%9h`Mym4lDA8>p`lFzB zfS=SwtLA6~u8L<)xOl?H;zNyIy~&?pE}Xk`cB;3-ds3B~YkEisZQ$v3%Dd2v+5Wo= zq4)_4%)~IC!@*ChpJ|7U&omMExkBhI*fb51ZxIPb8Q0BgfkNh^Hyg+Py2z|b6+#FN;D((?uhB4sjHD20lh_Z0qJcF4;Tx;~&?$l-X zX65ns)BMuvInNZ!-38n|;e?U46@Dyi8-%|mv6^~``A}%r&5$QyvMSF5?Q}y zb!OC%)}~06@<8@FBG)1kFrNn$7GWNKsMjF3`Rj}Yzt`6MstBFT9qB78ad#N&Tfg@| zR`vPP~^?7uxKPAxrWT3>m{BFGd$#zPt__eGO_y7K(vZZe~bzGOo zug#kARSb0pg$T(1PGWD~JDK*B(!<|9suxA7X`Kv0>DvnHPM|ymn3`QWe#8A|t-x_KkmHDeX@$mul=g5Cp`3fAy2T!Ax`Q7>TSI)CHO?4}q~k3MBZ zEC+GC3LYH}Swb7i-seCIPKP;xn&??zQBBF|5zK5`_TC0zI{0Umec2R}6xYV&O~ zzkj(P^fekvlm9R(*BC zt*kv~w@l+Km;BF%v}_L2Jj>7sxR8=2j6WJ)do?iEpl#y?wg925g0G~BJzr+fpiJ%# z%apu0NSIvQ<@Q`?4D&UWGU!l}A@Y!$7UQMGag6e%>AfxJ8_-4Rx-4o@5?#%I?h+qY zSG$ANFJN4$UW|#OUK9m~Nrr1hx zU~=NsL`uohbW`Z!QmMUW;rjY|B`;Y`57}$$XY3%A#ox%|4Gk*x)SBF?aX`mb2{Cz+ zHn6N|)Nl6&K>8=@(2&T3eMS@E!yairac2Y3DbF|GE>Z|H&}(d`bCp z`6g_Y#TUT)A(zGqwghuw9tXOVTr^1Ir`TzE@~pxCyF(E;2)S`YI^fgD-JVB}n}*;}Gs98M-4$$YF6=jQ$AfDNQEN|Jmy($MBlSnc zzCkEy3jzP()_Sv^TE>$0BHk|mdGQ1ew$vT`@olB7lm3Ept#<_UR&`8=Y#wByxd!dp zBjI3#?uVwwNBd8NvDt>*9ebQgm7wOHv9S_jWw+3cl{y?eVwVQ#n4+vitB;n?$5A;* z=ak!7SYwS%?#FcG?;-81u#tl*)g)bJss4O@c?9UuTwD>ij#x+H-U`lRzF>I0s^D(A zBV8gF-ta%2uYG@QLHcUD%Cz{m()Ab@ReYu{WB8BksxQc3mC^5!WbiFZsdaPM-Rjn8 zRC!Fc?O+O=YLFU-t`#Jd>Zj~c=Dj7DB}Ax5lTD#*OX*RwhLQTPVVL8x09Vythy3!;93;;-AWZrk-*@o_&edMs5k$(xZ#hwn#XF`YuXyw){7st6Wn8_3U}5)Nx$KxIQd$A%Glg zy}3-}%j)u5q5^H3RYFV2a)mdo>;oU%ou;n(RVYM>3;f4gS7%OXw`jwe0Z46|3sInGKC#GGH+rUzDzQ)I|{h`qU@3BT=^gdpSjmD&ha{V=smHD^hLJIDN z^cgs2mHIhI1G9y2859cVx^1t)fKI&MD-})58fE)60hx};6wv?X!k|zIdHP^}m}{y3 zSh}M^$3|mYpkF5!l*X_bY2Ph!lDSOgXEd{ezb6(jUqszkLD)EOc6~AWd?Ho~=xd@| ziHc2weQf`8KCqA59NxKRv$Hw3fGZy+>&>v%LGP1$r}e_DNj{GXQ4DzMx^UV3X&nlE zZcFB980RIoq)yX!LbV3W73iFdsK-sYOGR&$X0OJYGRn{JX?0?xFpwKQQ`?HWkur8* zH$$9TjPk8(O|X=bY70q44J>^4QK%uY?MiGue9%oN>H}Pilk#57& z$4v$xa3B5gWZg1U$*km`~1d;sIC$n{5^4?Rx(XAq1TNN;be;GR;EpSk{0`LZY#6sQ3)}mh2QYvMlgfd;IXQLRM!+~G!x)7Afvz4wZ0a&NyymzBk*h@wk6s6>j=dq)K+ z(gc)FP#_egNa&$0MM0!V?;xN76hw-Ij!Fp-AVTN_qJ$7as7WY+knESWzW*L)jB~p$ z&NyS=22$Q%dD@)MeB95Uk+HCQu%meui;Hzpdq#`>XfanjS-LT7G5mXrxG`7z#Wbxi z(We!<_t9lmSbTz{sa3uM_W>OWtq=LQ3HEfdwNJT^GR?isT00zM9{3gW+dBhhC8ZaC zHD`BoUwEd*We%dXm<&cpm=X?#B9xL+cF2!M_E-F(xA%qWr7l-&lx$rg|k=r&u}2(Fd9O2fx_5qWuy+cmu{4#=A87-2B0IfnPLsU9er;U`1?>ZPwU| ztKQ32rlgTb@gZRuyagPyx74b@+*Y84kPlATn^nV=4fK|!O97SHq0Xvo79j-xCNEpb zu7%&@(1<5iGoine)#cjg1ybWtqYYne_<)vq(9Vxq@2e$R>$WQE)T?EU{r8$>hJ|MG zcd(HSESu{($<}#|&EJU$jav&j+TpTm?e6MQCXqlj0&qQc!e~DD+%s%ZYrw$|ITIlA z8P#)OWwVVhk!QP?ox0C}l%uYJ*MEjzMegvQn?PjmxcJS?`@NpzsIBAv$@ro0{j$>M z{r;CNTa;%q@ru}p>uPeD!5CB(bN5+H^zuP<>_vgE=aR_o<=1NMhPIQzoL|~Qgp3pj z^-HlGll7tVT^I+3nvA3!PvbJRBrGFHHvgO>wo@tciz&_5#v^L`OzE4T2Q>)I-@L1;HFB z8g4uPgz2^|LH<<1I$`4rHq=g@xqK$W-&0HG25M6^0g({VO28$MJEc`vwhh9IxV3TC z=GyoneLMU{N>Rw;4tp`$<#v~7^}R)JC%?yzhf+XA(+}{EZ)R)4ab&R@$gzOx$J(Z_ zcJohO98pzI?zt#)kmrtTIqja-RPky5jN|`O;++r+A)X!6c{a|zD&n=9_2627rLU&Vjx&5kXlQD8NZ3;4S{z`t!xV z7KgXi)MaGf;33*Tc-0&cb@IoLoi7#1b!#7Hz5J>X7K&J!A(L4Jgma|gwU zHSUB)GT832PjuvVh)##rn)E=kSoqCga-;3Lj<|_{F72$8`q0)sa?lp^oZUZrD@EO0 z!$=H8hY;Tt>7!e}GrZL!$VCnKQd2MdShJUdj=xGH6S!j7Qo{1MMaSF(wW%)W&Rkam zt6gr}@oA2E<>Z0?-Us)gAT?P2y&54N#@=}ThGk0o8S)FgonP10!(P;|UT3^QmeR(8 z5UUO&;W~R~!Fmt)w@w%|`y#8zFs)?OiKK&w)GQyagb7yq!Dv>1a{1cisyW8k)LS{@ zlaO)_bEIJ-By6mwsDU+qE`A6ObD6Ttayq)tUQeBX3NfylPo-EqJ)ts$-(yabYElna}@F zuW~!3qAU=q&C$M1UmR)J{jvO5HG2*04yaK4FL)Z2lDN(h~V8 z5KgY{eiXEc#-}+YWS7|((1T|i%sG5et}D$Gvc&=^py^<<+%Y{swg@2%7P^Ea%}XtJ zp*cTDAG9YUg~Iv4+7HY-s}X^OJz)74k^m)*06l1C)~mukP1p_cM#pj_#?LwVQy z(E`T2Qs}&8PS7500bB4xz`4$88DLza;&Yc0(}^srh`J znfueFXN>*^o0kiEsfVAQe({?!h#q<$GkHmd#lu(rvFpsIF!%P@6*o&P1!vA&U(+$> zNZ?EE(Io5pHl7PRu?Anw_1ZS})4tIEk**j(ZB$gMIEYGHj(sIoG4iu;0Oef0dzigj z?wpxIEa&j$U)%jd$n2UF55mkqsj2LAiBhspj|;iIX{JKGaBk^wTm5n8_W zMH@b-7>K7KG&SOrpUk?sjNoi`WA6?h@^9dw1IWWnZ7p{P$+20xj-ms!q9E3qweo#` ziVJ`Cy1|pK?R%8YsH^vMYSlwLZPaDJoAsVLJWT0>#jtVtb43z%xW=}hpMtS%0o3t` za_yFzf{Cv_ryCx2&jPW)m{GyU&-D(~af%=TZXZOgPmj8X!^a7F*h4xQPy`|-Ox*2? zIL+rv8XlUP#YOF-ezrPk!4%R}Hv}En#=BsAnm5B3wb?|aq7cZA{LN&Y>h=!@IAN2T zpY)@UvRu+C`vLL?Q(1+zT=c{_iCf|?!`{Nu?xjATI?JN)F!1IW;qY+BE$DMQd?uxS z?eXG2>5%<;Wo6-EE9b`);rGLr;RqW3S=O0Cuzw% zbDe<=-4V%*B|YZy=ZB9r3j?h^1@#}E{E}2$APUdrH%7jHq8Pb|eNwQ}I=%L+a^IVJ z3A3v7_OcQ-G?vd#q-Z8bnc|I3*g2P`_Ao%a8thUJWjvb+xJuALgeHr_&|Ff*{We3j zYPEK`&931}g;9kjTMOB*`1mJoqJP;XZX3(*z`Jxg)=CGFAN6lQs(ZDvxium+I}fw< zZg2BqR#YUpRRrS7ZK9(HMGaKE)uH?)LNzXLj+Gb`I-Q(>gB!ZIx*pmo&Jd4!x+loN zu3zWN-^^Z_7Hza9d@c_e-f19HKBfvL{kqd`M)u+!aYl>qV?)2%*K8|~efq?(CiQGv zmiSU(O)gu;H)F${mA&SBSGXTVG<+;;xu!ok0`M6yS^FQHR#mLLs1W~~>Pw@kWY__= zH{fGkQN7YyWa#6_)GE@N&BIOjg7L@wq@&|#ktH(e<1huz1@GL+po{J9uDqXD`RLDl zH^b?Q<7t*USJr{r9*i2D4Tj<7Qm^Z+1nDS7+0`g`?L)z$^|d!bf)aUwA{tmsA!LVK ztb(&4!-$1vlr*E}n=3k*Et1IrBIFwN#?>`HKT~8X{G}^3IQ*SX%8IR>pA6e+b{ssY z!_!G|P;3lunF2YxlR#I$aGCr(61EAwayA)%=mUxlJFhPkev|f%;Z_4yQI6EH5#!_^ z$ddvzVggXL?Ke&GhJ@k4|FY#e}G}L^?Y21f)-eX|!n$(TbOd;`$R zM+L<+&{qJwsQzHXSq?CRO!IZ1zB7T}cNz|c%VLCd4L+~W!SZyT-2Uf3jpqKZkOt`g zs)-!M1OF!^Rj8Ljk8~&!WICo;#=i?g=8cXN99T69$fq^!S@S?IKGXT%b7#+SF?;GC zm~6LWx1CnF5#e#3G4!kr5J@1#=`bE^F_1b;|3b+VEY?vU0Br9_>;itI783NLHsMGd zqQX^47Ok<~B%*bMPXT@MLHpU!^z31R?F~4JmW#f3-v;PSG-uU3K1-x#KAOWu9juYg zIPcxr2SBV*VfATBOL2bwCzjxB#XlHjn)P~vxp$GOf2kR)eShWCHV*XWb0>43HszW! z-hX=`*Q3aYN~H#&o5-JAKbzf=pFiBi75f5|R`n9SAJh#NbAya7ilFq3Q&1h{0_@ziKUX392}RtT?iQ48XP zBU@5Vw*Pl~+=1kR*74p$2=RioY@qWo+(y4H+3ja`2kk@PVqfaMwGRxD8o0lM=q%LU zZAO1M!FFz}{~Fg_pLo->1e0{4&61J2Y*g-)+dj}|Y;_o&W{-uN$-j~RnXdr529R9D z#f(NsBvRn44`MuC#y7yD`4$&B%fYuY-C1n_y_ecnCOHWX_i+*%LuPj}2rVjNIU%&P zlhl+>ItzC=ha0Dg?5xi@h)I4A+*>V)6Z&}33p+m)Aud9NBW|LMWG3M13jXO8qkG6pH*B05SXo~*5RVwB)#*T4g64quIhvPL- zUq9of-1p4lh1#l|C(fXL$k$0`q>}0dGjT)>&;z@u2@RuXXV|dC-9+1&hTW;MpznGvXH4UVB6zee8tM1$(Z)n_@0H#(_fDg|0ogDk2ZrUp zNHX#%+3lQm;53gBg|{1-+x`F$K4H}74-jMPUijzQSZQ?}thWZGrO;)C5VUkgPldV| zeP_roD&W2uOtiO6f*UWV)sT7JK=26UHrF|rMz3_*nFGtwePzIFX?etmSHxn7;o`JN zf!^Op>}rwBegzVxLg+@~$enLZw4K7jLP5I;!dT=x6FI?uygh?*i3CmfW05kk7;0P6Wjy|kTbO8 z4+xOfGitVetz_}xss|ex5c~aYcwD~blkDdzROP|j8r}bSD2cGJ^G3ojJ!ry~dGtP} zCHo3XR87xC{Dq!puIB>FlwIPjIK=+>NwM}#L;EbuvHt31h!I*F1_%hU!{p>SxGYZ^ zDZ_XBL{i4OP+p__Z@V9YhVOyCQ9S;pw2zy3LyZrQdc!9WX-E%%W^NHQ?1SUf-g~4a zM5$YZ=sDOy$7BelDsJz%#kac|N1O8;6`ES%7G)Z5dcS7un3kkn4GsG~4irs98HO1~ zq@N^gV4Lcs%hyj3L`QD?^BC_l9VWX)jXnas@d3{qWcwA;JVA*~rg;t#MrK=T{h%~m zP|?xmnL+veL4Ag?si7_%guqbgYg&?F($@?Fx9H@WPB6>##hdwrFqd?a<*=c5s^JIj zM<(fBn;}ug;mK~i?DD==r*Th>y`kX&jC}dc!9GLj#_N+623f^~yPCymbXjnbC;vkt zsId8Z5#%)?C5-sb)0yDIaR=bSM~PvndZHH+p?PX)qmml9GR-j`z=o(IXh@%(Dvh*6 z5Wn4JUo|l!4z89e1iWQIqpHgS;$$|*mR2R1@?X>C3z#m@i{;v0pLy(Y)0E~=@O5@E zu7n8vO}Ka3y^}JTzc0IRB?11XW#!{Pf=@BO{9+ZP<1N9;dM~zQm`!`458?FIH3mwAVIzYo~bJ)pxlFV&zCfKo@!wAPd)T55{#vazoG1 zPJ=F7ZoelH;NX((CKzv!l@Cn^0f+RYmTcJ7bK5ANy*7c@z&cFFJbO?`-9Q5 z0=bRQ+Vfq8mxGPGU+jB?0d443=!CU*Ud_hd!h%MA=fBOjS z1UdHw8NnF-kCDB(K(y*PugC%p;@3<{TSfhxMDt&TZdMK_;uf#4)o^vSE*#L_c;^kP zMtC^l6a4cAx@3Ko$|s%kHH~KOIz%RpLU^G*)FWXta?nE;Ec~}qgK2<3R=KfOLv={( zS07ztC#FS?nbll6W9hoS59Dp&%G=QJrCg6uD|4-{;(O0;;{2vN>2fhbQ`qb0Q;Pp= z+f4Mzlu2=TT9);EeifzVUUMnw{Q4iinlTyAsm`;UcI4;6`4kN)Yb(azGc-K-QL`QM zgCm>dT?S7dXVa&L=%-FggkN#%GErLz+k!l!l?^k*6eyp6_6W=l?W#yTIc!d+jFMcM z*G>)y3d&7zkze9Dkyi`)iC?8LU~)jWeZl1LCGU;ep>Xin^m+zJ8Le0Fnk0D7C18v_ zS6>LB9R5=+yjwk`s5H$?a7PywN$lJY_-=-dhQ$UPD@FozCC$)`Q%Mhc6S&hx%EF1m zg`}S)x-od|q=}}4M}Xo>Z0mXpIYaT}UP&AhwwaUcnN!@)@eSxJl*d>ptuw#bEB{fs z0eHoh$6c;Ld#xmc)(`e%{hJjcD^DcY1qLuX%fen#RY*D>h#jhRTm{zuXj!d8t#Etv zI^BKhqm?q^?;W3w=%r9xtcBJZG6+dt)j@!=mU2jSYR)+iN?3KlPA(LzVYL`<8VWq( zVE59E5(6Rh*)`~ulC3VOHFb@*-8&P1kZ8BMQWq~Gf1l^T7#b>-_z#GPHhmk8ZYz!J zFFu?u<|wKO|9COKEbDRmR*W!5>GJpsh2~?nqRRPv;ZLXkNc5@+?uwE^31rnfeKDu> zWl!zC{~CN_SQwNR3gSw!dt+c%{b5^EUq!Iq7CdlE>pn0$V0^1a?@l`M?cE=IWIGSj z2}+x_nZ}Bmj<6yJAT|CKEcVxS+GG;(ZsE`ob5`_t=V*Yx=|*T#yGdF3>hB&^M$WhD zs6^!6SyxRMPd7D2IDEDCHae`AcT(1eKMv{q^QM@zWIi9|6*5^q_N--bLz1*BY}r|fGoc8_9YC-A_~nLQxM zbXfOV+>~64DDeEFPE$^+=u9R$W!rLI+gUnV@(ji|{~QHMr330svSWq`BubrHRx#uZ ze&uCnt|-P`h$b4}ElL2~ZIrc6NUnz3!q&;K6K}WdIK4kfQk%fyWsSUWQ{7nlh(ipe z&f7WXms+X>2#J9MH<@s(T!Omvji-CBO zyPCgJv7g8pB|xMz>AT3aE~k`Kg0>*i6E0kFBI?}@^7U^2jQ95j6Ik^ug-%s7sOC_L zgTJ>#y0uAuSn938-QC9Rm_{%ERvqdP>f~^KfsU)zY2R?^6osox7TRQ1phitkpf&8X zOnGEW@#M@z5dT0g)MEaF&_!rQZXIGsrI-`**mRd=S39H+nvP|qHzcFyDO&y6#tOmPPz*p+E3Z| z%8MA1^~oyq{|s1#mgnO;dl!2NjU73cQHC{gd_kryS-JErwPHD^2@dMxs7G^hiSqh$ zb&g{kLEX<*5+S9xg{UG^yE(%6pH1fy9nPianNa9uCf>o*ajgO(xk8BN3W5W@ifYFNiaerpALpf031MvpZy}R}m`W`5{A|doPxnf)QN4b~% z7#j+?Ny+IBQPm;nbo2n0KV|J2(mz&xXyeW|QZU$6{ifO^!t@|eyC%tg(#INV^12%o zufHNb94>h#=={d)BRLVwj;#GAsy54R^d zwc^fZJP*=yy&@agOVIdrt=;&Mo;~X_0}(0LOS#-w<2k5MeUvSA<)ukG4GivvX5C2o z3RK**jZRFQunnow9k3aWQ@=48mb^W zbzAMCYola$s1eSZ(8az|(iiUx1+IvU{Fi>xf>Z|HY$@!9_6J&OX42u`a9~6P}&Ke2S-}7NF!>qOS2HJkkEF$N_1-Az^@0`_m z2>3^GO9LPBrEM?c!o{;9C1}}!AIkbJ8Ihvhbjg9sMExu+co)r11<)_u{E4IQCkU$! zv^;hS1AI&$KmsN;aC5&s*xe9z+{|kFTbloz;w{hDdiV-&!z+CE9X+An^9&TR$8mV> z2ANSmJHpCNDXMy238)=xQq){7xx|fm6tN=40)MXB{rTW@Z$E#66aU|3@QZ}x z-n-%`Co^vR%1P5%dqp#sTzaB^9^c<|S=qV9ZkI_PQMi*bRR3{jDONFSfWYoFfVI|7 zqsqOOa{F;kM zfU3!T{(QSRueZNk#aI381{C}>&ulW_u*pk72$QU?hml<*z8<5v} z#R_Jc!SB5IGE$#@tjM2|p|rdvBu7?x9X^LikVWA~cMK3bNP8duO=c5x;CUYUNtvVD z^Zc_5eRso(#!w>CJoM;k+242M{B8w(eRP$R&HrJ#efL?d0LN6F|J&>uBZsiOf%_BeR3E-_;}f!Q z%vUTSQ0}u?sm16-&T9zVJ3~%J7bB}E6(CL)YZ$7Lw29wpdi8cK>k9qbTD%W+!_uA4 z3FMZyBH1f}%71EK{O+-#ZtGgsj~sV9ssrhL$CX@Eg$Z751Ge&xsN+ zHoUUcPH9Su_8VjNFoltMjW7xH1p+OHjrv60ov=L+ik~pYG}sbBHLA)MI;rBr*>UgP z8L#^~QR=9zcBoqFq+K7GkG>_Jv90W@?u347im|H>(89RQ&_hkTel`r2R283}{j*pE zKG%@6*iuCvy_dr7gF3IDspV`ykS}9MYjxx|YH7=q3uE}du8!s&oqn& zv@Mhl`+46=e6XhU%D`)(6OO7`+;NT>`X@eeaOW~Un#U*_*o8`Sbq=^lOVpE zaeHHM`8l!<8s(##J3#1eYSE8sI}2$~$~Vi1#)egUsecOkoU%nx2WGgzA?H4YfyphO zXC-%YzHxFTI!o)m_R5(2Pha}7Ny^%lEM5YX%6srMO5l&;?4XMnDv-_$?TaZFv&{Cf zVo_o~*rwVyIHTe{V0O(9Q=ZI==I`@Ex{1QZ+>ZX?FnDuZ6Nn`FeO8#RRG2XT?UWEV zZ0qbb=}V*$+j;Bm9*8(U*RL0mj$Ii-X^!8PIE?gU;us4GeuEhcYDN%zyoX~Zg4h2H z7bjlKrCEaQNM40HTio)`&FDRa!>ip_lm5ZJl007uvMKZDlwPz;ZUib2KR1(uE*{+z zUUI7X2VdQ3hsW5!maP1ZjM=Ux^<(j`pbiOZauc@|O(?MsF|uC{Gf)>>d==!@>Qd96 z@_Rfm{~!%X?)9|mZ5z(x^DFU+OdE8ght7KQXSI{8Z%L>C?qXmtfD=CrbK3pKD&hYV zU%dyO^;hiRN4{)?+4%yUG`G@Hi95X!$m(LKy(#%R*H?P2WSR?WlaqBnyV}t}EvhNL z+s4(@Tgz6XBl zDp@Gg<3+IkNnxB%OZdzEO<-F__C=L(VW73cVx27J0qtgcCoWoguEW)Jzk5>TE8TjZ z>7kt!#cDD582#`gx|5C^$2muqG9RP`1}~JpWg7^%fIM}RJBxPfSIMe>2{&4M0Qvj& zM%xE@zMGD!l(ZPP{O-2{fAcq={Dgx%0He-F5sfdcac{bN+uLrZNw>kK~$j$3-o zm41zEd{-gObTe(Iz{+$WM&Q4?7lJK~^~|}?$;elae++Sb`ryPDvhqcY(D)y2_MkyK zcdj_^NlB|V(?%~Q5F`XPD=823;k?D#PG$YhNL82S_j~S@-c|y}MY9gS2Pl!Gx;kBj zuemt?aUjTnYV*I5DN16D1Uf?6mfNR-gqJi3+J)wwSPxzqt`PdJ;cI_0JWsbQkUIeyFx2T%nUZ2eGWV zWaPdgq4N22Z4vP+oFt3>Ox(A?3{Ud1+_k#D)PX0-ZH*a0g4Xz)^9T3GB#P@LL4V=d zny1`d_#`<|g}C_h2dBvD8K}Y%sht|ZvIB7AOAl`hwNW1l~iGY^0gEdLD^Tz@$~kQ#V? zyWhB1(91Kc+i~t6DeB_8&3oDeX?}+?zQ332hPoRJl>Ydx{mo$~_uTi+%IwD2`;+q7 z5Vyk~pNL;92wv)oALj4H@WD9$(g;ZRu3cx1IRH8xTX>FO5vca;aKtHeXm$L!}1JtYf)x|m1QH+}@BV!k|2m`LC zjc#yx)0-RFk*ZOii%sbcW==JPBU5ZU+}u&1Y=)%TPX-k_B)J|Zl$|RxYc+|9jHkp- z$=FVocr~LAi#-0$!rzw$@;isZ1rP6zbfM;*&i5<|A!-J?lTS)fUN=giF;^<%)&zw_ zjntp|f9KYEJoD_a$(?F1f!M8SsLcMJHr4M*sMIN{hq@!S_#BY=dVR_kmtmF5St;8a zJHAYxN}M+|?t%F_#2McX%ho9L4;qCyxTsmTRKK)k`&2u0A3lD=#x{80hI%oM6L+2FU*O`74c?p9p? zbQzatO2?c2JP`}NNV}A3eTGBVmsoG}=6&X`z3+nOX>O}f$*W$yQr`ult@GZcS*HV^ zw|4Y-NgkuWyKv?>2BrAD4~w2MI;2BpEgTJFc#i=CMO*GkY^jsB&I5b)qAsM=ce=tJ z$V+1HcalR~Gly1D$kZvMV6sk|k%PL^QC(;K67CJSP@sb<=7mr8+bOEG6O(KI%L(`_ zUZVkjgwrWl)28K%%z1ZFK%ph{@p4#HTEhb@Y&d`;JHX%=Fw5pT?~Q6DU>j$v{aorh zPDSn!Zj<`v8@61-!)4f>gopj?L2yPJ{EID)+WACY%=e4XIowS-jG8%k7ML1!Q?LWr z_!OrA)oow>=$nx&1!3dP=sA(Y&SGO61HZCSvu_soZ)x4=%*3HJ4G{$k*e_!>$VIN| zIKPeZz#~Ub*|^DY{)jgiwb9Nq`cNQ73)KZ7(Q!N0wU_8`y>J9F7aw4WD=;;n!!vrB^xTJd1oMohMA6C~PA7v%-tNF12XKph z!xwW$kU7wnTFrvn2=))=`?g33Y6Mp$*F-ES> zMB@gd-QC?~hs14?w|I&-luU~|d50;_TU_S!{ibbw6|2cm4VQ2U#LX|-tRwVwgmK+y z?x-SZloqI8nk~?OJIw&Q6AthO0Nf5#3P9d6A4Ck2$Kr3pAZa;An70$|N5rph&()6^ zK-c(jd-{dnp4@R+n|WGe`cLSLj&Ym!LCjg3$LSHcJNJ5SbKc{Mb7oSqF^G=sYTCCG zobQhyX+99U5j3?8)ZepvPDs-ho&BD--!v;GEOWV^e#CG%?1aS+bsn^Ke#*|BY7Ox# z%#aHI({lKTcd(7CJv$f!d6$^MSvD{Tjohg(HU&n9JdGr4vj4Q*sqkAl&oFIXChenH z4D>%lj6zAxz~%etT$e&gPgFSJh%7D!=Bb5c^v{gR?ggH#b>;o>nusGwnU$ z->XJS)Vubk+Xj?uD4VK@_v1J~- zYd3Kb@>>H~fKbrNLOs-xD;Z>i+K&Qw9psnSs7dnjQi(T=llQOEd4uj)<{6y)at`IS zB<=u8_|B+cTMIL0)11s&uG}_>*O| z2+QpTKjP=}Kw?IhMqS^6L!%E6(GIw4j9hdC+$<}TT|6x)wW>5usC|3cj#q2%PcEm_ zP}hABYxzQ718IZ@M+^=~bAI0K5TRe1G#?JSYP6sF3l!E%6+6NzN{Bwd;}v~Fv4$^3 zq`rN6uOSmaAtF*b4KmeODm>W)NHhCN4&<>KW$`gMt1Xe|VU}Z&o}P9gH1E2vZaG*& zMC(4uh!1k6iZiXhrj2s1unJ;NvnMn{2MjC&##*EiWfVU}j&zVz(!VkY9*SH}Tcg6h zrtmlcmgsjQsKgPJ?R_Ks^flqQzKi~#EyMdz4SC8*0V50F^m8E8f5l9Ni=3 z1=N?jeHMjKIKt z#Et}{ynhH9F&x{1^7US&=m}^^hsA=T6`ax@r>&8_2?Izd^Po~+rcZBiEeUxlAG((;VZ@OME+magsP!EdJ-ICm{K^CTS0K~o{dVAc4 zGi?BCkH*Q(S&&YHxp{KRY?5p4XtJk;Ax#uBCFeRE%n95Wovm`&r&ehF@ic>PHGNa%pfz4&%);9?9& z#z@(+@ta&G_j0$wRpX3QaH0QMPh;;Fi&7Ae`8MykmqG;LOcQ~J?!71!y6FgvCVpQ# zY%7r9dd(F3zH0k)0*>Mw#0C^DCO`!cZz+8hv(LO&vXY=;=l zSaK6)$=_ugQ*DI>5EOr8H8}$CRi_DMlM=;7X<0;I)G0LoG~(iBaF_hvb*auNq8`%d zrNedAuwJPPzxTHA+YOXi(>p+F^v&q?#T83m;nx?XI)jsc)a09@bh{bmr(*(u)w@}kPPvINu!^XA*3y|LaB3j9ot;r(Ia9urg(>^oV0Ld=_0!*990ve2yI>H zp8Zf_pu76!=I4s&=aSi^2ZevogVG2|bc3$zEBFVtX#J;{MnqPUb)!mD`_fJ+0lcbY zM~)4)(n`{O@!EMEfBCwXRKWlhX9f8Q2 zpbC5s?%By?O*LmB9k@s)`SYF`B~O1m)(V_Uo|2v}-jlN#rPOkcSUr=N1gn4DyZY86 zsK^ZIYm}#VF?Y)Q2}rLi13j~t)X6yc!-#-puA)z~XIgMz;Pk}(SD*VWx$=Ry;DIZz z8XcN&SMgryZ~2e&lQS@7`~1ds_~TEIvBoB@r*`g=A^V_5P3`>&(CSRMPeA*y@Y8tV zN!!nLDmus~MTd72jqjaaiS;57D=4;8?@9mr$6pA__A^Fl2?dWpX0;x+_!@Ytcz3q> zPxZDp$RCmMB0n{lMGLSs2QR~Xvp`=R01hGd7suDptOHz4vD}@qFPiTZ&ULCoOHiSS zXxU!;Br~)Z<(i_Uy!WaT)e||Z+IBkytTwXwo7x!brIsXa#S{=|1LlSWP1~Iw=p!C+ z1tUj_RA>WRw!^o=^p!xa^R&0WkKw~)K=3Y)v8@xFnzEtiOguljGL!ecxwLdCak<2# zrU;m%jkq6f)#&Vpv(w^`IBfNIj862Q|7crV&|Z#U^L&TfP*Q zicbs3h=ZljN4nx4KPM^Zq={yTG!~1VEfp9>g5P7iI_ zhaa(-jr)*Hf!&@}dqG(AYrNSg(^zlo?398qwdM8}j)+^k&N>&=#ZWU?q(1!tmDPrL z*k_daU@Jtj#E@ZcA@M$$UY{p|yFs{~d#k0;Z0fFPI&sQWP{hFrcL& z-N9xhzz)BcuGE;HLMrl@b;W^hJ<_^gGjau3c5arhZdc5Et9hPy`Az*hS?L>86^_=X zziPbZ7L%L;bI+AxHM?6Yu{SHzEyziyLuMP1yW%I3lzJiBCUO3=6N0m9@wqyO7@g|k z_)ECotXdh_NceXO<@D8n$k($j5+NPvj3mm>4})bpJvq|k6f}Dy$H0`exk9P_g`*e{_UZi-k686sER`JH$oa5}WX_}1t=fyP$qR-j0G9jQn zm7rUG#JWlT191YJ@vGh+S;T15A58)02;@sBXjzvPe1He&36Kp6|GTq$x{;RBX%(A0Ulx|9$kgCf4;fSc~188Ws zdiiR>8ERyCcS>~IqgRKbU!<464ypxxMTo%rMb1)AwgD0SSP#Hyqkk>-SoYr%EQ)5* zTm1RBn-mj0D`Yh{QQF+p5!tfTZ$0wdLs$9qY4)#+9$g5Nc^ldn)kc4tEs@bL3>R)+ z9PpA$M3)}Ra&C$_1LMnf#2VnUA1hud-MYx}sm(&d-sUtyugPf-0JbUH zu}e0_UM>=5xkg|4ZSW$_->~ZLi{dRHt*seHQxjd?#|)y{ep#FoAiCJ$RrAF(S_Q%v zRQagKS;Hx>O!I~>Sj1WoTeme0x&!I{H_c~~W`j!y@xaT&5q5jKmgo!KY@iENz?%>d z`zqs3@c}2;d)icFwB+eRsJWLX)!F+hQl@-e^BvdL#3ziSIF6WmLA9Ubhdg;!ah;tV zo_;^>`h<-bZ*WR~!T%^^A(Tv-E8tht48nd7?=I)wE_)&5swmXd$7ynuAXf9&5E^)T zJuI>)KMM8#BNN^qK69lrC*{l@!$nxJ&2vyc=2fSJGw;Z)r%!Il`S58Ij6oGAR$^h- z*l+puPESuW%e72Y;Bzlen>PE-415b6`NRHRSfvPfb^s-bj5J@Ky+9T>7dYz9 zajH6~UZy=Osnw5p>#*i|rME|$y9M-)0s;&9ADf>rv>oWtYWkDtQkd`zW~Fx`#;ZZe z1Vzu_URN}0-jnIfcOEo|x!O6!#=T8H6-^J3SSplJ;JEBdeDbl=R+LX4a(LB`q2zVL z+=|zQ?gAi9@TwST49RjGIO*Bjr{NA+C0@1|`8a4Z)RdYa-&k^?PwE%V5h%!`Rvd17 z$*PP$_9dXYmuo>9z#c>P1?M zTNKEWt`m=j;_$ZLLQ@46f*0D@uH%E%cJ%CcF3;?23t*&>@nK7tJKDZhhuOHBWHvc7 zN%QOgJ*zMtW#3s6EZOsh7)u&8-Y}>JpKXw&2VaN|nGQDUs9*b{Ss<)x{;Y#%yPW~? zrFWuWXu|e|pw!7AJLl$z{I|eyZn59(c7IpWBV|InQ^I|+oz3(0$Q699h2#0`)Lj>c zCnCojCDRvgq)TMHnr&Eq{s(+yY*SB7c;Kyb6IG34oe`|O$W1-T8kX6y0FR}#_5nm$ zl*xt=9}_FeyM6h4ofR_C{6tc=>|&0ymG1SQ0cDc^ueF7f0xK^L^fds0FGM7fBp=zq zpBJkn74Ukkph$|)XgeW?^P9bVqP^a;V)W)s_~ZjPwn;u@jvKYl?n6zPy+fV7X>5`{ zs~0AbFy>~77XF33g=SG~yViabXq2Ay$1Xqs)`oyg_|?>VY4MODKNP0`r=h)EG?xWP zMR(GbGe}nu2&Wn&wI&0Tfm$1?{8aL^+&^obAg`2EpK-L(E#4X#wJ5b0TPP@HHMlpnfJxSGNDptFkk1yoorN*{L(9?gBrs>qq2FNyb!IoTmzx8PJ*sjv z<@i0ZeNHEGGYGg3@K_^&I`XH%iPMUgN^5@xhF>cldG}h~^M`sV(Y3=jZ{R$N8}sIL zcvN`QSlHO@Y*L`aE|mNp1p}b>{XsEB4t|8z=r>6OwP{?r6H>H+@JT4~(kQWT{2xQm zsQ&~QrznK#RYdi|k_qt+ydR#47U=v8uDW{FZXPx$HPMEReNBK1fCA~y-;tEvvkKLJ zK5vW-Y3+L#zI75SK2+xKII`N7`nc>e0X zNLmu?Ojq{B+V&ik-LXYQ{hVw!4;|A$)w#g>LXQoiE_k~AK)=r6Z30O%M}~V^@kR6ba*Mvbi0pY~M^CF*&j(6M z$L~zP7MH>1a{4jf9~)GtYqBM>7=qkX|6|U|Rg_pT2KON+WLmbQ7Ih{$^!c5^l(3P5 zxQ#E^wg_OtWB>7$9Pn+d8E;ajDD6^-*!lLdJOA2~k*RnOyah2M$sk}k+Mtufp?kOJBf?dJ{7$3oak9 zV_ck5Tsa_%IRpOHtNnwDq4=PpWe>GI-&xf69PR$AzG~9ZgSWF?IU$6-^GJ_PzYYUI zASyUGEa?I~sY$V`p0?B?5m1pZXvp-yHtMzqs~PC2sl{3dbr|F#1^tW%i{D>EacQOH z3X>(G6Om1%D~-GZ-NA#jP`gK1cb)&RhfL@;OI7a#U(&JsVs89tqndVzc7Ch9Q+sAK zdUh+m!QVA^s!E$Rh#cK;-Zk8=88|?H@MHRK@7fes=s3}dz)g~>1{{FneT-_Nhs{>3 zT@h!F%2Lz#O=057r<%_)pYeB!&OCyB*|bx%URcoXNH>^&_lpH|R@uz`j7K+1$rfvK z@0%oeWew=-VP0t@DK6c1{hNf5UATYpV~bCGKaRh@93hN^PgY&ih?-N5`&?muho zTR105V59=Duj+j2m4y)=Il-c!zS`JGHG>+>rDEX#x-=3^fq1Iz2uJlvgmcFN0jz5B z5>b4msN1sVtax_MfRs=Ffb0q%?Pbw#R+^c9rUd}=AmL`y3d&w5^~`gW6|Z@UDYFvU>y$O0uTtfSs7f(kKkpTYC}C;>{gTQ?b*^?@fJz2+!rSn@#k7Ev zz2m5+fRonpEUxX_?Nzjbi?jcWyYC8Xs{7tVQBe`_QxWN+AV`-IAT$*Pm0kp-_a1t$ z0tzBc0SO(E-g`nXQX&KhJ&@2th!BeO9_H}*`#&>tGZ%9+#fOUn$jRAzuf5kg>s{}9 zv2XG<^_D$5XW5-!U-e24t8oBmOOsA{vY5JjQ{AAZZ-M-;`Hp)^VL}#s;Oa z_$+>HzYIq80%e*BMWY5|pnBMQekDz9Z^c5O>+TR(fl^GxW2kYtSrK*6`b$vSAIF#kv{NAw(b$q@z`WQ#s`4V$58stL>KXJ@y6)#Rz%vNad< zT#rghF@}(yGMX@OBje#{m%dZ;TiIewJ+Yb3{I7@U5&zrZ`}PC!A$q&X%<~^+5USzga6YI6zJ&^ z^Pl#%?5}VCeK;Tp`9BACj*C{F>vb~%z^1iniPnh7Io2sG``@unu-}CF|KF%25TE=% z()x6)2T&t90<@_UW&kE5kaNxj3V8)j0h~*DqiI_u=$D1}@fv(2Hs}QBzO~pxy7_t~ z#+(9iGloNtHO*Rl)_G>gti0vO?wlf9%37NGy7`I$AMe>Y59eRTlI#onXt#}s+nmFI z@XjEsP`yLsE9-pWN0qM^*3OB(ssO3@#{pg-NW$Iup#kTT3O9Pa@%SUEOYqR5L z#*k5(-OjxstEnUXLf}901OUuY6@b4P zbroDL)CgS4U!lO~bji}liAh-8)A>e(uhF`Xy{NkcYe^@d-l~b6}&OrrMsE*B`HHlwX*9G^tWA&uJrDg5TBgF<3O% zoN`0)rEqp2x3A&^*Xy<^3Ex}Kj$2g$335ydYk1>t*Ak;Le#Ako6kXNnpbNeV$zKew z2R^F!V?zz!gY^5iWa!ey4814my7|4TY%}MVOX-C99#(jn@)?4^}i7{d|KJ>JRFPPs3Ijs9$7U5 z=3=Z=-b(U4^+J0zu>kpVgQ=ipMdLTBGKUsHpWKghW495&BR>8sqo6g-YS)oKBDWA1#H*TDv}vA$J*FWlQsVTdV1u1u-&n5-Phan zfF;pIby|%y7$M!*5HM80y4!L)1#5{UGHsm@T%{bA2d@6lvP`qC0@8L3eZc5VA3CFvIPfz1Ua}b&~dOF0ywF8(Q!0j2?D#ITp`egRH9WIwN4a_mb zvR0gzOi-_#fg45EvR#xjIMpWPfAh)T+5m`ft2E5zYYY{(EonNx-Jjk{urRrw)l<{(f&n{CGjA|9PH$QWp=^258i3@-ngdq6N|)8;0xjJBTvKcrhHAInY$?5+pLHEXZOWMc`o~GuFHhV_i7YDla zzsKFfbv+T1<=+Y-QRDXucoL=ewl!Le35k+Hi-=o}v3-m)$^~>W^oQOzvJGw^V@L2+ zO9&P~23MD9V}YrC7BX^S#72^}lc2=e8^3>Z{!E>f*Gpo}wb24Iq#Lsgf}|P_z?G9& zBf?x|pZ3LWD+M~*cle}%O(gXO>dPRfv68X`ST5P`esQ_2dv}BU~O9gyIH-QBx~nq$;bzseomMrUL2uB+1Bo$3hP4Ap|IY z|Ez+oF#l9)_hq#o<{@3)FAwR9`69Lq!zu%6nfH@eMxxF2m~gfuwWapJOZX=@ z)so09Da{{JmHoo9F{U>tl`;=EalCkw`YliWG9>I47oFt*nu7QVk2?znB%c$_N2Sb| z2@s*g($aypnsZMV>!Ir4dY|+^febQ_w@WPni7x|H1V|~n(DbvbjLT2_hnojc#(<31v_2{_ zUJ@?uy6}UIF`}}L_KQm${O5qQBnuNxS(jPj{xR>LvZ4CD`D-n(8Py zmU3iq@nt~wk!iyyGo0kis5bSyXG@qjj#|e!V0REEKk40aZ`P7@Y4;v6n36V7g0!O3 zsz<|_)hE(e);e4VShlWbcRj#_U5WQKNJw0uI|Mjyzdl~0`>AY(MG4$B*I%GhE?M$? z!K{wP!ycA)vS-Tn$~!^>l1`&7=j-kwWMjTE75|p*-KtDWbJ8snpMeF$n!nM^=9n#a zL#78Y!IK{$_r8_;TP|*1W8z6NGJ>l^Ma+`CuvLkc`Rm&`TF~V`XX*rUL7JtmKjQGg zkp!H`HZG}WONg2XVrVqMTI%QUPlVme6xwux&B7q@ct)=b-Y3$D90RG9tQAgw(vw&T z^uTuz<$KV8D9HONKvY@UsS0_->J^xm=1^Y3IZlTp8Ns!`kxse@p=pkfjIXO{2A(pb& z!H;;k5`FaG!0V*{NqQB+c}d~05DjzViV)jFzmk6t(`XRsW{{h9(l5h+{xu4yE?Zu- zv^HM4_nv>G9cbKQ*1*K7%gH49%2mUfm&fB*oif3_7x5$-^4^6@p@ydZk&`~!KUOFT z9R97q4VJIly2(spB|?{lsS@|wg2_Fqnr)}uC$(Ky1>8T+@9njb+Rc5pUPvJs)2+Mv zLr=3E;-8elz~mks`w+m|!_QN4_IISIB(7do!5A2HMx@6xa3-ICE(d;_@4N+fbAC^- z&;nVA|8^TfzGja-q07$C3~Z38a5J->5}WZhANqK8gkaIxQ;~MJJHpW?|o#4B8d7Va~0cAb2@1D-xfOq?Vf=N~f(0mcI+GINQ?W9*=`z$Q z^7L>E9O;U16|rsnWUW_{eWLTE_gCE$S(R6nO<4v`hIt*c28*2^_0tXxIKT`{O3--M zK=q#ecYzr+3>`^VA|k{K0q)L?_qHzT z!=CNG2s>m}jf=B$bbWR24Itg$*h6>y1bIaa*UR8V@E9)9aRnVry$h68^)53ujGhn9DU1Vj!R-_ele-~*vlxd0GVVAWKbov5$>-I zmWatXmf8N;hf195O%Hzr+}pOkhkX&q9mw?(LgYf zg7=od3HUZ=Nglaw+NijR+dlx9G>G>*(d)SuEY|i_YH^M}DUh@kF7+>vB(B~a5r6vz zU5Chfx5MD1xmkQqdZ^P(0lp1&L009ni`m=)SGQ>(uR;Rnpya3d%GExe@@g)x!)Akb z8(C{PKkGJm>@`CpT(*RwQmH#6=(}DER+PP?bGgNzPsy)^lz*M}0=JN3t8ZTftx7w| zY(~<~MTiDWlsIRLl(QJ5ryn zxEDfL9VO+3lzo#was~04kL=%*b!x-+o`QM3NFquH7n}`f@&?D}EPa)UpLa(+l`i7c z_D@(1^G5LgYNTkGIVS?0WHfSkm5H!z9-t|K9e)phTr1(C9DjI5mAA5 zS}Eld55J!<^3p}D=0W&ZVpze*!_Y(gwga~{7W{p+(!ZX|{2i2wfM`Y9Ld^_^?ISIy zWMhVs9Q85;9nXV01S|zwJE~2A2Q%md8I}t_hk{3zZA%AOIc~|XZac^hF;)}zFt9bT zez?>gK0?{Czn_5Cb_`6wAtVyNo~E3po~CU=UDKIl(>BeoG@Csj$l>PiI zWv@K%@Y`;uYgLmnuCry@5^NYVhIelV=Rxi2r*BrWG}O>MJM0w_p|S^Nk6)+EHc%OB zWjhKR{;+7dGsPiJQ$Z6qmm~HVtu&M>=ANwZF7S`fh%Y$~9`ILjcp9 z&CX`AQW{x3b1bueU+MDP#nQxxCg1#mFN{L$sz+Qj+#4QSz(}oQ1fJV2(3@pgubA=%Xzm4Aze$l!3%VLQtqVr>sm|9d27{0+hsp z6BGTNY#mtQbZ!K{;FSiWmOe94rw=n(&-n8V7aBsZJfa#ZNX>Hv+3KI+22iWTCnjoT zu~QlY@3L27=lx~Y!4E|soGHA;J|q)K6JHm@`V{9vO zVIXuqL}A&Chusm| zZ-D4+vhMsK=yZW1+yyhG>Ksjue?%!YPF?9WzhlXTemhbDFh(n-#h8nG!Ar*wLj0hm z{^OVQK-5M?q9HK{ZA;*?h*FrCWy{k`-EiRLn;FPg_H4Htd`!6Q^U3&dVNaae{Y0-L z;yxXPj0kg^Jo6kmrw+f_Rv7yN-SJ81xaSuE!flFa@%ESHz20n!b3Y`gJC!+K3Z8A5 zQ02YMPBLzM^#<=T1d?TVc(``w+&ARKzkD1R%3;Pif3%nHyCk-9zA^WmUO?ZK0F|EK1%pH@rRVEnpJNGs=Oqh%ZqfcLR<{-q#Wtq zz*LNrJgiJO;(V>+NOAb26vFrm8~)v2nOMXm&s>z;eL@XHxFp_h^5D;FblZcussBhFN095Y^g+qRInAlJn3U)b`F5}rBw;urFX{0zb zYeQLnlBdB_QBysU5?!l|$meOp9{#waPacrwj3Jsx`XC)pSijf zZvS9=v-Q54ZDdIs{y*88$>ElpOwh=Cd}-MYYsMS{7a6k_-iIEY;NI9>CHNEw2u)i2 zIT*f-UPHLIAX?h029u(!*G)$ycq$C#r7KTl&kj*UUptJ^&$``AG@@Wzm_T{-NVvI$4$x~uproCF08sKP8v zE5EyF$sgNjDcw~Ik&^r7CcN8k{#^XZcclB4xhA#}+;V$_>d@tb%hm2InIti6TiqTT zm+=TlyG*thn%VJ&2~mKY$Vis4#7(5NDn)O^f-}D(VZ-b#(AJxucRO69%EF(cebn-O zQg8Ur)CB!ag#jT91vj+~Q^8dRSE<{NR95a^ON{MMqVY3&nb`-=%vwHFJxT|HpF9uc}2( z_|xexCOInNYzg9@+>YgVZ=)X0zet>A=xEyVHAxXEd2H@e)#vgYrTWT5&r$*j<{`fK zcoia&sRLcEQ2Ei0a$oQSG0;7sp0(AxqO!Qt`CaCRk?xXzpn=vo1(s3?7OvZBl8V37 zC!XL_NEC2?r}|`Vq6}L>GZ+e8zIl@BJO4Z}GFknA7H*KQ+rRdS^3J&W$#b64u-7s{ zon2ChXT4a<^Y}Lr(Z~h7@*l87d*6EPa%1VjiL%oRg?i&~{6Ho?o9!$5cC;kJF~sJM zyg7$^Ivt`^e4tv{AIRS`_{DJLhq@5RTTt#>8{efoH3%+>_FQPO*Hc^PuTZd30BGi| z;1i;@j6JMet2|rmPOlzxmzKjN$y;DIn~_Hwu7OM1MoVZ=blHEsL9w^#0zR=4EL}Qw zNbXR~4&-q6V2`~j4@H%Kr(@16I{WdG{gE?7)iuKfAds0Rij#FagxnlDj z>>bFJ1Y*>ci4C@=qUjxP@Ow&=1^G;~tR6DY(2(3a9$l5vf_$U_D7_&;9o91l`)fk^ ztMsW%eKx;c?%Q`)1>fRI|lZ@_`Sy$Sbkt z7Vw1G*?S7G9#{YjDIB9)o7a^|LB7pYch5NSts-6XuTPi<5y7MjgaLUzK5A#Kjl7aNdONn zhp)LzRfepULi9~^u`<1&S6e_tSU0uiG3x&es0vV2{vnm!BIY<#{8%=Kj}~tbZGNEu zg-;A_VDRWOYsi){UOQr`l@@pjg;?e`^o62&@wP?6=RN_SzyU&OG3f#*7;C-)i;snK zTQ2m*G*O~WHHht-O7u688>$?>5Le3Y(hKel^ZwmF{SZw( zefHYl0SI%l9DLPz(qGA;>_Wz7J0!?GoAB<@lxtflMRs7iWcntN4xX`yx)7J*{Orwh z{5kz^Q=lU*(OLs=Oy|fFaW*GIz+-9N)69{u=o1z<&VqWsc$jloeLuJCJn6`JJJtRJ z`Qz5RL*yUHS94f(m%C9_6Y0j;gT+w7H6J#%bTGS!4h~kW87#Do`yQd3&hI^c3sn?f z6X-qTO6s#L|^B>;nRx))}e_OVh!c|_z!hv2}8ZegA+!#O@3 z_#gcic{T4^k%9d@hW2P)U`o z6ke08>1;^+ch=*&#XTbWDZO%}(W`~#1Wr(XKWp*|m8`WNW`A*E=F3+L$&CfW&<(zr zWf5V!6CSUeQaXn>jLE1lKvij_qfoOIsRIam5%yc$)>&7T{2akw@|>nqJq@dJ#Yzhy zwr7>3I-(g!*;spQ^0ME^SJIc-ip5SVn99CEwJ@aB#0~8A*%u2)LXK6I{i}f*mqV>$ zXtrJSTfg39y?aYz9-hKl^KwK%GB*`T}1jhZ}|n+n&8_c7abb*p6Iw zlbuKhjlFIT2+di+q^?12v%**ObY0D=P1E^DcYSP8*{7y|4Q=>(x^{$e-x;8NRDR^Y z61OaZW(|9*?4Z5W+E`8UUs)LnU;$*)-)I8#gZ4z0aJS_)PI=DtC4%=Of<^{XVwSb_ zb9cErkmYh`c%&iASwpvN?s#UbZdNViww>f5)~c3Rk2^JmY`I8k5r&CIe?K*Tu13*; zpM4FMcZ%Alc&ja0nVd0&CE8Bv0ovO-E|DjrzZQ*}EUXFB9os2>-cFdi@QHo%b0y=M z@a+UXVATGBnSDv1&Iu-6BwgfBtM-{c`*5-(J=$)*_aXc)}W^K$ZB@#Yt25* zKxuq!=!Pnw8er&U!Syw2OvS;mFce3%(&B!djghilIJX@kRTdpBZJqr zCB?9koSEnPW`M1q`aYuo#;se1=09D!9o!fmfizR7%FUtdin zQoE=BIAM_Dv-1?=Hq`BVvL%sJ95)f=qw>}xiKD0xOHLQ>ZNP<`s(iTIHm2_@ zZ4vIfIsgbI?%(RuFI$h6JO=bFH#AdM4ilSgv)A)w1|lP4@+K#X({Us`IQr4&a73Xl}X2FD8sq>v;9^Ss2z0OBhQpDUTnxjj(9@e2zB>q^J$lxlKB*~t?!r1 zr7JBeIqOOkkw%$AZtjR_%UP|zPpq60q38fZILA4CnPYtOVf~FH|7Z9QCnfC0z5Rwv z%SWJM%N+E)4_aiOYLx>>`nv8B;%9|eGA5y*?MbzOXjKP(6?yIL`&mari7b()FK|9+ ze*Xqw%PKlF*?55m|KuHm!pj%@CbO?TsPt){aj$7wYdR|#Y#(JzG&k9Mis^PQGZ@C4 zQ@YQkl57@kr9$9|P_vVziHtqzkzDl5)~(bh8zK{7fM)W7C zU=_arI)Ujg>Gks8GE}M%VwLxO5h{?}|Neew44 zFVRzieMU9MTAfu;N}zk*CjOcF(ozN>D4A$R|MyH0Ngk-Ob{NR-(AjlFI4XjvQ(qqk z#j*n`;gu2~wu$mkK)2hWbid2;UL%v~6nJg_M_R)J)uMs?Y%$2jZickACdRkt`2$yl z0KdaO$ZSDB8z;7_*d84g#y0} z{UbQ|%?brDw}!DY3u*D@!5>QGpKH4(nE!ALxfb6TY?3!OfLwe^(RZ^zB)(&nEQ>j; z`@%))bh4LMb1t&op`Y{GtKKuhzr{ALa??b>w@+U&HtyApS0R67l(2C}7Au4vDqkQw z|5qW!TWC^U<<$nRX;bdDTcD(Oz(lAMJy6Llu6yo1+}MvG;;gVVrbK>M9o6v@lV#H7 z*ec|;SM-~Iu~;&wtli3(vOSN+ow4Ne`Z`)&jArTQrBqr*>>Y|8W^7)D{>%{VMzQ{y z^ny+_O{g+!gNpw0ba?ODvwCaYuQJ@o--*u{Q}2Gc`0umacN#FRsE1kG0XYHb@p`M5 zO|28A41k!YxZP(zPkE+PZ`zHpWS5yX-~<2b%zEDFqAp zPukOxCTk5=mifC*0`)B6xoZKhow1JOejQ*KgTs+g=1by))U9d1zDM!vrNUuf$6Ofe zbkQ$&Cqx`L#>~+byQeZOI>-Guk9JdJyVZg4*xgeD$-sO+x)Sfr_tD{EvU*h+4WPGv zo|D{gRsEr({YM0D?`Gb|xG_1GdM~Jhw_G@-R3tQdv{s+bAqG?L7m494vG#mQ_3seh z`%471TTN@%yruKf-+-y}i2X|Q{{`9xiHi8aOh$^#$ICMUg!}RLz+kIT9na2ZRuFwt zW*yM_1>I>`hi3cuHqfMY$y)7KTj^{1RG^0x3MJT5mNG~Yb#>TR&PNX30Yxl4k|p~Q z?g9f6mr_SybA*%>1xVAtrL#TSWbt9_NdJ1_qP%}B`A??tyFW1@uisfQt7K+r$8OL1Rbn*!U=yU4 zHNvp`zkfxhTXhxm*R04EsoNj@{o(s5wuwuBFTY4$O8t99<{EBt`|st`^_vcV*PrYc zbBOYPeqS$FaqaKreXswoZtDE3U}6GxfpG$KH^8e!S#No%fLD?;9{ulNYhp}pKW%pH z@fEOz@9n_K&{yEG?+%q*jRvBedI~fl#99pri6;o|M&IlPckG{F3x)J5Dr3EhpSc}F zUIc8?F5QnR2L?qWFg>vK@npj=c9pUw99}>>s`~%y5 zKA5O7W(08J5yj`p*N*l@ZQfK7C<;qyi88n}bkaDRsgWX*jq@d40I{NJb)Y z*uBCh&%qq~cIhBluJKVdA*V#rX)tV`eeErMHQO36ksr;ObymE!)(>oWOGXk+85Ko6 zrl{pWo;7B;b^7XkF6LGr4<;LydsQ*dhmJh+vk8SJj#am6TbHozs9207ai&lxhUFKy zP{ZB}0*Hay@%OK^YfSMw8uj0wC^4+*rG|eh+57Q_V1`u=DRuBm9iJ0Wu~X zBpGhDA@+>-PyCEh*R%XC*tAEr=S@y@KfifX1@o(cc8Ewjer}oLUX$EZ*NjHYb3@lJ zp^rkl0+m524t(^&51uX+Q#>d#i=)if8wAowQ{4x36PGG@>!Jd|c-6V&rw=%s(|hBYr2- z@mLsGGVAOq*N$yaI5dIYKD%WiFUvYze$WWguYD(bp;eY!@d;^q6C#e)qWG3Bt^N)J zDY$Eb*yVO)h>WET&2-^7l6bivg?*V9X#935c<0|m*s};6uPfEA-|+K#)S62XUdn?p zK1mO>J}M#X7yp>u|52;3tE7ND-eiO6^M#Pl%f3we0?BQ$-mN z$apK~CueTJUksus62{btW2YfL{}|Fpe$+L+N*jQtlR@uFMHx9Meza}aZ}=)+qZp!0 zCp8fFpr6G-8{#fEbe(Q@?6Q4Iw)(R%Et4WL5Lke=?XBm2{rq5UM%=rO z8!gb~YRzrA?)JO^#@aWxBSqh4Thmc8*H)Boz3_4mfJZY$8zbUO+%PD65mNFIsMdvX zkSP0YMUJq0{mHSz=$aPFu(^!pMZhn3gLW%>+o%skh;`U8u`D(p{43+3$Uo9@gwe1x z&UwoX%AwQg4ab{5HcDy6aGrXQfN}~;iGNN5xsz^$cUhmV`X7%`y;S{qpm>Go%dR?= zyWcg6B0rz23h_jXiey@~0c-NX5cUa&S#dKUBCyxDJ$~;|9G($U*?c{$8+TcMC5+U) zVA8)|q!?C?_PyDCL7gzpMx-K_6H{H#Qf=C7Eu{{rc^pr}y+f>wb40ol*7IVZ*FkGaqJb*6 zvqa8kz+@e8lB0?tje-Ym*j^B^$#w7zMZ9i-X&c?^-J-~F8qN#xjVjHzaWjrBUKx~G zcEQ@W9&l{aA4xDxFD=O``HERxQJY*asm5Ljtr&N@ZHkf?BbaCI8ZgkvI=1S{MTYu< zj{9s0qSSW{xfuE`zoP_MGX-Y6dOozyxd4mdxG)byhF4E-pn{qOd}p*!-3{|wSa}DB zAnqG!g;Xo+V_aWOLyR z{VJO^D9yy5GWLV1A;J>5;gm@=NtdU6X%Xg~mFg|?%f!viE6go*;Lk}E_$^KBJ|Y;mH({p#=+b$?6}$;b&t)$Ms4ZjvgLTg4!l%h5>^ zzm{vUc{qj0(&hJ;gXv|n_auk7+LZQGkM)y2AZtHHF+_yU(emh6TNL4lFG-c8;%*XjM%t|`X5UjfV@M(v z<`lJp$ed`%vQX)RnOf;xzvP`QMS&Z)!vls$CK)gC!7SzPTZE37hc;U7?n#K-kweQW zes&E>Clv76R1`i{YQ7~|5`=!SBa>OP$$4a0t|0x;foAs&?_F)({kx|s#Rle}oqX7D z3_s(hsfEVuK;uFyy$fN{g;6bid}l&UBfm#F)RDslUe(wr*bt=IZY65eC2by@o04;5 z(;)w~AYC&*sb%)fF;e@ns;;e@!pSyfo+#EFg+JvWo(1fb%&{toFd3jd9QY?+NE8{n zmw(O4Ul=VSR$odT(mn+m-J>3<)S=zl`w}MI&fPSOygH)&$K9#&p;@{DYXth5#@`?giRtM5XD~id^&if1z>~`NHxYxTO*4PYm<)fpv z)pD;6?~WNK&8d}v9!N@|<}t>TsJ9VIXCK+p$)=N9d)Ct7Yv6@d1`D6LgULS2u zF1BC)wi+9f;o$gB+_&`c;;hP{X6$EXP>n36RoHj!ZtzeDBe`~O0r^0@HsGc_&MI~r z#)fg<3oEKReBr7&zFV(%8t?Ae?8J3B31#Zg!`o#aZQpHB*5tc^sZ)JQCo&P0_9-KO zZd6uv`^`FiWy|m5Lbhp*+K9F0@ycOnu?f%k9_H0F_mU;!JHiI-hXmk-^>mb!Az4D7gwppfJ^hN8wPam}}ed_=<LG(k~@Zh4hb!#p>DygzFdln$G@M{}=~)b4nfqz411a#aA2R zA4v*36e?af2UR^oQ3r`t1$mA&lRIYJhtHyy`*NZ`czl8_bTxyTf{rB5SB~!-qd1g~R4~U|Iq1Oj@C%%y?l%;83j^ z-G1y<4>!=by|+~1$f5qT#t4GgWOq^qk4 zp3o|g@TsvY5AyZbt1DF7u6DwyRjaEiw~8veA(c~ul-rGg%*N4%=CdEE=KUKZn|1q1 zsjAf=RN7Ls;>BLUiL^Bz$FfGPKXgX3N)-~};QBw6>-4*p&eF36PPtXl2HF*S(GPo8 zerodEXf)E|wzr#bVY<%#mF&Ng0!ucpDN<7vjVGL1yN-=cb2KQ$I_3$jX@_HFwu71@ zPRg2tAPDV}HEqREM@hfE62BRM z5`fRh%mW=RL<+3_neRwO1m~{%x9(f}&f4o2So7Baa+{Mt{kNU$8I#wG*T;Zv=hS9q z;L+nra{RrSNe_oWGn zuWd-jtCTstVyGGKeUB5E@cW!Chf9pu8r%43=ME~*9h<#gHB31UtV%%X0G9Bj&a~r7 zlSNoE?(g{B)Qm^wE`)|H%1f*3B>r$4mFFY=6{RRf? zwJ~GpmwC2Z9#jjcK4Q)_e=sej`fw00x*ibJ{KpUI2)G6{4sGzW`SX1Dbl zOLX;{>yp9!q7yeVHYCH-l56I7hYr_G^$dM{{b~;{OZ#*6ouSCc62(~^4FI*HJ)q$# zyC2au$jPbPFz9qQ@~%Tzd36DWWwwzeWe-K_54E?!#lDew(Xp|pdsiXr=)yV97eM8 zV2L)OCZ(SZ3`}`G>s=Gq4W9h?er>!_ohP8&wfH)nzQQr7n zz}I#YUQ#FKX{YhS^k>6NHotc+-kx9S(-Q^P`fiqZr1(|X-Yust{T8Bg;`og=vbcoD z!1Nv7m{A&At22Zt=fB*sknPIhVefg_k&H|)muBGl><-%z9%}5_E_Yz6CmkkpcH*{g zdJIU&))F%O1|B_nwBjqh!mt~o5&H}1h-;1c^XBZ?X<>ebt2Fn>e3;B?>-K=;`pkKc z;!+*W-^UxRUU*Fj(UY1nlM$NmvD&RQ_^b-!^`Zv5gQBnqU+&0qFYU=u?S_0O*>A!( zKpy8bN+(s>Q+LCHBG;lOQyPtFBEV^L+wZZn4k*w3co#SPWS5M5$*#U>zj-pGpEc-Y z2xv{Fyw5wv>90NRhh#;gD@ZMdKiSsp#Mb;shXlhf#mApoH+agM7D)f#fZLa!Qej$y zS`C5HY{#O{U!JR-ntuueWvmqqQT= zB4m(KGd8L5cH?i_Ot0SK4XM5&cx#he2yoaO{9CGvrSiY!-1J(WD0&nb?GehVlyny+I|{06TSf zJhAia2MrUgE0?qS&8!CQ_ui|Oh<`<6#}qBq-mL@ull3Nd9QuO@kN>Ep7M?V~2XvTE z-CjHkf1VCV{c`#(fHY}9wb5Mnd;s3=+SzIA83Ch8xEyv}xkmMw{5{8m8H1INizsxs&t=Z*^d6-~M7frb z&>acWx~!+q2!;6x&#$*0I^Sn@_}oh*7R{&?g*s8Px`(0O(v(85u(6P-Gqa7ft}FTbMTC43T-B;SBki}M)3aH0=TSey1sdSJ6n$f^z8ij|)34N^-Ijoz zAqB&_mD&82ZvjX?_~^wp`3=5iH0_-umN*jY{hy}04dFA$7HHnU(Ci1nG_B*`B;T0) z?NLfmDb?m@9!B>(i=c&=q5Ye0^`oMq>H=CyimEaDfO?#J`315+u5=Cqmipp2koW8I zZ}&v0$lBua)t+7m_N6$aId)wceT;tiinWe|NM0|i&>a4P_0MjW9-#=4=<9gs^Kf@; ze{pzIaB9%GNAUiiJ0V(-{zfyj`d4#$oRj8UbE?P_506M z$Q6~(=wD~sW!WKEHN*WS3!#=1D%{m1qu=(~FfDPWy_G&YMRjZe^NF+jY{wYfG==2( zo8`Jn2gqg=zz}$QOtwE$$PC=zB2+CKk&(^)6xO_Y^NL%v%$IP&?~Xq%0=Jn)ct*?s> z{~h6r;IO;5)XN`UW@gyqUUrtFbonjUuvAIOEaN}1yEE*AagTW(qjnV9)GIVX;kSl% zF}6~bvlrdZ2t$WG%kKT2p?O{W?Y{HK#m6h@xknb?j8U&-5j6Tb=^br|5tok~;3YXK zX`UPU!{x#Cx{ezGs8-qGXE`)9W81^6gp*nFAV=V^&5Sq7QN(Yx=Q%0zQRn!5NPVta z3$>`t%?FK0p9FL)bG<;&W`s41k3a?s02oI%?mXCQ^Is;1`%>6`a-Wd=Md3^$Z$42| z$N0)@+4Yyh^OS={_`R9^lj9EPtRht1|Nb(n-`7dhF291akj8g}@F9rv#s1i7b%^q; zm2cuY5vx>1a*V*pI*ztkGA(?@nv9dg*n-A<@ie4 zj!2{&50o3FQB(Wh|305IFBJ!731gJGqvpgutyn%Lr_oVS`!t+}V#h&R6``dPFh=|n z>R;TRmq8nrTvXmWPj~T+tWG(txQ(UF8hZD-P|aXOnP&RV4LnvSR$c!04$bdBSWE&36u+tCfhB|k;4AI-4k3F>_pyHHyWr5Uq#`BX zvW)VvPaQ@&*BL})^JDC{c|g{eQ(K_A4PMX!z5tV~k?D@=9;%Ae&=X3Cpws|CLkJMcw*%hK^StxU_sws9GvEB)d1ual%E>wV?7h!A zYhCMF*Q#cGADxT7^y{hM>HL(5V_)(eCPrTZlJ zrYPZJ204)2@m}e>t?ZMY41*z{d;!I)F`-2qThVgzIdJphn;Z#1`4$WMS2Tl84=N0# znDy8CiOHluHy|d{5xnQ~*11wXU_;%HJpc&=E)_e^sLT(0T3*?RC&El{>+eAmtZ&(P zbo2lpk3V!1fv=s!PK#6u1oeX&dD*4;D(avYUe)RF;loS7Deq@bn90hr4Ra`8=`m2R zunn)gW=9|F@m1bz5)FjgB?WHy`qA1IDIE`Zp)5>}QUZx@1s<22I|_*C}s zes#0SX@4rgE)c63exO1b1!CMK5Vcn7ktvm+R$|09V8ziVZ$1T;g2_``{uWaCE0n&( z=*PhgvP^Tlzt!y+s_@DHJtJ(EfV(X1ENi~?9B+zG9fitV&74*wab2eIHo!=geL%U& z(hulRSrZ>Maw`&nZizV;q_1&dX~?~RJw`i9=%Hp0%efoEy2f#Xm(!JZ;#o(}O4+by zBnUT9GS$6|Q6-D|2@rta5ma=8GZA*A?;R@C648KVF{Kk~lku+kg}@=jc#}aFiOu|2 zJ&o_69mj(NMR#vjFi${?CFQJ6k0^s)2N;JCE=i6(dt3Lj zRLGSZ_`-JwAbdZv1ja@i!zuYR|2oEiQ_?BFJDk#dSJ0PyJuNXuyHycUSFW+YRx9aU zFXBIUTh= zHXRU1vzMYetRc`;O{)%8;+Jn#MNg8}r$w^cxyI7TwS>%!LkhWAYx`)bDlO2Jc?XVt$_ z5|FpU?sGv@x$zr7BybieITeB^jxdqd#<_fzYkisdVV64hVYAFE+n4|ik-#V(v2{7G zcCPr(Jluifv1Y^a4SFd~7kAh6*&E@E`mBt1IIWHxYsoh>BOl%-xqwuq9@s?jN&bh! zEK0 zHIgQ(dxzhQwv3H?4zNG9s84SwFDxvqT+mNJ@4Ugii||l%0kt}v(R|d%%XGCuspoML z`lD^^C<J(Km9c(TAXJ`0}qeTKrP)#Q0rhV5D_-_8L;cVYpSxx<>bwcMJ+F{ z>Ra79V@Wt5y7x={#KOE7<;>DRX07gllT6#aApkyhf>hvIBQ_o_R)aRA(z_EL`VJ9F ztq91#%~bmAqQmS5ZadSGQUnU(;gy826GGKKkUDT0Wkbk~h++`yWK`2!?k1#87J%Ll z2^_i9Uk9wPMb4p9#{h5Qy+p#q&KDg&tv1K!OwW`Id<&oNEw^>8%)^s1R99=rU-UmU zc?6tIHj=&C9-FoDC!G$=lsgc-yI^dck~Tr?Rp1oWzIM%}300S2(yiz|GTYHr!RjWE zC+=waEu&8ElHGXc!lK71Pay2_i)J&kw$5Z!A)nSrnD@HODCfgGJTU#OUirXrojo>@ z@2id=U!$X?iN?os9p);vD}}Z!^zotBJdjO%>H1QWA0^~w?b+T-9zUFX+VPwUNpD3! zYQ+-KyBd*`N2O=k7p@|c^72FfdPo#FAYX8)OSnyPI$9hjpY(R7U1_7N&vaPMrO)Hc z3KXvsW#DHkL9|A_3vSLj_|WBHO8KSHb@8%ND+iSE0aR^XBPZqBYp)aHH~Z7ZBqz6Ax%NhgxLUK7GL?H91PE6M`5(~xC%WahY8&si4=1^76pf_Sv) z9Ni$=fD0f}0ZT9;7syQ3bXoe`T-lvMb?owsoi(X+DxJ*yCVNYyFuzhx&bGX%J;TE4 z>h;Jyr*=3Vfp#oi5|&-m_S<>X3tH+flqLFWE!q4AsW2;nZ4IU%G8SxJ%I?@5j*mb{NPOv z_=GM&|D81PdH8z*kG#*M%`j{|Yx2NsuKPYIQC9c`4*L}8E#%zeYk*$29(~waV6k^? zrMFF0VZFa(muA21R9=!`v9b#;)LYQy;L>NpqIokydw)p#Bcjj4MhrJcV>hLt79?O0 z{`JA_5wZDF=FI+U4r7b1IkJnEqkoXO6d-p26^U3GA$(&Kc2CwQf+FP@oQ9(r^hTKR|U8zU|X?-E}gMMJdN1PcE? zWB(R`!c0%Rmg3JlB6ZSObfbN#`i7vT6{e%=^w@W&7E{Yw0;B6-bF96Gx-?4&%t@+@Xjx;z6lLA-V_oMCTW^qWYYC>>@x~tX|-FN4{BNc zv~wmQ<9^rs{+x$fKyxl*ER`>n$saM-U*@nnrZI2s64}`CE<~?5TMtUbdaE*ga&pbB z9c`?>2zKDl_Mt-hE6)3Nw77vnMEjq|6`$AC=nnetwIZnt5n8c#0bAi*wqj1|7GsAk z`9{S)2=?r-app>(C{v2|C=I5c&6o2;vo29?HpkL&b)Q$ko2T{(323`AlCrBz z{gMc&>f-nF6}KPxfbKB^!4&AzbODmZ5?mofJglMlseu28If3!g>jCFipRGg zVP*K&0N}UZb5{kpPGSaak^*9iqHxgwqJEOvoGnOH5SE(7lkT~R>%Yg41DNe<%vpJr zM+?a+f#g)2k-{46m4FL@*R z`S{O&>|q5>2*=f*O`;^%TNcJkEJ&4|Pgxtdwa0ln7=D33C@FBai9WJlfR2C znQwd83!`87%&Z;UtAAcADnlPBR>U z+B;Y>hz~TPJ51O<6kHaO3T4zVK*%)!y#DzpSp`lh6G-f>MV~1!%kP(Xq=5uys%tBN zu#xW~)y;+~mYM8q=C-UwuPaLD!E=%pA8#jBLN+f;AKRIg@@nSn;_u*Y5_vdO^b6tz zQaelg2N2J^s}52wo+r~?!7$vm;-~0O@bVNMCWtGesu&>PF{JeIu7ajxHY>*Z-0Cm| z;$ox2x*XNLcD-M1eX*yqC_DdH4RV%PcrUu5Xc_4gs|Wk&x4LAc)M#(SFit+S)Zh=I zk692(!Ew!txC}428}g9^=E$2?KQeG(jH9POINYPEL*JM5Q8_Cg@V)!a&DtE@;O;y} zmT_=*#U?DNZm!W}zV@L$kr}aOwhuR*e}eH4Huhw_caYV^CJuVsyZ31;;b1jW-eDE- zSeng#`UKz=(?IjU!otKjZgZ*Cx(y(;+Q^C$1ukVWI#=lw(t^GNOtUB+$W@@3HG@-vu7HC7PGbs8?qOkP`w5^9dP!V!{PFnW2;)8{gwDfX8J*vXlx4b_ zm~uM?F4S|_BxlwhUgg;PFDZ~t<|Eofd;asvB@nDW#P^=V;YEFa9AeUvHfKk^b9$U2 zXC2|U`o-DfX!sj(k*C?ECn$`b!e-A*GY_;Bd+O49=1uWnef z9YG%s6XfKDqmehyeppE8h=pU$N)!}Ov_(-rX1)zIa3qd;^=azR?yQQHHARd1;5rw1 z4%TEO1pmQ)den=zWO)QSGxu@C3|WfK@xtO6{i$aB9igllImVuVB&)4XrO8;+sYdjc z8X)!RqME*rMUrO*&?A)iDkI!AEkZ3w7$X{I5IpO`3%Co2sEyN^vm4atL2U-X>k^KN z#m8xko8lJBF3(L+Qds%uU2L6OU>HW~EU)3^gB|0iS#hLlRBxJLk=je9S1;|x;tso% z&<>MmY5MRlF7K%vYV*hMAekc;Z$XWOf!~4e&;ZsLb6`Z&;Wy zcv7)Gvy|+SKu(eMijBbqi<-pV*7H#DSc^c}MeHrBFsg5}i;n2pjO8W{=@ZfNkuX?L zxb8tFuQ5xjSw-uxAY!C_Uk;NJk;f-3E$2i#+=FxKfG6TkVV(%f) zam^Zl7)*rq5L*t8U z4rsOBoQ${*P!P-O`J{U^tmS;1z0u$42HYu=J#-e?G zUSu}zWRA2}px2_$1Tf|WR&v+v=twBEjXN|$T#?N_fBO~sz%v}r)c3-NI>aX_c5meu z;B2FQ_g8qw2ry{0Z)qE8>WNYa

dpMN|{<5l)w(ip7aj~k#-YqHF8H#?Wqdykt~=gqhC>@*vYbL4(r0o!mqUZP z@qMoB(w0ZTqT_=1OT$ws#^S1)s&WdS6ojGKO|hnlrf*Zdm;5W>&uuL(n!V}qBfIiK zSLICcMx+Z;HgrQ0Fos&x8}tcNm8=)Ma%zj6nh3-`{H=E-(>2Hf=5Zqio$Flaj?5Y} z0~j_ASs3Qe?1>R%liTv*K@!CynFntvOvH0#u+@e0k3~!FEe9Wdk`m|D3r~i^`9W%{ z_plC=H~EpW$ex|4n9CYZYs;=^(DxX1j-EBV#UqFM%5XIHojCk&atRK>zjF!d=g;3J zP;TM|{!S)jgy@lXUC1#@Uz$Dwwp_kc2BU^>hRDmF%EAp9owO3?w_zEQv%NI%qGx9y zpSx6Y+T;}AFVS@Kn$p$9NpIpsX`LyW^W{_2PyKmTq{2mV*fr|ryN&y7Y@JdpTpBYw z9a1p?H+uRqoo9Bnu7GEQldYF|cE1RJ#FbA2^LfWl?p`h+9x=^zGO#>(I5V$wERnVY(o1W7+GIb>Ydob&5ZVoM%bGlSr=jv3a5|LRuRe`z@wQMjK;HBckZJ(&i2@1Gw$k z8nZ?6D}*HU^G6({1V!8<<6brvA0Sw8P22n0c=>sxTS_A`)m4Y1fmsomMmR-z*7ApX z6~0n73XOZv=0Be$lA0qsk6BV*>W>mAkm~xrRVf&B6eQD}EtKCHn-Ao!uqT)Zk_<}# z+f%&Y1d}5VHx>TaV6bx#z+h5UFN+@yJYA`Ib=Yb!w>+SP|Fk8dZB_Q>M7=KitDdmb zIBnR%#B05ivLr8=v*uK;W>U9i7iB)~FW>LRFSA}^si~>-xhO`tz5JyB`>%ssIEdxY zc3ETh)*=e)qO0t^hF2rmDK)OW*L;|;&dSD-R~%uvY33z&3R|zOsYwnkd}OB#Sdcl2 zEVIl_G;5r=Ac@%~OVOwBLWMOtoc$H5&-9%3Lrf+BfP>I>S$sY=aWT1%f%Usl*#y1_ z;CLIhy-*(-T1-n9>Ft8W8x0Z^>jHf-PXn6AiatQrD0g7-&K~K%D}`(>u|)-Nb!npy9C%Z>*RIShz~wX zGV=mqa<%CupnR)dS@eB`a^J4vYDJ4#r&4>P`tehmJ;B`*!R@^mM21Tmg{!|tq2|PI z6OsqKeemvic&b@R4)4@(UClr`n|^`X15&Tc^_BXQ2aTy;QM>y2_iGo-&OYSY=*?HT zcrWp@h$J9&<|~dT-8AyDou3An7U5O@!wU}oY+YP$8B)o^c-MVd zrx!4+tUTUtSB?ht0|V!5VR}(1DNlhxe{1x$HBU9*r?I>FdUrD=<4iGc2_#Oh$Fl<9N(BKN_jZ z^u@pz#_qtS_MORKkBOZcc=*mN_jyN8F{A%W$8RuSjsrMNmT&mv{bjlk{IPP^>eyd|&CRvB%N!yILxsl>%Eo+qPpY zL-=nXhi#XEb;f_?UJigR3h}df8SBdVH28);4kXf+KoB=H-IGBA zskx0owUr--RUVE#@k`Wdf=6}OT(6|+(pNzY|C`3kbJ}lW0x;`}@#>qyAmJM``|LrW z=}-=OkVgu!;r?_a=|yR10C^{yhuCqJJNEW7D^HvNffWh5mDfj!sQ$~{KZdk}h8+F* z+VWuz0pjuQ|>o0wxOT^v;q(A%E zo2Ld`y#Y(h4@8nM!1QYtv7hcHhXe8~3s0GVtfPVMc;6DCb^}|=(n4M%0H9QOKH3<5_Uzd`o|mG?K!6?1Edku)lpg?~t+$v9j(Vya zHOpgMgoK|gn&_xC@%ydD+&-fP0LT2Dubylu!c3;*-*V2hea1P!TN(z^sEBpK%1$|lx_;4z(-RJMZFR#BnW|GSWE$tZA{~euBgzmJq_>*;JDpAUN`2+ zwPc%GkRN)mBl${W?b^7kHyOpKsMB`{n@9Zk`s&B?^8FwKUQ%DLA#iiVcQVoY`wK;V zE=ZE^#8H7Smq65wc>Js->zl#kRJ_ppFyg?rY40*h*0 z3ZSRS2ftc1;EQ4zPV#};S6&3SSE$)h?{Xsus&q91Ibi{HfUV9GxLIH#rRjHitK(|K zQ>H>{t|-%Y^RoXDxIs&r`A2 ztoN57C17L0FXwIfaa;=%I??;*A1jID?R$^M#!NrkrAidVHyO=ulaGY1&u#teZi!3R^L_bR^m6qlrj23I9H<7`u?ew~S810=_rdP3bKK$Okms zMTG9;lluGDA7{<10MxCIWF__#36;2L?0#ES1zHTpb^EgcS^y&HWfT>3P@f-}4$_9D zmUhY0aZ!LoSnh4WeldGe*k|~a(n-;mi%fAnCS8R=4cx4nXUI~N*JWHd_tGO48*2BZ z78I`w@B0`?#etrO6vMlRt1bJEQ`7h;pa_pWF3Sy-<7Z*;_xsxNC(P_pQ?PJs`F!)87XeGS(* z7Ci4q3~lW0w3isAK zbXFN72^1QNbm6KE)e9HhxZ(;zt-qlKIo*`E6L)rCepwmclEGlNe3?!cDmE4MxzCl>mG zQ=;T`5r9RsRoROi>QX#D)ta73`*y|4RN@;ArwumThh1Obm{epaV~K13ipg6Ry@#;J zw$k>&3p8bj*z*%^QM6Npy@4~iH%(^0oAK#B3$8mY5x$6ugr@)+-dv z`4g~+f_F%_rHl?9)6dtNbRN;E_4HN#w2(3lk^rMSzhD?0NJHSF$y&`#w3aUqJIvthQHrHtC(+Vfkk8 zx>QlgO{*y8^7m*G)nb{c7-xTL5m8!uA|;pX_l`oN2XvD8)Yq&h5Ag69FvEp^KPA28 z6b1KzG}tp#X)8Fac7Oc+M(xk#H_w&(N^K>_J>yG@V)LU~0ug6d^Z8<@D)~&SA9bF7 ztvWgQV`)B<#LT@AYj*N9?2(OeM*Ce;^+vmU)XQ+aaPD~>+g*B{9R8>Ug8y^Q#*!=! zlOq?FzjKORprSi&JE*WpNm-KxJN?&pJ>EpcyJ9l8?2F_2 zNUL>H0pr<5{uDJb(0xV~K1)33BecDpFXLEo=NaNm>nily#N)w!AII>#r%M9;i$la` zKZb>l4)Mm~IvrFs64Oh?fW8o>y=O#2ApXF-o~>*Ii~Z9_=^o_|Y0rMKnb$K|AoSp8 z<-{kkU&(zu*?I##?w_X^SycKDY~0!gUqlzxqNp`tcu-`0zu))y z(9TH^uXAYvEy@|}+XFrP!NFev-XjO_9xe@rO|IWA-&DrC4Uv27QC^7rji|P3i0 zdtUGe&p~8|J83>Mj6Sp?B;?r?A$To=k#03MX77bGFLhp8)W%Di2d>AT;)3SaPmH-_ z=jEjJ3u5szwSC%AKy1SF41b=vIcyg~RlXJCX#ppz?;pBXlyP*x(IS2>j3%C=$jep| zTzi6z?L7;4`-kj_wR@#plmzu?Y5fPrU1T}ZmtkL0``58wmmYka8XiT_e>ywj4dL@o z^`2C<-i1`3nzpFOyBFi&j@xyrtQMZ^5>o}wt1*cBctIG7K08G8j#Ubn=*+*-I(yvQ zXC#@MdSfu>{C&+quo_$tmHghHnZrN3%*`{T8zFC8X3B-bptH`OzmVjQ(a$7`boS-H z=->&I(X66??s@WqwJ<1>bl=6jKx5^*6OTFG5{u|o@pei(a{esS(V?L02ZPcQK&ky; zKWEkG+LS9R{G?-{*u|LNjGDmArKCDP?mPb>h{4FFPrYNuMm65CTF)Myo2rA z8gS?h-M`rPK%r^De~SJ)9h2-kaDTn%*tMN?ZeJf}Gf0ocT%*yq$h6`+A0^XVLtg&B zDVaPX{x_6NjAiRXPEjnp}E%e%hyfmdvdTH{8tdnQK)orXvHCFml(T>IA1{AMhLk}n2X*J=%VD5VXRJ{LHh z3ayvL#<-NE`07GK|IOAyA1PL&!*zCMH0RC467R431{eJYJ{p`OgFCwiDN@(GI7`BRkFxpt!B=Q310BSd6=@cDN54L48 z2b1CrimTHkl?k#aIff1ml~kRVCb za_Hs|M=tXYea*Fa19#K+iw(81VRf1YGeu8Db?EGr2sLzj^ziJy!7;-uFUm`Ln3(Yq z7cJ{(-1Ey1erd4#+^CCv65hj~+)CQ?iF`|N6ZCnW$!Uo0PWo)j#n*6Bq!D-;=yE~rsDu+t{UyX*4#dn)_Tuayq23q`njd6}IawKOgG zx@RmX=eL}Qc1+Bt_ClhQYTOsiH$$?vj+VG8Q~doTrMc={x%PyTQT3}$uNTT3f-bi2 zufIPt_%5VG?FYXl6 z>6W5iUFjjgA%o;C_J+<;0L>!h+25qR>(CMPD)>I~E?;qSuzWI+>yiy9A~t`$+n`zK zX-}E0x@L9z*Hz zg!)A4Y9V|LVMqJ3nv+aE^w}48u+%zqy`cK-^sUJ;R|X(vuPcOD67eEevKMKmpEYRi za_;EE6k4f4+BXiX+`&TC)_w9y2KefBcqqr*@oX@(s<+pd@qv##~d9{w1;(7 zzygmI6^2;ebL{?73V&ysK0k<_Va6@Ob9plTi2`#4(lUQ#Mm0%#7R;8`tH!wPh-<08 zC0Gs*<&%k;Pg#4Q5uz8GJCjIoSg$&rE7a$>_AG#6XwYKp=NvkJ#~~Eqezf?8S^hb} zRU<1nEbhfJn^czjq|Ns(T&kC~EyQhCc2B&B;LVu}6;7R%sZQmwBvR;$#^z~$86q?r zmsYIZ8*=WVlPCTq{VIV^RxpbsIX{pkHtd)qln6t&+(Wl#=B>TYO)1o~^f;?rb8f9! zVY9eJMyFeoo@y(pRa-WmHmI`hWHe$|v_aO!TNrJsaItod`LV6VIz@bL%;2#qu##3i z5X%V!{(P8Muf2_(>6$tv8SJE1aNaE>@VUT~XH>fqlR%-8he?4zRO6`9AyoqnbRc>H z@RIMKx)?^Zz?*%iOBt3;H|_F+^UQ}_Paq^;#lh|+)|wr>fPRY^%^3<&&cj5}8zB$> zR1#5=txs?3A4&aHK=p{6)r}4ObQ*uMY20H`o(_u%xE6M?x-H-RlCkQEMJTYA$x=W{ zp&z|FC4e(%njRgHA9sLgUS7_-^#U}57XTxtpV>6ghN4Z(>MG1@lwU7PN)N3xHpxH! zmo7`cz(`^LZhT6ceUEE8&PjR`h;SIG=j?I(iMVdt|DHnLVtv)U2e?!nI}3q!0yD$9 z_SYRCHYg7=UfMrU_r*<7(dD5gvQUKe7q(v^AoP(rKAwo{54cfk5TVIyQoiKJpHCRRjb9#SEalTlfCYjLWhf@IQhqV_hyw*`Nvt7Yv&z zdC$JZ0kqG1qU|WC&v~zg8e~a3_$>`M#i(wt$O~Xl-kK;AhpT)FNbnxLC4f^_5V%IK z9DuNBSbmd|vd3Ujf!pE(eZT8FH_cezey|j3dDvM}L!3HMo7P3qZfJ?gGGq zB5}<5swL3B7_iZvpjO7?5cTOum+Ux)BW@c2v&<)?tR&R z1MsvAh$;-&eIMl|r5tb+ffEfFM29sPhpzOHT|9Evmd$@BEG|(k@&kZ_) z%JcbSp}wgAcb6_3z5`?plDK5)s7Lyym=(Z@BYt@yND3gCG0IuR>42Dcz2hmqVj|vk zmemrN1WIn0wXTjvoy$LB3vd+fZpc{W34A&ovY^wyTC!gVO)~RtmbI2B>ok(&KeG5-OY0 zqSahL@qLy}npPyQbq!<0Z=McXbI$=Z9WlO->IX=N<)~CIguZza!Pc*R9^j(_$kj=S zHDje8U@g5J?p6vL8zknq_6pJf(JZH`gJ1jxSRCqJ{>}-kgUSH6Z`~d*;7`;lINBOR= zcHU;RT7J5YyNp%H#tYc_-=aL8Nup4vvxJWQDPk+oZ>1_@G6_#?Sdh;d+3;1y|29L( z2;ix@=qDsg!_Z)HyQKA6njuoS+I`s|0b{}VJ0Q(I4wIT zzlZ_`M2Ghtd}vn#SL)^slemZ*i;zr*fqY230#P?Sca(PFp7nT3rH_35{YUPkI2OnR z_EZ_fGZ0v-v}UO)$HtjA_oWGJsu>^40m|DyP{KYo`Vjh^$1 zS)BxG!7k?2{QSp6MGd09H2D2p!1IW8cB)Av@sD?*z{%^CmoMZ-qf_(6Pxa2F!2=Yx5_4XtcWGnhK7ftF@ zO^pZ-VZan%ZP8xb5G_Z7oKHJ5iwVhQuxh*U>g8abnmvu)MNzoP5v!| zRu5v?lO0L(8BB?9u3;VcN~icJO7*pII-X8L$b7g)cl&HTxRn$Q;$nI3T5)||hqkU{ zuLiCp#mZQ-4ooNOUzPX6W41Zu7b3Se9UI&Kz8b;`pvC<$!6Dym3W_t|e|%ET)>8bB zI8Iv^`0vzrwp{wv)HDlZAWAnYC&{!yI1g#dKW0ld0S3;p^k7Ol84il6!4YJ-%?r4! zl(bb#^ZS&oEdBPrVa@Vy;!j5vh~oHIm3Ker&mv6pPm&eC>-I^+y8Qa{b&crO^~^n3 zci8&5%4RmC!o6FfIj2yMU6LiVtl(f!%g4D6L1?Y7Z=GG&04(osE<|g`Uod|HhTBcB zuyEH6|4dYsHf+p!?RGXt6LgV&-2ReL;WJVf!YVAUq~QJRb7RC@d2EidnoCHWK(5D1 z@{4(NCYN|C^CqO)u`|p^YZCp80T?8MQ#K^iGw`A0z<{}cpGr}(UaJF#NO#vf`Xo5M zK<`2qRm0 zzJoIO>dDi}`7yr!0AD*eDTuyN;|!x{fB*K2B@V3&TVD7On|fE(mCMw8=y0N01eI^y z=N^gE>fwU|ZkTB4Q3E=Lk^RNRvsXIC98XLzujxY{6pyWTS-y4dJ4dNK^NvHF@2b9Fgslj+ zK0ycasv3^3_+XEdJ?W#vqg7C4cYET6kw*HJ{+h^${xX%3@4@X0%K-0_T^w|VZ4AhLpQyzEO}50K6X~eqIk6EY z3O`sX?pcw;OD;;=LS6h zR;@&8n^e@c%9WGrg$qjwAA0$s?|kbG!Bx$A&cN$oA5r2`WxUaj0 ztSICGaFeTl<(qMDmdM+2T=O0EV)g`18QG)p{C`0Npy^?GDkg$9c9^BSpThgLLoH`v z){FBoqBFtpKT>i5lol%n`?{hJwbZ^whO2KNw$X}=}s+a7~CPqAk>by z!|EUYHv5(=FK?Tc*KZ7+onVzn4rY_{FbypSD5NZOwB^N2d*K_h*Xa>L2zWKyR3n&MwrN(IS3|g`1weJb{sqsl~zyVo_0e$qP z2drW;mfRXleQlw!XxM+<*sRY22w5!KzJJ1EA%O#E8CqhdHC4z)MmT=Hc~TWqz0_^$ z1hc?z1Em4WE}qGU7+Q6DZN&wEPF1DF4MBmz`3Uv(#Tb(Os@DA}A2FEAE^H{ZV!CnL z!((G>w_3C}qTO`ayHt3$N#-j$ep(NfTxyt*2?Hi=>$XAt(!lEZoQNO!IDM5e4ip9xutg{4R&F+<*IN zfKJ&?!vK$C`*fNn##e;(<=r~$1NK7jjn}q~2pd})PyK{1@gL8zB1XK#Bl!1)}49Ov%+v4vFQL+YewexjneFmBfTIwqX4-gV-tH$&b z=6em63`vMQckt=lI_lPbND(jHNkaD@?ih>^o@f-hf2-Gv_$V8w2*m(e}`;ol{cwj zyQ&b35R6ZfxQLU+Z`^UOUb9$Ia$`c~2YlDcNt7`3=KZ7%*O_G#QBy=*viPKiA5(iy z$SVp&@3e+jq9}rf)N11OuuqyN6 zZ%fsC&E@Z^>~^aXdn46@e1nO~h!*|#7adqo9%%#WP5f>92Cu@>AgN`)OEEg*fsyPx z{Bv=-hsDGkU@=gE6)s$#n`X=gy00IXU$p8-*s|W+W~j0AA4U<0nVuY2+x@3_jo>CR$yb1e!X9 z08y-CM*%v|NYRL~cAp8tl+?G!B~q^Un=n(fEZ>?cbS#@0LfRy zlU7z0*0ygF3X*2Bm2>7<<~_+O#_;!YIFnNMB#bqxkiCq!CP0C+z`_F~>gVz56(ks$ zit69PT48+z8a#{=kdiJ&Uwy=&H8nLGPvZZ!Z|`I5duWf*WdF{x;W9XG`&ro9@Jiee z&1sB#1z?qJ9sC`>T)#gWziY&{{`>!*)H1}PAJj^1Pr~3w9rgKOCr643W^|z6bYdOQF>J=p(6r8 zx{w5<3jsocfCK{4Z}8pkz308>{cz5?U+#xwlKDOJ%v!T%)>`xbuUJ!KJ=U{4XBik6 zSb=x%m@_c^fu{e)oo1we-;la=n%=k9X|HaWCo0T=t%n9iIJ7d~Wuar7sx2~x z`I2kxhc~sd7N!oZ%a{TWe2)xU1OY+Gj_RhF)P#i$Ddg4R&SJNpN!P9!swlQ z4(a3NU@&FoGC6LGPQ{BHxA;H)9)5i^C}O>n)9n*pj5?=9JNt&e+q3jEAs>{)IVxRb ze38g4GPg0Pp?C6a-D-mno0OEXW#U`|!+qe~R{AL90;Ogy;G2YZP_TCeq;qFYUO@e? zoJSKF1n*RXKQrs|uP&voR+6|g0ZQP@MePW1XSI>$daa-}L z;+qI_tAoE*#!E`5UdRivw|5C}tE3O3mvkj@IcM z8hyA)_Q>DEIb1#JI~SciN?|^qzk_ zKw!>`w7BSV=@FxadCp;c=S-nlbXf{)AH@&LZ6z2_{o!{q{3Oq1nMJEoP$EFUCyHF} zOY#xWixMq1DYmXR(dJ3W`f&OB@&n$nwA!yn9)<7|4Ubz+u*Pw1lvq`Ep_0U`D~hV1 zgNwQ^k7qEi9Cqtj9eM@+Xk42Fb7wxNytn+@T3@fl%2e9YLb7DA8+|B1ebT$ORD2=6 zwCPw%qO!{0-uElpwargRo536aH8JcWY#xdOm1E?exEUSzAzrmiPGz z5UoL*;rtTs|DNRkssCOz;?}R?jD|1^qwK71$3)Y=H*00v|dW6W_og_IH)o&p2 zx~=^$-D&e}+_ZUgabL^I($E3GW1|f~8OrkC)=(=o7AMys;YB3h(e3-}3ms`z}MsF{Ss`+U_9 zcWlhvS`AzlLEKQX=NuT+-J@lyTamn|yh}0&O)7P~hjyf+d~0o(3vlGVx+U>K#zd@8 zVzQ-tQ3_->ag(ywYuO#dQ#9dSz|GDxs3cz_t~q^=G!Rk3cIC+OYIE4con*gj?EW{l z7#fP%7R&6siDOLJi~9W0iQ(7S-!P@{GE;u8_fkITF?)bAK9d>-w#H#S%kOn+Y)9ZK z&WAsC_F*CU+lY*y!RDO5wH&<>v5U(oX+5M>Qt-tVl(opC#*nQsD512n#pAQBsG!=Q z#!(Y61=(a!ks{X(od$)i>sZ|T%H7QSrVu}EP}?kN-%=rL>|k~YiWn#Q4$;P4of=r=^r=?oGMT3I*YrkUV`X?)KD6 zK!4FdPy-gTzuxIo4|v?mOc{)k%w*GTB2$}IA0}fDb3+!ND->5L5>ge)8fSjJ|8T_1 zX(Y57vGHU)G(a;uh;*sO?g%ZbS9|3)lCXh_QjtZ6LJ23%XvggJC5cfwI#2m;&g;|! z$9So{3uvw6?f$^*kv%g5i~Rnzni-)FiH?^`GPWE?OB@MiyYBUD-9Pe=^{ae@-j(ym)cDCTJx4BgAj@U9vJB zIxxsT%JidC$A9kKK(F%1fKB(Fggk<0>B%^1Y*D*r<(I#_zYQjV$ccxXu^a6Mbnm`Z z_)ak?^d$04!Tor%)g!I0roX3oj)Z$be=KUSO<0mBwc6*2JCnYHC>!HJk(@A>zQSm+ zyWjXDe&uGM(F(%GuMV^Xg2=-{0-9;vNXZ8pN1+giu91-u>R?}XOm~_!aCejZz%G$% zusL+Q!O=Y|$VE4tN9|%u2N8D@{8wuvH6^D=<8VC@$dey0ICv3Tm=lqaI!0R_B|K&3 z>=T)rm%1N9P@IhX*&r)_>!>(H{QhB|O=y;3>$^x1U5GJ1a+v=cQC2<^S62D;pzWP( z#FF}GyjU^!7f4sAcVu=NfOjZ<7K>Am^5vJuzUuP3qR^y!^eSFMa|XN{|7&|Mq{*js zZN^_S=gW*KjuY`sb$0>vL3UzPPG00G*rR5(<^|;q+n)V-%)D4DzhqCTmhUDi(w-hnyWUTqO(ZvXH;NW420#V2*q@vrgRiC*9g97=G-wr3&QF4a`RyHF5I zsOmPz%=hA3bzJ5bB~whcjd}0tpSLCT#2uT;kU7?uM!g_uNSZ95AUs!v-hM8TJeqD4fFR@Hh_Ud;W6yMfc z@gC6_uF;zR(wK2waMH5SXX92rI>#Hy9L}YjNHQLO*%rWvo}fgZX;dlS)O1Tg<41J@ zA4WH1ImW0+mWW!Tfp%ZP;ot0e5H)4(K}~*j!(txo8}X>v11+QGs}(tLy!Tgio~wQ~ zyr(H9Qb<3$A3_HwIcZz!2_ZA}0L~{tDi)ZlTIluEpAS&!ax#u4YP8hdUdKZhh-T-j zox}(P&rXoTC zIV9Bg>MtVqv%nwUWN1YGqi^Xhnmuzd8vD7s6Ela95yV7oe|k?8)47th@U>8gMt!st z`Sq=?t}a57fSw_mjbGhsSkhT->zk{`-qs3ai&MOr!kc{QtA)D-F#-3u8`l}W)y27T zd(y-4de;M=eTkCh0x6GxCgk?0`vR|t23(@=%Q~79Jq?D8#A{&Fmr`b@AdaKfLah#< z3I}=N@Tpv0kLh`<7$UVMY>fL?-+h$4Z$7rF+7LEbYdq||h6wK42p*Z;*`@h~7CU<8 zcQx(TN`nt{TvU6zl1Wf|%^v0LwS61w#6ACCEt3bgsvbIoW<6P#18PGl0a@<4`P)Ho ze8S8?qFWlgn2g&Mmu+gju9V{cRLR?+pRDD1dDSXZp^UeBXN9d`AsEK9iE3-OT3dBf z!&giiJsy-!hAVw~5;ft-QLBsNHjDhuZzs2tw3%@d(yB0O-qzqJ1rtMf$10f1e`($b-c)i}=l`W3^qq<~ z5TatwyIN?l;?nfsndu>NY=9FKq;?yo8OLXE^*J8x zj#4;Ve?8rC?3+TXh4v}9uyv;P96jMu8*_{&4P>kIm$~z~sCMSZ_i`qvydHsd{YgRbN{+y(kG6>$eKIr^>Z(4q4*$pl+?VS&h zL#mO#D`_FmodCU%k{S$`UK=Mx}%G#O7Kvr$g|bH#Ykd%G>Bja{JCo zDS`SURX?H7Z3=DU|FcQ*A!&dB3pcI*+#_e2gqm)3DL@W7w1964E4^Z7T%l^cRF2EK zWwE#Ro)tU!*ZITB(Xo?unV+ky`^M_rY?awB1!%@x?j#NVTre*^N9Al0N9%{-yA37RbvzIq1lCRPs7NBAGvi!CGJ&S}O`xw;WR8fwv z2=Crl2*zCuaZ+jLISwC#wScg8dIhHhQs;q}?oE3YaRFq!T^2hmd!m3J4Oxo&#N!^n z248&kliDkl$=$(!u%xHUs|dGjJy<~ypgG|M5l4G7g`e3jXp3U+4PUdpfB!C37&*{6 zuOD==mdnIOYEee2>01!Cs(3cUY)I(PxxhMHTLoM7evqREXZ>fF6Wz!*kt^FDd>{f* z_EYZ{{|Z0VPk!)Kq^_xl<$e8>6Og30=0bI;^~L(csJOGOie#tT$P)9<6h4i>rsY;g z!rU&N0zA+GQ&=8S6qGl<&Ii}nK&WqbJ>&FTWC9B^yb6Wf&XqVgA$b1#<;<XyO+&B@e*<3QWmQ0MxJurv)@Lxy0QL2X^ebm%t3kqxA z-OmoTwjLg;8!X>vBjF!+jFn5Z;d_=!0rYo*#hVY~vhYFmg~kWnrp5=~s=rmg#yrm2 z6>}p-IjIU=sqc`$4q;ejGJNXo&ufcp8y)VGG!(HWkgE$V`ZmJLf1*yXYu{M@GjgV= zY^@`x2fRPCzo-a_1SU>e-<$yMcFgxgP+KRNZ*IHm?{r`-hObqzcM$+VB74oGT-Kp7ru}^!8*9-j1>C9q!`J|MKDaml`4SM zlG?^(@6=5mpaW3$=7C3;uY;)x@(bYcFHm!~MYMgeo7nWdBX}AqYj@?In95@8T&;9I zTe`1zvBfe%zbknuchNs|KX3Bw_}=Cze=YGijWgb75oSf>dVVSca_<_r2M+?2K?CUp z#slu7k#sNTDRt^gGvA_)vRe|oEsoAyn`JY#oT=wR=AmU7TgfOVL=fPV_4|BJ!07eTW(*_*^i*r&dF-`l-$lMbmtA7wQbkLrq{N1r|e(k!~ zFcdRo9ZkIZJHSnSiMgS`tEB(AY8|Ft)&<;I*(kx-kcLO4ISvWYxxpKixx)(qhadT* zp!fj`S(Vy6;f{TOch%lr{OA}=UI;w5=1QyV61%c-mYQYJI^_ZGQZ+NS`{^3f+EwKx zzRvf+Tl4BG8H>uyw1Bc+L*dWp^^_aP%A)LsRahfIhGx9&Re&aKLvT9s*IJ0 z%u?svV5$M_d~$s5a*H}kryw^{^sFU6mh17q5_vf$E49p`Oz7c{9^<^zyKm&yJO@hK$N{dCH` zGcH<~`V^#(3BDynZD4be&&0QNU@Xg;{Ja3~8u@&rdu#8-^y_IRPdvb*1lIM zdgcD110%_c^mx&ncV%IP2pmn1Cqo;zgc8e?l{Ryf}i zlZ~lR`wi8E%qTveuUpzL1+8qe8%yx5S#6JIZ}TVhA)l0xOIHTlTU1OueaCeVkxMn`6G`iIEN_44p^XmCGIrUa9>NVtjJ%7Z7{{VL}66?=)YSx7i z=rZqSt8UnolP~{!Nb8a2HMtx@rt!ZM26OfEgvnIyYMp?|Q3a@eNg*RxTkY_Z1AIrL zm?oiWX`PrQ(P_a6*K? z$T49$|1f;pX2ZZC+zvL>dbH+wf6)2KKNm#`i#qSBy3p7e{7-l^-*VPy;4d(g88G@ib0QKY|QK< zx_D2HZAKR_J!yHgvUGzqSbBuno|?S#rY#x&j*dev4-Y51%YmUc|A||c2Q1eraS{wX z*US@-#y}4g=TV07BvUQ=lKqBZcfEysza;P~;wLAwLe`qM@hMVQEsmDQh;#_|K%!W& zSmPMREgoH10Q(jU|G1V4dvJ`;mf#v-J&l9Kh{J6X{>(Ox4z)9dpQJ#KwQBEr<4MW?;oU5}hE-A0s^{sz>pS>zZ7M*85EZCaA9$yt z7C%P8FVkUc3i+1Br|0&qNHTsm>#8dKiLkncdy zHI2T1MeUhfRl{drbS%UP`p9un{TG+t;~2H=mNe)zLH0w7oP+76m55KK+W*2ASm{pA z2>vCN!+<}ETduI1`$?UbDlG_{7}MpA;`K4Gx_ZJ2?mK|8T1CzXlY~i zP!o~YldvnIP;B&8kIyu);zRFf7|hTJ6sRJ2#mufHBC&zAY_}On@SYbvv%y!hfPnv| z+E@hLi96luH6!W0@|4Gp*#XQaD{?IDTAQ)ygOy(CmgE;}DIR@X_h9-{$v4v{o%&b5 zUB~>Mn=v_cJ!__FB)uuA5@DrOi=(#P^RJXi_aw9gWBUGP>|D&Tz5#nh^62e^QX7o; zi`Kk|%5fjdqkX5G=F3MNw$Qt4R-RJ}JLNIv19<6BH~R#&qU|Fpk32QMk)XC+Zj~93 zV@Z}UDGis5ubFv|-I!jhGdP?OPJxlm!D@Q9=EvrP+#TD*@a8Icp5{hxj_oR~XUi;eDOkAu;&6M)^}DN3$hZHa?k zChDs!vDjz|Gf&+w8V{M2ID406UZ4^>S2P|paJcpOb6rR3w7~Ms78CYk8&Ts6ok7`? zY6X0+_M{Uo_}&apgmRwa-07t$ZKvIXsd66ud_P5MO(+(a96TmkO?gjYtJ>x^FVuKW zw2NNKIN}=|i6_nVU8q6qaqOAC8Vy{naUOM2?Qb`W(6x@=yhQYv8N$V#0~~Lq&9nk6 z;KAWio$c~!m;J_yLlV%-MHP{KuknzG#%illO%sEa)q}niaS)5^em3^-wpFXnw2*0`6?OpHebF)E zez?wOyDD{!?Bn^q$~<28;;ISFkwC56g*m8+FM7?3d89PmR?qDS8i+3)dh4IjiJan0 zQIP8o)glWGyO$h5Nw>Gif&Ai5cuTt-v zN`FfeXbLuGm^qSSva=ogvJ|&&v9bpHfVm+3n+-Qr8d5{Qpv>1|t;0vccKB#t1-803 zXfxbafsx&k{5HOo<9>1hkPVN~D0pk7THc7p2N3LRUuopyrr_tK$TGq*|GjhdF>xbh z-Xbn7}q#VbGrj8f6^QxJFxG z!ndz>@6u-KM;9_ff3xr*nyc+PTPlmw&rjL<7B*}rm5;?lsp1;(+S6Gc`5Gvt%9pC_ zYQT#2(C@K8d5smRPK~?(@MkuSnqv0BxCq%|g(=Q5PWMZ@KUZ-S+S}gEQIiq}-nqi@ z@(Zsk<&VvJn>Nog$oRq|B4WCj;5nEOPTh8^RnO7Em^jN;G}2(ruc}h^e?KT9C-b`^ zfPwHotQh$3M+O!S0MWzm!JP!Igkm6ui!SaiKRqo26k{)5Qhck68EjZ!f9PhIFsWE^ zlSL*$<_&>ou$$GK?VU#$R^n?he=Fin!c`v)y7+JC$ai~OrV>m4;*YHlpZxs0AMp$h z?de9zwjGx}Sf0W9-j%5e<<B4^m@eb1URZ~CN$RS~kk~&o+GVt8q~^;#z0P&BsT}znHM_P+d{ao+i3q@KrC-jq08KsNNSi zejdqdVmH0BKsSlBI9)MrsCu(G+>~|RA2sa8 zA~1Tz&@M+j>D9%-FDMhu0`(}H6IXc$zh1T>%HCSU6<~;{-agXZ#?B1v@y3%QfK?qP zr|?(lnmAb1QAPkkbTdn)%zcCx2?0=M2Pp4Qs1@N=(c!U7a>N4|{R8V;sL>sA0;3@3BzV>hPar7KP& z@Zr1qhBguEe?qZ7qwGU>ar4il9S@J{41cWoT@l*3+4(}LEPh_V*`}PVoGaWzA-S+8ny^T(;%pP}MxlN0?w+$6) z_Tt73Ce7irxWKK)<$6mo#vU0@eXV(*vK zP`mX-=XQ9#I!i$2O+zWVCaTApc*0#SIYq`GZ(A%1-A89=;_h3#p2mE60CsaxeYy!g zl(vU@HMIepJFx|Vjt;yg$n8%~!s#|0($jB)^!rLpLanhlq~m?88EXC+|7bAE#_s{O z?Dd((JayILhdmSYTDeU{E|W+4A9QbysxEL3r{BZSeHPbkdhwW*D`e>{cmF*WFmqKi z-E~K?U@yI4dH@HzwFUJE{oFVBLGLU*`G1v_{pTQ|6*)KEHa4vymb|y$zpaMqH-;2PGD{Uo zMFp1p!C=Wo-=DFL+pa7I2~l1a#QHxT^dW=!Nen2Hl<5JJYd0$|ZG(n~_MXTQ=!kqD z!g}X8K>TA=0yF?y+AVT1p<6T)7zfF;|0axnSa0q1WQyw76zq5^4p~14X*ifb9rUJY zjx6@?js{zm32N9K5AGCh! zd%D9e6#R1BP{s0*={yE%ewd$M#dC;VfjA$ z#tS0_5H0VkSb(|4J91$FiV?t&@R3_-Lw!Nm<#JS&H;E)7js9>Uu2)<}6K*4h6&1W0 zb2-?1f!hQ*W4}S^yI%@+zdM}Q+t!7QQz>-l^iEwUy*yg*qDNYCrY=7Ev(Fz4kBpCJ zUuU@wd7sEQS#6eZh9ynd^ZQ3X4^>xzzr5vZll=VPd~<#iveem5VW1mVjjl5NtmMgO z8()_V#{P;HF7Ehq(JXy1>!E&6-s=!|)U~6F6+rFtf%enSZo$mLF)zy7y?7C}{8~Vz z6AZVZbkkl2TvHK1$uP)%Z)j7_{}dFLbhi?bE?iadHP6;o=GM+cG^6I>xxNe;QSXLo zTe)+&zz=6xO~&o*o>bpO0nz?EScUjv89K4i)tN0JRob!S=k6oxpZ*n{dv-!+G`hg- z5cx2w&X*X6<9Ig2DtyIZQL?3gcHPg0eno$Eil~&A$8_MPP}%*+lhyWvsAp%BA6zx+ z=Sf%S(r{k-L*|WaMIyJjuR99w9Dj8ff{0?%>yeRG&fi%XnZLX`gI@Q_2iXc+@vjOx zhYGAVQ3u4AKN@R)es9+U#rV@R4sL0*w!X{s74nH0o|3nZl@yp{pOe(Gk`&zCWf=ux zw0vL52E$Qp8D)?H%yWpl><-IFVQrv0&y17N@H}I-Lb>39iwnItaTRK2|G|vKn>O}(eUp5e_;MTw|5fbcIdmG*V=G3OmIu>j zrD1O$sL^lUOxR0KHBRxC%!@^zf;a}G>HfmTLo?HVxn}iIi#A$zZT^Llj?@CC(uQ)ltU-4-Q^#?3*zx-X)-TI` zb5eiBmV_NW7#j`s$o;{5XCbxa1#Z4{cTi(I;PSJH&&yfn)s5j9hAQwaHry-rN>6%D zcapv_I;40oIgD2xY1WNGoS*jJRh05UDoeO;wKF zumU+eP)wG`jxJ{?j56{J$sRCYev2jM) z0j!PUN%Xw<8qCJm#RwYfEpbM}7^+hi<*%XZYY9lpLv``zg*i zL_V3VyE58y;)RjtugG`%4(jIK(G!>$i6g&*XL-FE#xDxUK)TH=S&tpAQPR$ep^4Xf zmRQl`6O*V6r|)d63DK_=F1lCoV8L!(4Cyf1VXl6k`M8^nua$?-SzIy(;g;cJXqB7P zCz3t#>WXjL8I`X43qz2MjO+gHbE!TC<1q%M9qdSOL6|Rfgv~kh?t%eDEKX%0)cIKN zN_yTairwEip~6$`%W5j^7V0Wm^}?0+2g|!3u11LfC+Bav?!+K-7HA z$qUB`oX)X>>=f2JH|wG*(0*RBO4!%@+-Atvk*Mu-1-|L{S{K0(DE*@FfGc494hhxu z{PWKZh-y1{inqwmR@>+EK)Q0H5zeO{5asZy#NbS5dyqgmw{Kau_;SnSMZ>B3U0A1O z?MGJna-O9xrzij&aGS0F_PC!7v6!`R%&`*3=-1~M5x5L^Ch%qy3jktz_0mmJ*35~o zq0$oTEy6k7YiC(3b4BCZYuycz&Ysw+ZkXftY23M_DH!v#=U$kat!+}N<%*r3PmCw6ll*UW`=e2c!VF>rPJETsLlo^AnFZ zT7oVu;HYKIf+)(~B`Cl|d+974UCSu(I)-2a>)I_C&3+X#p!nJ@P+5V*XM0}U8#T=G zMr*LabT+Cvyj|3P(g=BZpTvViLSu5W^%)F0X%r;UO$Jndb_--`s@veYVAS9;_Ym6J z8XMP$hko)-I!N-~ELc9;*$*G7h9c-cv!ydv>DEBkRF3QGq3Bv>yVmBkr;3D4vHH5Y zZ!WWqUldOF^MiO7byV%FhifxUbjci$1a4Rt~O(``4= zK&uvs8;W8anq@IDG1)(KBLC@G|0$C;>6fqqkyxk~@?XY7{~A9c8i%F{TWZ(=n1M+L z`}Tro3ULo#<%R9qga4ZTmq*+lT$p}MG%cB)s~D`1AtjN^jp4)aA38iMN)$`IXp&e( zY|-HI-?s3;AjG{6HfLTfP5Wln71fn_W|js#dX=@ABzh~gUG#Xe&iT^u`=(3GJe{a| zr_cj2Ro`4`5AJ_|!uB6W88R-xAe;RPhkwOZ=L6hn>Kex0ZiQQqA6%n_&_~oGm7akZ zgPi`&cS#q+QzG06LtSACee3T0i}v!n3!nbqxL#H2(fJ-YUQ*UDUXp|wB|H#(_>XtS zN_Q;I(T3u%yRWveBI5|&)$2W2?08E@tB@=?4C4k|GgMmHY$ipvE{SQ z?4-j&dx_PvEw-w9gC6i39O)vdBWece$QOv4+7t5ngVV_|Xs~(WWHH4sUd`3l#p1PT z?RXAwp1NZ>?BR&5>}qE%Um#bqO4yA7ohYB4pcEy&|NOd-8&PAcmnqrrh+qS!ul6CC zU0ZGX$vW-ddW25jsXy#+uD>-%C6G675CHNfpj`OxRBAHNe_d7`QqV;?AIQGWYv8o? z^TMs2Ka{Qdv&UF_r2a7QWhcr(b3eSrXJTp9$(#*?gj1zIRG$PF2W@oy^zvV zHsKPLb&9+V38Yi!-?5ra31?UN9w^HUe%_oj=bpoEb06TWPj$%l#G`|cB7&cv<3Q&H z^8wrPxDC*`+39am#pjULz33>X`j02AI~~`#f%7Yt?rkgT3fP0%ywkyPy8WKtclY_~ z52G;sZWx@yym>T1sW;SiJgI#cT6} zhNF(;oZUc;l{$ulAG#VNzrcnT4qyOfGOjOZ2O@ zF+DCU$?Je>+(WJYnPp>vj>C^;!f(=?WhyI)xJCjl#&LUw%WDafFyV4aNWL@k@Lgpo z14XFpt=s^Had6a=Uc&5%6S`}a%WHGR7Po(sJU|BnHum|{AY6(&^JM^^FZwYo@Zt8e z6oO^iHp^YC+IHd<4sx#6V<=g+JH&As4tH>O`o5H*e}>zN2me^>c1@FG@!zgN930c- zd{EGLv8ge`D7_~A;q1l9J8*nh&e*nZqr!|9Lovi}Tng|r%{i(%Y>szEg(RQGn>}Lj zRL2O0;U7E8f}i9xmlAq*W6%y!<_&!wGiNmlzY#!`6P9(()srm;_SO=k_zF3-N%&bg zEd;)OP%>XZgl8BE3s-bCl9p!+KB=b3y9K%D7QFL=)DaAxkCal1zaIWOMZh?gyhgj- z^L{UW0X3YXU!;@suov%qOLd;o=Xifzuv{$+HQyF62a!`ypvhNAV2uKe?)s(3BrXJ> z9|l9tmKD!92J*)flTDY7R+4}};5B5P ztW$5_3G`<3vz8z1&POIp)Jc5{<5oOFTa{0qur+1Op+qt|jDOagFW1xK3>gG%ZUCf2^H#pXm~1j*F>-j;NMP&AV_~&& zi}un6(DMj|`fyXz5o9copbS)~d@$>nXulrfy=f{Xy#|%>=FQVl@;#mqmR23b^*Tn> zS^301nR-R2LAWyMQhlSUc>Iv|cdh;S`?AWK?dF$?u>AO;tLv|3^|rYNd^OtM4qFQE zyZw2XtLVUUP4Few{_^6ha1T4KgX>=Cp||IOMRB2LBN?B|jvxO5`?sthUx=)4!^%4ea_E;LIZce; zkXbm{``^Nfx_FRJzeOGSqf3g$gU?XGnTF44zU{3)qIs=&Jd&VgqK@rm02vStFk%h^ z5;HtDD|%<~EVAPRBCt2YDVi4S=%=^)4~p`@2n*FTsVDtm_KXYWu5ATpTia*DkuQ|c zOOW$p$OHt86Q~VFLY-9&Sf$=RKJ5mbgiGrPFKU9hhGu3=z4rg;>KAgT#izGwS^yRB z-w^FVEvBb`QMGwxzpb@+x5MFlc70EpkUua2v2@ zg>sU1bEAQ5?k+!$*f_NI`*vJB%CpL97AghvtR&fkP8YKrN0JSDm;3A8C&-UNAcE0N z8jGf;MH0?PZhRfcWfL2i;T6~(B!6m!o`ND2MCKTDOoI~1;f|oa4r$}W8u)38?_~Y* zfD9P4Jr5V0`^8k$m1pPoXXqFw=2hpPfU=vzV~!)&4p_v4&GJ+}97?{juc>@UHTOKt zv%ri0uvwmYk_B<%9qM4K8*?qlt_mEHQ(g+6)d(x1XSHiGzh)xZcxr1S@F<5GM{-_a ztIyg8xg#p#fz?w>n2mYjyS&uwkxe)lIArTz3ztBbG?i$?JA9ZIb)YP?zwj-lFaZZD33@3D5YL{nO75yI;=Xdu!O{ z!{!VKJ^berBh)xelP`7hz+{1WIqz=D7e7#~FD_LkZ|0MN?ie9!yks1<3vAc%La@6p z`85^}no6g+md=R;e;jmbnDn%|n-0eYEh4-;fahbR!liRXb3&YE_cAB;x&4<4VS=#F z@pI!Ldt=OwS!ZpBHD#{b_Os;KyH3YG_1x(B%t?Dl9lu=n#`x0v_eOlpZWO?E3Z2q zsy6{OfRR(1Zcx^&39k_yuTeKzyEC7npy9mDyY|SrwTfmc&VCw{!w@94U=N^vSUcP@+qp^5 z!Hhk6;S96j?iLaG`L>OKAGNueS${uw+OW!sM&PXmGT@BJ(gQk>pxpAr_*cVQPDIde-Hwd72vA zi~biK(l$++HGqrSCf0!L%<1 zQRa}*d4QQRT0j*LI{Js09gEBZ%MQ3)Ml^M92roP*jqg`ZPC(+;Q_Runu7txh4=)o& zwjeVYxG;V)+`d<*q-eqFVG2j|!fgI6A1PStIo{H%FFU9rWM}`y)4U;!c-hM>E%EC` zi3Qtlt1@dp+P(M*tP7ViN}V_pj60CI2v5gPZ%YHU!Iim;Sc+AJVjiOs{-CcfhP#l| zx!`d9q=^>u>E``*%fwkbVb{jKITi+)uV{sjylUA+G`DlB8}}onZohA+s`?G(N87J#2?P+U``( zu8E#`>KkpHN@ofJeqw0a6vnIh7Ty`3{jH+DsMiue2=#l|>@vLN{h#BoWGL*k$Sn9K z5Wmj~_UJom>K?Plxi(}5s9aaDe9adst%^F2EayKqv@+&dbN3bofr{}y`)55JV(Ded zWu;@yei8_f`C9Xle^nuN>35*jI77S)Cci!wmew?!CfBjTwq0Us3bqWCm;)@QXb)F}0mEDrwK|VHiHvJgQ2(!3KW$25pwcwE2re{^CwslXF zpM^%8+Rhig_?feAn`YHrBZb%&eNiS$X35-xTSAOlHS?v)W|iM;*=h3M)b>RTnE0QI zOPB1f<;viAoQ=A#0Vo!I#ukrYV3x${42?Nt%ok~kEO?# zC37vs7+*Q;m(C(1SA?hUMOOVno;uqr2>HN@=D5?w=gukDGWbFImPI-4b~x*;zLW^) zQq{4KWdGkOg7nulzeZ$EZSTgo4>)euGE9&s@}6;anfk^k zBW1q+P0IyxMUbn$(l2Ga_C6V%GE8jM9_YQB-LSb9v+>qle-8@E)(5r=)t3Z=MqpGH zdZfb0zM_ns)_k42O~tv`ZSX*Oz#@JpzRYpHBCJBtqQAp7X$51B{zVf+@A0Qp#tnO& zWr_=DFaCm8U^!mEaX!`|2jmx`mxlc{(c-8w6-Ac!m&I->2cIWYV#}r`ww^T4#|OR; z;rsb{pn}^6@hhgQyS91zZgY8j6WyquJv;rBS0fzOBIf&cFf)&OljJeg_5|&Ry3;u% zI?`p?xz`n8tcaH=*(3%whLE+<8G{loaV90O*%S9gh8_AJPu)e;307Lmc>wtStS7(=DH&P(`=`;myHYU1FrK6s)KTSD#OSPE(p7`dwAu zuRg9wVv>>gh=BIz zG1sT|Pu{9y4k7w`ht!jUGnR0=FKi{u+u~TSqPs7ur=OY7=V@=Rb0C2It{@{8yS4$4 zn#qwd?T4iy*awX%WOx|@l&dehkTg+^M1PEgDTLd5O{Ovg!{kv6x|LS?vR+6exD0rEUdnki`qY63 z)Mk3YeMTbnkl@oy8Q1z(s$1RP{q?Fu_9oM#?)&y@nlx7k_r1d=srFg>>*eYC8JpaF zEl&n?UMtrhKI#}CK}f*7#%?ktcrszx_isHg;LR^%Am11v+3PZg4wrF&XblP4rver!qp6a);K8={Js-=GlHp~%*g7)!?^i!yB}M&dfv7lUd{A?I zE$U?}(5vMN%@^cspXNmdK-6BYc_b7yflzOj3}s#vjVGP6Vv=@5(%J+ny8NXJsgguU z9-TjY@--GQxh*Z5EC)Hex6h6H44?1s&wl-+B!8>@U1H@%<>soG|K8bSX9*B^2lAa) z=hqzW{jb2;lAyVn&pcNEHai}n>9H~MF!aQ!#bWuQuWLa2R?u1GU?5*{4xST=kV%my zEaV?*GHJp)D^i+zRC`h4wWa=vL93@a$IekOCtX@f1pLO%BKw>AH?!9k(Fhd}XnRfF zn_NaY?-_;P+-Y%pX=@ifS0T7@e7pZao=v19*jeV(bm_Xa7arT!~Bf3JTp-pi1|_KTsTcyf!Y?8nQn zc}+W~KmNzERO~|^{;neW9GLUA(B=P`y`)=tm}s5 zHc`=Z`fS{71lRSv-cH8_W?<#D;{GAY6X^VX5Lw z(Bz5U)Pe#0&%*h(;WyNy{}|{|1~rG=YD;%XSM}~AqWo!$ANCqk;mg#^Crxl=WC?s>pRLpWc^zv+b-LWZ0eQH?dWhvymw9|g*g zO#5ck<^Q8IHoLkED3Ehpn020mI@7ugIqM!OH0uuldq?cY<%9QMpc?KWC)L+Q2HaTV7Pu%K>tnOP*sJNY2lyDf+SU4LX~&tC)VcxH0k@!Gt> z*&J?*TWSuN@CkMhsbSV*r(Kjz5tX!Fwmxe0t_V`pf3>zYl!YEG&_qkZ@NvgyF|H-& zxX|UkLF;_yQI}EhX#8mIXr+LFz?xQp3$+F#xh9BFd!ydj$q(g+i#tDSm01KcQRn`) zcKNP4v*U+Bd_U0&xnrt<1A3nxPr-~XbT34$eZuh!99#%K9?L78Yw>x>;W(-=sxxZ! zA5YNU8rli{wSZLyF;Y6^JC`*Tteu@$;r;;K873-zuIS0WzL37fE~HFf#Uwjbb}KV8 zJ>yD?2a?I{gsm3z(e5%D)39LV+J>W-SmMTTVz@Be7#^Y;eaAb!S&8xH)8mdmCNO97 zzKk67NC2#CEp^rvIMb;zqrWXGMD$4hYobS-KZ6Uy?lgf#21@dR4lP<-3glgeJff!fw8e`esp0Jl>TwE6bX&F>zX55KZzf^su zjUb*n*g#mgCm6c)9A0!14-cRWF6*@m=KeB(i%|6;G8xvVCK09Z!q-<{?~-S9J!QPf zl=DG^b22a7*&YD_*7$}bg(;bpYNgj#S!!ni%Guq5wQ#04nCrSvt3XRfdJZ}@-K%Vm z5Lg~+CDGTOOl~&S^Un8vQK@zSR1*zA-BmU-pPvT(vL!FE(TAcY*rvQK>;|JcSzL&Lbu8+k22D}FokC=!jI-i+G^P4u5z`t1Y&mVn= zdbNK?m3f2;(8CnQ1Mqy}|Hw!DC!81e?xslZJvpA3LTAq%q(pfGDYTh|@-rJCR-6n7 z`14`^wadew@Yinl7rR(}zn`i2>dF=s50vMgBa{<37*GFbC_YT=_ zFG`z^LlbE;7UG%Ov(6r0+-HhW4*JAzBNl^-qafBzx_GwiPnz5$bxUTv_X1N;K=qpd zisMV)O~#(xmKm8D$t0aU(JqpUN`F)HXb8Q#D4ns7P&IF9#D#zXqLbq>9b*0( zzu2+wE8OEamt%8z?Ce-y`-1!BE{XE}M~hL_c9FLUJl_qTi%?+DYb1#sbsbnFB^;Q+ z1KPGs>CXUq4xPpm_8H{HWfuST_*Z6O9|WlxHI zl6TdG0=mUP-6S%tcWFWXkjwv77auuu1OrjA^m%j2ij4da*qMw(w*;9#T{tOB=yGy^ z+@->}e}5>q^NNbSq(~gqmkVdN#dNHtA!+_Q?`+!^j1dFR=;WwkvuLQndRQmhL2F(5 zEMd*&hCBDCk)q1D8qH0v9-?jTTz_2?XiWwfA%B%v$Nk^yL|g#k5l#5Pg!*D>kvV3? zO9P;<=KqL8>M=3Uk169+Y)<;Lave$2HAeIO7(=s(SRr=mF=Z!pI2rI=-+lQ^n!7|? z0zO~+7j*uu<-Z`J`t}_$(C>&W_7@0(p@EFo@`pqbkr$!*i$unu=kZzxouU9n^S_m1 z?Erv3cP^}vdTC5j2zzgkg;QzeuO$gj{y z`Q6ClJ*JkRp(%-yCg!bovH9o>$O2^R{8;Q5b|7_}+~o)JUo&S+a9i9>X%Bq+uu>(V0mMWxl1FjU7uy^*iNqcZwgDErx`<4|Wt5qEeTvzZqf3h*2I>%$Eu;Ne; z@2=iDtk?4KSs8dBHy;q@eX=god$s4`C(XRhjkk5hoZ8C= zu<8DR%!iQ6#Gc%UJ}Efp%-SSTahfc#T?suki=lZt`s$2X{pxpRPd0nHi8Mq4_*{W@JJZ$0kf(EXC_Kn9R1;f0*G)HCs)>;& zhi@9auSaJrEBVLd5R9izcH3WHrN408G1sl!%mk1=bGzNu^lFj0BG!NxWeBfwoiHPE zpb+}(u`nEBXr9obeJSHz;8MLZlk;_WIGdtgW@_Xp!4@=dSaLDw#~Qv&^b>t^S>qh; zY=ty0hWQtkXL>tT&fJ5R=0~C7s6CjXO9I|CYg~5=b%oe~k%_CLwsY@9x84c4EKQRM zPOukSYzo{eMl_t>Aw2)s;41%mnKfkR5tSOA&XQ(yAqu#OqS%pCkJnbPaU1M#8nJCJWSgT!YplDw-f9qMiS=i;M5}ZC{v>tScZNJ z)cN@a7>4aSLR|2$9Z{mv#?J!$as>ZOL0On-~6nL*=mdcXI9s^L3wl4X;rm@z@vN_+Zv z+0IF=L3z={=6P%aCfTi1WUlaT`wgdwP3eZeSU0=xQxb$vW8REj7z}dk)U3X8n|{LS zyth5UW39}5T(@E3RwUG~p)aYz7p&qe^$`}~zI$YZi-b+pDEn4w2gxb~ES@f->;Kpk zg{KiGwN|Fzi2oknxx$F4mkhY{R1!XoBs1B)2-EAFKdf+DFL!fPnSv7-1;$O&9`s=; z7tG4G2%qK@YS)zNS53+X=_e}H=G;I5TFyuF*Xp^bA!k?j*6!z?SLK%0S%nLOjTGa=JfC(l-IkW2mk2l}69mr54= zp2~0KmM`p7kXkl1_0nEMo|=)iqRHk7SrVpqFY@ zACh}iW)}M(f#x%Y0^Ss-NA(vzN+|Hbmpk?ARfG#51-;+NHk$3X;gw*3x>7tf&WkPC zu^{|HeAXeZa{z#I$WFH2AbP%sVkWia8%sEyZb`7n8<4q$P+Y=5ImfNI?_-Od%N|RW z{La9F9Z!KK!&Oadtaw=hZkIm1$dV36Um35FdE6+vUA>d)ugQ8H01#!lCs%Y!V6fkK zZ|U^Fhg-Pq-CoD=N&Hjm?r3}N`Pp67cXl>TqX##%e9e^JjKQzN0~O}B1*wFG{`eT( zOj>ySrVxFDh=LB{4w$RDae(%^;1gcX>tFSjVvKgsVfKw8)QR;D0sP_iuD**7OA_nh z9b$&|yJvwcuXY{2S@`V^+6Dpu=?c`j`syT$cOdjoLAmP!>G6m<`Ow?BYr%ZL`l?M; z-~RKQflZbtzLx>t9}#_|QEtuOay!S&YtWgwZl_!WDQ3Osum^LKxRqM{{6@pXb$HD~ zVj#4xlffNS!VEdT)f6G(imxB4d@YOGdF0k55SFSzW0VFh((^^U^l$4OV_yoaFk`m3 znRaT^gbisl^FTF<2ud!(Q!;gRo-)v*%x2 zLVVcS{6-gT#i5Y2K1l|=U+T&#d>Qc0f#e@BKKa*z_`g$Pk^(NBc(!xSwFb6FFibPF z{~~gLs1h+|$x96HuHB;+P;@d?-k)Hv?uXosV_&p;s5B3%Uf{d+yX@!eVJRReV2O?xYCYrOA_k$wMrnUput0#8RW{ zo-{Z+A4lI*6zEl9=XDVgm<*BdQ7*1i(3)pgS}%!_ji7U~QGBpExW|0RfwvrybV8TQ zY^C$M-tzG-r_IxSjTS7asU!gFor`gr`1aiFla+%#)O%an^T6kThs8#q zqqfV`&cUan|KKaOA-*jM7VU0}r|eikf6HyO63duL&~G-WFPB=wZqCnmG)W{K@Cpc%WrW~qSbim^mO#gKuRPdOY58?`G6}`?Alsi0Y-EJvEBkHvD1J1y9{8vkwA3|3 z@bD=Gzde09S@#8*SMO{&`#@K^pgj~kDy_S>u6b0`ZmMrz?}q9lU%JwyFn4cjtwXG` zv(ZA?ks0v)_hVljKBFpAd;V09SavdHR1qJ;6XhtZd&k$!V$SM&Vz4%B-Q|1Ro+K!K z9mHz&@@8o3M2bLKYJtw9m6Eqh)t`AIL*6M*gLnMUWRmK&E$*f(=?@nj4w}Hp6D4Kv z9Y)&Ww4ta{9R&+k?W4>_mL~AswV|mm@X+-L8^UyZGE0_IL#9kwob30o5=IiYJSXY~ z2$gHNwS5(KGEIA)S=$D8 z?{l~BOzX_N!LRt3&H?}!B3J9}38+opvDGokHWVbgyveV>If%HO%e5plTy%eSExULa zCbc9jq=4dVe;#X)Tvl|l##=)A<)e4_QQ3gK@wDe&$2ayox^GVnG8i#+YRNh#y(Pyt z`>j}fLX>B95h*yPwfe&0%$^*IwEMes8?}T$q(47hZj(FL$9=O6CjbCxVxIeD8;Don)%k9@xp|(pqjlIK6|ew|9;o_wHKo+Eu2ENBJ`Xe zZdL1rYM1F3;blD1Yfu{!g}hh9^@M{gjO?&2`jtoNC)*~!RbWm_@#@`kd_WB??`H>P zqcTqPJ~iz(3^CJ|?an#L32Cp)0~~vp0N?Lj;Hl^S>Rpgvf40Ysa*pCX!lX;y1dM}+ zWwT-O`7iOe#MeZ5mgBOawEBKUmb#Vg;r8MAKJ2A0ZP%wCa(0)&1N5p4lAMwZ&NRa9 ztJ`D4{eGqh38y(Fjk|ql6j6~bi){G?r*K1!4R^CNsD0Hb+bCyu`Jzl+*sC_ZMx-YU z&4iCdCGP^hjG$;08s9?iD4Co$g1JL}C{GK->u;ddg+EjJ~3;aHT0+ z`nv{Qz5(!17i+(3NmLB!L-x76iP=LR;D61-`BA};S4*eS&s8P@9uIspe!Q!rMob^% zh?p%ny0x)LLFE_HvNMYLXh@ygEprEE%$yP|RK%oz@V-^CZtLnE?l02@W)&R2JqzD( zyW6y!zh~T?a~`S0?`kO0lK{F55lZv6%t`5GK@FJm1h@5CX1QXSs;xoBZX|yf8NFD2 z%DbU%CL}bh4vyg{erxo%-_LrV5f3Za5LZKA(~d!Ez;@wk*hl5hYCt_2kuAlo;R>5N zR(c_Z#hX|!w}{(BMxyl)ZS~(e#vW@6KNzFeUme|H39jJ*5!~s#=1d1&!ykA8(AKz*=?>?ee;EV2HadN z8S!>qhU|)ZQD)BdbBW#L|`9AE}$ zabFOH;<~vS^ZAz4{Pga|!k127DLUqMjc+U2dgLXderm-J;+vDa!NJOp4L*A8d^p+N z1!Iu~Il>9!p|mvBpCdO0PbU2ik^JF0A;qlj-$pf}h0W)`nTYL5LNuRb>sa*kbe#gp z(394k&rT$=k+8X<4B*tkxhZmc?o4L}y%ZnWpTTC{p7&?DR`eD~#oTb*G-&p|n{;&8 zaseceA#yZ+fa@Fd()X?l@_1OZB*?@2^wraw_q{dz_H=r}D%^M-zNGTp;l5?^$;e9d zX?*o{6g>(#nV0}viVs&)EB4x>iEOwB!3R<#{uH~+ahsfuT~x(Ens(P&G;lP+HaImn&+eCf+)wvaiSr2j+eK$4aW`fe!U;HGUGh_xyFK8xc@U|JR{i@ zWi!^J?U=-%D2#a#WIAxS`tCvmt#F-B}B5A5ffv$eaX-FGG|Aiw&1{qpY zI7$vJI5x63*Pgw)slW!BOz4oQbOh-GD_tkXO|gyoUi8*WgWKBz3*;0*4+XLW@=jdJ zAeX*R6Z0>M ztr&a~Edup=irI`3qV8=q%Q!Lm*n%V+I1x>Gfkk9!+3>D8GZ0a(yL6EV-Q?OX?)s8^ z{o`~=ROfI-pj2-v1BKs`lwNZ5y(kcylS(eqt}5iqtgexM8jt?4b+B;jz}Tkh#%q)W zy47J|&o$dWJn3e)iim-fUy>_`r_y=Uf$M2$FUwTU^S7A9f|OgHO!|_B7(2qtY!Ur) zr5tX8Ewz0$>yiRMz>v;rXOZX zJ;|zU5DiLm1>NK+bk{*%FCX7Mr2ralX(%m@32F}1nVPj4T~FoT!z9YJYx&Zn2h2>0 zjP5lD#Szju7=p)x#aG=J2qwDOs{}V&#Yn87xjmhmQ|T3(_H+O11M>mx9yr5k&=@^H z^g>SNzRGb!BkW~lm?jx54cFXtO(IdRU0f%t{c6~dnM|FlZ4^LMx{j|BB~jgJ&CG61 z*rltBd}+qa<;lcN;XZlC#qJaE;qw2wv|jmGG#DfD2vT&yHMf^p(9bhRwEO|k;i16? z{_#r7s)#n2M!kIK5NH(CX3uM~J3SCHE3nY*&_5BAUeR-qFFJn>;?Y0id?XhRo*iOv zGis~21Sq5;difUY^(=VH$v74FP(+C9D3z}7!RcrK zQG@*ci?~VRtKJzmAC$}#yJVg1{(`Gy&{XYf4~1!Pph7FdGn@3Dj(j6Qllw^pIn>EQ?+gkNj8d-WAKp__`rlr-KzlS zPmai#Y$g4#J#{wvjq9TTC;T|5stbvD2%p zHPFgee}DMu>$AI!wBqlVZ(fb-N@2L=SItyt`$rX!UUhu*i@!_H>b0qxA)mVj_LGdn zZEbR0Lw?S&6)e*yYWwg;+75n|G{4d(h|zC+xKtcfnz6b-<$&@jcmE`%P4LeYO@x4k ztZ;yXISJtV=Zkzs^~5iNMH=%BK#>h)NUdpZbjY`~Nq$-W$L+FUEYifvcaq}ULv)ui z@6%R%O?uFJ%J{99tI0ie>XIE|_kTNX)Z13mL04y0OY-hP_!7;Z!Os0_ zr+sT=)Nv#aE+Sldu|w}yiT7S)m*e$sjJ7%e+!Rb$kz_*`W;qenQ~)! zIOb2XZ!B+|V*Sz`mkrS4RpQVhTkfIXq$B*bqkbs-tS{(lbAu*Lg-A`_hT=f3cM35U z1PPiH?GB>2S9Xyx@-I5Dxbt4y`#L}Y6p|X+_0OaKoOQD5(*V0Cb@`f*Ty0>Bd)Vru z)ymseeD58i62w;r!43C5YpB@VZ5Vplelv?4?(XKaEQq1yT0!dVeI}@;PD$mh%NZSX z3;#Tn%`)<8UA@3f=mqPI%LIrZvRAu8OzY87Z)lAZ66YuhSau)dVRpV#a-VgZ5ZX1zg^7}krYdrOFY4l!xrF+xF?ecgq4 Date: Tue, 17 Oct 2023 13:45:04 -0700 Subject: [PATCH 52/53] Update .gitignore --- .gitignore | 1 + 1 file changed, 1 insertion(+) diff --git a/.gitignore b/.gitignore index 7fb1293083..305e73e838 100644 --- a/.gitignore +++ b/.gitignore @@ -39,3 +39,4 @@ rabbitmq-server.download.tar.xz /docs/source/volttron_api/ *ecobee_*.json .env* +dist/ From 2711dab76972e9c70ffefc975f52033f3fb7d2d7 Mon Sep 17 00:00:00 2001 From: Craig <3979063+craig8@users.noreply.github.com> Date: Tue, 17 Oct 2023 21:59:12 +0000 Subject: [PATCH 53/53] Move AGENT_DEMO to AGENTDEMO --- services/core/IEEE_2030_5/{AGENT_DEMO.md => AGENTDEMO.md} | 0 services/core/IEEE_2030_5/README.md | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) rename services/core/IEEE_2030_5/{AGENT_DEMO.md => AGENTDEMO.md} (100%) diff --git a/services/core/IEEE_2030_5/AGENT_DEMO.md b/services/core/IEEE_2030_5/AGENTDEMO.md similarity index 100% rename from services/core/IEEE_2030_5/AGENT_DEMO.md rename to services/core/IEEE_2030_5/AGENTDEMO.md diff --git a/services/core/IEEE_2030_5/README.md b/services/core/IEEE_2030_5/README.md index e516f98c00..49a752f42f 100644 --- a/services/core/IEEE_2030_5/README.md +++ b/services/core/IEEE_2030_5/README.md @@ -19,7 +19,7 @@ The following diagram illistrates the data flow for the 2030.5 agent from the Pl Agent->>PlatformDriverAgent: Publishes Event Controls ``` -To see this process in action, please try out the [Agent Demo](AGENT_DEMO.md). +To see this process in action, please try out the [Agent Demo](AGENTDEMO.md). ## Agent Config File