Python bindings to interact with all XBOS services.
Install using pip. Currently requires Python 2.
pip install xbos
Almost all interactions in XBOS begin with a BOSSWAVE client:
from xbos import get_client
# uses $BW2_AGENT, $BW2_DEFAULT_ENTITY by default
client = get_client()
client = get_client(agent="172.17.0.1:28589",entity="/home/oski/myentity.ent")
xbos.devices
contains bindings for interacting with the following devices:
- Thermostat
- Plug
- Light
The bindings respect the standard XBOS interfaces
xbos.services
contains bindings for interacting with the following services:
Below are a set of simple examples
from xbos import get_client
from xbos.devices.thermostat import Thermostat
# get a bosswave client
c = get_client() # defaults to $BW2_AGENT, $BW2_DEFAULT_ENTITY
# instantiate a thermostat
tstat = Thermostat(c, "410testbed/devices/venstar/s.venstar/420lab/i.xbos.thermostat")
# print cached state; blocks until we get first report.
# maintains subscription in background.
print tstat.heating_setpoint
# batch actuation
state = {
"heating_setpoint": 72,
"cooling_setpoint": 76
}
tstat.write(state)
# or individually
tstat.set_heating_setpoint(72)
from xbos import get_client
from xbos.services.pundat import DataClient, timestamp, make_dataframe
# get a bosswave client
c = get_client() # defaults to $BW2_AGENT, $BW2_DEFAULT_ENTITY
dc = DataClient(c,archivers=["ucberkeley"])
uuids = dc.uuids('name = "air_temp" and Deployment = "CIEE"')
# get timestamps
start = timestamp('6/25/2017')
end = timestamp('6/28/2017')
# get 1-hour window data for the first uuid
data = dc.window_uuids(uuids[0], start, end, '1h')
# get a dataframe from the results, keyed by the UUID
dfs = make_dataframe(data)
print dfs[uuids[0]].describe()
from xbos.services.hod import HodClientHTTP
hc = HodClientHTTP("http://ciee.cal-sdb.org")
q = """
SELECT ?x ?uri WHERE {
?x rdf:type/rdfs:subClassOf* brick:Temperature_Sensor .
?x bf:uri ?uri .
};
"""
print hc.do_query(q)
#[{u'?uri': u'ciee/sensors/s.hamilton/00126d0700000060/i.temperature/signal/operative',
# u'?x': u'hamilton_0060_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000005e/i.temperature/signal/operative',
# u'?x': u'hamilton_005e_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000005d/i.temperature/signal/operative',
# u'?x': u'hamilton_005d_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000005c/i.temperature/signal/operative',
# u'?x': u'hamilton_005c_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000005b/i.temperature/signal/operative',
# u'?x': u'hamilton_005b_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000005a/i.temperature/signal/operative',
# u'?x': u'hamilton_005a_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000002e/i.temperature/signal/operative',
# u'?x': u'hamilton_002e_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000002c/i.temperature/signal/operative',
# u'?x': u'hamilton_002c_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000002b/i.temperature/signal/operative',
# u'?x': u'hamilton_002b_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d070000002a/i.temperature/signal/operative',
# u'?x': u'hamilton_002a_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d0700000029/i.temperature/signal/operative',
# u'?x': u'hamilton_0029_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d0700000028/i.temperature/signal/operative',
# u'?x': u'hamilton_0028_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d0700000027/i.temperature/signal/operative',
# u'?x': u'hamilton_0027_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d0700000025/i.temperature/signal/operative',
# u'?x': u'hamilton_0025_air_temp'},
#{u'?uri': u'ciee/sensors/s.hamilton/00126d0700000022/i.temperature/signal/operative',
# u'?x': u'hamilton_0022_air_temp'}]
from xbos import get_client
from xbos.services.pundat import DataClient, timestamp, make_dataframe, merge_dfs
from xbos.services.hod import HodClientHTTP
from xbos.devices.thermostat import Thermostat
# get a bosswave client
c = get_client() # defaults to $BW2_AGENT, $BW2_DEFAULT_ENTITY
# get a HodDB client
hod = HodClientHTTP("http://ciee.cal-sdb.org")
# get an archiver client
archiver = DataClient(c,archivers=["ucberkeley"])
# query for CIEE occupancy sensors
q = """
SELECT ?sensor ?uuid WHERE {
?sensor rdf:type/rdfs:subClassOf* brick:Occupancy_Sensor .
?sensor bf:uuid ?uuid .
};
"""
res = hod.do_query(q)
uuids = [r["?uuid"] for r in res]
sensors = [r["?sensor"] for r in res]
lookup = dict(zip(uuids, sensors))
for uuid, sensorname in lookup.items():
print uuid, '=>', sensorname
start = '"2017-08-21 00:00:00 PST"'
end = '"2017-07-20 00:00:00 PST"'
# get 15min interval data
dfs = make_dataframe(archiver.window_uuids(uuids, end, start, '15min', timeout=120))
# resamples the merged dataframes to 10min mean buckets
merged = merge_dfs(dfs, resample='10T', do_mean=True)
merged.to_csv("data.csv")
from xbos import get_client
from xbos.services.pundat import DataClient, timestamp, make_dataframe
from xbos.services.hod import HodClientHTTP
from xbos.devices.thermostat import Thermostat
# get a bosswave client
c = get_client() # defaults to $BW2_AGENT, $BW2_DEFAULT_ENTITY
# get a HodDB client
hc = HodClientHTTP("http://ciee.cal-sdb.org")
# query for CIEE thermostats
q = """
SELECT ?tstat ?uri WHERE {
?tstat rdf:type brick:Thermostat .
?tstat bf:uri ?uri .
};
"""
ciee_tstats = hc.do_query(q)
# instantiate some classes
tstats = {}
for info in ciee_tstats:
tstats[info['?tstat']] = Thermostat(c, info['?uri'])
# print some settings
for name, tstat in tstats.items():
print name, 'has heat/cool', tstat.heating_setpoint, tstat.cooling_setpoint