离散时间傅里叶变换(DTFT)核心原理、MATLAB/Python实现与工程应用全解析

news2026/5/18 10:52:32
1. 项目概述从连续到离散的信号分析桥梁信号处理领域里我们常常需要分析一个信号的频率成分。对于连续时间信号我们有强大的工具——连续时间傅里叶变换。但现实世界中的计算机和数字系统处理的都是离散的、一串串的数字序列比如一段数字音频、一幅图像的像素值或者传感器按固定时间间隔采集的温度数据。这时连续时间傅里叶变换就显得有些“水土不服”了。离散时间傅里叶变换也就是我们常说的DTFT正是为了解决这个问题而生的核心工具。它专门用来分析离散时间信号的频率特性是连接连续世界与离散世界、理论分析与工程实践的一座关键桥梁。简单来说DTFT回答了一个根本问题一个给定的离散时间序列比如x[n] {..., 1, 2, 3, ...}它里面包含了哪些频率的正弦波成分各自的“强度”幅度和“起始位置”相位又是怎样的理解DTFT不仅是学习数字信号处理课程的必经之路更是从事音频处理、图像分析、通信系统设计、乃至机器学习中特征提取等工作的基本功。无论你是正在啃教材的学生还是需要快速回顾原理的工程师掌握DTFT的来龙去脉、性质和应用中的那些“坑”都能让你在信号处理的世界里看得更清楚走得更稳。2. DTFT的核心定义与数学内涵解析2.1 从连续傅里叶变换到DTFT的推导逻辑要理解DTFT最好从它的“前身”——连续时间傅里叶变换说起。对于一个连续时间信号x(t)其傅里叶变换X(ω)定义为积分形式揭示了信号在连续频率域ω上的能量分布。然而当我们用ADC模数转换器以采样周期T对x(t)进行采样时得到的就是离散序列x[n] x(nT)。这里的n是整数索引。DTFT的直接定义式看起来非常简洁X(e^(jω)) Σ_{n-∞}^{∞} x[n] * e^(-jωn)这个公式是DTFT分析的起点。我们需要深入理解其中每一个符号的含义X(e^(jω)) 这是变换后的结果。注意它的自变量是e^(jω)而不仅仅是ω。这种写法暗示了X是复变量z在单位圆z e^(jω)上的取值这直接关联到更广泛的Z变换。X(e^(jω))本身是一个复数它同时包含了幅度信息和相位信息。x[n] 待分析的离散时间序列。求和下标从负无穷到正无穷这意味着在理论上DTFT要求信号是双边无限的。这一点在实际应用中至关重要我们后文会详细讨论如何处理有限长信号。e^(-jωn) 这是复正弦基函数。ω是数字角频率单位是弧度/样本。它与模拟角频率Ω的关系为ω ΩT。e^(-jωn)可以展开为cos(ωn) - j sin(ωn)因此DTFT的本质是将序列x[n]投影到一组频率为ω的复正弦基上求得该频率分量上的“投影系数”。注意这里ω的物理意义。ω π对应的是数字频率中的最高频率奈奎斯特频率即f_s/2采样频率的一半。ω从-π到π或0到2π的变化就覆盖了离散信号所能表示的所有频率成分。2.2 DTFT的性质与物理意义深度剖析DTFT不是一堆枯燥的公式它的每一条性质都有深刻的物理和工程意义。掌握这些性质才能灵活运用DTFT。1. 周期性X(e^(j(ω2πk))) X(e^(jω))其中k为任意整数。 这是DTFT最显著的特性之一。因为核心的复指数项e^(-jωn)本身就以2π为周期。这意味着X(e^(jω))是一个以2π为周期的连续函数。在工程上我们通常只观察ω在[-π, π]或[0, 2π]这一个周期内的图像就足够了。这解释了为什么数字系统的频率响应总是周期重复的。2. 线性性若x1[n]的DTFT为X1(e^(jω))x2[n]的DTFT为X2(e^(jω))则a*x1[n] b*x2[n]的DTFT为a*X1(e^(jω)) b*X2(e^(jω))。 线性性是所有线性变换的基础它保证了我们可以对复杂信号进行分解分析再合并结果。3. 时移与频移特性时移x[n - n0]的DTFT为e^(-jωn0) * X(e^(jω))。时域上的延迟在频域体现为所有频率分量附加一个线性相位偏移-ωn0。在滤波器设计中这个性质关乎系统的相位响应是否线性。频移调制e^(jω0 n) * x[n]的DTFT为X(e^(j(ω-ω0)))。时域乘以一个复正弦导致频域频谱的整体搬移。这是通信系统中调制技术的理论基础。4. 时域卷积与频域相乘x[n] * h[n]卷积和的DTFT为X(e^(jω)) * H(e^(jω))。 这是信号处理中最重要、最强大的性质之一。它意味着时域中复杂的卷积运算在频域中变成了简单的乘法运算。这是FFT快速傅里叶变换加速卷积计算、以及滤波器频率设计方法的根基。设计一个滤波器h[n]本质上就是在塑造其频率响应H(e^(jω))。5. 帕斯瓦尔定理Σ_{n-∞}^{∞} |x[n]|^2 (1/2π) ∫_{-π}^{π} |X(e^(jω))|^2 dω该定理揭示了能量守恒。时域信号的总能量等于其频域能量谱密度在一个周期内的积分。这使得我们可以从频域角度分析和比较信号的能量。6. 对称性如果x[n]是实序列绝大多数工程信号都是那么其DTFTX(e^(jω))满足共轭对称性X(e^(jω)) X*(e^(-jω))。 由此可推出幅度谱|X(e^(jω))|是偶函数|X(e^(jω))| |X(e^(-jω))|相位谱∠X(e^(jω))是奇函数∠X(e^(jω)) -∠X(e^(-jω))这个性质非常实用。在绘制实信号的频谱时我们只需画出ω从0到π的部分因为负频率部分是正频率的镜像没有新的信息。这大大简化了分析和可视化的工作。3. DTFT的数值计算与MATLAB/Python实操理论上DTFT需要对无限长序列在连续频率上求和。但计算机只能处理有限长的离散数据。因此工程上的“计算DTFT”实际上是在做两件事1) 用有限长序列近似2) 在离散的频率点上进行求值。这正是DFT离散傅里叶变换和其高效算法FFT所做的工作。3.1 从DTFT到DFT/FFT有限长与离散化的必然假设我们有一个长度为N的有限长序列x[n]其中n 0, 1, ..., N-1。我们可以将其视为一个无限长序列中截取出来的一段即加了一个矩形窗。我们要计算其频谱不可能计算所有连续的ω只能在一组离散的频率点ω_k 2πk / Nk 0, 1, ..., N-1上进行求值。将这组离散频率ω_k代入DTFT公式X[k] X(e^(jω_k)) Σ_{n0}^{N-1} x[n] * e^(-j*(2πk/N)*n)这个公式就是DFT的定义式。而FFT只是一种高效计算DFT的算法家族如Cooley-Tukey算法。因此我们通常说用FFT来计算一个有限长序列的频谱本质上是在对信号的DTFT进行频域采样。实操心得在MATLAB或Python中fft函数返回的就是X[k]。k0对应直流分量ω0kN/2当N为偶数时对应奈奎斯特频率ωπ。要获得真实的数字角频率向量应该是omega (0:N-1) * (2*pi/N)。如果想得到以零频率为中心的对称频谱可以使用fftshift函数。3.2 关键参数设置与频谱图解读下面通过一个具体的例子展示在MATLAB/Python中如何计算并可视化一个信号的DTFT通过FFT实现并解释所有关键步骤和参数。案例分析一个包含两个频率分量的合成信号。假设采样频率Fs 1000 Hz我们合成一个1秒长的信号包含一个50Hz和一个120Hz的正弦波并加入一些随机噪声。% MATLAB 代码示例 Fs 1000; % 采样频率 (Hz) T 1/Fs; % 采样间隔 (秒) L 1000; % 信号长度 (样本数) 对应1秒 t (0:L-1)*T; % 时间向量 % 生成信号 50Hz 和 120Hz 正弦波 x 0.7*sin(2*pi*50*t) sin(2*pi*120*t); x x 0.5*randn(size(t)); % 加入高斯白噪声 % 计算FFT NFFT 2^nextpow2(L); % 使用下一个2的幂次作为FFT长度提高计算效率并便于插值 X fft(x, NFFT); % 计算NFFT点FFT X X / L; % 除以信号长度L使频谱幅度具有物理意义对应原正弦波的振幅 % 构建单边频谱的频率向量 f Fs/2 * linspace(0, 1, NFFT/21); % 只取正频率部分到奈奎斯特频率Fs/2为止 % 计算单边幅度谱 X_mag_single_side 2 * abs(X(1:NFFT/21)); % 乘以2是因为能量对称将负频率能量加到正频率 % 绘图 figure; subplot(2,1,1); plot(t(1:100), x(1:100)); % 绘制前100个点看时域波形 title(时域信号 (前0.1秒)); xlabel(时间 (秒)); ylabel(幅度); subplot(2,1,2); plot(f, X_mag_single_side); title(信号的单边幅度谱 (通过FFT计算DTFT)); xlabel(频率 (Hz)); ylabel(|X(f)|); grid on; xlim([0, Fs/2]); % 聚焦在0到奈奎斯特频率之间# Python (NumPy Matplotlib) 代码示例 import numpy as np import matplotlib.pyplot as plt Fs 1000.0 # 采样频率 (Hz) T 1.0 / Fs # 采样间隔 (秒) L 1000 # 信号长度 (样本数) t np.arange(0, L) * T # 时间向量 # 生成信号 x 0.7 * np.sin(2 * np.pi * 50 * t) np.sin(2 * np.pi * 120 * t) x x 0.5 * np.random.randn(*t.shape) # 加入高斯白噪声 # 计算FFT NFFT 2**int(np.ceil(np.log2(L))) # 下一个2的幂次 X np.fft.fft(x, NFFT) # 计算NFFT点FFT X X / L # 归一化 # 构建频率向量 (单边) f Fs / 2 * np.linspace(0, 1, NFFT//2 1) # 计算单边幅度谱 X_mag_single_side 2 * np.abs(X[0:NFFT//2 1]) # 绘图 plt.figure(figsize(10, 8)) plt.subplot(2, 1, 1) plt.plot(t[:100], x[:100]) # 绘制前100个点 plt.title(时域信号 (前0.1秒)) plt.xlabel(时间 (秒)) plt.ylabel(幅度) plt.grid(True) plt.subplot(2, 1, 2) plt.plot(f, X_mag_single_side) plt.title(信号的单边幅度谱 (通过FFT计算DTFT)) plt.xlabel(频率 (Hz)) plt.ylabel(|X(f)|) plt.grid(True) plt.xlim([0, Fs/2]) plt.tight_layout() plt.show()关键参数与操作解析FFT点数NFFT 我们使用了2^nextpow2(L)。使用2的幂次长度能让FFT算法基2-FFT效率最高。NFFT也可以大于信号长度L这相当于在序列后面补零。补零并不能提高频率分辨率分辨率由有效数据长度L决定但可以让频谱图看起来更光滑即对DTFT进行更密集的频域采样使得曲线细节更明显。归一化X X / L 这一步至关重要。对于幅度谱除以信号长度L后频谱峰值才能对应原始正弦波的真实振幅例如0.7和1.0。如果不做归一化峰值幅度会与L成正比失去物理可比性。单边谱与双边谱 由于实信号频谱的共轭对称性我们通常只显示正频率部分单边谱。在计算单边幅度谱时除了直流分量k0外其他正频率分量需要乘以2以补偿被忽略的负频率部分的能量。频率向量f的构建 频率向量f的范围是从0到Fs/2奈奎斯特频率长度是NFFT/21。f[k]对应的就是X[k]这个FFT结果所代表的实际物理频率Hz。3.3 窗函数的影响与选择在上面的例子中我们默认对信号x[n]加了一个矩形窗即直接截取了一段。加窗是有限长信号分析中无法避免的操作但窗函数会扭曲真实的DTFT。频谱泄漏 对于无限长的正弦信号其理想的DTFT是在该正弦频率处的一个冲激。但当我们用矩形窗截取一段时相当于用矩形窗的频谱一个sinc函数去卷积这个理想冲激导致冲激“扩散”开来主瓣变宽旁瓣出现。这就是频谱泄漏——能量从本应集中的频率点泄漏到了整个频域。减小泄漏的方法就是使用非矩形窗如汉宁窗、汉明窗、布莱克曼窗等。这些窗函数在时域两端平滑地衰减到零其频谱的主瓣宽度可能略有增加但旁瓣电平显著降低从而抑制了泄漏。% MATLAB 加窗示例 window hann(L); % 生成汉宁窗注意转置以匹配行向量 x_windowed x .* window; % 时域加窗 X_windowed fft(x_windowed, NFFT) / (sum(window)/2); % 计算FFT并归一化窗函数能量补偿 % ... 后续绘图与之前类似# Python 加窗示例 window np.hanning(L) x_windowed x * window # 归一化因子需考虑窗函数的能量这里使用平均幅度近似补偿 X_windowed np.fft.fft(x_windowed, NFFT) / (np.sum(window)/2.0) # ... 后续绘图与之前类似注意事项 加窗后信号的总能量会减少因为两端被衰减了。为了保持幅度谱的物理意义在归一化时除数不再是信号长度L而应该是窗函数的相干增益或有效噪声带宽的补偿因子。对于幅度谱常用sum(window)/2作为归一化因子对于对称窗。这是一个容易出错的细节需要根据具体的分析目的是看精确幅度还是看频率位置来调整。4. DTFT在滤波器设计与系统分析中的应用实战DTFT不仅是分析工具更是设计工具。在数字滤波器设计和线性时不变系统分析中DTFT扮演着核心角色。4.1 通过DTFT理解滤波器频率响应一个线性时不变系统完全由其单位脉冲响应h[n]或系统函数H(z)描述。而该系统的频率响应H(e^(jω))就是h[n]的DTFT。H(e^(jω))是一个复数其模|H(e^(jω))|称为幅度响应表示系统对不同频率信号的放大或衰减倍数其辐角∠H(e^(jω))称为相位响应表示系统对不同频率信号造成的相位延迟。例如设计一个简单的5点移动平均滤波器h[n] [1/5, 1/5, 1/5, 1/5, 1/5]n0,1,2,3,4。 我们可以直接计算其DTFT来观察其频率特性H(e^(jω)) (1/5) * Σ_{n0}^{4} e^(-jωn) (1/5) * (1 - e^(-j5ω)) / (1 - e^(-jω))利用欧拉公式可以推导出其幅度响应为|H(e^(jω))| (1/5) * |sin(5ω/2) / sin(ω/2)|绘制这个函数我们会看到一个低通滤波器的特性低频部分ω接近0增益接近1高频部分ω接近π增益很小。这就是一个最简单的FIR有限长脉冲响应滤波器。在实际工程中我们几乎总是用FFT来计算h[n]的DTFT从而得到其频率响应的离散采样图。% MATLAB 分析移动平均滤波器频率响应 h ones(1,5)/5; % 脉冲响应 N_freq 1024; % 频率采样点数 [H, w] freqz(h, 1, N_freq, whole); % 使用freqz函数计算频率响应 % freqz 本质上就是计算了 h[n] 的DTFT在离散频率点 w 上的值 figure; subplot(2,1,1); plot(w/pi, abs(H)); % 横轴归一化为 π title(移动平均滤波器幅度响应); xlabel(数字频率 (×π rad/sample)); ylabel(|H(e^{j\omega})|); grid on; subplot(2,1,2); plot(w/pi, angle(H)/pi); % 相位以 π 为单位 title(相位响应); xlabel(数字频率 (×π rad/sample)); ylabel(相位 (×π rad)); grid on;4.2 滤波器设计中的DTFT视角窗函数法窗函数法是设计FIR滤波器最直观的方法之一其核心思想直接源于DTFT。理想滤波器频率响应 首先给定一个理想的频率响应H_d(e^(jω))例如理想低通滤波器的H_d(e^(jω))在通带内为1阻带内为0。理想脉冲响应 通过对H_d(e^(jω))进行逆DTFT得到理想的、无限长的单位脉冲响应h_d[n]。对于理想低通滤波器h_d[n]是一个 sinc 函数是非因果且无限长的。加窗截断 为了得到一个因果的、有限长的FIR滤波器我们用一有限长窗函数w[n]去截断h_d[n]得到实际可实现的脉冲响应h[n] h_d[n] * w[n]n在窗函数长度内。频域效应 根据DTFT的卷积定理实际滤波器的频率响应H(e^(jω))是理想频率响应H_d(e^(jω))与窗函数频谱W(e^(jω))的周期卷积。W(e^(jω))的主瓣宽度决定了过渡带的宽度旁瓣电平决定了阻带衰减和通带波纹。因此选择不同的窗函数汉宁、汉明、凯泽等就是在主瓣宽度过渡带和旁瓣电平阻带衰减之间进行权衡。这个过程完美地体现了DTFT作为时域和频域之间桥梁的作用设计在频域步骤1转换到时域步骤2再通过时域操作步骤3影响最终的频域特性步骤4。5. 常见问题、误区与排查技巧实录在实际应用DTFT通过FFT时会遇到各种问题。下面是一些典型问题及其背后的原理和解决方案。5.1 频谱图看起来“不对”频率、幅度、相位问题问题1频率轴标度错误峰值位置不对。现象 明明输入是50Hz正弦波频谱峰值却出现在别的频率上。排查检查采样频率Fs和频率向量f 确保f向量的计算正确。f (0:NFFT/2) * (Fs / NFFT)。如果使用了fftshift频率向量也需要相应调整为(-NFFT/2 : NFFT/2-1) * (Fs/NFFT)。检查信号长度与频率分辨率 频率分辨率Δf Fs / N其中N是参与FFT的数据点数非补零后的NFFT。如果50Hz不是Δf的整数倍峰值就会出现在两个离散频率点之间并且幅度会因“栅栏效应”而低于真实值。这时可以通过补零来增加NFFT使频谱曲线更光滑更容易通过插值观察峰值位置但记住这并不能改变真实的频率分辨率Δf。解决方案 确保Fs设置正确理解f向量的含义。对于精确测频可以考虑使用更高级的算法如通过主瓣内插值如相位差法、比值法来估计真实峰值频率。问题2频谱幅度不对与信号实际振幅不符。现象 一个振幅为1的正弦波频谱峰值不是1。排查是否做了正确的归一化对于单边幅度谱计算fft后需要先除以信号长度 N再对正频率分量除直流外乘以2。是否使用了窗函数如果使用了非矩形窗归一化因子需要改变。矩形窗的归一化因子是N汉宁窗大约是sum(window)/2。错误的归一化因子会导致幅度失真。能量是否被分散如果存在频谱泄漏信号频率不是频率分辨率的整数倍正弦波的能量会分散到多个频点导致主峰幅度降低。加窗可以减少泄漏但也会改变主瓣幅度需要对应的幅度补偿。解决方案 严格按照“fft-除以有效长度考虑窗-取绝对值-单边谱乘以2”的流程处理。对于校准应用可以使用已知幅度的标准信号进行系统校准。问题3相位谱杂乱无章或不符合预期。现象 计算出的相位谱在非峰值频率处呈现随机噪声状或者在峰值频率处的相位值与理论值有偏差。排查低能量处的相位无意义 在信号频谱幅度很小接近噪声水平的频率点其相位信息被噪声主导是随机且无意义的。这是正常现象。相位卷绕angle()函数返回的相位主值在[-π, π]之间。如果一个信号的相位变化超过这个范围会发生2π的跳变导致相位图出现锯齿状跳变。这时需要使用unwrap()函数进行相位解卷绕。时域信号非整周期截断 这是导致相位测量偏差的常见原因。如果截取的一段信号不是正弦波周期的整数倍相当于给原信号加了一个矩形窗该窗的相位特性会干扰原始信号的相位。加窗如汉宁窗可以在一定程度上缓解但最佳实践是尽量保证同步采样整周期截断。解决方案 关注高能量频点处的相位使用unwrap(angle(X))获得连续相位对于精确相位测量确保整周期截断或使用合适的窗函数和校正算法。5.2 混叠与频率归一化理解数字频率ω问题如何理解数字频率ω和模拟频率f的关系为什么频谱图只画到Fs/2核心概念——混叠 根据奈奎斯特采样定理采样频率Fs必须大于信号最高频率f_max的两倍否则高频分量会混叠到低频区域造成无法挽回的失真。在数字频率域ω 2πf / Fs。当f从0变化到Fs/2时ω从0变化到π。超过Fs/2的频率成分其数字频率ω会“折叠”回[0, π]区间这就是混叠在数字频率域的体现。工程实践 因此在绘制离散信号的频谱时我们通常只关心0到π对应0到Fs/2这个“基带”范围。Fs/2这个频率点被称为奈奎斯特频率是离散系统能无混叠表示的最高频率。操作检查 在代码中确保你的信号不包含高于Fs/2的频率成分。如果信号来源是模拟的必须在ADC之前使用抗混叠滤波器低通滤波器截止频率略低于Fs/2来滤除高频分量。5.3 分辨率、补零与栅栏效应问题增加FFT点数补零能提高频率分辨率吗这是一个经典误区。补零不能提高频率分辨率。频率分辨率Δf 在DTFT/DFT的语境下它定义为能够区分两个频率分量的最小间隔。它只取决于信号的有效时间长度T N * T_s即Δf 1 / T Fs / N。这里N是原始数据的点数不是补零后的NFFT。补零的作用 补零是在时域数据后添加零值样本然后做更长的FFT。这相当于对原始的DTFT由N点数据决定进行更密集的采样让频谱曲线看起来更光滑减少了“栅栏效应”带来的视觉障碍使得峰值位置可以通过内插看得更清楚。但它并没有增加任何新的信息因此不能分辨出原本N点数据无法分辨的、频率差小于Fs/N的两个信号。提高分辨率的唯一方法 增加信号的实际记录长度N即增加时间T。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2621394.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;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…