

# Intellectual Property

# Component Histogram

Version 1.1

February, 2015

Corporate HQ & Design Center 380 Stevens Ave. Suite 206 Solana Beach, CA 92075 <u>http://www.macnica-na.com</u>

# License and Terms of Use

This IP Core with its associated source code and support files, are being provided on an "as-is" basis and as an accommodation. Therefore all warranties, representations or guarantees of any kind (whether express, implied or statutory) including, without limitation, warranties of merchantability, non-infringement, or fitness for a particular purpose, are specifically disclaimed.

This source code may only be used in an Altera programmable logic device and may not be distributed without permission from Macnica Americas, Inc. It is provided free of royalties or fees of any kind.

#### **Document Revision History**

| Revision | Date           | Comments                       |  |
|----------|----------------|--------------------------------|--|
| 1.0      | August, 2014   | Initial Draft                  |  |
| 1.1      | February, 2015 | Minor clean-up and corrections |  |
|          |                |                                |  |
|          |                |                                |  |
|          |                |                                |  |

# 1 Contents

| 1 | Con  | tents                                  |
|---|------|----------------------------------------|
| 2 | Intr | oduction4                              |
| 3 | Refe | erences                                |
|   | 3.1  | Industry Standards and Specifications4 |
|   | 3.2  | , Related Documents                    |
| 4 |      | ctional Description                    |
| T | 4.1  | Interface Description                  |
|   |      |                                        |
|   | 4.1. | 1 Control6                             |
|   | 4.1. | 2 Video                                |
|   | 4.2  | Registers                              |
|   | 4.3  | Functional Description7                |
|   | 4.4  | Programming                            |
|   | 4.5  | Specifications                         |
|   | 4.6  | Image Size9                            |
|   | 4.7  | Performance9                           |
|   | 4.8  | Resource Utilization                   |

# 2 Introduction

The Component Histogram module generates histogram data for three color components in parallel. If the input pixel data is of the format RGB, then they R component is assumed to be in the upper 8 bits of the Avalon-ST data bus, followed by Green, and then a Blue value in the lower 8 bits.

Three independent histogram tables are implemented – with one for each color component. The tables have a width of 20 bits.

The image data is sub-sampled both horizontally and vertically. Additionally, the horizontal subsampling averages four pixel samples prior to updating the table. The first line of the frame is sampled, followed by the 5<sup>th</sup> line etc.

The histogram data is useful in video systems to analyze the content of the image in order to implement software-controlled Auto White Balance or other algorithms, typically in systems using an image sensor as the video source.

# **3 References**

#### 3.1 Industry Standards and Specifications

Citations

#### 3.2 Related Documents

Video and Image Processing User Guide, Altera Corp.

www.altera.com/literature/ug/ug\_vip.pdf

Avalon Interface Specifications, Altera Corp.

www.altera.com/literature/manual/mnl\_avalon\_spec.pdf

# 4 Functional Description

The symbol below depicts the QSYS component and all of the signals. There are only two interfaces:

- An Avalon Slave with separate clock and reset, plus interrupt
- An Avalon Streaming video sink

