コグノスケ


2014年11月15日

USB-DACと矩形波

前回はSin波を見ました(2014年10月18日の日記参照)が、今回は矩形波を見てみようと思います。

サンプリング周波数の1/2の周波数(以降、1/2 fsと書きます)の矩形波のLPCMデータを下記のように表すとします。


周波数1/2 fsの矩形波のLPCMデータ

矩形波と書きましたが、このデータをアナログに変換しても矩形波にはなりません。下記のような22kHzのSin波になります。


周波数1/2 fsの矩形波をアナログに変換

私もそれほど詳しくはありませんが、標本化定理と言って、ある波形をサンプリング周波数44kHzでサンプリングした際、完全に元の波形に戻せるのは1/2 fs未満、つまり22kHzまでの周波数を持った波形、という定理があります。それ以上は情報が失われ、元に戻せません。

見た目は周波数22kHzの波形に見える矩形波でも、波形の立上がり、立下りの部分に高い周波数を含んでいて、この部分が失われてしまうため、元に戻らないのです。

同じ理屈で1/4 fsの矩形波、つまり44kHzのサンプリング周波数で、11kHzの矩形波を表そうとしても、立上がり、立下りの部分が失われ、11kHzのSin波になります。LPCMデータの最大値は変わりませんが、22kHzの時より振幅が大きくなるのが面白いですね。


周波数1/4 fsの矩形波をアナログに変換

見た目が矩形波らしくなるのは1/6 fsか1/8 fsくらいでしょうか。つまり44kHzのサンプリング周波数で、7.4kHzか5.5kHzの矩形波を表そうとしたときです。


周波数1/6 fsの矩形波をアナログに変換


周波数1/8 fsの矩形波をアナログに変換

実際やってみましょう

では、下記のLPCMデータを使ってUSB-DACで再生してみます。

各種揃えましたが、訳あって、この中からサンプリング周波数44kHzのデータを使うことにします。まずは1/2 fsから。


ONKYO SE-U33GXV2の22kHz矩形波出力(fs = 44.1kHz)

綺麗なSin波です。次は1/4 fsです。


ONKYO SE-U33GXV2の11kHz矩形波出力(fs = 44.1kHz)

これも綺麗なSin波ですね。振幅が先ほどより大きいのがわかると思います。次は1/6 fsと1/8 fsです。


ONKYO SE-U33GXV2の7.4kHz矩形波出力(fs = 44.1kHz)


ONKYO SE-U33GXV2の5.5kHz矩形波出力(fs = 44.1kHz)

角の部分はまだガタガタしていますが、矩形波らしくなってきたのがわかります。

編集者:すずき(2019/09/08 12:45)

コメント一覧

  • すずきさん(2014/11/19 02:30)
    DA 変換を調べていたら、どうも、図のような補完でリンギングが起きているわけではなさそうです。信号処理は難しいな…。
open/close この記事にコメントする



2014年11月20日

DA変換

前回の日記(2014年11月15日の日記参照)では、DA変換を理解できていなくて、いい加減な図を描いてしまったので、今日はLPCMのサンプル値から連続時間信号を生成した場合の波形を計算して描いてみようと思います。

調べたところによれば、サンプル値x[n] を離散時間フーリエ変換し、周波数領域に変換して、得られた周波数領域のうち角周波数 -π/Ts < ω < π/Tsのみを残すローパスフィルタを掛け(※)、残った周波数領域を逆フーリエ変換すると、連続時間信号になるそうです。

(※)Tsはサンプリング周期、つまり何秒に1回サンプリングするかを表す記号です。

計算をすっ飛ばして結果だけ言うと、時間をTsずつずらしながら、各サンプル値x[n] とsinc関数(理想的なローパスフィルタを逆フーリエ変換するとsinc関数になる)の積を取り、全て足し合わせれば、連続時間信号になります。何故なのか説明できるほど理解できていませんが、ひとまずそういうモンということで、計算してみます。


周波数1/2 fsの矩形波のLPCMサンプルデータと連続時間信号

サンプル値は -400から400で、サンプリング周期Tsは20 [s]、サンプリング周波数fsは1/20 = 0.05 [Hz] とし、0〜960 [s] までを計算しています。横軸tの単位は [s] です。

これだけだと、ふーん……。で終わってしまうので、わかりやすいように、1個目のサンプルと、2個目のサンプルのみで、連続時間信号を計算してみます。


各LPCMサンプルデータと対応するsinc関数

赤色(系列2)が1個目のサンプル、緑色(系列3)が2個目のサンプル、青色(系列1)が総和です。1/2 fsかつ、ピーク値がLPCMのサンプル値とほぼイコールのSin波が計算されるのがわかると思います。

じゃあ1/4 fsは?というと、こうなります。


周波数1/4 fsの矩形波のLPCMサンプルデータと連続時間信号

前回の適当な図とは違い、1/4 fsのSin波が出力され、ピーク値はLPCMのサンプル値を超えてしまう、という様子もよくわかると思います。ちなみに連続時間信号のピーク値はt=409(真ん中の山の頂点)で563.7です。

もちろん1/6 fsや1/8 fsも計算可能ですが、長くなってきたので、また後日にでも載せます。

