Spotlighting the Participant: An Interactive Bokeh Visualization App for Soundscape Data Exploration
Author: Fabian Rosenthal
This repo creates an interactive data visualization app using bokeh for python. It builds on the study dataset by Versümer, Steffens and Rosenthal (2023): See researchgate and Zenodo. The app make the large crowdsourced dataset accessible and explorable from the perspective of the participants. It allows to explore the subjective ratings in a more intuitive way than with traditional statistical methods and get a better understanding of the diversity of the data.
This contribution was developed as a project for the Data Visualization course with Konrad Förstner at University of Applied Sciences Cologne. See the technical report at researchgate.
In this README you learn how to run the app locally using a bokeh server from the command line.
This program was developed and tested on Windows 10 with Python 3.11.3 and bokeh 3.1.1. Other version might as well work but are not guaranteed to do so.
First, clone the repo to your local machine. Then open a new command line and navigate to the directory e.g. using cd path\to\this\repository
.
Make sure to install the requirements from the requirements.txt
file for example using pip install -r path\to\requirements.txt
from the command line.
To run this app locally, you need to start a bokeh server from the command line.
If you are using a virtual environment, make sure to activate it before running the server.
For example, if you are using conda, you can activate the environment using conda activate name_of_the_environment
.
Now we're ready to start the bokeh server by running the following command:
bokeh serve --show app.py
Your command line should output something like this
`Starting Bokeh server version 3.1.1 (running on Tornado 6.2)
2023-07-02 06:07:48,262 User authentication hooks NOT provided (default user enabled)
2023-07-02 06:07:48,278 Bokeh app running at: http://localhost:5006/main
2023-07-02 06:07:48,278 Starting Bokeh server with process id: 17576
2023-07-02 06:07:52,951 WebSocket connection opened
2023-07-02 06:07:52,967 ServerConnection created
and your browser should now open automatically. If it doesn't, you can simply open a new browser window and go to localhost:5006/app
.
When you first run the app, it loads the dataset from Zenodo and makes preprocessing steps. This may take a second.
To make it start a bit faster the next time, the preprocessed data is pickled and saved in the data
folder.
If you want to load the data from scratch, delete the data/data.pickle
file.
The slider in the top right lets you select the participant. The plots and values will update on release of the slider automatically. We will have a look at the use of the buttons later.selecting the participant you are able to explore
- person factors,
- an activity profile,
- the typical soundscape composition,
- personality traits,
- ratings of the soundscape dimensions
- loudness ratings
- and situational ratings for each participant.
Have fun exploring the diverse participantsy and their subjective ratings in the dataset interactively!
You have the possibility to mark people or data points that are useful for you. A logfile is created in the background for every session. It is in the /logs
folder. It will include every slider change, so you have a history of what you looked at. Also you can mark special participants in the log file by using the button Log Participant
. And when data points are currently selected you can also log the keys corresponding to the data in the original table by using the Log Selection
button. For the button, outputs we also create a .csv
file, so you can easily access these logged information and incorporate them in filtering processes working with the data.