## Y. Y. Bilinskiy Cand. Sc. (Eng.),Ass. Prof.; V. Y. Bilinskiy; A. O. Mel'nichuk REPRESENTATION OF EDGE LOCATION DETECTOR ON PLIC OF COMPANY XILINX

Hardware representation of edge location detector is presented in the article. The offered parallel conveyer algorithm of image processing in which, the parallel-recursive processing of data using Gauss filters with different degrees of blur is executed at the first stage. At the second stage the conveyer processing of data which make part of "sliding window" is executed. For realization of such device, the PLIC Khs3s1000 family of Spartan-3 of company Xilinx is selected.Circuit synthesis was executed in CADD of Xilinx Project Navigator 7.1, modeling was executed by means of the simulation program f ModelSim SE PLUS 5.1. Such realization of device allowed to improve the detector operation rate 20-25 times.

Keywords: image preprocessing, rolling, pixel, low frequency filter, programmable logical integrated circuit

**Introduction.** Linear processing operation, with a "sliding window" is the basis for many procedures of images processing, the essence of the operation is that some limited two-dimensional area, "window of processing", consistently occupies all possible positions in image plane. The value of one initial image indication is calculated for every window position using its indication values, which are within this window [1].

Spatially-invariant processing of such type is described by general relation [2]:

$$g(n,m) = G[\{f(n-k,m-l)\}, (n,m) \in D],$$
(1)

where f(n,m), g(n,m)- two-dimensional sequence of indications of input and output images accordingly; G –change operator; D – finite set of indications plural, which defines the processing window dimensionality.

It means that the discrete image signal value at the system output is the result of digital convolution of input discrete signal with finite- pulse characteristic - FIR-filter. However, such convolution calculation has practical value only for small dimensionalities of window and small images, since calculation volume is proportional to the dimensionality of the window and image.

**Prior information sources analysis.** Many rapid convolution algorithms for FIR-filters are known nowadays, but because of data processing complexity, it is hardly possible to process the image rapidly, using them. Another approach aimed at processing speed increasing is the hardware realization of digital filters, which requires application of complex devices and large hardware resources. In this case, the most effective version of hardware realization is usage of programmable logical integrated circuits (PLIC).

PLIC become the most widely spread element base for using in digital signals processing (DSP). Due to developed architecture, high clock rate and low price, PLIC are irreplaceable for prototyping and short-run production.

There exists some architectures

of digital FIR-filters on PLIC: parallel, serial and serial-parallel. Digital filters with parallel architecture have the best performance and minimum delay, but require a lot of logical resources of the microcircuit. Serial filters have the least performance and maximal delay, but they are more compact, as compared with devices having parallel architecture [3].

In [4, 5] the method of refined edge detection is offered, based on the finding of intersections of common points between the filtered images due to application of low-frequency Gauss FIR-filters with different blur level, which can be described by the expression:

$$J(x,y) = p(H^*(n,m)|_{\sigma^1} - H^{**}(n,m)|_{\sigma^2}),$$
(2)

where  $H^*(n,m)$ ,  $H^{**}(n,m)$  – images, resulted from the low-frequency filtration with the appropriate blur levels of  $\sigma 1$  i  $\sigma 2$ ; p – scaling index.

Refined edge can be obtained, using the elementwise conversion :

$$h(n,m) = \begin{cases} 1, & \text{if } J(n-1), m \end{pmatrix} \cdot J((n),m) < 0 \\ 1, & \text{if } J(n-1), m \end{pmatrix} \cdot J((n),m) = 0 \\ J_{J((n-1),m) \neq J((nm))}; \\ 0, & \text{if } J(n-1), m \end{pmatrix} \cdot J((n),m) \ge 0. \end{cases}$$
(3)

Since the basic processing labour-consumption of such method is concentrated in the arithmetic convolution operations, and two convolution operations are used in this method, then processing time grows practically twice.

The goal of research is to increase processing speed of edge detector, based on the lowfrequency PLIC-based Gauss filter.

