科学音频处理(二):如何使用 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 的图像

信号 2 的图像(880 赫兹)


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

信号 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中国”

时间: 2024-09-01 15:56:19

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

科学音频处理(一):怎样使用 Octave 对音频文件进行读写操作

Octave 是一个 Linux 上类似于 Matlab 的软件,它拥有数量众多的函数和命令,支持声音采集.记录.回放以及音频信号的数字化处理,用于娱乐应用.研究.医学以及其它科学领域.在本教程中,我们会在 Ubuntu 上使用 Octave 的 4.0.0 版本读取音频文件,然后通过生成信号并且播放来模仿在各种情况下对音频信号的使用. 本教程中关注的不是安装和学习使用安装好的音频处理软件,而是从设计和音频工程的角度理解它是如何工作的. 环境准备 首先是安装 octave,在 Ubuntu 终端

科学音频处理(一):怎样使用Octave对音频文件进行读写操作

Octave 是一个 Linux 上类似于 Matlab 的软件,它拥有数量众多的函数和命令,支持声音采集.记录.回放以及音频信号的数字化处理,用于娱乐应用.研究.医学以及其它科学领域.在本教程中,我们会在 Ubuntu 上使用 Octave 的 4.0.0 版本读取音频文件,然后通过生成信号并且播放来模仿在各种情况下对音频信号的使用. 本教程中关注的不是安装和学习使用安装好的音频处理软件,而是从设计和音频工程的角度理解它是如何工作的. 环境准备 首先是安装 octave,在 Ubuntu 终端

Android音频处理之通过AudioRecord去保存PCM文件进行录制,播放,停止,删除功能_Android

音频这方面很博大精深,我这里肯定讲不了什么高级的东西,最多也只是一些基础类知识,首先,我们要介绍一下Android他提供的录音类,实际上他有两个,一个是MediaRecorder,还有一个就是我们今天要用到的AudioRecord,那他们有什么区别呢? 一.区别 MediaRecorder和AudioRecord都可以录制音频,区别是MediaRecorder录制的音频文件是经过压缩后的,需要设置编码器.并且录制的音频文件可以用系统自带的Music播放器播放. 而AudioRecord录制的是P

微信小程序-图片、录音、音频播放、音乐播放、视频、文件代码实例_javascript技巧

本文介绍了微信小程序的开发,主要包括图片.录音.音频播放.音乐播放.视频.文件,具体如下: 图片: wx.chooseImage(OBJECT) 从本地相册选择图片或使用相机拍照. OBJECT参数说明: 注:文件的临时路径,在小程序本次启动期间可以正常使用,如需持久保存,需在主动调用 wx.saveFile,在小程序下次启动时才能访问得到. 示例代码: wx.chooseImage({ count: 1, // 默认9 sizeType: ['original', 'compressed'],

iOS编程中的音频知识(二):那么多种格式我应该用哪一个?

iPhone支持不少格式,比如AAC,HE-AAC,AMR,IMA4等等,你可以在以下网址看到比较全的格式和简要介绍: http://www.raywenderlich.com/69365/audio-tutorial-ios-file-data-formats-2014-edition 这看起来是一条长长的单子,但是实际上仅仅少数的格式被推荐使用.要想知道该用哪些格式,你必须首先牢记如下几条: 你可以播放线性PCM,IMA4以及少数其他未压缩或简单压缩的格式更快一些并且可以同时播放没有问题.

视音频同步推送-是否有视音频裸流一起推送的例子?

问题描述 是否有视音频裸流一起推送的例子? SRS设计理念真好,我们很喜欢. 文章中给出单独推送H.264 及AAC裸流的例子,是否有视音频裸流一起推送的例子?因为实际中大多是视音频一起的. 解决方案 http://download.csdn.net/detail/ganhuanghuang/4984256 解决方案二: 谢谢! 我需要的是视音频裸码流同步推送,你推荐的是"SDL播放PCM音频裸流",不是一回事.

音频名称和长度-android 如何获取raw文件下音频的名称和时长?

问题描述 android 如何获取raw文件下音频的名称和时长? 我在res/raw文件下放了8个很短的音频,想把它们的名称和时长获取出来显示在一个listview中,如何获取它们的名称和时长呢? 解决方案 百度了一种方法,测试有用,记录下来,算是对问题的回答. 思路:遍历raw目录下文件,可以获取文件的id和名称(根据id拼接出音频资源的uri):通过MediaPlayer获取音频的duration. 主要代码如下: Field[] fields = R.raw.class.getDeclar

视频转音频转换器如何将视频转成音频

  打开视频转音频转换器:狸*窩.全能.音视频.转换器;添加视频,把自己喜欢的一段视频添加进来:视频预览,可以预览一下视频文件是否是完整有效的;设置输出格式功能按钮是小三角形图样的;这个则是高级设置按钮. 点击小三角形图样的按钮,在弹出的上拉框中,选择"常用音频"让后再选择"MP3格式"可以看到预置方案已经为"MP3"了,就是输出格式变为MP3格式了. 点击""扳手按钮,进入高级设置界面,去掉视频,只保留勾选音频,就是把这段视

C++ 学习之旅二——说一说C++头文件

  作为一个二手的.net程序员,你看到了C++头文件一定就犯迷糊了,这到底是个啥玩意.再我纠结了24个小时, google20次,度娘10下,看过10来骗文章以后,我可能稍微开窍了.我对C++头文件总结,与.net比较如下:    一.C++头文件究竟是什么,你怎么看? 每个C++/C程序通常分为两个文件.一个文件用于保存程序的声明(declaration),称为头文件.另一个文件用于保存程序的实现(implementation),称为定义(definition)文件.C++/C程序的头文件以