| MACNICA                                                                                                                                                                                                                                      | Component Histog                                                                                                  | jram                                                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| Block Diagram     Show signals                                                                                                                                                                                                               | component_histo                                                                                                   | ogram_0                                                     |
| clk<br>reset_n<br>avalon_strea<br>din_ready<br>din_valid<br>din_data[23.0]<br>din_startofpack<br>din_endofpack<br>avs_address[3<br>avs_cs<br>avs_readdata[3<br>avs_writedata[3<br>avs_writedata[3<br>avs_writedata]<br>avs_write<br>avs_read | ready<br>valid<br>data<br>startofpacket<br>et<br>control<br>.0]<br>address<br>chipselect<br>readdata<br>writedata | interrupt_sender<br>irq<br>avs_intr<br>avs_intr<br>avs_intr |

Figure 1 – Component Histogram top-level interfaces

# 4.1 Interface Description

## 4.1.1 Control

| Interface    | Description                                                   | Notes |
|--------------|---------------------------------------------------------------|-------|
| Avalon Slave | A standard Avalon Slave interface for controlling the various |       |
|              | settings and reading the histogram table.                     |       |

## 4.1.2 Video

| Interface                  | Description                                                                    | Notes          |
|----------------------------|--------------------------------------------------------------------------------|----------------|
| Avalon Streaming<br>(sink) | A standard Avalon-ST Video interface, 8 bits per color, two colors in parallel | 8bpp, parallel |

# 4.2 Registers

| Register                        | Description                                                                                                                                                                                                                                                                                                                                                                                          | Notes |
|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Control Register<br>(address 0) | This is the standard VIP control register. As usual, bit '0' is the<br>"Go" bit that enables the module. Additional bits are:<br>[0] – The "go" enable bit<br>[1] – interrupt enable                                                                                                                                                                                                                 |       |
| Status<br>(address 1)           | <ul> <li>[0] = '1' = frame completed. Writing a '0' to this bit will enable the capture of another frame if the "go" bit is still '1'.</li> <li>[1] = interrupt pending. Writing a '0' to this bit will clear the interrupt.</li> </ul>                                                                                                                                                              |       |
| Histogram Data<br>(address 2)   | <ul> <li>[0] = clear the histogram table contents by writing a '1' to this bit</li> <li>[2:1] = Ram Select. There are three independent tables that hold the histogram results. The bits written to this register select the table to be read back as follows:</li> <li>"00" = red component histogram</li> <li>"01" = green component histogram</li> <li>"10" = blue component histogram</li> </ul> |       |
|                                 | After writing the Ram_Select bits to select the desired table,<br>reads from this address will return the data in the histogram<br>ram, starting from address zero. The address is auto-<br>incrementing, and cleared internally when a frame capture is<br>completed, OR when a write to this register occurs (e.g. when<br>the ram_select bits are written).                                       |       |
|                                 | The table data is 20-bits and is stored in the LSB of the returned 32-bit value.                                                                                                                                                                                                                                                                                                                     |       |

#### 4.3 Functional Description

The Component Histogram is not a pass-through implementation and has no Avalon Streaming video Source output. Instead, it relies on a Splitter to provide a separate Avalon Streaming Source to the component histogram module. In the test system shown below it is fed directly by a Test Pattern Generator.

A sample verification testbench implementation is shown below.



NOTE: Note that the Component Histogram has been renamed from the default component\_histogram\_0 convention. Due to an anomaly with QSYS, the source files are not properly copied to the simulation or synthesis sub-directories unless the \_0 suffix is removed. Rename your instance as shown in the example above by right-clicking on the name and selected "rename" from the menu.

#### 4.4 Programming

The programming flow is fairly simple:

- 1) Enable the Histogram by setting the "go" bit, and optionally the Interrupt Enable bit, in the Control register. The next single valid frame that is received will be analyzed.
- 2) The host then either waits for the completion interrupt, or checks the "frame complete" bit in the status register.
- 3) The host clears the interrupt bit (if used)
- 4) The host reads the contents of the table.
- 5) The host initiates the clearing of the table by writing to register (2) with a '1' in bit 0.
- 6) The host writes a '0' to bit zero of the status register to enable another capture, or alternatively turns off the "go" bit to disable the function
- 7) The clearing of the histogram ram requires two clocks per location, so with these 256-deep table approximately 512 clocks are required. All three tables are cleared simultaneously. The frame complete and "go" bits are not evaluated until after the histogram table is cleared, so there is obviously ample time for the host CPU to set these bits as desired.

A very simple polled implementation is shown below:

```
#include "sys/alt_stdio.h"
#include <io.h>
#include "../component_histogram_test_bsp/system.h"
int main()
{
  alt_putstr("Hello from Nios II!\n");
int frame done,i,temp,table;
  /* Event loop never exits. */
 while (1){
         // enable histogram
         IOWR(COMPONENT HISTOGRAM BASE,0,1);
         frame done = 0;
         while(!frame_done){
                 frame_done=IORD(COMPONENT HISTOGRAM BASE,1);
         }
         //read a bit from each of the three tables
         for(table=0;table<3;table++){</pre>
               IOWR(<u>COMPONENT HISTOGRAM BASE</u>,2,table << 1);</pre>
               for(i=0;i<32;i++)</pre>
                 temp = IORD(COMPONENT HISTOGRAM BASE,2); // We don't set bit 0, so table is
not cleared
         }
         //alt_printf("data %x\n",<u>temp</u>);
         // clear it
         IOWR(COMPONENT HISTOGRAM BASE,2,1); // NOW we set bit 1, initiates table clear
         //NOW clear the frame completed bit. The init busy will prevent a new capture
         IOWR(COMPONENT HISTOGRAM BASE,1,0);
  }
 return 0;
}
```

## 4.5 Specifications

#### 4.6 Image Size

The implementation supports an image width of 2K pixels. There is no height restriction. Given that the table implements a 20-bit width for a maximum count of 2^20 counts, or a "mega"-count, and the 4:1 sub-sampling both vertically and horizontally, a maximum of 16 Mpixels per frame could be supported without overflow.

#### 4.7 Performance

The design supports a pixel rate clock of > 150 MHz and a control port clock of > 100 MHz in the test system shown, with a NIOS/e class selected as the control master.

| Fm | nax Summary |                 |                     |      |  |
|----|-------------|-----------------|---------------------|------|--|
|    | Fmax        | Restricted Fmax | Clock Name          | Note |  |
| 1  | 66.02 MHz   | 66.02 MHz       | altera_reserved_tck |      |  |
| 2  | 147.91 MHz  | 147.91 MHz      | avs_clk             |      |  |
| 3  | 232.61 MHz  | 232.61 MHz      | vid_clk             |      |  |

#### 4.8 **Resource Utilization**

| Target Device Family | Variation          | Memory              | ALM  |
|----------------------|--------------------|---------------------|------|
| Cyclone V            | standard RGB input | 15360 bits / 3 M10K | ~160 |