科学音频处理(二):如何使用 Octave 对音频文件进行基本数学信号处理

简介:

信号叠加

两个信号 S1(t)和 S2(t)相加形成一个新的信号 R(t),这个信号在任何瞬间的值等于构成它的两个信号在那个时刻的值之和。就像下面这样:

 
  1. R(t) = S1(t) + S2(t)

我们将用 Octave 重新产生两个信号的和并通过图表看达到的效果。首先,我们生成两个不同频率的信号,看一看它们的叠加信号是什么样的。

第一步:产生两个不同频率的信号(oog 文件)

 
  1. >> sig1='cos440.ogg'; %creating the audio file @440 Hz
  2. >> sig2='cos880.ogg'; %creating the audio file @880 Hz
  3. >> fs=44100; %generating the parameters values (Period, sampling frequency and angular frequency)
  4. >> t=0:1/fs:0.02;
  5. >> w1=2*pi*440*t;
  6. >> w2=2*pi*880*t;
  7. >> audiowrite(sig1,cos(w1),fs); %writing the function cos(w) on the files created
  8. >> audiowrite(sig2,cos(w2),fs);

然后我们绘制出两个信号的图像。

信号 1 的图像(440 赫兹)

 
  1. >> [y1, fs] = audioread(sig1);
  2. >> plot(y1)

信号 1 的图像

信号 1 的图像

信号 2 的图像(880 赫兹)

 
  1. >> [y2, fs] = audioread(sig2);
  2. >> plot(y2)

信号 2 的图像

信号 2 的图像

第二步:把两个信号叠加

现在我们展示一下前面步骤中产生的两个信号的和。

 
  1. >> sumres=y1+y2;
  2. >> plot(sumres)

叠加信号的图像

和信号的图像

和信号的图像

Octaver 中的效果

在 Octaver 中,这个效果产生的声音是独特的,因为它可以仿真音乐家弹奏的低八度或者高八度音符(取决于内部程序设计),仿真音符和原始音符成对,也就是两个音符发出相同的声音。

第三步:把两个真实的信号相加(比如两首音乐歌曲)

为了实现这个目的,我们使用格列高利圣咏Gregorian Chants中的两首歌曲(声音采样)。

圣母颂曲Avemaria Track

首先,我们看一下圣母颂曲并绘出它的图像:

 
  1. >> [y1,fs]=audioread('avemaria_.ogg');
  2. >> plot(y1)

圣母歌曲

圣母歌曲

赞美诗曲Hymnus Track

现在我们看一下赞美诗曲并绘出它的图像。

 
  1. >> [y2,fs]=audioread('hymnus.ogg');
  2. >> plot(y2)

赞美诗曲

赞美诗曲

圣母颂曲 + 赞美诗曲

 
  1. >> y='avehymnus.ogg';
  2. >> audiowrite(y, y1+y2, fs);
  3. >> [y, fs]=audioread('avehymnus.ogg');
  4. >> plot(y)

圣母歌曲 + 赞美诗曲

圣母歌曲 + 赞美诗曲

结果,从音频的角度来看,两个声音信号混合在了一起。

两个信号的乘积

对于求两个信号的乘积,我们可以使用类似求和的方法。我们使用之前生成的相同文件。

 
  1. R(t) = S1(t) * S2(t)
 
  1. >> sig1='cos440.ogg'; %creating the audio file @440 Hz
  2. >> sig2='cos880.ogg'; %creating the audio file @880 Hz
  3. >> product='prod.ogg'; %creating the audio file for product
  4. >> fs=44100; %generating the parameters values (Period, sampling frequency and angular frequency)
  5. >> t=0:1/fs:0.02;
  6. >> w1=2*pi*440*t;
  7. >> w2=2*pi*880*t;
  8. >> audiowrite(sig1, cos(w1), fs); %writing the function cos(w) on the files created
  9. >> audiowrite(sig2, cos(w2), fs);>> [y1,fs]=audioread(sig1);>> [y2,fs]=audioread(sig2);
  10. >> audiowrite(product, y1.*y2, fs); %performing the product
  11. >> [yprod,fs]=audioread(product);
  12. >> plot(yprod); %plotting the product

注意:我们必须使用操作符 ‘.*’,因为在参数文件中,这个乘积是值与值相乘。更多信息,请参考 Octave 矩阵操作产品手册。

乘积生成信号的图像

乘积信号的图像

乘积信号的图像

两个基本频率相差很大的信号相乘后的图表效果(调制原理)

第一步:

