

# Edge Detection System using Pulse Mode Neural Network for Image Enhancement

S.Jagadeesh Babu Assistant Professor, Department of ECE,Dhanalakshmi College of Engineering,Chennai,India, Email:jagadeesh0406babu@gmail.com

P.Karunakaran Assistant Professor, , Department of ECE,K.L.N College of Information Technology,Madurai , India, Email:karunakaranvkp@gmail.com

> S.Venkatraman Assistant Professor, Department of ECE, Vel Tech Chennai,India. Email:venkivl18@gmail.com

I.Hameem Shanavas Assistant Professor, Department of ECE, M.V.J College of Engineering,Bangalore-67,India. Email:hameemshan@gmail.com

T.Kapilachander

Assistant Professor, Department of ECE, Sudharsan college Engineering, Trichy, India, Email:kapilachander84@gmail.com

Abstract ----Edge detection of an image reduces significantly the amount of data and filters out information that may be regarded as less irrelevant. Edge detection is efficient in medical imaging. Pulse mode neural networks are becoming an attractive solution for function approximation based on modulation. frequency Early pulse mode implementation suffers from some network constraints due to weight range limitations. To provide the best edge detection, the basic algorithm is modified to have pulse mode operations for effective hardware implementation. In this project a new pulse mode network architecture using floating point operations is used in the activation function. By using floating point number system for synapse weight value representation, any function can be approximated by the network. The proposed pulse mode MNN is used to detect the edges in images forming a heterogeneous data base. It shows good learning capability. In addition, four edge detection techniques have been compared. The coding is written in verilog and the final result have been simulated using Xilinx ISE simulator.

*Index Terms*—Edge detection, Pulse mode, Synapse multiplier, Floating point operation.

The goal of edge detection is to mark the points in a digital image at which the luminous intensity changes sharply. Sharp changes in image properties usually reflect important events and changes in objects included in the image. Edge detection

preserves the important structural properties of an image and acts in a similar way as a filter do for irrelevant data. Owing to the function approximation capabilities of neural networks, artificial neural networks can be used efficiently, instead of conventional edge detection approaches, such as: Laplacian method, Canny operator, etc... The same network hardware can be used by modifying synaptic weight, for approximating other image processing function.

Multilayer neural networks (MNNs) are used for applications taking high-resolution inputs. Therefore, if the range of the weights is small, learning is not possible with high input resolution. The proposed system uses simple floating point number to represent the synaptic weight values while the network input and output level are represented by the frequency of the pulse signal. Using the floating point operation , synaptic weights cover a very wide range thus providing MNN applications with high precision.

This work implements a new neural network based edge detection system acting as a canny operator. An improved digital pulse mode neuron was used with the following features:

# I. INTRODUCTION

•Activation function is smooth;

•Accompanying synapse multiplier is very simple.

Modeling complex functions with neural networks, increases dramatically the neural network size, stating the use of more hardware resources. Accordingly, the design of a compact neuron become indispensable in neural network implementation. The whole system is implemented on a virtex II field programmable gate array (FPGA) platform and the neuron characteristics are tested experimentally.

The remainder of this paper is organized as follows: Section II introduces the neural network based edge detector design principle. Section III describes the general architecture of pulse multilayer neural network. An improved architecture based on floating point operations in the activation function is proposed in section IV. Finally, experimental results are presented in Sections V, followed by conclusion in Section VI.

## II. NEURAL NETWORK BASED EDGE DETECTION DESIGN PRINCIPLE

In this work, canny operator is used as an edge detector. According to Canny, the optimal filter can be efficiently approximated using the first derivative of a Gaussian function . A multilayer neural network was learning the canny operator. For validation and test, a series of image data base was used. Each one is formed by a particular set such as hands (for biometry applications), mammography images (for breast cancer classification) and simple images for validation and tests such as dinosaur images, etc,... Each set is subdivided into two classes, one is for the network learning, and the other is for test of network generalization. Training of input layer is obtained by 3x3 mask sweeping the sample images. The network output is taken as the middle point in the image, resulting from the canny operator. Back propagation algorithm is applied for each image data base. After testing the generalization procedure task, in each case, we memorize the parameters for further application. Once, we have the different network parameters for each set of images, we use them accordingly in forward operation [1].

## III. GENERAL ARCHITECTURE OF PULSE MODE NEURAL NETWORKS

