このページの内容は最新ではありません。最新版の英語を参照するには、ここをクリックします。
comm.CPMModulator
CPM 法を使用した信号の変調
説明
comm.CPMModulator
System object™ は、連続位相変調 (CPM) 法を使用して入力信号を変調します。出力は、変調信号のベースバンド表現です。変調および適用されるフィルター処理の詳細については、CPM 法およびパルス整形のフィルター処理を参照してください。
CPM 法を使用して信号を変調するには、次のようにします。
comm.CPMModulator
オブジェクトを作成し、そのプロパティを設定します。関数と同様に、引数を指定してオブジェクトを呼び出します。
System object の機能の詳細については、System object とはを参照してください。
作成
構文
説明
cpmmod = comm.CPMModulator
は、CPM 法を使用して入力信号を変調する変調器 System object を作成します。
cpmmod = comm.CPMModulator(
は、名前と値の引数を 1 つ以上使用してプロパティを設定します。たとえば、Name
,Value
)'SymbolMapping','Gray'
は、変調されたシンボルに対してグレイ符号順のシンボル マッピングを指定します。
cpmmod = comm.CPMModulator(
は、M
,Name
,Value
)ModulationOrder
プロパティを M
に設定し、オプションで名前と値の引数を設定します。
プロパティ
特に指定がない限り、プロパティは "調整不可能" です。つまり、オブジェクトの呼び出し後に値を変更することはできません。オブジェクトは呼び出すとロックされ、ロックを解除するには関数 release
を使用します。
プロパティが "調整可能" の場合、その値をいつでも変更できます。
プロパティ値の変更の詳細については、System object を使用した MATLAB でのシステム設計を参照してください。
ModulationOrder
— 変調次数
4
(既定値) | 2 のべき乗のスカラー
変調次数。2 のべき乗のスカラーとして指定します。変調次数 M = 2k は、信号コンスタレーション点の数を指定します。ここで、k は、シンボルごとのビット数を示す正の整数です。
データ型: double
BitInput
— 入力データをビットとして提供するオプション
0
または false
(既定値) | 1
または true
入力データをビットとして提供するオプション。logical 0
(false
) または logical 1
(true
) として指定します。
このプロパティを
false
に設定する場合、入力は範囲 [–(ModulationOrder
– 1), (ModulationOrder
– 1)] の奇数整数値の列ベクトルでなければなりません。このプロパティを
true
に設定する場合、入力は長さ k のビット ワードの列ベクトルでなければなりません。ここで、k = log2(ModulationOrder
) です。詳細については、シンボル セットを参照してください。
データ型: logical
ModulationIndex
— 変調指数
0.5
(既定値) | 非負のスカラー | 列ベクトル
変調指数。非負のスカラーまたは列ベクトルとして指定します。詳細については、CPM 法を参照してください。
データ型: double
FrequencyPulse
— 周波数パルス整形のタイプ
'Rectangular'
(既定値) | 'Raised Cosine'
| 'Spectral Raised Cosine'
| 'Gaussian'
| 'Tamed FM'
変調された信号の位相遷移を滑らかにするために変調器が使用する周波数パルス整形のタイプ。'Rectangular'
、'Raised Cosine'
、'Spectral Raised Cosine'
、'Gaussian'
、または 'Tamed FM'
として指定します。詳細については、パルス整形のフィルター処理を参照してください。
MainLobeDuration
— メイン ローブ期間
1
(既定値) | 正の整数
スペクトル レイズド コサイン パルスの最大ローブのメイン ローブ期間。変調された信号をパルス整形するために変調器が使用するシンボル区間の数を表す正の整数として指定します。
依存関係
このプロパティを有効にするには、FrequencyPulse
プロパティを 'Spectral Raised Cosine'
に設定します。
データ型: double
RolloffFactor
— ロールオフ係数
0.2
(既定値) | 範囲 [0,1] のスカラー
スペクトル レイズド コサイン パルスのロールオフ係数。範囲が [0, 1] のスカラーとして指定します。
依存関係
このプロパティを有効にするには、FrequencyPulse
プロパティを 'Spectral Raised Cosine'
に設定します。
データ型: double
BandwidthTimeProduct
— ガウス パルス整形の帯域幅とシンボル時間の積
0.3
(既定値) | 正のスカラー
ガウス パルス整形の帯域幅とシンボル時間の積。正のスカラーとして指定します。BandwidthTimeProduct
は、符号間干渉の増加を代償に帯域幅を狭くするために使われます。
依存関係
このプロパティを有効にするには、FrequencyPulse
プロパティを 'Gaussian'
に設定します。
データ型: double
PulseLength
— 周波数パルス整形の長さ
1
(既定値) | 正の整数
シンボル区間における周波数パルス整形の長さ。正の整数として指定します。周波数パルス長の詳細については、パルス整形のフィルター処理の LT を参照してください。
データ型: double
SymbolPrehistory
— シンボル プレヒストリ
1
(既定値) | スカラー | ベクトル
シンボル プレヒストリ。範囲 [– (ModulationOrder
– 1), (ModulationOrder
– 1)] の奇数の整数要素をもつスカラーまたはベクトルとして指定します。このプロパティは、オブジェクトの最初の呼び出しの前に、変調器によって使用されるデータ シンボルを新しいものから順番に定義します。
スカラー値は長さ
PulseLength
– 1 のベクトルに展開されます。ベクトルの場合、長さが
PulseLength
– 1 でなければなりません。
データ型: double
InitialPhaseOffset
— 初期位相オフセット
0
(既定値) | スカラー
変調波形の初期位相オフセット (ラジアン単位)。スカラーとして指定します。
データ型: double
SamplesPerSymbol
— 出力シンボルあたりのサンプル数
8
(既定値) | 正の整数
出力シンボルあたりのサンプル数。正の整数として指定します。このプロパティは、入力される各整数またはバイナリ ワードごとのサンプル出力の数を表します。パルス整形で定義されているように、すべての非バイナリ スキームに対して、この値は 1 より大きくなければなりません。
データ型: double
OutputDataType
— 出力のデータ型
'double'
(既定値) | 'single'
出力のデータ型。'double'
または 'single'
として指定します。
使用法
入力引数
出力引数
Y
— CPM 変調されたベースバンド信号
列ベクトル
CPM 変調されたベースバンド信号。列ベクトルとして返されます。この出力ベクトルの長さは、入力サンプル数と SamplesPerSymbol
プロパティで指定されたシンボルあたりのサンプル数を掛け合わせたものと同じです。出力データ型を指定するには、OutputDataType
プロパティを使用します。
データ型: double
| single
複素数のサポート: あり
オブジェクト関数
オブジェクト関数を使用するには、System object を最初の入力引数として指定します。たとえば、obj
という名前の System object のシステム リソースを解放するには、次の構文を使用します。
release(obj)
例
グレイ マッピングとビット入力による信号の CPM 変調と CPM 復調
CPM 変調器 System object と CPM 復調器 System object を作成します。
cpmmodulator = comm.CPMModulator(8, ... 'BitInput',true, ... 'SymbolMapping','Gray'); cpmdemodulator = comm.CPMDemodulator(8, ... 'BitOutput',true, ... 'SymbolMapping','Gray');
エラー レート計算機 System object™ を作成します。これはビタビ アルゴリズムによって発生する遅延を考慮します。
delay = log2(cpmdemodulator.ModulationOrder) ... * cpmdemodulator.TracebackDepth; errorRate = comm.ErrorRate('ReceiveDelay',delay);
3 ビットのワードを 100 個送信し、エラー レートの結果を出力します。
for counter = 1:100 data = randi([0 1],300,1); modSignal = cpmmodulator(data); noisySignal = awgn(modSignal,0); receivedData = cpmdemodulator(noisySignal); errorStats = errorRate(data,receivedData); end fprintf('Error rate = %f\nNumber of errors = %d\n', ... errorStats(1),errorStats(2))
Error rate = 0.004474 Number of errors = 134
GFSK 変調と復調の適用
comm.CPMModulator
とcomm.CPMDemodulator
System object を使用して、ガウス周波数偏移変調 (GFSK) の変調と復調をランダム ビット データに適用します。
GFSK の変調器と復調器のペアを作成します。
gfskMod = comm.CPMModulator( ... 'ModulationOrder',2, ... 'FrequencyPulse','Gaussian', ... 'BandwidthTimeProduct',0.5, ... 'ModulationIndex',1, ... 'BitInput',true); gfskDemod = comm.CPMDemodulator( ... 'ModulationOrder',2, ... 'FrequencyPulse','Gaussian', ... 'BandwidthTimeProduct',0.5, ... 'ModulationIndex',1, ... 'BitOutput',true);
ランダム ビット データを生成して GFSK 変調を適用します。散布図を使用してコンスタレーションを表示します。
numSym = 100; x = randi([0 1],numSym*gfskMod.SamplesPerSymbol,1); y = gfskMod(x); eyediagram(y,16)
GFSK 変調されたデータを復調します。復調された信号データが元のデータと等しいことを検証するには、GFSK の変調と復調のプロセスでガウス フィルター処理によって発生する遅延を考慮します。
z = gfskDemod(y); delay = finddelay(x,z); isequal(x(1:end-delay),z(delay+1:end))
ans = logical
1
連続位相変調の位相ツリーのプロット
連続位相変調 (CPM) を適用した信号の位相ツリー ダイアグラムをプロットします。"位相ツリー ダイアグラム" は時間の経過に伴う変調信号の位相をプロットした曲線を多数重ね合わせたものです。明確な曲線は、変調器へのさまざまな入力から生成されます。この例では、CPM 変調器の設定を定義し、シンボル マッピングを適用して、結果をプロットします。各曲線は、識別可能な (定数) 入力信号による CPM 変調器のシミュレーションの異なるインスタンスを表します。
例で使用するパラメーターを定義し、CPM 変調器 System object™ を作成します。
M = 2; % Modulation order modindex = 2/3; % Modulation index sps = 8; % Samples per symbol L = 5; % Symbols to display pmat = zeros(L*sps,M^L); % Empty phase matrix cpm = comm.CPMModulator(M, ... ModulationIndex=modindex, ... FrequencyPulse="Raised Cosine", ... PulseLength=2, ... SamplesPerSymbol=sps);
for
ループを使用して、0
が -(M-1
) に、1
が -(M-2
) になるように (以下同様) マップし、入力シンボルのマッピングを CPM シンボルに適用します。位相行列の列に、変調シンボルのアンラップ位相角を入力します。
for ip_sig = 0:(M^L)-1 s = int2bit(ip_sig,L,1); s = 2*s + 1 - M; x = cpm(s); pmat(:,ip_sig+1) = unwrap(angle(x(:))); end pmat = pmat/(pi*modindex); t = (0:L*sps-1)'/sps;
CPM 位相ツリーをプロットします。
plot(t,pmat); title('CPM Phase Tree') xlabel('Samples') ylabel('Phase (radians)')
詳細
CPM 法
変調器の出力は、変調信号のベースバンド表現です。
ここで、
{αi} はアルファベット ±1、±3、±(M–1) から選択した M-ary データ シンボルのシーケンスです。
M は、ある正の整数 k に対する 2k の形式をとらなければなりません。ここで、M は変調次数であり、シンボル アルファベットのサイズを指定します。
{hi} は変調指数のシーケンスです。hi は、一連の指数 {h0, h1, h2, …,hH-1} を巡回します。H=1 の場合、変調指数は h0 の 1 つのみで、h として表されます。
シンボル上の位相シフトは、π × h です。
hi が区間によって異なるときは、オブジェクトは多重 h で動作します。位相状態の数を有限とするためには、hi は有理数でなければなりません。
パルス整形のフィルター処理
CPM 法では、変調された信号の位相遷移を滑らかにするためにパルス整形を使用します。関数 q(t) は、 の関係によって周波数パルス g(t) から得られる位相応答です。
指定された周波数パルス整形は、g(t) のこれらのパルス整形式に対応します。
パルス整形 | 式 |
---|---|
Rectangular | |
Raised Cosine | |
Spectral Raised Cosine | |
Gaussian | |
Tamed FM (管理された周波数変調) |
Lmain は、シンボル区間におけるメイン ローブ パルス存続時間です。
β はスペクトル レイズド コサインのロールオフ係数です。
Bb は帯域幅とガウス パルスの積です。
パルスの持続時間 LT は、シンボル区間におけるパルス長です。式で定義されているとおり、スペクトル レイズド コサイン、ガウス、および Tamed FM のパルス整形は無限長をもちます。実用性のため、LT は切り捨てられた有限長を指定します。
T はシンボル持続時間です。
Q(t) は相補累積分布関数です。
パルス整形のフィルター処理の詳細については、[1]を参照してください。
シンボル セット
バイナリ入力モードでは、オブジェクト処理は次の手順に従います。
入力ビットを長さ k のビット ワードに分割し、各ビットグループを範囲 [0, M – 1] の整数 L にマップします。k = log2(M) と M は、
ModulationOrder
プロパティで指定された変調次数です。バイナリ ワード マッピング オプションは、SymbolMapping
プロパティの指定に従って、バイナリ符号の順序またはグレイ符号の順序になります。各整数 L を 2L–(M–1) として符号付き整数にマップします。
整数入力モードの場合と同様に、変調処理を進めます。
参照
[1] Anderson, John B., Tor Aulin, and Carl-Erik Sundberg. Digital Phase Modulation. New York: Plenum Press, 1986.
拡張機能
C/C++ コード生成
MATLAB® Coder™ を使用して C および C++ コードを生成します。
使用上の注意および制限:
MATLAB コード生成における System object (MATLAB Coder)を参照してください。
バージョン履歴
R2012a で導入R2023b: 可変サイズのサポート
このサポートによって、オブジェクトを呼び出すたびに入力信号の長さを変えられるようになりました。
MATLAB コマンド
次の MATLAB コマンドに対応するリンクがクリックされました。
コマンドを MATLAB コマンド ウィンドウに入力して実行してください。Web ブラウザーは MATLAB コマンドをサポートしていません。
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)