Root-Raised-Cosine-Filter

aus Wikipedia, der freien Enzyklopädie

Das Root-Raised-Cosine-Filter, abgekürzt RRC-Filter, ist ein in der digitalen Signalverarbeitung angewandtes elektronisches Filter, welches zur Formung von Signalimpulsen zur Übertragung über einen Kanal, wie beispielsweise einen Funkkanal, verwendet wird.

Allgemeines

Das Root-Raised-Cosine-Filter entspricht der Wurzel (engl. root) aus dem Raised-Cosine-Filter und dient dazu, die Charakteristik des Raised-Cosine auf Sender und Empfänger gleichmäßig zu verteilen. Es stellt dann ein so genanntes Matched Filter dar und maximiert im Empfänger das Signal-Rausch-Verhältnis. Eine Besonderheit ist, dass ein Root-Raised-Cosine-Filter für sich alleine Intersymbolinterferenz (ISI) aufweist, das heißt die einzelnen Sendeimpulse „fließen“ am Übertragungskanal zeitlich ineinander. Erst die Kombination der beiden RRC-Filter bei Sender und Empfänger ergeben zusammen über die gesamte Strecke im Idealfall eine ISI-freie Übertragungsstrecke, welche eine zeitliche Unterscheidung der einzelnen Impulse erlaubt. Die einzelnen RRC-Impulse stehen orthogonal zueinander.

Das Root-Raised-Cosine-Filter ist neben dem Gauß-Filter eines der am häufigsten eingesetzten Filter zur Impulsformung bei digitalen Übertragungssystemen.

Übertragungsfunktion

Impulsantwort h(t) eines RRC für verschiedene roll-off-Faktoren β

Der Betragsverlauf der Übertragungsfunktion Hrrc(jω) eines RRC-Filters ist gegeben durch:

wobei Hrc(jω) die Übertragungsfunktion des Raised-Cosine-Filters darstellt.

Die Impulsantwort h(t) eines RRC-Filters ist durch den Roll-off-Faktor β, welcher die Bandbreite bestimmt, und die Dauer eines Sendesymbols Ts gekennzeichnet und besitzt folgende Form:

Beispiel-Implementierung

Nachfolgend findet sich eine Beispiel-Implementierung des RRC-Filters in Python mit Hilfe von NumPy, wobei die dafür verwendete Formel aus[1] entnommen wurde.

import numpy as np


def rrcosfilter(N, beta, Ts, Fs):
    """
    Erzeugt ein Root-Raised-Cosine-Filter, welches symmetrisch zum Mittelpunkt
    verläuft.
    Parameter:
    -----------
    N : int
        Anzahl der Filterpunkte.
    beta : float
        Roll-Off Faktor im Intervall [0, 1].
    Ts : float
        Die Symbolperiode (inverse der Symbolrate) in Sekunden.
    Fs : float
        Die Abtastrate in Hertz.
    Rückgabe:
    -----------
    h_rcc : numpy.ndarray
        Die Impulsantwort des Filters als NumPy-Array.
    """

    T_delta = 1/float(Fs)
    sample_num = np.arange(N)
    h_rrc = np.zeros(N, dtype=float)

    for x in sample_num:
        t = (x-N/2)*T_delta
        if t == 0.0:
            scaling = 1/np.sqrt(Ts)
            equation = 1-beta+(4*beta/np.pi)
            h_rrc[x] = scaling * equation
        elif beta != 0 and t == (Ts/(4*beta) or -Ts/(4*beta)):
            scaling = beta/np.sqrt(2*Ts)
            equation = (1+(2/np.pi))*np.sin(np.pi/(4*beta)) + (1-2/np.pi)*np.cos(np.pi/(4*beta))
            h_rrc[x] = scaling * equation
        else:
            scaling = 1/np.sqrt(Ts)
            numerator = np.sin(np.pi*(1-beta)*t/Ts) + (4*beta*t/Ts)*np.cos(np.pi*(1+beta)*t/Ts)
            denominator = (np.pi*t/Ts)*(1-np.square(4*beta*t/Ts))
            equation = numerator / denominator
            h_rrc[x] = scaling * equation
    return h_rrc

sample_rrc = rrcosfilter(N=189, beta=0.22, Ts=1e-5, Fs=100e6)

Literatur

  • John G. Proakis, Masoud Salehi: Communication Systems Engineering. 2. Auflage. Prentice Hall, Upper Saddle River NJ 2002, ISBN 0-13-095007-6.
  • John B. Anderson: Digital Transmission Engineering. 2. Auflage. Wiley-Interscience, 2005, ISBN 0-471-69464-9, S. 26–30.

Einzelnachweise

  1. John B. Anderson: Digital transmission engineering. Piscataway, New Jersey 2005, ISBN 1-280-31132-0.