Design Patterns in NI LabVIEW Developer Days 2009.

Slides:



Advertisements
Similar presentations
© 2007 Eaton Corporation. All rights reserved. LabVIEW State Machine Architectures Presented By Scott Sirrine Eaton Corporation.
Advertisements

NI LabVIEW Object-Oriented Programming
Threads, SMP, and Microkernels
TP4: S TATE M ACHINE D ESIGN P ATTERN  Definition  Infrastructure  Transition Code  Conclusion.
Concurrency Important and difficult (Ada slides copied from Ed Schonberg)
Jeff Beltramo NHTI-Concord’s Community College FRC Team 1922.
WHAT IS AN OPERATING SYSTEM? An interface between users and hardware - an environment "architecture ” Allows convenient usage; hides the tedious stuff.
Developing User Interfaces with Event-driven Programming
Loops in LabVIEW (while,for and case)
Threads, SMP, and Microkernels Chapter 4. Process Resource ownership - process is allocated a virtual address space to hold the process image Scheduling/execution-
Programming Logic and Design Fourth Edition, Introductory
Application Design Patterns in LabVIEW™
Computer Systems/Operating Systems - Class 8
Process Description and Control
490dp Synchronous vs. Asynchronous Invocation Robert Grimm.
National Instruments Confidential. 2 LabVIEW Development Tips and Tricks Revealed Carl Ljungholm - LabVIEW Product Support Engineer Travis Hailey - LabVIEW.
6/13/20151 CS 160: Lecture 13 Professor John Canny Fall 2004.
Department of Electrical and Computer Engineering Texas A&M University College Station, TX Abstract 4-Level Elevator Controller Lessons Learned.
Real-Time Kernels and Operating Systems. Operating System: Software that coordinates multiple tasks in processor, including peripheral interfacing Types.
Multithreading in Java Nelson Padua-Perez Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
A. Frank - P. Weisberg Operating Systems Introduction to Tasks/Threads.
C++ fundamentals.
Fundamentals of Python: From First Programs Through Data Structures
® IBM Software Group © 2006 IBM Corporation JSF Tab Controls This Learning Module shows how to develop server-side EGL applications with dynamic content.
Workshop 3 of 7 Welcome!. Today's Topics Review of Workshop 2 Loops While For Auto-indexing Shift registers Case Structure.
Introduction to Basic LabVIEW Design Patterns
Tips and Tricks to Speed LabVIEW Development Useful Nuggets to Save You Time ni.com/labviewzone.
LabVIEW an Introduction
Chapter 10 State Machine Diagrams
1 Lecture 4: Threads Operating System Fall Contents Overview: Processes & Threads Benefits of Threads Thread State and Operations User Thread.
Operating System Review September 10, 2012Introduction to Computer Security ©2004 Matt Bishop Slide #1-1.
Pattern Oriented Software Architecture for Networked Objects Based on the book By Douglas Schmidt Michael Stal Hans Roehnert Frank Buschmann.
Operating System 4 THREADS, SMP AND MICROKERNELS
LiveCycle Data Services Introduction Part 2. Part 2? This is the second in our series on LiveCycle Data Services. If you missed our first presentation,
© Janice Regan, CMPT 300, May CMPT 300 Introduction to Operating Systems Principles of I/0 hardware.
Chapter 3 Process Description and Control
Lecture 3 Process Concepts. What is a Process? A process is the dynamic execution context of an executing program. Several processes may run concurrently,
© Janice Regan, CMPT 300, May CMPT 300 Introduction to Operating Systems Introduction to Concurrency.
Threads, SMP, and Microkernels Chapter 4. Process Resource ownership - process is allocated a virtual address space to hold the process image Scheduling/execution-
Games Development 2 Concurrent Programming CO3301 Week 9.
Threads G.Anuradha (Reference : William Stallings)
Copyright ©: University of Illinois CS 241 Staff1 Threads Systems Concepts.
Digital Electronics and Computer Interfacing Tim Mewes 4. LabVIEW - Advanced.
Chapter 7 -1 CHAPTER 7 PROCESS SYNCHRONIZATION CGS Operating System Concepts UCF, Spring 2004.
CCR Deadlock By: Laura Weiland April 30, Project Description Implement a module to the Train Operating System (TOS) that manages the deadlock problem.
1: Operating Systems Overview 1 Jerry Breecher Fall, 2004 CLARK UNIVERSITY CS215 OPERATING SYSTEMS OVERVIEW.
Advanced LabVIEW Topics Dustin Cruise. Who is this guy? Graduate Student in Mechanical Engineering at Purdue University Specialty Areas: Combustion Control.
Workshop 2 of 4 Welcome!. Survey While You Wait ni.com/duke >> Recent Documents >> LabVIEW Workshop Participation Survey.
© Janice Regan, CMPT 300, May CMPT 300 Introduction to Operating Systems Operating Systems Processes and Threads.
LabVIEW.com.tw LabVIEW Community Speeding Up Your VIs 參考 NI 官方教材: LabVIEW Intermediate II for 7.
1 CSE 331 Model/View Separation and Observer Pattern slides created by Marty Stepp based on materials by M. Ernst, S. Reges, D. Notkin, R. Mercer, Wikipedia.
13-1 Chapter 13 Concurrency Topics Introduction Introduction to Subprogram-Level Concurrency Semaphores Monitors Message Passing Java Threads C# Threads.
Introduction Contain two or more CPU share common memory and peripherals. Provide greater system throughput. Multiple processor executing simultaneous.
Digital Electronics and Computer Interfacing Tim Mewes 2. LabVIEW Basics part II.
SMP Basics KeyStone Training Multicore Applications Literature Number: SPRPxxx 1.
Active-HDL Server Farm Course 11. All materials updated on: September 30, 2004 Outline 1.Introduction 2.Advantages 3.Requirements 4.Installation 5.Architecture.
Mutual Exclusion -- Addendum. Mutual Exclusion in Critical Sections.
Embedded Real-Time Systems Processing interrupts Lecturer Department University.
Threads, SMP, and Microkernels Chapter 4. Processes and Threads Operating systems use processes for two purposes - Resource allocation and resource ownership.
CHAPTER 6 Threads, Handlers, and Programmatic Movement.
Wednesday NI Vision Sessions
Ni.com/training LabVIEW Basics I National Instruments N. Mopac Expressway Austin, Texas (512)
Adding Concurrency to a Programming Language Peter A. Buhr and Glen Ditchfield USENIX C++ Technical Conference, Portland, Oregon, U. S. A., August 1992.
Lesson 7 Using Sequential and State Machine Algorithms
Welcome! Workshop 3 of 7.
EE 200 Design Tools Laboratory 14
Threads, SMP, and Microkernels
Lecture 4- Threads, SMP, and Microkernels
1/10/2019 JavaFX Events COSC 330.
Background and Motivation
Presentation transcript:

