FPGA implementation on MRI brain classification using support vector machine by Abdullah, Noramalina
 vi 
 
 
 
TABLE OF CONTENTS 
 
 
 
 
CHAPTER        TITLE           PAGE 
 
 
 
DECLARATION       ii 
ACKNOWLEDGEMENT      iii 
ABSTRACT        iv 
ABSTRAK        v 
TABLE OF CONTENT      vi 
LIST OF FIGURES       ix 
LIST OF ABBREVIATIONS     x 
 
         
  
 1   INTRODUCTION        
 
1.1 Introduction                                                              1                   
 1.2  Objective of the Research       2 
1.3 Problem Statement                      3
 1.4 Scope of the Research      4
 1.5 Dissertation Layout                 4
   
 
 vii 
2  LITERATURE REVIEW      
 
2.1 Introduction                                                               5 
2.2 Medical imaging      6 
2.3 Magnetic Resonance Imaging and Brain Tumors  7 
 
2.4 Motivation for Automated Classification   8 
2.5 Medical imaging using FPGA    12 
 
2.6 Thesis Contribution       14
  
 
 
     
3   IMAGE PROCESSING AND FPGA IMPLEMENTATION 
 
3.1 Introduction       15 
3.2 Image Processing      15
 3.3 Medical Imaging             17
             3.3.1  Magnetic Resonance Imaging ( MRI ) 
3.4  Brain Images of MRI      18 
   3.5       Image De-Noising using Discrete Wavelet Transform 19
  3.6 Feature Extraction       23 
3.7 Machine Learning and Classification    24
 3.8 Programmable Logic Devices ( PLD )   26 
3.9       Field Programmable Gate Arrays ( FPGA )                           28 
3.10     FPGA Implementation For Image Processing   28
 3.11 NIOS II as embedded processor    30
  
 
 
 
 
 
 viii 
4  METHODOLOGIES   
        
                        4.1      Introduction       33 
                        4.2      Research Flow Overview     33 
                        4.3      Input Data        34 
                        4.4      Image Processing      35
   4.4.1  Image De-noising and Wavelet Transform 
                           4.4.2  Feature Extraction 
4.5     Classification using Support Vector Machine   40 
4.6    Algorithm Implementation On FPGA based Platform  43 
     
5      RESULT AND DISCUSSION   
                                  
5.1 Introduction        50
 5.2 Normal and abnormal MRI Brain Images   51
 5.3  Implementation of Wavelet–based feature extraction 53
 5.4  Feature Extraction      54 
5.5 Classification using Support  Vector Machine                       55 
5.6 Running C programming in NIOS processor   57
 5.7 Discussion                  60
   
 
6      CONCLUSIONS AND FUTURE WORKS 
 
6.1 Conclusion                                                                          61
 6.2 Future Works                             62 
 
REFERENCES                               63 
 
Appendices A-D                        71 - 74 
 
 ix 
 
 
 
 
LIST OF FIGURES 
 
 
 
 
 
FIGURE NO.       TITLE                           PAGE 
 
 
 
2.1  The process of Magnetic Resonance Imaging   7 
 
3.1    Wavelet transform of an image Y up to level two   31 
 
4.1   The overflow of each stage which involved in this research  34 
 
4.2   The Graphic User Interface (GUI) which used in Matlab 2009  38 
 
4.3   The parameter which have been set by default  from the file  41
  ‘svm.train.exe’. 
4.4  The selection of file’s type in Quartus-II    44 
4.5    The type of hardware to be specified     45 
 
4.6  The setting in NIOS-II System Library     46 
 
4.7    The setting on software component     47 
 
4.8   The selection of NIOS II C/C++ Application In Nios’s   48 
  project window 
 
5.1  Axial, FLAIR T2-weighted MR brain images: (a) normal brain;  51 
  (b) abnormal brain 
 
5.2   The shape of lateral ventricle      51 
 
5.3  The shape and appearance of lateral ventricles is not clear  52 
 
5.4  Implementation of level 2 Daubechies 4 on Brain MRI using           53 
Wavelet Toolbox 
5.5  A part of text that shows the display of training set   55 
 x 
5.6  The overflow of setting in NIOS for algorithm implementation        57 
 
5.7             The C programming is successfully run in NIOS without any error   58 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 xi 
 
 
 
 
 
LIST OF ABBREVIATIONS 
 
 
 
 
 
AWGN - Additive White Gaussian Noise  
AMDI  - Advanced Medical and Dental Institute    
ANN  - Artificial Neural Network  
ASICs  - Application Specific Integrated Circuits  
CPLD  - Complex Programmable Logic Devices  
CT  - Computed Tomography  
CEM  - Constrained energy minimization  
DAUB-4 - Daubechies-4  
DSP  - Digital Signal Processing  
DWT  - Discrete Wavelet Transform  
DDR  - Double-Data Rate  
EDS  - Embedded Development Suite  
EM  - Expectation-Maximization  
FPGA  - Field Programmable Gate Arrays   
FLAIR  - Fluid Attenuated Inversion Recovery  
GPP  - General Purpose Processor  
GRE  - Gradient Echo  
GUI  - Graphic User Interface  
GM  - Gray Matter  
WM  - White Matter 
CSF  - Cerebral Spinal Fluid  
K-NN  - K-Nearest Neighbors  
MRI  - Magnetic Resonance Imaging  
MMU  - Memory Management Unit  
 xii 
MPU  - Memory Protection Unit  
MDTS  - Multidimensional Time Series  
NMR  - Nuclear Magnetic Resonance  
OSP  - Orthogonal Subspace Projection  
PCI  - Peripheral Component Interconnect  
PCA  - Principal Component Analysis  
PLD  - Programmable Logic Device  
PLI  - Programming Language Interface  
QDR  - Quad Data Rate  
SOM  - Self Organization Map  
SNR  - Signal To Noise Ratio  
SE  - Spin Echo  
SVM  - Support Vector Machine  
TPM-s  - Tissue Probability Maps  
VHDL  - Very High Description- hardware Language  
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 xiii 
 
 
 
 
 
LIST OF APPENDICES 
 
 
 
 
 
 
 
APPENDIX       TITLE                        PAGE 
 
 
 
 
A    Output of wavelet approximate coefficient           69 
 
 
B   The Default Parameter For Training In SVM          70 
 
 
C   Display of output from C-programming to classify            71 
normal or abnormal 
 
D   The output from C-program to show the percentage          72 
of  accuracy 
 
    
 
 
 
 
 
 
 
