Skip to main content

Quantitative X-Ray Fluorescence Analysis Support Library

Project description

This software library implements formulas to calculate, given an experimental setup, the expected x-ray fluorescence intensities. The library accounts for secondary and tertiary excitation, K, L and M shell emission lines and de-excitation cascade effects. The basic implementation is written in C++ and a Python binding is provided.

Account for scondary excitation is made via the reference:

D.K.G. de Boer, X-Ray Spectrometry 19 (1990) 145-154

with the correction mentioned in:

D.K.G. de Boer et al, X-Ray Spectrometry 22 (1993) 33-28

Tertiary excitation is accounted for with an appproximation.

The accuracy of the corrections has been tested against experimental data and Monte Carlo simulations.

License

This code is relased under the MIT license as detailed in the LICENSE file.

Installation

To build the library for python use, just use the python setup.py install approach. It is convenient (but not mandatory) to have cython >= 0.17 installed.

Example

There is a web application using this library for calculating expected x-ray count rates.

This piece of Python code shows how the library can be used via its python binding.

from fisx import Elements
from fisx import Material
from fisx import Detector
from fisx import XRF

elementsInstance = Elements()
elementsInstance.initializeAsPyMca()
# After the slow initialization (to be made once), the rest is fairly fast.
xrf = XRF()
xrf.setBeam(16.0) # set incident beam as a single photon energy of 16 keV
xrf.setBeamFilters([["Al1", 2.72, 0.11, 1.0]]) # Incident beam filters
# Steel composition of Schoonjans et al, 2012 used to generate table I
steel = {"C":  0.0445,
         "N":  0.04,
         "Si": 0.5093,
         "P":  0.02,
         "S":  0.0175,
         "V":  0.05,
         "Cr":18.37,
         "Mn": 1.619,
         "Fe":64.314, # calculated by subtracting the sum of all other elements
         "Co": 0.109,
         "Ni":12.35,
         "Cu": 0.175,
         "As": 0.010670,
         "Mo": 2.26,
         "W":  0.11,
         "Pb": 0.001}
SRM_1155 = Material("SRM_1155", 1.0, 1.0)
SRM_1155.setComposition(steel)
elementsInstance.addMaterial(SRM_1155)
xrf.setSample([["SRM_1155", 1.0, 1.0]]) # Sample, density and thickness
xrf.setGeometry(45., 45.)               # Incident and fluorescent beam angles
detector = Detector("Si1", 2.33, 0.035) # Detector Material, density, thickness
detector.setActiveArea(0.50)            # Area and distance in consistent units
detector.setDistance(2.1)               # expected cm2 and cm.
xrf.setDetector(detector)
Air = Material("Air", 0.0012048, 1.0)
Air.setCompositionFromLists(["C1", "N1", "O1", "Ar1", "Kr1"],
                            [0.0012048, 0.75527, 0.23178, 0.012827, 3.2e-06])
elementsInstance.addMaterial(Air)
xrf.setAttenuators([["Air", 0.0012048, 5.0, 1.0],
                    ["Be1", 1.848, 0.002, 1.0]]) # Attenuators
fluo = xrf.getMultilayerFluorescence(["Cr K", "Fe K", "Ni K"],
                                     elementsInstance,
                                     secondary=2,
                                     useMassFractions=1)
print("Element   Peak          Energy       Rate      Secondary  Tertiary")
for key in fluo:
    for layer in fluo[key]:
        peakList = list(fluo[key][layer].keys())
        peakList.sort()
        for peak in peakList:
            # energy of the peak
            energy = fluo[key][layer][peak]["energy"]
            # expected measured rate
            rate = fluo[key][layer][peak]["rate"]
            # primary photons (no attenuation and no detector considered)
            primary = fluo[key][layer][peak]["primary"]
            # secondary photons (no attenuation and no detector considered)
            secondary = fluo[key][layer][peak]["secondary"]
            # tertiary photons (no attenuation and no detector considered)
            tertiary = fluo[key][layer][peak].get("tertiary", 0.0)
            # correction due to secondary excitation
            enhancement2 = (primary + secondary) / primary
            enhancement3 = (primary + secondary + tertiary) / primary
            print("%s   %s    %.4f     %.3g     %.5g    %.5g" % \
                               (key, peak + (13 - len(peak)) * " ", energy,
                               rate, enhancement2, enhancement3))

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

fisx-1.0.5.zip (5.8 MB view details)

Uploaded Source

fisx-1.0.5.tar.gz (5.6 MB view details)

Uploaded Source

Built Distributions

fisx-1.0.5-cp35-none-win_amd64.whl (5.8 MB view details)

Uploaded CPython 3.5 Windows x86-64

fisx-1.0.5-cp34-none-win_amd64.whl (5.9 MB view details)

Uploaded CPython 3.4 Windows x86-64

fisx-1.0.5-cp27-none-win_amd64.whl (5.9 MB view details)

Uploaded CPython 2.7 Windows x86-64

fisx-1.0.5-cp27-none-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl (6.5 MB view details)

Uploaded CPython 2.7 macOS 10.10+ intel macOS 10.10+ x86-64 macOS 10.6+ intel macOS 10.9+ intel macOS 10.9+ x86-64

File details

Details for the file fisx-1.0.5.zip.

File metadata

  • Download URL: fisx-1.0.5.zip
  • Upload date:
  • Size: 5.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for fisx-1.0.5.zip
Algorithm Hash digest
SHA256 5a8856a9a04943ba41a9ba8da448f1aef0dac484104d9b8f51343a52ee1046d2
MD5 cdafe16ab2e48e89ea64264ca94a4b72
BLAKE2b-256 52292464d8196753fd657e9d81f262f800f8dd807420e7b610a8df47772b6665

See more details on using hashes here.

File details

Details for the file fisx-1.0.5.tar.gz.

File metadata

  • Download URL: fisx-1.0.5.tar.gz
  • Upload date:
  • Size: 5.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for fisx-1.0.5.tar.gz
Algorithm Hash digest
SHA256 98b653ca46b3a20f8d1bd52606b8c331b92e37a739014d40c80cd40542690fb6
MD5 f308c1fa5183961ae25462f4cf1e793e
BLAKE2b-256 b3008452b4249a333e587553051534629463e45c879df4d88d38247dba7a43ba

See more details on using hashes here.

File details

Details for the file fisx-1.0.5-cp35-none-win_amd64.whl.

File metadata

File hashes

Hashes for fisx-1.0.5-cp35-none-win_amd64.whl
Algorithm Hash digest
SHA256 d2619acf74fae1864ae8ee4edee838294f969bc7bc427104eb5c61764a5259b3
MD5 ff49a5c88840940718f3507661a7fd2b
BLAKE2b-256 7e33df057af28f4dd3e44959a1c00bc9e75bab72c01f6044a801b3d95849410f

See more details on using hashes here.

File details

Details for the file fisx-1.0.5-cp34-none-win_amd64.whl.

File metadata

File hashes

Hashes for fisx-1.0.5-cp34-none-win_amd64.whl
Algorithm Hash digest
SHA256 a087d23ce03130696e0bb45a3368804953daab412c5bc0c148ee223c4aea4fb4
MD5 d9bf7b1f31a73480caf3005ca30be71b
BLAKE2b-256 eaa82406a294a820bc919cb562f1dd006b95b7ca7174060ef789dcd1128b9320

See more details on using hashes here.

File details

Details for the file fisx-1.0.5-cp27-none-win_amd64.whl.

File metadata

File hashes

Hashes for fisx-1.0.5-cp27-none-win_amd64.whl
Algorithm Hash digest
SHA256 cd6dfe51ea638cf7f1e518917c4d359b8803a7f29d5881dc297fbf43529f7b07
MD5 2f1166e8f91e7c85550c128fcabfc731
BLAKE2b-256 cb5f59b92ae09407b3a94392b6855d7ad42fe42c55e573f337c8bf9eb76e8e58

See more details on using hashes here.

File details

Details for the file fisx-1.0.5-cp27-none-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl.

File metadata

File hashes

Hashes for fisx-1.0.5-cp27-none-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl
Algorithm Hash digest
SHA256 05e367dabfff2b0b682696281d686167aed0a977235cf6c5b4946085b8bb9a84
MD5 4261ca3bc88336256ae1dafff4375081
BLAKE2b-256 f2325204123d83026a8b5f5c1bc69cf67916e2e3863b372149964b91a3e21a24

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page