Skip to content

A low-latency real-time sonification pipeline for joint action research.

License

Notifications You must be signed in to change notification settings

zeyus/QTM_Bela_Sonification

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

QTM Low-latency Sonification

This project uses the Bela hardware device to sonify motion capture data from Qualisys Track Manager (QTM).

Contents

Harmony in Motion: Real-time Sonification Strategies for Joint Action Research

Cognitive Science Bachelor's Project

The thesis was written around the investigation of the effect of low-latency sonification on the synchroniciy of joint action tasks. The project was supervised by Anna Zamm (PhD, Assistant Professor, Aarhus University).

Abstract

Joint actions involving high levels of coordination often require individuals to represent and monitor their own actions as well as their partner’s actions in parallel, but current research is unclear on how this occurs under various circumstances. Using different movement sonification mapping strategies, we enhance attention towards either individual or joint outcomes of actions, and separate them into experimental conditions. Five subject pairs participated in a pilot experiment investigating whether synchrony is optimized when focusing on self-other or joint outcome representations. In the experiment, blindfolded subjects moved sleds along a track, while attempting to remain as synchronous as possible. The sled movements were captured with a motion capture system which sent 3D positional data to a low-latency sonification pipeline to implement the mapping strategies. The results showed that there were significant differences between the two sonification strategies. Notably, the No Sonification control condition consistently outperformed both sonification conditions, possibly due to environmental auditory localization that may have been masked during the sonification conditions. This pilot experiment successfully implemented a novel paradigm for joint action research that can be used in further studies in the field.

The final thesis can be found in this repository in the docs directory in the following formats:

The R Markdown file can be used to rerun the analyses and generate the LaTeX and PDF files.

Project Structure

The project is structured as follows:

  • data: Contains the anonymized raw data from the experiment
  • docs: Contains the final thesis and other documentation
  • docs/templates: Contains the latex template used for the thesis as well as the citation style
  • res: Contains the resources for the project (audio files, images, etc.)
  • scripts: Scripts used to prepare the data for analysis
  • src: Contains the source code for the project
  • src/qsdk: Contains the source code for the Qualisys SDK
  • src/res: Soundfiles used in auditory stimuli generation
  • src/utils: Various functions sort-of organised into what they do (sound, spatial, etc)
  • src/utils/config.h: Pretty much anything you would want to change is in here, the experiment, label, and sonification options
  • src/utils/globals.h: Global variables and constants. I think defining things here (especially instead of in the main render loop) can help bela performance to avoid mallocs?
  • src/utils/latency_check.h: If this file is included, you can get the output of a round-trip QTM API call, saved in /var/log/qtm_latency.log on the Bela.
  • src/render.cpp: The main Bela sonification application
  • src/settings.json: The Bela settings file that is used by default

Usage

Sonification

  1. Connect the Bela to the computer where Qualisys Track Manager (or with network access) will run via USB.
  2. Clone / download the repository to your PC important note: if you would like to access the data in the data directory, you will need to install Git LFS and run git lfs pull after cloning.
    git clone https://github.com/zeyus/QTM_Bela_Sonification.git
    # optionally, with git lfs
    git lfs pull
  3. Start Qualisys Track Manager, open a project with at least 2 labelled markers
  4. Edit src/render.cpp to change the marker names to match the ones in your project and the IP address of the computer running QTM
  5. TBD: sonification scheme
  6. Copy the src directory to the Bela project directory
    scp -r QTM_Bela_Sonification/src [email protected]:/root/Bela/projects/QTM_Bela_Sonification
  7. Start the QTM recording / playback with real-time output enabled
  8. Connect to the Bela board via SSH and run the project
    ssh [email protected]
    /root/Bela/scripts/run_project.sh QTM_Bela_Sonification -c "--use-analog no --use-digital no --period 32 --high-performance-mode --stop-button-pin=-1 --disable-led"

Important note: When compiling, you must ensure that the compiler is in C++14 mode by using CPPFLAGS=-std=c++14

Data

Subject Information

Only relevant if you have collected your own data, using the same setup as the thesis.

Will be read from the data/raw directory, and the subject information will be used to generate the plots and condition information.

It should be called subject_information.tsv and have the following required columns:

  • id [string]: The subject ID
  • trial_order [n|t|y]: n = no sonification, t = task based, y = sync based
  • partner [string]: The partner ID
  • door_or_window [d|w]: The door or window side (room specific, a way of distinguishing which of the two tracks a subject used)
  • handedness [l|r|a|NA]: The handedness of the subject (left, right, ambidextrous, or no answer)
  • age [range n|NA]: The age range bracket the subject reported, or no answer
  • tone_deaf [y|n|NA]: Whether the subject reported being tone deaf, or no answer
  • gender [string|NA]: The gender reported by the subject, or no answer
  • years_formal_music_training [float|NA]: The number of years of formal music training reported by the subject, or no answer
  • rating1
  • rating2
  • rating3
  • rating4

QTM Data Format

The raw data are expected to be 3D data exported from QTM as a TSV including the events/labels. The files should be placed in the data/raw directory and should be named as follows:

qtm_capture_{subjecta}_{subjectb}{_suffix}.tsv

Where:

  • subjecta is one of the subject ids (e.g. azsw) (can be anything valid in a filename but will stop at the first _ or .)
  • subjectb is the other subject id (e.g. wsza) (can be anything valid in a filename but will stop at the first _ or .)
  • _suffix is an optional suffix (e.g. _test) (can be anything valid in a filename but will stop at the file extension .tsv)

Example (using above):

qtm_capture_azsw_wsza_test.tsv

Data Preparation

The data preparation can be replicated by running the R scripts in the scripts directory.

Open Source Libraries

Included

Used