Skip to content

apeck12/cmtip

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

cmtip is a Python implementation of cartesian MTIP (multitiered iterative phasing), and in some sense a next-generation spinifel. The three main algorithmic components are:

  1. alignment, in which images are aligned by comparison to references slices through the diffraction volume. These reference slices are computed from the autocorrelation volume using the forward nonuniform FFT (NUFFT).
  2. solving for the autocorrelation by maximizing the consistency of the oriented images with the intensity model. This component makes use of the adjoint NUFFT.
  3. phasing, in which rounds of hybrid-input output (HIO), error reduction (ER), and shrink-wrap are used to compute the density from the oversampled autocorrelation.

This repository was structured with modular testing in mind. Alignment and phasing accuracy can both be checked by supplying the ideal autocorrelation, while the autocorrelation solver can be checked by assuming ground truth orientations. At each iteration of the full pipeline, the estimated autocorrelation and density maps are saved as MRC files and the predicted orientations are saved to a numpy array. Acceleration has been achieved by parallelization through MPI.

Current dependencies are skopi, finufft, cufinufft, and mrcfile, all of which are available through pip install.

Scripts have been provided for the simulation of a noise-free dataset and its reconstruction. For example, to simulate a 5k image dataset, one could run:

$ python simulate.py -b ./examples/input/amo86615.beam -p 3iyf.pdb -d pnccd {PATH_TO_SKOPI}/skopi/examples/input/lcls/amo86615/PNCCD::CalibV1/Camp.0:pnCCD.1/geometry/0-end.data 0.2 -n 5000 -o 3iyf_sim.h5

The simulation code requires a GPU. To reconstruct on a single CPU core:

$ python reconstruct.py -i 3iyf_sim.h5 -t 5000 -b 2 -m 81 -n 10 -o rec

See docstrings for further information.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages