File: update_mrcz_to_0.5.0.py

package info (click to toggle)
python-mrcz 0.5.9-1
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 520 kB
  • sloc: python: 2,484; makefile: 5; sh: 1
file content (60 lines) | stat: -rw-r--r-- 2,030 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
import glob, sys, os, os.path as path
import numpy as np
import mrcz
from distutils.version import StrictVersion
import shutil

args = sys.argv
directory = '.'
"""
This script is used for updating a directory of older MRCZ files from versions
<= 0.4.1 to the 0.5.0 standard, so that the volume sampling is set to the 
default (Mx, My, Mz) = [0, 0, 1].
"""

if len(sys.argv) > 1:
    directory = sys.argv[1]

mrcz_files = glob.glob(path.join(directory, '*.mrc'), recursive=False)
mrcz_files.extend(glob.glob(path.join(directory, '*.mrcz'), recursive=False))

backup_dir = path.join(directory, 'backup')
os.makedirs(backup_dir)
for filename in mrcz_files:
    shutil.copy(filename, path.join(backup_dir, path.basename(filename)))

    data, meta = mrcz.readMRC(filename)

    compressor = meta['compressor'] if 'compressor' in meta else None
    clevel = meta['clevel'] if 'clevel' in meta else 1
    voltage = meta['voltage'] if 'voltage' in meta else 0.0
    C3 = meta['C3'] if 'C3' in meta else 0.0
    gain = meta['gain'] if 'gain' in meta else 1.0
    pixelsize = meta['pixelsize'] if 'pixelsize' in meta else [0.1,0.1,0.1]
    pixelunits = meta['pixelunits'] if 'pixelunits' in meta else u'\\AA'
    
    if 'packedBytes' in meta:
        meta.pop('packedBytes')
    if 'minImage' in meta:
        meta.pop('minImage')
    if 'maxImage' in meta:
        meta.pop('maxImage')
    if 'meanImage' in meta:
        meta.pop('meanImage')
    if 'extendedBytes' in meta:
        meta.pop('extendedBytes')

    mrcz.writeMRC(data, filename, meta=meta,
        pixelsize=pixelsize, pixelunits=pixelunits,
        voltage=voltage, C3=C3, gain=gain,
        compressor=compressor, clevel=clevel)
    
    # Try and read every file back in.
    try:
        mrcz.readMRC(filename)
    except:
        raise ValueError('{} could not be re-read'.format(filename))
    
print('__All__ originals were backed up to %s, remember to delete them' % path.join(directory, 'backup'))