Difference between revisions of "Applets:Principle of Pseudo-Ternary Coding"
Line 27: | Line 27: | ||
==Theoretical Background== | ==Theoretical Background== | ||
− | == | + | == General description of the pseudo-multilevel codes == |
+ | <br> | ||
+ | In symbolwise coding, each incoming source symbol qν generates an encoder symbol cν, which depends not only on the current input symbol qν but also on the NC preceding symbols qν−1, ... , qν−NC. NC is referred to as the "order" of the code.<br> | ||
− | + | Typical for symbolwise coding is that | |
+ | *the symbol duration $T$ of the encoded signal (and of the transmitted signal) matches the bit duration $T_{\rm B}$ of the binary source signal, and | ||
− | + | *encoding and decoding do not lead to major time delays, which are unavoidable when block codes are used.<br><br> | |
− | + | The "pseudo-multilevel codes" – better known as "partial response codes" – are of special importance. In the following, only "pseudo-ternary codes" ⇒ level number $M = 3$ are considered. | |
− | + | *These can be described by the block diagram corresponding to the left graph. | |
− | * | + | *In the right graph an equivalent circuit is given, which is very suitable for an analysis of these codes. |
− | + | [[File:EN_Dig_T_2_4_S1_v23.png|right|frame|Block diagram (above) and equivalent circuit (below) of a pseudo-ternary encoder|class=fit]] | |
− | |||
− | |||
− | |||
− | + | One can see from the two representations: | |
− | * | + | *The pseudo-ternary encoder can be split into the "non-linear pre-encoder" and the "linear coding network", if the delay by NC⋅T and the weighting by KC are drawn twice for clarity – as shown in the right equivalent figure. |
− | * | + | *The "non-linear pre-encoder" obtains the precoded symbols bν, which are also binary, by a modulo–2 addition ("antivalence") between the symbols qν and KC⋅bν−NC: |
:$$q_\nu \in \{-1, +1\},\hspace{0.1cm} K_{\rm C} \in \{-1, | :$$q_\nu \in \{-1, +1\},\hspace{0.1cm} K_{\rm C} \in \{-1, | ||
+1\}\hspace{0.3cm}\Rightarrow \hspace{0.3cm}b_\nu \in \{-1, | +1\}\hspace{0.3cm}\Rightarrow \hspace{0.3cm}b_\nu \in \{-1, | ||
+1\}\hspace{0.05cm}.$$ | +1\}\hspace{0.05cm}.$$ | ||
− | * | + | *Like the source symbols $q_\nu$, the symbols $b_\nu$ are statistically independent of each other. Thus, the pre-encoder does not add any redundancy. However, it allows a simpler realization of the decoder and prevents error propagation after a transmission error.<br> |
− | * | + | *The actual encoding from binary (Mq=2) to ternary (M=Mc=3) is done by the "linear coding network" by the conventional subtraction |
:$$c(t) ={1}/{2} \cdot \big [b(t) - K_{\rm C} \cdot b(t- N_{\rm | :$$c(t) ={1}/{2} \cdot \big [b(t) - K_{\rm C} \cdot b(t- N_{\rm | ||
C}\cdot T)\big] \in \{-1, \ 0, +1\}\hspace{0.05cm},$$ | C}\cdot T)\big] \in \{-1, \ 0, +1\}\hspace{0.05cm},$$ | ||
− | : | + | :which can be described by the following [[Linear_and_Time_Invariant_Systems/System_Description_in_Time_Domain#Impulse_response|"impulse response"]] resp. [[Linear_and_Time_Invariant_Systems/System_Description_in_Frequency_Domain#Frequency_response_.E2.80.93_Transfer_function|"transfer function"]] with respect to the input signal b(t) and the output signal c(t): |
:$$h_{\rm C}(t) = {1}/{2} \cdot \big [\delta(t) - K_{\rm C} \cdot \delta(t- N_{\rm | :$$h_{\rm C}(t) = {1}/{2} \cdot \big [\delta(t) - K_{\rm C} \cdot \delta(t- N_{\rm | ||
C}\cdot T)\big] \ \ \ \circ\!\!-\!\!\!-\!\!\!-\!\!\bullet\ \ \ H_{\rm C}(f) ={1}/{2} \cdot \left [1 - K_{\rm C} \cdot {\rm e}^{- {\rm j}\hspace{0.05cm}\cdot\hspace{0.05cm} 2\pi \hspace{0.05cm}\cdot \hspace{0.05cm}N_{\rm C}\hspace{0.05cm}\cdot \hspace{0.05cm}T}\right]\hspace{0.05cm}. $$ | C}\cdot T)\big] \ \ \ \circ\!\!-\!\!\!-\!\!\!-\!\!\bullet\ \ \ H_{\rm C}(f) ={1}/{2} \cdot \left [1 - K_{\rm C} \cdot {\rm e}^{- {\rm j}\hspace{0.05cm}\cdot\hspace{0.05cm} 2\pi \hspace{0.05cm}\cdot \hspace{0.05cm}N_{\rm C}\hspace{0.05cm}\cdot \hspace{0.05cm}T}\right]\hspace{0.05cm}. $$ | ||
− | * | + | *The relative redundancy is the same for all pseudo-ternary codes. Substituting Mq=2, Mc=3 and Tc=Tq into the [[Digital_Signal_Transmission/Redundancy-Free_Coding#Symbolwise_coding_vs._blockwise_coding|"general definition equation"]], we obtain |
:rc=1−RqRc=1−TcTq⋅log2(Mq)log2(Mc)=1−TcTq⋅log2(Mc)⇒rc=1−1/log2(3)≈36.9%. | :rc=1−RqRc=1−TcTq⋅log2(Mq)log2(Mc)=1−TcTq⋅log2(Mc)⇒rc=1−1/log2(3)≈36.9%. | ||
{{BlaueBox|TEXT= | {{BlaueBox|TEXT= | ||
− | + | The $\text{transmitted signal of all pseudo-ternary codes}$ is always represented as follows: | |
:s(t)=+∞∑ν=−∞aν⋅g(t−ν⋅T). | :s(t)=+∞∑ν=−∞aν⋅g(t−ν⋅T). | ||
− | * | + | *The property of the current pseudo-ternary code is reflected in the statistical bonds between the aν In all cases aν∈{−1, 0,+1}. |
− | * | + | *The basic transmitting pulse g(t) provides on the one hand the required energy, but has also influence on the statistical bonds within the signal. |
− | * | + | *In addition to the NRZ rectangular pulse gR(t) can be selected in the program: |
− | :* | + | :*the Nyquist impulse ⇒ impulse response of the raised cosine low-pass with rolloff factor r: |
:gNyq(t)=const.⋅cos(π⋅r⋅t/T)1−(2⋅r⋅t/T)2⋅si(π⋅t/T) ∘−−−∙ GNyq(f), | :gNyq(t)=const.⋅cos(π⋅r⋅t/T)1−(2⋅r⋅t/T)2⋅si(π⋅t/T) ∘−−−∙ GNyq(f), | ||
− | :* | + | :*the root Nyquist impulse ⇒ impulse response of the root raised cosine lowpass with rolloff factor r: |
:g√Nyq(t) ∘−−−∙ G√Nyq(f)=const.⋅√GNyq(f). }} | :g√Nyq(t) ∘−−−∙ G√Nyq(f)=const.⋅√GNyq(f). }} | ||
<br><br> | <br><br> |
Revision as of 00:42, 23 March 2023
Open Applet in new Tab Deutsche Version Öffnen
Contents
Applet Description
Das Applet behandelt die Eigenschaften der bekanntesten Pseudoternärcodes, nämlich:
- Bipolarcode erster Ordnung bzw. AMI–Code (von: Alternate Mark Inversion), gekennzeichnet durch die Parameter NC=1, KC=+1,
- Duobinärcode, (DUOB), Codeparameter: NC=1, KC=−1,
- Bipolarcode zweiter Ordnung (BIP2), Codeparameter: NC=2, KC=+1.
Am Eingang liegt die redundanzfreie binäre bipolare Quellensymbolfolge ⟨qν⟩ ∈{+1,−1} ⇒ Rechtecksignal q(t) an. Verdeutlicht wird die Generierung
- der binär–vorcodierten Folge ⟨bν⟩ ∈{+1,−1}, dargestellt durch das ebenfalls redundanzfreie binäre bipolare Rechtecksignal b(t),
- der pseudoternären Codefolge ⟨cν⟩ ∈{+1, 0,−1}, dargestellt durch das redundante ternäre bipolare Rechtecksignal c(t),
- das gleichermaßen redundante ternäre Sendesignal s(t), gekennzeichnet durch die Amplitudenkoeffizienten aν, und den (Sende–) Grundimpuls g(t):
- s(t)=+∞∑ν=−∞aν⋅g(t−ν⋅T).
Der Grundimpuls g(t) – im Applet "Rechteck", "Nyquist" und "Wurzel–Nyquist" – bestimmt nicht nur die Form des Sendesignals, sondern auch den Verlauf
- der Autokorrelationsfunktion (AKF) φs(τ) und
- des zugehörigen Leistungsdichtespektrums (LDS) Φs(f).
Das Applet zeigt auch, dass das gesamte Leistungsdichtespektrum Φs(f) aufgeteilt werden kann in den Anteil Φa(f), der die statistischen Bindungen der Amplitudenkoeffizienten aν berücksichtigt, und das Energiedichtespektrum Φ∙g(f)=|G(f)|2, gekennzeichnet durch die Impulsform g(t).
Anmerkung: Im Applet wird kein Unterschied zwischen den Codersymbolen cν∈{+1, 0,−1} und den Amplitudenkoeffizienten aν∈{+1, 0,−1} gemacht. Dabei sollte nicht vergessen werden, dass die aν stets Zahlenwerte sind, während für die Codersymbole auch die Notation cν∈{Plus, Null, Minus} zulässig wäre.
Theoretical Background
General description of the pseudo-multilevel codes
In symbolwise coding, each incoming source symbol qν generates an encoder symbol cν, which depends not only on the current input symbol qν but also on the NC preceding symbols qν−1, ... , qν−NC. NC is referred to as the "order" of the code.
Typical for symbolwise coding is that
- the symbol duration T of the encoded signal (and of the transmitted signal) matches the bit duration TB of the binary source signal, and
- encoding and decoding do not lead to major time delays, which are unavoidable when block codes are used.
The "pseudo-multilevel codes" – better known as "partial response codes" – are of special importance. In the following, only "pseudo-ternary codes" ⇒ level number M=3 are considered.
- These can be described by the block diagram corresponding to the left graph.
- In the right graph an equivalent circuit is given, which is very suitable for an analysis of these codes.
One can see from the two representations:
- The pseudo-ternary encoder can be split into the "non-linear pre-encoder" and the "linear coding network", if the delay by NC⋅T and the weighting by KC are drawn twice for clarity – as shown in the right equivalent figure.
- The "non-linear pre-encoder" obtains the precoded symbols bν, which are also binary, by a modulo–2 addition ("antivalence") between the symbols qν and KC⋅bν−NC:
- qν∈{−1,+1},KC∈{−1,+1}⇒bν∈{−1,+1}.
- Like the source symbols qν, the symbols bν are statistically independent of each other. Thus, the pre-encoder does not add any redundancy. However, it allows a simpler realization of the decoder and prevents error propagation after a transmission error.
- The actual encoding from binary (Mq=2) to ternary (M=Mc=3) is done by the "linear coding network" by the conventional subtraction
- c(t)=1/2⋅[b(t)−KC⋅b(t−NC⋅T)]∈{−1, 0,+1},
- which can be described by the following "impulse response" resp. "transfer function" with respect to the input signal b(t) and the output signal c(t):
- hC(t)=1/2⋅[δ(t)−KC⋅δ(t−NC⋅T)] ∘−−−∙ HC(f)=1/2⋅[1−KC⋅e−j⋅2π⋅NC⋅T].
- The relative redundancy is the same for all pseudo-ternary codes. Substituting Mq=2, Mc=3 and Tc=Tq into the "general definition equation", we obtain
- rc=1−RqRc=1−TcTq⋅log2(Mq)log2(Mc)=1−TcTq⋅log2(Mc)⇒rc=1−1/log2(3)≈36.9%.
The transmitted signal of all pseudo-ternary codes is always represented as follows:
- s(t)=+∞∑ν=−∞aν⋅g(t−ν⋅T).
- The property of the current pseudo-ternary code is reflected in the statistical bonds between the aν In all cases aν∈{−1, 0,+1}.
- The basic transmitting pulse g(t) provides on the one hand the required energy, but has also influence on the statistical bonds within the signal.
- In addition to the NRZ rectangular pulse gR(t) can be selected in the program:
- the Nyquist impulse ⇒ impulse response of the raised cosine low-pass with rolloff factor r:
- gNyq(t)=const.⋅cos(π⋅r⋅t/T)1−(2⋅r⋅t/T)2⋅si(π⋅t/T) ∘−−−∙ GNyq(f),
- the root Nyquist impulse ⇒ impulse response of the root raised cosine lowpass with rolloff factor r:
- g√Nyq(t) ∘−−−∙ G√Nyq(f)=const.⋅√GNyq(f).
Eigenschaften des AMI-Codes
Die Pseudoternärcodes unterscheiden sich in den Parametern NC und KC. Der bekannteste Vertreter ist der Bipolarcode erster Ordnung mit den Codeparametern NC=1 und KC=1, der auch unter der Bezeichnung AMI–Code (von: Alternate Mark Inversion) bekannt ist.
Dieser wird zum Beispiel bei ISDN (Integrated Services Digital Networks) auf der so genannten S0–Schnittstelle eingesetzt.
Die Grafik zeigt oben das binäre Quellensignal q(t). Im zweiten und dritten Diagramm sind dargestellt:
- das ebenfalls binäre Signal b(t) nach dem Vorcodierer, und
- das Codersignal c(t)=s(t) des AMI–Codes.
Man erkennt das einfache AMI–Codierprinzip:
- Jeder Binärwert "-1" von q(t) ⇒ Symbol L wird durch den ternären Koeffizienten aν=0 codiert.
- Der Binärwert "+1" von q(t) ⇒ Symbol H wird alternierend mit aν=+1 und aν=−1 dargestellt.
Damit wird sichergestellt, dass im AMI–codierten Signal keine langen "+1"– und auch keine keine langen "–1"–Sequenzen enthalten sind, was bei einem gleichsignalfreien Kanal zu Problemen führen würde.
Dagegen ist das Auftreten langer Nullfolgen durchaus möglich, bei denen über einen längeren Zeitraum keine Taktinformation übertragen wird.
Um dieses zweite Problem zu vermeiden, wurden einige modifizierte AMI–Codes entwickelt, zum Beispiel der B6ZS–Code und der HDB3–Code:
- Beim HDB3–Code (grüne Kurve in obiger Grafik) werden vier aufeinanderfolgende Nullen im AMI–codierten Signal durch eine Teilsequenz ersetzt, die die AMI–Codierregel verletzt.
- Im grau hinterlegten Bereich ist dies die Folge "+ 0 0 +", da das letzte Symbol vor der Ersetzung ein "Minus" war.
- Damit ist beim HDB3–Code die Anzahl aufeinanderfolgender Nullen auf 3 begrenzt und beim B6ZS–Code auf 5.
- Der Decoder erkennt diese Codeverletzung und ersetzt "+ 0 0 +" wieder durch "0 0 0 0".
Zur AKF–Berechnung eines Digitalsignals
In der Versuchsdurchführung werden einige Größen und Zusamenhänge verwendet, die hier kurz eräutert werden sollen:
- Das (zeitlich unbegrenzte) Digitalsignal beinhaltet sowohl die Quellenstatistik (Amplitudenkoeffizienten aν) als auch die Sendeimpulsform g(t):
- s(t)=+∞∑ν=−∞aν⋅g(t−ν⋅T).
- Ist s(t) die Musterfunktion eines stationären und ergodischen Zufallsprozesses, so gilt für die Autokorrelationsfunktion (AKF):
- φs(τ)=E[s(t)⋅s(t+τ)]=+∞∑λ=−∞1/T⋅φa(λ)⋅φ∙gs(τ−λ⋅T).
- Diese Gleichung beschreibt die Faltung der diskreten AKF φa(λ)=E[aν⋅aν+λ] der Amplitudenkoeffizienten mit der Energie–AKF des Grundimpulses:
- φ∙g(τ)=∫+∞−∞g(t)⋅g(t+τ)dt.
- Der Punkt soll darauf hinweisen, dass φ∙g(τ) die Einheit einer Energie besitzt, während φs(τ) eine Leistung angibt und φa(λ) dimensionslos ist.
Zur LDS-Berechnung eines Digitalsignals
Die Entsprechungsgröße zur AKF ist im Frequenzbereich das Leistungsdichtespektrum (LDS) Φs(f), das mit φs(τ) über das Fourierintegral fest verknüpft ist:
- φs(τ)∘−−−∙Φs(f)=∫+∞−∞φs(τ)⋅e−j2πfτdτ.
- Das Leistungsdichtespektrum Φs(f) kann unter Berücksichtigung der Dimensionsbereinigung (1/T) als Produkt zweier Funktionen dargestellt werden:
- Φs(f)=Φa(f)⋅1/T⋅|Gs(f)|2.
- Der erste Term Φa(f) ist dimensionslos und beschreibt die spektrale Formung des Sendesignals durch die statistischen Bindungen der Quelle:
- φa(λ)∘−−−∙Φa(f)=+∞∑λ=−∞φa(λ)⋅e−j2πfλT=φa(0)+2⋅∞∑λ=1φa(λ)⋅cos(2πfλT).
- Φ∙g(f) berücksichtigt die spektrale Formung durch g(t). Je schmaler dieser ist, desto breiter ist |G(f)|2 und um so größer ist damit der Bandbreitenbedarf:
- φ∙g(τ)∘−−−∙Φ∙g(f)=|G(f)|2.
- Das Energiedichtespektrum Φ∙g(f) hat die Einheit Ws/Hz und das Leistungsdichtespektrum Φs(f) nach der Division durch den Symbolabstand T die Einheit W/Hz.
Leistungsdichtespektrum des AMI-Codes
Der Frequenzgang des linearen Codiernetzwerks eines Pseudoternärcodes lautet allgemein:
- HC(f)=1/2⋅[1−KC⋅e−j⋅2π⋅f⋅NC⋅T]=1/2⋅[1−K⋅e−j⋅α].
Damit ergibt sich für das Leistungsdichtespektrum (LDS) der Amplitudenkoeffizienten (K und α sind Abkürzungen entsprechend obiger Gleichung):
- Φa(f)=|HC(f)|2=[1−Kcos(α)+j⋅Ksin(α)][1−Kcos(α)−j⋅Ksin(α)]4=...=1/4⋅[2−2⋅K⋅cos(α)]
- ⇒Φa(f)=|HC(f)|2=1/2⋅[1−KC⋅cos(2πfNCT)]∙−−−∘φa(λ⋅T).
Insbesondere erhält man für das Leistungsdichtespektrum (LDS) des AMI–Codes (NC=KC=1):
- Φa(f)=1/2⋅[1−cos(2πfT)]=sin2(πfT).
Die Grafik zeigt
- das LDS Φa(f) der Amplitudenkoeffizienten (rote Kurve), und
- das LDS Φs(f) des gesamten Sendesignals (blau), gültig für NRZ–Rechteckimpulse.
Man erkennt aus dieser Darstellung
- die Gleichsignalfreiheit des AMI–Codes, da Φa(f=0)=Φs(f=0)=0 ist,
- die Leistung PS=s20/2 des AMI–codierten Sendesignals (Integral über Φs(f) von −∞ bis +∞).
Hinweise:
- Das LDS von HDB3– und B6ZS–Code weicht von dem des AMI–Codes nur unwesentlich ab.
- Die hier behandelte Thematik können Sie sich mit dem interaktiven Applet Signale, AKF und LDS der Pseudoternärcodes verdeutlichen.
Eigenschaften des Duobinärcodes
Der Duobinärcode ist durch die Codeparameter NC=1 und KC=−1 festgelegt. Damit ergibt sich für das Leistungsdichtespektrum (LDS) der Amplitudenkoeffizienten bzw. für das LDS des Sendesignals:
- Φa(f)=1/2⋅[1+cos(2πfT)]=cos2(πfT),
- Φs(f)=s20⋅T⋅cos2(πfT)⋅si2(πfT)=s20⋅T⋅si2(2πfT).
Die Grafik zeigt das Leistungsdichtespektrum
- der Amplitudenkoeffizienten ⇒ Φa(f) als rote Kurve,
- des gesamten Sendsignals ⇒ Φs(f) als blaue Kurve.
In der zweiten Grafik sind die Signale q(t), b(t) und c(t)=s(t) skizziert. Wir verweisen hier wieder auf das Applet Signale, AKF und LDS der Pseudoternärcodes, das auch die Eigenschaften des Duobinärcodes verdeutlicht.
Aus diesen Darstellungen geht hervor:
- Beim Duobinärcode können beliebig viele Symbole mit gleicher Polarität ("+1" bzw. "–1") direkt aufeinanderfolgen.
- Deshalb gilt Φa(f=0)=1 und Φs(f=0)=1/2⋅s20⋅T.
- Dagegen tritt beim Duobinärcode die alternierende Folge " ... , +1, –1, +1, –1, +1, ... " nicht auf, die hinsichtlich Impulsinterferenzen besonders störend ist.
- Deshalb gilt beim Duobinärcode: Φs(f=1/(2T)=0.
- Das Leistungsdichtespektrum Φs(f) des pseudoternären Duobinärcodes ist identisch mit dem LDS bei redundanzfreier Binärcodierung mit halber Rate (Symboldauer 2T).
Exercises
- First, select the number (1, 2,... ) of the task to be processed. The number "0" corresponds to a "Reset": Same setting as at program start.
- A task description is displayed. The parameter values are adjusted. Solution after pressing "Show Solution".
(1) Consider and interpret the binary pre–coding of the AMI code using the source symbol sequence C assuming b0=+1.
- The modulo–2 addition can also be taken as "antivalence". It holds bν=+1, if qν and bν−1 differ, otherwise set bν=−1 :
- b1=(q1=+1) XOR (b0=+1)=−1, b2=(q2=−1) XOR (b1=−1)=−1, b3=(q3=−1) XOR (b2=−1)=−1,
- b4=(q4=+1) XOR (b3=−1)=+1, b5=(q5=+1) XOR (b4=+1)=−1, b6=(q6=+1) XOR (b5=−1)=+1, b7=b8=...=−1.
- With the initial condition b0=−1 we get the negated sequence: b4=b6=−1. All others bν=+1.
(2) Let b0=+1. Consider the AMI encoded sequence ⟨cν⟩ of the source symbol sequence C and give their amplitude coefficients aν.
- It holds: a1=0.5⋅(b1−b0)=−1, a2=0.5⋅(b2−b1)=0, a3=0.5⋅(b3−b2)=0, a4=+1, a5=−1, a6=+1, a7=−1, a8=a9=...=0.
- In contrast to the pre–coding, the conventional addition (subtraction) is to be applied here and not the modulo–2 addition.
(3) Now consider the AMI coding for several random sequences. What rules can be derived from these experiments for the amplitude coefficients aν ?
- Each binary value "–1" of q(t) ⇒ symbol L is encoded by the ternary coefficient aν=0. Any number of aν=0 can be consecutive.
- The binary value "+1" of q(t) ⇒ symbol H is represented alternatively with aν=+1 and aν=−1 , starting with aν=−1, if b0=+1.
- From the source symbol sequence A ⇒ ⟨qν≡+1⟩ the code symbol sequence +1,−1,+1,−1,... . Long sequences ⟨aν≡+1⟩ or ⟨aν≡−1⟩ are shot out.
(4) Continue with AMI coding. Interpret the autocorrelation function φa(λ) of the amplitude coefficients and the power density spectrum Φa(f).
- The discrete ACF φa(λ) of the amplitude coefficients is only defined for integer λ values. With AMI coding (NC=1) holds: For |λ|>1 ⇒ all φa(λ)=0.
- φa(λ=0) is equal to the root mean square of the amplitude coefficients ⇒ φa(λ=0)=Pr(aν=+1)⋅(+1)2+Pr(aν=−1)⋅(−1)2=0.5.
- Only the combinations (+1,−1) and (−1,+1) contribute to the expected value E[aν⋅aν+1] Result: φa(λ=±1)=E[aν⋅aν+1]=−0.25.
- The power density spectrum Φa(f) is the Fourier transform of the discrete ACF φa(λ). Result: Φa(f)=1/2⋅[1−cos(2πfT)]=sin2(πfT).
- From Φa(f=0)=0 follows: The AMI code is especially interesting for channels over which no DC component can be transmitted.
(5) We consider further AMI coding and rectangular pulses. Interpret the ACF φs(τ) of the transmission signal and the PDS Φs(f).
- φs(τ) results from the convolution of the discrete AKF φa(λ) with φ∙g(τ). For rectangular pulses (duration T): The energy–AKF φ∙g(τ) is a triangle of duration 2T.
- It holds φs(τ=0)=φa(λ=0)=0.5, φs(±T)=φa(1)=−0.25, , φs(±2T)=φa(2)=0. Between these discrete values, φs(τ) is always linear.
- The PDS Φs(f) is obtained from Φa(f)=sin2(πfT) by multiplying with Φ∙g(f)=sinc2(fT). This does not change anything at the zeros of Φa(f) .
(6) What changes with respect to s(t), φs(τ) and Φs(f) with the Nyquist pulse? Vary the roll–off factor here in the range 0≤r≤1.
- A single Nyquist pulse can be represented with the source symbol sequence B in the s(t) range. You can see equidistant zero crossings in the distance T.
- Also, for any AMI random sequence, the signal values s(t=ν⋅T) for each r correspond exactly to their nominal positions. Outside these points, there are deviations.
- In the special case r=0 the energy–LDS Φ∙g(f) is constant in the range |f|<1/2T. Accordingly, the energy–ACF φ∙g(τ) has a sinc shape.
- On the other hand, for larger r the zeros of φ∙g(τ) are no longer equidistant, since although G(f) satisfies the first Nyquist criterion, it does not Φ∙g(f)=[G(f)]2.
- The main advantage of the Nyquist pulse is the much smaller bandwidth. Here only the frequency range |f|<(1+r)/(2T) has to be provided.
(7) Repeat the last experiment using the Root raised cosine pulse instead of the Nyquist pulse. Interpret the results.
- In the special case r=0 the results are as in (6). Φ∙g(f) is constant in the range |f|<1/2T and outside zero; φ∙g(τ) has a sinc shape.
- Also for larger r the zeros of φ∙g(τ) are eqidistant (but not sinc shaped) ⇒ Φ∙g(f)=[G(f)]2 satisfies the first Nyquist criterion.
- On the other hand, G(f) does not satisfy the first Nyquist criterion (except for r=0). Intersymbol interference occurs already at the transmitter ⇒ signal s(t).
- But this is also not a fundamental problem. By using an identically shaped reception filter like G(f) intersymbol interference at the decider is avoided.
(8) Consider and check the pre–coding (bν) and the amplitude coefficients (aν) with the duobinary coding (source symbol sequence C, b0=+1).
- b1=(q1=+1) XOR (¯b0=−1)=+1, b2=(q2=−1) XOR (¯b1=−1)=−1, b3=...=b7=+1, b8=b10=...=−1, b9=b11=...=+1.
- a1=0.5⋅(b1+b0)=+1, a2=0.5⋅(b2+b1)=0, a3=0.5⋅(b3+b2)=0, a4=...=a7=+1, a8=a9=...=0.
- With the starting condition b0=−1 we get again the negated sequence: a1=−1, a2=a3=0, a4=...=a7=−1, a8=a9=...=0.
(9) Now consider the Duobinary coding for several random sequences. What rules can be derived from these experiments for the amplitude coefficients aν?
- The discrete ACF values are φa(λ=0)=+0.5, φa(λ=1)=+0.25, φa(λ=2)=0 ⇒ Φa(f)=1/2⋅[1+cos(2πfT)]=cos2(πfT).
- Unlike the AMI coding, the encoded sequences ⟨aν≡+1⟩ and ⟨aν≡−1⟩ are possible here ⇒ For the Duobinary code holds Φa(f=0)=1 (≠0).
- As with the AMI code, the "long zero sequence" ⇒ ⟨aν≡0⟩ is possible, which can again lead to synchronization problems.
- Excluded are the combinations aν=+1, aν+1=−1 and aν=−1, aν+1=+1, recognizable by the PDS value Φa(f=1/(2T))=0.
- Such direct transitions aν=+1 ⇒ aν+1=−1 resp. aν=−1 ⇒ aν+1=+1 lead to large intersymbol interference and thus to a higher error rate.
(10) Compare the coding results of second order bipolar code (BIP2) and first order bipolar code (AMI) for different source symbol sequences.
- For a single rectangular pulse ⇒ source symbol sequence B both codes result in the same encoded sequence and the same encoded signal c(t) ⇒ also an isolated pulse.
- The "Permanent–One sequence" A now results ⟨cν⟩=⟨−1,−1,+1,+1,−1,−1,+1,+1,. ..⟩ instead of ⟨cν⟩=⟨−1,+1,−1,+1,−1,+1,...⟩.
- The simple decoding algorithm of the AMI code (the ternary 0 becomes the binary −1, the ternary ±1 becomes the binary +1) cannot be applied to BIP2 .
(11) View and interpret the various ACF and LDS graphs of the BIP2 compared to the AMI code.
- For AMI: φa(λ=±1)=−0.25, φa(λ=±2)=0. For BIP2: φa(λ=±1)=0, φa(λ=±2)=−0.25. In both cases: φa(λ=0)=0.5.
- From the AMI power density spectrum Φa(f)=sin2(π⋅fT) follows for BIP2: Φa(f)=sin2(2π⋅fT) by compression with respect to the f–axis.
- Zero at f=0: At most two +1 directly follow each other, and also at most only two −1. In the AMI code +1 and −1 occur only in isolation.
- Next zero at f=1/(2T): The infinitely long (+1,−1) sequence is excluded in BIP2 as in the Duobinary code.
- Consider and interpret also the functions φs(τ) and Φs(f) for the pulses "rectangle", "Nyquist" and "Root raised cosine".
Applet Manual
(A) Theme (veränderbare grafische Oberflächengestaltung)
- Dark: schwarzer Hintergrund (wird von den Autoren empfohlen)
- Bright: weißer Hintergrund (empfohlen für Beamer und Ausdrucke)
- Deuteranopia: für Nutzer mit ausgeprägter Grün–Sehschwäche
- Protanopia: für Nutzer mit ausgeprägter Rot–Sehschwäche
(B) Zugrundeliegendes Blockschaltbild
(C) Auswahl des Pseudoternörcodes:
AMI–Code, Duobinärcode, Bipolarcode 2. Ordnung
(D) Auswahl des Grundimpulses g(t):
Rechteckimpuls, Nyquistimpuls, Wurzel–Nyquistimpuls
(E) Rolloff–Faktor (Frequenzbereich) für "Nyquist" und "Wurzel–Nyquist"
(F) Einstellung von 3⋅4=12 Bit der Quellensymbolfolge
(G) Auswahl einer drei voreingestellten Quellensymbolfolgen
(H) Zufällige binäre Quellensymbolfolge
( I ) Schrittweise Verdeutlichung der Pseudoternärcodierung
(J) Ergebnis der Pseudoternärcodierung: Signale q(t), b(t), c(t), s(t)
(K) Löschen der Signalverläufe im Grafikbereich M
(L) Skizzen für Autokorrelationsfunktion & Leistungsdichtespektrum
(M) Grafikbereich: Quellensignal q(t), Signal b(t) nach Vorcodierung,
Codersignal c(t) mit Rechtecken, Sendesignal s(t) gemäß g(t)
(N) Bereich für Übungen: Aufgabenauswahl, Fragen, Musterlösung
About the Authors
This interactive calculation tool was designed and implemented at the Institute for Communications Engineering at the Technical University of Munich.
- The first version was created in 2010 by Stefan Müller as part of his diploma thesis with “FlashMX – Actionscript” (Supervisor: Günter Söder).
- In 2020 the program was redesigned by Carolin Mirschina as part of her bachelor thesis (Supervisor: Tasnád Kernetzky ) via "HTML5".
- Last revision and English version 2021 by Carolin Mirschina in the context of a working student activity.
The conversion of this applet to HTML 5 was financially supported by "Studienzuschüsse" (Faculty EI of the TU Munich). We thank.