主要内容

生成多通道音频

这个例子展示了如何使用多个音频通道设置连续音频生成。这个信号是韩德尔的“哈利路亚副歌”的一个样本,它被分成连续的片段,并分成两部分回放。这个例子的第一部分在单个扬声器和低音炮上播放每个片段。第二部分用不同的扬声器(声音唱诗班)播放每个片段。

加载音频数据

负载韩德尔的“哈利路亚”。

加载变量:

  • y代表哈利路亚波形

  • Fs代表采样频率

负载汉德尔

创建数据采集

使用DirectSound.作为供应商ID。

dq = daq(“声音处理软件”

增加通道并调整生成扫描速率以匹配音频采样频率

增加6个音频输出通道,将生成扫描速率设置为音频采样速率。

addoutput(dq,“Audio7”1:6,“声音的”);dq.rate = fs;

绘制音频数据

目视识别与合唱中的每个“Hallelujah”对应的音频段,并选择这些段开始和停止的示例号。曲线中的每种颜色对应于合唱的不同段。

确定每个段的结束

在视觉上识别分段边界并标记它们。

细分= [20000,36000,45000,55000,长度(y)];

扬声器参数定义

在命名的单元格数组中设置扬声器的选择speakerselection在六个不同的扬声器中发挥“Hallelujah”的五个部分。

nspeakers = 6;nspeakergroups = 5;nspeakerselection = cell(1, nspeakergroups);

将发言者分配到组

每个扬声器选择指定5.1声道扬声器系统中的哪个扬声器播放每个音频片段(这些分配可能因您的扬声器系统而异)。对于示例的第一部分,使用单个扬声器与低音炮(4)配对。

  • 演讲者1:左前

  • 发言人2:右前

  • 发言人3:中心

  • 扬声器4:次低音扬声器

  • 扬声器5:左后方

  • 扬声器6:右后方

扬声器{1} = [4,6];%段1;演讲者4和6扬声器{2} = [4,5];% 2段;发言人4和5扬声器{3} = [1,4];% 3段;扬声器1和4Speakerselection {4} = [2,4];% 4段;演讲者2和4Speakerselection {5} = [3,4];% 5段;演讲者3和4[singlechanneloutpuls] =...surroundSoundVoices(y, segmentEnd, nspeakers, nspeakergroups, speakerselection);

写入单通道输出

写一系列单通道输出然后暂停在继续下一节之前。

写(dq,singlechanneloutpuls);暂停(3);

将发言者分配到组

每个扬声器选择指定5.1声道扬声器系统中的哪个扬声器播放每个音频片段(这些分配可能因您的扬声器系统而异)。在例子的第二部分,使用几组说话者。请注意,低音炮(4)包含在所有扬声器选择中

  • 演讲者1:左前

  • 发言人2:右前

  • 发言人3:中心

  • 扬声器4:次低音扬声器

  • 扬声器5:左后方

  • 扬声器6:右后方

Speakerselection {1} = [4,5,6];%段1;扬声器4,5,6Speakerselection {2} = [1,2,4];% 2段;扬声器1,2,4Speakerselection {3} = [3,4];% 3段;演讲者3、4Speakerselection {4} = [1,2,3,4];% 4段;1 2 3 4号喇叭扬声器{5} = [1,2,3,4,5,6];% 5段;所有的演讲者[multiChannelOutput] =...surroundSoundVoices(y, segmentEnd, nspeakers, nspeakergroups, speakerselection);

写多路输出

写(dq multiChannelOutput);
功能[multiChannelOutput] = surroundSoundVoices(audioOut, segmentEnds, numSpeakers, numSpeakerGroups, speakerGroups)%将输出波形的连续段分发给多个组一对一关系中的扬声器%。输入波形被打破%变成连续段。每个段由一个且唯一的段输出每组议员组,每组都被访问。%将输入波形分解为各种组播放的段%的扬声器。在这个演示中,我们要慢慢添加“声音”%通过增加更多的扬声器产生输出波形。特别地,我们将把输出波形看作是一个连续的%段的序列(每组扬声器的一个段)。例如,如果%我们有3组发言者,我们可以想到分手输出%波形到3个段:输出= [S1 S2 S3]%扬声器组1输出:S1 0 0%扬声器组2输出:0 s2 0% Speaker group 3输出:0 0 s3multiChannelOutput = repmat(0.01, length(audioOut), numSpeakers);startOfSegment = [1 (segmentEnds(1:end-1)+1)];i = 1:numSpeakerGroups speakergroup = speakerGroups{i};n =元素个数(speakergroup);j = 1:n range = startOfSegment(i):segmentEnds(i);multiChannelOutput(range, speakergroup(j)) = audioOut(range);结束结束结束