Materials and results of investigations. The parallel conveyer algorithm of preliminary image processing, according to which the parallel-recursive data processing with low-frequency Gauss filters with different blur levels is executed at the first step. At the second step, the elementwise subtraction operation of two filtered images are executed.

The flow diagram of such processing is showed in Figure 1. Such detector has input/output devices, two buffer storages (MS1, MS2), which provide continuous information recording and read-out, two Gauss filters (GF), and also elementwise subtraction arithmetic operations device (Sub).

In Figure 2 the filter flow diagram is shown, which assumes the performance of five arithmetic operations over each pixel. Such filter consists of multiplexing devices (MD), elementwise addition devices (ADD) and registers (Rg), for storage of input data of the pixel which is processed, and data of processing results.



Figure 1. Structural diagram of the edge detector device

As such processing is executed over the data of all pixels, according to (1), that make part of "sliding window", then for fast-acting increase, it is suggested to use some one-dimensional filters sets, which operation is synchronized in time. The Gauss one-dimensional filter from the indications consequence of input f(n) signal, with the window width size into output sequence g(n)and is described by the relation:

$$g(n) = \sum_{l=-L^{-}}^{L^{+}} h(l) f(n-l),$$
(4)

where h(l) – pulse characteristic of the filter, which equals zero over the limits of the Наукові праці ВНТУ, 2008, № 2

 $[-L^-, L^+]$  interval.

Such processing scheme provides the data read-out of every pixel, included in the processing window, with clock rate, and can be presented as a sum of K pixels values of «sliding window».

$$h(l) = \sum_{k=0}^{K-1} a_k h_k(l),$$
(5)

$$y(n) = \sum_{k=0}^{K-1} a_k h_k(n),$$
(6)

$$y_{k}(n) = \sum_{l=-L^{-}}^{L} h_{k}(l) f(n-l),$$
(7)

where  $a_k$  – indexes;  $h_k(l)$  – linearly independent basis functions, decomposed in the numerical series;  $y_k(n)$  – processing signals.

Hence, on every clock rate signal, multiplexing of these pixels on the appropriate mask coefficients is performed in pipeline manner, in every multiplexing cycle, the addition of result with previous result

is carried out. This process is executed until the end of data processing of all the pixels within the "sliding window".

Values of pixel intensity as a rule are 24-bit by 8 bits on every color of RGB system. It means that three identical one-dimensional filters, operating parallel in time can be used for filtering.

Hardware representation of parallell conveyer processing, performed by the edge detector was realized on Xilinx company PLIC of Spartan-3 families.

The attractive feature Xilinx company PLIC for DSP algorithms realization, as compared with other manufactures PLIC is internal fast-acting distributed RAM, which is arranged in the blocks of necessary size. The use of such RAM is very effective for DSP algorithms realization by means of distributed arithmetic method, and also for coefficients storage, results of intermediate calculations, etc. Thus, due to hardware facilities to provide parallel processing operation, flexible device structure adaptation for necessary algorithm, high integration efficiency of development facilities, simple construction of highly productive DSP system becomes possible on a single crystal in the shortest possible time[6].

For realization of the above-mentioned device the PLIC Xc3s1000 families of Spartan-3of Xilinx corp. is chosen, the basic characteristics are given in the Table:

Table

System gateLogical cellsDistributed memory,<br/>KbitsAvailableMaximal system<br/>frequency MHz10617 280102 103391326

Parameters of PLIC Xc3s1000 families of Spartan-3of Xilinx Corp.

Based on the analysis given in Table 1, we can make a conclusion: PLIS Xc3s1000 families of Spartan-3 satisfies all the characteristics for detector construction.

Device description at the register transmissions level was executed on VHDL language, for obtaining of PLIS geometry file, the SAPR of Xilinx Project Navigator 7.1 is used, the filter operating imitation is executed, using simulation program - ModelSim SE PLUS 5.1.

In Figure. 3 the flow diagram of device with one one-dimensional filter is shown, this filter provides 8-bit data processing by "sliding window", with dimensionality of 5x5.

The dual-port memory principle is used for continuous data processing implementation. After the recording of 2 KB data in RAM **mem0 the** next data is recorded in analogical memory **mem1**. That

