projekte:vector_graphics_adapter

Vektorgrafikausgabe über den VGA Port auf Oszilloskop

Vektorgrafik auf dem Oszilloskop dürfte so alt sein wie der X/Y-Modus. Neben Lissajous-Figuren erfreut sich die Soundkarte als Quelle für Oszilloskop-Vektorgrafik einiger beliebtheit. Dabei werden linker und rechter Kanal mit der X bzw. Y Auslenkung des Oszilloskops verbunden und bewegen so den Elektronenstrahl im analogen Oszilloskop.

Eine Soundkarte ist im Prinzip ein Digital-Analog Wandler, hat jedoch Tiefpassfilter welche zwar die Audio-Qualität erhöhen, aber die Geschwindigkeit mit welcher der Elektronenstrahl bewegt werden kann eng limitiert. Außerdem sind in der Regel Koppelkondensatoren verbaut, welche den für Lautspecher schädlichen Gleichstromanteil entfernen. Dadurch verliert die Grafik jedoch den Nullpunkt und wabert um den Mittelpunkt aller Vektoren falls sie nicht gut auf diese Gegebenheiten angestimmt wird.

Mehr Vektorausgabe über VGA Doch der PC besitzt ja meist noch einen weiteren Digital-Analog-Wandler: Den VGA Anschluss. Eigendlich für Raster-Grafik gedacht, lässt er sich prima zur Ausgabe von Vektorgrafik zweckentfremden. Von den 3 analogen Kanälen (Rot, Grün und Blau) werden zwei genutzt um den Elektronenstrahl des Oszilloskops in X bzw. Y Richtug auszulenken. Der VGA-Port kann die Bilddaten auch mit sehr hoher Geschwindigkeit (> 100MHz) ausgeben, davon kann man bei Soundkarten nur träumen. Auch stöhrende Ausgangsfilter gibt es nicht. Damit ist er fast ideal für komplexe Vektor-Darstellungen geeignet.

Verbindung VGA-Port mit Oszilloskop

  • VGA Pin 1 (Rot) mit dem Horizontal Eingang (Meist Ch2) des Oszilloskops verbinden.
  • VGA Pin 2 (Grün) mit dem Vertikal (Y) Eingang (Meist Ch1) des Oszilloskops verbinden.
  • Massen von PC und Oszilloskop verbinden.
  • Die Vektorisierung ist als mpv video filter implementiert.
  • Das Video (oder Bild) wird mittels Canny Kantenerkennung in ein Kantenbild umgerechnet.
    • Dazu habe ich in einen mpv fork den OpenCV-Canny Algorithmus als Video Filter eingebaut (-vf canny)
    • Alternativ kann der edgedetect Filter aus ffmpeg/libavfilter verwendet werden (-vf lavfi=edgedetect)
  • Anschließend wird ein weiterer Videofilter nachgeschaltet, welcher das Kantenbild in eine Vektorfolge umrechnet. (-vf vector).
    • Dieser Filter basiert auf dem OpenCV FindContours funktion, welche die Kanten als Vektor-Pfad extrahiert.
  • Der Vektorpfad wird anschließend als „Vektorbild“ ausgegben, dabei entspicht Rot dem X und Grün dem Y Wert des Vektors. Die im Vektorbild verfügbaren Pixel werden auf die Vektoren anteilsmäßig aufgeteilt.
  • Der ffmpeg edgedetect Filter liefert einen Intensitätswert, welcher die Ausgeprägtheit der Kante repräsentiert.
    • Bei der Umsetzung in das Vektorbild wird dies berücksichtigt indem der Anteil an der Koordinaten an der Ausgabezeit entsprechend angepasst wird.
    • Je kleiner der Anteil desto schneller überstreicht der Elektronenstrahl die Kante und desto dunkler erscheint Sie.
    • Damit ist es möglich die Helligkeit auch ohne Z-Eingang verändern.
  • In der unteren linken Ecke (0,0) erscheint ein heller Punkt, dies ist eine Folge der Austastlücken („H/V-Blank“).
    • Um den Phosphor des Oszilloskop zu schonen sollte dieser außerhalb des sichtbaren Bereiches der Röhre bewegt werden.
  • Beispiel „Vektor“-Bild zur Ausgabe auf dem VGA-Port: Ausgabe-Bild zur Anzeige auf dem "Vektor"-Bildschirm.
  • Zunächst das VGA Timing so einstellen das möglichst wenig störende H-Blanks erzeugt werden:
    xrandr --newmode scope 26.7  2048 2049 2060 2060 200 200 216 216 +hsync +vsync
    xrandr --addmode VGA1 scope
    xrandr --output VGA1 --mode scope --right-of <HAUPTBILDSCHIRM>
  • ffmpeg (libav besitzt den edgedetect filter nicht)
  • opencv
  • Modifizierter mpv media player: git clone https://github.com/da1l6/mpv
  • Beispielaufruf:
    • Mit ffmpeg Kantenerkennung:
      /pfad/zu/build/mpv --fs --geometry=<BREITE-HAUPTBILDSCHIRM>:0 --loop --vf scale=576:512,lavfi=[edgedetect=high=0.04:low=0.03],vector:width=2048:height=200 <VIDEO>
    • Mit openCV Kantenerkennung:
      /pfad/zu/build/mpv --fs --geometry=<BREITE-HAUPTBILDSCHIRM>:0 --loop --vf scale=576:512,canny:t1=128:t2=130,vector:width=2048:height=200 <VIDEO>
    • Die optimalen werte für t1 (bzw. low) und t2 (bzw. high) können je nach Material variieren. Einfach ausprobieren.
    • Der Canny-Algorithmus ist sehr Rechenintensiv, deshalb wird das Bild zuerst mit –vf scale:w:h herunterskaliert.

TV-Testbild Rastergrafik auf Scope ohne Z-Eingang

Der bei der Vektorgrafik benutzte Trick zur Helligkeitsänderung kann benutzt werden um Rastergrafik auszugeben.

Dabei werden die X/Y-Koordinaten (R/G-Farbkanäle) kontinuierlich so erhöht, das der Oszilloskop-Bildschirm zeilenweise überstrichen wird, wie bei einem Raster Monitor.

Helligkeitsunterschiede werden mittels Geschwindigkeitsänderung erzeugt. Helle Breiche werden langsamer überstrichen als dunkle indem die entsprechnden Koordinaten im „Vektorbild“ öfter wiederholt werden.

/pfad/zu/build/mpv --fs --geometry=<BREITE-HAUPTBILDSCHIRM>:0 --loop --vf scale=256:256,vectorraster:width=2048:height=300 <VIDEO>

Super Mario Bros. 1 auf Scope mpv kann mit Hilfe von ffmpeg den Bildschirminhalt aufzeichnen. Damit lassen sich (z.B. Spiele) auf dem Oszilloskop darstellen.

Das funktioniert prinzipiell sowohl im Raster als auch im reinen Vektorgrafikmodus. Das bild Rechts ist mit dem Rastergrafik modus entstanden.

/path/to/build/mpv av://x11grab::0 --demuxer-lavf-o='video_size=<BREITE>x<HÖHE>,grab_y=<XPOS>,grab_x=<YPOS>,framerate=30' ...

Video Eingänge wie TV-Karten oder Webcams lassen sich auch abgreifen:

/path/to/build/mpv tv:// ...

Wer kein analoges Oszilloskop sein eigen nennt kann auch ein modernes digitales Oszilloskop verwenden, allerdings sind die Darstellungsergebnisse deutlich schlechter. Insbesondere der Rastergrafik-Modus ist kaum zu verwenden.

Die Ursache liegt darin, dass digitale Oszilloskope periodisch das Eingangssignal abtasten und dann an der zu den gemessenen Spannungen passenden Stelle einen Punkt zeichnen, welcher aber immer die selbe Helligkeit hat. Da das Abtasten nicht synchron zum Pixeltakt des VGA-Ports ist, werden auch viele Zwischenwerte im Übergang zwischen zwei Pixeln gemessen. Dies führt zu starkem „Rauschen“ auf dem Bild.

DSO zur Darstellung DSO zur Darstellung

DSO Tipps:

  • Eine hohe Bildwiederhohlrate einstellen (z.B. 120Hz) um den Pixeltakt zu erhöhen und damit die Zeit „zwischen“ den Pixeln zu reduzieren.
  • Ein möglichst breites Seitenverhältniss verwenden um wenig H-Blanks zu haben (ist immer gut).
  • Geringe Speichertiefe einstellen (e.g. ~7kPoints).
  • Mit der Samplerate rumspielen bis so wenig „rauschen“ wie möglich sichtbar ist.
  • projekte/vector_graphics_adapter.txt
  • Zuletzt geändert: 2017/03/01 19:19
  • von 127.0.0.1