The operation of the MNN is divided into two phase, learning phase and retrieving phase. During learning phase, weights are adjusted to perform a particular application. During the retrieving phase, data from neurons of a lower layer is propagated forward to neurons in the upper layer through feed forward connection network. Inspired by biological model, pulse mode network operations uses frequency to represent the signal levels. Synaptic weighting is therefore a frequency multiplication. Activation function is a saturation function with nonlinear characteristics, being at best programmable in an active way[2].

## IV. PROPOSED EDGE DETECTION OPERATION WITH SINGLE CANNY BLOCK STRUCTURE



Figure 1.Architecture of the Edge detection operation with single canny block

In figure 1, the test image is converted into binary format by using MATLAB. Then the binary values are multiplied with that of the weight function and forwarded to that of the neuron unit the neuron unit provides the detected edges as output.

## A. Floating Point Activation Function

The synaptic weight is represented using floating point representation as follows[1]

Figure 2. Floating point process

## B. Synaptic Unit

The synaptic unit mainly performs the operation of multiplying the weights with that of input image which is in binary format.



Figure 3.Synaptic Unit

#### С. C. Synaptic Multiplier

This block mainly performs the function of concatenation. The weights which are split into mantissa and exponential part are multiplied with the inputs. The resulting result is arranged in the concatenation block. The output of the block is fed into that of the neuron unit. The block diagram of the synaptic multiplier is shown in figure 4.



Figure 4.Synaptic Multiplier

#### D D. Neuron Unit

In the neuron unit, weighted neuron outputs from the lower layer are summed up and the outputis generated using the activation function. Every period of Tf, the sum of input weight values from synapse multipliers H(s) k is fed to the register, where it is accumulated[3]. When R is positive, +P is subtracted from the register and the output pulse of ramp function neuron is generated with a frequency equal to one. Afterwards, the content of the register alternate positive and negative and the gradient of the change is Ρ.

When  $-P \leq H(s)$   $k \leq +P$ , the content of the register becomes positive or negative alternately. Therefore, the activation function of the proposed neuron uses floating point operation is ramp function, which is given by

$$f(y) = \begin{cases} 1 & if \quad y > P \\ \frac{x}{2*P} & if \quad -P \le y \le P \\ 0 & if \quad y < -P \end{cases}$$
(1)

The neuron unit block diagram is given in figure 5.



Figure 5. Structure of Neuron Unit

#### **PROPOSED ARCHITECTURE FOR EDGE** V. **DETECTION OPERATION WITH 32 CANNY BLOCK**



Figure 6. 32 Canny Block Structure

The concept of edge detection is extended to 32 canny blocks by using single canny block as reference. The two main principles used are,

- BPN OPERATION
- GENERALIZED DELTA RULE

Back propagation algorithm aims at finding the change in weights by backtracking the obtained output to the input. The generalized delta rule states that the new updation of weights is given by the sum of the original weight and two times the difference of the original output and the difference output[4][5].

by,

The rule is given by,

$$w(t+1)_i = w(t) + 2(d_k - y_k)x_{ki}$$
 (2)

where,

 $w(t+1)_{I-}$  Updated Weights

| w(t)                      | - Original Weight     |
|---------------------------|-----------------------|
| d <sub>k</sub>            | - Original Output     |
| $\mathbf{y}_{\mathbf{k}}$ | - Reference Output    |
| x <sub>ki</sub>           | - Corresponding Input |

## VI. MODULES FOR 32 CANNY BLOCK

## A. Training of Neural Network

The block diagram for implementation of 32 canny block is shown in figure.6,

The pixels of the re-sized image are given as binary input to the neural network. Based upon the neural network trained using single canny block, the edges corresponding to the input are produced at the output.

The weights of the calculated value and the reference value are compared and the positive or the negative difference between the two values is calculated. Based upon the error calculated the hidden and output layer weights are updated and the updated values are forwarded to the input. The process is repeated for 32 blocks in a loop fashion so that the error gets totally eliminated or reduced to a very small amount. The resulting output pixel value represents the edges of the overall image[6].

## B. Updation of Hidden Layer Weights

The input pixel values are applied to the neural network unit which is denoted as  $x_p$  and is represented as[7],