Design Patterns in NI LabVIEW Developer Days 2009

2 What Is a Design Pattern? Based on LabVIEW code template or framework Widely accepted and well-known Easily recognizable

3 Benefits of Using Design Patterns Simplify the development process  Developers can easily understand code  Do not have to “reinvent the wheel”  Provide preexisting solutions to common problems Reliability  Many have been used for years – they are “tried and true”  Refer to large development community and resources online

4 Getting Started: How Do I Choose? Identify the most important aspect of your application:  Processes that require decoupling  Clean, easy-to-read code  Mission-critical components Select a template based on potential to improve

5 Caution You can needlessly complicate your life if you use an unnecessarily complex design pattern. Do not forget the most common design pattern of all – data flow !

6 Basic Tools Loops Shift registers Case structures Enumerated constants Event structures

7 Today’s Discussion As we look at each design pattern, we will discuss  A problem we are trying to solve  Background  How it works  Technical implementation  Demonstration  Use cases/considerations

8 Design Patterns Basic State machine Event-driven user interface Producer/consumer Advanced Object-oriented programming

State Machine I need to execute a sequence of events, but the order is determined programmatically. LabVIEW Basics I and II National Instruments Customer Education

10 Background Dynamic Sequence: Distinct states can operate in a programmatically determined sequence Static Sequence

11 Vending Machine Initialize Wait Change Quarter Dime Nickel Exit Vend Soda costs 50 cents No Input Quarter Deposited Total <50 Total ≥50 Change Requested Dime Deposited Nickel Deposited Total <50 Total ≥50 Total >50 Total = 50