is, while the first data portion is read from **mem0** and processed, the second portion is recorded from the port into **mem1**.

Input data is recorded by addresses which are set by the 12-digit counter **count12**. The data recording address bus is multiplexed by the multiplexer **mux22x2** with the data read address bus. After 2047 value is achieved, the signal **count(11)** is formed, which switches the multiplexer **mux22x2** into data address reading mode, multiplexer **mux\_8** into data reading from memory **mem0** and **mem1** mode and starts the counter by 25 module **count\_mod25**. The values **of count\_mod25** are transmitted to the input of data storage (CDS) **addr\_conv**, at the output of which the reading data address is formed by certain "sliding window" principle. After the counter overflow **count\_mod25** the **OVF** signal is formed, which initializes the counter on the 2022 module **count2022\_mod**. The result of counting is added to the result at the output (CDS) of **addr\_conv**, that allows data read executing, by the addresses of new "sliding window". Thus, the data read address through the multiplexer passes to RAM address bus. The data multiplexing operation is executed in mult by the appropriate mask coefficient, which are received from CDS **coef\_conv** by the counter addressing results **count\_mod25**.

Each 25 cycles the results of multiplication are added, as in this case 5x5 mask is used. After addition in **sum\_ 16** the division operation by the total weight coefficient of "sliding window" is executed in **div256**, the result of which is the processed data, given out in the PC port.

After the 25 cycle termination, the circuit is reset, and the reading address shifting by one digit is performed, that is, «sliding window» shift for the next pixel processing and the circuit operation is repeated.



Figure. 2. Structural diagram of one-dimentional FPC-filter

In Figure 4 the time charts of one-dimensional filter operation modeling are shown, using the digital circuits simulation program - Modelsim SE PLUS 5.1.

The results of modeling confirmed that maximum operating frequency of three one-dimensional filters of edge detection, realized on the single-crystal PLIS Xc3s1000, is 41 MHz. The circuit uses all crystal resources, and for data array processing by "sliding window" of 5x5 size, less than 30 cycles are needed.

It means that for one pixel processing, the time of  $0,73 \ \mu s$  is needed. Program realization of the same procedure using, for instance, the computer having the operating frequency of 3 GHz, the time of 3,9



Figure. 3. Basic diagram of edge detector with one one-dimentional filter, using the Xilinx Project Navigator 7.1

 $\mu$ s is needed. It enables us to make a conclusion about the higher operating rate of the device, realized on PLIC, which grew 5,2 times.

**Conclusions.** The low-frequency Gauss filter of edge detector is realized on the base of PLIC Xc3s1000 family of Spartan-3. Such realization enables to improve operation rate, and can be widely used in the devices for preliminary images processing in large arrays of data.

