李 伟,李子晋,高永伟
(1.复旦大学 计算机科学技术学院,上海 201203; 2.复旦大学 上海市智能信息处理重点实验室,上海 200433;3.中国音乐学院 音乐科技系,北京 100101)
音乐与科技的融合具有悠久的历史.早在20世纪50年代,一些不同国家的作曲家、工程师和科学家已经开始探索利用新的数字技术来处理音乐,并逐渐形成了音乐科技/计算机音乐(Music Technology/Computer Music)这一交叉学科.20世纪70年代之后,欧美各国相继建立了多个大型计算机音乐研究机构,如1975年建立的美国斯坦福大学CCRMA(Center for Computer Research in Music and Acoustics)、1977年建立的法国巴黎IRCAM(Institute for Research and Coordination Acoustic/Music)、1994年成立的西班牙巴塞罗那UPF(Universitat Pompeu Fabra)的MTG(Music Technology Group)以及2001年成立的英国伦敦女王大学C4DM(Center for Digital Music)等.在欧美之后,音乐科技在世界各地都逐渐发展起来,欧洲由于其浓厚的人文和艺术气息成为该领域的世界中心.该学科在中国大陆发展较晚,大约20世纪90年代中期开始有零散的研究,由于各方面的限制,至今仍处于起步阶段[1].
音乐科技分为两个子领域: 一是基于科技的音乐创作;二是数字音频与音乐技术的科学技术研究.本文内容限于后一领域.音乐科技具有众多应用,例如数字乐器、音乐制作与编辑、音乐信息检索、数字音乐图书馆、交互式多媒体、音频接口、辅助医学治疗等.这些应用背后的科学研究通常称为声音与音乐计算(Sound and Music Computing, SMC),在20世纪90年代中期被定义为国际计算机学会(Association for Computing Machinery, ACM)的标准术语[2].SMC是一个多学科交叉的研究领域.在科技方面涉及到声学(Acoustics)、音频信号处理(Audio Signal Processing)、机器学习(Machine Learning)、人机交互(Human-Machine Interaction)等学科;在音乐方面涉及作曲(Composition)、音乐制作(Music Creation)、声音设计(Sound Design)等学科.国际上已有多个侧重点不同的国际会议和期刊,如1972年创刊的JNMR(Journal of New Music Research)、1974年建立的ICMC(International Conference on Computer Music)、1977年创刊的CMJ(Computer Music Journal)、2000年建立的ISMIR(International Society for Music Information Retrieval Conference)等.
SMC是一个庞大的研究领域,可细化为以下4个学科分支.(1) 声音与音乐信号处理: 用于声音和音乐的信号分析、变换及合成,例如频谱分析(Spectral Analysis)、调幅(Magnitude Modulation)、调频(Frequency Modulation)、低通/高通/带通/带阻滤波(Low-pass/High-pass/Band-pass/Band-stop Filtering)、转码(Transcoding)、无损/有损压缩(Lossless/Lossy Compression)、重采样(Resampling)、回声(Echo)、混音(Remixing)、去噪(Denoising)、变调PS(Pitch Shifting)、保持音高不变的时间伸缩(Time-Scale Modification/Time Stretching, TSM)、线性时间缩放(Time Scaling)等.该分支相对比较成熟,已有多款商业软件如Gold Wave、Adobe Audition/Cool Edit、Cubase、Sonar/Cakewalk、EarMaster等.(2) 声音与音乐的理解分析: 使用计算方法对数字化声音与音乐的内容进行理解和分析,例如音乐识谱、旋律提取、节奏分析、和弦识别、音频检索、流派分类、情感分析、歌手识别、歌唱评价、歌声分离等.该分支在20世纪90年代末随着互联网上数字音频和音乐的急剧增加而发展起来,研究难度大,多项研究内容至今仍在持续进行中.与计算机视觉(Computer Vision, CV)对应,该分支也可称为计算机听觉(Computer Audition, CA)或机器听觉(Machine Listening, ML)[3].注意计算机听觉是用来理解分析而不是处理音频和音乐[4],且不包括语音.语音信息处理的历史要更早数十年,发展相对成熟,已独立成为一门学科,包含语音识别、说话人识别、语种识别、语音分离、计算语言学等多个研究领域.CA若剔除一般声音而局限于音乐,则可称为音乐信息检索(Music Information Retrieval, MIR),这也是本文主要的介绍内容.(3) 音乐与计算机的接口设计: 包括音响及多声道声音系统的开发与设计、声音装置等.该分支偏向音频工程应用.(4) 计算机辅助音乐创作: 包括算法作曲、计算机音乐制作、音效及声音设计等.该分支偏向艺术创作.
与音乐有关但是与SMC不同的另一个历史更悠久的学科是音乐声学(Music Acoustics).音乐声学是研究在音乐这种声音振动中存在的物理问题的科学,是音乐学与物理学的交叉学科.音乐声学主要研究乐音与噪声的区别、音高音强和音色的物理本质、基于电磁振荡的电声学、听觉器官的声波感受机制、乐器声学、人类发声机制、音律学、与音乐有关的室内声学等.从学科的角度看,一部分音乐声学知识也是SMC的基础,但SMC研究更依赖于音频信号处理和机器学习这两门学科.同时,研究内容面向音频与音乐的信号处理、内容分析和理解,与更偏重于解决振动相关物理问题的音乐声学也有较大区别.为更清楚地理解各学科之间的区别与联系,我们将音乐科技及听觉研究各领域关系分别示于图1和图2.
图1 音乐科技各领域关系图Fig.1 A relation graph of different music technology fields
图2 听觉研究各领域关系图Fig.2 A relation graph of different auditory research fields
从20世纪90年代中期开始,互联网在世界范围内迅速普及.同时,以MP3(MPEG-1 Layer 3)为代表的音频压缩技术开始大规模应用.此外,半导体技术和工艺的迅猛发展使得硬盘等存储设备的容量越来越大.这几大因素使得传统的黑胶唱片、磁带、CD光盘等音乐介质几乎消失,取而代之的是在电脑硬盘上存储,在互联网上传输、下载和聆听的数字音乐.海量的数字音乐直接促使了音乐信息检索(MIR)技术的产生,其内涵早已从最初的狭义音乐检索扩展到使用计算手段对数字音乐进行内容分析理解的大型科研领域,包含数十项研究课题.2000年国际音乐信息检索学术会议(ISMIR)的建立可以视为这一领域的正式创建.
基于内容的音乐信息检索(及相关音乐科技)有很多应用.在娱乐相关领域,典型应用包括听歌识曲、哼唱/歌唱检索、翻唱检索、曲风分类、音乐情感计算、音乐推荐、彩铃制作、卡拉OK应用、伴奏生成、自动配乐、音乐内容标注、歌手识别、模仿秀评价、歌唱评价、歌声合成及转换、智能作曲、数字乐器、音频/音乐编辑制作等.在音乐教育及科研领域,典型应用包括计算音乐学、视唱练耳及乐理辅助教学、声乐及各种乐器辅助教学、数字音频/音乐图书馆等.在日常生活、心理及医疗、知识产权等其他领域,还包括乐器音质评价及辅助购买、音乐理疗及辅助医疗、音乐版权保护及盗版追踪等应用.此外,在电影及很多视频中,音频及音乐都可以用来辅助视觉内容进行分析.以上应用均可以在电脑、智能手机、音乐机器人等各种平台上进行实现.
早期的MIR技术以符号音乐(Symbolic Music)如MIDI(Musical Instrument Digital Interface)为研究对象.由于其具有准确的音高、时间等信息,很快就发展得比较成熟.后续研究很快转为以音频信号为研究对象,研究难度急剧上升.随着该领域研究的不断深入,如今MIR技术已经不仅仅指早期狭义的音乐搜索,而从更广泛的角度上包含了音乐信息处理的所有子领域.我们根据自己的理解,将MIR领域的几十个研究课题归纳为核心层和应用层共9个部分(图3).核心层包含与各大音乐要素(如音高与旋律、音乐节奏、音乐和声等)及歌声信息处理相关的子领域,应用层则包含在核心层基础上更偏向应用的子领域(如音乐搜索、音乐情感计算、音乐推荐等).下面依次对其概念、原理、基本技术框架以及典型算法进行介绍.
图3 音乐信息检索(MIR)的研究领域Fig.3 Illustration of MIR research topics
MIR研究领域的科研涉及一些基本的乐理知识,在图4中汇总显示,在下述文字中可参照理解.
图4 MIR的研究领域常用的基本乐理常识Fig.4 Musical knowledge commonly used in MIR
音乐中每个音符都具有一定的音高属性.若干个音符经过艺术构思按照节奏及和声结构(Harmonic Structure)形成多个序列,其中反映音乐主旨的序列称为主旋律,是最重要的音乐要素,其余序列分别为位于高、中、低音声部的伴奏.该子领域主要包括音高检测、旋律提取和音乐识谱等任务.
2.1.1 音高检测
音高(Pitch)由周期性声音波形的最低频率即基频决定,是声音的重要特性.音高检测(Pitch Detection)也称为基频估计(Fundamental Frequency/f0Estimation),是语音及音频、音乐信息处理中的关键技术之一.音高检测技术最早面向语音信号,在时域包括经典的自相关算法[5]、YIN算法[6]、最大似然算法[7]、SIFT(Simplified Inverse Filter Tracking)滤波器算法[8]以及超分辨率算法[9]等;在频域包括基于正弦波模型[10]、倒谱变换[11]、小波变换[12]等的各种方法.一个好的算法应该对声音偏低偏高者都适用,而且对噪音鲁棒.
在MIR技术中,音高检测被扩展到多声部/多音音乐(Polyphonic Music)中的歌声信号.由于各种乐器伴奏的存在,检测歌声的音高更加具有挑战性.直观上首先进行歌声与伴奏分离有助于更准确的检测歌声音高[13],估计每个音频帧(Frame)上的歌声音高范围也可以减少乐器或歌声泛音(Partial)引起的错误尤其是八度错误(Octave Errors)[14-15],融合几个音高跟踪器的结果也有希望得到更高的准确率[16].此外,相邻音符并非孤立存在,而是按照旋律与和声有机地连接,可用隐马尔科夫模型(Hidden Markov Model, HMM)等时序建模工具进行纠错[17].除了歌声,Goto等使用期望最大化(Expectation Maximization, EM)方法并结合时域连续性来估计旋律和低音线的基频[18].
2.1.2 旋律提取
旋律提取(Melody Extraction)从多声部/多音音乐信号中提取单声部/单音(Monophonic)主旋律,是MIR领域的核心问题之一.在音乐检索、抄袭检测、歌唱评价、作曲家风格分析等多个子领域中具有重要应用.从音乐信号中提取主旋律的方法主要分为3类: 即音高重要性法(Pitch-salience based Melody Extraction)[19-20]、歌声分离法(Singing Separation based Melody Extraction)[21-22]及数据驱动的音符分类法(Data-driven Note Classification)[23].第一类方法依赖于每个音频帧上的旋律音高提取,这本身就是一个极困难的问题.此外还涉及旋律包络线的选择和聚集等后处理问题.第三类方法单纯依赖于统计分类器,难以处理各种各样的复杂多声部/多音音乐信号.相比之下,我们认为第二类方法具有更好的前景.这里并不需要完全彻底的音源分离,而只需要像文献[21]那样根据波动性和短时性特点进行旋律成分增强或像文献[22]那样通过概率隐藏成分分析(Probabilistic Latent Component Analysis, PLCA)学习非歌声部分的统计模型进行伴奏成分消减,之后即可采用自相关等音高检测方法提取主旋律线(Predominant Melody Lines).以上各种方法还面临一些共同的困难,如八度错误,如何提取纯器乐的主旋律等[24].
2.1.3 音乐识谱
音乐可分为单声部/单音和多声部/多音.单声部/单音音乐在某一时刻只有一个乐器或歌唱的声音,使用2.1.1节中的音高检测技术即可进行比较准确的单声部/单音音乐识谱(Monophonic Music Transcription).目前急需解决的是多声部/多音音乐识谱(Polyphonic Music Transcription),即从一段音乐信号中识别每个时刻同时发声的各个音符,形成乐谱并记录下来,俗称扒带子.由于音乐信号包含多种按和声结构存在的乐器和歌声,频谱重叠现象普遍,音乐识谱(Music Transcription)极具挑战性,是MIR领域的核心问题之一.同时,音乐识谱具有很多应用,如音乐信息检索、音乐教育、乐器及多说话人音源分离[25]、颤音和滑音(Glissando)标注等[26].
多声部/多音音乐识谱系统首先将音乐信号分割为时间单元序列,然后对每个时间单元进行多音高/多基频估计(Multiple Pitch/Fundamental Frequency Estimation).再根据MIDI音符表将各基频转换为对应音符的音名,最后利用音乐领域知识或规则对音符、时值等结果进行后处理校正,结合速度和调高估计输出正确的乐谱.
多音高/多基频估计是进行音乐识谱的核心功能,经常使用对音乐信号的短时幅度谱[27]或常数Q变换(Constant-Q Transform)[28]进行矩阵分解的方法,如独立成分分析(Independent Component Analysis, ICA)[29]、非负矩阵分解(Non-negative Matrix Factorization, NMF)[30]、概率隐藏成分分析(PLCA)[31]等.与此思路不同,文献[32]基于迭代方法,首先估计最重要音源的基频,从混合物中将其减去,然后再重复处理残余信号.文献[33]使用重要性函数(Salience Function)来选择音高候选者,并使用一个结合候选音高的频谱和时间特性的打分函数来选择每个时间帧的最佳音高组合.由于多声部/多音音乐信号中当前音频帧的谱内容在很大程度上依赖于以前的帧,最后还需使用谱平滑性(Spectral Smoothness)[34]、HMM、条件随机场(Conditional Random Fields, CRFs)等进行纠错.
音乐识谱的研究虽然早在30年前就已开始[35],但目前仍是MIR的研究领域中一个难以解决的问题,只能在简单情况下获得一定的结果.随着并发音符数量的增加,检测难度急剧上升,而且性能严重低于人类专家.主要原因在于当前识谱方法使用通用的模型,无法适应各个场景下的复杂音乐信号.一个可能的改进方法是使用乐谱、乐器类型等辅助信息进行半自动识谱[36],或者进行多个算法的决策融合[37].
音乐节奏是一个广义词,包含与时间有关的所有因素.把音符有规律地组织到一起,按照一定的长短和强弱有序进行,从而产生律动的感觉.MIR领域与节奏相关的子领域包括: 音符起始点检测、速度检测、节拍跟踪、拍子/小节线检测及强拍估计、节奏型检测.由于与英文对应的中文翻译混乱,本文采用文献[38]中的术语.
2.2.1 音符起始点检测
图5 理想情况下一个音符的时间域信息描述: 起始点(Onset)、上升(Attack)、过渡(Transient)和下降(Decay)Fig.5 The description of Onset, Attack, Transient and Decay in an ideal note
音符起始点(Note Onset)是音乐中某一音符开始的时间[39],如图5所示.对于钢琴、吉他、贝斯等具有脉冲信号特征的乐器的音符,其起始(Attack)阶段能量突然上升,称为硬音符起始点(Hard Note Onset).而对于小提琴、大提琴、萨克斯、小号等弦乐或吹奏类乐器演奏的音符,则通常没有明显的能量上升,称为软音符起始点(Soft Note Onset).音符起始点检测(Note Onset Detection)通常是进行各种音乐节奏分析的预处理步骤[40],在音乐混音(Music Remixing)、音频修复(Audio Restoration)、歌词识别、TSM、音频编码及合成(Audio Coding and Synthesis)中也都有应用.
在单声部/单音音乐信号中检测音符起始点并不难,尤其是对弹拨或击奏类乐器,简单地定位信号幅度包络线的峰值即可得到很高的准确率.但是在多声部/多音音乐信号中,检测整体信号失去效果,通常需要进行基于短时傅里叶变换(Short-time Fourier Transform, STFT)、小波变换(Wavelet Transform, WT)、听觉滤波器组的子带(Subband)分解.如文献[41]在高频子带基于能量的峰值挑选(Peak-picking)来检测强的瞬态事件,在低频子带使用一个基于频率的距离度量来提高软音符起始点的检测准确性.文献[42]没有检测能量峰值,而是通过观察相位在各个音频帧的分布也可以进行准确检测.除了常规子带分解,还有其他的分解形式.如文献[43]对音乐信号的频谱进行NMF分解,在得到的线性时域基(Linear Temporal Bases)上构造音符起始点检测函数.文献[44]将音乐信号基于MT(Matching Pursuit)方法进行稀疏分解(Sparse Decomposition),通过稀疏系数的模式判断信号是稳定还是非稳定,之后自适应地通过峰值挑选得到Onset矢量.
除了基于信号处理的方法,后来又发展了多种基于机器学习的检测方法.机器学习主要用于分类,但具体应用方式并不相同.例如,文献[45]使用人工神经网络(Artificial Neural Network, ANN)对候选峰值进行分类,确定哪些峰值对应于音符起始点,哪些由噪声或打击乐器引起.希望避免峰值挑选方法中的门限问题.文献[46]则使用神经网络将信号每帧的频谱图(Spectrogram)分类为Onsets和Non-onsets,对前者使用简单的峰值挑选算法.
2.2.2 速度检测
速度检测/感应(Tempo Detection/Induction)获取音乐进行的快慢信息,是MIR节奏类的基本任务之一.通常用每分钟多少拍(Beats Per Minute, bpm)来表示.速度检测是音乐情感分析(如欢快、悲伤等)中的一个重要因素.另一个有趣的应用是给帕金森病人播放与其走路速度一致的音乐,从而辅助其恢复行动机能[47].
进行音乐速度检测通常首先进行信号分解.核心思想是在节奏复杂的音乐中,某些成分会比整体混合物具有更规律的节奏,从而使速度检测更容易.如文献[48]将混合信号分解为和声部分和噪声部分两个子空间(Subspace),文献[49]将混合信号分解到多个子带.打击乐器控制速度进行,文献[50]使用非负矩阵分解(NMF)将混合信号分解为不同成分(Component),希望把不同的鼓声甚至频谱可能重叠的底鼓和贝斯声分解到不同的成分.与此思想类似,文献[51]使用概率隐藏成分分析(PLCA)将混合音乐信号分解到不同的成分.
针对各个子空间或子带的不同信号特性,采用不同的软、硬音符起始点函数,使用自相关、动态规划等方法分别计算周期性,再对候选速度值进行选择[52].速度检测方法基本上都基于音频信号处理方法,文献[53]提出了一种基于机器学习的方法,该方法使用听觉谱特征和谱距离,在一个已训练好的双向长短时记忆单元-递归神经网络(Bidirectional Long Short Term Memory-Recurrent Neural Network, BLSTM-RNN)上预测节拍,通过自相关进行速度计算,训练集包含不同音乐流派而且足够大.以上方法对于节奏稳定、打击乐或弹拨击奏类乐器较强的西方音乐,速度检测准确性已经很高,而对于打击乐器不存在或偏弱的音乐准确性则较差.
在处理弦乐等抒情音乐(Expressive Music),或速度发生渐快(Accelerando)、渐慢(Rallentando)时,速度检测仍然具有很大的研究难度,需为每个短时窗口估计主局部周期(Predominant Local Periodicity, PLP)进行局部化处理[54].文献[55]使用概率模型来处理抒情音乐中的时间偏差,用连续的隐藏变量对应于速度(Tempo),形式化为最大后验概率(Maximum A Posteriori, MAP)状态估计问题,用蒙特卡洛方法(Monte Carlo)求解.文献[56]基于谱能量通量(Spectral Energy Flux)建立一个Onset函数,采用自相关函数估计每个时间帧的主局部周期,然后使用维特比(Viterbi)算法来检测最可能的速度值序列.
以上方法都是分析原始格式音频,还有少量算法可以对AAC(Advanced Audio Coding)等压缩格式音乐在完全解压、半解压、完全压缩等不同条件下进行速度估计[57].无论原始域还是压缩域速度检测算法,目前对于抒情音乐、速度变化、非西方音乐、速度的八度错误(减半或加倍/Halve or Double)等问题仍然没有很好的解决办法.
2.2.3 节拍跟踪
节拍(Beat)是指某种具有固定时长(Duration)的音符,通常以四分音符或八分音符为一拍.节拍跟踪/感应(Beat Tracking/Induction)是计算机对人们在听音乐时会无意识地踮脚或拍手的现象的模拟,经常用于对音乐信号按节拍进行分割[58],是理解音乐节奏的基础和很多MIR应用及多媒体系统如视频编辑、音乐可视化、舞台灯光控制等的重要步骤.早期的算法只能处理MIDI形式的符号音乐或者少数几种乐器的声音信号,而且不能实时工作.20世纪90年代中期以后,开始出现能处理包含各种乐器和歌声的流行音乐声音信号的算法,基本思想是通过检测控制节奏的鼓声来进行节拍跟踪[59].节拍跟踪可在线或离线进行,前者只能使用过去的音频数据,后者则可以使用完整的音频,难度有所降低[60].
节拍跟踪通常与速度检测同时进行[61-63],首先在速度图(Tempogram)中挑选稳定的局部区域[59].下一步就是检测候选的节拍点,方法各不相同.文献[61]将节拍经过带通滤波等预处理后,对每个子带计算其幅度包络线和导数,与一组事先定义好的梳状滤波器(Comb Filter)进行卷积,对所有子带上的能量求和后得到一系列峰值.更多的方法依赖于音符起始点、打击乐器及其他时间域局域化事件的检测[62].如果音乐偏重抒情,没有打击乐器或不明显,可采用和弦改变点(无需识别和弦名字)作为候选点[63-64].
以候选节拍点为基础,即可进行节拍识别.文献[61]用最高的峰值对应于速度并进一步提取节拍.文献[65]基于感知设立门限并得到节拍输出.文献[66]使用简单有效的动态规划(Dynamic Programming, DP)方法来找到最好的节拍时间.文献[67]采用机器学习中的条件随机场(CRF)这种复杂的时域模型,将节拍位置估计模拟为时序标注问题.在一个短时窗口中通过CRF指定的候选者来捕捉局部速度变化并定位节拍.
对大多数流行音乐来讲,速度及节拍基本维持稳定,很多算法都可以得到不错的结果,但具体的定量性能比较依赖于具体评测方法的选择[68].对于少数复杂的流行音乐(如速度渐慢或渐快、每小节拍子发生变化等)和绝大多数古典音乐、交响乐、歌剧、东方民乐等,节拍跟踪仍然是一个研究难题.
2.2.4 拍子检测、小节线检测及强拍估计
音乐中有很多强弱不同的音符,在由小节线划分的相同时间间隔内,按照一定的次序重复出现,形成有规律的强弱变化即拍子(Meter/Time Signature).换句话说,拍子是音乐中表示固定单位时值和强弱规律的组织形式.在乐谱开头用节拍号(如4/4、3/4等)标记.拍子是组成小节(Bar/Measure)的基本单位,小节则是划分乐句、乐段、整首乐曲的基本单位.在乐谱中用小节线划分,小节内第一拍是强拍(Downbeat).拍子和小节提供了高层(High-level)的节奏信息,拍子检测/估计/推理(Meter Detection/Estimation/Inference)、小节线检测(Bar line/Measure Detection)及强拍检测/估计(Downbeat Detection/Estimation)在音乐识谱、和弦分析等很多MIR任务中都有重要应用.
一个典型的检测拍子的方法是首先计算节拍相似性矩阵(Beat Similarity Matrix),利用它来识别不同部分的重复相似节拍结构[69].利用类似的思路,即节拍相似性矩阵,可进行小节线检测.使用之前小节线的位置和估计的小节长度来预测下一个小节线的位置.该方法不依赖于打击乐器,而且可以在一定程度上容忍速度的变化[70].对于没有鼓声的音乐信号,通过检测和弦变化的时间位置,利用基于四分音符的启发式音乐知识进行小节线检测[64].音乐并不一定都是匀速进行,经常会出现渐快、渐慢等抒情表现形式,甚至出现4/4或3/4拍子穿插进行的复杂小节结构(如额尔古纳乐队演唱的莫尼山),这给小节推理(Meter Inference)算法带来巨大困难.文献[71]提出一个基于稀疏NMF(Sparse NMF)的非监督方法来检测小节结构的改变,并进行基于小节的分割.
强拍估计可以确定小节的起始位置,并通过周期性分析进一步获得小节内强拍和弱拍的位置,从而得到拍子结构[72].对拍子和小节线检测都非常有益.文献[73]将强拍检测和传统的节拍相似性矩阵结合,进行小节级别(Bar-level)的自动节奏分析.早期强拍序列预测方法采用Onset、Beat等经典节奏特征及回归模型[74],近年随着深度学习(Deep Learning)技术的成熟,出现了数个数据驱动的强拍检测算法.文献[75]使用深度神经网络(Deep Neural Networks, DNN)在音色、和声、节奏型等传统音乐特征上进行自动特征学习(Feature Learning),得到更能反映节奏本质的高层抽象表示,使用Viterbi算法进行时域解码后得到强拍序列.类似地,文献[76]从和声、节奏、主旋律(Main Melody)和贝斯(Bass)4个音乐特征出发进行表示高层语义的深度特征(Deep Feature)学习,使用条件随机场(CRF)模型进行时域解码得到强拍序列.文献[77]使用两个递归神经网络(Recurrent Neural Networks, RNN)作为前端,一个在各子带对节奏建模,一个对和声建模.输出被结合送进作为节奏语言模型(Rhythmical Language Model)的动态贝叶斯网络(Dynamic Bayesian Network, DBN),从节拍对齐的音频特征流中提取强拍序列.
2.2.5 节奏型检测
音乐节奏的主体由经常反复出现的具有一定特征的节奏型(Rhythmic Pattern)组成.节奏型也可以叫做节拍直方图(Beat Histogram),在音乐表现中具有重要意义,使人易于感受便于记忆,有助于音乐结构的统一和音乐形象的确立.节奏型经常可以清楚地表明音乐的流派类型,如布鲁斯、华尔兹等.
该子领域的研究不多,但早在1990年就提出了经典的基于模板匹配的节奏型检测方法[78].另一项工作也使用基于模板匹配的思路,对现场音乐信号进行节奏型的实时检测,注意检测时需要比节奏型更长的音频流.该系统能区分某个节奏型的准确和不准确的演奏,能区分以不同乐器演奏的同样的节奏型,以及以不同速度演奏的节奏型[79].鼓是控制音乐节奏的重要乐器,文献[80]通过分析音频信号中鼓声的节奏信息进行节奏型检测.打击乐器的节奏信息通常可由音乐信号不同子带的时域包络线进行自相关来获得,具有速度依赖性.文献[81]对自相关包络线的时间延迟(Time-lag)轴取对数,抛弃速度相关的部分,得到速度不变的节奏特征.除了以上信号处理类的方法,基于机器学习的方法也被应用于节奏型检测.文献[82]使用神经网络模型自动提取单声部/单音或多声部/多音符号音乐的节奏型.文献[83]基于隐马尔科夫模型从一个大的标注节拍和小节信息的舞曲数据集中直接学习节奏型,并同时提取节拍、速度、强拍、节奏型、小节线.
音乐通常是多声部/多音,包括复调音乐(Polyphony)和主调音乐(Homophony)两种主要形式.复调音乐拥有漫长的历史,从公元9世纪到18世纪前半叶流行于欧洲.18世纪后半叶开始到现在,主调音乐逐渐取代了复调音乐的主要地位,成为最主要的音乐思维形式.复调音乐含有两条或以上的独立旋律,通过技术处理和谐地结合在一起.主调音乐以某一个声部作为主旋律,其他声部以和声或节奏等手法进行陪衬和伴奏.特点是音乐形象明显,感情表达明确,欣赏者比较容易融入.其中,和声(Harmony)是主调音乐最重要的要素之一.和声是指两个或两个以上不同的音符按照一定的规则同时发声而构成的声音组合[84].与和声相关的MIR子领域有和弦识别及调高检测.
2.3.1 和弦识别
和弦(Chord)是音乐和声的基本素材,由3个或以上不同的音按照三度重叠或其他音程(Pitch Interval)结合构成,这是和声的纵向结构.在流行音乐和爵士乐中,一串和弦标签经常是歌曲的唯一标记,称为所谓的主旋律谱(Lead Sheets).此外,和弦的连接(Chord Progressions)表示和声的横向运动.和声具有明显的浓、淡、厚、薄的色彩作用,还能构成乐句、乐段,包含了大量的音乐属性信息.和弦识别在音乐版本识别、音乐结构分析等多个领域具有重要作用,它另一个有趣的应用是为用户的哼唱旋律自动配置和弦伴奏[85].
典型的和弦识别(Chord Detection)算法包括音频特征提取和识别模型两部分.音高类轮廓(Pitch Class Profile, PCP)是描述音乐色彩的半音类(Chroma)特征的一个经典实现,是一个12维的矢量.由于其在12个半音类(C、#C/bD、D、#D/bE、E、F、#F/bG、G、#G/bA、A、#A/bB、B)上与八度无关的谱能量聚集特性,成为描述和弦及和弦进行的首要特征(如图6所示,所有灰色的音符C或c,不管其在哪个组或八度,其频谱能量均相加得到C半音类的Chroma值.其余依此类推).对传统PCP特征进行各种改进后,又提出HPCP(Harmonic PCP)、EPCP(Enhanced PCP)、MPCP(Mel PCP)等增强型特征.这些特征在一定程度上克服了传统PCP特征在低频段由于各半音频率相距太近而引起的特征混肴的缺陷,而且增强了抗噪能力[86].文献[87]没有使用所有的频率来计算Chroma,它首先检测重要频率(Salient Frequencies),转换为音符后按照心理物理学(Psychophysics)规则为泛音加权.近年来,随着深度学习的流行,文献[88]采用其特征学习能力自动获取更抽象的高层和声特征.
常规的和弦检测算法以固定长度的Frame进行音频特征计算,不符合音乐常识.更多的算法基于Beat级别的分割进行和弦检测[89].这符合和弦基本都是在小节开始或各个节拍处发生改变的音乐常识,也通常具有更好的实验结果[90].例如,文献[91]使用一个和声改变检测函数在各Beat位置分割时间轴,对每个片段的平均Chroma再进行和弦识别.流行音乐包含鼓、钹等各种打击乐器,对只依赖于和声成分的和弦检测带来干扰.文献[92]使用HPSS(Harmonic/Percussive Sound Separation)技术进行预处理,压制鼓声,强调基于和声成分的Chroma特征和Delta-Chroma特征.
图6 PCP(Chroma)特征计算原理图Fig.6 Principle of PCP(Chroma) feature calculation
在识别阶段,早期的方法采用基于余弦距离等的模式匹配(Pattern Matching)[89,93].随着研究的深入,隐马尔科夫模型(HMM)、条件随机场(CRF)、支持向量机(Support Vector Machine, SVM)、递归神经网络(RNN)等机器学习分类方法陆续被引入来建立和弦识别模型[94].和弦序列与根音(Bass Notes)、小节线位置(Measure Positions)及调高(Key)等音乐要素互相关联,文献[95]使用一个6层的动态贝叶斯网络(DBN)从音频波形中对它们同时估计,其中4个隐藏层联合模拟和弦、调高、根音、小节线位置,两个观察层模拟对应于低音(Bass)和高音(Treble)音色内容的低层(Low-level)特征.
音乐和弦并非独立存在,而是按照特定的音乐规则在时间轴上连接和行进[96].使用音乐上下文(Context)信息进行时间序列后处理通常可以提高性能.常用的方法有考虑和弦相对稳定性的平滑算法[89]、时间序列解码Viterbi算法[97]、递归神经网络[94]等.目前的和弦检测算法通常只能识别12个大小调的24个常用三和弦,对于更复杂的和弦如七和弦只有少数算法[98-101]才能实现,而且随着分类数量的增加,性能有所下降.
2.3.2 调高检测
调性(Tonality)是西方音乐的一个重要方面.调性包括调高(Key)和大小调(Major/Minor),是调性分析(Tonality Analysis)的一个重要任务.在乐理知识中,如图7所示,C、D、E、F、G、A、B是音名(Pitch Names),对应于钢琴上真实的键.Do、Re、Mi、Fa、So La、Si是唱名(Syllable Names),随着音乐的调高而变化.例如C大调中的Do就是C,对应的音阶(Scale)是C、D、E、F、G、A、B;D大调的Do就是D,对应的音阶是D、E、#F、G、A、B、#C.检测一首曲子的调高及调高的变化对于音乐识谱、和弦检测、音乐情感计算、自动伴奏、音乐结构分析、音乐检索等领域都有重要作用[102-105].
图7 音名、唱名对照图Fig.7 The correspondence plot of pitch names and syllable names
一个典型的调高检测(Key Detection)模型由两部分组成,即特征提取与调高分类(Classification)[106]或聚类(Clustering)[107].目前用来描述对调高感知的音频特征基本都是PCP(Chroma),还有基于音乐理论和感知设计的特征[108].尽管缺乏音乐理论支持,心理学实验表明这是一种有效的方法.比如著名的Krumhansl-Schmukler模型就是通过提取PCP(Chroma)特征来描述人们对调高的认知机制[109].调高检测通常使用的调高分类器包括人工神经网络(ANN)[110-111]、隐马尔科夫模型(HMM)[112]、支持向量机(SVM)[108]、集成学习(Ensemble Learning-AdaBoost)[113],有的算法还使用平滑方法减少调高的波动[111].大多数流行歌曲只有一个固定的调高,少数流行歌曲会在副歌这样具有情感提升的部分变调.古典音乐则经常发生更多的变调.对于这些复杂情况,需要进行调高的局部化检测.
音乐包括声乐和器乐两种形式.在声乐中,歌声通常承载音乐的主旋律,与节奏及和声一起构成音乐的3大要素.在MIR中与歌声信息处理(Singing Information Processing)相关的子领域包括歌声检测、歌声分离、歌手识别、歌唱评价、歌词识别等.其中歌声检测是其他子领域的前处理步骤.
2.4.1 歌声检测
歌声检测(Vocal/Singing Voice Detection)的任务是判定整首歌曲中哪些部分是歌声,哪些部分是纯乐器伴奏.歌声检测算法一般包含以下几个步骤: 将歌曲分成几十毫秒长的音频帧(Frame),从各帧中提取能够有效区分歌声和伴奏的音频特征,利用基于规则的门限方法或者基于机器学习的统计分类方法对特征进行歌声/非歌声(Vocal/Nonvocal)分类,考虑到歌声的连续性,最后还需对帧级别的分类结果进行平滑纠错处理.除了Frame,还可以节拍(Beat)为单位进行歌声检测[114].
歌声检测算法使用的音频特征包括谱特征(Spectral Features)、和声、频率颤音(Vibrato)、幅度颤音(Tremolo)、音色(Timbre)、歌声共振峰(Singing Formant)、主音高(Predominant Pitch)、梅尔频率倒谱系数(Mel-frequency Cepstral Coefficients, MFCC)、线性预测倒谱系数(Linear Prediction Cepstral Coefficients, LPCC)、线性预测系数(Linear Prediction Coefficients, LPC)等[115-122],使用的分类器也从高斯混合模型(Gaussian Mixture Model, GMM)[123]、HMM[115]、SVM[114]扩展到RNN[124]等深度学习手段.
基于监督学习(Supervised Learning)的歌声检测方法需要大量歌声/非歌声片段的手工标注,费时费力,价格昂贵.为解决这个问题,文献[125]将主动学习(Active Learning)技术集成进传统的基于SVM的监督学习方法,极大地减少了标注数据量.文献[126]提出另一个有趣的方法,利用MIDI文件中音符Onset/Offset(起始点/截止点)提供的准确的Vocal/Nonvocal边界,将MIDI合成的音频使用动态时间规整(Dynamic Time Warping, DTW)与真实音频进行对齐,从而用极少的代价获得大量的真实音频的歌声/非歌声标注训练数据.文献[127]使用Vibrato、Attack-decay、MFCC等特征对基于HMM的Vocal/Nonvocal分类器进行协同训练(Co-training).首先,使用Vibrato训练HMM,从自动标记的测试歌曲片段中挑选最可靠的部分加入到标注歌曲训练集;然后,对Attack-decay重复同样的过程;最后,用MFCC得到最后的Vocal/Nonvocal片段.协同训练充分利用丰富的未标注歌曲,大大减少了手工标注的工作量和计算代价.
进行歌声检测还有少数非监督学习(Unsupervised Learning)算法.文献[128]使用K奇异值分解法(K-Singular Value Decomposition, K-SVD)进行短时特征稀疏表示的字典学习(Dictionary Learning),估计每个码字(Code Word)出现的概率,并用其计算每帧加权函数的值,还使用一个二值门限将音乐分割为Vocal和Nonvocal片段.高阶泛音的时域波动是表征歌声的明显特征[119].文献[129]用正弦波模型(Sinusoid Model)将泛音随时间变化的频率模拟为一个缓慢变化的频率加上一个正弦调制.对泛音相似性矩阵(Partial Similarity Matrix)进行聚类,将和声相关的泛音聚类到各个音源,其中一个音源很可能是歌声,有利于对歌声检测和分离.
上述Frame-level的歌声检测经常会出现碎片化的结果.考虑到音乐中的歌唱区域前后关联并非独立存在,还需进行时域平滑后处理(Post-processing)去掉短时突变点.一类方法是通过一阶、二阶差分或方差等表示特征级(Feature-level)时域上下文关系[118],另一类方法是使用中值滤波、自回归滑动平均(Auto Regressive Moving Average, ARMA)[123]、考虑过去时域信息的模型如LSTM-RNN[118]、或同时考虑过去和未来时域信息的模型如BLSTM-RNN[124].
2.4.2 歌声分离
歌声分离(Vocal/Singing Voice Separation)是指将歌声与背景音乐伴奏进行分离的技术.在旋律提取、歌手识别、哼唱/歌唱检索、卡拉OK伴奏、歌词识别、歌唱语种识别等应用领域有十分重要的作用.由于歌声与由多种音调类乐器组成的伴奏都是和声的(不能被视为噪声),并按照和声结构耦合在一起(即基频或泛音重叠),而且还有多种打击类乐器的干扰,因此歌声分离具有相当大的难度和挑战性.简单的去噪(Denoise)方法并不适用[130].一个通用的方法可以将之视为盲源分离(Blind Source Separation, BSS)问题,如文献[131]结合独立成分分析(ICA)和小波门限方法(Wavelet Thresholding)来分离歌声.但是此类方法没有利用任何音乐信号本身的信息,通常效果较差.专门的歌声分离算法根据输入音乐信号音轨(Vocal Track)的数量可分为立体声歌声分离(Stereo Vocal Separation)和单声道歌声分离(Monaural Vocal Separation).注意不论音轨数量,输入都是多声部/多音音乐.
从立体声中分离歌声的传统方法假设歌声位于中央信道,利用声源的空间差异(Spatial Diversity)来定位和分离歌声.空间方法的结果可以接受,但有很多由于中央信道估计不准带来的失真和虚假部分(Distortions and Artifacts).文献[132]将基频f0信息集成进来.首先使用MuLeTs立体声分离算法预分离,得到它的f0序列,然后使用HMM对音高包络线进行平滑后再分离歌声及非歌声区域.文献[133]首先利用双耳信息即信道间强度差(Inter-channel Level Difference, ILD)和信道间相位差(Inter-channel Phase Difference, IPD)进行位于中央的歌声粗略分离,之后使用GMM对混合信号频域的低层分布进行聚类.文献[134]将歌声部分模拟为源/滤波器模型(Source/Filter Model),伴奏模拟为NMF的成分混合,立体声信号被假设为歌声与伴奏的瞬时混合,然后使用最大似然法(Maximum Likelihood)联合估计两个信道的所有参数.
近年来更多的研究集中于从单声道真实录音中提取歌声,与立体声歌声分离相比更加困难.单声道音乐信号分离主要包括以下几种技术框架:
(1) 基于音高推理(Pitch-based Inference)获得歌声泛音结构的分离技术[135].具体地说,就是从混合音乐信号中首先估计歌声基频f0包络线,然后通过f0及其泛音成分来提取歌声.相反,如果歌声首先被从混合音乐信号中准确地提取出来,f0的估计也会更容易.这实际是一个鸡生蛋、蛋生鸡的问题.为克服该限制,文献[136-137]提出一种迭代的方法,即首先用鲁棒主成分分析(Robust Principal Component Analysis, RPCA)算法初步分离歌声,从分离的歌声信号中初步估计歌声主旋律的f0包络线,并在基频重要性频谱图(f0Salience Spectrogram)中寻找最佳时域路径,之后将RPCA的时频掩蔽(Time-frequency Mask)和基于f0和声结构的时频掩蔽相结合,与上一步骤迭代进行更准确的歌声分离.
(2) 基于矩阵分解技术,如非负矩阵分解(NMF)、鲁棒主成分分析(RPCA)等的分离技术.基于NMF的算法分解音乐信号频谱,选择分别属于歌声和伴奏的成分并合成为时域信号[138-139].RPCA算法将混合音乐信号分解为一个低秩成分(Low-rank Component)和一个稀疏成分(Sparse Component).因为伴奏本身是重复的,所以被认为是低秩子空间.而歌声根据其特点则被认为是中等稀疏的[140].基于此思想,更适合音频的RPCA的非负变种即RNMF(Robust Low-rank Non-negative Matrix Factorization)也被引入进行歌声分离[141].采用矩阵分解技术有不同的粒度,粗粒度方式如RPCA利用歌声的特定性质直接将音乐信号分解为歌声和伴奏,细粒度方式如NMF将音乐信号分解为一套细化(Fine-grained)的成分,并重新组合来产生目标声源估计.文献[142]将两种方式以级联的方式结合,将音乐信号分解为一套中粒度成分(Mid-level Components).该分解足够细来模拟歌声的不同性质,又足够粗以保持该成分的语义,使得能直接组装出歌声和伴奏.
(3) 基于计算听觉场景分析(Computational Auditory Scene Analysis, CASA)的分离技术.CASA是一种新兴的声音分离计算方法[143],它的基本原理来自于Bregman提出的听觉场景分析(Auditory Scene Analysis, ASA)[144],主要思路就是利用感知线索(Cue)把混合音频信号分别组织进对应于不同声源的感知数据流.听觉场景分析(ASA)认为人类听觉器官的感知过程一般可以分成两个主要过程: 分割阶段(Segmentation)和聚集阶段(Grouping).在分割阶段,声学输入信号经各种时频变换(Time-frequency Transforms)被分解为时频单元(T-F Units),各单元被组织进片段(Segments),每个片段可近似认为来自单一声源.在聚集阶段,来自同一音源的Segments根据一套规则被合并到一起.分割片段和聚集使用的Cues包括时频近似度(T-F Proximity)、和声、音高、Onset/Offset、幅度/频率调制、空间信息等.受ASA启发,CASA利用从人类听觉系统中获得的知识来进行声音分离,希望获得接近人类水平的分离性能.与其他声音分离方法相比,CASA利用声音的内在性质进行分离,对声源进行了最小的假设,展现出极大的潜力.
文献[145-146]是基于CASA的单声道歌声分离的创始性算法.首先进行Vocal/Nonvocal部分检测,之后进行主音高检测得到歌声区域的歌声包络线,最后基于分割和聚集进行歌声分离.在分割阶段,基于时域连续性(Temporal Continuity)和交叉信道相关(Cross-channel Correlation)将时域连续的T-F单元合并成Segments.在聚集阶段,直接应用检测到的音高包络线.简言之,如果一个T-F单元的局部周期性与该帧检测的音高相匹配,那么该单元被标记为歌声主导(Singing Dominant).如果一个Frame中大多数的T-F单元被标记为歌声主导,那么这个Frame就被标记为歌声主导.如果一个Segment有超过一半的Frames是歌声主导,那么这个Segment就是歌声主导.标记为歌声的Segments被聚集为代表歌声的音频流.文献[147]使用CASA框架设计一个串联(Tandem)算法,迭代地估计歌声音高(Singing Pitch)并分离歌声.首先估计粗略的音高,然后考虑和声与时域连续性线索(Harmonicity and Temporal Continuity Cues)用它来分离目标歌声,分离的歌声再用来估计音高,如此迭代进行.为提高性能,提出一个趋势估计(Trend Estimation)算法来检测每个Frame的歌声音高范围,去除了大量错误的伴奏或歌声泛音产生的音高候选者.掩蔽函数(Masking Functions)是CASA类分离算法的核心,最常用的一个叫做理想二值化掩蔽(Ideal Binary Mask, IBM).标记为歌声的时频块具有紧密的时频域上下文关系,文献[148-149]使用深度递归神经网络(RNN)对掩蔽块的时频域连接进行优化,把分离过程作为最后一层的非线性过程,并进行网络的联合优化.
2.4.3 歌手识别
歌手识别(Singer/Artist Identification)是指判断一首歌曲是由集合中的哪个歌手演唱的.在歌手的分类管理、音乐索引和检索、版权管理、音乐推荐等领域都有重要应用.受乐器伴奏、录音质量、伴唱等的影响,歌手识别是一个十分困难的问题.此外,一个歌手每个专辑中的歌曲通常有很多类似之处.比如风格(Style)、配器(Instrumentation)、后处理方式(Post-production)等,使得训练和测试数据分布在同一唱片中时会产生偏高的识别结果,称为唱片效应(Album Effect)[150].除了少量算法采用半解压状态的修正余弦变换(Modified Discrete Cosine Transform, MDCT)系数作为特征直接在MP3压缩域上进行歌手分类识别[151-152],绝大多数算法都是以原始格式音频作为输入.
歌手识别借鉴了说话人/声纹识别(Speaker/Voiceprint Recognition)的整体技术框架[153].人类听觉系统(Human Auditory System, HAS)到底通过什么样的感知特征来识别特定的歌声,目前仍不得而知.由于歌声和语音之间在时频结构上的巨大差别,除了用于声纹识别的典型的音频特征如感知线性预测(Perceptual Linear Prediction, PLP)[154]、MFCC[155]等,还需引入更多表示歌声特性的特征,如音色[156]、反应歌手个性化风格的频率颤音倒谱系数(Vibrato Cepstral Coefficients)[157]等.音色是人耳区分不同音乐声音的基础[158].文献[159]从声音的正弦泛音的瞬时幅度和频率估计谱包络线(Spectral Envelope),作为特征输入分类器识别歌手.使用的分类器有GMM[160]、卷积神经网络(Convolutional Neural Network, CNN)[161]、混合模型[162]等.
由于伴奏的干扰,在进行歌手识别前通常需要进行歌声增强(Singing Enhancement)或伴奏消减(Accompany Reduction)等预处理[163-164].文献[163]采用基于NMF分解的歌声分离技术作为预处理.文献[164]首先提取主旋律(Predominant Melody)的和声结构,使用正弦波模型将这些成分重新合成为主旋律,并估计可靠的旋律帧从而实现伴奏消减.虽然增强或分离多声部/多音音乐中的歌声部分作为前处理被相信是一个提高歌手识别任务性能的有效方式,但是因为不可避免地存在失真,而且会传递到后续的特征提取和分类阶段,所以只能带来有限的提高.文献[165]是一种基于CASA的歌声增强预处理措施.在每个Frame上的二元时频掩蔽(Binary T-F Mask)包括可靠的歌声时频单元,和另外一些不可靠或丢失的歌声时频单元,频谱不完整.为减轻失真,使用两个缺失特征(Missing Feature)方法即重构(Reconstruction)和边缘化(Marginalization)处理不完整的歌声频谱(Vocal Spectrum),再进行歌手识别.与上述主要基于音频分离的方法思路不同,文献[166]提出了一个有趣的方法.从一个很大的卡拉OK数据集中手工混合左右声道的清唱歌声和伴奏,并研究清唱和带伴奏歌声之间在倒谱上的变换模型.当一个未知的带伴奏的歌声出现时,即可把带伴奏歌声的倒谱转换到接近清唱的水平,从而有助于后续的歌手分类识别.
当前已有的歌手识别算法在整体框架上与说话人/声纹识别相同,需要事先搜集大量的歌声清唱数据并建立歌声模型.但是与语音数据主要来自普通人群并相对容易获取不同,歌唱主要源自各种级别的艺术家,而且几乎都是带有乐器伴奏.大量搜集每个歌手的无伴奏清唱数据几乎是不可能的.许多歌手识别算法使用带伴奏的歌声进行训练,但效果并不如人意.文献[167]研究了用语音数据代替歌唱数据来刻画歌唱者声音的可能性,结论是很难用说话完全代替歌唱的特性,原因在于大多数人的说话和歌唱具有很大的差异.两个可能的解决思路是: (1) 将歌手的语音数据转换为歌唱数据增加训练数据量,然后使用歌声驱动的模型进行识别;(2) 将歌手的歌唱数据转换为对应的语音,然后使用大量语音数据训练的模型进行识别.
2.4.4 歌唱评价
歌唱评价(Singing Evaluation)是对演唱的歌声片段做出各方面的正面或负面描述,一直以来都是音乐学界所关注的课题之一.在歌唱表演、歌唱比赛、卡拉OK娱乐、声乐教育等场合都具有重要应用.目前已有的自动歌唱评价系统基本集中于卡拉OK场景.
早期的算法(如20世纪90年代中前期)受计算机软硬件的限制,只采用音量(Volume/Loudness)作为评价标准,经常跟人类评价的结果大相径庭.随着MIR技术及计算资源的发展,后续算法有了很大发展.常规思路是计算两段歌声中的各种音频特征如音量、旋律线的音高、音准(Intonation)、音程、音符时长、节奏、颤音、音频特征包络线、统计特征等之间的相似度,并给出一个用户表现的评价,如好/坏(Good/Poor)两个质量分类[168]、高/中/低(High/Medium/Low)3个质量分类[169]或总体评分[170-171].常用分类器有SVM等,测量相似性可使用动态时间规整(DTW)技术,由不同特征得到的相似性分数可使用权重结合到一起[172].
因为绝大多数歌曲都包含伴奏,在很多情况下无法找到歌星的清唱录音和用户歌声进行比较.文献[173]直接以歌手的CD/MP3带伴奏歌曲作为参考基准,以音高、强弱、节奏为特征与用户的歌声进行比较,除了给出用户的总体歌唱评价,还指出哪里唱的好和不好.该技术比较接近于人类评价方式.类似地,文献[174]的评价包括是否跑调或走音(Off Key/Be in Tune),这需要以很高的频率分辨率进行基频估计,通常小于几个音分(Cent).以上算法虽有一定效果,但很少考虑各个评价要素之间的关系.以系统评价和人类评价之间的相关系数定量衡量,经常与人类评价结果相去甚远[175].
另一个难题是如何进行歌唱的高级评价.即在跟准节奏和音高的前提下,如何像人类专家那样对音色具有何种特点、是否有辨识度,音域(Pitch Range)是否合适,吐字是否清晰,演唱是否感情饱满等进行高级评价.这方面的研究工作很少.文献[176]采用歌声相关的特征如频率颤音、和声噪音比(Harmonic-to-noise Ratio)针对中文流行歌曲的6种歌唱音色进行分类,这6种音色是浑厚(Deep)、沙哑(Gravelly)、有力(Powerful)、甜美(Sweet)、空灵(Ethereal)、高亢(High pitched).文献[177]使用基频、共振峰、和声及残差谱(Residual Spectrum)作为特征,识别用户的发音区域并分析其声音质量.推荐一个更合适的音域,避免唱破音出现嗓子疼痛等声带健康(Vocal Health)问题.对于歌曲来讲,歌词的正确发音也是非常重要的一个方面.好的歌手如邓丽君经常被评价为字正腔圆.文献[178]使用谱包络线和音高作为特征,混合高斯模型(GMM)和线性回归(Linear Regression)作为分类器,自动对歌唱元音(Singing Vowel)的质量进行分类评价.除了以上基于声学的歌唱评价方法,文献[179]通过测量嘴和下颌(Mandible)移动的肌电图(Electromyography,EMG)进行歌唱评价.
2.4.5 歌词识别
歌词识别(Lyrics Recognition/Transcription)与语音识别(Speech Recognition)问题的总体目标类似,都是把语言转换为文本;总体技术框架也类似,都包括声学模型和语言模型.但是由于歌唱和说话在声学和语言特性上的巨大差别,具体技术实现上需针对歌唱的特点进行更有针对性的设计.从声学模型来看,歌唱是一种特殊的语音.日常语音基本可视为匀速进行,音高变化范围很小.歌唱则需要根据音乐的旋律和节奏,以及颤音、转音等艺术技巧控制声带的发声方式、时间和气息的稳定性.一个普遍的现象是同一个人歌唱和说话的音色具有很大不同.从语言模型来看,歌词具有一定的艺术性,还需要押韵,也与日常交流的语言具有很大区别.此外,与单纯的语音不同,歌声几乎都是与各种乐器伴奏混合在一起,涉及信号分离的难题.而且搜集清唱歌声与歌词对应的训练数据十分困难.这些特点使得传统的语音识别模型无法直接使用,带来巨大挑战.
虽然很多歌曲的歌词已经被人工上传到各个音乐网站,但是仍然有很多歌曲缺少歌词.此外,如果歌词识别具有一定的准确率,则可以将基于声学特征(Acoustic Features)的歌唱检索转换为更成熟的基于文本的检索[180],或者帮助基于音频特征的歌唱检索.另外,歌词识别在歌曲分类、歌词与音频或口型对齐上也有一定应用.
目前为止,仅有极少数歌词识别的算法被提出,而且识别准确率很低.类似于经典语音识别框架,文献[181]使用音乐特征及HMM模型进行歌词识别,用合成的歌声解决缺乏训练数据的问题,在无乐器伴奏的歌声中(A Cappella)中识别音节(Syllable),并且为了响应音素(Phoneme)长度的变化,构建一个依赖于长度(Duration Dependent)的HMM.文献[182]利用类似的语音识别模型,用有限状态自动机(Finite State Automaton, FSA)描述识别语法,将待识别的歌词约束为数据库中存储的歌词.文献[183]对音乐中的音素进行识别(Phoneme Recognition)以帮助歌词识别.在有视觉信息的情况下,还可以发展基于视觉的歌词识别方法.文献[184]利用光学字符识别(Optical Character Recognition, OCR)引擎自动识别YouTube网站上下载的视频中的歌词.文献[185]通过口型信息帮助歌词识别,但效果有限.
音乐搜索(Music Retrieval)是指在给定某种形式的查询(Query)时,在数据库中检索与之匹配的结果集并按相关性从高到低返回的过程.按查询输入的形式,可进一步分为5个子领域: 音乐识别、哼唱及歌唱检索、音乐版本识别或翻唱识别、节拍检索、音乐借用.
2.5.1 音乐识别
音乐识别(Music Identification/Recognition)在产品上又称为听歌识曲.通常用手机或麦克风录制10s左右的音乐作为查询(Query)片段,计算其音频指纹后与后台音频指纹库中的记录进行匹配,并将最相似记录的歌曲名字、词曲作者、歌唱者甚至歌词等相关元数据返回.音频指纹是指可以代表一段音频重要声学特征的基于内容的紧致数字签名,音频指纹技术(Audio Fingerprinting)是音乐识别的核心,当扩展到一般音频时也可称为基于例子的音频检索(Query by Example, QBE).音频指纹算法首先提取各种时频域音频特征,对其建模后得到指纹,之后在指纹库中进行基于相似性的快速匹配和查找[186].
常用的音频特征有Chroma[187]、节奏直方图(Rhythm Histogram)[187]、节拍[188]、经KD树量化的旋律线字符集[189]、音高与时长[190]、树量化的MFCC峰值和谱峰值(Spectral Peaks)字符集[191]、MPEG-7描述子[192]、频谱图局部峰值[193]、从音乐的二维频谱图上学习到的图像特征[194]、MP3压缩域的听觉Zernike矩(Auditory Zernike Moment)[195]等.各种特征经常融合在一起使用.
录制的输入片段有可能经受保持音高不变的时间伸缩(TSM)和变调(PS)这两种失真.与一般的噪声类失真影响音频质量不同,这两种失真主要会引起音频指纹在时频域上的移动,产生同步失真(Desynchronization),从而使查询片段指纹与数据库音频指纹集匹配失败.文献[196]从二维频谱图上提取计算机视觉中的SIFT(Scale Invariant Feature Transform)描述子作为音频指纹,利用其局部对齐(Local Alignment)能力抵抗TSM和PS失真.
为使提取的特征更鲁棒,还需进行去噪、回声消除(Echo Cancellation)[188]等预处理.常用的指纹匹配方法包括经典的TF-IDF(Term Frequency-Inverse Document Frequency)打分匹配、局部敏感哈希(Local Sensitive Hashing, LSH)、倒排表(Inverted Table)等[189,191].文献[197]使用一个有趣的方法加速查询匹配,即首先自动识别Query和数据库歌曲的流派,在匹配阶段只计算Query与数据库中具有同样流派的歌曲的相似性.
2.5.2 哼唱/歌唱检索
哼唱/歌唱检索(Query by Humming/Singing, QBH/QBS)通常用麦克风录制长短不一的哼唱或歌唱声音作为查询片段,计算音频特征后在数据库中进行相似性匹配,并按匹配度高低返回结果列表,最理想的目标是正确的歌曲排名第一返回.典型的应用场景是卡拉OK智能点歌.与上述音乐识别技术相比,哼唱/歌唱检索不仅同样面临由于在空气中录音而引起的信号质量下降,还面临跑调、节拍跟不上等新的困难.哼唱/歌唱检索的结果与用户的哼唱/歌唱查询片段质量高度相关,存在很大的不确定性.
除了常规时频域音频特征,能够在一定程度上反应音乐主旋律走向的中高层音频特征更适合于哼唱/歌唱检索.早期的哼唱检索系统[198]根据音高序列的相对高低(Relative Pitch Changes)用3个字符即方向信息来表示旋律包络线,并区分不同的旋律.这3个字符是‘U’、‘D’、‘S’,表示当前音符的音高分别高于、低于、等于前一个音符的音高.3个字符表示的主要问题比较粗糙,于是文献[199]把旋律包络线扩展为用24个半音(Semitone)字符来表示,即当前音的一个正负八度.类似地,文献[200]也采用音程作为特征矢量,并增加了分辨率.与以上均不相同,文献[201]没有使用明确的音符信息,而是使用音符出现的概率来表示旋律信息.除了音高类的特征,文献[202]利用音长和音长变化对旋律进行编码,以获得更加精确的旋律表示.文献[203]采用符合MPEG-7的旋律序列,即一系列音符长度和长度比例作为Query.与上述不同,文献[204]从数据驱动出发,用音素级别(Phoneme-level)的HMM模拟哼唱/歌唱波形的音符片段,用GMM模拟能量、音高等特征,更加鲁棒地表示用户哼唱/歌唱的旋律.
由于用户音乐水平不一,哼唱及歌唱的查询片段经常出现音符走音、整体跑调、速度及节拍跟不上伴奏等现象.即使用户输入没有问题,音符及节拍的分割和音高识别算法也不会100%准确,可能产生插入或删除等错误[205].给定一个不完美的Query,如何准确地从大规模数据库里检索是一个巨大挑战.为克服音符走音现象,文献[206]对查询片段的音高序列进行平滑,去除音高检测或用户歌唱/哼唱产生的异常点(Outlier).绝大多数算法采用相对音高序列,而不是绝对音高.只要保持相对音高序列的正确,那么对于个别音符走音现象以上算法都是具有一定容错性的[207].为克服哼唱和原唱之间的速度差异,文献[208]首先使用原始Query来检索候选歌曲,如果结果不可靠,Query片段被线性缩放两倍重新检索.如果还不可靠,则缩放更多倍数.日本的卡拉OK歌曲选择系统Sound Compass[209]也采用类似的时间伸缩方法.为克服整体跑调现象,绝大多数算法采用调高平移(Key Transposition)办法进行纠错[208-209].用户哼唱的各种错误经常在开头和结尾处出现.基于此假设,文献[210]认为只有Query的中间部分是属于某个音乐的子序列.对两个流行的局部对齐方法即线性伸缩(Linear Scaling, LS)和DTW扩展后进行匹配识别.为抵抗Query可能存在的各种错误,文献[205]采用音频指纹系统描述重要的旋律信息,更好地比较Query和数据库歌曲.
另一个影响匹配性能的因素是如何切割Query和数据库完整歌曲的时间单元.文献[211]表明基于音符的切割比基于帧的分割处理更快.文献[200]表明所有音乐信息基于节拍分割会比基于音符分割对于输入错误更加鲁棒.文献[212]进一步提出一种基于乐句(Music Phrase)分割和匹配的新方法,使得匹配准确率大大提升.基于节拍和乐句的分割不仅性能更好,而且也更符合音乐语义.类似地,文献[213]也采用乐句尺度的分段线性伸缩(Phrase-level Piecewise Linear Scaling),基于DTW或递归对齐(Recursive Alignment)进行旋律匹配,并将每个乐句的旋律片段约束在一个有限范围内调整.
在旋律相似性匹配方面,最直接的技术是字符串近似匹配/对齐技术[203].随着研究的深入开始引入动态时间规整(DTW)、后辍树索引、隐马尔科夫模型(HMM)、K近邻(K-nearest Neighbor)、N-gram、基于距离的相似性(Distance-based Similarity)、基于量化的相似性(Quantization-based Similarity)、基于模糊量化的相似性(Fuzzy Quantization-based Similarity)等各种方法[209,214-215].大多数哼唱/歌唱检索方法在时间域测量音符序列之间的距离,文献[216]在快速傅里叶变换(Fast Fourier Transform, FFT)频域计算音符序列之间的欧氏距离(Euclidean Distance),匹配速度有所加快.基于动态规划(Dynamic Programming, DP)的局部对齐方法穷尽两个音乐片段之间所有可能的匹配,返回最佳局部对齐,缺点是计算代价太高,在指数增长的数据库规模下,准确的局部对齐已不可能.因此,对于大规模数据库需要更高效的检索办法.文献[217]实现基于音符音高的LSH索引算法,筛选候选片段,使用线性伸缩来定位候选者的准确边界.文献[218]使用多谱聚类(Multiple Spectral Hashing, MSH)得到特征矢量,之后用改进的DTW进行相似性匹配.文献[219]利用显卡GPU(Graphic Processing Unit)硬件强大的计算能力,实现局部对齐的快速算法,速度提高超过100倍.基于不同匹配策略可得到不同的结果,文献[220]在打分级别(Score-level)融合多个结果.
2.5.3 音乐版本识别或翻唱识别
音乐版本识别(Cover Song Identification, CSI)或翻唱识别判断两首音乐是否具有同样的本源.众所周知,很多音乐经过重新编曲、演唱和演奏后会形成很多版本.这些不同的版本会保持主旋律基本相同,但是音乐结构、调高、节奏(速度)、配器(音色)、歌唱者性别、语言等都可能会发生巨大变化[221].人类大脑具有高度的抽象思维、逻辑推理能力,识别多版本音乐轻而易举.但是音频数据的改变,却使机器识别相当困难.
绝大多数音乐版本识别算法使用一个通用框架,包括特征提取和模式匹配两步.在特征提取阶段,对应于各个音乐要素的高层特征很难准确计算.因此,直接采用高层特征的算法难以得到希望的效果.低层特征无法反映音乐语义,仅有少数CSI算法采用低层特征,如音色形状序列(Timbral Shape Sequences),即一首歌曲的经过量化的平滑频谱的相对改变[222].为弥补高、低层音频表示之间的鸿沟,在CSI中经常使用既能在一定程度上反映高层特征又能比较准确计算的中层特征(Mid-level Feature).文献[223]提出一个集成旋律和节奏特性的中层特征.首先进行节拍跟踪,产生独立于速度变化的节拍对齐(Beat-synchronous)表示.之后在连续音频节拍上进行多音高检测,在检测的音高上提取旋律线用于后续检索.文献[224]也类似地采用主旋律作为特征.多版本音乐保持主旋律基本不变,会使在此基础上配置的和声在很多情况下也保持基本不变.所以,和声类的特征也可以用于CSI.文献[225]采用半音类Chroma/PCP及其变种.文献[226]采用随时间变化的半音类图(Chromagram).文献[227]在Chromagram中去掉相位信息,并应用指数分布的频带得到一个对于乐器、速度、时移不敏感的特征矩阵.文献[228]受心理物理学启发,根据人类听觉对相对音高比绝对音高敏感的事实,采用描述相对音高的动态Chroma特征(Chroma-based Dynamic Feature).文献[229]在Chroma基础上用深度学习中的自编码器(Auto Encoder)学习一个更能刻画音乐本质的中间表示.文献[230]使用在MIDI训练的HMM识别的和弦序列.与以上基于原始格式音频输入的CSI算法不同,文献[231]在压缩域直接从AAC文件中提取一个低复杂度的有效特征,即在半解码(Semi-decoding)的情况下,直接将MDCT系数映射到12维Chroma特征上.
以上主旋律与和声类的中层特征对配器(音色)、歌唱者性别、语言等变化都具有较强的内在鲁棒性[232].对于节奏或速度变化,可采用基于节拍分割对齐的同步方法[226].对于调高变化,一般采用调高平移的措施[226].更严重的挑战来自多版本音乐中可能存在的音乐结构变化.一个典型的例子是苏芮演唱的“一样的月光”.该歌曲有两个版本,相差一段长1分多钟的副歌,前奏也完全改变.更多的例子体现在CD版歌曲和演唱会版本的歌曲,通常演唱会版本会在间奏处增加一大段乐手独奏的即兴表演.在音乐结构发生变化时进行CSI必须采用额外措施.首先按照前奏、主歌(一般2个)、副歌(通常大于2个)、桥段、间奏、结尾等部分分割,之后再调用上边的办法在各个局部进行音乐版本识别.文献[233]基于音乐结构分析提出一个新的CSI算法,只匹配重要部分(如主歌、副歌)而忽略次要部分,使用加权平均来集成各部分的相似性.
相似性度量一般包括互相关、归一化的Frobenius范数、欧氏距离、点积、动态时间规整(DTW)、Smith-Waterman对齐算法、隐马尔科夫模型(HMM)的最可能隐含状态序列、近似最近邻检索(Approximate Nearest Neighbor Search)等[226-227,230,232,234],在大规模匹配时还可采用局部敏感哈希(LSH)进行索引[223].除了以上常规方法,文献[235]基于信息论(Information Theory)方法研究CSI中的音频时间序列之间的相似性问题.在离散情况下计算归一化压缩距离(Normalized Compression Distance, NCD),在连续情况下计算基于信息的相似性度量(Information-based Measures of Similarity).文献[222]基于矢量量化(Vector Quantization)或聚类的思想设计一种CSI相似性匹配方法.将滑动窗口的各音频特征映射到以时间排序(Time-ordered)的高维空间中的点云(Point Cloud),同一歌曲不同版本对应的点云可近似认为由旋转(Rotation)、平移(Translation)或伸缩(Scaling)得到.通常融合不同的CSI检测算法能得到更好的结果,如文献[236]结合了DTW和Qmax的结果.
文献[234]研究了诸多要素对CSI的影响.实验表明: Chroma特征比MFCC等音色类特征更适合此任务,而且增加分辨率可提高识别准确性.余弦距离比欧氏距离更适合计算Chroma序列相似性.最佳平移索引(Optimal Transposition Index, OTI)对调高循环移位,以获得两首歌曲之间的最大相似性,比首先估计调高再平移的方法更准确.采用节拍跟踪、调高估计、旋律提取、摘要提取等中间步骤进行CSI,由于它们本身并不完全可靠,反而可能会使性能降低.考虑到在各个版本音乐间可能出现较大的歌曲结构改变,进行局部相似性计算或局部对齐是唯一可行的CSI检测方法.
2.5.4 敲击检索
敲击检索(Query By Tapping, QBT)是根据输入的节拍信息,从数据库中返回按节拍相似度高低排序的音乐列表.在整个检索过程中没有利用音高信息.随着个人手持设备的普及,QBT提供了一个通过摇晃或敲击设备的新颖有趣的音乐检索方式.现在该领域的研究成果还较少.
一个典型的方法是提取Query中音符时长矢量[237]作为特征,归一化处理后采用动态规划方法在输入时间矢量和数据库时间矢量特征间进行比对并排序返回.类似地,文献[238]采用与文献[237]同样的特征,只是把音符时长的名字改为音符起始点间距(Inter-Onset Interval, IOI),建立IOI比例矩阵(IOI Ratio Matrix),通过动态规划与数据库歌曲匹配.文献[239]提出的系统叫做BeatBank,用户在MIDI键盘或电子鼓上敲击一首歌的节奏,输入被转化为符合MPEG-7的节拍描述子(Beat Description Scheme)作为特征.文献[240]以音频中计算出的峰度(Kurtosis)的变化(Variations)作为节奏特征,并采用局部对齐算法匹配计算相似性分数.
2.5.5 音乐借用
图8 音乐借用识别与翻唱检索、歌曲片段识别的区别与联系Fig.8 Difference and relation between music borrowing, cover song identification and music identification
音乐借用(Music Borrowing)有着长期的历史.特别是在当今数字化时代,一个艺术家可以轻易地截取别人作品的某些部分,并将其集成到自己的歌曲中来.借用和被借用歌曲之间共享一个旋律相似的片段.通常音乐界认为适当的借用在艺术创作中是允许的,但是超过一定长度(如8小节)就涉嫌抄袭侵权行为.例如,台湾女子组合S.H.E的《波斯猫》借用了柯特尔比的《波斯市场》作为副歌部分的旋律,流行歌手卓亚君的《洛丽塔》的前奏来自钢琴曲《致爱丽丝》,李健的《贝加尔湖畔》则在桥段借用了一段俄罗斯民歌的旋律,这些属于正常引用的例子.而王力宏的《大城小爱》和周华健的《让我欢喜让我忧》全曲旋律非常相似,花儿乐队两张专辑中的13首歌曲也与其他歌曲旋律高度相似,这些都被指控涉嫌抄袭.从用户的角度来说,发现音乐引用会给用户带来不少乐趣,也可以进行作曲技巧分析.从法律的角度来看,检测歌曲之间的相似片段将有助于音乐作品的版权维护和盗版检测,具有重要的现实意义.
音乐借用最显著的特点是两个音乐作品中的相似片段往往都比较短,而且起止位置随机.对计算机处理而言这是一个难题.音乐借用与翻唱检索和音乐识别之间有区别也有联系,如图8所示.它们的相似点都是检测不同歌曲之间的旋律相似的部分,而区别在于翻唱检索基本以整首歌曲为单位,有较长的相似部分,如图8(a)所示;音乐识别则是固定一个短的片段,在另一首歌曲中检索与之相似的短片段,片段之间只是音频质量不同,如图8(b)所示;音乐借用也是检测相似短片段,但难点在于不知道相似片段在歌曲中的起始位置及长度,而且,类似于CSI,片段之间的音色、强弱、配器、速度、调高、语言等都可能不同,如图8(c)所示.据我们所知该问题在国内外MIR领域尚未被研究过.
如果把音高、旋律、节奏、和弦、调式、歌声等核心层的MIR领域理解为低层音乐语义(Low-level Music Semantics),那么音乐流派/曲风、情感、结构、摘要/缩略图、作曲家及乐器识别等应用层的MIR领域则可以理解为高层音乐语义(High-level Music Semantics).低层音乐语义的研究有助于高层音乐语义的分析理解和自动标注,进而基于此进行更有效的音乐搜索和推荐.
2.6.1 音乐流派/曲风分类
音乐流派/曲风(Music Genre/Style)指的是音乐的不同风格.西方音乐通常划分为流行(Pop)、摇滚(Rock)、爵士(Jazz)、乡村(Country)、古典(Classical)、蓝调(Blues)、嘻哈(Hip-hop)和迪斯科(Disco)等类别.如果考虑世界各地的民族音乐,那么划分的类别将更多更复杂.这些分类方法主观性强而且有争议,目前还没有一种通用的绝对标准.音乐流派分类在音乐组织管理、浏览、检索、情感计算和推荐中都有重要应用.
音乐流派分类是一个典型的模式识别问题,通常包括特征提取和统计分类两步.常用特征包括谱特征、倒谱特征、MFCC、频谱图上计算出的纹理特征、音高直方图(Pitch Histograms)等[241-242].特征的时域特性对分类也很重要[243].常用的分类器有GMM、SVM[244]、深度神经网络(DNN)[245]、卷积神经网络(CNN)[246]等.为解决流派类别定义的模糊性及有监督学习训练的困难,另一个思路是根据音乐内容分析比如节奏进行聚类,性能与有监督学习的方法相差不多[247].
2.6.2 作曲家识别
作曲家识别(Music Composer Recognition)是指通过听一段音乐并分析音频数据,识别出相应的作曲家信息,基本应用于音乐理论分析等专业场景.该领域的典型方法仍然是音频特征加上统计分类器.用常规低层音频特征刻画作曲家风格和技巧存在较大缺陷,提取高层音乐特征会更有利于挖掘作曲的内在风格和技巧[248].近些年,随着深度学习方法的流行,其从大数据(Big Data)中自动学习特征的能力也被用来深入研究作曲家的风格和技巧[249].文献中使用的分类器还包括决策树(Decision Trees)、基于规则的分类(Rule-based Classification)、SVM等[250].
2.6.3 智能乐器识别
每个国家、民族都有自己独特的乐器,种类繁多.如西方的风笛(Bagpipes)、单簧管(Clarinet)、长笛(Flute)、羽管键琴(Harpsichord)、管风琴(Organ)、钢琴(Piano)、长号(Trombone)、小号(Trumpet)、小提琴(Violin)、吉他(Guitar)等管弦乐器(Orchestral Instruments),还有鼓(Drum)、铙钹(Cymbal)等各种打击乐器(Percussive Instruments).到现代,还出现了各种模拟和扩展相应声学乐器音色的电声乐器(Electronic Instruments).中国也有很多的民族乐器,如古筝(Guzheng)、古琴(Guqin)、扬琴(Yangqin)、琵琶(Pipa)、二胡(Erhu)、马头琴(Horse-head String Instrument)等.准确识别乐器种类是音乐制作、乐器制造及评估等领域人士必备的专业技能,对音乐搜索、音乐流派识别、音乐识谱等任务都十分有益.
随着音频信息处理技术(Audio Information Processing)及人工智能技术(Artificial Intelligence, AI)的发展,出现了一些智能乐器识别(Intelligent Instrument Recognition)方法.主要的框架仍然是特征+分类器的通用模式识别框架.已用的特征包括LPC、MFCC、基于常数Q变换的倒谱系数、基于频谱图时频分析的音色特征、基于稀疏特征学习(Sparse Feature Learning)得到的特征;已用的分类器包括GMM、SVM、贝叶斯决策(Bayesian Decision)等[251-255].大多数方法识别单一乐器的声音输入.但是,在现实中音乐基本上都是多种乐器的混合.识别多声部/多音音乐中的各种乐器是一个重要而且更具挑战性的任务.文献[256]基于卷积神经网络(CNN)进行真实多声部/多音音乐中的主乐器(Predominant Instrument)的识别,网络以具有单一标签的固定长度的主乐器音乐片段训练,从可变长度的音频信号中估计主乐器,并在测试音频中采用滑动窗口,对信息输出进行融合.
2.6.4 音乐结构分析
音乐通常由按照层次结构组织的多个重复片段组成.音乐结构分析(Music Structure Analysis)的目的就是把音乐信号分割为一系列时间区域,并把这些区域聚集到具有音乐意义的类别[257].这些类别一般包括前奏(Intro)、主歌(Verse)、副歌(Chorus/Refrain)、间奏(Interlude)、桥段(Bridge)和结尾(Outro).注意主歌、副歌和间奏通常有多个段落,前奏、桥段、结尾则只有一个,而且副歌比主歌具有更高的相似度[258].音乐结构分析既可用于加深对音乐本身的理解,也可以辅助多个其他研究内容如音乐版本识别、乐句划分、音乐摘要、内容自适应的音频水印[259]等.
音乐内部具有高度的重复性,基于音频特征构造自相似矩阵(Self-similarity Matrix)成为结构分析的主要方法.可使用的音频特征包括音色、Chroma/PCP等[260-261].对自相似矩阵进行基于阈值的0/1二值化(Binarization)即得到递归图(Recurrence Plot)[262],这种量化处理可以使音乐中的重复模式(Repetition Patterns)对速度、乐器、调高的改变具有更强的鲁棒性.基于相似性思路文献[263]提出另一个更复杂的方法.首先在节拍帧上检测和弦,用动态规划匹配和弦后得到和声相似的区域,从而划分音乐结构.与以上基于重复模式相似性的方法不同,另一种结构分析的典型思路是基于对音频特征(如音色)的子空间聚类(Subspace Clustering),并假设每个子空间对应于一个音乐段落[264-265].
2.6.5 音乐摘要/缩略图
音频摘要/缩略图(Music Summary/Thumbnail)是指找到音乐中可听的最具代表性的音频片段.但是何谓最具代表性并没有很好定义,可以有多个选择.音乐摘要/缩略图有多个应用,比如制作彩铃、浏览、检索、购买数字音乐等[266].
获取音乐摘要/缩略图与音乐结构分析密切相关.一类方法只进行初步的结构分析,即基于音频特征计算各片段之间的相似性,再寻找最合适的片段集作为摘要/缩略图.使用的音频特征包括和声特征序列[267]及其直方图[268]、调性分析[269]等.另一类方法首先进行完整的音乐结构分析,之后从不同结构部分中提取摘要/缩略图.文献[270]使用副歌和它之前或之后的乐句合并组成摘要/缩略图,以保证摘要/缩略图开始和结束点位于有意义的乐句边界.文献[271]从流行音乐主歌和副歌中选择两个最具代表性的部分作为双摘要/缩略图.
2.6.6 音乐情感识别
音乐很容易和人产生情感共鸣,在不同的时间和环境下可能会需要带有不同感情色彩(如雄壮、欢快、轻松、悲伤、恐怖等)的音乐.音乐情感识别(Music Emotion Recognition, MER)在音乐选择与推荐、影视配乐、音乐理疗等场景都有重要应用,是近年来MIR领域的研究热点.
音乐情感识别最初被模拟为单标签[272]/多标签分类(Single/Multi-label Classification)问题[273].MER需要建立符合人类认知特点的分类模型,经典的如Hevner情感模型和Thayer情感模型[274].为克服分类字典的模糊性,另一个思路是将音乐情感识别模拟为一个回归预测(Regression Prediction)问题[275].由Arousal和Valence(AV)值构成二维AV情感空间,每个音乐信号成为情感平面上的一个点.心理学实验表明,Arousal和Valence两个变量可以表达所有情绪的变化.Arousal在心理学上可翻译为“活跃度”,表示某种情绪含有能量的大小或活跃的程度,文献中表达类似含义的还有Activation, Energy, Tension等单词.Valence在心理学上可翻译为“诱发力”,表示感到舒适或愉悦的程度,文献中表达类似含义的还有Pleasant, Good Mood, Positive Mood等词汇[276].
目前,绝大多数MER算法都是基于音乐信号的低层声学特征如短时能量、谱特征等.虽然计算方便,但是与音乐情感没有直接关系,效果往往并不理想.有些文章利用歌词作为辅助信息对音乐情感进行分析[277].未来需要在音乐领域知识的指导下,研究音乐高层特征(如旋律走向、速度、强弱、调性、配器等)与音乐情感之间的关系,而且需要与音乐心理学(Music Psychology)进行更紧密的结合,引入更先进的情感模型.
MIR还存在一些相关子领域,例如音乐推荐、音乐自动标注、歌声与歌词同步等.
2.7.1 音乐推荐
音乐推荐(Music Recommendation)通过分析用户历史行为,挖掘用户潜在兴趣,发现适合其喜好的音乐并进行推送.音乐推荐已在国内外多个音乐网站实现为产品,中文网站通常将此功能起名为“猜你喜欢”.据少量调查,目前的音乐推荐产品用户体验不佳.客户需求高度个性化,如何根据不同的时间、地点、年龄、性别、民族、学历、爱好、经历、心情等因素进行精准个性化推荐仍是未解决的研究难题.
主流的推荐技术主要有3种: (1) 协同过滤推荐(Collaborative Filtering Recommendation),认为用户会倾向于欣赏同自己有相似偏好的用户群所聆听的音乐[278].换句话说,如果用户A和B有相似的音乐喜好,那么B喜欢但是还没有被A考虑的歌曲就将被推荐给A.协同过滤推荐最主要的问题是不能给评分信息很少的新用户或新歌曲进行推荐,即冷启动(Cold-start)现象[279].(2) 基于内容的推荐(Content-based Recommendation),根据音乐间的元数据或声学特征的相似性推荐音乐[280].如果用户A喜欢歌曲S,那么具有与S相似音乐特征的歌曲都将被推荐给A.基于内容的推荐方法在一定程度上缓解了冷启动问题,更适用于新系统.(3) 混合型推荐(Hybrid Recommendation),除了传统的用户评价信息,还使用多模态数据如几何位置、用户场景、微博等社交媒体信息以及各种音乐标签如流派、情感、乐器和质量等[281].
除了从聆听历史中挖掘个人兴趣爱好以进行音乐推荐,现实生活中还需要其他种类的音乐推荐.例如,在缓解个人精神压力,为家庭录像选择最佳配乐、公共场合选择背景音乐时,需要基于情感计算进行推荐[282];在日常生活的不同场合(如工作、睡觉、运动)下通常需要不同种类的音乐.
2.7.2 音乐自动标注
近年来,互联网上出现了数以百万甚至千万计的数字音乐和音频,这也激发用户产生各种各样复杂的音乐发现(Music Discovery)的需求.例如,在一个怀旧的夜晚检索“八十年代温柔男女对唱”,在结婚纪念日找“纪念结婚的乐曲”,或者“萨克斯伴奏的悠扬浪漫的女生独唱”[283].这种查询本身是复杂甚至模糊的,与之前具有确定查询形式的音乐识别、哼唱/歌唱检索、翻唱检索等具有本质区别.
给音乐和音频赋予描述性的关键字(Descriptive Keywords)或标签(Tags)是建立符合这样需求的检索引擎的一个可行办法.音乐标签属于社会标签(Social Tags)的一种,可由用户人工标注或通过学习音频内容与标签之间的关系进行自动标注.音乐标签除了检索特定要求的音乐,还有很多应用,如建立语义相似的歌唱播放列表(Playlist)、音效(Sound Effect)库管理、音乐推荐等[284].
用户人工标注通常采用有趣的游戏方式,如文献[285]中的“Herd It”.用机器自动标注通常使用机器学习方式.文献[286]采用梅尔尺度频谱图(Mel-spectrogram)作为进行自动标注的一个有效的时频表示,使用完全卷积网络(Fully Convolutional Neural Networks, FCNNs)进行基于内容的音乐自动标注.采用更多的层数和更多的训练数据会得到更好的结果.
鉴于待标注的标签内容本身无法确定[287](包括音乐情感、歌手、乐手、流派、乐器、语言、音色、声部、场景、风格、年代、唱片公司、歌词主题、流行度、民族、乐队、词曲作者等无法穷尽的描述),对于海量数据也很难采用人类专家之外的客观评价,目前该类方法还处于不是很有效的状态.
音乐标注(Music Annotation/Tagging/Labelling)的主要挑战是如何减少人类劳动并建立可靠的分类标签.一个经典的方法是利用主动学习进行自动标注,即选择少数最有信息量的样本进行人工标注并加入到训练集.对于二类分类问题,倾向于在每次迭代中选择单个的未标注样本.主动学习的问题是在每次标注样本后都要重新训练,很容易使用户失去耐心.文献[288]提出一个新的多类主动学习(Multi-class Active Learning)算法,在每个循环选择多个样本进行标注.实现中需要注意减少冗余,避免选择异常点,以使每个样本为模型的改进提供独特的信息.
2.7.3 歌声与歌词同步
在一个制作优良的电影电视、卡拉OK或音乐电视(Music TV, MTV)节目中,歌手演唱的声音、歌手的口型(Mouth Shapes)、屏幕显示的歌词这三者之间必须保持同步,否则将严重影响观众的欣赏质量.三者同步涉及视频、音频、文本之间的跨媒体(Cross-media)研究,目前在文献中尚未发现完整的工作,仅有少量研究集中于歌声与歌词之间的同步(Singing/Lyrics Synchronization).
文献[289-290]设计了一个叫做LyricAlly的系统,将歌唱的声音信号与对应的文本歌词自动进行时间配对对齐.音频处理部分结合低层音频特征和高层音乐知识来确定层次性的节奏结构和歌声部分.文本处理部分使用歌词来近似得到歌唱部分的长度.文献[291]改进了LyricAlly系统,把行级别(Line-level)的对齐改进到音节级别(Syllabic-level)的对齐,该方法同样使用动态规划,但是使用音乐知识来约束动态规划的路径搜索.
在语音信息处理技术中,使用Viterbi方法可以有效地对齐单声部/单音语音和相应的文本.但是,该方法却不能直接应用于CD录音进行音乐信号和相应歌词之间的自动对齐,因为歌声几乎都是和乐器伴奏混杂在一起.为解决该问题,文献[292]首先检测歌声部分并进行分离,之后对分离的歌声采用语音识别中的音素模型(Phoneme Model)识别发声单元,再与文本对齐.文献[293-294]采用了一系列措施对以上基于Phoneme的模型进行改进: 包括将歌声元音(Singing Vowels)和歌词的音素网络(Phoneme Network)对齐;检测音频中摩擦辅音(Fricative Consonant)不存在的地方,阻止歌词中的摩擦音素(Fricative Phonemes)对齐到这些区域;忽略乐句之间(Inter-phrase)不属于歌词的元音发音;引入新的特征矢量进行歌声检测.文献[295]提出一个基于信号处理而不是模型的有趣方法.该方法首选使用文本到语音(Text-To-Speech,TTS)转换系统将歌词合成为语音,这样将音乐与文本歌词的自动对齐问题转化为两个音频信号之间的对齐问题,在词(Word)级别上进行.
传统的MIR并不包括算法作曲、歌声合成、音视频融合、音频信息安全等内容.但我们考虑到MIR本身也是处于不断进化的过程,将音频音乐技术领域里其他十分重要的算法作曲、歌声合成、音视频融合,甚至音频信息安全等内容纳入到扩展的MIR范畴将会是未来的发展趋势.
2.8.1 自动/算法/AI作曲
世界上的音乐,无论东方还是西方,均可以进行一定程度的形式化表示[296].这为引入计算机技术参与创作提供了理论基础.自动作曲(Automated Composition)也称算法作曲(Algorithmic Composition)或人工智能作曲(AI Composition),就是在音乐创作时部分或全部使用计算机技术,减轻人(或作曲家)的介入程度,用编程的方式来生成音乐.研究算法作曲一方面可以让我们了解和模拟作曲家在音乐创作中的思维方式,另一方面创作的音乐作品同样可以供人欣赏.
AI和艺术领域差距巨大,尤其在中国被文理分割得更为厉害.两个领域的研究者说着不同甚至非常不同的语言,使用不同的方法,目标也各不相同,在合作和思想交换上产生巨大困难[297].自动作曲研究中存在的主要问题有: 音乐的知识表达问题,创造性和人机交互性问题,音乐创作风格问题,以及系统生成作品的质量评估问题.
自从20世纪50年代,AI领域的不同技术已经被用来进行算法作曲.这些技术包括语法表示(Grammatical Representations)、概率方法(Probability Method)、人工神经网络、基于符号规则的系统(Symbolic Rule-based Systems)、约束规划(Constraint Programming)和进化算法(Evolutionary Algorithms)、马尔科夫链(Markov Chains)、随机过程(Random Process)、基于音乐规则的知识库系统(Music-rule based Knowledge System)等[298].算法作曲系统将受益于多种方法融合的混合型系统(Hybrid System),而且应在音乐创作的各个层面提供灵活的人机交互,以提高系统的实用性和有效性.
下边举一些有趣的例子.文献[299]提供一个交互式终端用户接口环境,可以实时对声音进行参数控制,从而使用进化计算(Evolutionary Computation)进行算法作曲,用遗传算法(Genetic Algorithms)来产生和评价MIDI演奏的一系列和弦.文献[300]从一段文本或诗歌出发,给每个句子分配一个表示高兴或悲伤的情绪(Mood),使用基于马尔科夫链的算法作曲技术来产生具有感情的旋律线,然后采用某些歌声合成软件如Vocaloid进行输出.马尔科夫链的当前状态只与前一个状态有关,而旋律预测有较长的历史时间依赖性,因此该方法具有先天不足.如何设计一个既容易训练又能产生长期时域相关性的算法作曲模型成为一个大的挑战.文献[301]利用最新的深度学习技术,即深度递归神经网络(RNN)的加门递归单元(Gated Recurrent Unit, GRU)网络模型,在一个大的旋律数据集上训练,并自动产生新的符合训练旋律风格的旋律.GRU尤其善于学习具有任意时间延迟的复杂时序关系的时间域序列,该模型能并行处理旋律和节奏,同时模拟它们之间的关系.该模型能产生有趣的完整的旋律,或预测一个符合当前旋律片段特性的可能的后续片段.
2.8.2 歌声合成
歌声本质上也是语音,所以歌声合成技术(Singing Voice Synthesis, SVS)的研究基本沿着语音合成(Speech Synthesis)的框架进行.语音合成的主要形式为文本到语音的转换.歌声则更加复杂,需要将文本形式的歌词按照乐谱有感情,有技巧的歌唱出来.因此,歌声合成的主要形式为歌词+乐谱到歌声(Lyrics+Score to Singing, LSTS)的转换.歌声和语音在发音机制、应用场景上有重大区别,歌声合成不仅需要语音合成的清晰性(Clarity)、自然性(Naturalness)、连续性等要求,而且要具备艺术性.
歌声合成涉及音乐声学、信号处理、语言学(Linguistics)、人工智能、音乐感知和认知(Music Perception and Cognition)、音乐信息检索、表演(Performance)等学科.在虚拟歌手、玩具、练唱软件、歌唱的模拟组合、音色转换、作词谱曲、唱片制作、个人娱乐、音乐机器人等领域都有很多的应用.
跟语音合成类似,歌声合成早期以共振峰参数合成法为主.共振峰(Formant)是声道(Vocal Tract)的传输特性即频率响应(Frequency Response)上的极点(Pole),歌唱共振峰通常表现为在3kHz左右的频谱包络线上的显著峰值.共振峰频率的分布决定语音/歌声的音色.以具有明确物理意义的共振峰频率及其带宽为参数,可以构成共振峰滤波器组,比较准确地模拟声道的传输特性.精心调整参数,能合成出自然度较高的语音/歌声.共振峰模型的缺点是,虽然能描述语音/歌声中最重要的元音,但不能表征其他影响自然度的细微成分.而且,共振峰模型的控制参数往往达到几十个,准确提取相当困难.因此共振峰参数合成法整体合成的音质达到实用要求还有距离[302].由上可知,高质量的估计声道过滤器(Vocal Tract Filter, VTF)即谱包络线的共振态/反共振态(Resonances/Anti-resonances)对歌声合成非常有益.已有算法经常使用基于单帧分析(Single-Frame Analysis, SFA)的离散傅里叶变换(Discrete Fourier Transform, DFT)来计算谱包络线.文献[303]将多帧分析(Multiple-Frame Analysis, MFA)应用于音乐信号的VTF构型的估计.一个具有表现力(Expressive)的歌手,在歌唱过程中利用各种技巧来修改其歌声频谱包络线.为得到更好的表现力和自然度,文献[304]研究共振峰偏移(Formant Excursion)问题,用元音的语义依赖约束共振峰的偏移范围.
与上述基于对发声过程建模的方法不同,采样合成/波形拼接合成(Sampling Synthesis/Concatenated-based Singing Voice Synthesis)技术从歌声语料库(Singing Corpus)中按照歌词挑选合适的录音采样,根据乐谱及下文要求对歌声的音高、时长进行调整,并进行颤音、演唱风格、情感等艺术处理后加以拼接.该方法使得合成歌声的清晰度和自然度大大提高,但需要大量的时间和精力来准备歌声语料库,而且占用空间很大.这类方法也称为基音同步叠加(Pitch Synchronous Overlap Add, PSOLA),以下列举几个例子.
基于西班牙巴塞罗那UPF大学MTG与日本雅马哈(Yamaha)公司联合研制的Vocaloid歌声合成引擎,第三方公司出品了风靡世界的虚拟歌唱软件——初音未来.该系统[305]事先将真人声优的歌声录制成包含各种元音、辅音片段的歌声语料库,包括目标语言音素所有可能的组合,数量大概是2000个样本/每音高.用户编辑输入歌词和旋律音高后,合成引擎按照歌词从歌声语料库中挑选合适的采样片段,根据乐谱采用频谱伸缩方法(Spectrum Scaling)将样本音高转换到旋律音高,并在各拼接样本之间进行音色平滑.样本时间调整自动进行,以使一个歌词音节的元音Onset严格与音符Onset位置对齐.文献[306]采用类似思路,在细节上稍有不同,而是采用重采样的方法进行样本到旋律的音高转换,基于基音周期的检测算法扩展音长.
与早期主要基于信号处理的方法不同,后期的歌声合成算法大量使用机器学习技术.基于上下文相关HMM(Context-dependent HMM)的歌声合成技术一度成为主流,用其联合模拟歌声的频谱、颤音、时长等[307].近年来,随着深度学习的流行,更适合刻画复杂映射关系的DNN技术被引入到歌声合成中.文献[308]用DNN逐帧模拟乐谱上下文特征(Contextual Features)和其对应声学特征之间的关系,得到比HMM更好的合成效果.文献[309]采用了另一种方法,没有用DNN直接模拟歌声频谱等,而是以歌词、音高、时长等为输入端,用HMM合成歌声和自然歌声的声学特征的区别为输出端,在它们之间用DNN模拟复杂的映射关系.歌唱是一种艺术,除了保持最基本的音高和节奏准确,还有很多艺术技巧如Vibrato、滑音等.这些技巧表现为歌声基频包络线(f0Contour)的波动,充分反映了歌手的歌唱风格.文献[310]使用深度学习中的LSTM-RNN模型来模拟复杂的音乐时间序列,自动产生f0序列.以乐谱中给定的音乐上下文和真实的歌声配对组成训练数据集,训练两个RNN,根据音乐上下文分别学习f0的音高和Vibrato部分,并捕捉人类歌手的表现力(Expressiveness)和自然性.对于一个乐谱来说,可能有很多风格迥异的歌唱版本,目前的歌声合成算法只能集中于模拟特定的歌唱风格.文献[311]首先从带标注的实际录音中提取f0参数和音素长度,结合丰富的上下文信息构建一个参数化模板数据库.然后,根据目标上下文选择合适的参数化模板,进行具有某种歌唱风格的歌声合成.
除了以上歌词+乐谱到歌声的转换,还有一类语音+乐谱到歌声的转换,即语音到歌声转换(Speech-To-Singing Conversion, STSC).这是在两个音频信号之间的转换,避免了以前声道特性估计不准或需要预先录制大规模歌唱语料库的困难,开辟了一条新的思路.文献[312]提出了一个简单的语音到歌声转换算法.首先分割语音信号,得到一系列语音基本单元.之后确定每个基本单元和对应音符之间的同步映射,并根据音符的音高对该单元的基频进行调整.最后根据对应音符的时长调整当前语音基本单元的长度.文献[313]采用类似思路,但是对用户输入进行了一定约束.输入的语音信号是用户依据歌曲的某段旋律(如一个乐句),按照节拍诵读或哼唱歌词产生的.因此每段语音信号可以更准确地在时间上对应于该旋律片段.后续处理包括按旋律线调整语音信号的音高,按音符时长进行语音单元时间伸缩,平滑处理音高包络线,加入颤音、滑音、回声等各种艺术处理.文献[314]设计了一个新的歌声合成系统“SingBySpeaking”,输入信息为读歌词的语音信号和乐谱,并假设已经对齐.为构造听觉自然的歌声,该系统具有3个控制模块: 基频控制模块,按照乐谱将语音信号的f0序列调整为歌声的f0包络线,同时调整颤音等影响歌声自然度的f0波动;谱序列控制模块,修改歌声共振峰并调制共振峰的幅度,将语音的频谱形状(Spectral Shapes)转换为歌声的频谱形状;时长控制模块,根据音符长度将语音音素的长度伸缩到歌声的音素长度.频谱特征可以直接反映音色特性,f0包络线、音符时长以及强弱(Dynamics)等组成韵律特征(Prosodic Features)反映时域特性.为得到高自然度的歌声合成,文献[315]使用适于模拟高维特征的DNN对这些特征进行从语音到歌声的联合模拟转换.
2.8.3 听觉与视觉的结合
人类接收信息的方式主要来源于视觉和听觉,现代电影和电视节目、多媒体作品几乎都是声音、音乐、语音和图像、视频的统一.绝大多数视频里都存在声音信息,很多的音乐节目如音乐电视里也存在视频信息.音视频密不可分,互相补充,进行基于信息融合的跨媒体研究对很多应用场景都是十分必要的.下边列举一些音视频结合研究的例子.
音乐可视化(Music Visualization)是指为音乐生成一个能反映其内容(如旋律、节奏、强弱、情感等)的图像或动画的技术,从而使听众得到更加生动有趣的艺术感受.早期的音乐播放器基于速度或强度变化进行简单的音乐可视化,在速度快或有打击乐器的地方,条形图或火焰等图形形状会跳得更快或更高.Herman等提出的音乐可视化理论[316]假定音高和颜色之间具有一定的关系,基于此理论使用光栅图形学(Raster Graphics)来产生音符、和弦及和弦连接的图形显示.音符或和弦的时域相邻性被映射为颜色的空间临近性,经常显示为按中心分布的方块或圆圈.电影是人类历史上最重要的娱乐方式之一,是一种典型的具有艺术性的音视频相结合的媒体.相比于早期的无声电影,在现代电影中声音和音乐对于情节的铺垫、观众情绪的感染、整体艺术水平的升华起到了无可替代的作用.文献[317]基于视频速度(Video Tempo)和音乐情感(Music Mood)进行电影情感事件检测,并对声音轨迹的进程进行了可视化研究.文献[318]结合MIR中的节拍检测和计算机视觉技术,融合音视频输入信息对机器人音乐家和它的人类对应者的动作进行同步.文献[319]分别计算图片和音乐表达的情感,对情感表达相近的图片和音乐进行匹配,从而自动生成基于情感的家庭音乐相册(如婚礼的图片搭配浪漫的背景音乐).文献[320]将音视频信息结合进行运动视频的语义事件检测(Semantic Event Detection),以方便访问和浏览.该文定义了一系列与运动员(Players)、裁判员(Referees)、评论员(Commentators)和观众(Audience)高度相关的音频关键字(Audio Keywords).这些音频关键字视为中层特征,可以从低层音频特征中用SVM学习出来.与视频镜头相结合,可有效地用HMM进行运动视频的语义事件检测.此外,还有电影配乐、MTV中口型与歌声和歌词同步等有趣的应用.
2.8.4 音频信息安全
音频信息安全(Audio Information Security)主要包括音频版权保护(Audio Copyright Protection)和音频认证(Audio Authentication)两个子领域.核心技术手段为数字音频水印(Digital Audio Watermarking)和数字音频指纹.音频水印是一种在不影响原始音频质量的条件下向其中嵌入具有特定意义且易于提取的信息的技术.音频指纹技术的细节可参照2.5.1节,本部分主要介绍数字音频水印技术.
2.8.4.1 音频版权保护
数字音频作品(通常指音乐)的版权保护主要采用鲁棒数字音频水印(Robust Audio Watermarking)技术.除了版权保护,鲁棒音频水印还可用于广播监控(Broadcast Monitoring)、盗版追踪(Piracy Tracing)、拷贝控制(Copy Control)、内容标注(Content Labeling)等.它要求嵌入的水印能够经受各种时频域的音频信号失真[321].鲁棒数字音频水印技术按照作用域可分为时间域和频率域算法两类.时域算法鲁棒性一般较差.频域算法充分利用人类听觉特性,主流思路是在听觉重要的中低频带上嵌入水印,从而获得对常规信号失真的鲁棒性.
早期的鲁棒音频水印算法主要集中于获得嵌入水印的不可听性(Inaudibility)或称感知透明性(Perceptual Transparency),和对常规音频信号处理失真(如压缩、噪声、滤波、回声等)的鲁棒性.如文献[322]把音频切成小片段,直接修改音频样本进行水印嵌入.水印按照音频内容被感知塑形(Perceptually-shaped),利用时域和频域感知掩蔽(Temporal and Frequency Perceptual Masking)来保证不可听性和鲁棒性.文献[323]将通信系统中借鉴来的直接序列扩频(Direct Sequence Spread Spectrum, DSSS)思想成功应用于数字水印技术中.将一个数字水印序列与高速伪随机码相乘后叠加到原始音频信号上,并利用人类听觉系统(Human Auditory System, HAS)的掩蔽效应(Masking Effect)进一步整形水印信号以保证其不可听到.为在感知质量(Perceptual Quality)、鲁棒性(Robustness)、水印负载(Watermark Payload)等相互冲突的因素中间达到平衡,文献[324]根据音频信号的内容进行自适应的水印嵌入,将一些低层音频特征用PCA(Principal Component Analysis)提取主成分后,使用数学模型来评价在感知透明性约束下的水印嵌入度.水印自适应地嵌入到小波域的第三层细节系数(Detailed Coefficients).
常规的音频信号失真主要通过降低音频质量来消除水印,这个问题很快被解决.后来的挑战主要集中于抵抗时频域的同步失真(Synchronization Distortions).这种失真通过对时频分量的剪切、插入等操作,使水印检测器(Watermark Detector)找不到水印的嵌入位置,从而使检测失败.抵抗同步失真主要有穷举搜索(Exhaustive Search)、同步码(Synchronization Code)、恒定水印(Invariant Watermark)和隐含同步(Implicit Synchronization)等4种方法[325].后两种方法因为明确地利用了音频内容分析,与之前将水印嵌入到时间域样本或频率域变换系数的算法不同,被称为第二代数字水印(Second-generation Digital Watermarking)技术[326].文献[327]基于恒定水印的思想,提出一种第二代数字音频水印算法,即通过调整音频信号每个帧的小波域系数平均值的符号来嵌入水印数据,从而使水印检测器对同步结构的变化不敏感.文献[328]基于隐含同步的思想,提出基于音乐内容分析的局部化数字音频水印算法.通过3种不同方法提取出代表音乐边缘(Music Edges)的局部区域,利用其感知重要性和局部性获得对信号失真和同步失真的免疫力(Immunity),然后通过交换系数法在其中嵌入水印.类似地,文献[329]基于音频内容分析和傅里叶变换,在时频域能量峰值点周围的ROI(Region of Interest)区域进行水印嵌入,以抵抗音频编辑和恶意随机剪切(Malicious Random Cropping)引起的同步失真.
除了音频水印,2.5.1节所述的音频指纹技术也可以用于版权保护.因其不需要往信号里加入额外信息,也称为被动水印(Passive Watermarking)技术.此外还有一些别名,如音频鲁棒感知哈希(Audio Robust Perceptual Hashing)、基于内容的数字签名(Content-based Digital Signatures)、基于内容的音频识别(Content-based Audio Identification)等.
2.8.4.2 音频认证
音频伪造(Audio Forgery)在当今的数字音频时代已经变得极其容易.对于重要录音信息(比如电话交谈的金融信息、领导人讲话、军事指令、时间地点等)进行恶意篡改(Malicious Tampering),或插入虚假信息,删除关键片段,制造虚假质量(Fake Quality)的音频等都会给政治、经济、军事、法律、商业等各个领域带来极大的影响.
脆弱及半脆弱数字音频水印(Fragile/Semi-fragile Audio Watermarking)主要用于数字音频作品的真实性(Authenticity)和完整性(Integrity)保护.脆弱水印在宿主数据发生任何变化时都会无法检测到,类似于密码学里的哈希值,典型的例子如LSB(Least Significant Bit)方法[330].半脆弱水印则融合了鲁棒水印与脆弱水印的特性,在能够抵抗有损压缩、噪声、滤波、重采样等可允许操作(Acceptable/Admissible Operations)的同时,对剪切、插入、替换等恶意操作(Malicious Operations)敏感[331].水印需要逐段嵌入,以便于在发生恶意操作时进行定位.基于水印的音频认证需要嵌入水印信息,也称为主动音频认证(Active Audio Authentication).
但是,在现实应用场景中,给所有的音频内容都预先嵌入水印是不可能的.因此,利用被动音频认证(Passive Audio Authentication),也称为音频取证(Audio Forensics),具有更大的应用前景.音频取证的基本方式包含听觉测试(Listening Test)、频谱图分析(Spectrogram Analysis)和频谱分析(Spectrum Analysis)等.高级方式利用音调(Tones)、相位、ENF(Electric Network Frequency)、LPCs、MFCCs、MDCT等各种音频特征及机器学习方法进行判断[332].文献[333]基于音频特征及朴素贝叶斯(Naïve Bayes)分类器确定数字音频使用的麦克风和录音环境.文献[334]在MP3格式的音频中发现,从低比特率(Low Bit-rate)转码得到的虚假高比特率(High Bit-rate)的MP3比正常MP3有更少的小数值MDCT系数.因此,小数值MDCT系数的个数可作为一个有效的特征来区分虚假质量MP3和正常质量MP3.
由于音频信号可能很长,有时需要判断其中的某一段是否被恶意篡改过,称为片段认证(Fragment Authentication)问题.文献[335]第一次提出一个解决方法,在音频频谱图上计算来自计算机视觉的SIFT描述子,利用其强大的局部对齐能力将待认证片段对齐到原始音频的相应位置,通过音频指纹比对检测可允许操作和恶意操作,精确进行篡改定位及分类.该方法需要保留原始音频,具有较大的局限性.
基于内容的音乐信息检索以数字音乐为研究对象,覆盖几乎一切与数字音乐内容分析理解相关的研究课题,是多媒体、信号处理、人工智能、音乐学相结合的重要学科分支.相似的技术框架扩展到一般音频后,统称为计算机听觉,也可称为音频与音乐计算.从学科角度讲,计算机听觉与语音信息处理最为相关,而且都以物理声学为基础.
本文介绍了音乐信息检索技术的发展历史、学科架构,将几十个研究课题按照与各音乐要素的紧密程度分类归入核心层与应用层.对每个研究课题,概述其研究目的和应用场景,总结主要的技术框架及典型算法.
与自然语言处理、计算机视觉、语音信息处理等相关领域相比,计算机听觉在国内外发展都比较缓慢.几个可能的原因包括: (1) 数字音乐涉及版权问题无法公开,各种音频数据都源自特定场合和物体,难以搜集和标注.近20年来,计算机听觉跟其他学科一样,绝大多数方法都是基于机器学习框架.数据的获取及公开困难严重影响了算法的研究及比较.(2) 音乐和音频信号几乎都是多种声音混合在一起,很少有单独存在的情况.音乐中的各种乐器和歌声在音高上形成和声,在时间上形成节奏,耦合成多层次的复杂音频流,难以甚至无法分离处理.(3) 计算机听觉几乎都是交叉学科,进行音乐信息检索研究需要了解最基本的音乐理论知识,进行音频信息处理则需要了解相关各领域的专业知识和经验.(4) 此外,作为新兴学科,还存在社会发展水平、科研环境、科技评价、人员储备等各种非技术类原因阻碍计算机听觉技术的发展.
MIR在娱乐、音乐教学、心理疏导、医学辅助治疗、公共及家庭环境监控、目标检测识别、智能交通、设备故障检测等方面具有很多应用,而且理论上所有视频应用都需要和音频结合,是一门非常实用具有广阔前景的技术.
致谢: 感谢4位匿名审稿人和北京大学陈晓鸥教授提出的宝贵修改意见!