Source code for tomo.convert

# **************************************************************************
# *
# * Authors:     J.M. De la Rosa Trevin (delarosatrevin@scilifelab.se) [1]
# *
# * [1] SciLifeLab, Stockholm University
# *
# * This program is free software; you can redistribute it and/or modify
# * it under the terms of the GNU General Public License as published by
# * the Free Software Foundation; either version 2 of the License, or
# * (at your option) any later version.
# *
# * This program is distributed in the hope that it will be useful,
# * but WITHOUT ANY WARRANTY; without even the implied warranty of
# * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# * GNU General Public License for more details.
# *
# * You should have received a copy of the GNU General Public License
# * along with this program; if not, write to the Free Software
# * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
# * 02111-1307  USA
# *
# *  All comments concerning this program package may be sent to the
# *  e-mail address 'scipion@cnb.csic.es'
# *
# **************************************************************************

from pwem.emlib.image import ImageHandler
from .convert import *


[docs]def writeTiStack(inputTiList, outputStackFn, outputTltFn=None, excludeList=None): """ Write a given list of tilt images as a single stack Params: inputTiList: input list of tilted images. outputStackFn: output path where to write the stack. orderBy: column to sort by, by default tilt angle (ascending) excludeList: a list of indexes of the images to skip (starting at 1) Results: A new stack file will be created and also a tlt file with tilt-angles """ excludeList = excludeList or [] ih = ImageHandler() j = 0 f = open(outputTltFn, 'w') if outputStackFn else None for i, ti in enumerate(inputTiList): if i + 1 not in excludeList: j += 1 ih.convert(ti, (j, outputStackFn)) if f: f.write('%f\n' % ti.getTiltAngle()) if f: f.close()
[docs]def getAnglesFromHeader(tsImage): """ Extract the tilt angles from the tilt-series stack using the IMOD program: extracttilts. """ anglesFn = '/tmp/angles.txt' args = '--input %s --output %s' % (tsImage, anglesFn) pwutils.runJob(None, 'extracttilts', args) angles = [] with open(anglesFn) as f: angles = [float(line) for line in f] return angles
[docs]def parseMdoc(mdocFn): """ Parse the mdoc file and return a list with a dict key=value for each of the [Zvalue = X] sections :param mdocFn: Path to the mdoc file :return: list of dictonaries """ zvalueList = [] with open(mdocFn) as f: for line in f: if line.startswith('[ZValue'): # We have found a new Zvalue zvalue = int(line.split(']')[0].split('=')[1]) if zvalue != len(zvalueList): raise Exception("Unexpected ZValue = %d" % zvalue) zvalueDict = {} zvalueList.append(zvalueDict) else: if line.strip() and zvalueList: key, value = line.split('=') zvalueDict[key.strip()] = value.strip() return zvalueList
[docs]def getAnglesFromMdoc(mdocFn): """ Return only the angles from the given mdoc file. """ return [float(d['TiltAngle']) for d in parseMdoc(mdocFn)]
[docs]def getAnglesFromTlt(tltFn): """ Parse the tilt-angles from tlt file. """ angles = [] with open(tltFn) as f: for line in f: line = line.strip() if line: angles.append(float(line)) return angles