Use the sinusoidal lookup table at left to generate a sine wave using a Q4.4 format phase increment of 0001.1011. Plot the “Base” and “Base + Offset\*Delta” columns in the graph below.

|  |  |
| --- | --- |
| 0 | 127 |
| 1 | 175 |
| 2 | 216 |
| 3 | 244 |
| 4 | 253 |
| 5 | 244 |
| 6 | 216 |
| 7 | 175 |
| 8 | 127 |
| 9 | 78 |
| 10 | 37 |
| 11 | 9 |
| 12 | 0 |
| 13 | 9 |
| 14 | 36 |
| 15 | 78 |

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Time | Index | Base | Delta | Offset\*Delta | Base + Offset\*Delta |
| 0 | 0000.0000 | 127 | 175-127 = 48 = 110000 | 0.0000\*110000 = 00000.0000 | 127+0 = 127 |
| 1 | 0001.1011 | 175 | 216-175 = 41 = 101001 | 0.1011\*101001 = 11100.0011 | 175+28 = 203 |
| 2 |  |  |  |  |  |
| 3 |  |  |  |  |  |
| 4 |  |  |  |  |  |
| 5 |  |  |  |  |  |
| 6 |  |  |  |  |  |
| 7 |  |  |  |  |  |
| 8 |  |  |  |  |  |
| 9 |  |  |  |  |  |
| 10 |  |  |  |  |  |
| 11 |  |  |  |  |  |
| 12 |  |  |  |  |  |
| 13 |  |  |  |  |  |
| 14 |  |  |  |  |  |

![](data:image/png;base64,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AAEC0QXkgOjkJiRAgAABAskIyAHJtEIhBAgQIEAguoAcEJ3chAQIECBAIBkBOSCZViiEAAECBAhEF5ADopObkAABAgQIJCMgByTTCoUQIECAAIHoAnJAdHITEiBAgACBZATkgGRaoRACBAgQIBBdQA6ITm5CAgQIECCQjIAckEwrFEKAAAECBKILyAHRyU1IgAABAgSSEZADkmmFQggQIECAQHQBOSA6uQkJECBAgEAyAnJAMq1QCAECBAgQiC4gB0QnNyEBAgQIEEhGQA5IphUKIUCAAAEC0QXkgOjkJiRAgAABAskIyAHJtEIhBAgQIEAguoAcEJ3chAQIECBAIBkBOSCZViiEAAECBAhEF5ADopObkAABAgQIJCMgByTTCoUQIECAAIHoAnJAdHITEiBAgACBZATkgGRaoRACBAgQIBBdQA6ITm5CAgQIECCQjIAckEwrFEKAAAECBKILyAHRyU1IgAABAgSSEZADkmmFQggQIECAQHQBOSA6uQkJECBAgEAyAnJAMq1QCAECBAgQiC4gB0QnNyEBAgQIEEhGQA5IphUKIUCAAAEC0QXkgOjkJiRAgAABAskIyAHJtEIhBAgQIEAguoAcEJ3chAQIECBAIBkBOSCZViiEAAECBAhEF5ADopObkAABAgQIJCMgByTTCoUQIECAAIHoAnJAdHITEiBAgACBZATkgGRaoRACBAgQIBBdQA6ITm5CAgQIECCQjIAckEwrFEKAAAECBKILyAHRyU1IgAABAgSSEZADkmmFQggQIECAQHQBOSA6uQkJECBAgEAyAnJAMq1QCAECBAgQiC4gB0QnNyEBAgQIEEhGQA5IphUKIUCAAAEC0QXkgOjkJiRAgAABAskIyAHJtEIhBAgQIEAguoAcEJ3chAQIECBAIBkBOSCZViiEAAECBAhEF5ADopObkAABAgQIJCMgByTTCoUQIECAAIHoAnJAdHITEiBAgACBZATkgGRaoRACBAgQIBBdQA6ITm5CAgQIECCQjIAckEwrFEKAAAECBKILyAHRyU1IgAABAgSSEZADkmmFQggQIECAQHQBOSA6uQkJECBAgEAyAt/PAePzzbXHx/5wXvZw/2Hj5vk4mbUohAABAgQIEGgm8OPXA3qDu/njYms69nB/++ZsNN02OqsO9ySBZuT2JkCAAAECyQj8OAc8L3X4sd87PuhM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)

-------------------------------------------------------------------------------------

-- BRAM\_SDP\_MACRO: Simple Dual Port RAM 7 Series

-- Source: Xilinx HDL Libraries Guide, version 2012.4

-- Link: https://www.xilinx.com/support/documentation/sw\_manuals/xilinx2012\_2/ug953-vivado-7series-libraries.pdf

-- Page: 10

-------------------------------------------------------------------------------------

sampleMemory: BRAM\_SDP\_MACRO

generic map (

BRAM\_SIZE => "18Kb", -- Target BRAM, "18Kb" or "36Kb"

DEVICE => "7SERIES", -- Target device: "VIRTEX5", "VIRTEX6", "SPARTAN6", "7SERIES"

DO\_REG => 0, -- Optional output register disabled

INIT => X"000000000000000000", -- Initial values on output port

INIT\_FILE => "NONE", --

WRITE\_WIDTH => 16, -- Valid values are 1-72 (37-72 only valid when BRAM\_SIZE="36Kb")

READ\_WIDTH => 16, -- Valid values are 1-72 (37-72 only valid when BRAM\_SIZE="36Kb")

SIM\_COLLISION\_CHECK => "NONE", -- Simulation collision check

SRVAL => X"000000000000000000", -- Set/Reset value for port output

INIT\_00 => X"8BC28AF98A31896988A087D8870F8647857E84B583EC8323825A819180C88000",

INIT\_01 => X"9830976A96A595DF95199452938C92C591FE913790708FA98EE18E198D528C8A",

INIT\_02 => X"A462A3A2A2E0A21FA15DA09B9FD89F169E529D8F9CCB9C079B439A7F99BA98F5",

INIT\_3E => X"7247717F70B76FF06F296E616D9A6CD46C0D6B476A8069BA68F5682F676A66A5",

INIT\_3F => X"7ECF7E067D3D7C747BAC7AE37A1A7951788977C076F7762F7567749F73D6730E")

port map (

DO => DO, -- Output read data port, width defined by READ\_WIDTH parameter

RDADDR => vecAddrRead, -- Input address, width defined by port depth

RDCLK => clk, -- 1-bit input clock

RST => reset, -- active high reset

RDEN => '1', -- read enable

REGCE => '1', -- 1-bit input read output register enable - ignored

DI => DI, -- Dummy write data - never used in this application

WE => "00", -- write to neither byte

WRADDR => "0000000000", -- Dummy place holder address

WRCLK => clk, -- 1-bit input write clock

WREN => '0'); -- we are not writing to this RAM