Skip to main content

Sklearn flavored library containing numerous Activity of Daily Livings datasets, preprocessing methods, visualizations and models.

Project description

Activities of Daily Living - Machine Learning

Contains data preprocessing and visualization methods for ADL datasets.

PyPI version Download Stats Read the Docs (version) License

Activities of Daily living (ADLs) e.g cooking, working, sleeping and device readings are recorded by Smart Home inhabitants.

The objective is to predict inhabitants activities using the device readings. Pyadlml offers an easy way to fetch, visualize and preprocess common datasets. Furthermore a pipeline and TODO

!! Disclaimer !!

Package is still an alpha-version and in active development. Consequently, things are going to change and break and may not work at all. Nevertheless, feel free to take a look the package and use what is already finished.

Last Stable Release

$ pip install pyadlml

Latest Development Changes

$ git clone https://github.com/tcsvn/pyadlml
$ cd pyadlml
$ pip install .

Usage example

Simple

from pyadlml.dataset import fetch_amsterdam

# Fetch dataset
data = fetch_amsterdam()
df_activites = data['activities']
df_devices = data['devices']

# Plot an inhabitants activity density distribution over one day
from pyadlml.plot import plot_act_density

plot_act_density(df_activities).show()

# Create a smart home device state vector and discretize the event data in 20 second bins
from pyadlml.preprocessing import StateVectorEncoder, LabelMatcher

sve = StateVectorEncoder(encoding='raw', dt='20s')
raw = sve.fit_transform(df_devices)

# Label the datapoints with the corresponding activity
lbls = LabelMatcher().fit_transform(df_activities, raw)

X = raw.values
y = lbls.values

# Proceed with machine learning techniques you already know
from sklearn.tree import DecisionTreeClassifier

clf = DecisionTreeClassifier()
clf.fit(X, y)
...

Advanced

from pyadlml.dataset import fetch_amsterdam
from pyadlml.pipe import Pipeline
from pyadlml.preprocessing import IndexEncoder
from pyadlml.dataset import TorchDataset
from torch import DataLoader
from pyadlml.model import NeuralHawkesProcess


# Fetch dataset
data = fetch_amsterdam()
df_activites = data['activities']
df_devices = data['devices']


pipe = Pipeline([
  ('enc', IndexEncoder()),
  ('lbl', LabelMatcher()),
  ()
])

dataset = TorchDataset(df_activities, df_devics, pipe) 
train_loader = DataLoader(dataset)
model = NeuralHawkesprocess()

for (x, y) in train_loader:
  

...

_For more examples and how to use, please refer to the documentation.

Features

  • 12 Datasets
  • Importing data from Home Assistant or Activity Assistant
  • Many visualizations and statistics for devices, activities and their interaction
  • Preprocessing methods:
    • Device encoder (index, raw, changepoint, last_fired, ...)
    • Feature extraction (inter-event times, time2vec, ...)
  • Window
    • Temporal windows, Fuzzy Time window,
  • Feature extraction for event-times
  • Cross validation iterators adapted for ADLs
    • Leave-K-day out, temporal slicing
  • Model flavours
    • RNNs
    • Transformer
    • Temporal point processes
    • Temporal Graph NNs

Supported Datasets

  • Amsterdam [1]
  • Aras [2]
  • Casas Aruba (2011) [3]
  • Kasteren House A,B,C [5]
  • MITLab [6]
  • Tuebingen 2019 [7]
  • UCI Adl Binary [8]
  • Casas Milan (2009) [4]
  • Casas Cairo [4]
  • Casas Tokyo [4]
  • Chinokeeh [9]
  • Orange [TODO]

Examples, benchmarks and replications

The project includes a leaderboard of current models to the best of knowledge. In addition, a lot of models are compared on a cleaned version of all the available datasets. Furthermore, there is a useful list of references that is still growing on papers to read.

Contributing

  1. Fork it (https://github.com/tcsvn/pyadlml/fork)
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Commit your changes (git commit -am 'Add some fooBar')
  4. Push to the branch (git push origin feature/fooBar)
  5. Create a new Pull Request

Related projects

Support

Buy me a coffee

How to cite

If you are using pyadlml for publications consider citing the package

@software{pyadlml,
  author = {Christian Meier},
  title = {PyADLMl - Machine Learning library for Activities of Daily Living},    
  url = {https://github.com/tcsvn/pyadlml},
  version = {0.0.10-alpha},
  date = {2022-11-15}
}

Sources

Dataset

[1]: T.L.M. van Kasteren; A. K. Noulas; G. Englebienne and B.J.A. Kroese, Tenth International Conference on Ubiquitous Computing 2008
[2]: H. Alemdar, H. Ertan, O.D. Incel, C. Ersoy, ARAS Human Activity Datasets in Multiple Homes with Multiple Residents, Pervasive Health, Venice, May 2013.
[3,4]: WSU CASAS smart home project: D. Cook. Learning setting-generalized activity models for smart spaces. IEEE Intelligent Systems, 2011.
[5]: Transferring Knowledge of Activity Recognition across Sensor networks. Eighth International Conference on Pervasive Computing. Helsinki, Finland, 2010.
[6]: E. Munguia Tapia. Activity Recognition in the Home Setting Using Simple and Ubiquitous sensors. S.M Thesis
[7]: Activity Recognition in Smart Home Environments using Hidden Markov Models. Bachelor Thesis. Uni Tuebingen.
[8]: Ordonez, F.J.; de Toledo, P.; Sanchis, A. Activity Recognition Using Hybrid Generative/Discriminative Models on Home Environments Using Binary Sensors. Sensors 2013, 13, 5460-5477.
[9]: D. Cook and M. Schmitter-Edgecombe, Assessing the quality of activities in a smart environment. Methods of information in Medicine, 2009

Software

TODO add software used in TPPs

License

MIT © tcsvn

sdf

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyadlml-0.0.7.16a0.tar.gz (228.2 kB view hashes)

Uploaded Source

Built Distribution

pyadlml-0.0.7.16a0-py3-none-any.whl (287.2 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page