## **THEIA Simple Scene Simulation Tutorial: Example 1**

Thank you very much for your interest in the project.

In this tutorial, you will set up THEIA to simulate a simple 3D scene consisting of 2 texturized triangles. This is the final output for this example:



Summary

| Number of triangles        | 2                      |
|----------------------------|------------------------|
| Resolution (pixels)        | 200x200                |
| Textures                   | Bi linear filter       |
| Behavioral Simulation Time | Less than 15 minutes * |
| Shaders                    | Default Shaders in ROM |

For simplicity, this tutorial uses the default algorithms stored in THEIA's internal ROM. In the next tutorials I will show how to write and load your own Shader code and also general your own scenes using *BLENDER*.

### **Step 1 – Download and the Simulation environment.**

**1.1** Download the 'theia\_gpu\_latest.tar.gz' file from Download section of the project web page.

**1.2** Un-compress the tarball.

**1.3** Please refer to the 'readme.txt' document under the 'test\_bench' folder for instructions on how to setup the XILINX ISE project.

**1.4** Assume the following paths:

SIM\_DIR: project directory created by ISE Project Navigator, this is where all the verilog files are located.

SRC\_DIR: folder that gets created after you unzip 'theia\_gpu\_latest.tar.gz'. Contains a

copy of the sources, doc, examples, etc.

### Step 2 – Download and copy the input files.

2.1 Copy the input files (\*.mem) from the SRC\_DIR/examples/scenes/example1 to SIM\_DIR/

| <br>Creg.mem     |
|------------------|
| <br>Params.mem   |
| <br>Textures.mem |
| <br>Vertex.mem   |

**Creg.mem**: has control register options (more on this in the documentation).

**Params.mem**: Scene configuration such as camera origen, light, Axis Aligned Bounding Box position, etc. (more on this in the documentation).

**Textures.mem**: binary representation of the texture memory (more on this in the documentation).

**Vertex.mem**: Binary representation of the triangle primitives (more on this in the documentation).

### **Step 3 – Configure the simulation.**

**3.1** Once the project has been created. Select Behavioral simulation under the 'source for' drop down menu:

| Design   |                                                                                                                                                                                                                                                                                                                                                     | ⇔⊡₽×     |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| Source   | s for: Behavioral Simulation                                                                                                                                                                                                                                                                                                                        |          |
| 🗐 Hierar | rchy                                                                                                                                                                                                                                                                                                                                                |          |
|          | <ul> <li>TestBench_Theia (TestBench_THEIA.v)</li> <li>THEIA - THEIACORE (Theia.v)</li> <li>MUX_RA0 - MUXFULLPARALELL_2SEL</li> <li>CU - ControlUnit (Unit_Control.v)</li> <li>V MEM - MemoryUnit (Unit_MEM.v)</li> <li>V EXE - ExecutionUnit (Unit_EXE.v)</li> <li>V GEO - GeometryUnit (Unit_GEO.v)</li> <li>V IO - IO_Unit (Unit_IO.v)</li> </ul> | _GENERIC |

| •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                            |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--|
| Processes: TestBench_Theia                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                            |  |
| <ul> <li>ISim Simulator</li> <li>Behavioral Check Syntax</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                            |  |
| Simulate Pobauiaral Model           Image: Simulate Pobauiaral Model           Image: Simulate Pobauiaral Model           Image: Region All           Image: Stop           View Text Report           Force Process Up-to           Open Without Update           Design Goals & Strate           Image: Stop           Image: Stop           Image: Stop           View Text Report           Force Process Up-to           Open Without Update           Design Goals & Strate           Image: Stop           Image: Stop <td>o-Date<br/>ating<br/>ategies</td> | o-Date<br>ating<br>ategies |  |

**3.2** select the 'TestBench\_Theia' file under the 'Hierarchy' tree control. Then right click on the Simulate behavioral model icon and select 'Process Properties'.**3.3** (optional) Make sure the 'advance' option is selected and add the 'DEBUG=1|DUMP\_CODE=1' flags in into the Macro option.

| Value Range Check                       |                                    |
|-----------------------------------------|------------------------------------|
| Specify Search Directories for 'Include |                                    |
| Specify 'define Macro Name and Value    | DEBUG=1 DUMP_CODE=1                |
| Specify Top Level Instance Names        | Testoenen_Theia                    |
|                                         |                                    |
|                                         |                                    |
|                                         | Property display level: Advanced 💌 |

This switches will tell the THEIA simulation executable to create extra debug information log files including a code dump.

# Step 4 – Run the Behavioral Simulation.

Click on the Simulate Behavioral model to start the simulation. You can also run the simulation from DOS or Linux command line (this way is a little faster).



While the simulation runs, it will print some dot characters and the current row line that is rendering, this way you can see it is running.

Optional: You can also look at the code dump file while the simulation is running

>tail -f SIM\_DIR/Code.log

Step 5 – Verify results and analyze the log files.

The easiest way to verify the results is by simply comparing the file 'Output.ppm' against the file 'Reference.ppm'

You can look at those files using **Gimp** or **XnView** under windows.

#### **Happy Simulation!**