$$\mathbf{x}_{p} = (\mathbf{x}_{p1}, \mathbf{x}_{p2}, \dots, \mathbf{x}_{pn})$$
(3)

The net input to the hidden layer units is given by,

$$\operatorname{net}_{pj}{}^{h} = \varepsilon_{i=1}{}^{N} w_{ji}{}^{h} x_{pi} + \theta_{j}{}^{h}$$
(4)

$$\begin{split} & w_{ji}{}^{h} - \text{weight of the corresponding hidden layer unit} \\ & x_{pi} - \text{corresponding input layer unit} \\ & \theta_{j}{}^{h} - \text{bias term (value = 1)} \end{split}$$

The outputs from the hidden layer is given by,

$$\mathbf{i}_{pj} = \mathbf{f}_j^{\,\mathrm{h}}(\mathrm{net}_{pj}^{\,\mathrm{h}}) \tag{5}$$

 $f_j^h$  – functional term of hidden layer The error at the hidden layer is given by,

$$\delta_{pj}^{\ h} = f_j^{\ h}(net_{pj}^{\ h}) \varepsilon_k \delta_{pk}^{\ o} w_{kj}^{\ o}$$
(6)

 $\delta_{pk}^{o}$  – error at the output layer

 $w_{kj}{}^{\mathrm{o}}-$  weight of the corresponding output layer unit

The updated weights of the hidden layer is given by,

$$W_{ji}^{\ h}(t+1) = W_{ji}^{\ h}(t) + \eta \delta_{pj}^{\ h} x_i$$
(7)

 $w_{ji}^{\ h}(t)$  – present weight of the hidden layer unit

 $\eta$  – learning parameter (0.05 to 0.25)

 $x_i$  – corresponding input unit

## C.Updation of Output Layer Weights

The net input to the output layer units is given

$$\operatorname{net}_{pk}^{o} = \varepsilon_{j=1}^{N} w_{ki}^{o} i_{pj} + \theta_{k}^{o}$$
(8)

 $w_{ki}^{o}$  – weight of the corresponding output layer unit  $\theta_k^{o}$  – bias term (value = 1) The results at the output layer is given by,

$$o_{pk} = f_k^{o}(net_{pk}^{o}) \tag{9}$$

 ${f_k}^{o}$  – functional term of output layer The error at the output layer is given by,

 $\delta_{pk}^{o} = (y_{pk} - o_{pk}) \tag{10}$ 

 $y_{pk}$  – present output value

o<sub>pk</sub> - reference output value

The updated weights of the output layer is given by,

$$W_{kj}^{o}(t+1) = W_{kj}^{o}(t) + \eta \delta_{pk}^{o} i_{pj}$$
 (11)

$$\begin{split} w_{kj}{}^{o}(t) &- \text{ present weight of the output layer unit } \\ i_{pj} &- \text{ output at the hidden layer } \end{split}$$

The updated hidden and output layer weights are forwarded to the input units. Based upon the new weights the above process looped around the network to calculate the edges[8].

## D.VLSI Implementation

The training of the neural network is based upon the above mathematical formulation and the coding is written in verilog. The output edges is in the form of pulse signals[9].

## **VII. EXPERIMENTAL RESULTS**

Based upon the comparison techniques above discussed a sample image has been taken and the four edge detection techniques are applied on the image. The original reference image is shown in Figure 7.

I.J. Image, Graphics and Signal Processing, 2012, 3, 42-48



Figure 7.Original reference Image

The output image of the Sobel edge detection technique is shown below. From the figure 8 we can infer that the noise performance is poor and the edge thickness is high.



Figure 8.Output of Sobel Image Technique

The output image of the Prewitt edge detection technique is shown below. From the figure 9 we can infer that the noise performance is stable and the edge thickness is high.



Figure 9. Prewit edge detection Technique

The output image of the Robert edge detection technique is shown below. From the figure 10 we can infer that the noise performance is stable and the edge thickness is medium.



Figure 10. Robert edge detection

The output image of the Canny edge detection technique is shown i below. From the figure we can infer that this technique has best noise performance and edge thickness is low. Hence canny edge detection is best suitable for neural network implementation.



TABLE .1 SUMMARY OF RESULTS

| Techniques | Noise       | Edge      |  |
|------------|-------------|-----------|--|
|            | Performance | Thickness |  |
| Sobel      | Poor        | high      |  |
| Prewitt    | Stable      | high      |  |
| Robert     | Stable      | medium    |  |
| Canny      | best        | low       |  |

