Applied Computational Intelligence and Soft Computing

Volume 2016, Article ID 6304915, 6 pages

http://dx.doi.org/10.1155/2016/6304915

## Cat Swarm Optimization Based Functional Link Artificial Neural Network Filter for Gaussian Noise Removal from Computed Tomography Images

^{1}Department of EEE, BIT Mesra, Ranchi, India^{2}Department of ECE, BIT Mesra, Ranchi, India

Received 25 November 2015; Revised 1 April 2016; Accepted 5 April 2016

Academic Editor: Thunshun W. Liao

Copyright © 2016 M. Kumar et al. This is an open access article distributed under the Creative Commons Attribution License, which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.

#### Abstract

Gaussian noise is one of the dominant noises, which degrades the quality of acquired Computed Tomography (CT) image data. It creates difficulties in pathological identification or diagnosis of any disease. Gaussian noise elimination is desirable to improve the clarity of a CT image for clinical, diagnostic, and postprocessing applications. This paper proposes an evolutionary nonlinear adaptive filter approach, using Cat Swarm Functional Link Artificial Neural Network (CS-FLANN) to remove the unwanted noise. The structure of the proposed filter is based on the Functional Link Artificial Neural Network (FLANN) and the Cat Swarm Optimization (CSO) is utilized for the selection of optimum weight of the neural network filter. The applied filter has been compared with the existing linear filters, like the mean filter and the adaptive Wiener filter. The performance indices, such as peak signal to noise ratio (PSNR), have been computed for the quantitative analysis of the proposed filter. The experimental evaluation established the superiority of the proposed filtering technique over existing methods.

#### 1. Introduction

CT imaging is one of the modern noninvasive medical imaging modalities, where the X-ray beam and digital geometry processing are used to generate slices of a two-dimensional image. The X-ray beam is scanned around the body to form many views or projection. The detector senses the acquired data and store them in the computer memory for processing. After that the algorithm like “Back projection” is used for image reconstruction. The volumetric data set can be further used to construct 3D images of human organs. CT imaging can provide quality visual information regarding human tissues at a particular time. Presently, CT imaging is becoming an indispensable part of the medical treatment process [1, 2]. CT images can be distorted at any stages, such as during acquisition, processing, compression, storage, transmission, and reproduction. It may result in a degradation of the medical image quality, which restricts the further applications of the output images [3].

CT images can get noisy due to Gaussian noise. It creates unnecessary low contrast images and makes difficulties in the minute observation of any abnormalities or disease. The Gaussian noise consists of a high-frequency component in noisy medical images [4]. Hence, the low pass filters like the mean or moving average filter could be a solution to this problem. Unfortunately, these filters blur the crucial edge information of the medical image. The medical image denoising is image specific and depends on the characteristics of noise. The selection of a filter is a critical task for any automated system, and to make it feasible according to hardware implementation, its algorithm should be computationally cheap. So, to avoid such problems, adaptive image filters like the “Wiener” filter, Artificial Neural Networks (ANNs) filter, and so forth were introduced [5, 6]. The “Wiener” filter is an optimal linear adaptive approach, and under the ideal circumstances, “Wiener” filters work very efficiently. In the last two decades, the ANNs have been playing a vital role in nonlinear image processing. ANNs can be used for a range of applications, such as image classification, recognition, preprocessing, and feature extraction.

In fact, in the case of a real image, noises are highly nonlinear in nature and sometimes not easy to express mathematically. Hence, in such cases, a nonlinear adaptive filter is required to solve the problem. The literature shows that ANNs can be applied in the designing of a nonlinear adaptive filtering. Initially, the supervised feed-forward ANNs filters were implemented by many researchers to develop a nonlinear image filter [7–9]. It consists of input, hidden, and output layers. The selection of the hidden layer and computational time is always an issue for the researcher. FLANN was initially developed by Pao [10] and it has expanded inputs based on some of the functional expansions like trigonometric expansion, Chebyshev expansion, power series expansion, and so forth. It can be assigned to a nonlinear task in a very efficient manner. The merit of FLANN accounts for the fact that it is simple in algorithm design and implementation. It takes less computational time than the ordinary feed-forward network like MLP and so forth [11]. So, FLANN was introduced and it can solve any nonlinear problem more efficiently than any other competitive networks. The structure of FLANN is a single layer neural network unlike the multilayer network. It is easy to design conducting less computational time [12]. Earlier, ANN and its variants training or updating of weights was based on the gradient search algorithms like Least Mean Squares (LMS), Back Propagation (BP), Recursive Least Square (RLS), and so forth. The limitation of these types of algorithms is that they can be fixed at a local optimum point and the derivative function should be continuous. Hence, to avoid the gradient insufficiency, heuristic or evolutionary computing techniques are to be employed in the training of ANNs [13–17]. The authors in [18] highlight the accurate application of CSO to solve different optimization problems in less computational time. The authors in [19] introduce an algorithm, that is, Enhanced Parallel Cat Swarm Optimization (EPCSO), to provide the routing scheme for wireless sensor network (WSN), so that the power consumption of sensors node can be minimized. Similarly, the authors in [20] applied CSO in solving multiobjective optimization problems and their benefits over other nature inspired techniques.

