Benutzer-Werkzeuge

Webseiten-Werkzeuge


pc:nummernschalterpruefer

Telefon- Nummernschalter mit dem Raspberry Pi prüfen

Falls man sich z.B. einen MFV-Konverter gebaut hat und der aber nicht so richtig funktionieren will, dann kann das schnell daran liegen, das der Nummernschalter nicht die Impulsfolgen produziert, die der IWV→MFV Konverter erwartet - so auch in meinem Fall, und auch wenn ich am Ende mit meinem Konverter gescheitert bin, so ist dabei immerhin ein Prüfprogramm abgefallen, was noch nicht so ganz rund läuft, aber wenigstens einen ersten Eindruck vermitteln kann, in wie weit der Nummernschalter sich überhaupt noch rührt.

Anforderungen

Das Programm ist für den Raspberry geschrieben, weil dieser mit seinen GPIOs die notwendigen Anschlüße für den Nummernschalter gleich frei Haus mitliefert.

Installation

Aktuell ist das Programm auf GPIO24 (Pin18) und den Masseanschluß gleich daneben (GND, Pin 20) konfiguriert. An diese beiden Pins schliesst man den NSI und NSA in Reihe an.

Weiterhin lädt man das folgende Programm auf den Raspi und startet es mit

python3 nummernschalterpruefer.py
nummernschalterpruefer.py
#!/usr/bin/python
 
# sudo apt-get install python3-rpi.gpio
from RPi import GPIO
from datetime import datetime
import time
 
ss = 0 # start time stamp
ls = 0 # last time stamp 
 
# returns the elapsed milliseconds since the start of the program
def millis():
    dt = datetime.now() 
    ms =  dt.minute * 60 *1000 + dt.second * 1000 + dt.microsecond / 1000
    return int(ms)
 
def mark(tick):
    print("\t", end="")
    for i in range(tick):
        if i > 100:
            break
        if i == 34:
            print (">", end="")
        elif i== 42:
            print ("<", end="")
        elif i== 56:
            print (">", end="")
        elif i== 68:
            print ("<", end="")
        elif i== 100:
            print ("%", end="")
        else:
            print (".", end="")
    print()
 
 
 
 
channel = 24
GPIO.setmode(GPIO.BCM)
GPIO.setup(channel, GPIO.IN, pull_up_down=GPIO.PUD_UP)
 
 
def main():
    global ss,ls,channel
    try:
        while True:
            success = GPIO.wait_for_edge(channel, GPIO.FALLING, timeout = 50)
            if success is None:
                continue
            print("start")
            ss=0
            while not success is  None:
                ls = millis() 
                if ss == 0:
                    ss= ls
                # wait for up to 5 seconds for a rising edge (timeout is in milliseconds)
                success = GPIO.wait_for_edge(channel, GPIO.RISING, timeout=1000)
                ts1 = millis()
 
                print ('H {} {} ' . format(ts1-ss, ts1-ls), end="")
                mark(ts1-ls)
                ls = ts1
                if not success is None:
                    success = GPIO.wait_for_edge(channel, GPIO.FALLING, timeout=1000)
                    if not success is None:
                        ts2 = millis()
                        print ('L {} {} ' . format(ts2-ss, ts2-ls), end="" )
                        mark(ts2-ls)
 
    except KeyboardInterrupt: # does not work if it runs in background.
        print ("\nQuit")
 
if __name__ == '__main__':
    main()
    GPIO.cleanup()

Die Ausgabe

Das Programm versucht die einzelnen Flanken zu erkennen und zeigt ihre Länge in Millisekunden an. Der besseren Optik wegen werden die Längen auch als Punkte ausgegeben, wobei dabei dann die standardisierten Impulslängen von 62ms und 38 ms +/- 10% durch < und > optisch angezeigt werden.

Bekannte Probleme

Die GPIO-Library ist nicht besonders gut dafür geeignet, Pin- Änderungen mit Timestamps zu koppeln, wenn Schalterprellen mit im Spiel ist. Wartet man nämlich auf eine beliebige Flanke, dann sagt einem die Funktion nicht, welche Art Flanke nun getriggert hat. Die muß man dann erst separat abfragen, aber die kann sich natürlich durchs Schalterprellen in der Zwischenzeit schon wieder geändert haben. Wartet man jedoch auf bestimmte Flanken, dann hängt man auf einmal voll im Schalterprellen, denn wenn man den zusätzliche Bounce-Parameter benutzt, dann ist man mit der Entprellzeit schon schnell im Toleranzbereich des Nummernschalter-Signals selber, und dementsprechend verschlechtert sich dann auch die Genauigkeit der Anzeige und damit die Aussagekraft der ganzen Messung. Darum ist das Programm in seiner jetzigen Form nur ein Hilfsmittel, aber noch kein echt verläßliches Messinstrument.

pc/nummernschalterpruefer.txt · Zuletzt geändert: 2020/02/01 12:38 von admin