Skip to main content

A Python package for visualizing and analyzing Atomic Force Microscopy(AFM) and Piezoelectric Force Microscopy(PFM) experimental data, offering tools to process, visualize, and extract meaningful insights from AFM images and measurements.

Project description

AFM-tools is a Python package for loading, processing, and visualizing Atomic Force Microscopy (AFM) and Piezoelectric Force Microscopy (PFM) data.

Installation

Install from PyPI:

pip install AFM-tools

Most users should use this pip install. It includes all core AFM/PFM features. 3D utilities in afm_tools.drawing_3d require mayavi (VTK/Qt stack), which is recommended via Conda.

Install from source:

git clone https://github.com/yig319/AFM-tools.git
cd AFM-tools
pip install -e .

Clone On A New Desktop (Core Pip Environment)

From a fresh machine, this is the recommended setup for core AFM-tools usage:

git clone https://github.com/yig319/AFM-tools.git
cd AFM-tools
python -m venv .venv
source .venv/bin/activate
pip install -U pip
pip install -r requirements-dev.txt
pip install -e .

Optional: 3D environment (Mayavi via Conda)

If you need drawing_3d/Mayavi features:

conda env create -f environment-mayavi.yml
conda activate afm-tools-3d

This Conda environment installs mayavi/vtk/pyqt plus AFM-tools dependencies. Use it when you need 3D visualization.

Quick Start

import numpy as np
from afm_tools.afm_viz import AFMVisualizer

# Example image array (replace with real AFM/PFM image data)
img = np.random.randn(256, 256)

viz = AFMVisualizer()
viz.viz(img=img, scan_size={"image_size": 256, "scale_size": 1, "units": "µm"})

Usage Guide

See USAGE.md for a practical guide to loading IBW files, plotting single channels, rendering multi-channel previews, and understanding what belongs in AFM-tools versus sci-viz-utils.

IBW Preview Style

The high-level IBW preview keeps the compact AFM/PFM plotting style as the default: percentile color limits, MAD-based outlier handling, inward colorbar ticks, small colorbar labels, the unit above the colorbar, and a bottom-right scale bar with its label offset from the bar.

from afm_tools.afm_viz import AfmPreviewOptions, load_afm_dataset, render_afm_preview

dataset = load_afm_dataset("tests/ibw_preview/sample.ibw")
rendered = render_afm_preview(
    dataset,
    AfmPreviewOptions(selected_channel_indices=[0], show_metric_overlay=True),
)
rendered.figure.savefig("sample_preview.png", dpi=180, bbox_inches="tight")

You can tune the restored defaults without rewriting the plotting function:

options = AfmPreviewOptions(
    selected_channel_indices=[0],
    colorbar_setting={
        "style": "compact",
        "tick_labelsize": 7,
        "unit_position": "top",
        "scale_image": True,
    },
    scalebar_setting={
        "text_offset": 0.55,
        "text_fontsize": 9,
    },
)

Use colorbar_setting={"style": "matplotlib"} for Matplotlib’s standard side-label colorbar. Use {"scale_image": False, "tick_unit": True} to keep raw meter-valued image data and scale only the colorbar tick labels, matching older AFM visualizer behavior.

To generate preview PNGs from the bundled sample IBW file:

python tests/ibw_preview/ibw_preview.py
python tests/ibw_preview/ibw_preview.py --channels all

The images are written to tests/ibw_preview/outputs by default.

Features

  • Read and parse AFM-related wave/image formats.

  • 2D/3D visualization utilities for AFM/PFM datasets.

  • Domain and morphology analysis helpers.

  • Video and plotting utilities for time/scan series.

Documentation

Sphinx documentation is provided in the docs directory.

Build docs locally:

pip install -r docs/requirements.txt
pip install -e .
sphinx-build -b html docs docs/_build/html

License

This project is licensed under the MIT License. See LICENSE.txt.

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

afm_tools-2.1.3.tar.gz (1.9 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

afm_tools-2.1.3-py3-none-any.whl (41.3 kB view details)

Uploaded Python 3

File details

Details for the file afm_tools-2.1.3.tar.gz.

File metadata

  • Download URL: afm_tools-2.1.3.tar.gz
  • Upload date:
  • Size: 1.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for afm_tools-2.1.3.tar.gz
Algorithm Hash digest
SHA256 0bc0da5784d6797a7750eddca97a98d413d1e08d146eaf3542f5d9bc51a591e5
MD5 f9666c1acf1be2e9595230174237f319
BLAKE2b-256 c78bde2de15856f8e6e033774f5dd24edab14818010af1905648bdc1e3f08197

See more details on using hashes here.

Provenance

The following attestation bundles were made for afm_tools-2.1.3.tar.gz:

Publisher: main.yml on yig319/AFM-tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file afm_tools-2.1.3-py3-none-any.whl.

File metadata

  • Download URL: afm_tools-2.1.3-py3-none-any.whl
  • Upload date:
  • Size: 41.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for afm_tools-2.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9919feb77a76a0fc2532662bc5df6606a38d20c3a09143640489516c9a6d148f
MD5 c52115587114ef7e889517a5c161ac01
BLAKE2b-256 c11642d9207544062d3f85ef21bdba709fd0a4499b9649197fc36ca0acf6b775

See more details on using hashes here.

Provenance

The following attestation bundles were made for afm_tools-2.1.3-py3-none-any.whl:

Publisher: main.yml on yig319/AFM-tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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