This project is modified from [xhls] reed\_solomon\_erasure(xapp1273)

# **Improvement**

Since both size of array c (size=4) and d (size=12) are small, use array\_partition directive to partition both arrays.

Latency is improved from 1994 cycles to 25 cycles.

## **HLS Screenshots**

Synthesis original

|             | ynthesis original                                                                        |                   |                             |                            |                                           |                                              |                       |  |  |  |
|-------------|------------------------------------------------------------------------------------------|-------------------|-----------------------------|----------------------------|-------------------------------------------|----------------------------------------------|-----------------------|--|--|--|
| Per         | Performance Estimates                                                                    |                   |                             |                            |                                           |                                              |                       |  |  |  |
|             | □ Timing                                                                                 |                   |                             |                            |                                           |                                              |                       |  |  |  |
|             | Summary                                                                                  |                   |                             |                            |                                           |                                              |                       |  |  |  |
|             | Clock Target Estimated Uncertainty                                                       |                   |                             |                            |                                           |                                              |                       |  |  |  |
|             | ap_clk 5.00 ns 4.229 ns 0.63 ns                                                          |                   |                             |                            |                                           |                                              |                       |  |  |  |
|             | Latency                                                                                  |                   |                             |                            |                                           |                                              |                       |  |  |  |
| □ Summary   |                                                                                          |                   |                             |                            |                                           |                                              |                       |  |  |  |
|             | Latency                                                                                  |                   | Latency                     | (absolute)                 | Interva                                   | l (cycles)                                   |                       |  |  |  |
|             | min                                                                                      | max               | min                         | max                        | min                                       | max                                          | Туре                  |  |  |  |
|             | 1994                                                                                     | 1994              | 9.970 us                    | 9.970 us                   | 1994                                      | 1994                                         | none                  |  |  |  |
|             | ⊕ Inst                                                                                   |                   |                             |                            |                                           |                                              |                       |  |  |  |
|             | Loo lization E                                                                           | p<br>stimate      | es                          |                            |                                           |                                              |                       |  |  |  |
|             | ⊕ Loo                                                                                    | p<br>stimate      |                             | DSP48E                     | FF                                        | LUT                                          | URAM                  |  |  |  |
|             |                                                                                          | p<br>stimate      | RAM_18K                     | DSP48E                     | FF<br>-                                   | LUT<br>-                                     | URAM<br>-             |  |  |  |
| -<br>C      |                                                                                          | stimate<br>y      |                             |                            |                                           | LUT<br>-<br>486                              |                       |  |  |  |
| D           | E Loo<br>lization E<br>Summar<br>Name                                                    | stimate<br>y      |                             |                            | -                                         | -                                            |                       |  |  |  |
| D<br>E<br>F | E Loo  Summar  Name  OSP                                                                 | stimate<br>y      | RAM_18K<br>-<br>-           | -                          | - 0                                       | -                                            | -                     |  |  |  |
| E FI        | E Loo  Summar  Name  OSP  Expression  IFO  Instance  Memory                              | stimate<br>y<br>E | RAM_18K<br>-<br>-           | -                          | - 0                                       | -<br>486<br>-                                | -                     |  |  |  |
| D E Ir      | E Loo  Summar  Name  OSP  expression  IFO  nstance  Memory  Multiplexe                   | stimate<br>y<br>E | RAM_18K<br>-<br>-<br>-<br>- | -<br>-<br>-                | 0<br>-<br>0<br>25                         | -<br>486<br>-<br>21                          | -<br>-<br>-           |  |  |  |
| D E Ir      | E Loo  Summar  Name  OSP  Expression  IFO  Instance  Memory  Multiplexe                  | stimate<br>y<br>E | RAM_18K 128 -               | -<br>-<br>-<br>-<br>-      | -<br>0<br>-<br>0<br>25<br>-<br>254        | -<br>486<br>-<br>21<br>15<br>230             | -<br>-<br>-<br>-<br>0 |  |  |  |
| D E F Ir N  | E Loo  Summar  Name  DSP  Expression  IFO  Instance  Memory  Multiplexe  Register  Total | stimate<br>y<br>E | RAM_18K 128 - 128           | -<br>-<br>-<br>-<br>-<br>- | -<br>0<br>-<br>0<br>25<br>-<br>254<br>279 | -<br>486<br>-<br>21<br>15<br>230<br>-<br>752 | -<br>-<br>-<br>0<br>- |  |  |  |
| E FI        | E Loo  Summar  Name  OSP  Expression  IFO  Instance  Memory  Multiplexe                  | stimate<br>y<br>E | RAM_18K 128 -               | -<br>-<br>-<br>-<br>-      | -<br>0<br>-<br>0<br>25<br>-<br>254        | -<br>486<br>-<br>21<br>15<br>230             | -<br>-<br>-<br>-<br>0 |  |  |  |

Synthesis improved

## **Performance Estimates**

## □ Timing

## ■ Summary

| Clock  | Target  | Estimated | Uncertainty |  |  |
|--------|---------|-----------|-------------|--|--|
| ap_clk | 5.00 ns | 4.278 ns  | 0.63 ns     |  |  |

## ■ Latency

## □ Summary

| Latency (cycles) |    | Latency (absolute) |          | Interval (cycles) |     |      |          |
|------------------|----|--------------------|----------|-------------------|-----|------|----------|
| min max          |    | min                | max      | min               | max | Туре |          |
|                  | 25 | 25                 | 0.125 us | 0.125 us          | 1   | 1    | function |

#### Detail

- Instance
- ⊥Loop

## **Utilization Estimates**

## □ Summary

| Name            | BRAM_18K | DSP48E | FF     | LUT   | URAM |
|-----------------|----------|--------|--------|-------|------|
| DSP             | -        | -      | -      | -     | -    |
| Expression      | -        | -      | 0      | 12912 | -    |
| FIFO            | -        | -      | -      | -     | -    |
| Instance        | 0        | -      | 296    | 365   | -    |
| Memory          | 96       | -      | 144    | 9     | -    |
| Multiplexer     | -        | -      | -      | -     | -    |
| Register        | 0        | -      | 10161  | 3680  | -    |
| Total           | 96       | 0      | 10601  | 16966 | 0    |
| Available       | 280      | 220    | 106400 | 53200 | 0    |
| Utilization (%) | 34       | 0      | 9      | 31    | 0    |

#### Cosim

# Cosimulation Report for 'rs\_erasure'

#### Result

|         |        | Latency |     |     | Interval |     |     |
|---------|--------|---------|-----|-----|----------|-----|-----|
| RTL     | Status | min     | avg | max | min      | avg | max |
| VHDL    | NA     | NA      | NA  | NA  | NA       | NA  | NA  |
| Verilog | Pass   | 24      | 24  | 24  | 1        | 1   | 1   |

Export the report(.html) using the Export Wizard

# System level bring-up

The system is implemented on Pynq Screenshot of Pynq running result

- [0] 0 out of 250 test vectors failed
- [1] 0 out of 250 test vectors failed
- [2] 0 out of 250 test vectors failed
- [3] 0 out of 250 test vectors failed

Total 1000 Test Vectors, Err Count = 0 pass

-----

Exit process