声纹识别
更新时间:2024-01-28 20:42:01 阅读量: 教育文库 文档下载
声 纹 识 别
25组
摘要
随着信息技术的发展,人们的交互手段越来越多样化,对身份鉴别的要求随之越来越高,生物认证技术基于人们自身的生理和行为特征进行身份鉴别,以其独特的优势,日益显示出它的价值。声纹识别技术,又称说话人识别技术(Speaker Recognition),被认为是最自然的生物认证技术,它是一项通过语音信号提取代表说话人身份的相关特征(如反映声门开合频率的基频特征、反映口腔大小形状及声道长度的频谱特征等),进而识别出说话人身份等工作方面的技术。近年来,声纹识别技术己成为研究领域的一大热点与此同时,这一技术也存在着许多问题,集中于怎样从语音信号中提取尽量多与身份相关且比较稳定的特征信息(声纹特征会受到说话人的身体状况、说话的方式、录音信道及环境噪音的干扰而波动),以及怎样进行改进特征提取的方法,使其针对现有的特征能得到更好的识别结果。它可以广泛应用于国家安全、刑侦、电话银行、智能门禁及娱乐增值等领域。
针对第一问我们我们采用文本相关数据,在matlab环境中建立MFCC模型,首先使用wavread(file)函数读入,然后以帧长256,帧移80进行分帧。接着由语句x=filter([1-0.9375],1,x)实现对高频的加重处理,滤除低频干扰,特别是50Hz到60Hz的工频干扰,对语音识别更为有用的高频部分进行频谱提升。接着,为了保持语音信号的短时平稳性,利用汉明窗函数来减少由截断处理导致的Gibbs效应。最后提取出声音信号中的采样值,频率和采样位数。
针对第二问我们首先采用双门限的算法端点检测vad(x),然后采用MFCC参数算法mfcc(x):输入为采样语音数据x,输出为mfcc参数,接着HMM参数初始化inithmm(samples,M),最后之别主程序显示出识别结果。
针对第三问我们通过LPC分析,得出最小的?可表示成:
?min???0,0???ak??0,k?k?1p (6)
显然,误差越接近于零,线性预测的准确度在均方误差最小的意义上为最佳,由此可以计算出预测系数。
最后我们根据上述分析得出改进办法。
关键词:MFCC HMM MATLAB 双门限的算法端点检测
短时傅里叶
1
一·问题重现
生物认证是通过人体特征进行人物身份认证的重要手段,包括人脸识别、虹 膜识别、指纹识别、体态识别和声纹识别等方法,它们被广泛地应用于国防、军 事和民用等诸多领域,推动着信息产业的蓬勃发展。
声纹识别又称说话人识别,是通过分析说话人的语音的特点,利用计算机自 动识别说话人的身份。声纹识别又分为文本相关和文本无关说话人的识别两大类。文本无关是指说话人的说话内容不受限制,文本相关是指说话人的说话内容必须是指定的内容。
评价声纹识别方法或模型的最重要指标是识别准确率,准确率越高越宜于应 用于实际。评价的另外一个重要指标就是识别所花的时间,即输入待识别的说话 人语音到识别结果的输出说话的时间,该时间越短约好。
试着利用采集到的说话人语音数据(文本相关和文本无关两类,见附录一),完成以下几点:
1)建立代表说话人身份的语音特征模型,通过编程从语音数据中提取说话 人特征;
2)利用说话人特征建立说话人模型或声纹识别模型;
3)利用语音数据评价你的说话人模型或声纹识别模型评价的好坏;
4)分析影响准确率的因素,采取措施进一步提高声纹识别的准确率。
2
二· 问题分析
2.1 问题一
问题一要求建立代表说话人身份的语音特征模型,通过编程从语音数据中提取说话人特征。我们采用文本相关数据,在matlab环境中建立MFCC模型,首先使用wavread(file)函数读入,然后以帧长256,帧移80进行分帧。接着由语句x=filter([1-0.9375],1,x)实现对高频的加重处理,滤除低频干扰,特别是50Hz到60Hz的工频干扰,对语音识别更为有用的高频部分进行频谱提升。接着,为了保持语音信号的短时平稳性,利用汉明窗函数来减少由截断处理导致的Gibbs效应。最后提取出声音信号中的采样值,频率和采样位数。
2.2 问题二
问题二要求利用说话人特征建立说话人模型或声纹识别模型。
(1)端点检测vad(x):采用双门限的算法。输入为采样语音数据x,输出X1, X2是起始端点和结束端点的帧数,并将xi到x2帧的语音数据存sample(k).wave结构数组中。
(2)MFCC参数算法mfcc(x):输入为采样语音数据x,输出为mfcc参数,取x1—2至x2—2帧的mfcc参数到sample(k).data结构数组中。
(3)HMM参数初始化inithmm(samples,M):输入为samples和NX*1的数组M,N为状态数,M是每个状态包含的高斯混合个数。
(4)viterbit识别算法:输入删模型和mfcc参数,回溯最佳状态路径,返回输出概率和状态路径。
(5)训练过程train(sample,M):对一次迭代函数baum.m实施n次迭代(设 置迭代次数)。输出为训练后的HMM模型参数和总输出概率,将模型参数存入 hmm{i}(hmm为一个cell数组)。
(6)识别主程序(recog):对输入待识别的语音用函数vad进行端点检测, 计算出MFCC参数之后,交由识别函数viterbi.m计算得到其对数形式的输出概率,最后显示出识别结果。
2.3 问题三
问题三要求利用语音数据评价你的说话人模型或声纹识别模型评价的好坏。 通过LPC分析,由若干帧语音可以得到若干组LPC参数,每组参数形成一个描绘该帧语音特征的矢量,即LPC特征矢量。由LPC特征矢量可以进一步得到很多种派生特征矢量,例如线性预测倒谱系数、线谱对特征、部分相关系数、对数面积比等等。不同的特征矢量具有不同的特点,它们在语音编码和识别领域有着不同的应用价值。
LP分析为线性时不变因果稳定系统V(z)建立一个全极点模型,并利用均方误差准则,对已知的语音信号s(n)进行模型参数估计。
如果利用P个取样值来进行预测,则称为P阶线性预测。假设用过去P个取样
3
值
?S?n?1?,S?n?2?,S?n?p??Sn的加权之和来预测信号当前取样值??。最小的?可
表示成:
?min???0,0???ak??0,k?k?1p (6)
显然,误差越接近于零,线性预测的准确度在均方误差最小的意义上为最佳,由此可以计算出预测系数。
2.4 问题四
问题四要求分析影响准确率的因素,采取措施进一步提高声纹识别的准确率。MFCC的分析着眼于人耳的听觉特性,Mel频率尺度的值大体上对应于实际频率的对数分布关系,更符合人耳的听觉特性,MFCC参数突出优点是不依赖极点语言产生模型的假定,考虑了人耳的听觉感知特性,抗噪声和抗频谱失真能力较强,从而提高识别系统的性能。
4
三· 模型假设
1、 假设语音信号都在同一理想状态下录制,其声纹特征不受录音信道及
环境噪音的干扰而波动。
2、 假设从语音信号中提取出的多为与身份相关且比较稳定的特征信息
3、 假设对说话人进行声纹识别时说话人的身体状况、说话的方式等与录
入时无区别。
5
四·符号说明
En:短时能量;
S?n?:信号当前取样值;
?S?n?:预测信号
ak:加权系数;
e?n?:预测误差;
?:平均预测误差;
min:最小平均预测误差;
Mel(f):梅尔頻率;
fs:声纹频率;
ccc:mfcc参数;
dtm:一阶差分参数;
6
?
五·模型建立与求解
5.1 问题一 5.1.1 语音读入
我们采用文本相关数据,在matlab环境中建立MFCC模型,首先使用wavread(file)函数读入,如图1所示为数字0的训练语音00.wav的信号波形图,第(I)幅图为完整的语音波形,第(II)、(III)幅图分别为语音的起始部分和结束部分的放大波形图。
Amplitude(normalized)(I) “00.wav”语音信号波形10.50-0.500.10.20.40.5Time:s(II) “00.wav”语音起始处放大波形图0.30.60.70.8Amplitude(normalized)10.50-0.50.20.210.220.230.250.260.27Time:s(III) “00.wav”语音结束处放大波形图0.240.280.290.3Amplitude(normalized)10.50-0.50.40.410.420.430.440.45Time:s0.460.470.480.490.5
图1 语音001.wav的信号波形图
5.1.2 分帧
语音信号是一种典型的非平稳信号,它的均值函数u(x)和自相关函数R(xl,x2)都随时间而发生较大的变化[5,9]。但研究发现,语音信号在短时间内频谱特性保持平稳,即具有短时平稳特性。因此,在实际处理时可以将语音信号分成很小的时间段(约10~30ms[5,7]),称之为“帧”,作为语音信号处理的最小单位,帧与帧的非重叠部分称为帧移,而将语音信号分成若干帧的过程称为分帧。分帧小能清楚地描绘语音信号的时变特征但计算量大;分帧大能减少计算量但相邻帧间变化不大,容易丢失信号特征。一般取帧长20ms,帧移为帧长的1/3~1/2。 在Matlab环境中的分帧最常用的方法是使用函数enframe(x,len,inc),其中x为语音信号,len
7
为帧长,inc为帧移。在本系统中帧长取256,帧移取80。
5.1.3 高频加重处理
对于语音信号的频谱,通常是频率越高幅值越小,在语音信号的频率增加两倍时,其功率谱的幅度下降6dB。因此必须对高频进行加重处理,一般是将语音信号通过一个一阶高通滤波器1-0.9375z-1,即为预加重滤波器。其目的是滤除低频干扰,特别是50Hz到60Hz的工频干扰,将对语音识别更为有用的高频部分进行频谱提升。在计算短时能量之前将语音信号通过预加重滤波器还可起到消除直流漂移、抑制随机噪声和提升清音部分能量的效果。预加重滤波器在Matlab中可由语句x=filter([1-0.9375],1,x)实现。
5.1.4 加窗
由于语音信号的能量随时间变化,清音和浊音之间的能量差别相当显著。因此对语音的短时能量进行分析,可以描述语音的这种特征变化情况。定义短时能量为:
En?m????[x(m)w(n?m)]采样幅度?2?m?n?N?1?n[x(m)w(n?m)]2,其中N为窗长
10-102000400060008000sample1000012000140001600018000N=502000400060008000sample1000012000140001600018000N=1502000400060008000sample1000012000140001600018000N=2502000400060008000sample1000012000140001600018000N=3502000400060008000sample1000012000140001600018000N=4502000400060008000sample1000012000140001600018000短时能量短时能量短时能量短时能量短时能量21004200105001050010500
图2 不同hamming窗长的短时能量函数
最后提取出声音信号中的采样值,频率和采样位数。
8
5.2 问题二 5.2.1 设计方案
语音识别属于模式识别范畴,它与人的认知过程一样,其过程分为训练和识别两个阶段。 在训练阶段,语音识别系统对输入的语音信号进行学习。学习结束后,把学习内容组成语音模型库存储起来;在识别阶段,根据当前输入的待识别语音信号,在语音模型库中查找出相应的词义或语义。
语音识别系统与常规模式识别系统一样包括特征提取、模式匹配、模型库等3个基本单元,它的基本结构如图2所示
图3 语音识别系统基本结构图
本次设计主要是基于HMM模型(隐马尔可夫模型)。这是在20世纪80年代引入语音识别领域的一种语音识别算法。该算法通过对大量语音数据进行数据统计,建立识别词条的统计模型,然后从待识别语音信号中提取特征,与这些模型进行匹配,通过比较匹配分数以获得识别结果。通过大量的语音,就能够获得一个稳健的统计模型,能够适应实际语音中的各种突发情况。并且,HMM算法具有良好的识别性能和抗噪性能。
5.2.2方案框图
图4 HMM语音识别系统
9
5.2.3隐马尔可夫模型
HMM过程是一个双重随机过程:一重用于描述非平稳信号的短时平稳段的统计特征(信号的瞬态特征);另一重随机过程描述了每个短时平稳段如何转变到下一个短时平稳段,即短时统计特征的动态特性(隐含在观察序列中)。人的言语过程本质上也是一个双重随机过程,语音信号本身是一个可观测的时变列。可见,HMM合理地模仿了这一过程,是一种较为理想的语音信号模型。其初始状态概率向量π,状态转移概率矩阵向量A,以及概率输出向量B一起构成了HMM的3个特征参量。HMM 模型通常表示成λ={π,A,B}。
5.2.4HMM模型的三个基本问题
HMM模型的核心问题就是解决以下三个基本问题:
(1)识别问题:在给定的观测序列O和模型λ=(A,B,π)的条件下,如何有效地计算λ产生观测序列O的条件概率 P(O︱λ)最大。常用的算法是前后向算法,它可以使其计算量降低到N2T次运算。
(2)最佳状态链的确定:如何选择一个最佳状态序列Q=q1q2…qT,来解释观察序列O。常用的算法是Viterbi算法。
(3)模型参数优化问题:如何调整模型参数λ=(A,B,π),使P(O︱λ)最大:这是三个问题中最难的一个,因为没有解析法可用来求解最大似然模型,所以只能使用迭代法(如Baum-Welch)或使用最佳梯度法。
5.2.5系统框图
原始语音数据特征参数提取端点检测数据储存模型训练模型库识别结果识别
图5 系统整体结构框图
5.2.6 实施方案
实施方法及具体过程如下: (1)端点检测vad(x):采用双门限的算法。输入为采样语音数据x,输出X1,
10
X2是起始端点和结束端点的帧数,并将xi到x2帧的语音数据存sample(k).wave结构数组中。
(2)MFCC参数算法mfcc(x):输入为采样语音数据x,输出为mfcc参数,取x1—2至x2—2帧的mfcc参数到sample(k).data结构数组中。
(3)HMM参数初始化inithmm(samples,M):输入为samples和NX*1的数组M,N为状态数,M是每个状态包含的高斯混合个数。
(4)viterbit识别算法:输入删模型和mfcc参数,回溯最佳状态路径,返回输出概率和状态路径。
(5)训练过程train(sample,M):对一次迭代函数baum.m实施n次迭代(设 置迭代次数)。输出为训练后的HMM模型参数和总输出概率,将模型参数存入 hmm{i}(hmm为一个cell数组)。
(6)识别主程序(recog):对输入待识别的语音用函数vad进行端点检测, 计算出MFCC参数之后,交由识别函数viterbi.m计算得到其对数形式的输出概率,最后显示出识别结果。
5.3 问题三
5.3.1 LP分析基本原理
LP分析为线性时不变因果稳定系统V(z)建立一个全极点模型,并利用均方误差准则,对已知的语音信号s(n)进行模型参数估计。
如果利用P个取样值来进行预测,则称为P阶线性预测。假设用过去P个取样值
?S?n?1?,S?n?2?,?pS?n?p??的加权之和来预测信号当前取样值
S?n?,则预测信号
S?n??为:
S?n???ak?n?k?k?1 (1)
其中加权系数用ak表示,称为预测系数,则预测误差为:
e?n??s?n??S?n??s?n???ak?n?k?k?1?p (2)
要使预测最佳,则要使短时平均预测误差最小有:
2??E??e?n????min (3)
2???e?n????ak?0,(1?k?p) (4)
令
??i,k??E??s?n?i?,S?n?k??? (5)
最小的?可表示成:
11
?min???0,0???ak??0,k?k?1p (6)
显然,误差越接近于零,线性预测的准确度在均方误差最小的意义上为最佳,由此可以计算出预测系数。
通过LPC分析,由若干帧语音可以得到若干组LPC参数,每组参数形成一个描绘该帧语音特征的矢量,即LPC特征矢量。由LPC特征矢量可以进一步得到很多种派生特征矢量,例如线性预测倒谱系数、线谱对特征、部分相关系数、对数面积比等等。不同的特征矢量具有不同的特点,它们在语音编码和识别领域有着不同的应用价值。
5.4 问题四
与普通实际频率倒谱分析不同,MFCC的分析着眼于人耳的听觉特性,Mel频率尺度的值大体上对应于实际频率的对数分布关系,更符合人耳的听觉特性,MFCC参数突出优点是不依赖极点语言产生模型的假定,考虑了人耳的听觉感知特性,抗噪声和抗频谱失真能力较强,从而提高识别系统的性能。
但是在系统实时处理上,与LPCC参数相比,MFCC参数计算有两个缺点:一是计算量大,计算时间长,很难达到实时性;二是精度难以保证,由于MFCC参数的计算需要FFT变换和对数操作,影响了计算机的动态范围,要保证其在单片机或DSP平台上的运算速度,就只有牺牲参数精度。
目前声纹识别技术的识别率,T-NETIX公司的SpeakEZ达到94%-95%。日本岩井公司在此基础上研制的同类产品据称其识别率以达到99.8%。根据最近的报道,国内的北京得意音通技术有限责任公司开发的“得意”身份证开发工具据其自称辨认和确认准确度都可以到达接近100%。
12
六·附录
主程序: clc,clear
disp('正在计算参考模板的参数...') for i=1:10
fname=sprintf('01w.wma',i-1); x=wavread(fname); [x1 x2]=vad(x); m=mfcc(x);
m=m(x1-2:x2-4,:); ref(i).mfcc=m; end
disp('正在分析语音信号...') for i=1:10
fname=sprintf('01w.wma',i-1);
[x,fs,bit]=wavread(fname,[2000,2512]); %采样% %sound(x,fs); %播放语音信号 figure(i);
subplot(3,3,1);
plot(x(1:256)); %原始语音信号的时域图形% title('原始信号') subplot(3,3,2)
[h,w]=freqz(x); %原始语音信号的频率响应图 hr=abs(h); plot(w,hr);
title('频率响应图');
xlabel('Frequency in rad/sample') ylabel('Magnitude in dB') subplot(3,3,3) hphase=angle(h);
hphase=unwrap(hphase); %求系统相频响应 plot(w,hphase); title('频率响应图');
xlabel('Frequency in rad/sample') ylabel('Phase in degrees')
y=fft(x,512); %傅立叶变换% mag=abs(y);
mag1=10*log10(mag);
13
f=fs*(0:255)/512; subplot(3,3,4)
plot(f,mag(1:256)); ?T频谱图 % title('fft变换后信号')
iff=ifft(y,512); %反傅立叶变换% ifm=abs(iff); subplot(3,3,5) plot(f,ifm(1:256)) title('ifft后信号')
% 短时傅里叶变换 Ts=1/fs; %N=T/Ts; N=512;
Nw=20; %窗函数长
L=Nw/2; %窗函数每次移动的样点数
Tn=(N-Nw)/L+1; %计算把数据x共分成多少段 nfft=32; ?T的长度
TF=zeros(Tn,nfft); %将存放三维谱图,先清零 for i=1:Tn
xw=x((i-1)*10+1:i*10+10); %取一段数据 temp=fft(xw,nfft); ?T变换
temp=fftshift(temp); %频谱以0频为中心 for j=1:nfft;
TF(i,j)=temp(j); %把谱图存放在TF中 end end
subplot(3,3,6)
fnew=((1:nfft)-nfft/2)*fs/nfft; tnew=(1:Tn)*L*Ts;
[F,T]=meshgrid(fnew,tnew); mesh(F,T,abs(TF))
title('短时傅立叶变换时频图') subplot(3,3,7)
contour(F,T,abs(TF)) title('等高线表示') end
disp('正在计算测试模板的参数...') for i=1:10
fname=sprintf('01x.wma',i-1); x=wavread(fname); [x1 x2]=vad(x); m=mfcc(x);
14
m=m(x1-2:x2-4,:); test(i).mfcc=m; end
disp('正在进行模板匹配...') dist=zeros(10,10); for i=1:10 for j=1:10
dist(i,j)=dtw(test(i).mfcc,ref(j).mfcc); end end
disp('正在计算匹配结果...') for i=1:10
[d,j]=min(dist(i,:));
fprintf('测试模板%d的识别结果为:%d\\n',i-1,j-1); end
子程序: Vad.m
function [x1,x2]=vad(x) %幅度归一化到[-1,1] x=double(x); x=x/max(abs(x));
%常数设置 FrameLen=240; FrameInc=80;
amp1=10; amp2=2; zcr1=10; zcr2=5;
maxsilence=3; %3*10ms=30ms minlen=15; *10ms=150ms status=0; count=0; silence=0;
%计算过零率
tmp1=enframe(x(1:length(x)-1),FrameLen,FrameInc); tmp2=enframe(x(2:length(x)),FrameLen,FrameInc); signs=(tmp1.*tmp2)<0; diffs=(tmp1-tmp2)>0.02; zcr=sum(signs.*diffs,2);
15
%计算短时能量
amp=sum(abs(enframe(filter([1 -0.9375],1,x),FrameLen,FrameInc)),2);
%调整能量门限
amp1=min(amp1,max(amp)/4); amp2=min(amp2,max(amp)/8);
%开始端点检测 x1=0; x2=0;
for n=1:length(zcr) goto=0;
switch status
case{0,1} %0=静音,1=可能开始 if amp(n)>amp1 %确信进入语音段 x1=max(n-count-1,1); status=2; silence=0;
count=count+1;
elseif amp(n)>amp2 zcr(n)>zcr(2) %可能处于语音段 status=1;
count=count+1; else %静音状态 status=0; count=0; end
case 2, %2=语音段
if amp(n)>amp(2) zcr(n)>zcr(2) %保持在语音段 count=count+1; else %语音将结束 silence=silence+1;
if silence elseif count else %语音结束 status=3; end end case 3, break; end 16 end count=count-silence/2; x2=x1+count-1; mfcc.m function ccc=mfcc(x) %设定mel滤波器系数 bank=melbankm(24,256,8000,0,0.5,'m' ); bank=full(bank); bank=bank/max(bank(:)); %设定DCT系数 for k=1:12 n=0:23;dctcoef(k,:)=cos((2*n+1)*k*pi/(2*24)); end %设置归一化的倒谱提升窗口 w=1+6*sin(pi*[1:12]./12); w=w/max (w); %设置预加重滤波器 xx=double(x); xx=filter([1-0.9375],1,xx); %对语音信号进行分帧 xx=enframe(xx,hamming(256),80); %计算每帧的mfcc参数 for i=1:size(xx,1) y=xx(i,:); s=y'.*hamming(256); %对信号S进行m计算 t=abs(fft(s)); t=t.^2; %对fft参数进行mel滤波取对数再计算倒谱 c1=dctcoef*log(bank*t(1:129) ); c2=c1.*w' ; %mfcc参数 m(i,:) =c2'; end %计算mfcc参数的一阶差分 dtm=zeros(size(m)); for i=3:size(m,1)-2 dtm (i,:) =-2*m(i-2,:)-m(i-1,:) +m(i+1,:)+2*m(i+2,:); end dtm =dtm/3; %合并mfcc参数和一阶差分参数 ccc= [m dtm]; %去除首尾两帧,因为这两帧一阶差分参数为0 17 ccc=ccc(3:size(m,1)-2,:); dtw.m function dist=dtw(t,r) n=size(t,1); m=size(r,1); %帧匹配距离矩阵 d=zeros(n,m); for i=1:n for j=1:m d(i,j)=sum((t(i,:)-r(j,:)).^2); end end %累积距离矩阵 D=ones(n,m)*realmax; D(1,1)=d(1,1); %动态规划 for i=2:n for j=1:m D1=D(i-1,j); if j>1 D2=D(i-1,j-1); else D2=realmax; end if j>2 D3=D(i-1,j-2); else D3=realmax; end D(i,j)=d(i,j)+min([D1,D2,D3]); end end dist=D(n,m); 18 参考文献 [1]王炳锡.语音编码[M].西安:西安电子科技大学出版社,2002. [2]何强,何英.MATLAB扩展编程[M].北京:清华大学出版社,2002. [3]王炳锡,屈丹,彭煊.实用语音识别基础[M].北京:国防工业出版社,2005. [4]易克初,等.语音信号处理[M].北京:国防工业出版社,2006,6. [5]胡航.语音信号处理[M].哈尔滨:哈尔滨工业大学出版社,2000,5. [6]胡广书.数字信号处理理论、算法与实现[M].北京:清华大学出版社,1997. [7]王炳锡,等.实用语音识别基础[M].北京:国防工业出版社,2005. [8]林波,吕明.基于DTW改进算法的弧立词识别系统的仿真与分析[J].信息技术,2006,30(4):56-59. [9]韩纪庆,张磊,郑铁然.语音信号处理[M].北京:清华大学出版社,2004 [10]李晋.语音信号端点检测算法研究[D].长沙:湖南师范大学,2006. 19
正在阅读:
声纹识别01-28
VFP的发展03-19
关于商业银行合规管理工作05-03
一般增值税退税审批系统单机版08-14
OPERA 系统操作04-07
某国际物流城项目可行性研究报告03-01
2013年黄冈中考精典生物参考答案07-29
交通信号配时方案设计07-04
最新关于高跟鞋的心情说说02-08
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 识别
- 艾默生边际网UPS电源维护操作手册(精简版)
- 重大安全事故应急救援预案及重大危险源清单 - secret - 图文
- 如何在高中生物课堂进行情感教育
- 四川电网光伏发电并网运行服务指南 - 图文
- 高考数学常见题型汇总(精华资料)
- 国家检验检测机构资质认定管理办法(第163号)
- 新人教版数学六年级下册:《数与代数内容的复习》教学设计
- 重医细菌学检验复习题
- wto案例分析—欧盟对中国鞋业反倾销案 邓成艳
- 中国房地产开发商排名百强榜单
- 2017-2022年中国白铜行业监测及投资机遇研究报告 - 图文
- 云南省新型工业化重点产业发展规划纲要
- 文献检索平时作业答案带图(温医)
- 施工组织设计
- 企业档案管理的创新探索
- 武汉大学排球理论考试题库
- 全球沼气工程市场调研报告
- 《新编英语教程》第-3-册的课文
- 2019年二级建造师《建设工程施工管理》模拟试卷
- 各地古牌坊集锦 - 图文