| 1.  |              |       |            |             |             |             |       |               |              |            |              |       |               |        |               |               |        |                |               |             |                 |               |              |        |               |                |   |
|-----|--------------|-------|------------|-------------|-------------|-------------|-------|---------------|--------------|------------|--------------|-------|---------------|--------|---------------|---------------|--------|----------------|---------------|-------------|-----------------|---------------|--------------|--------|---------------|----------------|---|
| 3.  |              |       |            |             |             |             |       |               |              |            |              |       |               |        |               |               |        |                |               |             |                 |               |              |        |               |                |   |
| 4.  | 52 I         | 53    | )54        | <u>)</u> 55 | <u>)</u> 56 | ¥57         | 158   | 159           | <u>)</u> 60  | )61        | 162          | 163   | 164           | 165    | <u>166</u>    | <u>)</u> 67   | 168    | <u>169</u>     | ¥70           | <u>Х</u> 71 | ¥72             | 173           | <u>174</u>   | ¥75    | Ĭ76           | ¥77            | h |
| 5.  | 1034         | 7     | 18         | χ9          | <u>χ</u> 10 | 111         | 263   | (264          | 1265         | (266       | 1267         | 519   | 1520          | 1521   | 1522          | )523          | 775    | 1776           | X777          | <u>)</u>    | <u>(</u> 779    | 1031          | 1032         | 1033   | 1034          | 1035           | 8 |
| б.  | 215          | 0     | )85        | χo          | χī          | 12          | 254   | 1255          | 10           | <u>)</u> 1 | 12           | 240   | 241           | 242    | (243          | 244           | 226    | 1227           | 1228          | 1229        | 1230            | 212           | )<br>213     | 214    | (215          | 1216           | F |
| 7.  | 24           | 0     | <u>)</u> 1 | 2           | )3          | )4          | 5     | )6            | X7           | )8         | <u>)</u> 9   | 10    | (11           | (12    | (13           | (14           | 15     | (16            | (17           | (18         | (19             | 20            | (21          | 22     | (23           | )24            | Q |
| 8.  | 1028         | 0     | )1         | )2          | )3          | <u>)</u> 4  | 256   | 257           | )258         | (259       | (260         | 512   | (513          | (514   | (515          | (516          | 768    | (769           | ),770         | (771        | (772            | 1024          | (1025        | (1026  | (1027         | (1028          | O |
| 9.  | 1            |       | (4         | 17          | <u>)</u> 4  | )1          | 4     | (15           | 24           | (15        | <u>(</u> 4   | 7     | 24            | (40    | 24            | )7            | 4      | (15            | )24           | (15         | (4              | 1             | 4            | X7     | <u>(</u> 4    | )1             |   |
| 10. | 215 🕽        | 0     | )85        | )(0         | )1          | <u>)</u> 2  | 254   | 255           | )0           | <u>)</u> 1 | 2            | 240   | 241           | 242    | 243           | 244           | 226    | 227            | )228          | 229         | 230             | 212           | )213         | (214   | (215          | (216           | C |
| 11. | 1            |       | (4         | X7          | 4           | <u> (1</u>  | 4     | )15           | (24          | (15        | 4            | 7     | 24            | (40    | 24            | <u>)</u> 7    | 4      | (15            | )24           | (15         | (4              | <b>1</b> 1    | 4            | X7     | <u>(</u> 4    | )1             |   |
| 12. | 215          | 0     | (340       | )(0         | )(4         | 2           | 1016  | (3825         | )0           | (15        | )(8          | 1680  | (5784         | (9680  | (5832         | (1708         | (904   | (3405          | )5472         | (3435       | (920            | 212           | (852         | (1498  | (860          | )216           | C |
| 13. | 215 🕽        | 0     | (340       | )(0         | <u>)</u> 4  | )2          | (1016 | 3825)         | )0           | (15        | (8           | 1680  | (5784         | )9680  | (5832         | (1708         | (904   | 3405)          | )5472         | (3435       | (920            | 212           | )852         | (1498  | (860          | )216           |   |
| 14. | 856 (        | 215   | )0         | (340        | <u>)</u> 0  | <u>)</u> 4  | 2     | 1016          | )3825        | <u>(</u> 0 | (15          | 8     | (1680         | (5784  | (9680         | )5832         | 1708   | (904           | 3405          | (5472       | 3435            | 1920          | <u>)</u> 212 | 852    | (1498         | (860           |   |
| 15. | 53 (         | 215   |            | (555        |             | )559        | 561   | (1577         | )5402        |            | (5417        | 5425  | (7105         | (1288) | 3 (22569      | 28401         | 30109  | 31013          | 34418         | (39890      | 43325           | 44245         | 44457        | 45309  | (46807        | 47667          |   |
| 16. | 52 [         | 0     | )215       |             | (555        |             | 559   | (561          | (1577        | (5402      |              | 5417  | 5425          | (7105  | (12889        | 22569         | 28401  | 30109          | <u>)31013</u> | 34418       | 39890           | 43325         | 44245        | 44457  | (45309        | 46807          | Q |
| 17. | 52 I         | 0     | 215        |             | 1555        |             | (559  | <u>1561</u>   | <u>)1577</u> | (5402      |              | 5417  | <u>)</u> 5425 | 7105   | <u>[12889</u> | <u>)22569</u> | 28401  | <u> (30109</u> | <u>)31013</u> | 34418       | <u> 39890 (</u> | <u>[43325</u> | 144245       | (44457 | 145309        | <u>)</u> 46807 | 0 |
| 18. | <u>856 [</u> | 215   | <u>jo</u>  | (340        | <u>10</u>   | 14          | 12    | <u>(1016</u>  | 13825        | <u> 10</u> | <u>(15</u>   | 18    | <u>(1680</u>  | (5784  | 19680         | <u>)5832</u>  | 1708   | <u>) 1904</u>  | <u>)3405</u>  | (5472       | (3435           | 1920          | <u>)212</u>  | (852   | <u>(1498</u>  | <u>)</u> 860   | L |
| 19. | 53 ]         | 215   |            | 1555        |             | )559        | 1561  | 11577         | 15402        |            | 15417        | 15425 | <u>)7105</u>  | 11288  | 3 122569      | <u>)28401</u> | 130109 | <u> 131013</u> | 134418        | (39890      | 143325          | 144245        | 144457       | 145309 | 146807        | 147667         | E |
| 20. | 53 ]         | 215   |            | ,555        |             | <u>,659</u> | 1561  | <u>,11577</u> | 1,5402       |            | <u>,5417</u> | ,5425 | 1/105         | 11288  | 3 122569      | <u>,28401</u> | 130109 | <u>,31013</u>  | 134418        | ,39890      | 143325          | 44245         | 144457       | 145309 | <u>,46807</u> | 1,47667        | E |
| 21. | 57           | 53818 |            |             |             |             |       |               |              |            |              |       |               |        |               |               |        |                |               |             |                 |               |              |        |               |                | E |
| 22. | 251 1        | /5    |            |             |             |             |       |               |              |            |              |       |               |        |               |               |        |                |               |             |                 |               |              |        |               |                |   |

Figure. 4. One-dimentional filter modeling results, using the ModelSim SE PLUS 5.1program: 1) clock frequency CLK; 2) resolution signal EN; 3) reset signal RST; 4) data recording in storage mem1; 5) data read from storage mem0; 6) data read from storage mem0; 7) data of counter by 25 module count\_mod25; 8) sliding window address addr\_conv; 9) matrix coefficients transmitting coef\_conv; 10) multiplexer data; 11) multiplexing coefficients; 12) multiplexing result mult; 13) multiplexing results recording in the FD1 register; 14) data reading from FD1 register; 15) recording data in the FDR register; 16) data reading from the FDR register; 17), 18) registers output data; 19) summation result sum\_16; 20) summation result recording in the FD2 register; 21) data reading from the FD2 register; 22) division operation

div256

**Conclusions.** The low-frequency Gauss filter of edge detector is realized on the base of PLIC Xc3s1000 family of Spartan-3. Such realization enables to improve operation rate, and can be widely used in the devices for preliminary images processing in large arrays of data.

## REFERENCES

1. Прэтт У. Цифровая обработка изображений: Пер. с англ. – М.: Мир, 1982. – 784 с.

2. Сойфер В.А. Методы компьютерной обработки изображений. – М.: ФИЗМАТЛИТ, 2003. – 784 с.

3. Distributed Arithmetic FIR Filter. – Режим доступу: http:// www.xilinx.com. – Заголовок з екрану.

 Білинський Й.Й. Математична модель локалізації краю зображення об'єкта // Інформаційні технології та комп'ютерна інженерія. – 2007. – № 3 (10). – С. 73 – 79.

5. Білинський Й.Й. Детектор виділення контуру та простих елементів зображення // Відбір і обробка інформації. – 2007. – № 27 (103). – С. 63 – 67.

6. Зотов В. Инструментальный комплекс Spartan-3 Starter Kit // Компоненты и технологии. – 2005. – №7. – С. 96 – 100.

**Bilinskiy** Yosyp – Associated professor of the Department of Design of Computer-based and telecommunication equipment;

Bilinskiy Volodymyr – Assistant of the Department of Theoretical Electronics and Electric Mesurements;

*Melnichuk Andriy* – Master of Sc. Department of Design of Computer-based and telecommunication equipment

Vinnytsia National Technical University.