/beams

An interface for visualizing and analyzing µSR data.

Primary LanguagePythonMIT LicenseMIT

beams logo Release Tests Build CodeQL

BEAMS

A simple interface for visualizing and analyzing µSR data.

Table of Contents

Getting Started

Prerequisites

  • Python 3.8 or greater

Installation

We recommend cloning the repository (the second option) as this makes updates for you much simpler (simply git pull)
  • Download a pre-built distribution under "Releases"

    or

  • Clone this repository with git clone https://github.com/FrandsenGroup/beams.git

  • Navigate into the BEAMS folder with cd beams

Without Anaconda

  • Run the following command to install the package requirements for BEAMS (note that you may need to use python3 instead of python, you can use python --version to make sure it is referencing the correct version)
python -m pip install -r python_requirements.txt

Anaconda

  • Run the following command in the anaconda prompt to install requirements.
conda install -c anaconda -c conda-forge --file conda_requirements.txt
python -m pip install musr2py

Start BEAMS for either, once you have navigated to the directory with the following

python beams

User Guide

Loading Files

By clicking the [+] button in the top left corner you will launch a prompt with four options of adding files. From disk (your computer), and then three different facilities: Triumf, PSI and ISIS. Clicking the [-] button will remove all the the files currently checked. ISIS recently changed their API so it will take you straight to their website (which is much improved and overall a better experience to work with anyways).

When you download files onto your computer from one of the three facilities, they need to be converted from their binary format to a format that our program can work with. You can do this by 'checking' the box next to each file you want to convert and pressing the 'convert' button. New files with the '.dat' extension will be created.

Once you have files in a format that our program can read you select the files you want to work with by checking the boxes and clicking the 'load' button. This loads the data from these files into the program, and you are now ready to interact with the data.

Plotting Asymmetries

Plotting the Asymmetry

Once your files are loaded, if they are files that can be plotted then they will show up in the file tree below the plotting buttons. Depending on the type of file you loaded, checking the box next to the file and clicking 'plot' may do one of three things.

If it is a '.dat' file, a file which contains histograms, a prompt will appear which will ask you to select which histograms should be used to calculate the asymmetry for that particular file. If you intend to use the same histograms for a large selection of files then you can press 'Apply All', otherwise you can press 'Apply' and specify for each file individually.

choosing your histograms for asymmetry

If it is a '.asy' file, a file which contains an asymmetry, then the asymmetry will be plotted as no more information is needed.

If it is a '.fit' file, a file which contains an experimental asymmetry, and an asymmetry calculated from a fit then the experimental asymmetry will be plotted with another plotted line for the calculated asymmetry.

Interacting with the Asymmetry

Once your asymmetry is plotted, you can now dynamically interact with it! You can experiment with this by moving the slider below each plot to adjust the binning of the asymmetry and adjust the x and y limits to focus on different areas. On the left side panel you will see the legend for the plots, as well as options for styling and adjusting the alpha parameter for the asymmetry.

choosing your histograms for asymmetry

Integrating Asymmetries

After plotting, you can also integrate asymmetries. To do this, select the runs for which you'd like to integrate asymmetries in the list directly under the "Plot" buttons in the right of the window. Then, right click on any of those runs and select "Integrate".

Selecting the integrate option

This will take you to the integration dialog, where you can interact with the integration in the same way as you can in the Histogram Panel. There are also buttons to export the left and right integrations as .int files.

Integration dialog

Saving Asymmetry Data

In beams you can save your asymmetry data as a .asy file (example found here). To save an asymmetry or group of asymmetries, check the box next to the runs in the upper-left hand panel and click the button that says 'Write'. The following prompt will appear (or a warning message indicating some problem with your selection).

beams logo

You can save the data in a couple different ways. By checking 'Full Data' this will write the full time, asymmetry and uncertainty arrays to the file you specify, whereas choosing 'Binned Data' and providing a Bin Size (in nanoseconds) will first bin the arrays before writing.

Using the option box at the top of the prompt you can write different files in different ways and specific locations, or you can write all selected files the same way (using the run number as the file name).


Interacting with Histograms

When you navigate to the histogram tab, you will be able to see the histograms for each loaded run and adjust meta values associated with them.

Upon first opening the tab, you will see this window on the left side panel. From here you can expand a specific run and click on the histogram you want to work with. You should see the histogram displayed on the screen.

Above the panel where you select histograms, you will see three buttons. Descriptions provided below.

See File

This will open up a small window displaying the contents of the file the run was loaded from. You cannot save changes from this prompt, it is purely for reference.

Reset

This will undo all changes you have made in this tab to the values of histograms that are CURRENTLY SELECTED in the panel below. If you have clicked save, those changes that were saved can not be undone (aside from setting the old values and saving again).

Save

