【Wolfram语言】46 音频与视频

音频与视频

词汇表

函数 说明
AudioCapture[] 从计算机麦克风捕获音频
AudioPlot[audio] 绘制音频强度
Spectrogram[audio] 从音频生成声谱图
AudioPitchShift[audio, r] 将音频移调
SpeechRecognize[audio] 识别音频中的单词
Speak["字符串"] 让计算机朗读字符串
SpeechSynthesize["字符串"] 合成语音音频
AudioIdentify[audio] 识别音频内容
VideoCapture[] 从摄像头捕获视频
VideoFrameList[video, n] 从视频生成帧列表
VideoMapTimeSeries[f, video] 将函数应用于视频的每一帧
AnimationVideo[expr, {t, min, max}] 通过动画生成视频

音频

12节 中我们看到 Wolfram 语言如何处理由音符组成的声音。

实际上它可以处理任何类型的音频,例如人声。

捕获音频

AudioCapture 可以从计算机的麦克风捕获音频。

捕获我说"不合逻辑的"短语 a cat, a dog, a squid

wl 复制代码
In[]:=AudioCapture[]


盒子表示你捕获的音频。

可以通过按播放按钮来播放。

还有许多对音频进行操作的函数。

波形图

例如,可以使用 AudioPlot 绘制音频强度。

将音频强度随时间绘制为图:

在此图中,大致可以区分出不同的单词。

频谱图

更详细的可视化方式是使用声谱图。

为音频生成声谱图:

声谱图有点像广义的乐谱,其中在某一音高处强度越高显示越暗。

语音识别

不同的语音或音素在声谱图中表现为不同的结构。
SpeechRecognize 试图分析整个声谱图以识别单词。

对于较长的音频,需要大量计算,因此可能需要一些时间。

识别音频中所说的内容:

wl 复制代码
Out[]=a cat, a dog, a squid

变调

将音高按 2 倍(即一倍八度)移位,会使我的声音变高、滑稽。

其声谱图会被拉伸。

为移调后的音频生成声谱图:

SpeechRecognize 无法正确识别所说内容:

wl 复制代码
Out[]=I can't. I don't. I Scream.

语音合成

Wolfram 语音不仅能识别语音,也能生成语音。
Speak 让计算机发声,SpeechSynthesize 给出明确的音频。

从文本合成语音并生成其声谱图:

复制代码
In[]:=Spectrogram[SpeechSynthesize["a cat, a dog, a squid"]]

计算机合成语音的声谱图与我的声音声谱图在某种程度上相似。

大多数计算机上,SpeechSynthesize 可以访问多种具有不同口音的声音,通常以名字描述。

使用不同口音的声音:

复制代码
In[]:=Spectrogram[SpeechSynthesize["a cat, a dog, a squid", #]] & /@ {"Tessa", "Juan",  "Luca", "Lekha"}

桌面版和网页版的可用声音样式不一样,可通过$VoiceStyles查询。

声音和音符

也可以从我们在第 12 节讨论的 Sound 对象生成音频。

在合成钢琴上按顺序演奏若干、跨八度的音符:

复制代码
In[]:=Sound[Table[SoundNote[12 n, 1, "Piano"], {n, 4}]]
Out[]=

对应的音频图,较高音调的音符衰减更快:

复制代码
In[]:=AudioPlot[Sound[Table[SoundNote[12 n, 1, "Piano"], {n, 4}]]]

以及其声谱图:

复制代码
In[]:=Spectrogram[Sound[Table[SoundNote[12 n, 1, "Piano"], {n, 4}]]]

合成小提琴的相应声谱图:

复制代码
In[]:=Spectrogram[Sound[Table[SoundNote[12 n, 1, "Violin"], {n, 4}]]]

类似ImageIdentify 函数,用于音频的是 AudioIdentify

AudioIdentify 将音频识别为小提琴:

复制代码
In[]:=AudioIdentify[Sound[Table[SoundNote[12 n, 1, "Violin"], {n, 4}]]]

视频

Wolfram 语音不仅处理音频,也处理视频。VideoCapture 可以从计算机摄像头捕获视频。

视频捕获

摄像头捕获视频:

复制代码
In[]:=video=VideoCapture[]

视频帧列表

从视频中获取帧列表作为图像:

wl 复制代码
In[]:=VideoFrameList[video, 6] // ImageCollage

提取音频

从视频中提取音轨并识别我说的话:

wl 复制代码
In[]:=SpeechRecognize[Audio[video]]
Out=Hello there, let me introduce you to my spiky friend.

视频映射时间序列

计算视频过程中红、绿、蓝的平均值:

wl 复制代码
In[]:=ListLinePlot[VideoMapTimeSeries[Mean[#Image] &, video], PlotStyle -> {Red, Green, Blue}]

动画视频

除了直接捕获视频外,还可以从文件获取或从服务器流式传输。

也可以使用程序创建视频。

AnimationVideo 类似于 Manipulate,但会自动动画化并生成视频。

视频通常包含大量数据,可能需要较长时间生成。

生成一个黑盘在黄色盘内"生长"的视频:

wl 复制代码
In[]:=AnimationVideo[
 Graphics[{Style[Disk[{0, 0}, 1], Yellow], 
   Style[Disk[{0, 0}, a], Black]}, ImageSize -> 100], {a, 0, 1}]

将视频保存为 .mp4 文件:

wl 复制代码
In[]:=Export["blob.mp4",%]

Manipulate 一样,可以在 AnimationVideo 中指定步长。

生成一个有 110 个扇区的饼图视频:

wl 复制代码
In[]:=AnimationVideo[PieChart[Table[1, n], ImageSize -> 100], {n, 1, 10, 1}]

下一步

写好代码

相关推荐
virus59452 小时前
悟空CRM mybatis-3.5.3-mapper.dtd错误解决方案
java·开发语言·mybatis
初次见面我叫泰隆3 小时前
Qt——3、常用控件
开发语言·qt·客户端
无小道4 小时前
Qt——QWidget
开发语言·qt
时艰.4 小时前
Java 并发编程之 CAS 与 Atomic 原子操作类
java·开发语言
梵刹古音4 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
梵刹古音4 小时前
【C语言】 结构化编程与选择结构
c语言·开发语言·嵌入式
Yvonne爱编码4 小时前
JAVA数据结构 DAY3-List接口
java·开发语言·windows·python
一方_self4 小时前
了解和使用python的click命令行cli工具
开发语言·python
南宫码农5 小时前
我的电视 - Android原生电视直播软件 完整使用教程
android·开发语言·windows·电视盒子
CoderCodingNo5 小时前
【GESP】C++四级/五级练习题 luogu-P1223 排队接水
开发语言·c++·算法