|
很多人在选择独立/外置声卡的时候,都会听说过asio,那么为什么要选择带asio的声卡呢?
) I: K# e+ H# H
0 E5 z+ B: I% H4 R: r/ d; R) c0 J+ U! D) B
2 A. e; a1 r1 L% z一.延时是如何产生的?
7 X, _9 }. H3 p4 [( V7 u$ q
# Z; W5 F9 {( n0 x& p4 H
0 d- c8 \! {5 c' j, Z8 M
9 U4 t' l" {+ m# C8 \不管你有多么讨厌延时,只要你需要用到电脑来处理你的音频,那么就一定会存在延迟,这是你消灭不掉的,只不过你可以通过一些手段来降低它,以达到一个你所能接受的范围。但在这之前,我们有必要来看一下延时究竟是如何产生的:' e2 @4 E# _% T$ T
7 Z1 u8 W$ N% R' }3 x4 _
+ B, F' N1 `, O* |+ h) u3 K2 [& ?% H5 G
01 模拟信号到数字信号的转换
5 {: X$ U7 W2 V3 K3 g/ ~0 x
. ~3 U3 d$ q7 A* Q. ^2 b
# T9 O7 e3 z1 j8 u7 y% `
# N2 e0 b$ T* o1 y+ [2 I
8 T: y, @: T% y
1 N2 {0 h5 |3 a, Q9 E8 B4 h; t7 y现如今,没有人能绕开数字音频,你的电脑之所以能处理、存储你动人的歌声,是因为声卡(Audio Interface)将模拟信号转换成了数字信号。! P: M) k" j! h! B# \
9 M! E; ?: R, p- p0 m [) s8 [* R/ ~' x3 u9 j2 `
5 f- K( c) U4 ^7 T6 h# _
声卡将模拟信号转换成数字信号是需要时间的,这就产生了一处延时,只是这一个延迟相比后面来说很小,我们不需要过于纠结。
+ ^1 Y4 ^6 w" a C$ C$ K" t( L! g
# X/ C6 G9 d0 `+ W# b$ J& x% V
9 @8 S( U7 z: c" [02 声卡驱动
: W, Y' N( ^9 v9 L8 \
$ c2 R% i; P! j, \3 a f
$ w8 Z/ o7 Z" M& Z6 `0 s5 c% ?2 e7 i5 Q6 K/ R+ i; D
但接下来的这个环节所产生的延迟有时候会大到离谱,不能忽略,这个环节就是声卡驱动(Audio Drivers)所产生的延迟。) o+ f0 G- Q6 [+ Y
6 x* X; u9 T1 u6 G" E6 y4 {& x+ t0 ?3 A) A
7 Z) b, a$ s9 Y' X3 N9 m
如果你是Windows用户的话,那么你对ASIO(Audio Stream Input/Output)这个名词一定不陌生,事实上有相当多一部分的人之所以买人生中的一块外置声卡,就是因为主板上集成的声卡不支持基于ASIO协议的声卡驱动,只能使用默认的MME或者Direct X这样的驱动。+ {5 t9 l6 B/ G, z5 s
) `4 D0 w: C. W
% t8 ^4 F2 N/ m) B: Y& e4 v* I& R
$ L1 S- N" e9 J8 Q+ y1 v9 L" ?. {MME跟Direct X所带来的延时实在是太高了,动不动就上千毫秒的延时,可以说是完全不可用的。; ?7 a" ~' f8 Y# [& a
& L2 [ |+ d L& K7 |
% M" o3 a9 s' @4 o0 N- c& N2 V
: U+ t% _' ?1 V) {- s+ }而ASIO则可以极大地降低延迟,所以说如果你要用Windows做音乐的话,一个支持ASIO的声卡是必不可少的。实在没有办法你也应该下载一个ASIO4ALL驱动。2 \6 X* l+ B M$ `9 W4 [/ ?7 @7 s7 u
8 ^7 q7 n- m/ C6 u9 q5 y
' N" D' B$ h# w) i8 A
1 \) v: A9 r3 m, `) B7 B* Z0 S( D1 M
) ^! e% N8 X" l" B4 T& L: n& o, i4 F
但如果你是Mac用户,那么自带的Core Audio就能提供相当低的延迟,所以如果你实在没有买独立声卡的预算或者说出门在外不好带声卡的话,那么自带的声卡的延迟也是完全可以接受的。$ W3 X* q2 ]! y! ~
: j4 q* k2 Q4 J* o/ Y8 y
! W! v% j7 y; S4 k7 u03 音频缓冲区(Audio Buffer)
/ I0 ?( Y# B( O8 n T; b( O( F$ M. R0 U# N! @% e: ]; |: S
& d3 G/ x D! L- [. v9 c" A
* `# @) d- t1 k* n在解决了声卡驱动的问题之后,延迟主要就出现在接下来这一个部分。在上一篇文章中我就有提到缓冲区大小(Buffer Size),提到了当出现爆音时一个可以检查的就是缓冲区大小是否过小。# R+ i0 I& w# P, Y/ [
! M' _0 }0 p) A A. J - n2 z* H' h, |1 j6 d3 m1 O0 W8 g
- O6 L* H" `" P* _0 ?9 H3 Z3 T" U0 `
音频缓冲区(Audio Buffer)其实就是一个用来暂时存放音频信息的空间,其单位是采样(Samples),配合采样频率(Sample Rate)我们可以计算出它所产生的延时,其公式如下:音频缓冲产生的延时=缓冲区大小/采样频率
3 i* l" C- t* i1 H5 ?7 s j
E$ H- | F% f6 Y* Q" t% S+ k: |+ Z! d9 M5 R& s
* P) p; R( v/ I3 H5 h- g
" \4 t% |. v& v' J# `! t) Y! @' @ h$ V6 s6 A' \8 M& @7 y6 B0 G
以我自己的设置为例子,采样频率为48kHz,缓冲区大小为256 Samples,那么根据上面的公式就可以计算出由音频缓冲所产生的延时为5.33毫秒。4 b8 R( Y9 Y4 @8 _) k6 Y( t
. \6 ?. S0 J! t6 ^- d2 Q4 T. M! r! @; p
5 |/ L8 h* j A' [这相比于模数转换所产生的微秒甚至是纳秒级的延迟要大得多,但相比于MME与Direct X那几百毫秒的延迟来说又不算大,所以Windows用户拥有一块支持ASIO的声卡确实是非常有必要的。
, {2 Q. V9 V8 Z9 i" x7 z2 P. J. k' q# {, t+ E& U
/ f D+ G! o8 L- M$ ?
, {) z: s. F. X" K+ r) a6 Y04 音乐宿主软件中的效果器
) \+ R% M% Q# T5 M1 x; P9 a0 k% L8 u; l
4 h; K1 Q2 d; C" H0 x% I0 F, K! O) _
3 }9 W# e! y! |" O. @& d9 O& c" E
4 X! o* z. ?& m9 U
7 M/ i- p/ z N5 z6 E( ?
: z6 M' \: X: q: Q在Ableton中,只要你把鼠标停留在装置标题栏上就能看到它所引入的延时, Z6 W( @- Q5 C
A. b7 _( E6 U1 ~+ R0 h6 c3 e7 Q' I- g k% B+ r7 o+ O
最后一个可能会引入延迟的环节便是DAW处理音频的环节,虽然大部分的效果器都能在设定的缓冲区大小内完成音频的处理,但总有一些比较复杂的效果器它需要更多的处理时间。
4 @# v& m2 j; ]9 ~6 r( h
& v" t! c- u, [2 @7 m7 Y& y0 R, c7 l: w
; i8 u* m/ r! J& |* @
9 P9 n/ T4 o, t4 B: ~这些效果器会在原本延时的基础上引入额外的延时,比如Ableton自带的EQ Eight在默认的情况下并不会引入额外的延迟,但当你打开了超采样(Over Sampling)的话,情况就变了。
4 G. D; Q) U) {" s, G
B% Q" W7 v* w+ q& R& g- ^
" i$ l& @! Z" v3 D0 t
* I" U% B d/ j; I7 I; ~& S: ]& K
) c% Q7 B# [% a% L+ ^, j( _0 a z q9 T* B7 ]" s B0 S: D+ W
以上便是声音进入电脑CPU这个过程中会产生延时的地方,我们把这个延迟称为输入延迟(Input Latency),然而CPU处理完的音频信号也不是会立刻输出到你的耳朵里的,这期间仍然还有一个延迟叫做输出延迟(Output Latency),但它差不多是输入延迟的一个逆过程,这里就不再详细赘述了。
- y( \1 _! R. m' `, Y
( y3 G+ q' I, K9 ~4 g J. o6 O" R
' e* T+ O* N% _6 E
: j$ e. H0 f0 o输入延迟加上输出延迟就是总延迟(Overall Latency),这三个参数你都可以在宿主软件的设置页面看到,一般是在设置声卡的页面。
. ^- c3 x! w& \' x* f# r |
|