AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Chart-Komponente die 1000 Werte / sec verträgt

Ein Thema von DelphiManiac · begonnen am 17. Jun 2012 · letzter Beitrag vom 18. Jun 2012
Antwort Antwort
Seite 1 von 2  1 2      
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#1

Chart-Komponente die 1000 Werte / sec verträgt

  Alt 17. Jun 2012, 19:41
Hallo,

ich habe folgende Anforderung und hoffe ihr könnt mir helfen.
Ich habe ein Messgerät, dass mir jede ms einen Wert übermittelt, diesen will ich in einer Plot / Graph Komponente darstellen.
Jetzt meine Frage, kennt ihr Graphen die damit umgehen können?

Gruß
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#2

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 17. Jun 2012, 19:48
Windows ist als Nicht-Echtzeitsystem eh nicht dafür geeignet genau aller 'ner MS was zu empfangen.

Warum willst du unbedingt ALL diese Daten live anzeigen?
Angucken kann sich das sowieso keiner.


Ich hab's jetzt nicht ganz sicher im Kopf, aber gaub wir laden so 100000 Werte in knapp 2-3 Sekunden da rein, wobei das Chart schnell ist, aber die DB braucht etwas, um diese Datensätze zu liefern. (z.B. 10 Datasetzt, á je 10080 Datensätze)
$2B or not $2B

Geändert von himitsu (17. Jun 2012 um 19:51 Uhr)
  Mit Zitat antworten Zitat
Daniel
(Co-Admin)

Registriert seit: 30. Mai 2002
Ort: Hamburg
13.920 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 17. Jun 2012, 19:56
Wie soll die Grafik denn aussehen? Ich meine - man wird ja wohl kaum in Echtzeit 1.000 Aktualisierungen pro Sekunde vornehmen wollen.

Soll die Grafik ein laufender ("scrollender") Strom an Werten sein oder addiert sich da etwas oder wird da gruppiert und summiert?

Du wirst auf jeden Fall eine Form von Zwischenverarbeitung benötigen, denn wenn Du jeden Meßwert auf nur einen Pixel legst, bist Du nach 1-2 Sekunden raus aus dem sichtbaren Bereich herkömmlicher Bildschirme.

Wenn das beispielsweise ein von rechts nach links laufender Strom werden sollte, dann könnte ich mir eine Art Array vorstellen, in dem Du die derzeit sichtbaren Werte ablegst und dann könntest Du z.B. in einem Thread, der dann ausschließlich lesend auf dieses Array zugreift, regelmäßig Deine Grafik aktualisieren.

Für die Realisierung würde ich mit TChart anfangen, alle Formen von Kantenglättung, Farbverläufen und Transparenz etc. abschalten und dann müsste das eigentlich passen - viel mehr als 10x pro Sekunde (wenn überhaupt) wirst Du das Diagramm wohl eh nicht aufbauen müssen - welcher Betrachter soll das so genau verfolgen können? Die Aktualisierungsraten könntest Du dann mit Deinem Thread steuern und einfach schauen, wie oft er das hinbekommt.
Daniel R. Wolf
mit Grüßen aus Hamburg
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#4

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 17. Jun 2012, 20:19
Wir habe eine derartige Anforderung mit eine eigenen Komponente umgesetzt die rund 20 pro Sekunde die Darstellung aus einem per Thread gefüllten Ringpuffer aktualisiert, ein weiterer Thread schreibt die Daten aus dem Puffer in eine Datenbank.
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#5

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 17. Jun 2012, 20:25
Hi,

ja 1000 Messwerte pro Sekunde werden vom Messgerät rausgehauen.
Ich will im Prinzip von links nach rechts in der Zeitachse die Werte eintragen, und dass muss nicht alle 1ms geschehen (kann es ja auch bei MS gar nicht) also ich hatte
mir vorgestellt das Empfangen in eigenem Thread zu machen, der dann alle 100ms 100 Werte zum zeichnen überträgt (per synchronized Methode).
Es geht um ein Druckventil, bei dem der Druck steigt und dann ein Ventil öffnet und der Druck wieder fällt, dass passiert in 4-5sec und da werden halt so ungefähr 4000 Messwerte
auflaufen, die ich möglichst dynamisch darstellen will.

Danke.

Gruß
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#6

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 17. Jun 2012, 20:26
Achso,

ja der Chart, sollte automatisch skalieren, da im Prinzip nur der Verlauf wichtig ist.
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#7

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 17. Jun 2012, 21:49
Du willst also allen Ernstes 1000 Werte pro Sekunde darstellen... Das braucht man nie und nimmer. Speichern und Aufzeichnen: Ja. Live darstellen? Kann ich mir nicht vorstellen.
  Mit Zitat antworten Zitat
