作者iitze (ici la lune)
看板Headphone
標題[閒聊] DIY R2R DAC w/FPGA
時間Thu Sep 29 07:53:16 2022
DAC規格有PCM跟PDM(dsd)
實作PCM目前市場多用晶片ESS/AKM/TI(BB)
是delta sigma架構
部份用FPGA實現R2R架構,但大多用分砌式來作
版上也有前輩多年前的文章討論R2R的diy
之前是diy做pcm1794
最近剛好看到schiit的Yggdrasil Less is More
有點被啟發,所以想來亂玩
參考hiro大的一系列文章,
還是很多不完全了解,但先做就對了
先上結果
https://i.imgur.com/ZEX28xm.jpeg
用TI的dac8814晶片,16bit R2R架構
但這不算是給音響用的,
官方文件應用寫Automatic Test Equipment/
Instrumentation/
Digitally-Controlled Calibration
但總之schiit都可以做了,就來玩吧
分砌式還是太搞剛,先用R2R的晶片先頂著
DAC8814輸入訊號的規格並不是i2s,
而一般分砌式的R2R看到都用FPGA來傳訊號
所以花了時間來複習FPGA,
找了一個開源的lattice平台,
接著就是繼續花時間來寫程式
將i2s轉成正確可以對應DAC8814電平表示的spi格式
跳過程式功力差痛苦debug階段,
然後上Elna交聯電容 10uf。
總之!終於有正常的聲音!
聽感上
跟之前做的pcm1794(mono mono, 192Khz)相比
也許是腦補(ikea效應),
真的就是覺得聲音更自然寬鬆,音場再大一點
但只有先測試基本R2R 48Khz
後續再來測試升頻192Khz或差動之類的
換歌曲也還偶爾會有小爆音要改
如果真有機會超想來聽聽高級分砌式R2R的DAC
另一個想做的是DSD架構
或是Mola Mola Tambaqui DAC架構
Just for fun.
感謝收看
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 220.135.220.116 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Headphone/M.1664409198.A.E45.html
※ 編輯: iitze (220.135.220.116 臺灣), 09/29/2022 07:55:42
1F:推 mtbigzan: 推DIY。淘寶崛起後,臺灣的DIY套件幾乎倒光光。09/29 08:09
2F:推 martinlin77: 推推推09/29 08:17
3F:推 Pointt: 推diy 太強了09/29 08:42
4F:推 goldie: 推 DIY09/29 09:01
5F:推 st93042: 好扯,自己寫FPGA,可以請教嗎XD09/29 09:02
可以喔
※ 編輯: iitze (220.135.220.116 臺灣), 09/29/2022 09:11:26
6F:推 Liandh: 可以試試github上的這個"max 2 audio dac"09/29 09:12
7F:推 Liandh: DSD最近剛跟團玩了DSC2.5.2, 先不論好壞,聲音真的不太一09/29 09:15
8F:→ Liandh: 樣09/29 09:15
9F:→ iitze: 我也是看到很有興趣,不過我是窮人自己洗板買料件,等過陣09/29 09:29
10F:→ iitze: 子集貨完再來焊,也已開始研究程式來PCM轉DSD想用FPGA做09/29 09:29
11F:推 dzwei: 如果把r2r的 +v 與 -v,用Fully OPA分開的話,準備兩個8bit09/29 10:58
12F:→ dzwei: 的r2r ladder(0.1%) 可以輕易的弄到16bits09/29 10:59
13F:→ dzwei: 如果能做 V+ V+/2 -V/2 -V(用vol referenc) 則能做到32bits09/29 11:00
我參考hiro 大說的電阻精準度會不太容易克服msb, sonnet 是有拼出24bit,但我還學識不
夠不知怎麼處理,我再學學
※ 編輯: iitze (220.135.220.116 臺灣), 09/29/2022 11:08:03
14F:→ dzwei: 我上面說的那個方法 就是克服電阻精度的其中一個方式XD09/29 11:44
15F:→ dzwei: +5對-5的時候 如果0.1%的電阻 可以做到9bit dynamic range09/29 11:46
16F:→ dzwei: 就是[+5-(-5)]/2^909/29 11:46
17F:→ dzwei: 但是今天把電路分成兩塊 +5到0用9bit D/A -5到0也用9bitD/A09/29 11:47
18F:→ dzwei: 最後再用加法器把兩塊加起來 這樣dynamic就提昇兩倍了09/29 11:48
19F:→ dzwei: 類似的方法 可以把他分成4塊 +5 +2.5 -2.5 -5 這樣09/29 11:48
20F:→ dzwei: 這樣理論上就能用0.1%精度的電阻 做到36bit09/29 11:49
21F:→ dzwei: 但是FDA跟voltage reference 還有op的精度 又是另一挑戰了09/29 11:50
來找資料研究
22F:→ aerial: 可以跟樓主下訂嗎?XD09/29 12:02
土砲好玩而已,賣產品還差很遠。謝謝你的肯定
23F:推 EntHeEnd: 推 超強09/29 12:06
24F:推 comipa: 真是有趣09/29 12:42
※ 編輯: iitze (220.135.220.116 臺灣), 09/29/2022 17:45:25
25F:推 whydan: 讚喔09/29 19:35
26F:推 bh2142: 喔喔好厲害,我之前也想搞,但我不會 dsp 就打消了念頭09/29 20:40
27F:→ bh2142: 有玩過 fpga 不過做的是 RISC-V SoC,dsp 從理論就不會09/29 20:42
28F:→ bh2142: 除非要工業用DAC不然用 FPGA 不搞 dsp 好像沒什麼意思09/29 20:45
29F:推 Ernest: 我是做analog ic的,還沒玩過fpga09/29 20:45
30F:→ Ernest: 但聽我雙棲的朋友,覺得FPGA容易上手多了09/29 20:46
31F:推 dzwei: 不過FPGA現在的用途太廣泛了 DSP其實其中一環XD09/29 20:52
32F:→ dzwei: 市場最大的 應該還是在tranceiver那塊 再來就是IC Design09/29 20:53
33F:→ dzwei: 的驗證 現在結合Arm在裡面的 功能又更強大了09/29 20:54
34F:→ dzwei: 以前要像電腦那樣搞TCP/IP的傳輸很麻煩 現在SoC化直接包在09/29 20:54
35F:→ dzwei: linux裡面 BSP的彈性也很大09/29 20:54
36F:推 bh2142: FPGA 現在最主要的用途就是驗證電路吧09/29 20:55
37F:→ bh2142: 不過我也不懂,我只是個資工系統仔09/29 20:56
38F:→ iitze: 太久沒玩FPGA,的確如d大所說,現在FPGA有趣可玩的東西變09/29 20:57
39F:→ iitze: 很多而且便宜很多,剛好這次機會重新學習一下09/29 20:57
40F:→ bh2142: 我對 FPGA 的印象就是,寫 Code 然後要合成很久,不過跟09/29 20:58
41F:→ bh2142: 實際去印一顆 IC 來測試比起來快多了09/29 20:58
42F:→ bh2142: 還有 probe 的功能很方便09/29 20:58
43F:→ dzwei: FPGA要編譯很久 就是Constrain給的不夠多XD 這個蠻吃經驗09/29 21:10
44F:→ dzwei: 不過現在入門的Zynq開發版都是200$ 對面的Intel開發資源09/29 21:11
45F:→ dzwei: 又是一攤死水 雖然這陣子樹梅派也漲了不少....09/29 21:11
46F:→ dzwei: 雖然7系列的zynq只有32位元的CortexA9 但很多時候已經足夠09/29 21:15
47F:→ dzwei: 自己也是建議從7系列這顆開始玩09/29 21:15
48F:推 Ernest: analog ic入手難度也很高呀,也是要驗很久,電子學底子要09/29 21:18
49F:→ Ernest: 很夠,才能抓鬼,前面規格沒做好,後面整盤去了了09/29 21:18
50F:→ Ernest: 而且一定得找fab下線,沒辦法在家自己做來玩09/29 21:19
51F:→ Ernest: 我就是對資工與通訊毫無興趣才選這個09/29 21:21
52F:推 yys310: analog神09/29 21:47
53F:推 ang728: 帥09/29 21:55
類比很難啊,我其實也不太懂,繼續學習,數位還比較懂,這次實驗FPGA有得到很多新知識
,覺得想做的東西就更多了,已知用火
※ 編輯: iitze (220.135.220.116 臺灣), 09/30/2022 04:33:08
54F:推 pinkg023: 真厲害 09/30 16:36
55F:推 rattrapante: 狂 10/01 22:34