This will save all changes you have made in this tab to the values of histograms that are CURRENTLY SELECTED. Once you save, all affected asymmetries will be recalculated, and you should see the changes shown appropriately in the plotting tab.

Navigation Bar

Depending on your purpose and the histogram, this may be a bit unwieldy to work with which is why a navigation bar is provided across the top of the tab.

beams logo

There are six buttons provided. They are described below in the order they appear on the bar.

Home

Pressing this button will undo all the changes (zooming and panning) that have visually been done to the display below. Useful if you've lost your spot panning around or zoomed in on the wrong area.

Undo

This will undo the last action you made (zooming or panning).

Redo

This will redo the last action that was undone.

Pan

This will allow you to move around the plotted histogram.

  • Note - Once you have pressed this button, you need to press it again to unselect the action.
Zoom

This will allow you to zoom in on specific portions of the plot (you can still see the whole plot if you pan around).

  • Note - Once you have pressed this button, you need to press it again to unselect the action.
Save

This will allow you to save what is currently displayed as an image file.

beams logo

Adjusting Values

Like other features in BEAMS, we try to make this adjusting values as intuitive and dynamic as possible. Below the navigation toolbar you will see a box with some (by default) disabled areas. As stated in the instructions, you will need to 'Check' the box to the left of the disabled options in order to enable them.

This is because, as seen in the image below, you can either specify the values for each in the input boxes OR use your mouse to select on the plot where you want those values to be. This can be an issue if, at the same time for example, you have the zoom feature also selected and are trying to navigate around the plot.

beams logo

There are five values you can adjust for each histogram. In order to move those values across the plot with your mouse, you need to have the radio button next to that value selected.

Background Start/End

These values define the section of the histogram which will be used to calculate the background radiation of the run.

T0

This value defines the start time of the run.

Good Bin Start/End

These values define the section of the histogram which will be used to calculate the asymmetry.

Combining Runs

Combining runs menu

There is an option to create a new combined run from individual runs in the histogram panel. Shift-click or ctrl-click multiple runs to select them in the left panel, then right click on those runs and select "Combine selected runs" to create the new combined run. The program will prompt you to name and save your new combined run as a .dat file, and then automatically load the new combined run into the program.


Fitting Asymmetries

Choosing your Fit Expression

beams logo

Near the top of the fitting tab you can see an area where you can provide the fitting expression as a function of 't'. Operations must be typed out explicitly (i.e. use '5*x' rather then '5x'). If the expression you provide is invalid, the box will be highlighted in red.


beams logo

Above the input for the expression you will see two boxes. The box on the left (Predefined Functions) contains some common function definitions that come loaded with the program. You can select the template you want to use and press 'Insert'. This will insert the function into the expression input box below (wherever your cursor is at in the box or at the end of the input if your cursor is not in it).

The box on the right (User Defined Functions) allows you to create a new function definition (with a specified name) and save it for future use. You can select from previously saved definitions and press 'Insert' to achieve the same behavior as described above.


Common Reserved Symbols + - * / ^ i e π pi
Common Functions - f(...) sin cos tan sinh cosh tanh exp pow

Specifying your Fit Parameters

When you provide a valid fit expression you will see the table of parameters, and the plot display below the input box update as you type. Below is an example of valid input.

beams logo

As you can see, the fit expression has two free variables (λ and β) and a third variable 'α' (this is a reserved symbol for the alpha value of the asymmetry). All three of these are accounted for in the parameter table.

The parameter table also has three separate sections you can interact with; Config, Batch and Output. Each of the three will be explained in depth.

Config

This is the first section of the parameter table shown above. There will be a row for each parameter and an additional row for α. For each parameter you can adjust the initial value used in the fit, the lower and upper bounds for that parameter, and whether or not that parameter should be fixed to the value provided.

  • Note - Adjusting a free variable will be reflected in the fit lines in the plot display. Adjusting alpha will be reflected in the asymmetry being plotted.
Batch

In the second section of the parameter table, you will once again see rows for each parameter with two new columns for each; Global and Run-Specific. For each parameter, you can only have ONE box checked (checking one will make the other box uncheckable).

By checking global, you are indicating that you want the parameter to be fit across all datasets - not individually for each.

By checking run-specific, you are indicating that you want to be able to specify every column in the config section (even the fixed column) individually for each run for that particular parameter. For example, you set the initial value for λ for one run to 2.0 and for another run to 3.0. By default, when you set the value that will be the initial value for every single run.

  • In order to assign values to individual runs, you select the runs (as shown below) and while they are selected you adjust the values in the config table. You will then find as you click through each run that the values have been applied and remembered.

  • If you select multiple runs that have conflicting values in one column or another for a parameter marked as run-specific, you will see a ' * ' in that cell or, if it is the fixed column, you will see a partial checkmark. If you adjust that cell then all conflicting values will be overwritten, otherwise if you don't edit it then they will remain unchanged.

Output