12 Breaking Down the Design Pattern Case structure inside of a while loop Each case is a state Current state has decision-making code that determines next state Use enumerated constants to pass value of next state to shift registers

13 Transition Code How It Works FIRST STATE NEXT STATE Step Execution Shift registers used to carry state Case structure has a case for every state Transition code determines next state based on results of step execution

14 Transition Code Options Step Execution

15 DEMO State Machine

16 Recommendations Use Cases User interfaces Data determines next routine Considerations Creating an effective state machine requires the designer to make a table of possible states Use the LabVIEW Statechart Module to abstract this process for more sophisticated applications

Event-Driven User Interface I am polling for user actions, which is slowing my application down, and sometimes I do not detect them! LabVIEW Intermediate I National Instruments Customer Education

18 Background Procedural-driven programming Performs a set of instructions in sequence Requires polling to capture events Cannot determine order of multiple events Event-driven programming Determines execution at run time Waits for events to occur without consuming CPU Remembers order of multiple events

19 How It Works Event structure nested within loop Blocking function until event registered or time-out Events that can be registered:  Notify events are only for interactions with the front panel  Dynamic events implement programmatic registration  Filter events help you to screen events before they are processed

20 How It Works 1.Operating system broadcasts system events (mouse click, keyboard) to applications 2.Event structure captures registered events and executes appropriate case 3.Event structure returns information about event to case 4.Event structure enqueues events that occur while it is busy

21 How It Works: Static Binding Browse controls Browse events per control Green arrow: notify Red arrow: filter

22 DEMO Event-Driven User Interface

23 Recommendations Use Cases UI: Conserve CPU usage UI: Ensure you never miss an event Drive slave processes Considerations Event structures eliminate determinism Avoid placing two event structures in one loop Remember to read the terminal of a latched Boolean control in its value change event case

Producer/Consumer I have two processes that need to execute at the same time, and I need to make sure one cannot slow the other down. LabVIEW Intermediate I National Instruments Customer Education

25 How It Works Master loop tells one or more slave loops when they can run Allows for asynchronous execution of loops Data independence breaks data flow and permits multithreading Decouples processes Thread 1 Thread 2 Thread 3

26 Breaking Down the Design Pattern Data-independent loops = multithreading Master/slave relationship Communication and synchronization between loops

27 Loop Communication Variables Occurrences Notifier Queues Semaphores Rendezvous

28 Queues Adding Elements to the Queue Dequeueing Elements Reference to existing queue in memory Select the data type the queue will hold Dequeue will wait for data or time-out (defaults to -1)

29 DEMO Queues

30 Producer/Consumer

31 DEMO Producer/Consumer

32 Creating Multithreaded Applications Data-independent loops automatically spawn separate threads in LabVIEW

33 Recommendations Use cases Handling multiple processes simultaneously Asynchronous operation of loops Considerations Multiple producers  one consumer One queue per consumer If order of execution of parallel loop is critical, use occurrences

Object-Oriented Programming – Factory I need my application to be scalable and modular without sacrificing memory efficiency. LabVIEW OOP System Design National Instruments Customer Education

35 Object-Oriented Programming What if we need multiple printers of different types?

36 Object Orientation – Classes A glorified cluster A user-defined data type A type of project library

37 Object Orientation – Objects An object is a specific instance of a class Object data and methods are defined by the class

38 Object Orientation – Inheritance Each child class inherits methods and properties from its parent Each child class can also have its own unique methods Laser Printer Printer Inkjet Printer Copy Machine

39 Object Orientation – Dynamic Dispatching Calling VI determines which version of a subVI to use at run time. This prevents unneeded subVIs from being loaded into memory. Laser Printer Inkjet Printer Copy Machine

40 Object Orientation – Creating Classes Create a class from within a project Add VIs to the class to control methods and properties

41 How It Works – Factory Factory design pattern One subVI handles the interaction and selection of the modular object Dynamically selects which subVI to load into memory Modularity only requires adding the new class to the project and modifying the subVI that chooses which class to call

42 DEMO Object-Oriented Programming – Generic Factory Pattern

