330 likes | 453 Views
Integrating Timing and Free-Running Actors with Dataflow Tim Hayles Principal Engineer National Instruments September 9, 2008. hayles@ni.com. Agenda. What is LabVIEW Dataflow? Why is timing important to NI? Further motivation for this research Key elements Asynchronous Data Wires
E N D
Integrating Timing and Free-Running Actors with DataflowTim HaylesPrincipal EngineerNational InstrumentsSeptember 9, 2008 hayles@ni.com
Agenda • What is LabVIEW Dataflow? • Why is timing important to NI? • Further motivation for this research • Key elements • Asynchronous Data Wires • Asynchronous Timing Wires • A small set of “Free Running” Actors • Implementation Details • Examples
What is LabVIEW Dataflow? • aka Structured Dataflow • Loops, cases, sequences, … • aka Homogenous Dataflow • Always a single token on a wire • aka simply as ‘G’ • Dynamically scheduled • Data driven • Simple to use and understand • Widely successful
Why is Timing Important to NI? • We make I/O products • I/O timing requires • Configuration • Routing • Synchronization • Multiple subsystems on one board • Multiple boards in one chassis • Multiple chassis • I/O timing must play well with application timing
Data Acquisition: Dataflow API • Generate a single, re-triggerable pulse, delayed from the trigger • DAQmx dataflow configures a circuit and activates it • Clearing the task has the side effect of disabling the circuit
Data Acquisition to the Pin • This mixed model is much closer to the actual hardware • Opening up the pulse generator can reveal more detail
Now we also want … • To further exploit parallelism even between nodes sharing a data transformation • To incorporate common data exchange techniques into the language • First class support for • Pipelines • Multi-rate • Streaming • Timing • Offer a multi-target programming canvas • Deployment, startup and shutdown order
Asynchronous Wire • No inherent semantics • All behavior conferred by implementation outside LabVIEW – though written in LabVIEW • One wire for data • One wire for timing • Producer and consumer nodes become “free-running” actors firing based on • Data or space availability • Timing
Timing Wires • Carry not time stamps, but ‘ticks’ • Time stamps are data • Ticks are unit-less and ephemeral state changes • Voltage transition • Boolean transition • Route signals • Clock domains for FPGA logic • Clocks for I/O timing and triggering • Triggers for timing computations • Abstract • Copper traces (actual wires) • Memory locations (‘soft’ clocks and triggers)
Timing Wires • Triggers can be polymorphic to accept time stamps (but that’s a data wire)
Asynchronous Data Wire • Buffered • Writer usually, though not always, ‘owns’ the buffer • Besides depth, buffer has type • Register • Fifo • Circular buffer • Type determines behavior • aka data exchange policy
IF-RIO Experiment • RF Transceiver product • Async wires and actors used on same canvas as LabVIEW dataflow
IF-RIO Experiment Now • A new palette of seven async actors and two dataflow actors • FPGA only
Harnessed User G Code • False case writes false to Start DAC otherwise empty • No notion of buffering policies used in async layer
Harnessed User G Code • LabVIEW dataflow makes the copy of the data • When the first copy is made, Start goes true and the DAC begins consuming data
Harness Integration of Dataflow • A technique for complete separation of the MOCs • The VI is pure LabVIEW dataflow • The free-running Harness generates the code to read and write the asynchronous wires and call the VI • Code generation is optimized for streaming
Harness Generated Code • If the harnessed VI does not support any of the streaming protocol terminals, the IP Block only executes when • There is no pending write • A read was succesful
System Diagram • MOC integration • Complete separation • Limited mixing • I/O integration • Discover • Configure • Operate • Target integration • Multiple targets • One canvas
G behind System Diagram • Just the accessors and terminals here
G behind System Diagram G code must provide the loop
More System Diagram Research • Relation to timestamp based MOCs • MOC hosting • Debugging • Simulation • Scheduling • A state machine for deployment, etc • Communication between the state machine and the hosted code • Mapping IP among processing resources
Contact Information • hayles@ni.com • www.ni.com\labview • Local contact: hugo.andrade@ni.com