2013年8月25日日曜日
minstrel の概要
・よくある RSSI を用いたレート制御は、マルチパスを考慮していないため、適切なレートになっていないことがある。
・minstrel は mac80211 上に実装されているが、もともと MadWifi の一部だった。さらには、博士論文にまでさかのぼる。
・全レートを試し、あるレートで送信成功ならそのレートを使い、失敗なら使わないようにする。
・どのレートで送信成功・失敗したかの記録を全てとっておき、基本的には送信成功しそうなレートを使っていく。
ときどき、最適と思われるレート以外のレートも使って、送信成功するようになったかの調査を行う。
・(再送などにより)送信に著しく時間がかかると、Linux カーネルの TCP 実装では次のフレームの送信を遅らせるようになっている。
・4回再送できるとしたら、再送のレートは次の順序で出す。
最速のスループットが出るレート・2番目に速いスループットが出るレート・もっとも送信成功しやすいレート・基本のレート
ただし、スループットの定義は、(そのレートでの送信成功率)× (そのレート [Mbps])
・EWMA(指数加重移動平均) により、古い結果より最近の結果を重要視するので、環境の変化に追随できる。
2013年6月23日日曜日
相関を持つ乱数の生成
相関を持つ正規分布な乱数を生成するためには、コレスキー分解を用いる。
下記はその確認用の matlab プログラム。
大きさ 1 を持つ N x 4 個の複素数の乱数 x を生成する。
実部・虚部それぞれが標準正規分布している。
また、4 列の列方向の乱数列どうしはそれぞれ独立である。
相関行列 corrcoef(x) の i,j 成分が対角成分以外ほぼ 0 になることから確認できる。
複素相関行列 R のコレスキー分解 chol(R) の下三角行列を x に乗算して、
相関のある乱数列 y を得ることができる。
y の相関行列 corrcoef(y) を計算すると、もとの R とほぼ等しくなっている。
下記はその確認用の matlab プログラム。
大きさ 1 を持つ N x 4 個の複素数の乱数 x を生成する。
実部・虚部それぞれが標準正規分布している。
また、4 列の列方向の乱数列どうしはそれぞれ独立である。
相関行列 corrcoef(x) の i,j 成分が対角成分以外ほぼ 0 になることから確認できる。
複素相関行列 R のコレスキー分解 chol(R) の下三角行列を x に乗算して、
相関のある乱数列 y を得ることができる。
y の相関行列 corrcoef(y) を計算すると、もとの R とほぼ等しくなっている。
N = 10000; x = 1/sqrt(2) * (randn(N,4) + randn(N,4) * I); corrcoef(x) # correlation matrix of y r = [ 1, -0.7+0.2I, 0.2+0.4I, -0.5+0.1I; -0.7-0.2I, 1, 0.3-0.2I, 0.4-0.2I; 0.2-0.4I, 0.3+0.2I, 1, 0.3+0.1I; -0.5-0.1I, 0.4+0.2I, 0.3-0.1I, 1] y = transpose(chol(r, 'lower') * transpose(x)); corrcoef(y) # correlation matrix of y
登録:
投稿 (Atom)