43 Recommendations Use cases Applications needing high-level modularity or scalability Memory conservation when loading subVIs Considerations More complex; requires strict architecture Not needed for limited applications

Using Design Patterns Let’s put what we have learned to use.

45 Using Design Patterns Problem: Create a responsive user interface We need an application with a responsive user interface that detects user inputs and reacts accordingly. This user interface should not use excessive CPU resources. The actions we need to take are not dependant on each other. Solution: Event-Based Design Pattern We should use an event-based design pattern because we need to limit the CPU usage while waiting for events. We should not encounter any race conditions because our actions are independent of each other.

46 Using Design Patterns Problem: Test and calibration system We need to test several devices on a production line. Based on the results of the test, we may need to calibrate the system using one of two calibration routines, then retest the system. Solution: State Machine Because we do not know which of the calibration routines we need to use, we should use a state machine to dynamically select which of the two states we should enter. Note: We should NOT use the object-oriented programming factory design pattern for this because we only have two calibration routines. Using object-oriented programming would be needlessly complex.

47 Using Design Patterns Problem: Data acquisition and data logging We need to acquire data from two external instruments that sample at different rates, filter the data, add the time of the test and the operator who performed the test to the data, and then write it all to a file. Solution: Producer/consumer We should use the producer/consumer architecture because we have multiple tasks that run at different speeds and cannot afford to be slowed down. Each of the external readings will be in separate producer loops and the data processing and logging will be in the consumer loop.

48 Using Design Patterns Problem: Dynamically render a group of 3D objects We need to create a series of 3D objects and display them. These objects will be different from each other but will share some similar properties. The number of each type that we will need to create will not be known until the program runs. Solution: Object-oriented programming We should use object-oriented programming with a factory that produces the proper number of each type of 3D object. Because we do not know how many will be produced beforehand and they all share some similar properties, dynamically creating these objects from an object-oriented programming factory is the most efficient solution.

49 DEMO Object-Oriented Programming – 3D Object Field

50 Resources Example Finder New>>Frameworks>>Design Patterns ni.com/statechart ni.com/labview/power Training  LabVIEW Intermediate I and II White paper on LabVIEW Queued State Machine ArchitectureLabVIEW Queued State Machine Architecture  Expressionflow.com

51 How to Develop Your LabVIEW Skills

52 Fast Track to Skill Development Certifications LabVIEW Basics I LabVIEW Basics II LabVIEW Intermediate I Certified LabVIEW Developer Exam LabVIEW Advanced I Certified LabVIEW Architect Exam LabVIEW Intermediate II Courses New UserExperienced UserAdvanced User Core Courses Begin Here Certified LabVIEW Associate Developer Exam ni.com/training If you are unsure take the - Quick LabVIEW quiz - Fundamentals exam

53 Certification

54 Training Membership: The Flexible Option Ideal for developing your skills with NI products 12 months to attend any NI regional or online courses and take certification exams $5,499 USD for a 12-month membership in the USA $4,799 USD for a 6-month membership in the USA

55 Next Steps Visit ni.com/training Identify your current expertise level and desired level Register for appropriate courses  $200 USD discount for attending LabVIEW Developer Education Day!

LabVIEW Learning Paths LabVIEW Basics I and II LabVIEW Instrument Control CompactRIO Fundamentals and LabVIEW FPGA RF Fundamentals and RF Application Development LabVIEW Machine Vision and Image Processing LabVIEW DAQ and Signal Conditioning LabVIEW Real-Time Application Development LabVIEW Intermediate I and II LabVIEW Advanced I: Large Application Development LabVIEW Object-Oriented Programming System Design Foundation Specialty Intermediate Advanced

Ways To Learn LabVIEW In A Classroom Near You Held at a local hotel or training facility Personal Interaction with Instructor and other Attendees On-line At Your Desk Live and Instructor-led No travel and reduced time away from work At Your Company Office Tailored course material for your company’s needs No travel required At Your Convenience Self-paced course kits On-demand training modules located in the Services Resource Center

Training & Certification Membership Program Unlimited access to all regional and on-line courses for one year Unlimited access to all certification exams for one year Option to retake all courses and exams ONE PRICE

Questions?