Skip to main content

Computer vision routines suitable for nucleate pool boiling bubble analysis

Project description

boilercv

DOI All Contributors

Computer vision routines suitable for nucleate pool boiling bubble analysis. See the documentation for more detail, including a Binder for running code live. Click the "launch binder" badge above and you will be able to run the notebooks in docs/experiments in your browser with different parameters, and even create your own notebooks.

Example

Overlay of the external contours detected in one frame of a high-speed video. Represents output from the "fill" step of the data process.

Bubbles highlighted with different colors

Overview

The data process graph shows the data process, and allows for individual steps in the process to be defined indpendently as Python scripts, Jupyter notebooks, or even in other languages like Matlab. The process is defined in dvc.yaml as as series of "stages". Each stage has dependencies and outputs. This structure allows the data process graph to be constructed, directly from the dvc.yaml file. This separates the concerns of data management, process development, and pipeline orchestration. This project reflects the application of data science best practices to modern engineering wokflows.

Usage

If you would like to adopt this approach to processing your own data, you may clone this repository and begin swapping logic for your own, or use a similar architecture for your data processing. To run a working example with some actual data from this study, perform the following steps:

  1. Clone this repository and open it in your terminal or IDE (e.g. git clone https://github.com/softboiler/boilercv.git boilercv).
  2. Navigate to the clone directory in a terminal window (e.g. cd boilercv).
  3. Create a Python 3.10 virtual environment (e.g. py -3.11 -m venv .venv on Windows w/ Python 3.11 installed from python.org).
  4. Activate the virtual environment (e.g. .venv/scripts/activate on Windows).
  5. Run pip install --editable . to install boilercv package in an editable fashion. This step may take awhile.
  6. Delete the top-level data directory, then copy the cloud folder inside tests/data to the root directory. Rename it to data.
  7. Copy the local folder from tests/data to ~/.local where ~ is your user/home folder (e.g. C:/Users/<you>/.local on Windows). Rename it to boilercv.
  8. Run dvc repro to execute the data process up to that stage.

The data process should run the following stages: contours, fill, filled_preview, binarized_preview and gray_preview. You may inspect the actual code that runs during these stages in src/boilercv/stages, e.g. contours.py contains the logic for the contours stage. This example happens to use Python scripts, but you could define a stage in dvc.yaml that instead runs Matlab scripts, or any arbitrary action. This approach allows for the data process to be reliably reproduced over time, and for the process to be easily modified and extended in a collaborative effort.

There are other details of this process, such as the hosting of data in the data folder in a Google Cloud Bucket (alternatively it can be hosted on Google Drive), and more. This has to do with the need to store data (especially large datasets) outside of the repository, and access it in an authenticated fashion.

Project information

Contributors

Blake Naccarato
Blake Naccarato

💻
asennain
asennain

📖

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

boilercv-2024.1.3.tar.gz (37.0 kB view details)

Uploaded Source

Built Distribution

boilercv-2024.1.3-py3-none-any.whl (40.9 kB view details)

Uploaded Python 3

File details

Details for the file boilercv-2024.1.3.tar.gz.

File metadata

  • Download URL: boilercv-2024.1.3.tar.gz
  • Upload date:
  • Size: 37.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for boilercv-2024.1.3.tar.gz
Algorithm Hash digest
SHA256 708f960d17cce3b713d53f58d986418224ad200deafa52c65ee9f09bbd10a285
MD5 75e67dc0d7f95e49b33d21f88ddca0f7
BLAKE2b-256 18c337e99e90784eb21ad3950150f116b3473c79ea219fe9a808bed8c124cb2e

See more details on using hashes here.

File details

Details for the file boilercv-2024.1.3-py3-none-any.whl.

File metadata

  • Download URL: boilercv-2024.1.3-py3-none-any.whl
  • Upload date:
  • Size: 40.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for boilercv-2024.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f8439a0297652c95c693b1fb6ba72dfdb44bcdc083ddc824b3b91da92ff154b0
MD5 f683b3287135ed12f2f76f1cbfb2df25
BLAKE2b-256 8d95cf1333febf4d462f0e370531491ef374d440d02acbbbb94650a14c59cb68

See more details on using hashes here.

Supported by

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