FPGA教程系列-Vivado中读取ROM中数据

FPGA教程系列-Vivado中读取ROM中数据

  • 生成coe文件教程

https://blog.youkuaiyun.com/ccsss22/article/details/124441036

本实验主要读取rom中的数据。rom中存储的数据为coe文件,用matlab可以生成。

生成coe文件


clc;
clear;
close all;
warning off;
addpath(genpath(pwd));
% --- 1. Parameters ---
num_points = 512;         % Number of points in the sine wave (e.g., 256 for a 256-depth ROM)
amplitude_scale = 1023;   % Scaling factor to match the desired integer range.
                          % 1023 corresponds to a 10-bit unsigned range (0-1023) or
                          % an 11-bit signed range centered at 0 (-1023 to 1023).
                          % We will generate a signed sine wave.
% --- 2. Generate the Sine Wave ---
% Create a time vector from 0 to 2*pi for one full cycle
t = linspace(0, 2*pi, num_points);
% Generate the floating-point sine wave
y_continuous = sin(t);
% Quantize and scale the wave to integer values
% The result will be in the range [-1023, 1023]
y_quantized = round(amplitude_scale * y_continuous);
% --- 3. Write to .coe File ---
file_name = 'sine_wave.coe';
fid = fopen(file_name, 'w');
% Check if the file opened successfully
if fid == -1
    error('Could not open file for writing.');
end
% Write the .coe file header
fprintf(fid, 'memory_initialization_radix=10;\n');
fprintf(fid, 'memory_initialization_vector =\n');
% Write the data vector
for i = 1:length(y_quantized)
    fprintf(fid, '%d', y_quantized(i));    
    % Add a comma after each value except the last one
    if i < length(y_quantized)
        fprintf(fid, ',\n');
    else
        fprintf(fid, ';'); % End the vector with a semicolon
    end
end
% Close the file
fclose(fid);
fprintf('Successfully generated %s with %d data points.\n', file_name, num_points);
% --- 4. Plot the Generated Wave for Verification ---
figure;
plot(y_quantized);
title('Generated Quantized Sine Wave');
xlabel('Sample Index');
ylabel('Amplitude (Integer Value)');
grid on;
axis tight; % Fit the axes tightly to the data

用上述程序,生成一个sine_wave.coe文件,生成的波形如图:

image

生成IP核

本仿真采用ROM核,位数11位,深度512.

image

image

编写top文件

`timescale 1ns / 1ps

module rom_top(
input clka,
input rsta,
output signed[10:0] douta
    );
    
reg[8:0] addra;
always @(posedge clka or posedge rsta)
begin
     if(rsta)
     begin
     addra <= 9'd0;
     end
else begin
          if(addra == 9'd511)
          addra <= 9'd0;
          else
          addra <= addra+ 9'd1;
     end
end
   
    
blk_mem_gen_0 blk_mem_gen_u (
  .clka(clka),            // input wire clka
  .rsta(rsta),            // input wire rsta
  .addra(addra),          // input wire [8 : 0] addra
  .douta(douta),          // output wire [10 : 0] douta
  .rsta_busy()  // output wire rsta_busy
);

endmodule

编写Testbench

`timescale 1ns / 1ps

module rom_top_tb;
reg clka;
reg rsta;
wire signed[10:0]douta;
rom_top rom_top_u(
.clka  (clka),
.rsta  (rsta),
.douta (douta)
);
initial
begin
clka = 1'b1;
rsta = 1'b1;
#100
rsta = 1'b0;
end
always #5 clka = ~clka;
endmodule


仿真分析

最终输出的结果,就是读取coe文件中的波形,即sin函数。当然可以用matlab生成各种各样的波形来进行读取。

image

工程文件:https://download.youkuaiyun.com/download/fantasygwh2015/92292030

【博士论文复现】【阻抗建模、验证扫频法】光伏并网逆变器扫频与稳定性分析(包含锁相环电流环)(Simulink仿真实现)内容概要:本文档是一份关于“光伏并网逆变器扫频与稳定性分析”的Simulink仿真实现资源,重点复现博士论文中的阻抗建模与扫频法验证过程,涵盖锁相环和电流环等关键控制环节。通过构建详细的逆变器模型,采用小信号扰动方法进行频域扫描,获取系统输出阻抗特性,并结合奈奎斯特稳定判据分析并网系统的稳定性,帮助深入理解光伏发电系统在弱电网条件下的动态行为与失稳机理。; 适合人群:具备电力电子、自动控制理论基础,熟悉Simulink仿真环境,从事新能源发电、微电网或电力系统稳定性研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①掌握光伏并网逆变器的阻抗建模方法;②学习基于扫频法的系统稳定性分析流程;③复现高水平学术论文中的关键技术环节,支撑科研项目或学位论文工作;④为实际工程中并网逆变器的稳定性问题提供仿真分析手段。; 阅读建议:建议读者结合相关理论教材与原始论文,逐步运行并调试提供的Simulink模型,重点关注锁相环与电流控制器参数对系统阻抗特性的影响,通过改变电网强度等条件观察系统稳定性变化,深化对阻抗分析法的理解与应用能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值