Analysing differential phase contrast data¶
Example of a paper doing this type of data processing: Strain Anisotropy and Magnetic Domains in Embedded Nanomagnets. The data and processing scripts used in this paper is available at Zenodo with the DOI 10.5281/zenodo.3466591.
Differential phase contrast analysis (DPC) is done using using the DPCSignal classes: DPCSignal2D
, DPCSignal1D
and DPCBaseSignal
.
Here, a test dataset is used to show the methods used to process this type of data. For information on how to load your own data, see :ref:load_dpc_data.
>>> import pixstem.api as ps
>>> s = ps.dummy_data.get_square_dpc_signal(add_ramp=True)
>>> s.plot()
data:image/s3,"s3://crabby-images/ee8d1/ee8d116f6423554e9749655a27186ca40d17d039" alt="_images/dpc_x_raw.jpg"
data:image/s3,"s3://crabby-images/69329/69329da90ef199a64de189a48f526f4c9e8eb1d8" alt="_images/dpc_y_raw.jpg"
Correcting d-scan¶
The first step is the remove the effects of the d-scan:
>>> s = s.correct_ramp()
>>> s.plot()
Note that this method only does a plane correction, using the corners of the signal. For many datasets, this will not work very well. Possibly tweaks is to change the corner size.
data:image/s3,"s3://crabby-images/e6ccd/e6ccd9997b44d8b1fb010cb39885b1c6db2c5d4b" alt="_images/dpc_x_cor.jpg"
data:image/s3,"s3://crabby-images/831f9/831f9d229df946cccedcb7e0d9fbdd5381d79d5b" alt="_images/dpc_y_cor.jpg"
Plotting methods¶
Plotting DPC color image using: get_color_signal()
>>> s_color = s.get_color_signal()
>>> s_color.plot()
data:image/s3,"s3://crabby-images/21a4f/21a4fcccd20e19bde95989559e0321d0906d47c4" alt="_images/dpc_color_image.jpg"
Plotting DPC phase image: get_phase_signal()
>>> s_phase = s.get_phase_signal()
>>> s_phase.plot()
data:image/s3,"s3://crabby-images/b4cf6/b4cf6cfa1836a5c0d1cbfaa73b50347cb39ac211" alt="_images/dpc_phase_image.jpg"
Plotting DPC magnitude image: get_magnitude_signal()
>>> s_magnitude = s.get_magnitude_signal()
>>> s_magnitude.plot()
data:image/s3,"s3://crabby-images/5e015/5e015fc4962eb2831d103111dbd76551bbcea011" alt="_images/dpc_magnitude_image.jpg"
Plotting bivariate histogram: get_bivariate_histogram()
>>> s_hist = s.get_bivariate_histogram()
>>> s_hist.plot(cmap='viridis')
data:image/s3,"s3://crabby-images/e3d34/e3d340fc65592431d0b2106767306654b5248b24" alt="_images/dpc_hist_image.jpg"
Plotting color image with more customizability: get_color_image_with_indicator()
>>> fig = s.get_color_image_with_indicator()
>>> fig.show()
data:image/s3,"s3://crabby-images/9e7b1/9e7b1252f9aa4fb86661c0c98b7bd010555a7a5a" alt="_images/dpc_color_image_indicator.jpg"
Rotating the data¶
Rotating the probe axes: rotate_data()
.
Note, this will not rotate the beam shifts.
>>> s_rot_probe = s.rotate_data(10)
>>> s_rot_probe.get_color_signal().plot()
data:image/s3,"s3://crabby-images/1bdc3/1bdc3a6b550cc1a3c2f50fba1537d9c02bfa6f0a" alt="_images/dpc_rotate_probe_color.jpg"
Rotating the beam shifts: rotate_beam_shifts()
.
>>> s_rot_shifts = s.rotate_beam_shifts(45)
>>> s_rot_shifts.get_color_signal().plot()
data:image/s3,"s3://crabby-images/8e185/8e185c8293be1c2922db7f2ea002c746adbbbf44" alt="_images/dpc_rotate_shifts_color.jpg"
Rotating both the probe dimensions and beam shifts by 90 degrees: flip_axis_90_degrees()
.
Note: in this dataset there will not be any difference compared to the original dataset.
So we slightly alter the dataset.
>>> s1 = s.deepcopy()
>>> s1.data[0, 50:250, 145:155] += 5
>>> s1.get_color_signal().plot()
>>> s_flip_rot = s1.flip_axis_90_degrees()
>>> s_flip_rot.get_color_signal().plot()
data:image/s3,"s3://crabby-images/04f64/04f6406f5b60dcdf6c89092b4356ffa7aa6bbff4" alt="_images/dpc_rotate_flip_color1.jpg"
data:image/s3,"s3://crabby-images/7fa39/7fa39b64f8f38e12b3f373a3530a3c99e03b6a2b" alt="_images/dpc_rotate_flip_color2.jpg"
Blurring the data¶
The beam shifts can be blurred using gaussian_blur()
.
This is useful for suppressing the effects of variations in the crystal structure.
>>> s = ps.dummy_data.get_square_dpc_signal()
>>> s_blur = s.gaussian_blur()
>>> s.get_color_signal().plot()
>>> s_blur.get_color_signal().plot()
data:image/s3,"s3://crabby-images/afc53/afc53e1381558665a607dec1dedad7fc4de23ac1" alt="_images/dpc_gaussian_nonblur.jpg"
data:image/s3,"s3://crabby-images/a650f/a650fa17026e63c48fbbaf9f73f24f1752489305" alt="_images/dpc_gaussian_blur.jpg"