5CCYB041 Object-Oriented Programming
5CCYB041
Object-Oriented Programming
Page 1 of 6
Coursework 1BEng Biomedical EngineeringObject-Oriented Programming
Coursework 1
Objective To gain practical experience of C++ coding to solve a simple problem.Introduction Magnetic Resonance Imaging is a powerful imaging technique capable of producing images ofinternal organs with good soft tissue contrast. It relies on a number of hardware components, as
illustrated in Figure 1: a powerful permanent magnet; magnetic field gradients provided bydedicated gradient coils (Figure 1, right); and radio-frequency coils to excite the nuclear spins(typicall1H) and detect the resulting nuclear magnetic resonance signal.
Figure 1: the different hardware components of a typical MRI scanner. Left: a cutaway view showing the
arrangement of the main magnet, gradient coils and RF coil. Right: an example of the design of a gradient
coil, showing the different concentric windings required to impart magnetic field gradients along the x,
y & z axes.
The role of the gradient coils is to impart a linear change in the resonance frequency of the1Hnuclear spins as a function of position, which allows the position of the signal to be inferred. To
provide full images, these magnetic field gradients need to be rapidly modulated in time, which isdone by driving very large currents through the gradient coils and switching them rapidly on &
off at appropriate times along the appropriate axes. 5CCYB041Object-Oriented ProgrammingPage 2 of 6Coursework 1
Eddy-currents in MRI Because of Faraday’s law of electromagnetic induction, these rapid and intense changes in the
magnetic fields induce voltages, which in turn drive currents in nearby conductive structures.
These eddy currents create magnetic fields that oppose the change in magnetic field that created
them (this is called Lenz’s law).In MRI, 代写5CCYB041 Object-Oriented Programmingthe net result is that the temporal evolution of the magnetic field gradient actually
produced will differ from the waveform provided to the gradient amplifier. This is illustrated inFigure 2, showing how an ideal trapezoidal input waveform will end up distorted and laggingbehind what was expected, and the resulting impact on images acquired using echo-planarimaging (a single-shot imaging technique). Eddy currents can affect the images in many different
ways, depending on the type of MRI sequence used and other factors, but they are invariablyproblematic. For this reason, a variety of techniques are used to minimise eddy-currents,
including hardware solutions (e.g. actively shielded gradients) and gradient pre-emphasis.Figure 2: illustration of the effect of eddy-currents. (a) the expected waveform (dotted line) is distorted
due to eddy-currents, resulting in the delayed time evolution of the actual gradients (solid line). (b) The
eddy-currents (solid line) originate from the rapid changes in the magnetic field that occur when there
is a change in the gradient (dotted line). (c) image that would ideally be acquired using echo-planar
imaging (EPI). (d) the image acquired when eddy currents introduce significant delays in the signal
shows clear ‘ghosting’ artefacts.
Gradient pre-emphasis Gradient pre-emphasis involves modifying the signal time course provided to the gradient
amplifier to compensate for the expected effect of eddy-currents, as illustrated in Figure 3. If theproperties of the eddy-currents are known, it is possible topredict the time course of the actual
gradient for a given input waveform. With pre-emphasis, the input waveform is modified so that
the time course of the actual gradient matches the desired waveform more accurately.For the purposes of pre-emphasis, eddy-currents are typically modelled as multiple components,each with a given amplitude and decay rate constant. The parameters of the different eddycurrent components are measured during routine maintenance as part of the calibration of theMRI scanner, and stored on the system for use in gradient pre-emphasis.5CCYB041Object-Oriented Programming
Page 3 of 6
Coursework 1Figure 3: illustration of gradient pre-emphasis. (a) the desired gradient waveform. (b) the actual gradient
time course obtained differs due to the effects of eddy-currents. (c) with pre-emphasis, a modifiedwaveform is provided as input to the amplifier, designed in such a way that the actual gradient time
course matches the desired waveform.
Instructions
Your task in this coursework is to write a C++ program to implement a simple gradient preemphasis strategy. This program should perform the following main steps (these are described inmore detail below):
- Load the parameters describing the eddy-currents for the system from the file provided.
- Load the desired time course for the gradient from the file provided.
- Make a copy the desired time course, which will be the initial input gradient time course.
- Compute the predicted time course for the input time course by taking the effects of eddycurrents into account.
- Compute the maximum absolute deviation between the desired and predicted timecourses, and display this value on the terminal
- Display the input and predicted time courses on the terminal.
- Compute the difference between the desired and predicted time course.
- Add that difference back to the current input time course.
- Go back to step 4 and repeat for the desired number of iterations
- If requested, write the final estimate of the compensated input time course to the file
specified on the command-line
Command-line interface
Your program should accept at least 2 arguments: the configuration file containing the parameters
for the eddy-currents, and the file containing the desired time course. If a third argument is
provided, this should be interpreted as a request to store the estimated compensated time courseto the file specified in that argument.Your program should also accept a “-n num” command-line option to override the default number
of iterations. If left unspecified, the default number of iterations should be set to 10.5CCYB041Object-Oriented ProgrammingPage 4 of 6
Coursework 1Loading the input data You are provided with a text file called parameters.txt file containing the eddy-currentparameters. Each line in this file contains two values: the amplitude and the rate constant for each
eddy-current component.You are also provided with a text file called gradient.txt file containing the intensity values atregular sampling intervals for the desired gradient time course.Computing the predicted gradient time course The impact of the eddy-currents can be predicted using a simple model. Each eddy-currentcomponent can be modelled independently, and will have an associated current 𝐼rrentcomponent.
- 𝑁 is the number of eddy-current components listed in the parameter file.omputing the compensated time course The compensation to be applied to the waveform can be computed using the following iterativeapproachGiven the desired waveform:
- Initialise the current estimate of the (compensated) input waveform as the desiredwaveform
- Repeat for the desired number of iterations:
o Compute the predicted waveform for the current input waveform
o Compute the difference between the desired and predicted waveforms
o Add the computed difference to the current input waveform, to produce the next
estimate of the input waveform5CCYB041
Object-Oriented Programming
Page 5 of 6
Coursework 1
Displaying the waveforms
The various waveforms can be displayed using the terminal_graphics library. Refer to the relevant
course slides and the project README for detailed instructions.
Briefly: download the terminal_graphics.h header and place it in your project folder, alongsideyour own code. Make sure to #include that header into your code. Then use the TG::plot()functionality as illustrated below:
#include "terminal_graphics.h"
...std::vector<float> desired_gradient, predicted_gradient;
...TG::plot (width, height)
.add_line (desired_gradient).add_line (predicted_gradient, 3);Writing the final compensated time course Your program should only store the output if provided with a third argument on the command
ine. If this is the case, you should write the final compensated time course to the file specified as
he last argument, in the same format as the original desired time course.
Example output The example below only shows the initial and last iteration of the algorithm:5CCYB041Object-Oriented ProgrammingPage 6 of 6
Coursework 1
Reporting Requirements
You should submit a C++ project that meets as many of the requirements as possible. You do notneed to submit any written report but do try to use variable/function naming, comments andindentation to make your program as easy to understand as possible. Also try to make yourprogram as resilient to runtime errors as possible.Submission will be via the KEATS system. The submission point will only allow you to upload asingle file so you should combine all files into a single ZIP file. Please only include your .cpp and.h files (please run “oop_build clean” first to remove any executables or object files).The hand-in date is 25 Feb 2025, 4 pm. Late submissions (within 24 hours of this deadline) will
be accepted but will be capped at the module pass mark (i.e. 40%).If your program does not meet all requirements, then please submit what you have written by thedeadline.
Assessment Your coursework will be marked on a number of factors:
- Does the program work? Does it meet all requirements? Has it been tested extensively?
60%)
- Program design and appropriate use of C++ language features, e.g. control structures,unctions, data types, etc. (30%)
- Use of comments, indentation and variable/function names to make code easy to
understand (10%The overall mark for this coursework will make up 10% of your total mark for this module.
This is an individual assignment. You are not permitted to work together with any other student. Note that general discussions about design decisions and/or coding strategies are
permitted, and such discussions can be a useful learning experience for you. But you should not,under any circumstances, share details of designs or code.
Code generated using AI assistants, etc. is also not permitted. While these tools may
(potentially) be useful in your learning to help clarify certain concepts, this is only true if they areused very cautiously and sparingly. Over-reliance on these tools to give you ready answers willinhibit your learning by preventing you from working things out for yourself. This will result in
failure in the final exam where you will have no access to these tools (note that the final exam
accounts for 60% of the overall marks on this module). We therefore strongly discourage the useof any form of AI assistants – in our opinion (and that of many others), these are detrimental toyour performance on the course.If you have any questions about this coursework please contact: J-Donald Tournie
浙公网安备 33010602011771号