引言
先進的接入技術(shù)碼分多址(CDMA)能夠有效利用帶寬,提高系統(tǒng)容量,應(yīng)用廣泛。IDMA交織多址是一種特殊的CDMA通信方式,使用碼片級的交織序列區(qū)分用戶。交織序列打亂原來編碼順序,使相鄰碼片近似無關(guān),且其接收端采用碼片到碼片的迭代多用戶檢測接收方式,計算復(fù)雜度較小。作為IDMA的關(guān)鍵技術(shù),交織序列的產(chǎn)生必須是隨機和獨立的,且交織序列之間互相關(guān)系數(shù)較小。但在實際中,當(dāng)數(shù)據(jù)幀長度較小,且用戶數(shù)較大時,隨機交織后序列的互相關(guān)系數(shù)以較大概率接近于1,使接收端不能正確檢測出用戶數(shù)據(jù),嚴重影響通信性能。文獻提出以互相關(guān)函數(shù)矩陣作為適應(yīng)度函數(shù),用進化算法獲得最優(yōu)交織序列,但進化算法易陷入局部最優(yōu)解,不能獲得全局最優(yōu)的交織序列。本文把粒子群算法引入交織算法中,在較少迭代次數(shù)的情況下即可獲得最優(yōu)解,同時仿真大用戶情況下的交織性能,實驗結(jié)果表明此算法性能較優(yōu)。
2 IDMA通信系統(tǒng)中的檢測原理與方法
圖1為IDMA通信系統(tǒng)發(fā)送和接收部分的結(jié)構(gòu)圖。該系統(tǒng)發(fā)送端包括K個用戶,第k個用戶發(fā)送的碼元序列為:dk=[dk(1),…,dk(i),…,dk(I)](I為發(fā)送序列碼元長度),經(jīng)碼長為S的重復(fù)編碼擴頻得到序列為:Gk=[Gk(1),…,Gk(j),…,Gk(J)],J為擴頻后的碼長,再經(jīng)交織器打亂順序重排后成為發(fā)送序列為:Xk=[xk(1),…,xk(j),…xk(J)]。
系統(tǒng)接收端采用Turbo型迭代譯碼結(jié)構(gòu),主要由基本信號檢測器ESE、解交織器和K個用戶譯碼器DEC組成。系統(tǒng)中考慮完全同步無記憶信道,接收信號r(j)表示為:
式中,n(j)為高斯白噪聲采樣,hk為第k個用戶的信道衰落系數(shù),ζk(k)為第后個用戶第j個碼片的失真,根據(jù)中心極限定理,ζk(j)滿足近似高斯分布,可用均值和方差函數(shù)表示。
基本信號檢測器模塊ESE的檢測算法概括如下:
式中E(.)表示均值,V(.)表示方差。
譯碼器DEC反饋的先驗信息經(jīng)交織后得到eDEC[xk(j)],更新ESE中接收信號的均值和方差,并產(chǎn)生輸入到譯碼器DEC的外信息eESE(xk(j)),外信息經(jīng)過解交織,作為譯碼器DEC輸入端的先驗信息,如此循環(huán)迭代直到規(guī)定的次數(shù)以后,K個用戶的譯碼器分別產(chǎn)生相應(yīng)信息序列的硬判決值dk。
3 基于粒子群的交織算法
3.1 粒子群算法的相關(guān)定義與操作
粒子群算法是一種基于迭代的優(yōu)化方法,具有易于實現(xiàn)、需要調(diào)整的參數(shù)少等優(yōu)點,并且在較少的迭代次數(shù)的情況下就可獲得全局最優(yōu)解。設(shè)粒子群粒子個數(shù)為M,在一個D維的搜索空間
織問題,這里定義粒子的位置和速度的含義及相關(guān)操作如下:
(1)粒子定義粒子的位置定義為一序列。對于搜索空間為D維的種群,序列長度為D。假設(shè)某個粒子j的位置為xj,D=5,則可表示為xj=(1,2,3,4,5);速度定義為粒子位置的變換集,即一組置換序列的有序列表,表示為:v={(ik,jk),ik,jk∈D},k∈{1,2,…,|v|,其中|v|表示該速度所含置換序列的個數(shù)。
(2)置換操作 假設(shè)某粒子i的位置為xi,定義置換序列(mi,ni),置換操作用以交換xi中第mi和ni個值的位置,則x'i=xi+(mi,ni),其中x'i為經(jīng)過置換操作后得到的新位置。
(3)加法操作包括粒子速度與速度的加法操作及粒子速度和位置的加法操作。設(shè)vi、vj、vk分別表示第i、第j及第k個粒子速度,xk為第k個粒子位置。vi+vj表示兩個速度相加的操作,其結(jié)果為兩個置換序列合并,產(chǎn)生一個新置換序列串;vk+xk表示速度和位置的加法操作,即將一組置換序列依次作用于某個粒子位置。其結(jié)果為一個新位置。
(4)減法操作主要指粒子位置與位置的減法操作。該操作相減后結(jié)果為一組置換序列,即速度。設(shè)xk為第k個粒子位置,xi為第i個粒子位置,則xi-xk為一個置換序列。例如:xi=(1,2,3,4,5),xk=(2,3,1,4,5),由于xi(1)=1,xk(3)=1,第1個交換序列為(1,3),xj=xk(1,3)=(1,3,2,4,5);又xi(2)=2,xi(3)=2,第2個交換序列為(2,3),xi=xj+(2,3),因此經(jīng)上述操作得到:xi=xk+{(1,3),(2,3)},所以xi-xk={(1,3),(2,3)}。
(5)乘法操作 指實數(shù)與粒子速度的乘法操作。對于在(0,1)任意實數(shù)c,設(shè)速度v有i個置換序列,則乘法操作截取速度置換序列,使新的速度置換序列個數(shù)為|cxi|(cxi取整)。
根據(jù)以上定義,粒子群的更新公式可描述為:
式中,c1與c2是兩個正的常數(shù),稱為加速因子,r1和r2為分布于[0,1]間的隨機數(shù)。