如何向音频文件中插入噪声

为了研究噪声和音乐对EEG的的影响,实验前需要准备一段夹杂噪声的音乐。

  1. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  2. % Program to insert the white Gaussian noise into muisc
  3. %y 音乐数据
  4. %Fs 采样率
  5. %bits 采样位,默认为16位
  6. %wgn(m,n,p) 获取m * n、噪声强度为p的高斯白噪声
  7. % author: Andy Wu
  8. % date: 6/10/2009
  9. % modify: 9/10/2009
  10. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  11. %打开一个名为“请选择背景音乐”的对话框,显示指定路径下所有的.wav文件
  12. [file_name,file_path]=uigetfile('F:\MatlabProgram\*.wav','请选择背景音乐');
  13. sound_path=strcat(file_path,file_name);
  14. %将选中的音乐文件的数据和采样率读到sound_data和Fs
  15. [sound_data,Fs,bits]=wavread(sound_path);
  16. sound_length=length(sound_data);
  17. %求出音乐的播放时间长度
  18. sound_time=sound_length/Fs;
  19. fprintf(1,'背景音乐播放长度 %6.2f(秒)\n',sound_time);
  20. %检查是否定义噪声时间, 否则输入噪声时间
  21. if ~exist('noise_time')
  22. noise_time=input('请输入噪声长度(秒):');
  23. end
  24. noise_length=noise_time*Fs;
  25. %输出一个噪声强度为1dBw,noise_length x 1的高斯白噪声矩阵数据
  26. noise_data=wgn(noise_length,1,1);
  27. %检查是否输入插入噪声的起始时间
  28. if ~exist('noise_start_time')
  29. noise_start_time=input('请输入您要设置的噪声起始时间(秒):');
  30. end
  31. %计算噪声数据插入位置
  32. noise_position=noise_start_time*Fs;
  33. %插入噪声数据
  34. sound_data(noise_position:noise_position+noise_length-1)=noise_data;
  35. %dlmwrite('F:\notify.txt',y); %将插入噪声后的音乐数据写入文本文件
  36. %soundData=csvread('F:\notify.txt'); %读出音乐数据至soundData
  37. object= analogoutput('winsound'); %建立硬件对象
  38. addchannel(object,[1 2]); %创建声音输出通道
  39. set(object,'SampleRate',Fs) %设置采样率
  40. data1 =sound_data(:,1); %双声道
  41. data2 =sound_data(:,1);
  42. putdata(object,[data1 data2]); %往声卡输送音乐数据
  43. %start(object); %开始输出音乐
  44. %stop(object) %停止输出音乐

How to insert a segment of noise to music file的更多相关文章

  1. 源码浅析:MySQL一条insert操作,会写哪些文件?包括UNDO相关的文件吗?

    DML操作的大致流程 在解答上述疑惑之前,我们来梳理一下DML操作的大致流程: 1.语法解析.语义解析 2.生成执行计划 3.事务修改阶段 1) 激活事务,事务状态由not_active变为activ ...

  2. 【UISegmentedControl】-  分段控件

    一.初始化 二.常见的属性 1.segmentedControlStyle属性:设置基本的样式 2.momentary属性:设置在点击后是否恢复原样 . 3.numberOfSegments属性:只读 ...

  3. UI--普通控件总结1--控件使用

    本文目录 0.UIView常用的属性和操作 0_1.UIView常见的属性 0_2.UIView状态 0_3.UIView常用的方法 1.文本框UITextField和文本视图UITextView 1 ...

  4. 『GreenPlum系列』GreenPlum 4节点集群安装(图文教程)

      目标架构如上图   一.硬件评估 cpu主频,核数推荐CPU核数与磁盘数的比例在12:12以上Instance上执行时只能利用一个CPU核资源进行计算,推荐高主频 内存容量 网络带宽重分布操作 R ...

  5. 【mysql】关于IO/内存方面的一些优化

    这里使用的是mysql  Ver 14.14 Distrib 5.6.19, for Linux (i686) using  EditLine wrapper 一.mysql目录文件 ibdata1: ...

  6. TOYS - POJ 2318(计算几何,叉积判断)

    题目大意:给你一个矩形的左上角和右下角的坐标,然后这个矩形有 N 个隔板分割成 N+1 个区域,下面有 M 组坐标,求出来每个区域包含的坐标数.   分析:做的第一道计算几何题目....使用叉积判断方 ...

  7. lucene原理及源码解析--核心类

    马云说:大家还没搞清PC时代的时候,移动互联网来了,还没搞清移动互联网的时候,大数据时代来了. 然而,我看到的是:在PC时代搞PC的,移动互联网时代搞移动互联网的,大数据时代搞大数据的,都是同一伙儿人 ...

  8. InnoDB存储引擎介绍-(7) Innodb数据页结构

    数据页结构 File Header 总共38 Bytes,记录页的头信息 名称 大小(Bytes) 描述 FIL_PAGE_SPACE 4 该页的checksum值 FIL_PAGE_OFFSET 4 ...

  9. 学习笔记:The Best of MySQL Forum

    http://mysql.rjweb.org/bestof.html I have tagged many of the better forum threads. 'Better' is based ...

