A Middleware Enabling Novice Programmers to Integrate Sensing in CPS Applications

Total Page:16

File Type:pdf, Size:1020Kb

A Middleware Enabling Novice Programmers to Integrate Sensing in CPS Applications BraceForce: A Middleware Enabling Novice Programmers to Integrate Sensing in CPS Applications Xi Zheng, Dewayne E. Perry, Christine Julien ([email protected], [email protected], [email protected]) The Center for Advanced Research in Software Engineering Mobile and Pervasive Computing Lab, Electrical and Computer Engineering The University of Texas at Austin TR-ARiSE-2013-003 © Copyright 2013 The University of Texas at Austin BraceForce: A Middleware Enabling Novice Programmers to Integrate Sensing in CPS Applications Xi Zheng, Dewayne E. Perry, Christine Julien The Center for Advanced Research in Software Engineering Mobile and Pervasive Computing Lab The University of Texas at Austin [email protected],[email protected],[email protected] ABSTRACT forms with little potential for portability to other plat- Even as the use of sensor networks to support CPS forms or integration with other sensors. Debugging CPS applications grows, our ability to seamlessly and effi- applications that inherently integrate with a physical ciently incorporate sensor network capabilities remains environment requires not only the aforementioned in- astoundingly difficult. Today, accessing remote sensing tegration of the application with sensing but also the data and integrating this data into the adaptive behav- use of a testing harness that, at debugging time, ac- ior of a dynamic user-facing CPS application requires in- cesses sensed data about the physical environment for teracting with multiple sensor platform languages, data the purposes of validating the actions of the applica- formats, and communication channels and paradigms. tion. Integrating sensing for application and debugging We present BraceForce, an open and extensible middle- support in a way that is easy, flexible, and portable is ware that allows developers to access the myriad remote essential for supporting CPS application development. sensing capabilities inherent to cyber-physical systems In general, research in this space has been focused on using very minimal code. Further, BraceForce incorpo- demonstrating the feasibility of applications, the devel- rates event- and model-driven data acquisition as first- opment of support services such as routing protocols or class concepts to provide efficient access to sensing while energy-saving algorithms, or on advancement of hard- retaining expressiveness and flexibility for applications. ware platforms and operating systems. Little focus has This paper presents the BraceForce middleware archi- been applied to effective development support for ap- tecture and key abstractions, describes their implemen- plications that integrate the capabilities of networked tations, and provides an empirical study using Brace- sensing platforms in easy to use and extensible ways. In Force to support CPS applications. addition to the variety of data formats, communication technologies, and programming platforms a developer Keywords must tackle, CPS applications also require handling net- work dynamics and energy constraints. sensor drivers, sensor network, mobile computing, smart- This paper introduces BraceForce, a middleware for phones, cyber physical systems CPS application development that simplifies the devel- opment, deployment, and debugging of CPS applica- 1. INTRODUCTION tions. In supporting application deployment, Brace- Developing and deploying CPS applications involves Force allows the developer to connect the application to a large amount of low-level programming that requires sensing assets in the deployment environment. In sup- interacting with different (often proprietary) data for- porting application debugging, BraceForce can be used mats, languages, and operating systems. In practice, to monitor a test environment using capabilities that applications are built for specific sensor network plat- may not be available in the deployment environment. Architecturally, BraceForce defines functional tiers that encapsulate related aspects but coordinate in such a way that the tiers' deployment to particular physical assets is flexible. Different tiers can be deployed on user-facing Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are devices or on sensing devices with limited capabilities, not made or distributed for profit or commercial advantage and that copies directly addressing and leveraging the specific capabili- bear this notice and the full citation on the first page. To copy otherwise, to ties and intentions of each device. BraceForce provides republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. auto-discovery of new sensing and computing assets, al- Copyright 200X ACM X-XXXXX-XX-X/XX/XX ...$5.00. lowing easy integration of new capabilities into existing velopment through an exploratory study of BraceForce applications or automatic and seamless extension of a applied to real CPS applications that rely on networked debugging environment. As BraceForce discovers new sensors. BraceForce provides a clear design contract for components, the tiered architecture organically extends integrating new sensors into existing applications. This to these new components, flexibly deploying the neces- paper makes the concrete contributions in three areas: sary tiers to the new components. 1. Supporting CPS application developers and users Instead of using a proprietary programming language (e.g., nesC [9]), supporting a single hardware platform ◦ BraceForce provides a simple and unified program- (e.g., ODK [5]), or creating a new standard (e.g., Dan- ming interface to reduce programming barriers of delion [19] or DASH [7]), BraceForce presents a simple CPS applications that integrate sensing. Java programming interface for integrating new sensing ◦ BraceForce's tiered architecture enables dynamic capabilities. To add a new sensor to BraceForce, a de- updates to CPS applications and their physical de- veloper just needs to implement a simple sensor driver ployments without intervention by the users. interface that provides essential commands (e.g., open, 2. Supporting flexible and expressive CPS applications close, query) and configuration. The driver implementa- ◦ BraceForce can be deployed to heterogeneous de- tion can be specific to the particular sensor but basically vices in different configurations to meet constraints translates raw data into meaningful BraceForce sensor of CPS applications and devices. data constructs, guided by the provided BraceForce in- ◦ BraceForce supports both pull- and push-based in- terfaces. BraceForce handles issues such as thread man- teraction with sensing devices. agement, networking, remote procedure call, etc. ◦ BraceForce embraces model-driven data acquisition BraceForce supports both the traditional pull and more to address energy concerns of CPS applications. flexible push based interaction with sensing devices. Out 3. Studying CPS application development of concern of energy-saving, BraceForce's default form of interaction is event-driven data acquisition, in which ◦ We demonstrate and evaluate how BraceForce makes sensed data is only pushed to an interested applica- both the development process more approachable tion on the occurrence of an event. Applications specify and the resulting CPS application more efficient. ◦ We demonstrate that MDDA within BraceForce thresholds on changes in sensed values that determine can significantly reduce the network overhead, which when new samples are returned. Such an approach has in turn reduces energy consumption. been shown to dramatically reduce energy costs of in- teracting with networked sensors. Existing approaches The next section places this paper's contributions in that support some integration of sensing capabilities the context of related work. In Section 3, we provide with mobile application development [5] provide only complete details of the BraceForce middleware. Sec- continuous sampling or instantaneous polling, which re- tion 4 presents the empirical design for our evaluation, quire the application to tune the interaction with the while Section 5 describes its results. sensing platform and therefore either expend extrane- ous energy or miss important sensed value changes. 2. RELATED WORK BraceForce embraces model-driven data acquisition BraceForce aims to make sensor programming trans- (MDDA) [14, 21, 22, 24, 27] to reduce energy costs of parent to CPS application developers by explicitly and integrating sensing in CPS applications. MDDA sup- intentionally hiding low-level sensing concerns. Brace- presses sensor readings that are predictable according to Force provides CPS application developers dynamic de- some a priori or learned model. BraceForce supports ployment and automatic discovery of networked sensors, (i) temporal models of data evolution based on previ- distributed data caching and aggregation capabilities, ous sensor readings [24]; (ii) models based on underlying and presents the networked sensors through a combina- physics principles of the sensed system [21]; (iii) mod- tion of event-driven and model-driven accessors, provid- els derived from applying data mining to prior sensed ing both flexibility for developers and efficiency for the data [14]; and (iv) models expressing correlations of data deployment. Existing approaches tackle similar and in in space and time [27]. While the use of model-driven some cases overlapping concerns, but, to our knowledge, data acquisition is itself not novel to
Recommended publications
  • Intel Threading Building Blocks
    Praise for Intel Threading Building Blocks “The Age of Serial Computing is over. With the advent of multi-core processors, parallel- computing technology that was once relegated to universities and research labs is now emerging as mainstream. Intel Threading Building Blocks updates and greatly expands the ‘work-stealing’ technology pioneered by the MIT Cilk system of 15 years ago, providing a modern industrial-strength C++ library for concurrent programming. “Not only does this book offer an excellent introduction to the library, it furnishes novices and experts alike with a clear and accessible discussion of the complexities of concurrency.” — Charles E. Leiserson, MIT Computer Science and Artificial Intelligence Laboratory “We used to say make it right, then make it fast. We can’t do that anymore. TBB lets us design for correctness and speed up front for Maya. This book shows you how to extract the most benefit from using TBB in your code.” — Martin Watt, Senior Software Engineer, Autodesk “TBB promises to change how parallel programming is done in C++. This book will be extremely useful to any C++ programmer. With this book, James achieves two important goals: • Presents an excellent introduction to parallel programming, illustrating the most com- mon parallel programming patterns and the forces governing their use. • Documents the Threading Building Blocks C++ library—a library that provides generic algorithms for these patterns. “TBB incorporates many of the best ideas that researchers in object-oriented parallel computing developed in the last two decades.” — Marc Snir, Head of the Computer Science Department, University of Illinois at Urbana-Champaign “This book was my first introduction to Intel Threading Building Blocks.
    [Show full text]
  • Native Implementation of Mutable Value Semantics ICOOOLPS ’21, July 13, 2021, Online
    Native Implementation of Mutable Value Semantics Dimitri Racordon Denys Shabalin Daniel Zheng [email protected] [email protected] [email protected] Faculty of Science Google Google University of Geneva Switzerland United States Switzerland Dave Abrahams Brennan Saeta [email protected] [email protected] Google Google United States United States ABSTRACT 1 INTRODUCTION Unrestricted mutation of shared state is a source of many well- Software development continuously grows in complexity, as ap- known problems. The predominant safe solutions are pure func- plications get larger and hardware more sophisticated. One well- tional programming, which bans mutation outright, and flow sen- established principle to tackle this challenge is local reasoning, de- sitive type systems, which depend on sophisticated typing rules. scrbibed by O’Hearn et al. [4] as follows: Mutable value semantics is a third approach that bans sharing in- To understand how a program works, it should be pos- stead of mutation, thereby supporting part-wise in-place mutation sible for reasoning and specification to be confined to and local reasoning, while maintaining a simple type system. In the cells that the program actually accesses. The value the purest form of mutable value semantics, references are second- of any other cell will automatically remain unchanged. class: they are only created implicitly, at function boundaries, and cannot be stored in variables or object fields. Hence, variables can There are two common ways to uphold local reasoning. One never share mutable state. takes inspiration from pure functional languages and immutability. Because references are often regarded as an indispensable tool Unfortunately, this paradigm may fail to capture the programmer’s to write efficient programs, it is legitimate to wonder whether such mental model, or prove ill-suited to express and optimize some al- a discipline can compete other approaches.
    [Show full text]
  • Ad-Hoc Data Transfer for Android Devices
    Master Degree Project Ad-hoc Data Transfer for Android Devices Author: Emre Baykal Date: 2013-03-17 Subject: Ad-hoc Data Transfer for Android Devices Level: Master Course code: 5DV00E Abstract With the introduction of smart phones and mobile devices, the rate of technology usage has became widespread. It is very likely to see anyone using mobile device on the street, in the bus, at work, at school or even at home no matter if there is a fully functional computer nearby. Particularly, the usage of smart phones is not just limited to basic communication; they are being used as a technological gadget in our daily lives for years. We can easily reach such applications on different fields e.g. image processing, audio tuning, video editing, voice recognition. With the help of these smart applications we are able to interact with our environment much faster, and consequently make life easier; relatively for sure. Apart from mobile phone industry, sharing and staying connected to our envi- ronment has become very popular. A person who has a mobile phones with latest technology desires to communicate with friends, share feelings instantly, and of course meet new people who understand him well. In this context, technology came to the point where needs of modern human overlaps todays technology. This study aims to provide a basic application to users who has got those needs in terms of sharing and communicating, for maintaining easy and costless solution. This study currently offers prototype application to this problem using WiFi Direct technology, and intends to be pioneer of its field in consequence of existing small numbers of related applications in the market.
    [Show full text]
  • Static Analysis of Unbounded Structures in Object-Oriented Programs Issue Date: 2012-12-19 Static Analysis of Unbounded Structures in Object-Oriented Programs
    Cover Page The handle http://hdl.handle.net/1887/20325 holds various files of this Leiden University dissertation. Author: Grabe, Immo Title: Static analysis of unbounded structures in object-oriented programs Issue Date: 2012-12-19 Static Analysis of Unbounded Structures in Object-Oriented Programs Proefschrift ter verkrijging van de graad van Doctor aan de Universiteit Leiden op gezag van Rector Magnificus prof. mr. P.F. van der Heijden, volgens besluit van het College voor Promoties te verdedigen op woensdag 19 december 2012 klokke 10:00 uur door Immo Grabe geboren te Kiel, Duitsland, in 1979 Promotiecommissie Promotoren: Prof. Dr. F.S. de Boer Universiteit Leiden Prof. Dr. M. Steffen Universitetet i Oslo Overige Leden: Prof. Dr. E. Broch Johnsen Universitetet i Oslo Prof. Dr. F. Arbab Universiteit Leiden Prof. Dr. J.N. Kok Universiteit Leiden Dr. M. Bonsangue Universiteit Leiden The work in this thesis has been carried out at the Christian-Albrechts- -Universit¨at zu Kiel, the Centrum Wiskunde & Informatica (CWI), and the Universiteit Leiden. The research was partially funded by the EU-project IST- 33826 Credo: Modeling and analysis of evolutionary structures for distributed services, the EU-project FP7-231620 HATS: Highly Adaptable and Trustwor- thy Software using Formal Methods, and the German-Norwegian DAAD-NWO exchange project Avabi (Automated validation for behavioral interfaces of asynchronous active objects). Copyright c 2012 by Immo Grabe Cover design by Immo Grabe. Printed by: Proefschriftmaken.nl || Uitgeverij BOXPress Published by: Uitgeverij BOXPress, Oisterwijk ISBN: 978-90-8891-154-75 Contents 1 Introduction 1 I Object Creation 5 2 Abstract Object Creation 7 2.1 Introduction............................
    [Show full text]
  • Braceforce: a Middleware to Enable Sensing Integration in Mobile Applications for Novice Programmers
    BraceForce: A Middleware to Enable Sensing Integration in Mobile Applications for Novice Programmers Xi Zheng, Dewayne E. Perry, Christine Julien The Center for Advanced Research in Software Engineering Mobile and Pervasive Computing Lab The University of Texas at Austin [email protected],[email protected],[email protected] ABSTRACT demonstrating the feasibility of applications, the develop- Even as the use of sensor networks to support mobile ap- ment of support services such as routing protocols or energy- plications grows, our ability to seamlessly and efficiently in- saving algorithms, or on advancement of hardware platforms corporate sensor network capabilities into our mobile ap- and operating systems. Little focus has been applied to ef- plications remains astoundingly difficult. Today, accessing fective development support for applications that integrate remote sensing data and integrating this data into the adap- the capabilities of networked sensing platforms in easy to use tive behavior of a dynamic user-facing mobile application re- and extensible ways. In addition to the variety of data for- quires interacting with multiple platforms, languages, data mats, communication technologies, and programming plat- formats, and communication paradigms. We present Brace- forms a developer must tackle, mobile applications also re- Force, an open and extensible middleware that allows de- quire handling network dynamics and energy constraints. velopers to access the myriad remote sensing capabilities This paper introduces BraceForce, a middleware for mo- inherent to today's mobile computing spaces (where mo- bile application development that simplifies the development, bile devices and sensors are closely integrated) using very deployment, and debugging of mobile applications.
    [Show full text]
  • Learning Object-Oriented Programming, Design and TDD with Pharo
    Learning Object-Oriented Programming, Design and TDD with Pharo Stéphane Ducasse with Damien Pollet September 29, 2017 master @ 86ac50a © 2017 by Stéphane Ducasse with Damien Pollet. This work is licensed under a Creative Commons “Attribution- NonCommercial-NoDerivatives 4.0 International” license. This is a human-readable summary of (and not a substitute for) the license: https://creativecommons.org/licenses/by-nc-nd/4.0/deed.en You are free to: s Share Copy and redistribute the material in any medium or format. The licensor cannot revoke these freedoms as long as you follow the license terms. Under the following terms: b Attribution You must give appropriate credit, provide a link to the license, and indicate if changes were made. You may do so in any reasonable manner, but not in any way that suggests the licensor endorses you or your use. n NonCommercial You may not use the material for commercial purposes. d NoDerivatives If you remix, transform, or build upon the material, you may not distribute the modified material. No additional restrictions You may not apply legal terms or technological measures that legally restrict others from doing anything the license permits. Layout and typography based on the sbabook LATEX class by Damien Pollet. Contents Illustrations viii 1 About this book 1 1.1 A word of presentation ............................ 1 1.2 Structure of the book ............................. 1 1.3 What you will learn .............................. 3 1.4 Typographic conventions ........................... 4 1.5 Videos ..................................... 5 1.6 Thanks ..................................... 5 I Getting in touch with Pharo 2 Pharo syntax in a nutshell 9 2.1 Simplicity and elegance of messages ....................
    [Show full text]
  • Android Chess: a Real Time Collaborative Software Application for Multiple Mobile Clients
    CALIFORNIA STATE UNIVERSITY, NORTHRIDGE Android Chess: A Real Time Collaborative Software Application for Multiple Mobile Clients A thesis submitted in partial fulfillment of the requirements for the degree of Master of Science in Software Engineering By Eduard S. Sarkisov December 2011 The thesis of Eduard S. Sarkisov is approved: Shan Barkataki, Ph. D. Date Jack Alanen, Ph.D. Date Richard Covington, Ph. D., Chair Date California State University, Northridge ii Table of Contents Signature Page .................................................................................................................... ii Abstract .............................................................................................................................. vi Chapter 1: OBJECTIVE AND GOALS ............................................................................. 1 Chapter 2: PROBLEM DESCRIPTION ............................................................................. 3 Chapter 3: BACKGROUND............................................................................................... 5 3.1 Why Chess................................................................................................................. 5 3.2 Why Aandroid & Java. .............................................................................................. 5 3.3 Initial Research .......................................................................................................... 6 3.4 Starting Point ............................................................................................................
    [Show full text]
  • Data Structures
    KARNATAKA STATE OPEN UNIVERSITY DATA STRUCTURES BCA I SEMESTER SUBJECT CODE: BCA 04 SUBJECT TITLE: DATA STRUCTURES 1 STRUCTURE OF THE COURSE CONTENT BLOCK 1 PROBLEM SOLVING Unit 1: Top-down Design – Implementation Unit 2: Verification – Efficiency Unit 3: Analysis Unit 4: Sample Algorithm BLOCK 2 LISTS, STACKS AND QUEUES Unit 1: Abstract Data Type (ADT) Unit 2: List ADT Unit 3: Stack ADT Unit 4: Queue ADT BLOCK 3 TREES Unit 1: Binary Trees Unit 2: AVL Trees Unit 3: Tree Traversals and Hashing Unit 4: Simple implementations of Tree BLOCK 4 SORTING Unit 1: Insertion Sort Unit 2: Shell sort and Heap sort Unit 3: Merge sort and Quick sort Unit 4: External Sort BLOCK 5 GRAPHS Unit 1: Topological Sort Unit 2: Path Algorithms Unit 3: Prim‘s Algorithm Unit 4: Undirected Graphs – Bi-connectivity Books: 1. R. G. Dromey, ―How to Solve it by Computer‖ (Chaps 1-2), Prentice-Hall of India, 2002. 2. M. A. Weiss, ―Data Structures and Algorithm Analysis in C‖, 2nd ed, Pearson Education Asia, 2002. 3. Y. Langsam, M. J. Augenstein and A. M. Tenenbaum, ―Data Structures using C‖, Pearson Education Asia, 2004 4. Richard F. Gilberg, Behrouz A. Forouzan, ―Data Structures – A Pseudocode Approach with C‖, Thomson Brooks / COLE, 1998. 5. Aho, J. E. Hopcroft and J. D. Ullman, ―Data Structures and Algorithms‖, Pearson education Asia, 1983. 2 BLOCK I BLOCK I PROBLEM SOLVING Computer problem-solving can be summed up in one word – it is demanding! It is an intricate process requiring much thought, careful planning, logical precision, persistence, and attention to detail.
    [Show full text]
  • On-Premises Developer Guide
    Informatica® Address Verification (On- Premises) 6.1.0 On-Premises Developer Guide Informatica Address Verification (On-Premises) On-Premises Developer Guide 6.1.0 September 2020 © Copyright Informatica LLC 1993, 2020 This software and documentation are provided only under a separate license agreement containing restrictions on use and disclosure. No part of this document may be reproduced or transmitted in any form, by any means (electronic, photocopying, recording or otherwise) without prior consent of Informatica LLC. U.S. GOVERNMENT RIGHTS Programs, software, databases, and related documentation and technical data delivered to U.S. Government customers are "commercial computer software" or "commercial technical data" pursuant to the applicable Federal Acquisition Regulation and agency-specific supplemental regulations. As such, the use, duplication, disclosure, modification, and adaptation is subject to the restrictions and license terms set forth in the applicable Government contract, and, to the extent applicable by the terms of the Government contract, the additional rights set forth in FAR 52.227-19, Commercial Computer Software License. Informatica, the Informatica logo, and any other Informatica-owned trademarks that appear in the document are trademarks or registered trademarks of Informatica LLC in the United States and many jurisdictions throughout the world. A current list of Informatica trademarks is available on the web at https://www.informatica.com/ trademarks.html. Other company and product names may be trade names or trademarks of their respective owners. Portions of this software and/or documentation are subject to copyright held by third parties, including without limitation: Copyright DataDirect Technologies. All rights reserved. Copyright © Sun Microsystems. All rights reserved.
    [Show full text]
  • The Tutor-In-The-Loop Model for Formative Assessment
    The Tutor-in-the-Loop Model for Formative Assessment Von der Fakultät für Mathematik, Informatik und Naturwissenschaften der RWTH Aachen University zur Erlangung des akademischen Grades eines Doktors der Naturwissenschaften genehmigte Dissertation vorgelegt von Diplom-Informatiker Daniel Chu Herding aus Münster (Westf.) Berichter: Prof. Dr. Ulrik Schroeder Prof. Dr. Christian Spannagel Tag der mündlichen Prüfung: 21. März 2013 Diese Dissertation ist auf den Internetseiten der Hochschulbibliothek online verfügbar. iii Acknowledgement Parts of the research described in this thesis has been carried out within the SAiL-M project (Semi-automatic assessment of inividual learning processes in mathematics)1. The project was funded by the German Federal Ministry of Education and Research (Bun- desministerium für Bildung und Forschung, BMBF) in the support program “Hochschulfor- schung als Beitrag zur Professionalisierung der Hochschullehre – Zukunftswerkstatt Hochschul- lehre” (“Higher Education Research as a Contribution to the Professionalization of Higher Education – Future Workshop Higher Education”). Project management organisation was provided by DLR2. SAiL-M was a joint research project of these partners: • Ludwigsburg University of Education • Karlsruhe University of Education • Weingarten University of Education • RWTH Aachen University 1 SAiL-M project: sail-m.de/en/. 2 DLR – Professionalization of Higher Education: http://www.dlr.de/pt_zwh. v Abstract Closed exercise types like multiple-choice tests are widespread in higher education, es- pecially for purposes of summative assessment. However, they cannot be considered learner-centric because they do not allow individual solutions. In contrast, assessing open-ended tasks is considerably more complex. Intelligent tutoring systems (ITS) aim at giving individual feedback fully autonomously, but due to their high development cost, they are available only for few domains.
    [Show full text]
  • A Framework for Supporting Automatic Simulation Generation from Design
    UNIVERSITY OF NEWCASTLE UPON TYNE DEPARTMENT OF COMPUTING SCIENCE UN IVERS ITY OF NEWCASTLE A Framework for Supporting Automatic Simulation Generation from Design by Leonardus Budiman Arief Ph.D. Thesis July 2001 Abstract Building a new software system requires careful planning and investigation in order to avoid any problems in the later stages of the development. By using a universally accepted design notation such as the Unified Modeling Language (UML), ambiguities in the system specification can be eliminated or minimised. The aspect that frequently needs to be investigated before the implementation stage can be commenced concerns the proposed system’s performance. It is necessary to predict whether a particular design will meet the performance requirement - i.e. is it worth implementing the system - or not. One way to obtain this performance prediction is by using simulation programs to mimic the execution of the system. Unfortunately, it is often difficult to transform the design into a simulation program without some sound knowledge of simulation techniques. In addition, new simulation programs need to be built each time for different systems - which can be tedious, time consuming and error prone. The currently available UML tools do not provide any facilities for generating simulation programs automatically from UML specifications. This shortcoming is the main motivation for this research. The work involved here includes an investigation of which UML design notations can be used; the available simulation languages or environments for running the simulation; and more importantly, a framework that can capture the simulation information from UML design notation. Using this framework, we have built tools that enable an automatic transformation of a UML design notation into a simulation program.
    [Show full text]