生成两个频率为 220 赫兹的声音信号。

 
  1. >> fs=44100;
  2. >> t=0:1/fs:0.03;
  3. >> w=2*pi*220*t;
  4. >> y1=cos(w);
  5. >> plot(y1);

载波

载波

第二步:

生成一个 22000 赫兹的高频调制信号。

 
  1. >> y2=cos(100*w);
  2. >> plot(y2);

调制中

调制中

第三步:

把两个信号相乘并绘出图像。

 
  1. >> plot(y1.*y2);

调制后的信号

调制后的信号

一个信号和一个标量相乘

一个函数和一个标量相乘的效果等于更改它的值域,在某些情况下,更改的是相标志。给定一个标量 K ,一个函数 F(t) 和这个标量相乘定义为:

 
  1. R(t) = K*F(t)
 
  1. >> [y,fs]=audioread('cos440.ogg'); %creating the work files
  2. >> res1='coslow.ogg';
  3. >> res2='coshigh.ogg';>> res3='cosinverted.ogg';
  4. >> K1=0.2; %values of the scalars
  5. >> K2=0.5;>> K3=-1;
  6. >> audiowrite(res1, K1*y, fs); %product function-scalar
  7. >> audiowrite(res2, K2*y, fs);
  8. >> audiowrite(res3, K3*y, fs);

原始信号的图像

 
  1. >> plot(y)

信号振幅减为原始信号振幅的 0.2 倍后的图像

 
  1. >> plot(res1)

低余弦

低余弦

信号振幅减为原始振幅的 0.5 倍后的图像

 
  1. >> plot(res2)

高余弦

高余弦

倒相后的信号图像

 
  1. >> plot(res3)

倒相余弦

倒相余弦

原文发布时间为:2016-09-30

本文来自云栖社区合作伙伴“Linux中国”

相关文章
|
15天前
|
存储 人工智能 机器人
【Matlab】Matlab 汉/英语(A/a)声学特征比较与基音频率分析(源码+音频文件)【独一无二】
【Matlab】Matlab 汉/英语(A/a)声学特征比较与基音频率分析(源码+音频文件)【独一无二】
|
1月前
|
机器学习/深度学习 数据采集 算法
m基于深度学习网络的花朵种类识别系统matlab仿真,包含GUI界面
m基于深度学习网络的花朵种类识别系统matlab仿真,包含GUI界面
30 6
|
3月前
|
算法 关系型数据库 计算机视觉
NumPy 秘籍中文第二版:五、音频和图像处理
NumPy 秘籍中文第二版:五、音频和图像处理
41 0
|
9月前
|
机器学习/深度学习 数据可视化 数据库
【MATLAB第5期】源码分享#基于小波时间散射网络(WTSN)和长短期记忆网络 (LSTM) 的ECG信号分类模型,含源代码+中文注释,保姆级教学
【MATLAB第5期】源码分享#基于小波时间散射网络(WTSN)和长短期记忆网络 (LSTM) 的ECG信号分类模型,含源代码+中文注释,保姆级教学
|
12月前
|
算法
labview信号时域分析编程笔记
labview信号时域分析编程笔记
80 0
数字信号处理音频FIR去噪滤波器(基于MATLAB GUI的开发完整代码+报告+课设)
数字信号处理音频FIR去噪滤波器(基于MATLAB GUI的开发完整代码+报告+课设)
160 0
数字信号处理音频FIR去噪滤波器(基于MATLAB GUI的开发完整代码+报告+课设)
|
算法 计算机视觉
砥砺的前行|基于labview的机器视觉图像处理|NI Vision Assisant(六)——Binary(二值图) 功能
砥砺的前行|基于labview的机器视觉图像处理|NI Vision Assisant(六)——Binary(二值图) 功能
439 0
砥砺的前行|基于labview的机器视觉图像处理|NI Vision Assisant(六)——Binary(二值图) 功能
|
存储 算法 编译器
数字信号处理-01- 数字信号处理基础知识
数字信号处理-01- 数字信号处理基础知识
127 0
数字信号处理-01- 数字信号处理基础知识
|
监控 算法 Java
【数字信号处理】数字信号处理简介 ( 数字信号处理技术 | 傅里叶变换 )
【数字信号处理】数字信号处理简介 ( 数字信号处理技术 | 傅里叶变换 )
193 0
|
资源调度 算法 计算机视觉
LabVIEW图像增强算法(基础篇—5)
LabVIEW图像增强算法(基础篇—5)
LabVIEW图像增强算法(基础篇—5)