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,和我的功能不太符合,最终也没有跑通代码

  • 44
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值