[1]:
# -*- coding: utf-8 -*-
# Copyright 2024 United Kingdom Research and Innovation
# Copyright 2024 The University of Manchester
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# Authored by: Hannah Robarts (UKRI-STFC)
Load and visualise data with NikonDataReader#
This how-to shows how to use the NikonDataReader
to load data from Nikon .xtekct files and quickly visualise the data and geometry
Get the example dataset dataexample.KORN
using download_data()
.
[2]:
from cil.utilities import dataexample
dataexample.KORN.download_data(data_dir='../data', prompt=False)
Title: Seeds in box micro-CT dataset
Keywords: tomography, CT, data
Publication date: 2022-07-21
DOI: 10.5281/zenodo.6874123
Total size: 2.8 GB
Link: https://zenodo.org/records/6874123/files/korn.zip size: 2.8 GB
Checksum is correct. (e19dd18183550be755a35b50359e33a0)
All files have been downloaded.
[2]:
True
Now set up the NikonDataReader()
to read an .xtekct file.
[3]:
from cil.io import NikonDataReader
file_name = '../data/korn/Korn i kasse/47209 testscan korn01_recon.xtekct'
data_reader = NikonDataReader(file_name=file_name)
data = data_reader.read()
Check the data has been loaded correctly by viewing the geometry with show_geometry()
to display information about the source and detector setup.
[4]:
from cil.utilities.display import show_geometry
show_geometry(data.geometry)
data:image/s3,"s3://crabby-images/d3238/d32388f92af8b92a85ef416d8cc3e99c177644bd" alt="../../_images/demos_NikonDataReader_7_0.png"
[4]:
<cil.utilities.display.show_geometry at 0x7f51429bb650>
And view a central projection of the data with show2D()
[5]:
from cil.utilities.display import show2D
show2D(data)
data:image/s3,"s3://crabby-images/1b982/1b982217691c67d5735b8313a36521e373fc3a84" alt="../../_images/demos_NikonDataReader_9_0.png"
[5]:
<cil.utilities.display.show2D at 0x7f514278f860>
By default the NikonDataReader
argument normalise
is True
, which means all projections are loaded and normalised by the detector white level, which is stored in the .xtekct file as WhiteLevel. If you want to load the data without normalisation, specify normalise=False
[6]:
file_name = '../data/korn/Korn i kasse/47209 testscan korn01_recon.xtekct'
data_reader = NikonDataReader(file_name=file_name, normalise=False)
data = data_reader.read()
[7]:
show2D(data)
data:image/s3,"s3://crabby-images/ef178/ef178eeeaf9f836529a16170f03a9b688076b3c6" alt="../../_images/demos_NikonDataReader_12_0.png"
[7]:
<cil.utilities.display.show2D at 0x7f5142897410>
Use the roi
argument to load a subset of the data. roi
should be passed as a dictionary e.g. {'axis_labels_1': (start, end, step),'axis_labels_2': (start, end, step)}
with axis labels that describe the data dimension labels
To load a cropped subset of the data, change the start and end values. ‘axis_label’: -1 is a shortcut to load all elements along the axis.
[8]:
roi = {'horizontal':(120, 870, 1), 'vertical':-1}
data_reader = NikonDataReader(file_name=file_name, roi=roi)
data = data_reader.read()
show2D(data)
data:image/s3,"s3://crabby-images/428ff/428ff0a17dcf3097190b052eed484702c3c8cd19" alt="../../_images/demos_NikonDataReader_14_0.png"
[8]:
<cil.utilities.display.show2D at 0x7f5140f73770>
To load a binned subset of the data, change the step value. Here we use different binning for the horizontal and vertical dimensions which results in a different aspect ratio
[9]:
roi = {'horizontal':(None, None, 4), 'vertical':(None, None, 2)}
data_reader = NikonDataReader(file_name=file_name, roi=roi)
data = data_reader.read()
show2D(data)
data:image/s3,"s3://crabby-images/4876f/4876f0350d231ba5fc128817dd36ec06eb194688" alt="../../_images/demos_NikonDataReader_16_0.png"
[9]:
<cil.utilities.display.show2D at 0x7f5142896870>
We can also use the argument fliplr=True
to flip all projections in the vertical axis. If we enable this option we see that the projection is flipped in the left-right direction/
[10]:
data_reader = NikonDataReader(file_name=file_name, fliplr=True)
data = data_reader.read()
show2D(data)
data:image/s3,"s3://crabby-images/7065e/7065efd55cfbf57e1fee1d51d3a52a36eaaef609" alt="../../_images/demos_NikonDataReader_18_0.png"
[10]:
<cil.utilities.display.show2D at 0x7f5140d84890>
Sometimes we might want to load the geometry from the Nikon file without loading the data, for example if we want to load the raw data files separately and use the geometry from the .xtekct file. We can do this by instantiating the data reader and calling get_geometry()
[11]:
data_reader = NikonDataReader(file_name=file_name)
ag = data_reader.get_geometry()
show_geometry(ag)
data:image/s3,"s3://crabby-images/573d5/573d5ab43a07165ba47f94490e1822631b847cf9" alt="../../_images/demos_NikonDataReader_20_0.png"
[11]:
<cil.utilities.display.show_geometry at 0x7f52b9e9d1f0>
Uncomment the cell below to delete the dataset and its folder
[12]:
# import shutil
# shutil.rmtree('../data/korn')