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

Matlab的Simulink系统仿真(simulink调用m函数)

这几天要用Simulink做一个小东西,所以在网上现学现卖,加油!

起初的入门是看这篇文章MATLAB 之 Simulink 操作基础和系统仿真模型的建立_matlab仿真模型搭建-CSDN博客

写的很不错

后面我想在simulink中调用m文件

在 Simulink 中调用 MATLAB .m 文件中的函数,可以通过使用 "MATLAB Function" 模块来实现。以下是具体步骤:

步骤 1:编写并保存 .m 文件

确保您已经编写并保存了需要调用的 MATLAB .m 文件。例如,假设我们有两个文件:

  1. calculatePhaseDiff.m

matlab

Copy

    function phase_diff = calculatePhaseDiff(tx_signal, rx_signal)% 计算发射和接收信号之间的相位差phase_tx = angle(hilbert(tx_signal)); % 发射信号的瞬时相位phase_rx = angle(hilbert(rx_signal)); % 接收信号的瞬时相位phase_diff = phase_rx - phase_tx;      % 相位差end

  1. phaseToDistance.m

matlab

Copy

    function distance = phaseToDistance(phase_diff, frequency, c)% 根据相位差计算距离% phase_diff: 相位差 (弧度)% frequency: 载波频率 (Hz)% c: 光速 (m/s)wavelength = c / frequency;delta_time = (phase_diff / (2 * pi)) * (1 / frequency);distance = delta_time * c;end

  1. 启动 MATLAB 并打开 Simulink。
  2. 创建一个新的空白模型。

步骤 3:添加并配置 MATLAB Function 模块

  1. 打开 Simulink 库浏览器(Library Browser)。
  2. 选择 “User-Defined Functions” 类别,然后拖动 “MATLAB Function” 模块到模型画布上。
  3. 双击 “MATLAB Function” 模块打开其编辑窗口。

步骤 4:在 MATLAB Function 模块中调用外部函数

MATLAB Function 模块1 - 计算相位差

配置第一个 MATLAB Function 模块以调用 calculatePhaseDiff 函数:

  • 编辑 MATLAB Function 模块,复制并粘贴以下代码:

matlab

Copy

    function phase_diff = calculatePhaseDiffModule(tx_signal, rx_signal)% 调用外部文件 calculatePhaseDiff.m 中的函数phase_diff = calculatePhaseDiff(tx_signal, rx_signal);end

  • 确保 calculatePhaseDiff.m 文件位于 MATLAB 的当前工作目录或 MATLAB 路径中可访问的位置。

MATLAB Function 模块2 - 通过相位差计算距离

配置第二个 MATLAB Function 模块以调用 phaseToDistance 函数:

  • 编辑第二个 MATLAB Function 模块,复制并粘贴以下代码:

matlab

Copy

    function distance = phaseToDistanceModule(phase_diff, frequency, c)% 调用外部文件 phaseToDistance.m 中的函数distance = phaseToDistance(phase_diff, frequency, c);end

  • 确保 phaseToDistance.m 文件位于 MATLAB 的当前工作目录或 MATLAB 路径中可访问的位置。

步骤 5:连接各个模块

按照需要将各个模块连接起来。例如:

  1. 载波生成与调制

    • PN Sequence Generator -> BPSK Modulator Baseband -> Sine Wave -> Product
  2. 传输与接收

    • Product -> AWGN Channel -> Carrier Recovery
  3. 信号处理

    • 发射信号和接收信号分别连接到 calculatePhaseDiffModule 的两个输入。
    • calculatePhaseDiffModule 的输出(相位差)连接到 phaseToDistanceModule 的输入。
    • 将频率和光速的常数输入 phaseToDistanceModule,并将其输出连接到 Scope 观看结果。

示例连接图

plaintext

Copy

  发射部分:+-------------------+| PN Sequence Gen   |+-------------------+|+-------------------+| BPSK Modulator    |+-------------------+|+-------------------+|    Sine Wave      |+-------------------+|+-------------------+|   Multiplier      | 调制信号+-------------------+|+-------------------+| AWGN Channel      | 加入噪声+-------------------+|接收部分:+-------------------+| RF Receiver       | 接收信号+-------------------+|+-------------------+| Carrier Recovery  | 载波恢复, 提取相位+-------------------+|+-------------------+| BPSK Demodulator  | 进行BPSK解调+-------------------+|+-------------------+| MATLAB Function   | 计算相位差 (calculatePhaseDiffModule)+-------------------+|+-------------------+| MATLAB Function   | 计算距离 (phaseToDistanceModule)+-------------------+|+-----------+|   Scope   | 显示结果+-----------+

运行仿真

  1. 设置仿真参数(如仿真时间等)。
  2. 运行仿真,确保 calculatePhaseDiff.m 和 phaseToDistance.m 文件在 MATLAB 路径中可访问。
  3. 在 Scope 中观察相位差和距离计算的结果。

通过正确配置 MATLAB Function 模块并连接合适的输入和输出,您可以成功调用外部 .m 文件中的函数来实现复杂的信号处理和计算。

是参考的上面的步骤,起初是对于MATLAB function比较迷茫,后来发现是在library brower进行搜索,之后再定义一下功能和调用的函数

这样子就可以用起来了

我之前也看过一些文章,是让改InitFcn,和我的功能不太符合,最终也没有跑通代码

http://www.lryc.cn/news/378801.html

相关文章:

  • C语言中操作符详解(一)
  • 【论文阅读】Multi-Camera Unified Pre-Training via 3D Scene Reconstruction
  • 深入了解NumPy的原理与使用
  • Linux Centos 环境下搭建RocketMq集群(双主双从)
  • 全网最全postman接口测试教程和项目实战~从入门到精通
  • 【ARM】MDK Debug模式下Disassembly窗口介绍
  • 灵活的招聘管理系统有五种方法帮助成功招聘
  • 美摄科技匿名化处理解决方案,包含模糊、同色、马赛克、效果遮挡等各种形式
  • O2OA的数据库数据库配置-使用不同用户访问Oracle时报错-表或视图不存在
  • leetcode56 合并区间
  • Elasticsearch扩展性探索:水平扩展与集群管理
  • node版本过高出现ERR_OSSL_EVP_UNSUPPORTED错误
  • 不得不看的AI前沿理论与技术: LLM-Assisted Light大模型
  • 流行跨链桥总结
  • 代理网络基础设施 101:增强安全性、速度和可扩展性
  • 小游戏app看广告app开发案例
  • VOC数据集
  • [Linux内核驱动]内存动态申请
  • 在Worpress增加网站的二级目录,并转向到站外网站
  • torch.max函数
  • “打造智能售货机系统,基于ruoyi微服务版本开源项目“
  • LeetCode347:前K个高频元素
  • 2.线上论坛项目
  • Java面试题:讨论synchronized关键字和java.util.concurrent包中的同步工具,如Lock和Semaphore
  • 酱香型白酒派系介绍
  • 编译chamfer3D报错
  • BuildConfig类找不到,BuildConfig.java类不在编译加载路径问题解决
  • 海外版coze前端代码助手
  • python pyautogui实现图片识别点击失败后重试
  • 怎么看电脑实时充电功率