編集者:すずき(2014/11/22 17:13)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2014年11月25日

DA変換の続き

前回の日記(2014年11月20日の日記参照)の続きです。

サンプリング周波数(以降fsと書く)の1/6や1/8の周波数を持った矩形波のLPCMデータをDA変換したらどんな波形になりますか?という計算をしています。


周波数1/6 fsの矩形波のLPCMサンプルデータと連続時間信号


周波数1/8 fsの矩形波のLPCMサンプルデータと連続時間信号

前々回に掲載したUSB-DACの出力波形と比べてみても、形が似ていることがわかると思います。


ONKYO SE-U33GXV2の1/6 fs = 7.4kHz矩形波出力(fs = 44.1kHz)(再掲)


ONKYO SE-U33GXV2の1/8 fs = 5.5kHz矩形波出力(fs = 44.1kHz)(再掲)

当然ながらONKYO SE-U33GXV2は信号発発生器ではないので、波形が歪んでいても文句は言えません。しかし素人が見たり測ったりする限りでは、波形の歪みもなく、ノイズも少なく、基本に忠実なDACです。今更ながら、良い買い物だったなあ、と思います。

そう思うなら、オシロに繋いでないで音楽聴けよって?ええ、ええ、わかってますとも。

理想と現実

計算に使ったsinc関数(sin(x) / x形の関数のこと)は、やっかいなことに無限の過去から無限の未来まで値を持ちます。そのため、あるサンプルの値を変えると、過去から未来の全ての計算結果に対して影響が出ます。

下記グラフのようにLPCMデータ上は0でも、未来のデータの影響を受けるため、0ではないレベルの信号が出力されてしまいます。


周波数1/2 fsの連続時間信号の鳴り始め

無限に影響が出るとは言っても、この世の機械では計算ができませんので、実際に売られているDACなどの機器ではどこかで影響を打ち切っていると思われます。もしくは思い切って信号の再現性は捨ててsinc関数を使わずに計算しているはずです。

じゃあ実際、どの辺まで計算しているんでしょうね?ということでUSB-DACの鳴り始めの信号にトリガを掛けて、オシロスコープで見てみます。


ONKYO SE-U33GXV2の 周波数1/2 fs = 22kHzの連続時間信号の鳴り始め(fs = 44.1kHz)

なお、計算値(-400〜 +400)と対応が取りやすいように、いずれのUSB-DACの振幅も -4V〜+4Vの振幅になるように音量を調整しています。

マイナス側に一番大きく -6Vくらいまで振れている波が、一番最初のLPCMデータに対応した信号になります。計算したグラフと見比べるとわかりやすいです。

最初の波より前についても、計算したグラフの形と、オシロスコープの波形がほぼ一致していますので、LPCMデータを入力していない部分は、値0のLPCMデータとして扱っていると見て問題なさそうです。

セカンドオピニオンとしてCreative X-Fi Go! Proにも登場いただくことにします。前々回泣かされたCreative SB Play! とは違って、X-Fi Go! ProのSin波は非常に綺麗です。


Creative X-Fi Go! Proの 周波数1/2 fs = 22kHzの連続時間信号の鳴り始め(fs = 44.1kHz)

何というのか、鳴り始めを打ち切ったような波形ですね。残念ながらセカンドオピニオンならず。せっかく買ったのに、ションボリですね…。

過去への影響と遅延

オシロスコープの波形と、0データとの交点を数えてみると、下記のように少なくとも鳴り始めより17〜18個前のサンプルまで影響を及ぼしているように見えます。


ONKYO SE-U33GXV2の鳴り始め以前の0との交差部分

これは少なくとも18サンプル以上DAC内部に貯めてから、信号の値を計算している、ということの現れです。たくさん貯めてから計算するほど、理想のDA変換に近づきますが、貯めすぎればDACの処理遅延に繋がり、使い勝手は悪くなります。

ちなみに18サンプルの遅延はfs = 44.1kHzのとき、わずか0.408 [ms] に過ぎません。ざっと、この10倍〜20倍のサンプルを貯めてから計算しても、人間に全くわからないレベルの遅延に収まるでしょう。

恐らく、USB-DACはもっとたくさんのサンプルを貯めていて、遅延も大きいはずなのですが、今持っている測定手段からは、これ以上の精度で信号が読めないので、真実については何とも言えませんねー……。

もっと良い測り方をご存じの方は教えていただけると嬉しいです。手持ちの機材で測れそうなら試してみます。

編集者:すずき(2014/11/25 22:45)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



こんてんつ

open/close wiki
open/close Linux JM
open/close Java API

過去の日記

open/close 2002年
open/close 2003年
open/close 2004年
open/close 2005年
open/close 2006年
open/close 2007年
open/close 2008年
open/close 2009年
open/close 2010年
open/close 2011年
open/close 2012年
open/close 2013年
open/close 2014年
open/close 2015年
open/close 2016年
open/close 2017年
open/close 2018年
open/close 2019年
open/close 2020年
open/close 2021年
open/close 2022年
open/close 2023年
open/close 2024年
open/close 過去日記について

その他の情報

open/close アクセス統計
open/close サーバ一覧
open/close サイトの情報