Rigorous Data Processing and Automatic Documentation of Srf Cold Tests∗

Total Page:16

File Type:pdf, Size:1020Kb

Rigorous Data Processing and Automatic Documentation of Srf Cold Tests∗ 18th International Conference on RF Superconductivity SRF2017, Lanzhou, China JACoW Publishing ISBN: 978-3-95450-191-5 doi:10.18429/JACoW-SRF2017-TUPB069 RIGOROUS DATA PROCESSING AND AUTOMATIC DOCUMENTATION OF SRF COLD TESTS∗ K. G. Hernández-Chahín1y, S. Aull, N. Stapley, P. Fernandez Lopez, N. Schwerg CERN, Geneva, Switzerland 1also at DCI-UG, Guanajuato, Mexico Abstract • Although it is instructive and recommended for any beginner in the field of SRF to implement their own Performance curves for SRF cavities are derived from set of analysis functions, for routine operation a single primary quantities which are processed by software. Com- reviewed and protected set is needed. monly, the mathematical implementation of this analysis is • In general the implementation of mathematical expres- hidden in software such as Excel or LabVIEW, making it sions in any programming language (graphical or text) difficult to verify or to trace, while text-based programming is cumbersome or unpleasant to read. like Python and MATLAB require some programming skills for review and use. As part of an initiative to consolidate In order to overcome these problems the cold-test software and standardise SRF data analysis tools, we present a Python system should meet the following requirements: program converting a module containing the collection of • Single point of function definition • Built-in documentation all commonly used functions into a LATEX(PDF) document carrying all features of the implementation and allowing for • Version control a review by SRF experts, not programmers. The resulting • Nesting and re-use of the core implementation document is the reference for non-experts, beginners and test • Simple and reliable review process stand operators. The module is imported in any subsequent • Automatic tests and sanity checks processing and analysis steps like the symbolic analysis of In this paper we present an approach consisting of two the measurement uncertainties or the study of sensitivities. core components: 1) a central python implementation As an additional layer of protection the functions can be fur- (srf_functions) of all analysis functions as e.g. provided ther wrapped including assertions, type and sanity checks. in Padamsee’s book [8] and 2) an automatic documentation This process maximises function reuse, reduces the risk of tool (dokator) converting the functions and especially the human errors and guarantees automatically validated and underlying code into a type-set representation for review by documented cold test results. SRF experts and practitioners and not programmers. INTRODUCTION SRF_FUNCTIONS 2017). Any distribution of this work must maintain attribution to the author(s), title of the work, publisher, and DOI. During cold tests of SRF cavities a great number of differ- Figure 1 shows the approach with the central element © ent signals are measured and automatically recorded. The the srf_functions. This module or library contains all acquisition and storage is done by test programs often written mathematical expressions used for the evaluation of the mea- in LabVIEW [1,2] or INSPECTOR [3]. From these primary surements and used in the construction of more complex quantities we derive figures of merit such as the unloaded analysis routines. These functions are used for all compu- quality factor Q0 and the accelerating gradient Eacc. The first tations from the data taken with the measurement software processing and derivation of these quantities is done immedi- (INSPECTOR or LabVIEW) during the cold test to the post ately using the data acquisition software, where the routines processing of the final results. for the calculations are implemented using the programing language provided by the software manufacture. The final Single Point of Function Definition analysis of the data is conducted during the post-processing We base our approach on one single Python [6,7] module, using Excel [4], MATLAB [5] or Python [6, 7] where the srf_functions, which contains the implementation of all analysis routines are custom libraries of the user. computations. We chose Python due to its wide spread Over the last year we came across the following problems use, flexibility and various freely available packages. The and pitfalls of this approach: implementation is kept to a minimum of complexity while • In LabVIEW and Excel the implementation of the anal- placing the effort in clean definitions and documentation. ysis function is somehow hidden from the operator and difficult to verify by the user. Un-typed Function Definition • The functions have to be implemented twice, once for the test software and once for post-processing hence In the core module we define all functions un-typed. This doubling the effort for maintenance. means that the implementation does not rely on any specific features as long as the used objects support standard math ∗ Work supported by the Beam Project (CONACYT, Mexico). operation such as + - * / ** with the latter being the y [email protected] power operator in Python. Special symbols or functions like SRF Technology R&D TUPB069 Content from this work may be used under the terms of the CC BY 3.0 licence ( Cavity 543 18th International Conference on RF Superconductivity SRF2017, Lanzhou, China JACoW Publishing ISBN: 978-3-95450-191-5 doi:10.18429/JACoW-SRF2017-TUPB069 Cross- & Sanity-Checks • Examples illustrating the function use, common results Assertions Version and providing a layer of tests. Control SRF Functions Furthermore variable names may use LATEX notation such as underscores for subscripts. Notice that the approach is similar to common documen- tation tools such as Epydoc [12] and also bases on features Measurement Measurement of reStructuredText [13]. An example of the built-in Data Software documentation is shown in Fig. 2 highlighted in red. Display Version Control The srf_function module and its documentation are included in a version control system such as EDMS [14] or Post Processing GitLab [15] in order to keep track of all changes and mak- ing the current version available to the team. Back-tracing Report problems and evaluating improvements is aided by the open source of the Python module and text-based comparison of different versions of the code. Figure 1: Flowchart of the measurement data from the anal- ysis tools towards the final report with the central definition Automated Testing of all functions in the SRF-function module. Software engineering encourages the use of various test- ing techniques as part of a software quality assurance testing strategy to maintain the required level of reliability, reduce π can be defined in the preamble of the module and may be the risk of failure during operation, and provide confidence overwritten on import. that code changes will not have any adverse affects [16]. This approach allows to use the functions with any kind When testing, different types of defect are found at each of Python objects supporting the aforementioned operators level of abstraction, and the lowest level, code (unit) tests, which is true for numbers as well as symbols as provided by are often implemented to ensure correctness for individual the sympy package [9, 10]. functions as a minimum testing requirement. For the construction of more complicated or coupled ex- For this Python provides docstring which serves as both pressions the functions can be called and re-wrapped into simple examples of the use of the function in the documenta- higher order systems. This, e.g., allows to automatically tion, and for function verification upon module import using derive the expressions for the loaded Q and accelerating doctest [17]. Doctest’s power rests in its simplicity [18, p gradient based only on primary quantities: 157], but for larger more robust test scenarios unittest is 2017). Any distribution of this work must maintain attribution to the author(s), title of the work, publisher, and DOI. © preferred. 2 2πPt f k 3 Q0 6 Pf −Pr −Pt 7 = 6 q 7 (1) Pt k Sanity Checks Eacc ¹P ;P ;P ; f;k;κ º 6 7 f r t E 6 κE 7 4 5 Extending on the possibility to import and re-use the core Built-In Documentation definitions the functions can be wrapped by a facade layer [19] to include typing and sanity checks. This ranges from A very useful Python feature are docstrings [11]. A doc- enforcing certain data types, including assertions [20] for string is the first statement in a function or class declaration certain inputs such as power reading shall be greater than a providing the user with the documentation. This can be certain minimum or zero, as well as proper error handling used to include all information necessary to understand the to prevent the process from crashing. function call signature, the physics behind the computation as well as give reference to text books such as [8]. LabView Import Maintaining the following conventions the docstring can LabVIEW is often used for cavity testing. Hence it is be made human and computer readable allowing for auto- advantageous to use the same math functions for the post- matic processing and display. The documentation consists processing and for the actual cavity tests. There are several of the following blocks: general solutions for including Python functions in Lab- • Description of the greater context of the function (op- VIEW, each with its own advantages in terms of ease, and tional). performance. We describe three, just to demonstrate the • Definition of the parameters with their symbol, name possibilities and provide an idea of the benefits of each. and unit. One of the simplest solutions is to use LabVIEW ’s built- • Description of the return value(s) with name, symbol in ability (System Exec VI) to execute a Python script and unit. containing the math functions [21]). A new instance of the • Optional notes for function use. Python script is executed every time, meaning this solution • References used in the description and/or notes.
Recommended publications
  • Key Benefits Key Features
    With the MapleSim LabVIEW®/VeriStand™ Connector, you can • Includes a set of Maple language commands, which extend your LabVIEW and VeriStand applications by integrating provides programmatic access to all functionality as an MapleSim’s high-performance, multi-domain environment alternative to the interactive interface and supports into your existing toolchain. The MapleSim LabVIEW/ custom application development. VeriStand Connector accelerates any project that requires • Supports both the External Model Interface (EMI) and high-fidelity engineering models for hardware-in-the-loop the Simulation Interface Toolkit (SIT). applications, such as component testing and electronic • Allows generated block code to be viewed and modified. controller development and integration. • Automatically generates an HTML help page for each block for easy lookup of definitions and parameter Key Benefits defaults. • Complex engineering system models can be developed and optimized rapidly in the intuitive visual modeling environment of MapleSim. • The high-performance, high-fidelity MapleSim models are automatically converted to user-code blocks for easy inclusion in your LabVIEW VIs and VeriStand Applications. • The model code is fully optimized for high-speed real- time simulation, allowing you to get the performance you need for hardware-in-the-loop (HIL) testing without sacrificing fidelity. Key Features • Exports MapleSim models to LabVIEW and VeriStand, including rotational, translational, and multibody mechanical systems, thermal models, and electric circuits. • Creates ANSI C code blocks for fast execution within LabVIEW, VeriStand, and the corresponding real-time platforms. • Code blocks are created from the symbolically simplified system equations produced by MapleSim, resulting in compact, highly efficient models. • The resulting code is further optimized using the powerful optimization tools in Maple, ensuring fast execution.
    [Show full text]
  • Towards a Fully Automated Extraction and Interpretation of Tabular Data Using Machine Learning
    UPTEC F 19050 Examensarbete 30 hp August 2019 Towards a fully automated extraction and interpretation of tabular data using machine learning Per Hedbrant Per Hedbrant Master Thesis in Engineering Physics Department of Engineering Sciences Uppsala University Sweden Abstract Towards a fully automated extraction and interpretation of tabular data using machine learning Per Hedbrant Teknisk- naturvetenskaplig fakultet UTH-enheten Motivation A challenge for researchers at CBCS is the ability to efficiently manage the Besöksadress: different data formats that frequently are changed. Significant amount of time is Ångströmlaboratoriet Lägerhyddsvägen 1 spent on manual pre-processing, converting from one format to another. There are Hus 4, Plan 0 currently no solutions that uses pattern recognition to locate and automatically recognise data structures in a spreadsheet. Postadress: Box 536 751 21 Uppsala Problem Definition The desired solution is to build a self-learning Software as-a-Service (SaaS) for Telefon: automated recognition and loading of data stored in arbitrary formats. The aim of 018 – 471 30 03 this study is three-folded: A) Investigate if unsupervised machine learning Telefax: methods can be used to label different types of cells in spreadsheets. B) 018 – 471 30 00 Investigate if a hypothesis-generating algorithm can be used to label different types of cells in spreadsheets. C) Advise on choices of architecture and Hemsida: technologies for the SaaS solution. http://www.teknat.uu.se/student Method A pre-processing framework is built that can read and pre-process any type of spreadsheet into a feature matrix. Different datasets are read and clustered. An investigation on the usefulness of reducing the dimensionality is also done.
    [Show full text]
  • Compiling Maplesim C Code for Simulation in Vissim
    Compiling MapleSim C Code for Simulation in VisSim 1 Introduction MapleSim generates ANSI C code from any model. The code contains the differential equations that describe the model dynamics, and a solver. Moreover, the code is royalty-free, and can be used in any simulation tool (or development project) that accepts external code. VisSim is a signal-flow simulation tool with strength in embedded systems programming, real-time data acquisition and OPC. This document will describe the steps required to • Generate C code from a MapleSim model of a DC Motor. The C code will contain a solver. • Implement the C code in a simulation DLL for VisSim. VisSim provides a DLL Wizard that sets up a Visual Studio C project for a simulation DLL. MapleSim code will be copied into this project. After a few modifications, the project will be compiled to a DLL. The DLL can then be used as a block in a VisSim simulation. The techniques demonstrated in this document can used to implement MapleSim code in any other environment. MapleSim’s royalty -free C code can be implemented in other modeling environment s, such as VisSim MapleSim’s C code can also be used in Mathcad 2 API for the Maplesim Code The C code generated by MapleSim contains four significant functions. • SolverSetup(t0, *ic, *u, *p, *y, h, *S) • SolverStep(*u, *S) where SolverStep is EulerStep, RK2Step, RK3Step or RK4Step • SolverUpdate(*u, *p, first, internal, *S) • SolverOutputs(*y, *S) u are the inputs, p are subsystem parameters (i.e. variables defined in a subsystem mask), ic are the initial conditions, y are the outputs, t0 is the initial time, and h is the time step.
    [Show full text]
  • Labview Graphical Development Environment Labview
    LabVIEW Graphical Development Environment LabVIEW NI LabVIEW •Intuitive graphical development LabVIEW PDA Module for test, measurement, and control •Graphical development for portable, •Complete programming language handheld devices with built-in tools for data acquisition, instrument control, LabVIEW Datalogging and measurement analysis, report Supervisory Control Module •Graphical development for generation, communication, monitoring and distributed and more applications •Application templates, thousands of example programs LabVIEW Vision •Compiled for fast performance Development Module LabVIEW Real-Time Module •Graphical development for high-level machine vision and image processing •Graphical development for real- time control, deterministic LabVIEW Add-On Tools performance, reliability, and •See page 44 for a full listing embedded execution Operating Systems LabVIEW FPGA Module •Windows 2000/NT/XP •Graphical development for •Mac OS X creating custom I/O boards with • Linux FPGA technology •Solaris Overview Analyze National Instruments LabVIEW is a powerful development Raw data is typically not the desired end result of a measurement and environment for signal acquisition, measurement analysis, and data automation application. Powerful, easy-to-use analysis functionality presentation, giving you the flexibility of a programming language is a must for your software application. LabVIEW has more than 400 Measurement and Automation Software without the complexity of traditional development tools. built-in functions designed specifically
    [Show full text]
  • Ulx for NI Labview
    ULx for NI LabVIEW Software Quick Start June 2016. Rev 3 © Measurement Computing Corporation Trademark and Copyright Information Measurement Computing Corporation, InstaCal, Universal Library, and the Measurement Computing logo are either trademarks or registered trademarks of Measurement Computing Corporation. Refer to the Copyrights & Trademarks section on mccdaq.com/legal for more information about Measurement Computing trademarks. Other product and company names mentioned herein are trademarks or trade names of their respective companies. © 2016 Measurement Computing Corporation. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form by any means, electronic, mechanical, by photocopying, recording, or otherwise without the prior written permission of Measurement Computing Corporation. Notice Measurement Computing Corporation does not authorize any Measurement Computing Corporation product for use in life support systems and/or devices without prior written consent from Measurement Computing Corporation. Life support devices/systems are devices or systems that, a) are intended for surgical implantation into the body, or b) support or sustain life and whose failure to perform can be reasonably expected to result in injury. Measurement Computing Corporation products are not designed with the components required, and are not subject to the testing required to ensure a level of reliability suitable for the treatment and diagnosis of people. QS ULx for NI LabVIEW Table
    [Show full text]
  • CS3101 Programming Languages -‐ Python
    CS3101 Programming Languages - Python Spring 2010 Agenda • Course descripon • Python philosophy • Geng started (language fundamentals, core data types, control flow) • Assignment Course Descripon Instructor / Office Hours • Josh Gordon • PhD student • Contact – [email protected] • Office hours – By appointment, feel free to drop a line any<me Syllabus Lecture Topics Assignment Jan 19th Language overview. Course structure. Scrip<ng HW1: Due Jan 26th essen<als. Jan 26th Sor<ng. Parsing CSV files. Func<ons. Command HW2: Due Feb 2nd line arguments. Feb 2nd Func<onal programming tools. Regular HW3: Due Feb 9th expressions. Generators / iterators. Feb 9th Object oriented Python. Excep<ons. Libraries I. Project Proposal: Due Feb 16th Feb 16th GUIs. Databases. Pickling. Libraries II. Course Project: Due Feb 28th Feb 23rd Integra<on with C. Performance, op<miza<on, None profiling. Paralleliza<on. Grading Assignment Weight Class par<cipa<on 1/10 HW1 1/10 HW2 1/10 HW3 1/10 Proposal 1/10 Project 5/10 Extra credit challenge problems Depends how far you get Late assignments: two grace days / semester, aber which accepted at: -10% / day. Resources / References • Course website: – www.cs.columbia.edu/~joshua/teaching – Syllabus / Assignments / Slides • Text books – Learning Python – Python in a Nutshell (available elect. on CLIO) – Python Cookbook • Online doc: – www.python.org/doc Ordered by technical complexity - no<ce anything? Course Project • Opportunity to leverage Python to accomplish something of interest / useful to you! • Past projects: – Gene<c
    [Show full text]
  • They Have Very Good Docs At
    Intro to the Julia programming language Brendan O’Connor CMU, Dec 2013 They have very good docs at: http://julialang.org/ I’m borrowing some slides from: http://julialang.org/blog/2013/03/julia-tutorial-MIT/ 1 Tuesday, December 17, 13 Julia • A relatively new, open-source numeric programming language that’s both convenient and fast • Version 0.2. Still in flux, especially libraries. But the basics are very usable. • Lots of development momentum 2 Tuesday, December 17, 13 Why Julia? Dynamic languages are extremely popular for numerical work: ‣ Matlab, R, NumPy/SciPy, Mathematica, etc. ‣ very simple to learn and easy to do research in However, all have a “split language” approach: ‣ high-level dynamic language for scripting low-level operations ‣ C/C++/Fortran for implementing fast low-level operations Libraries in C — no productivity boost for library writers Forces vectorization — sometimes a scalar loop is just better slide from ?? 2012 3 Bezanson, Karpinski, Shah, Edelman Tuesday, December 17, 13 “Gang of Forty” Matlab Maple Mathematica SciPy SciLab IDL R Octave S-PLUS SAS J APL Maxima Mathcad Axiom Sage Lush Ch LabView O-Matrix PV-WAVE Igor Pro OriginLab FreeMat Yorick GAUSS MuPad Genius SciRuby Ox Stata JLab Magma Euler Rlab Speakeasy GDL Nickle gretl ana Torch7 slide from March 2013 4 Bezanson, Karpinski, Shah, Edelman Tuesday, December 17, 13 Numeric programming environments Core properties Dynamic Fast? and math-y? C/C++/ Fortran/Java − + Matlab + − Num/SciPy + − R + − Older table: http://brenocon.com/blog/2009/02/comparison-of-data-analysis-packages-r-matlab-scipy-excel-sas-spss-stata/ Tuesday, December 17, 13 - Dynamic vs Fast: the usual tradeof - PL quality: more subjective.
    [Show full text]
  • Power Meter Samples
    Power Meter Samples March 22, 2012 Prepared by: Newport Corporation 1791 Deere Avenue Irvine, CA 92606 1 INTRODUCTION................................................................................................................. 1 2 1830-R .................................................................................................................................... 1 2.1 GPIB SAMPLE.................................................................................................................. 1 2.1.1 GPIBSample.lvproj ................................................................................................. 1 2.1.1.1 GPIB_Query_With_SerialPoll.vi........................................................................ 1 2.1.1.2 GPIB_Query_Without_SerialPoll.vi .................................................................. 1 2.1.1.3 GPIBCommunicationTest.vi............................................................................... 1 2.2 USB SAMPLE ................................................................................................................... 2 2.2.1 GetPower.lvproj...................................................................................................... 4 2.2.1.1 SampleGetPower.vi ............................................................................................ 4 3 1918 - 2936 FAMILY............................................................................................................ 4 3.1 C#...................................................................................................................................
    [Show full text]
  • Getting Started with Labview
    LabVIEWTM Getting Started with LabVIEW Getting Started with LabVIEW June 2013 373427J-01 Support Worldwide Technical Support and Product Information ni.com Worldwide Offices Visit ni.com/niglobal to access the branch office Web sites, which provide up-to-date contact information, support phone numbers, email addresses, and current events. National Instruments Corporate Headquarters 11500 North Mopac Expressway Austin, Texas 78759-3504 USA Tel: 512 683 0100 For further support information, refer to the Technical Support and Professional Services appendix. To comment on National Instruments documentation, refer to the National Instruments website at ni.com/info and enter the Info Code feedback. © 2003–2013 National Instruments. All rights reserved. Important Information Warranty The media on which you receive National Instruments software are warranted not to fail to execute programming instructions, due to defects in materials and workmanship, for a period of 90 days from date of shipment, as evidenced by receipts or other documentation. National Instruments will, at its option, repair or replace software media that do not execute programming instructions if National Instruments receives notice of such defects during the warranty period. National Instruments does not warrant that the operation of the software shall be uninterrupted or error free. A Return Material Authorization (RMA) number must be obtained from the factory and clearly marked on the outside of the package before any equipment will be accepted for warranty work. National Instruments will pay the shipping costs of returning to the owner parts which are covered by warranty. National Instruments believes that the information in this document is accurate. The document has been carefully reviewed for technical accuracy.
    [Show full text]
  • RF Design and Test Using MATLAB and NI Tools
    RF Design and Test Using MATLAB and NI Tools Tim Reeves – [email protected] Chen Chang - [email protected] © 2015 The MathWorks, Inc.1 What are we going to talk about? ▪ How MATLAB and Simulink can be used in a wireless system design workflow ▪ Wireless Scenario Simulation ▪ End-to-end Simulation of mmWave Communication Systems with Hybrid Beamforming ▪ Developing Power Amplifier models and DPD algorithms in MATLAB ▪ Use of National Instruments PXI for PA characterization with DPD 2 Common Platform for 5G Development Mobile and Connectivity Standards Unified Design and Simulation Baseband RF MIMO & PHY Front End Antennas Deep Channels & C-V2X Learning Propagation Prototyping and Testing Workflows OTA Model- Deploy to Waveform Based C/C++ Tx/Rx Design 3 What differentiates high data rate 5G systems from previous wireless system iterations? ▪ High data rates (>1 Gbps) requires use of previously “under-used” (mmWave) frequency bands ▪ mmWave requires MIMO architectures to achieve same performance as sub-6GHz – Lower device power and high channel attenuation ▪ Antenna array, RF, and digital signal processing cannot be designed separately! – Large communication bandwidth → digital signal processing is challenging – High-throughput DSP → linearity requirements imposed over large bandwidth – Wavelength ~ 1mm → small devices, many antennas packed in small areas 4 How is the presentation set up? Link Level Modeling Scenario Modeling TRANSMITTER Digital Baseband DAC PA Front End Channel Digital PHY RF Front End Antenna Digital Baseband ADC LNA
    [Show full text]
  • EPICS and Labview
    EPICS and LabVIEW Tony Vento, National Instruments Willem Blokland, ORNL-SNS •Graphical dataflow programming •Interactive front panel / GUI •Efficient compiled execution •Targets Windows, Real-Time, FPGA, Linux, Macintosh, DSP, Other Processors •I/O and analysis libraries •Distributed networking capabilities EPICS and LabVIEW Interfaces (Oak Ridge and Others) 1. Shared Memory Interface to IOC (I/O Channel) Links LabVIEW and IOC Process Variables (PVs) Data from LabVIEW is available to the IOC Windows 2. CA (Channel Access) Client LabVIEW as a display environment for PVs No programming required Windows, Macintosh, Linux 1. Shared Memory Interface • db & cmd file generator at startup • Development tool -Cloning/documentation Windows PC Application Template tools • Standard Examples LabVIEW • NADs implemented: • Shared Memory Records BCM, BPM, ES, FC, TTS • LabVIEW Library Shared Memory (M. Sundaram, C. Long, W. (D. Thompson) Blokland, LANL, BNL) EPICS IOC+CA Channel Access Graphical programming • Drivers to DAQ • Processing routines • Graphs/Plots Accelerator Controls Shared Memory Interface Shared Memory IOC written by D. Thompson. LabVIEW Library by W. Blokland. The shared memory interface buffers the data and implements functions to: • Create, find and destroy variables • Read from and write to variables • Set and receive events • Retrieve information about variables Program startup 1. LabVIEW loads and runs Top-Level VI 2. LabVIEW gets variable declarations, generates .db and starts IOC 3. IOC starts and loads db file. Each time the IOC creates a PV record, the record creates a Shared Memory (SM) entry 4. LabVIEW finds references to SM entries by resolving PV names EPICS dB Utility The dBGenerate Utility automatically generates the database file for the EPICS IOC as well as the cmd file and an Excel file.
    [Show full text]
  • Integrating Data Acquisition and Instrument Control with Your Scilab Scripts
    Integrating Data Acquisition and Instrument Control with Your Scilab Scripts Darcy Dement Marketing Director National Instruments France [email protected] Who We Are 800 700 •Leaders in Computer-based Measurement and Automation 600 •Long-term track record of NI HQ growth and profitability 500 •$677M revenue in 2009 400 •More than 5,100 employees; operations in 40+ countries 300 •Fortune’s 100 Best Companies to 200 Work For 11 consecutive years •16% invested in R&D 100 0 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 00 01 02 03 04 05 06 07 08 09 2 What We Do Low-Cost Modular Productive Software Highly Integrated Hardware for Development Tools Systems Platforms Measurement and Control Used By Engineers and Scientists for Test, Design, and Control 3 The Numerical Mathematics Consortium http://www.nmconsortium.org/ 4 Discussion Topics: Connecting Math with the Physical World • Need for adding interactivity & instrumentation • A software option for interfacing with the physical world: NI LabVIEW • Using Scilab with LabVIEW • Use cases • Demo • Technical information 5 Textual Math Strengths • Scripted math • Sequential order of execution • Vector and matrix operations • Algorithm design for signal processing • Familiarity • User network and community 6 Need for Instrumentation & Interactivity • Acquire real-world data • Perform frequency • Visualize data with with hardware analysis, probability, professional user • Generate real stimuli statistics, math, curve interfaces • Control any of 1000’s of fitting, interpolation,
    [Show full text]