当前位置: 首页 > news >正文

Matlab-FPGA 小数转换为定点二进制小数脚本和转coe文件格式脚本

Matlab-FPGA 小数转换为定点二进制小数脚本:

% 更新于2023年6月17日,修改旋转因子文件,不修改fpga
%首先明确我们的二维FFT的数组维数,此为1024*8的二维矩阵,1024行,8列
column = 1024;
row = 8;
nk=[];
N=column*row;
for i=0:row-1for j=0:column-1nk=[nk,j*i];end
end
for k=1:column*row %必须保存所有可能的数值w_re(k)=cos(2*pi*(nk(k))/N);w_im(k)=-sin(2*pi*(nk(k))/N);
end
W2=w_re+1i*w_im;
numint=1;%numint位整数,numdec位小数
numdec=14;%选取的总位数为1+numint+numdec,其中1为符号位所占用。
fp1=fopen("w_re_data.txt",'w');
fp2=fopen("w_im_data.txt",'w');
% temp=diag(ones(length(a)))';
a=w_re;%a 为被定点化的矩阵或标量,为实数
for i=1:length(a)fixed_a=floor(a(i)*2^numdec);  %模拟计算机中直接截位的结果%限幅if ((fixed_a>=2^(numint+numdec))||(fixed_a<-2^(numint+numdec)))fixed_a=sign(a(i))*(2^(numint+numdec)-1)+0.5*(sign(a(i))-1);%正数最大是2^(numint+numdec)-1,负数最大是-2^(numint+numdec)end%转化为补码if (a(i)<0)%需要写成补码的形式!fixed_a=fixed_a+2^(numint+numdec);fixed_bin=dec2bin(fixed_a,numint+numdec);fixed_bin=strcat('1',fixed_bin);   elsefixed_bin=dec2bin(fixed_a,numint+numdec);fixed_bin=strcat('0',fixed_bin);end% 保存数据到txt文件
%     for j=1:numint+numdec+1fprintf(fp1,"%s",fixed_bin);fprintf(fp1,'\r\n');end
fclose(fp1);
clear a;
a=w_im;
for i=1:length(a)fixed_a=floor(a(i)*2^numdec);  %模拟计算机中直接截位的结果%限幅if ((fixed_a>=2^(numint+numdec))||(fixed_a<-2^(numint+numdec)))fixed_a=sign(a(i))*(2^(numint+numdec)-1)+0.5*(sign(a(i))-1);%正数最大是2^(numint+numdec)-1,负数最大是-2^(numint+numdec)end%转化为补码if (a(i)<0)%需要写成补码的形式!fixed_a=fixed_a+2^(numint+numdec);fixed_bin=dec2bin(fixed_a,numint+numdec);fixed_bin=strcat('1',fixed_bin);   elsefixed_bin=dec2bin(fixed_a,numint+numdec);fixed_bin=strcat('0',fixed_bin);end% 保存数据到txt文件
%     for j=1:numint+numdec+1fprintf(fp2,"%s",fixed_bin);fprintf(fp2,'\r\n');end
fclose(fp2);

数据转.coe文件脚本:

clear
clc
depth    =8192; % rom深度    
% width    =32;   % 数据宽度
cstr0=textread("w_re_data.txt",'%s'); % 将TXT中的数据以文本的方式取回
cstr1=textread("w_im_data.txt",'%s');
%实部
fid   =fopen('rotate_re.coe','wt');             % 创建文件
fprintf(fid,'memory_initialization_radix=2;\n'); % memory_initialization_radix:定义存储器初始化值的基,可取值为2进制,10进制,16进制等
fprintf(fid,'memory_initialization_vector=\n');  % memory_initialization_vector 储存器内数据向量
for  idnex =1:depthif(idnex<depth)    fprintf(fid,'%s,\n',char(cstr0{idnex}));else fprintf(fid,'%s;\n',char(cstr0{idnex}));  % 最后的数据应以[;]结尾end 
end 
% 虚部
fid   =fopen('rotate_im.coe','wt');             % 创建文件
fprintf(fid,'memory_initialization_radix=2;\n'); % memory_initialization_radix:定义存储器初始化值的基,可取值为2,10,16等
fprintf(fid,'memory_initialization_vector=\n');  % memory_initialization_vector 储存器内数据向量for  idnex =1:depthif(idnex<depth)    fprintf(fid,'%s,\n',char(cstr1{idnex}));else fprintf(fid,'%s;\n',char(cstr1{idnex}));  % 最后的数据应以[;]结尾end 
end 
http://www.lryc.cn/news/404483.html

相关文章:

  • 逆向案例二十三——请求头参数加密,某区块链交易逆向
  • CSS 导航栏:设计、定制与优化
  • JS 如何处理链接被用户点击中键的操作
  • Android 11 使用HAL层的ffmpeg库(1)
  • 友力科技数据中心搬迁方案
  • GitHub敏感信息扫描工具
  • Linux云计算 |【第一阶段】ENGINEER-DAY4
  • C++与VLC制作独属于你的动态壁纸背景
  • 平凯星辰黄东旭出席 2024 全球数字经济大会 · 开放原子开源数据库生态论坛
  • Mac OS 下安装 NVM,1秒教会你
  • 搭建博客系统#Golang
  • 算法——滑动窗口(day6)
  • 推荐一款基于Spring Boot 框架开发的分布式文件管理系统,功能齐全,非常便捷(带私活源码)
  • Mysql-查询
  • 广东科学技术职业学院计算机学院领导一行莅临泰迪智能科技参观交流
  • exo 大模型算力共享;Llama3-70B是什么
  • 测试——Junit
  • BUG ImportError: cannot import name ‘QAction‘ from ‘PySide6.QtWidgets‘
  • 对某次应急响应中webshell的分析
  • Vue3新特性
  • 一套功能齐全、二开友好的即时通讯IM工具,提供能力库和UI库,支持单聊、频道和机器人(附源码)
  • MySQL:JOIN 多表查询
  • 【机器学习】必会算法模型之:一文掌握 密度聚类,建议收藏。
  • 代码:前端与数据库交互的登陆界面
  • 发电机基础知识:负载组
  • 内网安全:各类密码的抓取
  • 前端面试题汇总2
  • 分布式服务框架zookeeper+消息队列kafka
  • 服务攻防-应用协议cve
  • Springcloud之gateway的使用详解