The principal objective of this paper is to restore a CT image from Gaussian noise by using a CS-FLANN filter. The Cat Swarm Optimization (CSO) has been introduced for the selection of optimum weight of the neural network, so that cost function, that is, error, can be minimized. The layout of the paper is as follows: Section 2 describes the way in which LMS-FLANN and CSO-FLANN filter are applied for CT image denoising. Section 3 is dealing with simulation studies and the results of the different proposed methodology. Section 4 highlights the conclusion and some future scope of the work.

#### 2. CSO Based FLANN Filter

##### 2.1. Cat Swarm Optimization

The CSO was first introduced by Chu and Tsai in the year 2007 to achieve better performance than the PSO [21]. The behavior of a cat in searching for its prey is modeled to solve the optimization problem by employing a new set of learning mechanisms. Interestingly, the CSO cat corresponds to a particle in PSO, and little bit difference is in its algorithm [22]. Cat activities are divided into two phases or modes, that is, the seeking phase and the tracing phase. In the seeking phase the cat observes the surrounding region and attempts to move the next position. Similarly, in the tracing phase, the cats chase some desired targets. If they find a nearest potential prey, they immediately shift themselves into the tracing phase [23, 24]. The seeking phase corresponds to a global search procedure in the optimization problem, whereas the tracing phase corresponds to a local search procedure. The parameters such as seeking memory pool (SMP), count dimension change (CDC), and mixed ratio (MR) are to be fixed. Next, the fitness values of all the candidate points are to be calculated and then assigned a similar probability to identical fitness function of the cats. Otherwise, calculate the selecting probability of each candidate point using (1). In this mode only best, maximum, and minimum fitness values are to be calculated and it can be further used in tracing mode or to solve optimization problems. In tracing mode the velocity and the position are to be assigned to each candidate. In every iteration, the fitness function values of cats are evaluated, and according to the best fitness values results will be preserved in the computer memory arrays. The algorithm is executed until the termination condition criterion is satisfied; otherwise, all the processes are recurring all over again according to the CSO algorithm; the behavior of a cat is customized as follows.

*Seeking Mode.* Probability is as follows:

*Tracing Mode.* Velocity is as follows: where dimension isand position iswhere , are the fitness value and probability of each candidates. Similarly, is the inertia weight, is the acceleration constant, and is any random values between 0 and 1. are the global and present positions, respectively. The algorithm of a CSO is given in Algorithm 1.

*Algorithm 1. *Algorithm for Cat Swarm Optimization is as follows.*Step 1*. Initialization of random position of cats in dimensional space that is, .*Step 2.* Initialization of random cat velocity as .*Step 3*. Cats are randomly picked from the population according to the mixture ratio; assign cats for seeking mode and tracing mode.*Step 4*. The fitness of each cat should be calculated and accordingly the local position and global position of cat will be assigned.*Step 5*. The previous global best and recent global best position are compared according to fitness function and according to that save the best one.*Step 6*. For a new population the cat’s position and velocity will be updated using (2) and (4).*Step 7*. Check the termination condition; if satisfied, terminate the program; otherwise, repeat Steps 4–6.

##### 2.2. CS-FLANN Filter

In the proposed work, selected nine noisy input pixels from a sliding window of size are exponentially expanded after a randomly generated weight “” is assigned to expand the input. logsig() is used as an activation function to obtain the estimated output, that is, “.” The desired value “” which is a middle pixel of the reference image is used to calculate the estimated error “.” Similarly, the whole process will be applied all over the same noisy image. The architecture and equations used for FLANN are as follows: Noisy few pixels exponentially expanded as Exponentially expanded noisy pixel array Estimated output Error LMS for weight updating of the LMS-FLANN filterwhere and represent the new weight and the previous weight, respectively. Similarly, obtain error is “” and “” is the learning rate of FLANN-LMS filter. In the CS-FLANN filter, to avoid the programming complexity and to reduce the training computational time, we introduced certain modification in seeking mode of proposed filter. Initially, we initialize the arbitrary sets of weights and the arrangement of weights will be as follows.

Sets of weights For each set of weights the error will be evaluated and according to the minimum error, the single set of best weight positions will be stored. The tracing parts (12) and (13) are used for generation and updating of new weight and velocities of candidates. By comparing the fitness of previous cost function and current cost function, the global best weight is stored.

For the next iteration, the velocity and the weight position are initialized by using (12) and (13). The above process will continue for “” number of times.

Equations (7) and (8) imply the following.

Fitness function:

New velocity:

New weight position: where and are the numbers of rows and columns of an image. , are the global best weights and the positions of weight of the th iteration. Similarly, , , and are the inertia, acceleration constant, and the randomly generated values ranging between 0 and 1, respectively. Figure 1 shows the basic structure of the FLANN filter. The adaptive algorithms LMS and CSO are applied for the training of proposed filter. The parameter-like error is utilized in the updating weights of FLANN.