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.mzph.cn/bicheng/49237.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【精品资料】数据安全治理解决方案(27页PPT)

引言&#xff1a;数据安全治理解决方案是一个综合性的体系&#xff0c;旨在通过策略、技术、流程和人力的有机结合&#xff0c;全面提升组织的数据安全防护能力&#xff0c;保障数据资产的安全与合规。 方案介绍&#xff1a;数据安全治理解决方案是组织为确保其数据资产的安全性…

Spark内核的设计原理

导读&#xff1a; 本期是DataFun深入浅出Apache Spark第一期的分享&#xff0c;主讲老师耿嘉安开场介绍了自己的从业经历&#xff0c;当前就职的数新网络与Spark相关的两款产品赛博数智引擎CyberEngine和赛博数据智能平台CyberData。 本次分享题目为《Spark内核的设计原理》&…

智能化一体闸门:助力行业发展

随着科技的飞速发展&#xff0c;智能化技术已经渗透到各个行业和领域&#xff0c;其中水利行业也不例外。智能化一体闸门以其高效、智能、便捷的特点&#xff0c;正助力着行业发展。 一、智能化一体闸门的定义与特点 智能化一体闸门&#xff0c;是集成了先进传感技术、自动控制…

Transformer之Swin-Transformer结构解读

写在最前面之如何只用nn.Linear实现nn.Conv2d的功能 很多人说&#xff0c;Swin-Transformer就是另一种Convolution&#xff0c;但是解释得真就是一坨shit&#xff0c;这里我郑重解释一下&#xff0c;这是为什么&#xff1f; 首先&#xff0c;Convolution是什么&#xff1f; Co…

java网络编程TCP和UDP协议

一、TCP 1、服务器端 package udpTest;import javax.management.MBeanRegistrationException; import java.io.*; import java.net.ServerSocket; import java.net.Socket;public class TCPService {public static void main(String[] args) {try {byte[] bufnew byte[512];Se…

什么是离线语音识别芯片?与在线语音识别的区别

离线语音识别芯片是一种不需要联网和其他外部设备支持&#xff0c;‌上电即可使用的语音识别系统。‌它的应用场合相对单一&#xff0c;‌主要适用于智能家电、‌语音遥控器、‌智能玩具等&#xff0c;‌以及车载声控和一部分智能家居。‌离线语音识别芯片的特点包括小词汇量、…

Python文件写入读取,文件复制以及一维,二维,多维数据存储

基础解释 在 Python 中&#xff0c;文件操作的模式除了 w &#xff08;只写&#xff09;、 a &#xff08;追加写&#xff09;、 r &#xff08;只读&#xff09;外&#xff0c;还有以下几种常见模式&#xff1a;- r &#xff1a;可读可写。该文件必须已存在&#xff0c;写操…

生成 HTTPS 证书并配置到 Nginx 的完整步骤

步骤 1: 安装 acme.sh 如果你还没有安装 acme.sh&#xff0c;可以通过以下命令进行安装&#xff1a; curl https://get.acme.sh | sh步骤 2: 生成 HTTPS 证书 使用 acme.sh 生成 forum.selectious.fun 的证书。你可以使用 standalone 模式&#xff0c;这意味着 acme.sh 会在…

视觉SLAM--回环检测

文章目录 创建字典相似度计算增加字典规模 回环检测的意义&#xff1a;可以使 后端位姿图得到一个 全局一致估计。 视觉SLAM的主流做法&#xff1a; 基于外观的回环检测方法&#xff0c;仅 根据两幅图像的相似性确定回环检测关系。这种方法&#xff0c;摆脱了累计误差&…

分类损失函数 (一) torch.nn.CrossEntropyLoss()

1、交叉熵 是一种用于衡量两个概率分布之间的距离或相似性的度量方法。机器学习中&#xff0c;交叉熵常用于损失函数&#xff0c;用于评估模型的预测结果和实际标签的差异。公式&#xff1a; y&#xff1a;真是标签的概率分布&#xff0c;y&#xff1a;模型预测的概率分布 …

数据库中的内、外、左、右连接

常用的数据库连表形式&#xff1a; 内连接 &#xff1a;inner join 外连接 &#xff1a;outer join 左外连接 &#xff1a;left outer join 左连接 &#xff1a;left join 右外连接 right outer join 右连接&#xff1a; right join 全连接 full join 、union 一、内连接 内…

企业私有云的部署都有哪些方式?

如今常见的企业私有云的部署方式有自建私有云、托管私有云、虚拟私有云、混合云、容器化私有云、本地数据中心部署等。如今&#xff0c;企业私有云的部署呈多样化趋势&#xff0c;以用来满足各个企业的具体需求。以下是RAK部落小编为大家汇总的企业私有云常见的部署方式&#x…

LeetCode 58.最后一个单词的长度 C++

LeetCode 58.最后一个单词的长度 C 思路&#x1f914;&#xff1a; 先解决当最后字符为空格的情况&#xff0c;如果最后字符为空格下标就往后移动&#xff0c;直到不为空格才停止&#xff0c;然后用rfind查询空格找到的就是最后一个单词的起始位置&#xff0c;最后相减就是单词…

flowable执行监听器动态指定审批人在退回时产生的bug

场景&#xff1a; 退回产生的bug&#xff0c;有一个结点&#xff0c;本身是通过执行监听器判断上一个结点的审批人来得到这个结点的审批人。之前是通过直接的获取最新task来拿到&#xff0c;但是在退回场景下&#xff0c;最新task为退回结点&#xff0c;故产生错误。 解决&…

C++ 正则库与HTTP请求

正则表达式的概念和语法 用于描述和匹配字符串的工具&#xff0c;通过特定的语法规则&#xff0c;灵活的定义复杂字符串匹配条件 常用语法总结 基本字符匹配 a&#xff1a;匹配字符aabc&#xff1a;匹配字符串abc 元字符&#xff08;特殊含义的字符&#xff09; .&#xff1a;匹…

stable diffusion webui环境配置遇到的问题

环境配置步骤&#xff1a; conda创建一个python3.10的环境&#xff0c;起个名叫sdenv, 使用命令conda create -n denv python3.10进入创建好的环境在webui的路径下直接运行python launch.py会自动开始安装所需的包&#xff08;可能需要梯子或者在系统配置中添加pip的国内源&am…

1Panel面板配置java运行环境及网站的详细操作教程

本篇文章主要讲解&#xff0c;通过1Panel面板实现java运行环境&#xff0c;部署网站并加载的详细教程。 日期&#xff1a;2024年7月21日 作者&#xff1a;任聪聪 独立博客&#xff1a;https://rccblogs.com/501.html 一、实际效果 二、详细操作 步骤一、给我的项目进行打包&am…

在jsPsych中使用Vue

jspsych 介绍 jsPsych是一个非常好用的心理学实验插件&#xff0c;可以用来构建心理学实验。具体的就不多介绍了&#xff0c;大家可以去看官网&#xff1a;https://www.jspsych.org/latest/ 但是大家在使用时就会发现&#xff0c;这个插件只能使用js绘制界面&#xff0c;或者…

陌陌聊天数据案例分析

目录 背景介绍和需求分析基于hive数仓实现需求开发根据聊天数据建库建表加载数据ETL数据清洗背景分析原始数据出现的问题ETL实现 需求指标统计思路需求开发 基于FineBI实现可视化报表配置流程构建可视化报表 总结 背景介绍和需求分析 陌陌是一个聊天平台&#xff0c;每天都会产…

不能包含中文的正则表达式

原文 1、不包含汉字[^\u4e00-\u9fa5] var r /^[^\u4e00-\u9fa5]$/ if(r.test(str)){} 2、只能包含汉字 [\u4e00-\u9fa5]