The output for edge detection using single canny block is shown in fig. The 9\*9 image in the binary format is entered as input and the horizontal component, vertical component, absolute functions of horizontal and vertical component and detected edge values are produced at the output.

| 🖬 wave-default<br>File Edit Cursor Zoom Compare Bookmark Format Window                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                         |                                                                                                                                                                                                                                                                                                                                         |  |                                                  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--------------------------------------------------|--|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                         |                                                                                                                                                                                                                                                                                                                                         |  | \$\$\$\$ \$\$\$\$ \$ <u>}</u> } T.  660 <b>6</b> |  |  |
| B-9       /carnylp1         B-9       /carnylp1         B-9       /carnylp3         B-9       /carnylp5         B-9       /carnylp5 <td< th=""><th>10010001<br/>0001001<br/>0001001<br/>0000001<br/>0000001<br/>11110000<br/>00001111<br/>1010010</th><th>100/0001           000/0001           000/0001           000/0001           000000           0000001           0000001           0000001           0000001           0000001           0000001           0000001           000001           0000111           10100101           1111111           319           229           00001000</th><th></th><th></th><th></th><th></th></td<> | 10010001<br>0001001<br>0001001<br>0000001<br>0000001<br>11110000<br>00001111<br>1010010 | 100/0001           000/0001           000/0001           000/0001           000000           0000001           0000001           0000001           0000001           0000001           0000001           0000001           000001           0000111           10100101           1111111           319           229           00001000 |  |                                                  |  |  |

Figure 11.Output of 32 canny block edge detection

The verilog coding for 32 canny block edge detection has been implemented targeting chip design and the result are summarized below.

The output for edge detection using single canny block is shown in fig 12. The 3\*9 image in the binary format is entered as input. Data strobe is set to low value and the mode strobe, read/write bus is set to a high state. After giving the run command the detected edges are displayed.



Figure 12. Output of single canny block

The verilog coding has been implemented targeting chip design and the device utilization and timing summary are shown below in tables below.

| Parameter        | Value<br>for 32<br>Canny<br>block | Value for<br>Prewit edge<br>technique | Value for<br>Robert edge<br>technique |
|------------------|-----------------------------------|---------------------------------------|---------------------------------------|
| Maximum          | 30.895                            | 81 out of                             | nil                                   |
| Frequency        | Mhz                               | 3072                                  |                                       |
| Minimum input    | 23.641                            | 139 out of                            | nil                                   |
| arrival time     | ns                                | 6144                                  |                                       |
| before clock     |                                   |                                       |                                       |
| Maximum          | 8.289 ns                          | 72 out of                             | nil                                   |
| output required  |                                   | 166                                   |                                       |
| time after clock |                                   |                                       |                                       |
| Maximum          | 13.837                            | 78096 Kb                              | 30.729 ns                             |
| combinational    | ns                                |                                       |                                       |
| path delay       |                                   |                                       |                                       |

TABLE 2: COMPARISON OF RESULTS

| TABLE 3.SYNTHESIZED RESULTS OF 32 CANNY |
|-----------------------------------------|
| BLOCK STRUCTURE                         |

| Parameters             | Value            |
|------------------------|------------------|
| No of Slices           | 2936 out of 3072 |
| No of Slice Flip Flops | 838 out of 6144  |
| No of 4 input LUT's    | 4825 out of 6144 |
| No of Bonded IOB's     | 12 out of 166    |
| No of TBUF's           | 8 out of 3072    |
| No of GCLK's           | 1 out of 4       |
| Total memory usage     | 127504 Kb        |

## VIII. VIII. CONCLUSION

Thus edges of a particular image are detected by means of pulse mode neural network for a single canny block and the result is simulated using Modelsim simulator. Also four edge detection techniques are compared and showed canny is the best. Also the concept of edge detection is be extended to 32 canny blocks by using Back Propagation algorithm and it is showed that the IOB's, maximum combinational path delay and total memory usage is reduced.

### REFERENCES

[1] Alima Damak, Mohamed Krid And Dorra Sellami Masmoudi, "Neural Network Based Edge Detection With Pulse Mode Operations And Floating Point Format Precision", International Conference On Design And Technology Of Integrate Systems In Nanoscale Era (08).

