MATLAB实战:5步搞定MSK调制解调完整流程(附信号对比图生成技巧)

news2026/3/13 18:21:50
MATLAB实战从零构建MSK调制解调系统掌握信号可视化与性能验证全链路在通信系统仿真与算法验证领域MATLAB以其强大的矩阵运算能力和丰富的信号处理工具箱成为了工程师和研究人员不可或缺的利器。对于学习数字调制技术的同学尤其是初次接触最小频移键控的朋友理论公式往往抽象而一个能跑通、能看见、能分析的完整仿真流程其价值远超几页教科书。本文将带你亲手搭建一个完整的MSK调制解调仿真链路核心目标不仅是复现代码更是深入理解每一个模块背后的物理意义并掌握生成可用于学术报告或论文的高质量信号对比图的技巧。我们将聚焦于如何验证你设计的系统是否正确工作这恰恰是课程设计、毕业课题或项目前期验证中最实际的痛点。1. 理解MSK为何它被称为“相位连续的FSK”在动手写代码之前厘清基本概念至关重要。MSK全称Minimum Shift Keying中文常译作最小频移键控。它本质上是一种特殊的连续相位频移键控。其“最小”体现在调制指数为0.5这意味着两个代表“0”和“1”的频率间隔恰好是比特率的一半从而保证了在码元转换时刻相位的连续性。这种相位连续性带来了巨大的优势恒包络特性。恒包络信号对功率放大器的非线性不敏感非常适合在卫星通信、移动通信等对功率效率要求高的场景中使用。我们可以把MSK信号用正交调制的形式来表达s(t) I(t)cos(2πf_c t) - Q(t)sin(2πf_c t)其中I(t)和Q(t)分别是同相和正交支路的数据它们并不是独立随机的而是由原始比特流经过串并转换和半正弦脉冲成形后得到的。理解这个正交分解模型是看懂后续所有代码和图形的钥匙。注意许多初学者容易混淆MSK与GMSK高斯滤波最小频移键控。GMSK是在MSK基础上对数据流先进行高斯低通滤波以进一步压缩频谱广泛应用于GSM系统。本文聚焦于标准的MSK。为了更清晰地对比MSK与其他常见调制方式的特性可以参考下表调制方式相位是否连续包络是否恒定频谱效率典型应用场景BPSK不连续非恒定较低深空通信、基础数据传输QPSK不连续非恒定是BPSK的2倍卫星数字广播、早期Wi-FiMSK连续恒定与BPSK相当卫星通信、蓝牙基础速率GMSK连续恒定略低于MSKGSM移动通信、蓝牙EDR2. 搭建MSK调制器从比特流到射频信号调制器的任务是将离散的二进制信息比特映射为适合在信道中传输的连续时间波形。我们分步拆解这个过程。2.1 数据预处理与差分编码首先我们需要生成或输入一串随机的二进制比特流。在仿真中常用randi函数生成。但MSK调制前通常需要进行差分编码这是为了在接收端进行非相干解调时避免相位模糊。差分编码的规则很简单当前输出码元是当前输入码元与前一个输出码元的乘积在±1的域中。% 参数设置 N 100; % 比特数 Tb 1e-6; % 比特周期例如1微秒 Fs 100 * (1/Tb); % 采样频率为比特率的100倍保证波形光滑 fc 2e6; % 载波频率例如2MHz % 生成随机比特流 (0/1) original_bits randi([0, 1], 1, N); % 将0/1映射为±1 data_nrz 2 * original_bits - 1; % 差分编码 diff_encoded zeros(1, N); prev_symbol 1; % 假设初始参考符号为1 for i 1:N diff_encoded(i) prev_symbol * data_nrz(i); prev_symbol diff_encoded(i); % 更新前一个符号 end2.2 串并转换与脉冲成形接下来将差分编码后的序列进行串并转换奇数位进入I路偶数位进入Q路。关键的一步是脉冲成形。MSK使用半正弦脉冲其宽度为2Tb。这保证了I路和Q路的符号在时间上错开一个比特周期并且脉冲波形是平滑的。% 串并分离I路取奇数位Q路取偶数位 I_symbols diff_encoded(1:2:end); Q_symbols diff_encoded(2:2:end); % 创建半正弦脉冲波形 t_symbol -Tb:1/Fs:Tb-1/Fs; % 一个符号周期对应的时间向量2Tb长 pulse_shape cos(pi * t_symbol / (2*Tb)); % 半余弦脉冲注意定义域 % 对I路和Q路符号进行脉冲成形 I_baseband []; Q_baseband []; for i 1:length(I_symbols) I_baseband [I_baseband, I_symbols(i) * pulse_shape]; end % Q路信号需要延迟Tb for i 1:length(Q_symbols) Q_baseband [Q_baseband, Q_symbols(i) * pulse_shape]; end Q_baseband_delayed [zeros(1, length(pulse_shape)/2), Q_baseband(1:end-length(pulse_shape)/2)];2.3 载波调制与信号合成最后将成形后的基带信号调制到载波上。I路乘以同相载波cos(2πf_c t)Q路乘以正交载波-sin(2πf_c t)然后相加得到最终的MSK信号。% 生成时间轴 t_total 0:1/Fs:(N*Tb - 1/Fs); % 生成载波信号 I_carrier cos(2*pi*fc*t_total); Q_carrier -sin(2*pi*fc*t_total); % 注意负号对应公式中的减号 % 确保基带信号长度与载波一致处理边界 min_len min([length(I_baseband), length(Q_baseband_delayed), length(t_total)]); I_baseband I_baseband(1:min_len); Q_baseband_delayed Q_baseband_delayed(1:min_len); t_total t_total(1:min_len); I_carrier I_carrier(1:min_len); Q_carrier Q_carrier(1:min_len); % 合成MSK信号 msk_signal I_baseband .* I_carrier Q_baseband_delayed .* Q_carrier;3. 设计匹配滤波器解调性能的关键在接收端我们需要从被噪声污染的MSK信号中恢复出原始比特。解调通常采用相干解调即用本地载波进行下变频然后通过低通滤波器提取基带信号。这里的滤波器设计直接决定了误码性能。3.1 滤波器类型选择对于MSK由于其特殊的半正弦脉冲形状理论上最佳的接收滤波器是与之匹配的半正弦匹配滤波器。但在实际仿真中我们常使用一个性能接近、易于设计的低通滤波器作为替代例如切比雪夫I型或椭圆滤波器以在带外抑制和计算复杂度之间取得平衡。提示使用MATLAB的filterDesigner工具可以交互式地设计滤波器并生成代码。但为了可复现性在脚本中直接定义滤波器系数是更好的实践。3.2 在代码中实现滤波器我们不依赖外部设计的myfilter函数而是在主脚本中直接生成一个合适的低通滤波器。这里以切比雪夫I型滤波器为例。% 设计低通滤波器用于解调后滤波 Fb 1/Tb; % 比特率 Fpass 0.6 * Fb; % 通带截止频率 Fstop 1.5 * Fb; % 阻带截止频率 Apass 1; % 通带衰减单位dB Astop 40; % 阻带衰减单位dB % 计算滤波器阶数和截止频率 [n, Wn] cheb1ord(Fpass/(Fs/2), Fstop/(Fs/2), Apass, Astop); % 生成切比雪夫I型滤波器系数 [b, a] cheby1(n, Apass, Wn, low); % 使用freqz查看滤波器频率响应 figure; freqz(b, a, 1024, Fs); title(解调低通滤波器频率响应);这个滤波器的通带应能无失真地通过基带信号主要能量集中在0.5/Tb以内同时有效地抑制载波二倍频分量和噪声。4. 实现MSK解调与比特判决解调是调制的逆过程。我们采用相干解调即用同步的本地载波进行下变频。4.1 下变频与滤波假设接收端已完美同步载波频率和相位这是一个重要假设实际中需要载波同步算法。% 模拟接收信号加入高斯白噪声 EbN0_dB 10; % 信噪比 snr EbN0_dB 10*log10(1); % 简化计算假设符号能量为1 received_signal awgn(msk_signal, snr, measured); % 相干解调与同相和正交载波相乘 I_demod received_signal .* I_carrier; Q_demod received_signal .* Q_carrier; % 通过低通滤波器滤除高频分量 I_filtered filter(b, a, I_demod); Q_filtered filter(b, a, Q_demod);4.2 采样与判决滤波后的I_filtered和Q_filtered信号理论上应该恢复出原始的、带有延时的I路和Q路基带波形。我们需要在最佳采样时刻对其进行采样。对于MSK由于I/Q路错开Tb其采样点也相应错开。% 计算最佳采样点考虑滤波器群延迟 group_delay mean(grpdelay(b, a)); % 滤波器的近似群延迟 % 每个符号的采样点数 samples_per_symbol Tb * Fs; % I路采样点在每个符号周期中间且考虑延迟 I_sample_idx round((1:length(I_symbols)) * samples_per_symbol * 2 - samples_per_symbol group_delay); I_sample_idx I_sample_idx(I_sample_idx length(I_filtered)); % 边界处理 I_sampled I_filtered(I_sample_idx); % Q路采样点比I路晚一个符号周期 Q_sample_idx I_sample_idx samples_per_symbol; Q_sample_idx Q_sample_idx(Q_sample_idx length(Q_filtered)); Q_sampled Q_filtered(Q_sample_idx); % 硬判决 I_decoded (I_sampled 0) * 2 - 1; % 大于0判为1否则-1 Q_decoded (Q_sampled 0) * 2 - 1;4.3 并串转换与差分解码将判决后的I/Q路符号交错合并然后进行差分解码的逆操作。% 并串转换 received_symbols zeros(1, N); received_symbols(1:2:end) I_decoded(1:length(I_symbols)); received_symbols(2:2:end) Q_decoded(1:length(Q_symbols)); % 差分解码 decoded_bits_nrz zeros(1, N); prev_recv 1; for i 1:N decoded_bits_nrz(i) received_symbols(i) * prev_recv; prev_recv received_symbols(i); % 注意这里更新的是接收符号本身 end % 将±1映射回0/1 decoded_bits (decoded_bits_nrz 1) / 2;至此我们完成了从比特到比特的完整链路。可以通过计算误码率来定量评估系统性能ber sum(original_bits ~ decoded_bits) / N。5. 生成论文级信号对比图可视化与调试艺术图形化展示是验证系统工作和呈现结果的核心。MATLAB的plot功能强大但生成清晰、专业、可直接用于报告的图表需要一些技巧。5.1 调制过程信号对比图一个好的对比图应该能清晰展示比特流、I/Q路基带信号以及最终MSK信号之间的关系。figure(‘Position‘ [100, 100, 800, 1000]); % 设置图窗大小 % 1. 原始比特流 subplot(4,1,1); stairs(t_total(1:min_len:end), [original_bits, original_bits(end)], ‘linewidth‘, 1.5); ylim([-0.2 1.2]); grid on; title(‘原始信息比特流‘); ylabel(‘幅度‘); set(gca, ‘FontSize‘, 11); % 2. I路和Q路基带信号 subplot(4,1,2); plot(t_total, I_baseband, ‘b-‘, ‘LineWidth‘, 1.5); hold on; plot(t_total, Q_baseband_delayed, ‘r--‘, ‘LineWidth‘, 1.5); grid on; legend(‘I路信号‘, ‘Q路信号 (延迟T_b)‘, ‘Location‘, ‘best‘); title(‘脉冲成形后的同相与正交基带信号‘); ylabel(‘幅度‘); set(gca, ‘FontSize‘, 11); % 3. 载波信号片段展示前几个周期 subplot(4,1,3); segment 1:min(5000, length(t_total)); % 只画前5000个点 plot(t_total(segment), I_carrier(segment), ‘c:‘, ‘LineWidth‘, 1); hold on; plot(t_total(segment), Q_carrier(segment), ‘m-.‘, ‘LineWidth‘, 1); grid on; legend(‘同相载波 cos(2πf_c t)‘, ‘正交载波 -sin(2πf_c t)‘, ‘Location‘, ‘best‘); title(‘载波信号局部‘); ylabel(‘幅度‘); xlabel(‘时间 (s)‘); set(gca, ‘FontSize‘, 11); % 4. 生成的MSK信号 subplot(4,1,4); plot(t_total, msk_signal, ‘k-‘, ‘LineWidth‘, 1); grid on; title(‘最终MSK调制信号‘); ylabel(‘幅度‘); xlabel(‘时间 (s)‘); set(gca, ‘FontSize‘, 11); % 调整子图间距 sgtitle(‘MSK调制过程信号分解‘, ‘FontSize‘, 14, ‘FontWeight‘, ‘bold‘);关键技巧使用subplot进行多图对齐方便对比时间关系。用不同线型和颜色清晰区分不同信号。合理设置坐标轴范围和网格增强可读性。使用sgtitle为整图添加总标题使用set(gca, ‘FontSize‘, 11)统一字体大小。对于载波这类高频信号只绘制一小段以避免图形过于密集。5.2 解调过程与误码验证图解调图的重点是展示恢复的信号与原始信号的对比以及眼图、星座图等用于性能评估的图形。figure(‘Position‘, [100, 100, 800, 600]); % 1. 发送与接收比特流对比 subplot(2,2,1); stem(1:N, original_bits, ‘b^‘, ‘filled‘, ‘MarkerSize‘, 5, ‘LineWidth‘, 1.2); hold on; stem(1:N, decoded_bits, ‘ro‘, ‘LineWidth‘, 1.2); grid on; legend(‘发送比特‘, ‘接收比特‘, ‘Location‘, ‘best‘); title([‘比特流对比 (误码数: ‘, num2str(sum(original_bits ~ decoded_bits)), ‘)‘]); ylabel(‘比特值‘); xlabel(‘比特序号‘); ylim([-0.2 1.2]); % 2. 滤波后的I/Q路信号与采样点 subplot(2,2,2); plot(t_total, I_filtered, ‘b-‘); hold on; plot(t_total(I_sample_idx), I_sampled, ‘b^‘, ‘MarkerFaceColor‘, ‘b‘, ‘MarkerSize‘, 8); plot(t_total, Q_filtered, ‘r--‘); plot(t_total(Q_sample_idx), Q_sampled, ‘ro‘, ‘MarkerFaceColor‘, ‘r‘, ‘MarkerSize‘, 8); grid on; legend(‘I路滤波输出‘, ‘I路采样点‘, ‘Q路滤波输出‘, ‘Q路采样点‘, ‘Location‘, ‘best‘); title(‘解调滤波后信号与采样时刻‘); ylabel(‘幅度‘); xlabel(‘时间 (s)‘); % 3. 眼图 (I路) subplot(2,2,3); eyediagram(I_filtered(1000:end), 2*samples_per_symbol, 2*samples_per_symbol, 0); % 忽略初始瞬态 title(‘I路基带信号眼图‘); % 4. 误码率随信噪比变化曲线蒙特卡洛仿真示例 subplot(2,2,4); EbN0_range 0:2:12; ber_sim zeros(size(EbN0_range)); for idx 1:length(EbN0_range) % 此处应嵌套一个完整的蒙特卡洛仿真循环计算平均误码率 % 为简洁这里用理论BER公式近似相干解调MSK的理论BER与BPSK相同 ber_sim(idx) 0.5 * erfc(sqrt(10^(EbN0_range(idx)/10))); end semilogy(EbN0_range, ber_sim, ‘-s‘, ‘LineWidth‘, 1.5, ‘MarkerFaceColor‘, ‘b‘); grid on; title(‘MSK系统理论误码率曲线‘); xlabel(‘E_b/N_0 (dB)‘); ylabel(‘误码率 (BER)‘);图形解读与调试价值比特对比图一目了然地显示是否有误码发生以及误码出现的位置。滤波信号与采样点图这是调试滤波器性能和采样同步的关键。观察采样点是否落在滤波后波形的稳定平坦处眼图张开最大处。如果采样点落在波形跳变沿误码率会急剧上升。眼图定性评估系统性能的利器。眼图张开度大、线条清晰说明信号质量好噪声和码间串扰小。BER曲线定量分析系统性能的标准方法。将仿真结果与理论曲线对比可以验证仿真模型的正确性。6. 进阶滤波器参数对系统性能的影响回到我们最初的设计滤波器的通带、阻带和衰减参数并非随意设定。让我们做一个小实验看看改变滤波器性能会如何影响最终的信号恢复。我们固定其他条件仅改变解调低通滤波器的阻带衰减Astop观察眼图和误码率的变化。% 测试不同滤波器性能 astop_values [20, 40, 60]; % 三种阻带衰减 colors {‘r‘, ‘g‘, ‘b‘}; figure; for a_idx 1:length(astop_values) % 设计新滤波器 [b_new, a_new] cheby1(n, Apass, Wn, ‘low‘, ‘StopbandAttenuation‘, astop_values(a_idx)); % 使用新滤波器滤波 I_filt_new filter(b_new, a_new, I_demod); % 绘制眼图 subplot(1, length(astop_values), a_idx); eyediagram(I_filt_new(1000:end), 2*samples_per_symbol, 2*samples_per_symbol, 0); title([‘阻带衰减 ‘, num2str(astop_values(a_idx)), ‘ dB‘]); end sgtitle(‘不同滤波器阻带衰减对I路眼图的影响‘);你会发现阻带衰减过低如20dB时眼图中会有更多“毛刺”和“杂散”眼图张开度变小这是因为更多的高频噪声和载波泄露进入了基带。而衰减过高如60dB虽然能得到更干净的眼图但滤波器的阶数可能会增加带来更大的群延迟和计算量。在实际工程中这就是一个典型的性能与复杂度折中的问题。掌握从理论推导到MATLAB实现再到可视化分析与调试的完整闭环才能真正吃透MSK这类调制技术。当你能够自如地调整参数、观察波形变化、分析性能曲线时那些抽象的通信原理概念就变成了你手中可操控、可验证的鲜活工具。下次当你需要验证一个通信算法时不妨试着用这套方法从搭建链路、设计滤波器到生成清晰的对比图一步步地将想法变为可视化的现实。

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

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

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…