随机推荐

  1. 秒杀多线程第七篇 经典线程同步 互斥量Mutex(续)

    java使用Synchronized关键字实现互斥,而同时有Lock支持. 这两个的效果是等同的,Synchronized性能的起伏较大,而lock比较收敛. 为了代码的可读性,Synchronize ...

  2. Testng 运行Cannot find class in classpath

    用Testng运行多个class,结果报: org.testng.TestNGException: Cannot find class in classpath: Salesman     at or ...

  3. 深入理解JVM一垃圾回收算法

    我们都知道java语言与C语言最大的区别就是内存自动回收,那么JVM是怎么控制内存回收的,这篇文章将介绍JVM垃圾回收的几种算法,从而了解内存回收的基本原理. 一.stop the world 在介绍 ...

  4. 从块级元素和行内元素的分析到bfc的布局理解

    接口和属性介绍 播放器提供了progressMakers属性,是一个数组类型,每一条记录包含offset时间和text打点的内容,还可以包含其他属性,此属性用于告诉播放器进度条打点记录,记录内容属性说 ...

  5. 【NuGet】使用NuGet打包并发布至ProGet过程 (打包再次详解)【下篇】

    一.前言 上篇[1]主要介绍了利用csproj文件使用NuGet打包至ProGet的过程,并附上了用于在Jenkins上运行的python脚本.本篇的主要内容分为以下几点: 1. Nuspec与Nup ...

  6. 模块(3)-使用__future__

    使用__future__ Python的每个新版本都会增加一些新的功能,或者对原来的功能作一些改动.有些改动是不兼容旧版本的,也就是在当前版本运行正常的代码,到下一个版本运行就可能不正常了. 从Pyt ...

  7. Function.caller, arguments.caller, arguments.callee, arguments.callee.calller

    Function.caller指向当前函数的调用者,是arguments.caller的替代者 arguments.caller也是指向当前函数的调用者,已被废弃 arguments.callee是对 ...

  8. 「CodePlus 2017 11 月赛」可做题

    这种题先二进制拆位,显然改的位置只有每一段确定的数的开头和结尾,只需要对于每一个可决策位置都尝试一下填1和0,然后取min即可. #include<iostream> #include&l ...

  9. 全面支持Angular2的Web后台Bootstrap模板Sing App - Web & Angular 2.0 Dashboard

    在线预览 Sing App v3.3.0 (包含Angular 2.0版本实现) 现在,本模板完全支持Angular2.0版本啦. Sing Web App 是由专业前端工程师采用行业内流行的技术构建 ...

  10. Web前端之HTML详解20180327

    一.html概述 html就是超文本标记语言的简写,是最基础的网页语言.html通过标签来定义语言,代码都是由标签所组成. 1.html代码从<html>开始</html>结束 ...