Source code for PyMca5.EPDL97.GenerateEADLShellRadiativeRates

__doc__= "Generate specfiles with EADL97 shell transition probabilities"
import os
import sys
import EADLParser

Elements = ['H', 'He',
            'Li', 'Be', 'B', 'C', 'N', 'O', 'F', 'Ne',
            'Na', 'Mg', 'Al', 'Si', 'P', 'S', 'Cl', 'Ar',
            'K', 'Ca', 'Sc', 'Ti', 'V', 'Cr', 'Mn', 'Fe',
            'Co', 'Ni', 'Cu', 'Zn', 'Ga', 'Ge', 'As', 'Se',
            'Br', 'Kr', 'Rb', 'Sr', 'Y', 'Zr', 'Nb', 'Mo',
            'Tc', 'Ru', 'Rh', 'Pd', 'Ag', 'Cd', 'In', 'Sn',
            'Sb', 'Te', 'I', 'Xe', 'Cs', 'Ba', 'La', 'Ce',
            'Pr', 'Nd', 'Pm', 'Sm', 'Eu', 'Gd', 'Tb', 'Dy',
            'Ho', 'Er', 'Tm', 'Yb', 'Lu', 'Hf', 'Ta', 'W',
            'Re', 'Os', 'Ir', 'Pt', 'Au', 'Hg', 'Tl', 'Pb',
            'Bi', 'Po', 'At', 'Rn', 'Fr', 'Ra', 'Ac', 'Th',
            'Pa', 'U', 'Np', 'Pu', 'Am', 'Cm', 'Bk', 'Cf',
            'Es', 'Fm', 'Md', 'No', 'Lr', 'Rf', 'Db', 'Sg',
            'Bh', 'Hs', 'Mt']

[docs]def getHeader(filename): text = '#F %s\n' % filename text += '#U00 This file is a conversion to specfile format of \n' text += '#U01 directly extracted EADL97 radiative transition probabilities.\n' text += '#U02 EADL itself can be found at:\n' text += '#U03 http://www-nds.iaea.org/epdl97/libsall.htm\n' text += '#U04 The code used to generate this file has been:\n' text += '#U05 %s\n' % os.path.basename(__file__) text += '#U06\n' text += '\n' return text
if __name__ == "__main__": shellList = EADLParser.getBaseShellList() workingShells = ['K', 'L1', 'L2', 'L3', 'M1', 'M2', 'M3', 'M4', 'M5'] for shell in workingShells: fname = "EADL97_%sShellRadiativeRates.dat" % shell[0] print("fname = %s" % fname) if shell in ['K', 'L1', 'M1']: if os.path.exists(fname): os.remove(fname) nscan = 0 outfile = open(fname, 'wb') if sys.version < '3.0': outfile.write(getHeader(fname)) else: outfile.write(getHeader(fname).encode('UTF-8')) nscan += 1 for i in range(1,101): print("Z = %d, Element = %s" % (i, Elements[i-1])) element = Elements[i-1] try: ddict = EADLParser.getRadiativeTransitionProbabilities(\ Elements.index(element)+1, shell=shell) print("%s Shell radiative emission probabilities " % shell) except IOError: #print "IOError" #continue pass for key in shellList: if key not in ddict: ddict[key] = [0.0, 0.0] if i == 1: text = '#S %d %s emission rates\n' % (nscan, shell) text += '#N %d\n' % (2+len(shellList)-1) #generate the labels text += '#L Z TOTAL' for key in shellList: tmpKey = key.split()[0] if tmpKey in workingShells: if workingShells.index(tmpKey) <= workingShells.index(shell): continue text += ' %s%s' % (shell, tmpKey) text += '\n' else: text = '' total = 0.0 for key in shellList: total += ddict[key][0] text += '%d %.7E' % (i, total) for key in shellList: tmpKey = key.split()[0] if tmpKey in workingShells: if workingShells.index(tmpKey) <= workingShells.index(shell): continue text += ' %.7E' % ddict[key][0] text += '\n' if sys.version < '3.0': outfile.write(text) else: outfile.write(text.encode('UTF-8')) if sys.version < '3.0': outfile.write('\n') else: outfile.write('\n'.encode('UTF-8')) if sys.version < '3.0': outfile.write('\n') else: outfile.write('\n'.encode('UTF-8')) outfile.close()