/pd_walking

Detect walking in the PD population

Primary LanguagePythonOtherNOASSERTION

Detecting walking in the Parkinson's disease population

About this project

Human activity recogntion (HAR) models are useful for monitoring the activity of individuals, while wearing smart watches. One popular model for doing so in the OxWearables group is the Biobank Accelerometer Analysis tool, found here.

In the Walmsley iteration of the implementation of this tool, the raw accelerometery is predicted into 4 possible labels, sleep, sedentary, light and MVPA, using a Balanced Random Forest model, with hidden markov model (HMM) smoothing, applied to signal related features extracted from 30 second windows of acclerometery. The balanced random forest, and HMM are trained using a smaller, labelled dataset, Capture-24, taken from monitoring 151 healthy participants for 1 day. This approach to the development of HMM models has shown decent performance in identifying windows of high and low activity, capable of further epidemiology analysis.

Building on this work, OxWearables developed the stepcount tool, found here. This package took a similar approach of training using a smaller dataset to be applied on the large UK Biobank population. In this case, the stepcount model first uses with a balanced random forest, or self supervised Resnet 18 model with HMM smoothing, to detect periods of likely walking, and then uses a peak counter to count steps. This model is trained on the OxWalk dataset, collected from 39 healthy participants monitored for approximately 1 hour.

The identification of periods of activity/walking can be very useful for the identification of health conditions of individuals. Particiularly focused on walking, if we are able to reliably identify when participants are walking, this can give incite into properties like:

  • Walking incidence in the average day
  • Length of sustained bouts of walking
  • Intensity/speed of walking

For Parkinson's disease, various walking related properties can be strong indicators for disease condition. The early monitoring of walking properties can therefore give insight into properties such as:

  • The progression of the disease from early to late stages
  • The symptomatic walking behaviour of those with the disease
  • The efficacy of treatments addressing the walking behaviours of those with the disease

However, as we know that PD alters motor conditions of participants, therefore we cannot be certain that a walking model trained on only the healthy population, can seemlessly applied to the PD population and generate reliable predictions. Therefore this repository has been developed to assess the performance of the walking classifiers the PD population, and attempt to generate new classifiers capable of improving this performance.

To do so, we must use a walking labelled dataset of wrist worn accelerometery, monitoring a PD population. This is the MJFF Levodopa Response dataset, that monitored 28 PD participants over 4 days. For 2 days in clinic, 1 of which was off all medication, and 2 days at home, a battery of tasks were given to participants to perform, some of which included walking. It should be noted that as this dataset was collected based on a battery of tasks rather than in free living, HAR models will be evaluated without the HMM, that is intended to learn natural patterns in transitions between activities in free living.

Getting started

This repo can either be run from command line, or using jupyter notebooks. Before this however, we must ensure that all relevant packages are installed:

# create conda environment
$ conda env create -f env.yml
# activate environment
$ conda activate pd_walk 
# install pytorch packages
$ pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu117

This repo makes use of a .env file to store private usernames and keys to access data using synapse. In the same repository as this file, create a .env file containing:

SYNAPSE_USERNAME = "<user_name>"
SYNAPSE_APIKEY = "<api_key>"

replacing <user_name> and <api_key> with appropriate text from your synapse account.

Note: Running the full pipeline of this repo requires access to the MJFF-LR dataset. Instructions for getting access to this dataset can be found at https://www.synapse.org/#!Synapse:syn20681023/wiki/594679.

Running anaylsis

First we must prepare the datasets.

$ python prepare.py --overwrite

Then, we optimise the parameters of the model, to produce best performance. Note that this step takes some time, and can be skipped.

# Optimise random forest model
$ python rf_model.py
# Optimise Resnet18 model
$ python ssl_model.py

We then evaluate the models using cross validation.

# Evaluate train OxWalk, test OxWalk
$ python evaluate.py --train_source oxwalk --test_source oxwalk
# Evaluate train OxWalk, test Ldopa (no cross validation)
$ python evaluate.py --train_source oxwalk --test_source ldopa --cv 0
# Evaluate train Ldopa, test OxWalk (no cross validation)
$ python evaluate.py --train_source ldopa --test_source oxwalk --cv 0
# Evaluate train Ldopa, test Ldopa
$ python evaluate.py --train_source ldopa --test_source ldopa
# Evaluate train both, test both
$ python evaluate.py

Finally, we wish to visualise the association between model performance and UPDRS

$ python visualise.py

Licence

See LICENCE.md.

Acknowledgements

We would like to thank all our code contributors and research participants for their help in making this work possible.