- James A. Freeman, David M. Skapura (2008):"Neural Networks (Algorithms, Applications And Programming Techniques)" Pearson Education Third Edition Pg 103-108.
- [3] Alima Damak, Benoit Gosselin, Mohamed Sawan, Dorra Sellami Masmoudi AND Nabil Derbel (2007): "Modeling Of Cortical Neurons By Pulse Neural Networks" International CONFERENCE Ssd'07.
- [4] Mohamed KRID Alima DAMAK Dorra SELLAMI MASMOUDI (2006): "FPGA Implementation Of Programmable Pulse Mode Neural Network With On Chip Learning For Signature Application" International Conference Icecs'06.
- [5] Alima Damak, Mohamed Krid, Dorra Sellami Masmoudi And Nabil Derbel (2006): "FPGA Implementation Of Programmable Pulse Mode Neural Network With On Chip Learning" International Conference Dtis06.
- [6] Stavros Paschalakis, Miroslaw Bober (2004): "Real-Time Face Detection and Tracking For Mobile Videoconferencing". Siancedirect Real-Time Imaging 10 (2004), Pp. 8194.
- [7] H.Hikawa, "Digital Pulse Mode Neuron with Robust Nonlinear Activation Function", IEEE Tmns. On Neural Networks, Pp.2665-2670, IEEE 2004.
- [8] H. Hikawa (1999): "Frequency-Based Multilayer Neural Network With On Chip Learning Enhanced Neuron Characteristics". IEEE Trans.Neural Networks, Vol. 10, No. 3, Pp. 545-553.
- [9] B.Yegnanarayana (1999):"Artificial Neural Networks"Prentice Hall Of India Private Limited Pg 1-75



Jagadeesh Babu.S is currently working Assistant Professor, Department of ECE, Dhanalakshmi College of Engineering, Chennai. He has completed his Bachelor Degree in Electronics and Communication (2006), Masters in VLSI Design (2010).He has attended many Conferences in National and

International Level. His research areas are VLSI Testing, Low Power, Low Power Testing and image processing..email: jagadeesh0406babu@gmail.com



**Karunakaran.P** is currently working as Assistant Professor in the Department of ECE, K.L.N College of Information Technology, Madurai India. He has completed his Bachelor Degree in Electronics and Communication (2006), Masters in VLSI Design (2010).He had

published few journals and attended many Conferences in National and International Level. His research areas are VLSI Testing, low Power Testing and Image processing. email: karunakaranvkp@gmail.com



Venkatraman.S is currently working Assistant Professor, Department of ECE, Vel Tech, Avadi, Chennai, India. He has completed his Bachelor Degree in Electronics and Communication (2006), Masters in VLSI Design (2008) and also he completed Masters in Business

Administration (2009). He worked for various institutions in electronics and communication department around many states in India. He keeps many international publications on to his credit. His research areas are VLSI Physical Design and Testing, Low Power, Nano materials and CAD Algorithms.email:venkivl18@gmail.com.



Hameem Shanavas.I is the Doctoral Research Scholar of Anna University, Coimbatore, India. He is currently working Assistant Professor, Department of ECE, M.V.J. College of Engineering, Bangalore, India. He has completed his Bachelor Degree in Electronics and Communication (2006),

Masters in VLSI Design (2008) and also he completed Masters in Business Administration (2009). He worked for various institutions in electronics and communication department around many states in India .He had more than 30 publications in international level. He is in editorial committee of many International Journals like IJESET, WASET and reviewer for many Journals like IJESET, WASET and reviewer for many Journals like IEEE Transactions, Science Direct, VLSICS, SIPICS, and IJANS etc. He is the member of Professional bodies like ISECE, IACSIT, and IAEng. His research areas are VLSI Physical Design and Testing. Email:hameemshan@gmail.com.



Kapilachander.T is currently working Professor. Assistant of ECE, Sudharsan Department Engineering College, Trichy, India.He has completed his Bachelor Degree in Electronics and Communication (2006), Masters in VLSI Design (2008) He worked for various institution in electronics and communication department around

many states in India .He has published many journals and attended many Conferences in National and International Level. His research areas are VLSI Physical Design ,Testing, Low Power, and CAD Algorithms. email:kapilachander84@gmail.com