Skip to main content

Read and retrieve data from various AFM file formats.

Project description

AFMReader

PyPI version PyPI - Python Version Code style: Ruff Code style: black Code style: flake8

pre-commit.ci status fair-software.eu

Downloads Downloads Downloads

A library for loading various Atomic Force Microscopy (AFM) file formats into Python. This library is primarily intended for use with TopoStats.

Supported file formats

File format Description
.asd High-speed AFM
.gwy Gwydion
.h5-jpk Bruker
.ibw WaveMetrics
.jpk-qi-image Bruker
.jpk Bruker
.spm Bruker's Format
.stp WSXM AFM software files
.top .stp variant
.topostats TopoStats

Support for the following additional formats is planned. Some of these are already supported in TopoStats and are awaiting refactoring to move their functionality into AFMReader these are denoted in bold below.

File format Description Status
.nhf Nanosurf To Be Implemented.
.aris Imaris Oxford Instruments To Be Implemented.
.tiff Park Systems To Be Implemented.

Usage

If you wish to process AFM images supported by AFMReader it is recommend you use TopoStats to do so, however the library can be used on its own.

.topostats

You can open .topostats files using the load_topostats function. Just pass in the path to the file.

from AFMReader.topostats import load_topostats

image, pixel_to_nanometre_scaling_factor, metadata = load_topostats(file_path="./my_topostats_file.topostats")

.spm

You can open .spm files using the load_spm function. Just pass in the path to the file and the channel name that you want to use. (If in doubt use one of the following: "Height", "ZSensor", "Height Sensor").

from AFMReader.spm import load_spm

image, pixel_to_nanometre_scaling_factor = load_spm(file_path="./my_spm_file.spm", channel="Height")

.gwy

You can open .gwy files using the load_gwy function. Just pass in the path to the file and the channel name that you want to use. (If in doubt use one one of the following: "Height", "ZSensor", "Height Sensor").

from AFMReader.gwy import load_gwy

image, pixel_to_nanometre_scaling_factor = load_gwy(file_path="./my_gwy_file.gwy", channel="Height")

.asd

You can open .asd files using the load_asd function. Just pass in the path to the file and the channel name that you want to use. (If in doubt use the "TP" topography channel).

Note: For .asd files, there seem to only ever be two channels in one file. "TP" (topography) is the main one you will want to use unless you know you specifically want something else.

Other channels: "ER" - Error, "PH" - Phase

from AFMReader.asd import load_asd

frames, pixel_to_nanometre_scaling_factor, metadata = load_asd(file_path="./my_asd_file.asd", channel="TP")

.ibw

You can open .ibw files using the load_ibw function. Just pass in the path to the file and the channel name that you want to use. (If in doubt, use HeightTracee (yes, with the extra 'e'), ZSensorTrace, or ZSensor).

from AFMReader.ibw import load_ibw

image, pixel_to_nanometre_scaling_factor = load_ibw(file_path="./my_ibw_file.ibw", channel="HeightTracee")

.jpk

You can open .jpk files using the load_jpk function. Just pass in the path to the file and the channel name you want to use. (If in doubt, use height_trace or measuredHeight_trace).

from AFMReader.jpk import load_jpk

image, pixel_to_nanometre_scaling_factor = load_jpk(file_path="./my_jpk_file.jpk", channel="height_trace")

.h5-jpk

You can open .h5-jpk files using the load_h5jpk function. Just pass in the path to the file and the channel name you want to use. (If in doubt, use height_trace or measuredHeight_trace).

Note: Since .h5-jpk stores timeseries AFM data a dictionary of timestamps for each frame is also returned.

from AFMReader.h5_jpk import load_h5jpk

frames, pixel_to_nanometre_scaling_factor, timestamp_dict = load_h5jpk(file_path="./my_jpk_file.jpk", channel="height_trace")

.stp

You can open .stp files using the load_stp function. Just pass in the path to the file you want to use.

from AFMReader.stp import load_stp

image, pixel_to_nanometre_scaling_factor = load_stp(file_path="./my_stp_file.stp")

.top

You can open .top files using the load_top function. Just pass in the path to the file you want to use.

from AFMReader.top import load_top

image, pixel_to_nanometre_scaling_factor = load_top(file_path="./my_top_file.top")

Contributing

Bug reports and feature requests are welcome. Please search for existing issues, if none relating to your bug/feature are found then feel free to create a new issue detailing what went wrong or the feature you would like to see implemented.

Pull requests are also welcome, please note that we have a Code of Conduct.

Setup

We use pre-commit to apply linting via ruff and pylint pre-commit hooks and use the Black and Flake8 code styles. To set yourself up for contributing after cloning the package and creating a Python virtual environment you should install the development dependencies and pre-commit as shown below.

# Activate your virtual environment, this will depend on which system you use e.g. conda or virtualenvwrapper
# Clone the repository
git clone git@github.com:AFM-SPM/AFMReader.git
# Change directories into the newly cloned directory
cd AFMReader
# Install the package along with the optional development (dev) dependencies
pip install -e .[dev]
# Install pre-commit
pre-commit install

This will ensure that any commits and pull requests you make will pass the Pre-commit Continuous Integration. Where possible ruff will correct the changes it can, but it may require you to address some issues manually, before adding any changes and attempting to commit again.

Citing

If you use or depend on AFMReader in your software please consider citing it in any derivative work that is published. Citation details can be found in the CITATION.cff file in this repository.

Also, please let us know if you use AFMReader in your software. You can either make a Pull Request to add it to the list below or you can email us at topostats@sheffield.ac.uk with details of your package.

Used By

AFMReader is a dependency of the following packages.

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

afmreader-0.0.6.tar.gz (55.0 MB view details)

Uploaded Source

Built Distribution

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

afmreader-0.0.6-py3-none-any.whl (43.4 kB view details)

Uploaded Python 3

File details

Details for the file afmreader-0.0.6.tar.gz.

File metadata

  • Download URL: afmreader-0.0.6.tar.gz
  • Upload date:
  • Size: 55.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for afmreader-0.0.6.tar.gz
Algorithm Hash digest
SHA256 55110f291538487571baadcec4919f947675f719203d825891a3eab2d9e65e86
MD5 454345c3e21beea562b5c5c5c5449be5
BLAKE2b-256 74f20bafd3db4772aecab91f7522b1194076d696528d18efe455aa7433326a91

See more details on using hashes here.

Provenance

The following attestation bundles were made for afmreader-0.0.6.tar.gz:

Publisher: pypi.yaml on AFM-SPM/AFMReader

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

File details

Details for the file afmreader-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: afmreader-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 43.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for afmreader-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 52ec5a7e1851baf96055e580c41a882b6435843f66b9dd8c5ad4e2bcf32c170f
MD5 8086f99354f9425045283789607fa6b4
BLAKE2b-256 c4e3f67e887c4997a8e7a2d74bd654161aaaed2db134e1062d17ef83cedb140c

See more details on using hashes here.

Provenance

The following attestation bundles were made for afmreader-0.0.6-py3-none-any.whl:

Publisher: pypi.yaml on AFM-SPM/AFMReader

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