wav 格式音频文件生成例子
wavfile is a simple sound library for use in CSE 20211. This library allows you to generate arbitrary sound waveforms in an array, then write them out to a standard WAV format file, which can then be played back by almost any kind of computer.
Note: As a courtesy to others in the course or the lab, please use headphones when working with sounds.
Digital Sound Primer
A computer generates digital sounds by creating a digital waveform. A waveform is simply a sequence of digital values that describe how a speaker is to be physically pulsed by an digital-to-analog (DAC) converter. Positive values in the waveform indicate the speaker is to be pushed slightly outward, creating positive air pressure, while negative values indicate the speaker is to be pulled slightly inward, creating negative air pressure.
The sampling rate of a digital sound indicates how many digital values are used per second of playback. The standard for CD-quality sound is a sampling rate of 44.1KHz. The volume of a digital sound is simply the amplitude of the waveform: bigger changes mean louder sounds.
The character and quality of a sound is entirely described by the shape of its waveform. Try clicking on the waveforms below to see what they sound like. A sine wave is smooth and open, like a flute. A square wave is piercing, like a smoke alarm. A triangle wave sounds rather brassy. The random wave sounds like white noise.
Sine Wave![]() |
Square Wave![]() |
Triangle Wave![]() |
Random Wave![]() |
A sound with a regular pattern has a fundamental frequency which is the number of peaks in the waveform per second. The sine, square, and triangle waves above all have a frequency of 440Hz, which is a concert-A pitch. (Note also that the frequency is not the same as the sampling rate.)
Most sounds in the real world are not as clean and simple as the waveforms above. Instead, they are a sum of multiple waveforms at different frequencies. Musical instruments tend to produce a strong waveform at the pitch actually played. This is known as the fundamental frequency. At the same time, they also produce quieter sounds at integer multiples of the fundamental frequency, known has harmonics.
For example, click on the three sounds below. The first is a sine wave at 440Hz. The second adds a harmonic at 880Hz. The third adds another harmonic at 1760 Hz. If you listen carefully, you will see that the sounds with more harmonics are more pleasant and more realistic. (I think it sounds like a pipe organ.)
| Fundamental Frequency |
Fundamental + 1 Harmonic |
Fundamental + 2 Harmonics |
|---|---|---|
![]() |
![]() |
![]() |
Getting Started
It is very easy to generate waveforms like those above to create digital sounds and (eventually) music. To get started, download the following files:
And compile them together as follows:
Then, run the example program:
The program creates a file called sound.wav. To play back the file on Linux, use the play command:
How it Works
The sound library only has three functions:
wavfile_open creates a new file whose name is given by the first argument. It automatically puts the standard WAV header into the file for you. If successful, it returns a pointer to a FILE object. If unsucessful, it returns null.
wavfile_write writes data to an open file. The first argument must be a pointer to a FILE object returned by wavfile_open. The second argument is an array of waveform data, and the third argument is the number of samples to write. This function may be called multiple times to add more sounds to an open wavfile.
wavfile_close completes writing to a wavfile. It is required to call wavfile_close when your sound is complete, otherwise the file will not be usable.
Finally, the header contains a constant WAVFILE_SAMPLES_PER_SECOND which indicates how many samples are in a waveform per second of playback.
Example Program
The program example.c creates a simple wavfile that plays a sine-wave for one second. It works as follows:
First, an array of shorts is created to hold a waveform that will last for two seconds:
short waveform[NUM_SAMPLES];
For clarity, we define a few variables to indicate the frequency and volume of the sound. 440Hz is a concert A pitch, and the volume of the waveform is simply the amplitude, which can be up to 32768.
int volume = 32000;
Then, we fill the array with a sine wave of the desired frequency:
for(i=0;i<NUM_SAMPLES;i++) {
double t = (double) i / WAVFILE_SAMPLES_PER_SECOND;
waveform[i] = volume*sin(frequency*t*2*M_PI);
}
Finally, we use the wavfile library to write out the waveform to a file:
wavfile_write(f,waveform,length);
wavfile_close(f);
Using the simple sound library, writing out the sound file is easy. All of the challenge lies in constructing a waveform that plays the desired sound.
转自:
https://www3.nd.edu/~dthain/courses/cse20211/fall2013/wavfile/
wav 格式音频文件生成例子的更多相关文章
- (原创)speex与wav格式音频文件的互相转换
我们的司信项目又有了新的需求,就是要做会议室.然而需求却很纠结,要继续按照原来发语音消息那样的形式来实现这个会议的功能,还要实现语音播放的计时,暂停,语音的拼接,还要绘制频谱图等等. 如果是wav,m ...
- (原创)speex与wav格式音频文件的互相转换(二)
之前写过了如何将speex与wav格式的音频互相转换,如果没有看过的请看一下连接 http://www.cnblogs.com/dongweiq/p/4515186.html 虽然自己实现了相关的压缩 ...
- c#使用SoundPlayer播放wav格式音频
1.引用System.Media名称空间下的类SoundPlayer SoundPlayer player = new SoundPlayer(); 2.方法调用Play(); public vo ...
- 调用CImg库显示WAV格式音频波形
最近在做傅里叶变换和小波变换时经常要通过显示波形来检验算法,但通过visual studio之类显示波形又显得麻烦,而且不能跨平台. CImg是一个跨平台的C++的图像处理库,提供的图像处理等功能十分 ...
- ffmpeg 合并aac格式音频文件
1:连接到一起 'ffmpeg - i "concat:D:\learn\audio\1.aac|D:\learn\audio\2.aac" - acodec copy D:\le ...
- S3C2416裸机开发系列19_Fatfs播放录像wav音频文件
S3C2416裸机开发系列19 Fatfs播放录像wav音频文件 国际象棋男孩 1048272975 多媒体资源,一般都是以文件的形式存储在固化存储器中.Fatfs所支持的fat32为windo ...
- 解析WAV音频文件----》生成WAV音频文件头
前言:请各大网友尊重本人原创知识分享,谨记本人博客:南国以南i WAV音频文件介绍: WAV文件是在PC机平台上很常见的.最经典的多媒体音频文件,最早于1991年8月出现在Windows3.1操作系统 ...
- WAV格式文件无损合并&帧头数据体解析(python)(原创)
一,百度百科 WAV为微软公司(Microsoft)开发的一种声音文件格式,它符合RIFF(Resource Interchange File Format)文件规范,用于保存Windows平台的音频 ...
- Android 音视频开发(一):PCM 格式音频的播放与采集
什么是 PCM 格式 声音从模拟信号转化为数字信号的技术,经过采样.量化.编码三个过程将模拟信号数字化. 采样 顾名思义,对模拟信号采集样本,该过程是从时间上对信号进行数字化,例如每秒采集 44100 ...
- .NET winform播放音频文件
前提:最近要求做一个在winform端做一个音频文件播放的功能,至此,总结最近搜寻的相关资料. 一.微软提供了三种方式来播放音频文件 1.通过System.Media.SoundPlayer来播放 2 ...
随机推荐
- Linux的用户和权限 [补档-2023-07-07]
Linux用户和权限 3-1. su用户切换命令 exit用户退出命令 用户切换命令的语法: su [-] [用户名] 其中: - 可选,表示是否在切换用户后加载环境变量,建议带上. ...
- HarmonyOS 实战小项目开发(一)
HarmonyOS 实战小项目开发(一) 日常逼逼叨 在经过一周多的Harmonyos 开发基础知识的学习后,自己通过对于Harmonyos基础知识的学习之后,结合自己的一些想法,独自完成了利用Ark ...
- Linux输出转换命令 xargs
一.基本用法 xargs命令的作用,是将标准输入转为命令行参数. 原因:大多数命令都不接受标准输入作为参数,只能直接在命令行输入参数,这导致无法用管道命令传递参数 如下面 echo 不接受标准输出做参 ...
- Oracle 中LONG RAW BLOB CLOB类型介绍
说明: RAW: 未加工类型,可存储二进制数据或字节符 LONG: 可变长的字符串数据,最长2G,LONG具有VARCHAR2列的特性,可以存储长文本一个表中最多一个LONG列[不建议使用] LONG ...
- C++ 虚基类
虚基类(Virtual Base Class)在面向对象编程中的作用是解决多重继承中的菱形继承问题(Diamond Inheritance Problem)和共享基类问题(Shared Base Cl ...
- win32 - Session 0 隔离
在Windows XP,Windows Server 2003和Windows操作系统的早期版本中,所有服务都与登录控制台的第一个用户在同一会话中运行.该会话称为会话0.在会话0中一起运行服务和用户应 ...
- 关于谷歌浏览器出现“错误代码:net::ERR_UNSAFE_PORT”的解决办法
搭建项目时需要自己配置端口信息,但是有人搭建之后会出现如下情况 但是换用edge等浏览器没有问题,这是因为chorme浏览器有自己的默认非安全端口, 若访问这些端口就会出现这个错误,并且所有采用cho ...
- 【笔记】css —— BFC 原理
一.什么是 BFC BFC 即 Block Formatting Contexts (块级格式化上下文),具有 BFC 特性的元素可以看作是隔离了的独立容器,容器里面的元素不会在布局上影响到外面的元素 ...
- go词法作用域陷进
问题 // 创建一些目录,再将目录删除 // 错误写法 var rmdirs []func() for _, dir := range tempDirs() { os.MkdirAll(dir, 07 ...
- 深入理解String
深入理解String String是Java中的一个类,是一个引用类型,用于表示字符串.它是不可变的(immutable),即一旦创建,其值就不能被修改.任何对String对象的修改操作都会创建一个新 ...





