Skip to main content

Activity detection algorithm compatible with the UK Biobank Accelerometer Dataset

Project description

ActiNet

GitHub all releases DOI

A tool to extract meaningful health information from large accelerometer datasets. The software generates time-series and summary metrics useful for answering key questions such as how much time is spent in sleep, sedentary behaviour, or doing physical activity.

Install

Minimum requirements: Python>=3.9, Java 8 (1.8)

The following instructions make use of Anaconda to meet the minimum requirements:

  1. Download & install Miniconda (light-weight version of Anaconda).

  2. (Windows) Once installed, launch the Anaconda Prompt.

  3. Create a virtual environment:

    conda create -n actinet python=3.9 openjdk pip
    

    This creates a virtual environment called actinet with Python version 3.9, OpenJDK, and Pip.

  4. Activate the environment:

    conda activate actinet
    

    You should now see (actinet) written in front of your prompt.

  5. Install actinet:

    pip install actinet
    

You are all set! The next time that you want to use actinet, open the Anaconda Prompt and activate the environment (step 4). If you see (actinet) in front of your prompt, you are ready to go!

Usage

# Process an AX3 file
$ actinet sample.cwa.gz

# Or an ActiGraph file
$ actinet sample.gt3x

# Or a GENEActiv file
$ actinet sample.bin

# Or a CSV file (see data format below)
$ actinet sample.csv

# Specify column names for CSV (default: time,x,y,z)
$ actinet sample.csv --csv-txyz 'timestamp,accel_x,accel_y,accel_z'

# Or specify columns by index (0-indexed)
$ actinet sample.csv --csv-txyz-idxs '0,1,2,3'

See the Usage page for further uses of the tool.

Troubleshooting

Some systems may face issues with Java when running the script. If this is your case, try fixing OpenJDK to version 8:

conda create -n actinet openjdk=8

Output files

By default, output files will be stored in a folder named after the input file, outputs/{filename}/, created in the current working directory. You can change the output path with the -o flag:

$ actinet sample.cwa -o /path/to/some/folder/

<Output summary written to: /path/to/some/folder/sample-outputSummary.json>
<Time series output written to: /path/to/some/folder/sample-timeSeries.csv.gz>

The following output files are created:

  • Info.json Summary info, as shown above.
  • timeSeries.csv Raw time-series of activity levels

See Data Dictionary for the list of output variables.

Plotting activity profiles

To plot the activity profiles, you can use the -p flag:

$ actinet sample.cwa -p
<Output plot written to: data/sample-timeSeries-plot.png>

Crude vs. Adjusted Estimates

Adjusted estimates are provided that account for missing data. Missing values in the time-series are imputed with the mean of the same timepoint of other available days. For adjusted totals and daily statistics, 24h multiples are needed and will be imputed if necessary. Estimates will be NaN where data is still missing after imputation.

Processing multiple files

Windows

To process multiple files you can create a text file in Notepad which includes one line for each file you wish to process, as shown below for file1.cwa, file2.cwa, and file2.cwa.

Example text file commands.txt:

actinet file1.cwa &
actinet file2.cwa &
actinet file3.cwa 
:END

Once this file is created, run cmd < commands.txt from the terminal.

Linux

Create a file command.sh with:

actinet file1.cwa
actinet file2.cwa
actinet file3.cwa

Then, run bash command.sh from the terminal.

Collating outputs

A utility script is provided to collate outputs from multiple runs:

actinet-collate-outputs outputs/

This will collate all *-Info.json files found in outputs/ and generate a CSV file.

Citing our work

When using this tool, please consider citing the works listed in CITATION.md.

Licence

See LICENSE.md.

Acknowledgements

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

Project details


Download files

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

Source Distribution

actinet-0.7.0.tar.gz (69.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

actinet-0.7.0-py3-none-any.whl (53.0 kB view details)

Uploaded Python 3

File details

Details for the file actinet-0.7.0.tar.gz.

File metadata

  • Download URL: actinet-0.7.0.tar.gz
  • Upload date:
  • Size: 69.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for actinet-0.7.0.tar.gz
Algorithm Hash digest
SHA256 19b4bbe3050504058c94bf810b05fa9a737eea6685f62305f5e7d6b04f52c344
MD5 ada4d38c11bb15dc565dcade75db3193
BLAKE2b-256 ba141269c2c627290bbcf6281af77ef1ca05e126b2c56edee78abdaf7258b438

See more details on using hashes here.

File details

Details for the file actinet-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: actinet-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 53.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for actinet-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e24e06f5eb1904d8ab62d3ae1d13c08a242de8401b16f942ef210185033b3cb1
MD5 e582d4b1f35b95b3d861ee27a04b47fd
BLAKE2b-256 b4fd0f639e5a18ca1e24cb90f6929a89fed3cc0b5701235d596a5a1b0b545ba0

See more details on using hashes here.

Supported by

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