联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-23:00
  • 微信:codinghelp

您当前位置:首页 >> C/C++编程C/C++编程

日期:2025-03-05 10:32

Object-Oriented Programming Page 1 of 6 Coursework 1

BEng Biomedical Engineering

Object-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 of

internal 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 by

dedicated gradient coils (Figure 1, right); and radio-frequency coils to excite the nuclear spins

(typically 1H) 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 the 1H

nuclear 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 is

done by driving very large currents through the gradient coils and switching them rapidly on &

off at appropriate times along the appropriate axes.

5CCYB041

Object-Oriented Programming Page 2 of 6 Coursework 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, the 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 in

Figure 2, showing how an ideal trapezoidal input waveform will end up distorted and lagging

behind what was expected, and the resulting impact on images acquired using echo-planar

imaging (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 invariably

problematic. 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 the

properties of the eddy-currents are known, it is possible to predict 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 eddy current components are measured during routine maintenance as part of the calibration of the

MRI scanner, and stored on the system for use in gradient pre-emphasis.

5CCYB041

Object-Oriented Programming Page 3 of 6 Coursework 1

Figure 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 modified

waveform 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 pre emphasis strategy. This program should perform the following main steps (these are described in

more detail below):

1. Load the parameters describing the eddy-currents for the system from the file provided.

2. Load the desired time course for the gradient from the file provided.

3. Make a copy the desired time course, which will be the initial input gradient time course.

4. Compute the predicted time course for the input time course by taking the effects of eddy currents into account.

5. Compute the maximum absolute deviation between the desired and predicted time

courses, and display this value on the terminal

6. Display the input and predicted time courses on the terminal.

7. Compute the difference between the desired and predicted time course.

8. Add that difference back to the current input time course.

9. Go back to step 4 and repeat for the desired number of iterations

10. 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 course

to 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.

5CCYB041

Object-Oriented Programming Page 4 of 6 Coursework 1

Loading the input data

You are provided with a text file called parameters.txt file containing the eddy-current

parameters. 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 at

regular 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-current

component can be modelled independently, and will have an associated current 𝐼𝑛 (with initial

value zero). The instantaneous chance in the gradient, 𝑑𝐺, causes the current to increase in

proportion. At the same time, the resistance in the system causes the current to reduce in

proportion to the magnitude of the current. The predicted gradient is then given as the input

gradient minus the eddy-current contributions, which is the sum of their currents weighted by

their respective amplitude parameter.

This can be written in simplified form as:

𝑑𝐺𝑡 = 𝐺𝑡 − 𝐺𝑡−1

𝐼𝑛,𝑡 = 𝐼𝑛,𝑡−1 + 𝑑𝐺𝑡 − 𝑅𝑛 × 𝐼𝑛,𝑡−1

𝐺𝑡

′ = 𝐺𝑡 − ∑𝐴𝑛 × 𝐼𝑛,𝑡

𝑁

𝑛

where:

• 𝐺𝑡 and 𝐺𝑡

are the input and predicted waveforms at time point 𝑡 respectively

• 𝐼𝑛,𝑡

is the value of the current at time point 𝑡 for the nth eddy-current component

• 𝐴𝑛 and 𝑅𝑛 are the amplitude and rate constant parameters for the nth eddy-current

component.

• 𝑁 is the number of eddy-current components listed in the parameter file.

Computing the compensated time course

The compensation to be applied to the waveform can be computed using the following iterative

approach:

Given the desired waveform:

• Initialise the current estimate of the (compensated) input waveform as the desired

waveform

• 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 waveform

5CCYB041

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, alongside

your 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 line. If this is the case, you should write the final compensated time course to the file specified as

the 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:

5CCYB041

Object-Oriented Programming Page 6 of 6 Coursework 1

Reporting Requirements

You should submit a C++ project that meets as many of the requirements as possible. You do not

need to submit any written report but do try to use variable/function naming, comments and

indentation to make your program as easy to understand as possible. Also try to make your

program as resilient to runtime errors as possible.

Submission will be via the KEATS system. The submission point will only allow you to upload a

single 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 the

deadline.

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,

functions, 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 are

used very cautiously and sparingly. Over-reliance on these tools to give you ready answers will

inhibit 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 use

of any form of AI assistants – in our opinion (and that of many others), these are detrimental to

your performance on the course.

If you have any questions about this coursework please contact: J-Donald Tournier (jacques donald.tournier@kcl.ac.uk).


版权所有:留学生编程辅导网 2020 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp