MATLAB生成mif文件

news2024/9/21 4:21:29

MATLAB代码

% 参数设置
N = 4096; % 数据点数量
t = linspace(0, 2*pi, N); % 时间向量
width = 12; % 位宽

% 正弦波
sine_wave = 2.5 * sin(t) + 2.5; % 幅度在0到5之间

% 三角波
tri_wave = 5 - abs(mod(t/(2*pi)*4, 2) - 1);

% 方波
square_wave = 2.5 * (square(t) + 1); % 将范围调整为0到5之间


% 将波形数据保存为MIF文件
save_to_mif('sine_wave.mif', sine_wave, N, width);
save_to_mif('tri_wave.mif', tri_wave, N, width);
save_to_mif('square_wave.mif', square_wave, N, width);

% 读取并绘制正弦波
sine_wave_data = read_mif('sine_wave.mif', N, width);
figure;
plot(sine_wave_data);
title('Sine Wave');
xlabel('Sample');
ylabel('Amplitude');

% 读取并绘制三角波
tri_wave_data = read_mif('tri_wave.mif', N, width);
figure;
plot(tri_wave_data);
title('Triangle Wave');
xlabel('Sample');
ylabel('Amplitude');

% 读取并绘制方波
square_wave_data = read_mif('square_wave.mif', N, width);
figure;
plot(square_wave_data);
title('Square Wave');
xlabel('Sample');
ylabel('Amplitude');

% 函数:保存为MIF文件
function save_to_mif(filename, data, depth, width)
    % 打开文件
    fid = fopen(filename, 'w');
    
    % 写入头部信息
    fprintf(fid, 'DEPTH = %d;\n', depth);
    fprintf(fid, 'WIDTH = %d;\n', width);
    fprintf(fid, 'ADDRESS_RADIX = UNS;\n');
    fprintf(fid, 'DATA_RADIX = UNS;\n');
    fprintf(fid, 'CONTENT BEGIN\n');
    
    % 写入数据
    for i = 0:depth-1
        fprintf(fid, '%X : %X;\n', i, round(data(i+1) * (2^width - 1)));
    end
    
    % 写入结束
    fprintf(fid, 'END;\n');
    
    % 关闭文件
    fclose(fid);
end

% 函数:从MIF文件中读取数据
function data = read_mif(filename, depth, width)
    % 打开MIF文件
    fid = fopen(filename, 'r');
    
    % 跳过文件头部信息,找到 "CONTENT BEGIN"
    while true
        line = fgetl(fid);
        if contains(line, 'CONTENT BEGIN')
            break;
        end
    end
    
    % 初始化数据数组
    data = zeros(1, depth);
    
    % 读取数据部分
    for i = 1:depth
        line = fgetl(fid);
        % 解析地址和值
        tokens = regexp(line, '(\w+) : (\w+);', 'tokens');
        if ~isempty(tokens)
            addr = hex2dec(tokens{1}{1}); % 地址
            value = hex2dec(tokens{1}{2}); % 数据值
            data(addr + 1) = value / (2^width - 1); % 恢复原始的归一化数据
        end
    end
    
    % 关闭文件
    fclose(fid);
end

运行结果 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2092648.html

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

相关文章

Hive Tutorial For Beginners

Hive Tutorial For Beginners 一、Hive历史(History of Hive) Facebook 在面对日益增长的大数据时,选择了 Hadoop 作为解决方案。 但问题在于,许多用户并不熟悉 Java 或其他编程语言,这使得使用 Hadoop 的 MapReduc…

代码随想录——回文子串(Leetcode 647)

题目链接 我的题解(双指针) 思路: 当然,以下是对您提供的代码的解释: class Solution {public int countSubstrings(String s) {// 初始化回文子字符串的数量int count 0;// 遍历字符串的每个字符,使用…

无人机之电池篇

无人机电池作为无人机的重要组成部分,其性能、使用、保养及选择都至关重要。以下是对无人机电池的综合介绍: 一、无人机电池的基本参数 电池容量:电池容量直接影响无人机的续航能力。大容量电池,如5000mAh的电池,能提…

无人机道通布局的讲究详解!!!

一、通道分配与功能对应 基本通道:无人机遥控器通常至少包含四个基本通道,分别对应无人机的上下(升降)、左右(副翼)、前后(俯仰)和旋转(方向舵)控制。这些通…

关于报错 SLF4J: Failed to load class “org.slf4j.impl.StaticLoggerBinder“ 的可能原因

1. 絮絮叨叨 学习或工作中,如果需要从头建立日志打印体系,笔者通常直接照抄之前的博客:《Java maven工程配置slf4j》,直接粘贴、复制相关依赖除了上述博客提到的slf4j-api、logback-classic,也看到过slf4j-simple、lo…

区域生长算法详解与Python实现

图像分割是计算机视觉中一个重要的任务,区域生长算法是其中的一种常见方法。本文将详细介绍区域生长算法的原理,并通过Python代码实现,带你一步步理解它的实际应用。 1. 区域生长算法简介 区域生长算法是一种基于像素相似性进行图像分割的方…

2025款宋L EV全面升级加量不加价,仅18.98万元起

8月30日,2024成都车展正式开幕,备受期待的比亚迪王朝网B级先锋猎装SUV——2025款宋L EV正式上市,搭载“天神之眼”高阶智能驾驶辅助系统DiPilot 100,e平台3.0、CTB、云辇-C三大明星技术,并新增外观内饰配色。凭借智驾、…

【2024】Datawhale X 李宏毅苹果书 AI夏令营 Task2

本文是关于李宏毅苹果书”线性模型“学习内容的记录。 线性模型 线性模型(linear model):将输入的特征 x x x(或 x \bold{x} x)乘上权重 ω \omega ω(或 ω \bold{\omega} ω),再…

Python简易IDE工作界面制作

、 休闲一下,学习编程还是要学习一些界面编程,能够根据需要制作图形操作界面,这样我们开发的程序才能方便操作和使用,同时获得更友好的人机交互体验。下面是一个用PyQt5制作的简易界面,供大学参考。如下图所示&a…

罪人的终幕(原题)

题目背景 而我承诺你,一切都将在一场盛大的,如同戏剧般的审判中结束…… 小小地旋转,轻轻地跳跃,然后便是「罪人」的谢幕。 题目描述 定义函数 𝑎(𝑥)a(x) 表示自然数 𝑥x 的不同的质因子的和。…

数据增强在Sentence Transformers中的作用:提高句子评分任务的性能

Sentence Transformers 是一个强大的 Python 库,它基于 Transformer 模型架构,如 BERT、RoBERTa 和 XLM-RoBERTa 等,用于学习和操作句子级别的向量表示。这个库特别适合于处理自然语言处理(NLP)任务,能够为…

实用好软-----电脑端 开源的视频无损剪切与合并工具

这个是一个开源项目LosslessCut 无损剪切就是基于关键帧的剪切,不需要重编码,因此速度非常快, 缺点就是切割时间无法达到非常精确,可能前后会有几秒的差距, 要做到精确的剪切,只能重编码。 LosslessCut在切…

学习之SQL语句之DQL(数据库查询语言)

DQL英文全称是Data Query Language(数据查询语言),数据查询语言,用来查询数据库中表的记录 查询关键字:SELECT 数据准备: CREATE TABLE emp ( id INT COMMENT “编号”, workno VARCHAR ( 10 ) COMMENT “工号”, NAME VARCHAR ( 10 ) COMME…

windows配置hadoop环境

目录 一、windows配置hadoop环境1、下载文件2、解压3、移动winutils.exe4、移动hadoop.dll5、配置代码内容 一、windows配置hadoop环境 1、下载文件 首先下载所需要的文件内容 共有三个文件,可以通过 这个链接 获得 2、解压 使用解压工具将 hadoop-3.0.0.tar.gz…

堆的时间复杂度分析

一,建堆的时间复杂度分析 堆是一颗完全二叉树,满二叉树又是一颗特殊的完全二叉树。 对于满二叉树来说,第一层的节点个数为2^0,第二层的节点个数为2^1,......所以可以得到第h层的节点个数为2^(h-1)。总结点个数N2^02^1...2^(h-1)2^h-1。那么就…

桌面日历工具

Desktop Calendar 官网 设置安装目录,防止默认装到C盘修改为自己想要安装的位置调整位置和大小

ip地址变化是什么意思?手机地址ip一直变化怎么办

IP地址作为互联网设备的唯一标识,‌其稳定性对于网络连接至关重要。‌然而,‌手机IP地址频繁变动可能带来一系列问题。‌本文将深入探讨IP地址变化的含义、‌IP地址频繁变动的原因,‌以及提供手机地址IP一直变化的有效应对策略。‌ 一、IP地址…

申请商标及版权时千万要注意字体!

近日有个渠道合作的朋友申请版权,就是几行文字,普推知产老杨一看这个字体有点特别,不是免费字体,一问也不是他们美工自己设计,是在网上找的字体,一检索果然是商业字体,赶紧建议换字体。 以前经常…

list类底层逻辑实现

list的底层逻辑是一个双向带头链表。那么list的底层其实就跟我们之前实现的带头双向链表相同,都是开辟一个一个单独的节点,最后再通过指针将各个单独的节点链接起来即可。 我们来类比之前编写的双向带头链表实现具体的内容。 创建一个list类的主体 就像我…

一个浏览器插件如何月入12万美元:深入了解 GoFullPage

一个浏览器插件如何月入12万美元:深入了解 GoFullPage 前言 GoFullPage 这个插件的诞生,源于其创作者 Peter Coles 的一个简单想法:解决一个他在日常开发工作中遇到的痛点。早在 2012 年,Coles 发现许多现有的网页截图工具无法完…