A simple module for testing used at Bliq Photonics
Project description
BliqTools
Cross-platform Python tools to manipulate any type of images and data from Bliq microscopes (and general). Used by Bliq programmers internally and by the community. For now, fairly limited with only tools for unittesting and limited tools for nirvana files and folders, but the goal is to add more and more this project public.
Project objectives
- To collect often-used tools in a single package, easy to install.
- To make manipulation of images task-oriented by removing the boiler-plate, generic code.
- To let the community look at the code, and tailor it to their needs.
Installing
Python 3.12 is the version used for development, and setuptools have evolved away from setup.py
. The best method to install bliqtools
is pip
:
pip install bliqtools
or install from source:
cd bliqtools/ # In root directory of project prproject.toml
python3 -m pip install .
This will install with the current version of Python. You can then use it in scripts with:
from bliqtools.testing import MemoryMonitor, Progress, TimeIt, Debuggable
from bliqtools.nirvana import FilePath
from bliqtools.bigimage import BigImage
Tools for managing metadata in Nirvana filenames
A very simple extension to pathlib.Path
: an extension that will automatically extract all the metadata from the filename as described in Nirvana's software.
This metadata is then available using properties. See the unittests at the end of the nirvana.py
file.
Tools for very large images: BigImage
previews
A class called BigImage
is available to construct a very large image with small blocks. The class will manage any memory issues and will save to disk the data if needed. The main method is get_preview(factor)
that provides a scaled down version for display. The construction of this preview is very fast (less than a second for a 1 GB image from 17x17 data blocks of size 2048x2048).
Example usage
from bliqtools.bigimage import BigImage
img = BigImage()
for i in range(10):
for j in range(10):
small_block = np.random.randint(
0, 255, size=(2048, 2048), dtype=np.uint8
)
img.add_block(coords=(i * 2048, j * 2048), data=small_block)
preview = img.get_reduced_resolution_preview(factor=32)
plt.imshow(preview)
plt.show()
Tools for unittesting
In bliqtools.testing
, you will find these functions. You can also run the tests that are incorporated directly into the file by running it.
Progress
is a simple class used with contextlib that can provide reasonable feedback. The user provides total number of iterations and calls next() every iterations.
with Progress(self.total, description="Volume creation") as progress:
for i,j,k in self.index_list:
tile = self.tile(i,j,k)
volume[i-1,j-1,k-1,:,:] = tile
progress.next()
TimeIt
is a simple class to time a small section of code:
with TimeIt(f"Get layers (single)"):
stitcher.get_layers()
Debuggable
can be used as a parent class to get useful debugging functions, like _dump_internals() or to see what variables have changed between calls.
def test_base_stitcher_still_working(self):
stitcher = Stitcher(self.valid_root_dir, overlap=0.2, channel="Grayscale")
self.assertIsNotNone(stitcher)
# stitcher._save_state()
stitcher.array_from_tiff_dirs()
stitcher.make_z_stack()
stitcher._dump_internals()
will print:
-- begin test_base_stitcher_still_working (/Users/dccote/GitHub/Stitching/stitcher.py @line 276)
no_c_directory [<class 'str'> ] : /Users/dccote/Downloads/Test_maps
app_directory [<class 'NoneType'> ] : None
overlap [<class 'float'> ] : 0.2
dtype [<class 'numpy.dtypes.UInt8DType'> ] : uint8
channel [<class 'str'> ] : Grayscale
channels [<class 'NoneType'> ] : None
start_memory [<class 'int'> ] : 8276803584
save_name [<class 'NoneType'> ] : None
array_paths [<class 'list'> ] : []
sorted_files [<class 'list'> ] : len=945
use_zarr_arrays[<class 'bool'> ] : False
og_arrays [<class 'NoneType'> ] : None
z_stacks [<class 'numpy.ndarray'> ] : shape=(5, 740, 2780)
-- end test_base_stitcher_still_working (/Users/dccote/GitHub/Stitching/stitcher.py @line 276)
MemoryMonitor
can monitor memory in a separate thread during a long calculation to provide insight on performance. It will print out the time and memory available when done:
with MemoryMonitor(self.id()) as monitor:
stitcher = ArrayStitcher(volume_kji=volume)
with TimeIt(f"Save Zarr {volume_shape}"):
stitcher.save("/tmp/test-zarr.tif")
and can be used to provide a graph of memory available vs time:
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file bliqtools-1.1.7.tar.gz
.
File metadata
- Download URL: bliqtools-1.1.7.tar.gz
- Upload date:
- Size: 27.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7cd8fb8b7f308502908212474e1edbb4c4b84406338248c095928acffcfd6498 |
|
MD5 | 431702a36b5d497d797d2e684f283d84 |
|
BLAKE2b-256 | df6987f995b3c5f9fc867ef575e9fbcd43ef110f1d9287fdbaf96249057035a6 |
File details
Details for the file bliqtools-1.1.7-py3-none-any.whl
.
File metadata
- Download URL: bliqtools-1.1.7-py3-none-any.whl
- Upload date:
- Size: 30.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7c4437c1092c48e77c41a7d42e2e41e55e38e8b5f8883cc87875888266bc065e |
|
MD5 | 819b1e519011eb5d80e6c4dd3cc2b4fd |
|
BLAKE2b-256 | 7c140cbfa38cc16582f68d9df5445d18c355f3659ac869f2d827bfffd11ddefc |