金慶的專(zhuān)欄
C++博客
::
首頁(yè)
::
新隨筆
::
聯(lián)系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評(píng)論 :: 0 Trackbacks
公告
我的隨筆
我的評(píng)論
我參與的隨筆
留言簿
(12)
給我留言
查看公開(kāi)留言
查看私人留言
隨筆分類(lèi)
(502)
1. C/C++(166)
(rss)
2. 網(wǎng)游開(kāi)發(fā)(108)
(rss)
3. Golang(20)
(rss)
4. Linux/Unix(30)
(rss)
5. 軟工與管理(44)
(rss)
6. Python(23)
(rss)
7. Erlang(18)
(rss)
8. Rust(16)
(rss)
9. 其它(77)
(rss)
隨筆檔案
(423)
2023年1月 (1)
2022年11月 (1)
2022年10月 (2)
2022年9月 (1)
2022年4月 (6)
2022年1月 (2)
2021年12月 (4)
2021年11月 (6)
2021年10月 (2)
2021年9月 (2)
2021年8月 (7)
2021年7月 (2)
2021年5月 (2)
2021年3月 (1)
2021年2月 (2)
2021年1月 (1)
2020年12月 (1)
2020年10月 (1)
2020年9月 (5)
2020年8月 (1)
2020年7月 (1)
2020年6月 (1)
2020年4月 (2)
2020年3月 (3)
2020年2月 (3)
2020年1月 (1)
2019年12月 (1)
2019年9月 (2)
2019年4月 (2)
2019年1月 (1)
2018年12月 (1)
2018年11月 (3)
2018年10月 (1)
2018年9月 (3)
2018年8月 (3)
2018年7月 (2)
2018年6月 (4)
2018年5月 (4)
2018年4月 (4)
2018年3月 (1)
2018年1月 (2)
2017年12月 (2)
2017年11月 (3)
2017年10月 (3)
2017年8月 (7)
2017年7月 (1)
2017年6月 (1)
2017年5月 (3)
2017年4月 (3)
2017年3月 (3)
2017年2月 (2)
2017年1月 (2)
2016年12月 (5)
2016年11月 (2)
2016年10月 (2)
2016年9月 (1)
2016年8月 (6)
2016年7月 (3)
2016年6月 (2)
2016年5月 (4)
2016年4月 (2)
2016年3月 (2)
2016年1月 (3)
2015年12月 (2)
2015年11月 (2)
2015年10月 (1)
2015年8月 (2)
2015年7月 (1)
2015年6月 (1)
2015年5月 (4)
2015年4月 (3)
2015年3月 (4)
2015年2月 (5)
2015年1月 (4)
2014年12月 (3)
2014年11月 (3)
2014年10月 (2)
2014年9月 (3)
2014年8月 (1)
2014年4月 (4)
2014年3月 (1)
2014年2月 (4)
2014年1月 (5)
2013年12月 (5)
2013年11月 (5)
2013年9月 (2)
2013年8月 (2)
2013年7月 (2)
2013年6月 (2)
2013年5月 (1)
2013年1月 (2)
2012年12月 (1)
2012年11月 (1)
2012年9月 (1)
2012年8月 (3)
2012年7月 (2)
2012年6月 (1)
2012年4月 (3)
2012年3月 (2)
2012年2月 (3)
2012年1月 (2)
2011年11月 (2)
2011年10月 (3)
2011年9月 (2)
2011年8月 (2)
2011年7月 (3)
2011年6月 (2)
2011年5月 (3)
2011年1月 (2)
2010年12月 (1)
2010年11月 (2)
2010年10月 (2)
2010年9月 (3)
2010年8月 (2)
2010年7月 (3)
2010年6月 (1)
2010年5月 (3)
2010年4月 (3)
2010年3月 (5)
2010年2月 (4)
2010年1月 (4)
2009年12月 (2)
2009年11月 (3)
2009年10月 (4)
2009年9月 (3)
2009年8月 (2)
2009年7月 (4)
2009年6月 (1)
2009年5月 (3)
2009年4月 (4)
2009年3月 (2)
2009年2月 (5)
2009年1月 (1)
2008年12月 (7)
2008年11月 (4)
2008年10月 (1)
2008年9月 (3)
2008年8月 (4)
2008年7月 (3)
2008年6月 (4)
2008年5月 (6)
2008年4月 (7)
2008年3月 (6)
2008年1月 (5)
2007年12月 (7)
2007年11月 (4)
2007年10月 (5)
2007年9月 (6)
2007年8月 (8)
2007年7月 (5)
相冊(cè)
公告照片
搜索
積分與排名
積分 - 659000
排名 - 25
最新評(píng)論
1.?re: boost::asio::spawn 將一統(tǒng)C++網(wǎng)絡(luò)庫(kù)
asio 成為C++首選網(wǎng)絡(luò)庫(kù)
--linda
2.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
--金慶
3.?re: mingw編譯OrzNet
能發(fā)送一個(gè)mingw編譯好的OrzNet庫(kù)給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
--bigbad
5.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯(cuò)誤(11054)
2.?SVN中邪惡的replace(10972)
3.?VS2005編譯libevent(10429)
4.?混音算法的學(xué)習(xí)與研究(10230)
5.?C調(diào)用lua腳本的效率測(cè)試(9018)
評(píng)論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯(cuò)誤(18)
4.?C++引用優(yōu)于指針(17)
5.?ACE與ASIO之間關(guān)于Socket編程的比較(16)
混音算法的學(xué)習(xí)與研究
混音算法的學(xué)習(xí)與研究
金慶 2007.10.31
(轉(zhuǎn)載請(qǐng)注明來(lái)源于金慶的專(zhuān)欄)
想把原來(lái)一個(gè)舊程序中的混音算法改善一下,就大致研究了一下混音算法。
原來(lái)的混音是直接加和,因?yàn)橐粼匆袅亢苄。B溢出也沒(méi)考慮。
出來(lái)的效果只能是大概有個(gè)響動(dòng),不過(guò)程序應(yīng)用的領(lǐng)域只需達(dá)到這點(diǎn)就足夠了。
現(xiàn)在音源音質(zhì)改善了一點(diǎn),有必要也對(duì)混音算法做點(diǎn)改進(jìn)了。
主要還是曾經(jīng)看到這樣一篇混音新算法的轉(zhuǎn)載文章[3],一直想應(yīng)用一下。
再次翻到那篇文章,算法很簡(jiǎn)單,表達(dá)也很清晰,就是不知道原理。
算法簡(jiǎn)述如下:
For n-bit sampling audio signal
If both A and B are negative Y = A + B - (A * B / (-(2 pow(n-1) -1)))
Else Y = A + B - (A * B / (2 pow(n-1))
注意代碼與算法稍有不符。代碼中兩種情況都除以(-(2 pow(n-1) -1))),根據(jù)算法,大部分情況下都應(yīng)該除以(2 pow(n-1))。是否減1有什么作用?如果不必減1,對(duì)于整數(shù)運(yùn)算就可以用移位實(shí)現(xiàn)。
如果對(duì)多路混音該如何擴(kuò)展算法呢?
算法的出處未注明,所以我搜索了一下,找到一篇論壇帖子(但與原文中引文并不一致):
http://www.dsprelated.com/showmessage/27372/1.php
從中可以看到,算法并沒(méi)有什么數(shù)學(xué)根據(jù),而且從兩路擴(kuò)展到多路效果并不好。回貼的沒(méi)有一個(gè)贊同這一算法的。
看來(lái)不能盲目照搬沒(méi)有根據(jù)的算法。
[3]中還有一個(gè)NOKIA的代碼下載,根據(jù)所附鏈接,下載了這個(gè)NOKIA的例子,其中混音的代碼在CMixerThread::FillBuffer()中,發(fā)現(xiàn)只是簡(jiǎn)單的加和再限值,沒(méi)有什么利用價(jià)值。
后來(lái)終于找到該算法的出處:
http://newlc.com/topic-10064
作者自己說(shuō),該算法對(duì)于5個(gè)通道以上就不太好,算法的好處是不會(huì)溢出。但有人反映聲音有飽和的趨向。
總結(jié)一下我對(duì)混音算法的學(xué)習(xí),大概有以下幾種方式:
1. 直接加和
2. 加和后再除以混音通道數(shù),防止溢出
3. 加和并箝位,如有溢出就設(shè)最大值
4. 飽和處理,接近最大值時(shí)進(jìn)行扭曲(“軟件混音的實(shí)現(xiàn)”一文算法就是這類(lèi))
5. 歸一化處理,全部乘個(gè)系數(shù),使幅值歸一化。(只適用于文件)
6. 衰減因子法,用衰減因子限制幅值[1]。
直接加和,或除以通道數(shù)的混音方法有嚴(yán)重缺陷,效果可能很差。箝位法最大混音數(shù)大約是4個(gè),飽和處理最大混音數(shù)可能再高幾個(gè)。對(duì)于大量的混音,應(yīng)該采用衰減因子法。
文獻(xiàn)[2]提出了一個(gè)自對(duì)齊權(quán)重法(align-to-self weighted,簡(jiǎn)稱(chēng)ASW),以一個(gè)時(shí)間幀為單位進(jìn)行衰減,可能在幀之間有斷續(xù),效果應(yīng)該不如平滑的衰減。
如果[1]中的衰減因子計(jì)算時(shí)能考慮整個(gè)時(shí)間片的數(shù)據(jù),而不僅僅是當(dāng)前點(diǎn),那樣效果會(huì)更好吧。
(轉(zhuǎn)載請(qǐng)注明來(lái)源于金慶的專(zhuān)欄)
參考文獻(xiàn):
[1]
視頻會(huì)議中關(guān)于混音算法的一些筆記
[2]
多媒體會(huì)議中的快速實(shí)時(shí)自適應(yīng)混音方案研究 (PDF)
[3]
軟件混音的實(shí)現(xiàn)
posted on 2007-10-31 17:27
金慶
閱讀(10230)
評(píng)論(5)
編輯
收藏
引用
所屬分類(lèi):
9. 其它
評(píng)論
#
re: 混音算法的學(xué)習(xí)與研究
2007-10-31 19:37
Minidx全文檢索
看得不是很明白...
回復(fù)
更多評(píng)論
#
re: 混音算法的學(xué)習(xí)與研究
2007-10-31 20:06
neoragex2002
模擬聲音就是傅立葉級(jí)數(shù)分解(級(jí)數(shù)求和);模數(shù)轉(zhuǎn)換就是抽樣,抽樣的理論基礎(chǔ)
是乃奎斯特定理,也就是說(shuō)只有當(dāng)抽樣頻率為5個(gè)音道中最高頻率的2倍時(shí),直接相加才是正確的,不是所有場(chǎng)合都可以直接加的。至于音量,做個(gè)簡(jiǎn)單的均衡就可以了。
回復(fù)
更多評(píng)論
#
re: 混音算法的學(xué)習(xí)與研究
2007-11-01 09:40
金慶
@neoragex2002
前提當(dāng)然是滿(mǎn)足采樣定理,語(yǔ)音采樣都是標(biāo)準(zhǔn)8K。關(guān)鍵就是均衡的方法,沒(méi)有簡(jiǎn)單的均衡方法。
回復(fù)
更多評(píng)論
#
re: 混音算法的學(xué)習(xí)與研究
2007-11-01 13:48
<a href=http://minidx.com>minidx.com</a&g
原來(lái)是這么回事
回復(fù)
更多評(píng)論
#
re: 混音算法的學(xué)習(xí)與研究
2008-01-10 23:20
白
謝謝金以及回復(fù)討論的朋友
正找混音的思路
回復(fù)
更多評(píng)論
刷新評(píng)論列表
只有注冊(cè)用戶(hù)
登錄
后才能發(fā)表評(píng)論。
【推薦】100%開(kāi)源!大型工業(yè)跨平臺(tái)軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
TortoiseGit is OK but GitExtensions fails
DeathVoteExpirationTimeout in Orleans
How to delete local branches of GitExtension
Clustering provider in Orleans
Why Orleans' actor is virutal
What comes after microservice?
Rust Deref coercion example
Rust Error Return Check Policy
Rust visibility
Why does Rust check borrow even in single thread
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問(wèn)
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
久久国产精品一区二区
|
亚洲精品无码久久久久去q
|
久久精品无码一区二区无码
|
久久99这里只有精品国产
|
国产精品久久久久一区二区三区
|
国内精品久久久久影院免费
|
久久久无码精品亚洲日韩蜜臀浪潮
|
国内精品伊人久久久久777
|
免费精品久久久久久中文字幕
|
精品久久久久久久中文字幕
|
久久精品成人免费观看97
|
久久国产成人午夜aⅴ影院
|
久久婷婷色综合一区二区
|
久久久久99精品成人片
|
日韩欧美亚洲综合久久影院Ds
|
一本色道久久88综合日韩精品
|
久久精品国产亚洲Aⅴ香蕉
|
国内精品久久九九国产精品
|
国产亚州精品女人久久久久久
|
精品国产91久久久久久久a
|
久久影视综合亚洲
|
精品人妻伦九区久久AAA片69
|
亚洲色大成网站www久久九
|
www.久久精品
|
欧美久久亚洲精品
|
国内精品久久久久久久久电影网
|
久久人人爽人人爽人人片AV不
|
伊人久久大香线蕉精品
|
久久一区二区三区免费
|
亚洲国产精品无码成人片久久
|
久久91综合国产91久久精品
|
久久国产成人亚洲精品影院
|
亚洲综合日韩久久成人AV
|
色综合久久综精品
|
国内精品久久国产
|
久久亚洲综合色一区二区三区
|
青草久久久国产线免观
|
久久久老熟女一区二区三区
|
久久有码中文字幕
|
久久久国产精品网站
|
久久久国产精华液
|