Measuring Laser Beam Size#
This example shows how to measure the size of a laser beam along the propagation axis, using using DataLab:
Load all the images in a folder
Apply a threshold to the images
Extract the intensity profile along an horizontal line
Fit the intensity profile to a Gaussian function
Compute the full width at half maximum (FWHM) of intensity profile
Try another method: extract the radial intensity profile
Compute the FWHM of the radial intensity profile
Perform the same analysis on a stack of images and on the resulting profiles
Plot the beam size as a function of the position along the propagation axis
First, we open DataLab and load the images:
data:image/s3,"s3://crabby-images/bef5c/bef5c86010ecfc24a3aa76f4302c08a4306d06c6" alt="../../_images/012.png"
Open the image files with âFile > OpenâŠâ, or with the button in
the toolbar, or by dragging and dropping the files into DataLab (on the panel on
the right).#
data:image/s3,"s3://crabby-images/a19a0/a19a0f32534d65548cbb2b6cee1d5d3a9142d606" alt="../../_images/013.png"
Select the test images âTEM00_z_*.jpgâ and click âOpenâ.#
The selected images are loaded in the âImagesâ panel. The last image is displayed in the main window. On each image, we can zoom in and out by pressing the right mouse button and dragging the mouse up and down. We can also pan the image by pressing the middle mouse button and dragging the mouse.
data:image/s3,"s3://crabby-images/396dc/396dcfb76d851ccbdd07f7b284268a6fede74378" alt="../../_images/023.png"
Zoom in and out with the right mouse button. Pan the image with the middle mouse button.#
Note
If we want to display the images side by side, we can select the
âDistribute on a gridâ entry in the âOperationsâ menu.
data:image/s3,"s3://crabby-images/b3d44/b3d44d712cae76c0e3cc314c97ccb7feda925a06" alt="../../_images/033.png"
Images distributed on a 4 rows grid#
But, letâs go back to the initial display by selecting the âReset image positionsâ entry in the âOperationsâ menu.
If we select on of the images, we can see that there is background noise, so it might be useful to apply a threshold to the images.
data:image/s3,"s3://crabby-images/f0f47/f0f47c972f89472363c2a0a9c3b8db9056fbe6e4" alt="../../_images/043.png"
Select one of the images in the âImagesâ panel, select the associated image
in the visualization panel, and enable the âCross sectionâ tool in
the vertical toolbar on the left of the visualization panel (this tool is a
PlotPy feature). On this figure, we
can see that the background noise is around 30 lsb (to show the curve marker,
we had to select the profile curve and right-click on it to display the context
menu, and select âMarkers > Bound to active itemâ).#
data:image/s3,"s3://crabby-images/453e7/453e74eee56e3490e9d2b8fc1ce3f9b9e08b51ca" alt="../../_images/053.png"
Another way to measure the background noise is to use the âImage statisticsâ tool
in the vertical toolbar on the left of the visualization panel.
It displays statistics on a the rectangular area defined by dragging the mouse
on the image. This confirms that the background noise is around 30 lsb.#
data:image/s3,"s3://crabby-images/c1518/c1518801553beccd720c5971a14c8698c3410e1b" alt="../../_images/063.png"
After applying a threshold at 35 lsb (with âProcessing > ThresholdingâŠâ), we can compute a more accurate position of the beam center using âAnalysis > Centroidâ.#
data:image/s3,"s3://crabby-images/d4a59/d4a5919e413e6a8bf6a3190c05fe67c36aaeec9a" alt="../../_images/073.png"
Then we can extract a line profile along the horizontal axis with âOperations > Intensity profiles > Line profileâ. We set the row position to the centroid position computed previously (i.e. 668).#
data:image/s3,"s3://crabby-images/2a6c7/2a6c7da6d1807555a2d0b66d376fafbca19b9e5e" alt="../../_images/083.png"
The intensity profile is displayed in the âSignalsâ panel. We can fit the profile to a Gaussian function with âProcessing > Fitting > Gaussian fitâ. Here we have selected both signals.#
data:image/s3,"s3://crabby-images/03d7e/03d7e88c9a939be5d324827f3201ae4bbaadcce8" alt="../../_images/093.png"
If we go back to the first signal, the intensity profile, we can also directly compute the FWHM with âAnalysis > Full width at half maximumâ. The âResultsâ dialog displays a lot of information about the computation, including the FWHM value (that is the L column, âLâ for âLengthâ because the result shape is a segment and FWHM is the length of the segment).#
data:image/s3,"s3://crabby-images/0e7f1/0e7f1625d63b808ea1e65b5918d3ee313249ac2e" alt="../../_images/103.png"
The FWHM is also displayed on the curve, with an optional label (here, the
title of this measurement has been displayed with
âView > Show graphical object titlesâ or the button in the toolbar).#
Now, letâs try another method to measure the beam size.
From the âImagesâ panel, we can extract the radial intensity profile with âOperations > Intensity profiles > Radial profileâ.
data:image/s3,"s3://crabby-images/831ff/831ff8394850c1b73a5084eeb4d2d3f354442889" alt="../../_images/113.png"
The radial intensity profile may be computed around the centroid position, or around the center of the image, or around a user-defined position. Here we have selected the centroid position.#
data:image/s3,"s3://crabby-images/d80fe/d80feb5360825235b353c88a0d59e238b9bccf67" alt="../../_images/122.png"
The radial intensity profile is displayed in the âSignalsâ panel. It is smoother than the line profile, because it is computed from a larger number of pixels, thus averaging the noise.#
All these operations and computations that we have performed on a single image can be applied to all the images in the âImagesâ panel.
To do that, we begin by cleaning the âSignalsâ panel (with âEdit > Delete allâ or
the button in the toolbar). We alse clean the intermediate results
in the âImagesâ panel by selecting the images obtained during our prototyping
and deleting them individually (with âEdit > Removeâ or the
button).
Then, we select all the images in the âImagesâ panel (individually, or by selecting the whole group âg001â).
data:image/s3,"s3://crabby-images/2cce9/2cce974bf10148b6f766babd1617709edafbbffb" alt="../../_images/132.png"
We apply the threshold to all the images, and the we extract the radial intensity profile for all the images (after selecting the whole group âg002â - it should be automatically selected if you had selected âg001â before applying the threshold).#
data:image/s3,"s3://crabby-images/69a37/69a37607e18ca80bc151803bd2b5029b04247aeb" alt="../../_images/141.png"
The âSignalsâ panel now contains all the radial intensity profiles.#
data:image/s3,"s3://crabby-images/b6284/b6284c61c43ff352808e674ce7ee473356c1babc" alt="../../_images/151.png"
We can compute the FWHM of all the radial intensity profiles: the âResultsâ dialog displays the FWHM values for all the profiles.#
Note
If you want to show the analysis results again, you can select the âShow resultsâ
entry in the âAnalysisâ menu, or the âShow resultsâ
button, below the image list:
data:image/s3,"s3://crabby-images/c4170/c4170d9b545a79a6d58890d069609ad4c40d57d4" alt="../../_images/121.png"
data:image/s3,"s3://crabby-images/b227b/b227ba134270a65d81ce2e6e74cc6065720d3f2c" alt="../../_images/161.png"
Finally, we can plot the beam size as a function of the position along the
propagation axis. To do that, we use the âPlot resultsâ feature
in the âAnalysisâ menu. This feature allows to plot result data sets by
choosing the x and y axes among the result columns. Here, we choose the
to plot the FWHM values (L) as a function of the image index (Indices).#
data:image/s3,"s3://crabby-images/44023/44023a6e37e2f96e13924c52aa24ce0bdd11d332" alt="../../_images/171.png"
The plot is displayed in the âSignalsâ panel and shows that the beam size increases with the position along the propagation axis (the position is here in arbitrary units, the image index).#
data:image/s3,"s3://crabby-images/ff6d9/ff6d9fbdcdaedcdbfb7053088b15b0193a19572a" alt="../../_images/181.png"
We can also calibrate the X and Y axis using âProcessing > Linear calibrationâ. Here we have set the X axis to the position in mm (and entered the title and unit in the âPropertiesâ group box).#
Finally, we can save the workspace to a file . The workspace contains
all the images and signals that were loaded or processed in DataLab. It also contains
the analysis results, the visualization settings (colormaps, contrast, etc.), the
metadata, and the annotations.
If you want to load the workspace again, you can use the âFile > Open HDF5 fileâŠâ
(or the button in the toolbar) to load the whole workspace, or the
âFile > Browse HDF5 fileâŠâ (or the
button in the toolbar) to load
only a selection of data sets from the workspace.