Skip to main content

Write Chimera Map (CMAP) files

Project description

Cmapfile is a Python library and console script to write Chimera Map (CMAP) files, HDF5 files containing series of 3D XYZ datasets.

CMAP files can be created from numpy arrays and various file formats containing volume data, for example, BIN, TIFF, LSM, OIF, and OIB.

CMAP files can be visualized using UCSF Chimera [2], a program for interactive visualization and analysis of molecular structures and related data.

Author:

Christoph Gohlke

License:

BSD-3-Clause

Version:

2026.1.8

DOI:

10.5281/zenodo.17979877

Quickstart

Install the cmapfile package and all dependencies from the Python Package Index:

python -m pip install -U cmapfile[all]

Print the command line usage:

python -m cmapfile --help

See Examples for usage cases.

Source code and support are available on GitHub.

Requirements

This revision was tested with the following requirements and dependencies (other versions may work):

Revisions

2026.1.8

  • Improve code quality.

2025.12.18

  • Improve code quality.

  • Drop support for Python 3.10, support Python 3.14.

2025.1.1

  • Improve type hints.

  • Support Python 3.13.

2024.8.28

Refer to the CHANGES file for older revisions.

Notes

The CMAP file format according to [1]:

Example of HDF format written by Chimera (Chimera map format) follows.
The Chimera map file reader will allow all fields to be missing (except
the 3D data).

/image (group, any name allowed)
 name "centriole" (attribute)
 step (1.2, 1.2, 1.2) (attribute)
 origin (-123.4, -522, 34.5) (attribute)
 cell_angles (90.0, 90.0, 90.0) (attribute)
 rotation_axis (0.0, 0.0, 1.0) (attribute)
 rotation_angle 45.0 (attribute, degrees)
 color (1.0, 1.0, 0, 1.0) (attribute, rgba 0-1 float)
 time 5 (attribute, time series frame number)
 channel 0 (attribute, integer for multichannel data)
 /data (3d array of uint8 (123,542,82)) (dataset, any name allowed)
 /data_x (3d array of uint8 (123,542,82), alternate chunk shape) (dataset)
 /data_2 (3d array of uint8 (61,271,41)) (dataset, any name allowed)
    subsample_spacing (2, 2, 2) (attribute)
 (more subsampled or alternate chunkshape versions of same data)

References

  1. Thomas Goddard. [Chimera-users] reading in hdf5 files in chimera. https://www.cgl.ucsf.edu/pipermail/chimera-users/2008-September/003052.html

  2. UCSF Chimera, an extensible molecular modeling system. https://www.cgl.ucsf.edu/chimera/

  3. Globals for Images - SimFCS. https://www.lfd.uci.edu/globals/

Examples

Convert a 5D LSM file to CMAP file:

$ python -m cmapfile "/my data directory/large.lsm"

Convert all BIN files in the current directory to test.cmap. The BIN files are known to contain 128x128x64 samples of 16-bit integers. The CMAP file will store float32 maps using subsampling up to 16:

$ python -m cmapfile --shape 128,128,64 --step 1,1,2 --dtype i2 \
                     --cmap test.cmap --subsample 16 --astype float32 *.bin

Change the step size in the CMAP file:

$ python -m cmapfile --step 1,1,1.5 test.cmap

Print the cmapfile script usage:

$ python -m cmapfile --help

Usage: cmapfile [options] files

Convert volume data files to Chimera MAP files.

Options:
--version             show program's version number and exit
-h, --help            show this help message and exit
-q, --quiet
--filetype=FILETYPE   type of input file(s).
                      For example, BIN, LSM, OIF, TIF
--dtype=DTYPE         type of data in BIN files. For example, uint16
--shape=SHAPE         shape of data in BIN files in F order.
                      For example, 256,256,32
--offset=OFFSET       number of bytes to skip at beginning of BIN files
--step=STEP           stepsize of data in files in F order.
                      For example, 1.0,1.0,8.0
--cmap=CMAP           name of output CMAP file
--astype=ASTYPE       type of data in CMAP file. For example, float32
--subsample=SUBSAMPLE
                      write subsampled datasets to CMAP file

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

cmapfile-2026.1.8.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

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

cmapfile-2026.1.8-py3-none-any.whl (14.3 kB view details)

Uploaded Python 3

File details

Details for the file cmapfile-2026.1.8.tar.gz.

File metadata

  • Download URL: cmapfile-2026.1.8.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for cmapfile-2026.1.8.tar.gz
Algorithm Hash digest
SHA256 4eff7c52f3c098a5be844e8ca412d04354baac299145a0f9704dc546557596bb
MD5 248078fb2eb364e1b5bee6b3cdc96f71
BLAKE2b-256 384ce6e25f6d3dd3cbbd413a5741a54ff7dd1ac3e77c9f68f91234dbdd405270

See more details on using hashes here.

File details

Details for the file cmapfile-2026.1.8-py3-none-any.whl.

File metadata

  • Download URL: cmapfile-2026.1.8-py3-none-any.whl
  • Upload date:
  • Size: 14.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for cmapfile-2026.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 1f366ea704d757f8ee87465e7054b977b1ee848d41a6d7e43d49b9f2c64cebb1
MD5 c26abf96c4a530ca51a9268fef0d9675
BLAKE2b-256 2bf369ee8c3308575136330c37101a9e8e9ffcb20f88c42b5fc4f56282730bb7

See more details on using hashes here.

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