FlexPro
HistoryBase
Ingénierie
Formation
Téléchargements
Support FlexPro
Connaissance
Communauté
À propos de nous
Références
Emplois
Contact général
Liste des revendeurs
Support FlexPro
FR
DE
EN
Porte-plaquette
Produits et solutions
Support et téléchargements
Entreprise
Magazine
Contact
Langue
MyWeisang

Paramètres du compte.

Topic

how do i return multiple datasets

Page d'accueil ' Communauté ' FPScript ' comment retourner plusieurs jeux de données

Voir les messages de 3 - 1 à 3 (sur un total de 3)
  • Auteur
    Messages
  • #33228
    Martin Kneppe
    Participant

    I am currently using FlexPro Demo.
    The first simple script i wrote is appended below.
    I am trying to get all slopes from two datasets and evaluate the position and the time-shift between the two datasets. As result i get the Position and the time-shift as a list of values.
    How do i return both lists as two new dataset ?

    Dim Array1,Array2,Position,Difference
    Dim i,a,b,c

    Array1=Slopes(‘DSS 1 SI’, 2, 1, 1, EVENT_POSITIVE)
    Array2=Slopes(‘DSS 1 SI’, 2, 1, 1, EVENT_NEGATIVE)

    a=NumberOfRows(Liste1);
    b=NumberOfRows(Liste2);
    if a>b Then
    c=b
    else
    c=a
    End

    Position=0#2#(c+5)
    Difference=0#(c+5)

    FOR i = 0 TO c-1 DO
    Position[i][0]=Array1[i]
    Position[i][1]=Array2[i]
    Difference[i]=Liste2[i]-Liste1[i]
    END
    Return Signal(Position,0.1),Signal(Difference,0.1)]

    #33230
    Martin Kneppe
    Participant

    I am currently using FlexPro Demo.
    The first simple script i wrote is appended below.
    I am trying to get all slopes from two datasets and evaluate the position and the time-shift between the two datasets. As result i get the Position and the time-shift as a list of values.
    How do i return both lists as two new dataset ?

    Dim Array1,Array2,Position,Difference
    Dim i,a,b,c

    Array1=Slopes(‘DSS 1 SI’, 2, 1, 1, EVENT_POSITIVE)
    Array2=Slopes(‘DSS 1 SI’, 2, 1, 1, EVENT_NEGATIVE)

    a=NumberOfRows(Liste1);
    b=NumberOfRows(Liste2);
    if a>b Then
    c=b
    else
    c=a
    End

    Position=0#2#(c+5)
    Difference=0#(c+5)

    FOR i = 0 TO c-1 DO
    Position[i][0]=Array1[i]
    Position[i][1]=Array2[i]
    Difference[i]=Liste2[i]-Liste1[i]
    END
    Return Signal(Position,0.1),Signal(Difference,0.1)]

    #33229
    Bernhard Kantz
    Participant

    For each dataset you have to create your own FPScript formula. Create two new formulas and use the [b]List Element Operator[/b] to take an element from a list.

    Example:
    Formula1 with the name “ListFormula”
    return [&ltvalue1&gt1, &ltvalue2&gt2]

    Formula2:
    ListFormula.Value1
    or
    ListFormula.[“Value1”]
    or
    ListFormula.[0]

    Formula3:
    ListFormula.Value2

    support@weisang.com

Voir les messages de 3 - 1 à 3 (sur un total de 3)
  • Vous devez être connecté pour répondre à ce sujet.