In the third section of the parameter table, you will see rows for each parameter and two new columns; Value and Uncertainty. These columns are only filled out after you have run a fit. When you select a fit on the left hand side panel, the value and uncertainty of the calculated parameters will be displayed here. If you select multiple fits at one time, a ' * ' will be placed in cells where there are conflicting values.

Specifying the Range and Bin-Size to Use

Similar to the settings in the tab where we plot the asymmetries, in this tab there are options directly below the display where you can adjust the range and bin-size of the asymmetry to be used in the fit. These setting will be applied to all runs used in the fit.

Fitting

Once you have your fit expression and parameters set you need to check the box next to each run that you want to be part of the fit. Once they are all checked, you can click [Fit] and a loading popup will come up until the fit is finished.

Fit Results

Viewing Results

Once your fit is complete, it will appear in the left-side panel (reference the image below). You will see a parent node (with the current timestamp as the name, you can right-click -> rename to change this) with a child node for each run you chose to include in the fit. If you select one of the children nodes, you will see the asymmetry and the fit line for that particular run shown in the display. If you select the parent node, you will see the asymmetries and fit lines for every run included in the fit. Additionally, you can ctrl-click or shift-click to select a custom range of fits to display.

Every run currently being displayed will have the color in the display shown to the left of the name of the run.

beams logo

Saving Fit Results

If you right-click on a single fit, a range of fits, or a parent node in the left-side panel you will see the option to 'save' these fits. If you click it, you will see a prompt which will offer several choices.

dialog for writing fit data

Summary

An example of this file can be found here. It is a single file summary of all fits you selected which you can order in the file by either temperature, field or run number if those values are available. It can be read back in to the program to display the fits if you have not moved your data files (you will need to adjust the file paths in the .fit file if you have).

Parameter

An example of this file can be found here. It is a single file which allows you to select one parameter and one independent variable from a set of runs for a given fit. The data is formatted as pure numerical data (for easily reading into other programs), with comments delimited by # containing information on the column headers and fitting equation.

Directory

This creates a list of files (example of a single file found here) in the provided directory. The file contains the time, calculated and observed asymmetries, and uncertainty as displayed in the fit tab. It's name is determined by the meta value you select in the prompt (this will be used for each fit selected so make sure you choose a unique meta value like RunNumber).

Zip

Same as the format above except the list of files is compressed as a zip file.

File Formats

External Supported File Formats

File Extension Description
.msr Histogram data from TRIUMF
.bin Histogram data from PSI
.mdu Histogram data from PSI
.nxs_v2 Histogram data from ISIS

BEAMS File Formats

Click on the file extension to see an example file (for non-binary file types).

File Extension Description
.dat Histogram data for a single run.
.asy Experimental asymmetry, uncertainty and time for a single run.
.fit A verbose summary of a fit or range of fits.
.calc Experimental and calculated asymmetry, uncertainty and time for a single run.
.int Export of an integrated asymmetry containing an independent variable, the integrated asymmetry, and uncertainty.
.prm A single parameter with its uncertainty exported with an independent variable and its uncertainty as pure numerical data to be read back into other programs for analysis.
.beams A saved beams session

Troubleshooting

Can't install requirements on Mac (Apple Silicon)

For trouble installing requirements on Apple Silicon see the answer to this issue.

$ brew install openblas
$ pip install cython pybind11 pythran numpy
$ OPENBLAS=$(brew --prefix openblas) CFLAGS="-falign-functions=8 ${CFLAGS}" pip install --no-use-pep517 scipy

Text in file trees is truncated

If the text is truncated or the items on the screen are misaligned slightly you most likely don't have PyQt5 installed (you can confirm this by running pip freeze in the terminal and you will probably see QtPy). Simply fix by using pip to install PyQt5.

$ pip install PyQt5

(PyQt5) ImportError: DLL load failed

Resolved in this Issue 37

Possible solution in the answer to this question on Stack Overflow: https://stackoverflow.com/questions/42863505/dll-load-failed-when-importing-pyqt5

(PyQt5) Could not load the Qt platform plugin "xcb" in "" even though it was found

If you are attempting to install using WSL, this was resolved here as a recommendation to install using PowerShell or the Command Prompt or possibly WSL2 instead.

Histogram navigation toolbar is not loading

There is an open issue for this (Issue 97). As of right now we do not have a solution. Consider uninstalling and reinstalling the python library 'matplotlib' and 'PyQt5'.

The pre-built distribution will not run on my system

You can open an issue in Github so we can try and debug it, but the easiest course of action is to build from source. You can follow the instructions in the Getting Started section

My files from TRIUMF, PSI, or ISIS aren't being converted

Please open up an issue if this happens as it means we need to update our program to read the new format.

I can't search/download files using the built-in dialogs

The website we are pulling from likely changed its API; please open an issue in GitHub or contact us.