Motion-sensitive magnetic resonance imaging (MRI), or cine-mode MRI can be used to observe fluid flow, such as cerebral spinal (CSF) or airway or ventricular motion or any other anatomy where detection of motion is useful. Software used by an MRI system can time images to a trigger signal, such as heartbeat or breathing to capture images that are phase shifted relative to the signal to capture cinematic frames that can highlight motion relative to that trigger. However, because successive images are not truly successive or time-adjacent, the way a video image can be captured with an image sensor, the relative quality of the animation created by cine MRI is less than ideal. Traditionally, multiple acquisitions are used to reduce artifacts, leading to a slow acquisition process to improve cine MRI quality.
Described herein are systems and methods for reconstructing undersampled MRI images using a neural network. According to one embodiment, a system for recreating images from undersampled MRI image data includes an MRI imaging system comprising a plurality of magnets and RF coils configured to acquire undersampled MRI image data that include one or more images, each having a plurality of non-contiguous acquired scan lines and a processor and memory configured to execute software instructions that implement a series of cascading image enhancing stages that each produce enhanced output image data from input image data. A first stage receives the undersampled MRI image data while each remaining stage receives the output image data from a previous stage. Each stage includes a data consistency block that generates multi-coil input images by multiplying a sensitivity map, applies a first Fourier transform, replaces data in each image with the acquired scan lines at respective locations, and performs a second inverse Fourier transform. Each stage further includes a convolutional neural network (CNN) configured to estimate a regularizer term for the input image data, wherein the regularizer term attempts to minimize a difference between a true image and the output of the data consistency block. Each stage further includes a combinational block that combines the outputs of the data consistency block and CNN to create the output image data for the stage. The system further includes a memory configured to store recreated image data from a final stage of the cascading image enhancing stages.
According to one aspect of some embodiments, undersampled MRI image data includes a group of sequentially captured images of a patient. The sequentially captured images can be captured relative to a one of a patient's heartbeat and breathing. Each CNN in each stage can consider the group of sequentially captured images to create the regularizer term for each individual image. A location in k-space of the non-contiguous acquired scan lines can vary between subsequent images. According to one aspect of some embodiments, each CNN is a five-layer CNN. According to another aspect of some embodiments, the series of cascading image enhancing stages comprised eight stages. According to another aspect of some embodiments, the undersampled MRI image data is undersampled by a factor of at least 8x.
According to one embodiment, a method for recreating images from undersampled MRI image data includes receiving undersampled MRI image data that include one or more images, each having a plurality of non-contiguous acquired scan lines, and executing software instructions that implement a series of cascading image enhancing stages that together recreate images from the undersampled MRI image data, where each stage feeds an enhanced output image data to the next stage. The method further includes creating consistent data within each stage by adjusting the input image data by one of more sensitivity maps, applying a first Fourier transform, replacing data in each image with the acquired scan lines at respective locations, and performing a second Fourier transform. The method further includes estimating a regularizer term for the input image data within each stage using a convolutional neural network (CNN), wherein the regularizer term attempts to minimize a difference between a true image and the output of the data consistency block, and combining the outputs of the data consistency block and CNN to create the output image data for the stage. A recreated image data from a final stage of the cascading image enhancing stages is output.
The accompanying drawings, which are incorporated in and form a part of the specification, illustrate the embodiments of the invention and together with the written description explain the principles, characteristics, and features of the invention. In the drawings:
This disclosure is not limited to the particular systems, devices and methods described, as these may vary. The terminology used in the description is for the purpose of describing the particular versions or embodiments only, and is not intended to limit the scope.
As used herein, the terms “algorithm,” “system,” “module,” or “engine,” if used herein, are not intended to be limiting of any particular implementation for accomplishing and/or performing the actions, steps, processes, etc., attributable to and/or performed thereby. An algorithm, system, module, and/or engine may be, but is not limited to, software, hardware and/or firmware or any combination thereof that performs the specified functions including, but not limited to, any use of a general and/or specialized processor in combination with appropriate software loaded or stored in a machine readable memory and executed by the processor. Further, any name associated with a particular algorithm, system, module, and/or engine is, unless otherwise specified, for purposes of convenience of reference and not intended to be limiting to a specific implementation. Additionally, any functionality attributed to an algorithm, system, module, and/or engine may be equally performed by multiple algorithms, systems, modules, and/or engines, incorporated into and/or combined with the functionality of another algorithm, system, module, and/or engine of the same or different type, or distributed across one or more algorithms, systems, modules, and/or engines of various configurations.
As used herein, the terms “MM sequence,” “pulse sequence,” or “MM pulse sequence” are interchangeable and can include a particular combination of pulse sequences and/or pulsed field gradients that result in a particular set of MRI data. An MRI sequence can be used either individually or in combination with one or more other MRI sequences (i.e., multi-parametric MRI).
As used herein, the term “MRI data” can include an MRI image or any other data obtained via MRI (e.g., biomarker data or a parameter map). An MRI image can include a three-dimensional image or a two-dimensional image (e.g., a slice of a three-dimensional image).
Embodiments use deep learning techniques, such as convolutional neural networks (CNNs) to accelerate the construction of dynamic MRI animations. Experiments using these embodiments reveal that artifact-corrected dynamic/cine MRI images can be acquired and reconstructed with 8x-10x undersampling, making these techniques more efficient than the prior art.
These techniques can be used for any temporally dynamic imaging, such as contrast-enhanced imaging. Cine MRI is one important application that can benefit from these techniques. Techniques utilize variable splitting to solve the optimization problems of dynamic MRI. In some embodiments, information is used from temporally adjacent frames to accelerate the solution.
Generally, in MRI imaging, an MRI signal is sampled repeatedly. Each iteration improves the image quality/detail. However, each iteration takes time, often requiring multiple seconds to acquire an image. Undersampling allows faster acquisition, but estimates need to be created to fill in the missing samples. The better the estimates of the missing information, the better undersampling techniques can be used. In various embodiments, machine learning is used to fill in missing information from undersampled images.
Traditional techniques require relatively lots of time for this process. Time constraints are exacerbated in cine or dynamic imaging, making traditional approaches less desirable.
MRI images are often created using a rasterized approach, with phase encoding and frequency encoded directions. For a full image capture, each cartesian point in the phase and frequency direction is captured with the RF imaging coil. For an undersampled image, only certain phase encoding lines are captured (which includes each frequency encoding point along that sampled phase). In various embodiments of the techniques described herein, the specific phase line that is sampled varies with each subsequent image. In contrast, it is common to undersample the same phase lines when acquiring static images.
White points show the position of the phase encoding lines through subsequent frames. In each mask, the y-axis represents the location of sampled scanlines in the phase-encoding direction (where data is collected for all frequency encoding locations in that line) and the x-axis is a temporal axis, showing how scanlines change for each successive frame. In this example, successive frames can be triggered off a cardiac rhythm, allowing cine capture and animation of MRI images by shifting the phase of the image relative to the rhythm. Other trigger signals, such as breathing can also be used. In mask 12, one in eight lines are sampled, yielding 8x undersampling; in mask 14, one in ten lines are sampled, yielding 10x undersampling. A learning model can be applied to this undersampled data to fill in an approximation of the missing imaging data.
General Compressed Sensing Model: In general, the MR image reconstruction problem can be formulated as an inverse problem Fm=y, where m is the complex-valued image series formatted as an N=Nm×Ny×Nt column vector, F is the Fourier encoding matrix, and y is the measurement k-space vector. Undersampling schemes are applied in practice to accelerate the acquisition process. Because of the applied undersampling, the inverse problem formulation would change to Fum=yu, where Fu is a composite operator with size M×N includes sensitivity maps S, Fourier encoding matrix F, and binary undersampling mask U. In MR undersampled inverse problems, usually the number of measurements M is significantly less than the number of unknown N (M<<N). Thus, a direct solution is not possible because the underdetermined nature of the data allows for multiple image solutions. To solve this problem, two general approaches can be used: Parallel Imaging (PI), which relies on using channel information to turn the underdetermined set of equations into an overdetermined problem; and Compressed Sensing (CS), which takes advantage of the incoherent measurements along with appropriate regularizers to solve the underdetermined MR reconstruction problem. Embodiments focus on the second category, CS. Conventional CS algorithms estimate the reconstructed image x by minimizing the constrained optimization problem in the k-space. To solve for image m given undersampled k-space yi, the compressed sensing reconstruction can be formulated as minimizing the following optimization problem:
In the data consistency/fidelity term (first term in Eq. 1), m is the estimated image, D is the undersampling mask/matrix, F is the Fourier transform, and S denotes the sensitivity map of the MRI RF receive coils (Si is the sensitivity of the ith channel coil). λ controls the weight of the data consistency term, and the number of channels is presented by nc. The regularization term (second term in Eq. 1) R(m) generally is a sparse regularizer, such as total-variation or the first norm of the wavelet transform of m. There are two points about Equation 1 worth noting: 1) the regularizer term, R(m), is a fixed operation and has to be defined a priori; and 2) solving such an optimization problem requires an iterative algorithm which could lead to a long reconstruction time.
To optimize the above equation efficiently, variable splitting is used by decoupling m in the regularization from the data fidelity term and decomposition of S i m such that no dense matrix inversion is involved in subsequent calculations. The problem becomes a multi-variable optimization problem:
where α and β are introduced penalty weights.
To solve for the above equation, one needs to alternatively optimize m, u and xi:
Here SiH is the conjugate transpose of Si and I is the identity matrix of size N by N.
In this step, we have turned the original problem into a denoising problem (denoted by denoiser) and two other equations, both of which have closed-form solutions that can be computed pointwise. Equation 3a corresponds to CNN block, equation 3b corresponds to the data consistency block, and equation 3 is the weighted sum block in the network.
To accelerate the reconstruction process and design a more powerful regularizer based on the historical data, embodiments use a CNN to resolve the regularizer term. Embodiments apply the CS reconstruction problem in Equation 1 into a 3D neural network/CNN to accelerate the reconstruction process and learn a more powerful spatio-temporal regularizer. This regularizer term is calculated to attempt to minimize a difference between a true image and the output of the data consistency term.
To understand the effect of undersampling (or to generate training data for a CNN), a subsampling mask 14a can be multiplied by fully sampled k-space data 28, resulting in undersampled k-space data 30. As can be seen, the distribution of sampled lines in subsampling mask 14a need not be uniform and can benefit from denser sampling near the center of the k-space. When the undersampled k-space data 30 is transformed into the image domain via a Fourier transform, such as FFT 32, the resulting image 34 has artifacts from the undersampling. Various embodiments address the disparity between undersampled image 34 and fully sampled image 22 by using deep learning techniques to resolve an approximation of a regularizer term using time-adjacent images in dynamic imaging.
Undersampled images 42 include a series of undersampled dynamic/cine MRI images that progress temporally. In some embodiments, system 40 considers groups of images 42 together, rather than wholly individually. While the images change with time, the features largely relate frame-by-frame. This allows heavy under sampling, such as 8x or 10x as shown by experiments using some embodiments. Learning system 40 includes a sequentially cascading series of convolutional stages 44 (44a, 44b, 44n shown, where n is the total number of convolutional stages) forming an image reconstruction pipeline. In some embodiments, eight convolutional stages (n=8) are sufficient.
Each convolutional stage 44 includes two parallel blocks paralleling the terms of Equation 3: a data consistency block 46 that does not include a learning block; and a CNN block 48 (shown as 48a-n, as each CNN block arrives at different heuristic terms after training) that include a multi-layer convolutional neural network. A combinational block 49 adds the outputs of data consistency block 46 and CNN block 48 to create an enhanced output image set that is input to the next convolutional stage. These blocks are not intended to be means-plus-function elements, rather logical subsections of the algorithm for image reconstruction corresponding to the functional terms of Equation 1. An exemplary CNN has five layers, each with 64 nodes. Any conventional CNN algorithm can be used. The purpose of each CNN block is to learn and create a regularizer term to improve the estimated image at each convolutional stage to arrive estimated images stored in memory 50, which are close to ground truth. At each stage, the output of the data consistency block is combined with the regularizer term from the CNN. The resulting image is then fed into the next block until n blocks have iteratively improved the image.
System 40 and the relevant block are implements as software instructions in memory coupled to one or more processors, using any suitable computational hardware.
Data Preparation and Training:
The embodiment illustrated in
For training the network, five sets of data including sensitivity maps, multi-channel undersampled raw data (k-space), undersampling masks (binary masks), coil combined single-channel complex zero-filled dynamic images, and coil combined single-channel complex aliasing free dynamic images (target) are required.
For testing the network, only four sets of the data are required, including sensitivity maps, multi-channel undersampled raw data (k-space), undersampling masks (binary masks), and coil combined single-channel complex zero-filled dynamic images. Three points are considered in designing the undersampling mask: 1) initial sampling lines on (discretized) golden steps were calculated; 2) the initial calculated lines were repositioned based on a predefined density distribution; and 3) lines were sorted in a way that they zigzag across time to minimize the gradient jump.
For training the network, the Adam optimizer was used with the momentum parameter β=0.9, mini-batch size=1, and an initial learning rate of 0.0001 to minimize the L1 norm between the reconstructed dynamic images and the corresponding dynamic targets. Weights for the network were initiated with random normal distributions with a variance of σ=0.01 and meanμ=0. The network was trained for five epochs, i.e., 5×8750 iterations in an end-to-end fashion based on the five sequential cardiac frames extracted from the dynamic training data. The training was performed with the Pytorch interface on a commercially available graphics processing unit (GPU) (NVIDIA Titan RTX, 24 GB RAM). Once the network was trained, it was tested based on the full-sized dynamic images rather than five sequential dynamic frames.
At step 74, a processor that implements the trained CNN stages receives the undersampled MRI image data from the MRI imaging system. Once the processor receives the image(s), images can be run through the multi-stage CNN system explained in
Data consistency steps 78 include adjusting the input image received at each stage (e.g., by multiplying) using a sensitivity map of the MRI imaging system, at step 80. At step 82, an FFT is performed to bring the adjusted image into the k-space domain. At step 84, hard replacement of the resulting k-space data is performed, such that any lines in k-space that have been sampled and received at steps 74 and 72 are replaced with the actual lines of acquired undersampled data. This is because the predicted image for the fully sampled data should include the actual acquired lines be an accurate image. This prevents image drift as the stages progress. At step 86, once the k-space has been corrected to include the actual known data, a second FFT is performed to bring the data back to the image domain to create a data-consistent image set from the images input to the block,
At parallel step 88, the processor estimates a regularizer term for the image data input to each stage using a CNN. The regularizer term attempts to minimize a difference between a true image and the output of the data consistency block. In some embodiments, the CNN is a 5-layer CNN. In some embodiments, the CNN layers consider multiple undersampled, sequentially captured images as input for the recreation of a regularizer term for a single image.
At step 90, the processor, at each stage, combines the outputs of the data consistency block (78) and CNN (88) to create the output image data for the stage. At step 92, if there are any remained stages in the cascading pipeline, the resulting image data is passed to the next stage, where that stage implements steps 78-90 (using a CNN that has been uniquely trained for each stage for step 88). In some embodiments, there are eight stages used. Once there are no remaining stages, the processor stores and outputs a recreated image data from a final stage of the cascading image enhancing stages, at step 94. This image data includes a series of predicted fully sampled dynamic images from the undersampled data received at step 74.
Medical Imaging System Architecture:
In some embodiments, the systems and techniques described above can be implemented in or by a medical imaging system, such as the medical imaging system 800 illustrated in
Computer system 801 may also include a main memory 804, such as a random access memory (RAM), and a secondary memory 808. The secondary memory 808 may include, for example, a hard disk drive (HDD) 810 and/or removable storage drive 812, which may represent a floppy disk drive, a magnetic tape drive, an optical disk drive, a memory stick, or the like as is known in the art. The removable storage drive 812 reads from and/or writes to a removable storage unit 816. Removable storage unit 816 may be a floppy disk, magnetic tape, optical disk, or the like. As will be understood, the removable storage unit 816 may include a computer readable storage medium having tangibly stored therein (embodied thereon) data and/or computer software instructions, e.g., for causing the processor(s) to perform various operations.
In alternative embodiments, secondary memory 808 may include other similar devices for allowing computer programs or other instructions to be loaded into computer system 801. Secondary memory 808 may include a removable storage unit 818 and a corresponding removable storage interface 814, which may be similar to removable storage drive 812, with its own removable storage unit 816. Examples of such removable storage units include, but are not limited to, USB or flash drives, which allow software and data to be transferred from the removable storage unit 816, 818 to computer system 801.
Computer system 801 may also include a communications interface 820. Communications interface 820 allows software and data to be transferred between computer system 801 and external devices. Examples of communications interface 820 may include a modem, Ethernet card, wireless network card, a Personal Computer Memory Card International Association (PCMCIA) slot and card, or the like. Software and data transferred via communications interface 820 may be in the form of signals, which may be electronic, electromagnetic, optical, or the like that are capable of being received by communications interface 820. These signals may be provided to communications interface 820 via a communications path (e.g., channel), which may be implemented using wire, cable, fiber optics, a telephone line, a cellular link, a radio frequency (RF) link and other communication channels.
In this document, the terms “computer program medium” and “non-transitory computer-readable storage medium” refer to media such as, but not limited to, media at removable storage drive 812, a hard disk installed in hard disk drive 810, or removable storage unit 816. These computer program products provide software to computer system 801. Computer programs (also referred to as computer control logic) may be stored in main memory 804 and/or secondary memory 808. Computer programs may also be received via communications interface 820. Such computer programs, when executed by a processor, enable the computer system 801 to perform the features of the methods discussed herein. For example, main memory 804, secondary memory 808, or removable storage units 816 or 818 may be encoded with computer program code (instructions) for performing operations corresponding to various processes disclosed herein.
Referring now to
It is understood by those familiar with the art that the system described herein may be implemented in hardware, firmware, or software encoded (e.g., as instructions executable by a processor) on a non-transitory computer-readable storage medium.
In the above detailed description, reference is made to the accompanying drawings, which form a part hereof. In the drawings, similar symbols typically identify similar components, unless context dictates otherwise. The illustrative embodiments described in the present disclosure are not meant to be limiting. Other embodiments may be used, and other changes may be made, without departing from the spirit or scope of the subject matter presented herein. It will be readily understood that various features of the present disclosure, as generally described herein, and illustrated in the Figures, can be arranged, substituted, combined, separated, and designed in a wide variety of different configurations, all of which are explicitly contemplated herein.
Aspects of the present technical solutions are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatuses (systems), and computer program products according to embodiments of the technical solutions. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
These computer readable program instructions can be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions can also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions can also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present technical solutions. In this regard, each block in the flowchart or block diagrams can represent a module, segment, or portion of instructions, which includes one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the blocks can occur out of the order noted in the figures. For example, two blocks shown in succession can, in fact, be executed substantially concurrently, or the blocks can sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
A second action can be said to be “in response to” a first action independent of whether the second action results directly or indirectly from the first action. The second action can occur at a substantially later time than the first action and still be in response to the first action. Similarly, the second action can be said to be in response to the first action even if intervening actions take place between the first action and the second action, and even if one or more of the intervening actions directly cause the second action to be performed. For example, a second action can be in response to a first action if the first action sets a flag and a third action later initiates the second action whenever the flag is set.
The present disclosure is not to be limited in terms of the particular embodiments described in this application, which are intended as illustrations of various features. Many modifications and variations can be made without departing from its spirit and scope, as will be apparent to those skilled in the art. Functionally equivalent methods and apparatuses within the scope of the disclosure, in addition to those enumerated herein, will be apparent to those skilled in the art from the foregoing descriptions. It is to be understood that this disclosure is not limited to particular methods, reagents, compounds, compositions or biological systems, which can, of course, vary. It is also to be understood that the terminology used herein is for the purpose of describing particular embodiments only, and is not intended to be limiting.
With respect to the use of substantially any plural and/or singular terms herein, those having skill in the art can translate from the plural to the singular and/or from the singular to the plural as is appropriate to the context and/or application. The various singular/plural permutations may be expressly set forth herein for sake of clarity.
It will be understood by those within the art that, in general, terms used herein are generally intended as “open” terms (for example, the term “including” should be interpreted as “including but not limited to,” the term “having” should be interpreted as “having at least,” the term “includes” should be interpreted as “includes but is not limited to,” et cetera). While various compositions, methods, and devices are described in terms of “comprising” various components or steps (interpreted as meaning “including, but not limited to”), the compositions, methods, and devices can also “consist essentially of” or “consist of” the various components and steps, and such terminology should be interpreted as defining essentially closed-member groups.
As used in this document, the singular forms “a,” “an,” and “the” include plural references unless the context clearly dictates otherwise. Unless defined otherwise, all technical and scientific terms used herein have the same meanings as commonly understood by one of ordinary skill in the art. Nothing in this disclosure is to be construed as an admission that the embodiments described in this disclosure are not entitled to antedate such disclosure by virtue of prior invention.
In addition, even if a specific number is explicitly recited, those skilled in the art will recognize that such recitation should be interpreted to mean at least the recited number (for example, the bare recitation of “two recitations,” without other modifiers, means at least two recitations, or two or more recitations). Furthermore, in those instances where a convention analogous to “at least one of A, B, and C, et cetera” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (for example, “a system having at least one of A, B, and C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, et cetera). In those instances where a convention analogous to “at least one of A, B, or C, et cetera” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (for example, “a system having at least one of A, B, or C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, et cetera). It will be further understood by those within the art that virtually any disjunctive word and/or phrase presenting two or more alternative terms, whether in the description, sample embodiments, or drawings, should be understood to contemplate the possibilities of including one of the terms, either of the terms, or both terms. For example, the phrase “A or B” will be understood to include the possibilities of “A” or “B” or “A and B.”
In addition, where features of the disclosure are described in terms of Markush groups, those skilled in the art will recognize that the disclosure is also thereby described in terms of any individual member or subgroup of members of the Markush group.
As will be understood by one skilled in the art, for any and all purposes, such as in terms of providing a written description, all ranges disclosed herein also encompass any and all possible subranges and combinations of subranges thereof. Any listed range can be easily recognized as sufficiently describing and enabling the same range being broken down into at least equal halves, thirds, quarters, fifths, tenths, et cetera. As a non-limiting example, each range discussed herein can be readily broken down into a lower third, middle third and upper third, et cetera. As will also be understood by one skilled in the art all language such as “up to,” “at least,” and the like include the number recited and refer to ranges that can be subsequently broken down into subranges as discussed above. Finally, as will be understood by one skilled in the art, a range includes each individual member. Thus, for example, a group having 1-3 components refers to groups having 1, 2, or 3 components. Similarly, a group having 1-5 components refers to groups having 1, 2, 3, 4, or 5 components, and so forth.
Various of the above-disclosed and other features and functions, or alternatives thereof, may be combined into many other different systems or applications. Various presently unforeseen or unanticipated alternatives, modifications, variations or improvements therein may be subsequently made by those skilled in the art, each of which is also intended to be encompassed by the disclosed embodiments.