-
FlexPro
- Zoom sur FlexPro
- Fonctionnalités & Options
- Domaines d’application
- Tous les avantages
- Nouveau dans FlexPro 2021
- Testez FlexPro gratuitement
- FlexPro View OEM Freeware
- Conseils d’achat
- Login
- Langue
- +49 6894 929600
- infoweisang.com
- Google Maps
- Produits
- News
- Support
- Société
- Emplois
- Contact
- Login
- Langue
- +49 6894 929600
- infoweisang.com
- Google Maps
ValuesInInterval in einer Schleife
- This topic has 5 replies, 2 voices, and was last updated 9 years, 3 months ago by Stefan Wyler.
-
AuthorPosts
-
August 6, 2015 at 6:35 am #12885Stefan WylerParticipant
Hallo Zusammen,
Ich lese aus einem Geschwindigkeitssignal 0 – 70 km/h in 5 km/h Abschnitten den Index heraus. ValuesInInterval erlaubt für die Grenzwerte “Lower und upper Limit” nur Einzelwerte. Wie kann ich die Such enach den Indexen automatisieren?August 6, 2015 at 6:35 am #8545Stefan WylerParticipantHallo Zusammen,
Ich lese aus einem Geschwindigkeitssignal 0 – 70 km/h in 5 km/h Abschnitten den Index heraus. ValuesInInterval erlaubt für die Grenzwerte “Lower und upper Limit” nur Einzelwerte. Wie kann ich die Such enach den Indexen automatisieren?August 6, 2015 at 11:31 am #9400Bernhard KantzParticipantWie bereits der Titel des Eintrags andeutet, kann dies durch eine Schleife in einer FPScript-Formel automatisiert werden. Da die Datensätze der ermittelten Indizes wahrscheinlich unterschiedlich lang sein werden, sollten diese in einer Liste gesammelt werden. Das folgende Codebeispiel erzeugt eine Liste (mit Elementname der Form “15-20 km/h”) der gefundenen Indizes:
Dim val = Geschwindigkeit Dim res For lower = 0 To 70 Step 5 Do Dim upper = lower + 5 Dim idx = ValuesInInterval(val, lower, upper) res := List(String lower : "-" : String upper : " km/h", idx) End res
Hat diese Formel den Namen ‘Bereiche’ so liefert
Bereiche.["30-35 km/h"]
den Indexdatensatz zu diesem Geschwindigkeitsintervall. Alternativ kann auch
Bereiche.[6]
angegeben werden, da es sich um den 7. Eintrag handelt (der Elementenindex ist nullbasiert!).
Natürlich können die Elementnamen den eigenen Bedürfnissen angepasst werden sofern sie eindeutig sind.August 13, 2015 at 5:11 pm #9403Stefan WylerParticipantDas funktioniert aber noch nicht optimal. Jetzt habe ich die einzelnen Geschwindigkeitssegmente welche mit “Aus” (Anfangsindex und Endindex) ausgelesen werden. Zur Anwendung dieser beiden Werte (die Liste hat 13 Zeilen) auf ein Beschleunigungsignal muss ich den Anfangs- und Endwert herauslesen (indexieren) aber das funktioniert nicht. Wie kann ich das Listelement weiterverarbeiten?
Dim val = v_fz
Dim res
For speed = 5 To 65 Step 5 do
Dim low = speed – 2
Dim upper = speed + 2Try
Dim idx = ValuesInInterval(val, low, upper, EVENT_INDEX, 1.5)
Dim A_F = idx[1n]*25
Dim A_L = idx[-1n]*25Catch idx
A_F = 0
A_L = 0
EndDim Aus = {A_F , A_L}
res := List(String low :”-” : String upper : “km/h”, Aus)End
resAugust 22, 2015 at 9:48 am #9405Bernhard KantzParticipantDie Funktion ValuesInInterval() liefert alle Indizes deren Werte im angegebenen Intervall liegen. Falls Sie nur an der ersten Überschreitung einer minimalen bzw. maximalen Grenze interessiert sind, wäre die Funktion NextLevelCrossing() geeigneter.
In Ihrem Code greifen Sie auf den zweiten und den letzten Index der Werte im aktuell angegebenen Intervall zu und multiplizieren ihn mit 25, gibt es dafür einen speziellen Grund? Eine ausführlichere Beschreibung könnte vielleicht das Problem erhellen.September 20, 2015 at 11:57 am #9406Stefan WylerParticipantMit dem Faktor 25 werden die unterschiedlichen Samplinraten vom GPS- zum Beschleunigunssignal korrigiert.
-
AuthorPosts
- You must be logged in to reply to this topic.