grl

Registriert seit: 5. Feb 2007
174 Beiträge
 
FreePascal / Lazarus
 
#8

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 17. Jun 2012, 22:35
Wie bekommst du denn die Daten? USB? Ethernet? Und kannst du dir sicher sein, daß das nur 4-5 Sekunden dauert?

Denn das spannende wird bei der Geschichte nicht das Anzeigen, sondern das aufzeichnen der Daten.

Das sollte in einem möglichst kurzen und knackigen Thread passieren und bitte, bitte ohne synchronize! Damit hältst du diesen Thread nämlich an.

Ich würde in dem Aufzeichnungsthread mich nur darum kümmern, die Daten entgegenzunehmen, evtl. eine erste Prüfung durchzuführen und sie dann (wenn's echt nur 5000 Werte insgesamt werden) in einen Buffer im Speicher schreiben. Ein weiterer Thread (evtl. im Hauptthread) holt die Daten dann wenn er Zeit hat aus diesem Buffer (für den du eine Critical Section brauchst), schreibt ihn in eine Datenbank oder eine Datei und kümmert sich dann darum, die Daten anzuzeigen. Dabei bietet sich an, nur die auch Darstellbaren Punkte vorher zu bestimmen. Die einfachste Form davon wäre, immer so viele Punkte zwischen zwei anzuzeigenden auszulassen, daß du im endeffekt soviele Punkte anzeigst wie du Pixel am Schirm hast. Bei 4000 Punkten und 1024 Pixel am Schirm wär das also ca. jeder 4. Punkt - alles andere siehst du eh nicht.

Wenn du's so machst ist die Chart-Komponente weitgehend unerheblich, außer du willst dann noch irgendwelche Interaktion mit dem Betrachter, also Teile des Charts auswählen, zoomen, irgendwas dran rumrechnen oder sowas.

Schlüsselstelle ist und bleibt die Übernahme der Daten in das System und wie du sie da in einen Speicher schreibst...

Gruß
Luggi
  Mit Zitat antworten Zitat
Benutzerbild von ChrisE
ChrisE

Registriert seit: 15. Feb 2006
Ort: Hechingen
504 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#9

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 18. Jun 2012, 09:38
Hi DelphiManiac,

also ich würde das Problem aufschlüsseln bzw. genauer definieren. Ich denke du brauchst die hohe Abtastrate, weil du z.B. spätere Analysen drüber laufen lassen willst - also offline - und da auch in bereich von 100 ms rein Zoomen willst um zu sehen was da los war. Aber all das betrifft ja erstmal nicht den Onlinebereich - also den Zeitpunkt des Aufnehmens. Aus meiner Sicht brauchst du Online meist nur ein Darstellung um zu sehen, dass etwas passiert und dass es so ungefähr in die Richtung geht wie man sich das vorstellt.
Dafür würde es am Anfang schon reichen nur jeden zehnten bis zwanzigsten Wert zu übergeben an das Chart. Es passiert dadurch natürlich in der Visualisierung ein undersampling - bzw. siehst du u.U. nicht jeden Peak. Aber für Online könnte das schon reichen.

Anders formuliert: Versuche Deine Anforderungen der Messtechnik / Datenverarbeitung von denen der Visualisierung getrennt zu betrachten und auch getrennt um zu setzten. Ich denke, dass könnte Dich weiter bringen.

Gruß, Chris
Christian E.
Es gibt 10 Arten von Menschen, die die Binär lesen können und die die es nicht können

Delphi programming rules
  Mit Zitat antworten Zitat
Popov
(Gast)

n/a Beiträge
 
#10

AW: Chart-Komponente die 1000 Werte / sec verträgt

  Alt 18. Jun 2012, 10:09
Ich habe vor einiger Zeit für eine Aufgabe paar einfache Test durchgeführt. Zwar kann man es nicht genau übertragen, aber ...

Zuerst das System: AMD 2,7 GHz. Es wurden farbige Quadrate um die 50 Pixel gezeichnet. Bei 3.000 Rechtecken hatte ich ein FPS von über 60, bei 10.000 Rechtecken hatte ich ein FPS von 30, bei 45.000 Rechtecken ein FPS von 5, das ergibt rechnerisch 225.000 Rechtecke pro Sekunde.

Allerdings fanden zwischendurch noch paar Berechnungen statt, alles lief im Rahmen des normalen Programms statt. Es war also keine reine Schleife.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:21 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz