Skip to content

notebooks

Jupyter Notebooks

This directory contains Jupyter Notebooks used to compute and visualize data generated with the help of this package.

This directory includes the following notebooks:

panel and bokeh subdirectories

The bokeh/ subdirectory contains some Python scripts that create various interactive plots to visualize annotation results. Plots are created using the Bokeh1 library.

The panel/ subdirectory contains Jupyter notebooks (*.ipynb) and Python scripts (*.py), which use Panel2 (member of the HoloViz ecosystem) to explore various way of interactively visualizing and analysing annotation results; though some are there just to explore Panel features. See its panel/README.md.

experiments subdirectory

The **experiments/ subdirectory contains Jupyter notebooks that are part of comparing automatic line annotations from this tool (PatchScope), with different datasets that include manual line annotations.

Running notebooks

If needed, install required packages with

python -m pip install --upgrade -r notebooks/requirements.txt
when in the top directory of the project (or use simply requirements.txt when in notebooks/ directory, that is in this directory).

It is recommended to use virtual environment, see the information in the main README.md file: Virtual environment.

Once installed, launch JupyterLab with:

jupyter lab

Development

You can install recommended packages with

python -m pip install --upgrade -r notebooks/requirements-dev.txt
when in the top directory of the project (or use simply requirements-dev.txt when in notebooks/ directory, that is in this directory).

The .gitignore file, .gitattributes file, and requirements.txt and requirements-dev.txt files are local to this directory, and are about Jupyter Notebooks that are here.

You can use nbdime for diffing and merging of Jupyter notebooks. The .gitattribute file is committed to the repository, but it needs Git config to work. You can add it with the following command (after installing nbdime):

nbdime config-git --enable
See Git integration section in the nbdime documentation.

Try to commit notebooks in a well-defined and consistent state, for example by restarting the kernel and re-running all cells before committing.

Dashboards

This directory includes various web dashboards that demonstrate how one can use this project.

All web applications in this directory use the HoloViz Panel framework.

Technology demos

Exploratory code

Diffannotator web dashboards

Development

Technology alternatives

Web dashboard libraries in Python

TODO

Common plotting interfaces

TODO

Interactive plotting libraries in Python

TODO


  1. Bokeh is an interactive visualization library for modern web browsers. 

  2. Panel is an open-source Python library designed to streamline the development of robust tools, dashboards, and complex applications entirely within Python. 

  3. Piotr Przymus, Mikołaj Fejzer, Jakub Narębski, Radosław Woźniak, Łukasz Halada, Aleksander Kazecki, Mykhailo Molchanov and Krzysztof Stencel "HaPy-Bug – Human Annotated Python Bug Resolution Dataset" (2024) 

  4. Steffen Herbold et al. "A fine-grained data set and analysis of tangling in bug fixing commits" https://doi.org/10.1007/s10664-021-10083-5