# A High-Efficient and Cost-Effective LCD Signal Processor Tze-Yun Sung<sup>1</sup> Chun-Wang Yu<sup>1</sup> Yaw-Shih Shieh<sup>1</sup> Hsi-Chin Hsin<sup>2</sup> <sup>1</sup>Department of Microelectronics Engineering, Chung Hua University, Hsinchu, Taiwan 300-12, R.O.C. <sup>2</sup>Department of Computer Science and Information Engineering, Formosa University, Hu-Wei, Taiwan 632-08 #### **Abstract** This paper investigates the system of LCD monitor and TV signal processor. It is shown that the processor provides scalar, brightness and contrast adjuster, Gamma correction and dithering. The algorithms are discussed and implemented by Verilog hardware description language. The key hard codes are displayed. The signal processor for monitor and TV achieves real-time and high performance. The system is evaluated and implemented on FPGA (Xilinx-XC2V6000). **Keywords**: LCD, scalar, brightness and contrast adjuster, Gamma correction, dithering. #### 1. Introduction In this paper, we discuss the algorithms of image scalar, brightness, contrast adjuster, Gamma correction and dithering. The system is integrated and the performance of the signal processor achieves real-time, area and power consumption under FPGA implementation are also optimized [1], [2]. The system diagram of control circuits of LCD monitor and TV is shown in Figure 1, the system is composed of analog to digit converter, video decoder and signal processor, which includes controller and microcontroller [3]. In the initial state, the microcontroller reads data from flash memory and writes commands and tables into register file of controller [4]. So far, we rarely find papers and documents to describe and discuss the algorithms and system architectures of LCD and TV signal processor. But the industry of LCD has been growing rapidly, and has become the main stream of high technology in Taiwan. This paper present the key components of the monitor and TV signal processor and propose the algorithms and the circuits implemented by Verilog codes [2]. The remainder of this paper is organized as follows. Section II presents the image scalar algorithm, and displays the key Verilog code, which describes the circuits of the scalar algorithm. In Section III, the algorithm and implementation of the brightness and contrast adjuster are proposed. Section IV applies the algorithm of Gamma correction to correct the input signal, and display true color. Section V presents the algorithm of dithering and implementation of the algorithm. Finally, the conclusions are given. ### 2. The Algorithm and Implementation of Image Scalar The purpose of image scalar is to enlarge and reduce the input image. The algorithm of image scalar avoids the distortion, when the scaling operation is performing. In this section, the algorithm will be described in detail. In this scalar, we may not use the special purpose digital signal processor [3]. The hardware is implemented by simple multipliers, and memory is saved. Hence, the hardware is saved, and implemented easily. Figure 3 shows the data flow of LCD monitor and TV signal processor. In Figure 2, the INP module recognizes the input signals and transfer to YUV 4:2:2 mode, which presents in video, S-video and HDTV. The SC module performs the function of image scalar. The CSC (color space converter) module transfers video signals to RGB mode. The transformation equation of CSC module is implemented by simple multipliers, adders and shifters [2], [3], [4]. In SC system, sc\_fifo and sc\_fifo4 module provide the memories for Y-buffer and X-buffer. All of input signal are stored in Y-buffer. The Y-buffer requires the memory capacity of 1024 (pixels) · 3-bytes · 8 (Lines), it saves hardware cost and performs the functions [4]. ## 2.1. The Data Retrieval and Computation The new horizontal line (row) is created by four-upper and lower rows. The data are stored and computed in Y-buffer. The algorithm of new pixel creation is described as follows[3], [4]: where $p_m1 \sim p_p2$ are presented as color level $(0\sim255)$ . According to this algorithm, the hardware is saved and the digital signal processor is not required, the low hardware cost is achieved. The key codes for performing the algorithm are described as follows: ``` \begin{aligned} & \text{assign my\_m1} = p\_m1[23:16] * \text{coeff}[34:27]; // C3 \\ & \text{assign my\_z0} = p\_z0[23:16] * \text{coeff}[25:18]; // C2 \\ & \text{assign my\_p1} = p\_p1[23:16] * \text{coeff}[16:9]; // C1 \\ & \text{assign my\_p2} = p\_p2[23:16] * \text{coeff}[7:0]; // C0 \\ & \text{assign ry} = \text{myr} + \{ \, 8'b0, \, \text{myr}[16:8] \, \} + 8'b80; \end{aligned} ``` ### 2.2. The Algorithm of Expanding and Reducing Lines In Y-buffer, we perform expand and reduce operation by using data set of horizontal scan lines to stay or jump. For example, if the data of original image is 800 horizontal lines, we may expand to 1024 lines; the special algorithm is developed and explained as follows: ``` inc_p = 1, 1, 1, 0, 1, 1, 1, 0, 1, 1, 1, 0, 1, 1, 1, 0, 1.... Line 20 Line 21 Line 22 Line 23 Line 24 Line 25 Line 26 ``` The numbers of left side presents the sequence of the new horizontal scan lines. The line 22 (L22)~line 25 (L25)generates new line 27, the equation is represented as New line $27 = a \times L22 + b \times L23 + c \times L24 + d \times 25$ New line $28 = e \times L22 + f \times L23 + g \times L24 + h \times L25$ where two set of parameters are different. The key codes for phase update are presented as follows: When we reduce lines and get the inc\_p as follows: inc\_p = 1, 1, 1, 2, 1, 1, 1, 2, 1, 1.... The algorithm is described as follows: where Line 16~19 are new lines for reducing the image. ### 2.3. The Parameters for Expanding Pixels and Lines In order to adjust the color and smooth the color distribution, the parameters or weighing factors must be found [3]. The data for computing the parameters are presented as follows: | | | 3 | 7 | | | | | |---------|---------|-----|-------|--------|-------|-------|----------| | | | 120 | P21 | P22 | P23 | P24 | | | Line 30 | • • • [ | 200 | 200 | 200 | 200 | 200 | • • • | | T : 01 | | P20 | P21 3 | 88 P22 | P23 | P24 | _ | | Line 31 | • • • | 180 | 180 | 180 | 180 | 180 | • • • | | | | P20 | P21 | P22 | P23 | P24 | = | | Line 32 | | 160 | 160 | 160 | 160 | 160 | ] | | T: 22 | | P20 | P21 | P22 | P23 4 | 0 /24 | 141 | | Line 33 | • • • | 140 | 140 | 140 | 140 | 140 | 41 | | | | P20 | P21 | P22 | P23 | P24 | | | Line 34 | • • • [ | 120 | 120 | 120 | 120 | 120 | | | | _ | P20 | P21 | P22 | P23 | P24 | | | Line 35 | • • • [ | 100 | 100 | 100 | 100 | 100 | | | | | P20 | P21 | P22 | P23/ | P24 | <u>.</u> | | Line 36 | • • • [ | 80 | 80 | 80 | 80 | 80 | | | | | | | | | 17 | | According to the algorithm, the parameters (0, 255, 0, 0), (-18, 221, 58, -6), (-16, 144, 143, -16) and (-6, 58, 221, -18) are given to new line $37\sim41$ . The new lines are obtained as follows: New line 37: ( $$0 \times 200 + 255 \times 180 + 0 \times 160 + 0 \times 140$$ ) $\div 256 = 179$ New line 38: $$(-18\times180 + 221\times160 + 58\times140 - 6\times120) \div 256 = 154$$ New line 39: ``` (-16×160 + 144×140 + 143×120 -16×100 ) \div 256 = 130 New line 40 : (-6×160+ 58×140 + 221×120 -18×100 ) \div 256 = 125 New line 41 : (0×140+255×120+0×100 - 0×80 ) \div 256 = 120 Hence, the line expansions are achieved, and feeling of observation is much better. ``` ### 2.4. The Algorithm of Expanding and Reducing Pixels In X-buffer, the data of pixel are computed for expanding or reducing pixels. The algorithm of expanding pixels is described as follows: where L20'new is a new horizontal line intermediately, and has not expanded pixels yet. New Line 20 has been expanded by pixels. ### 3. Implementations of Brightness and Contrast Adjuster The input signal is RGB, three colors are performed by brightness and contrast adjusting separately. Finally, three colors are performed an image together. The value of brightness is defined as $-128 \sim +127$ . 0 is default value. The brightness presents relative level. The level of brightness is defined as $0\sim199\%$ . The default level is 100% [5], [6]. The computation of brightness is defined as $$p \times 2^8 / 128 = p \times 255 / 128 \quad p \times 199\%$$ . The algorithm is described by Verilog code, which is displayed as follows: First, the brightness process performs the input image; the key code is displayed as | <pre>bright_r_in = reg bright r}</pre> | {reg_bright_r[7], | reg_bright_r[7], | | | | | | |-------------------------------------------------|--------------------|------------------|--|--|--|--|--| | <b>U</b> _ <b>U</b> _ / | ) . 1 · 1 . · · | | | | | | | | $g_{tmp} = \{1'b0, g_{con}\} + bright_g_{in}$ | | | | | | | | | $b_{tmp} = \{1'b0, b_{con}\} + bright_b_{in}$ | | | | | | | | | $r_{tmp} = \{1'b0, r_{con}\} + bright_{r_{in}}$ | | | | | | | | | $g_o = (g_tmp[9:8]==2'b11)?8'h00:$ | | | | | | | | | $(g_{tmp}[9:8]==2'b00)?g_{tmp}[7:0]:8'hFF$ | | | | | | | | | $b_o = (b_tmp[9:8] == 2'b11)?8'h00:$ | | | | | | | | | (b_tmp[9:8]==2'b00)?b_tmp[7:0]:8'hFF | | | | | | | | | $r_o = (r_tmp[9:8]==2'b11)?8'h00:$ | | | | | | | | | $(r_{tmp}[9:8]=$ | ==2'b00)?r_tmp[7:0 | ]:8'hFF | | | | | | | Basic computation | n equation: | | | | | | | | $Rout = Rin \times Con$ | ntrast + Bright | | | | | | | | $= 170 \times 16$ | 50 / 128 + 30 | | | | | | | | = 243.5 | | | | | | | | | | 2.5.0 | | | | | | | |---------|----------------|-------------|--|--|--|--|--| | | 244 | | | | | | | | Input | Hardware | Theoretical | | | | | | | | Implementation | Computation | | | | | | | C = 160 | | | | | | | | | B = 30 | Rout = 243 | Rout = 244 | | | | | | | Rin = | | | | | | | | ## 4. The Algorithm and Hardware Implementation of Gamma Correction The intensity of display related with input signal is nonlinear, which is presented function of $x^r$ , and x is input signal [5]. The equation is presented as $$Viewing\_gamma = \frac{1}{Image\_gamma} \times$$ LUT gamma × Display gamma where Image\_gamma is defined as $\gamma_{NTSC}$ =2.2, $\gamma_{PAL}$ =2.8, $\gamma_{RGB}$ =1 and $\gamma_{MAC}$ =1.8. and Display gamma is defined as $\gamma_{\text{CRT}} = 2.5, \gamma_{\text{LCD}} = 1.6.$ 170 The LCD transfer function in physics is shown in below: #### 5. The Algorithm and Hardware Implementation of Dithering The color level of input signal is 8-bit, but the Gamma correction upgrades color level to 10-bit. But the output signal requires the color level of 6-bit or 8-bit and the color distortion may occur, such as contour and color block. In this section, we downgrade the color distortion using dithering method, which simulates high quality image and eliminates contour and color block. In this signal processor, we choose the Bayer matrix to perform the dithering [1], [5], [6]. The Bayer matrix is represented as $$D_{2n} = \begin{pmatrix} 4D_n & 4D_n + 2U_n \\ 4D_n + 3U_n & 4D_n + U_n \end{pmatrix}$$ where $U_n$ is a n×n unit matrix, n 0. The $D_2$ of 2x2 and $D_4$ of 4x4 Bayer matrix are represented as follows : $$D_{2} = \begin{bmatrix} 0 & 2 \\ 3 & 1 \end{bmatrix}$$ $$D_{4} = \begin{bmatrix} 0 & 8 & 2 & 10 \\ 12 & 4 & 14 & 6 \\ 3 & 11 & 1 & 9 \\ 5 & 7 & 13 & 5 \end{bmatrix}$$ where the threshold values are shown in the matrices. Hence, the color space can simulate high quality image by using low color level. In vision color prospect, the difference of color level for human eyes is 1%. When 10-bit (0.1%) color level downgrades to 8-bit (0.4%), the difference of color level is less than 1%, the dithering process is not required. But we downgrades the color level to 6-bit (1.6%), the dithering process is required [5], [6]. #### 6. Conclusions In this paper, we use Verilog hardware description language (HDL) to implement the system. The system is partitioned into some modules. The architecture is easily debugged, and the modules are acted as IP, which can be reused. The human interface performs user friendly and full functions [7], [8]. The LCD monitor/TV signal processor is implemented; the low power and small area are taken into considerations. #### References - [1] PHILIPS , SAA6721E SXGA RGB to TFT graphics engine data sheet, 1999. - [2] D. E. Thomas, P. H. Moorby, The Verilog Hardware Description Language, Fifth Edition, Kluwer Academic Pub. 2002. - [3] T. Y. Sung, Y. T. Chen, C. S. Chen, "Image Processing Algorithms Applying on Flat Panel Display Controller", 2003 Computer Graphics Workshop, Hualian, Taiwan, August, 28~29, 2003. - [4] T. Y. Sung, Y. T. Chen, "Implementation of Optimal Image Scaling Algorithm for LCD - Monitor Controller," First Science and Technology Conference-Photonics and Communications, Kaohsiung, Taiwan, Dec. 9-10, 2004, PJ-01. - [5] T. Y. Sung, C. S. Chen, "Implementation of Color Image Processing Algorithms for LCD Monitor Controller," First Science and Technology Conference-Photonics and Communications, Kaohsiung, Taiwan, Dec. 9-10, 2004, A-04. - [6] R. C. Gonzalez, R. E. Woods, Digital Image Processing," Addison-Wesley Publishing Company, 2000. - [7] W. Z. Yang, The fundamentals of Digital Image Processing, Chang Hua Technology Publication Co., Taipei, Taiwan, 1995. - [8] W. Z. Yang, High Quality TV Technology, Chang Hua Technology Publication Co., Taipei, Taiwan, 1993. Fig. 1. The system diagram of control circuits of LCD monitor and TV Fig. 2. Data flow of LCD monitor and TV Signal Processor