arXiv:1408.0521v1 [cs.CY] 3 Aug 2014 A Hands-on Education Program on Cyber Physical Systems for High School Students Vijay Gadepally ∗ Ohio Supercomputer Center 1224 Kinnear Road Columbus, Ohio vijayg@osc.edu Ashok Krishnamurthy Ohio Supercomputer Center 1224 Kinnear Road Columbus, Ohio ashok@osc.edu Umit Ozguner The Ohio State University Electrical and Computer Engineering umit@ece.osu.edu ABSTRACT Cyber Physical Systems (CPS) are the conjoining of an enti- ties’ physical and computational elements. The development of a typical CPS system follows a sequence from concep- tual modeling, testing in simulated (virtual) worlds, testing in controlled (possibly laboratory) environments and finally deployment. Throughout each (repeatable) stage, the be- havior of the physical entities, the sensing and situation as- sessment, and the computation and control options have to be understood and carefully represented through abstrac- tion. The CPS Group at the Ohio State University, as part of an NSF funded CPS project on “Autonomous Driving in Mixed Environments”, has been developing CPS related ed- ucational activities at the K-12, undergraduate and gradu- ate levels. The aim of these educational activities is to train students in the principles and design issues in CPS and to broaden the participation in science and engineering. The project team has a strong commitment to impact STEM education across the entire K-20 community. In this paper, we focus on the K-12 community and present a two-week Summer Program for high school juniors and se- niors that introduces them to the principles of CPS design and walks them through several of the design steps. We also provide an online repository that aids CPS researchers in providing a similar educational experience. Categories and Subject Descriptors K.3.2 [Computers and Education]: Computer and Infor- mation Science Education – computer science education General Terms Education, Design ∗Vijay Gadepally is a PhD candidate at The Ohio State University and corresponding author 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 not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. To copy otherwise, to republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Copyright 20XX ACM X-XXXXX-XX-X/XX/XX ...$10.00. Keywords Education, Supercomputing, Human Factors, Cyber Physi- cal Systems 1. INTRODUCTION As the Cyber-Physical Systems Group (CPS) at The Ohio State University, under an NSF funded project entitled “Au- tonomous Driving in Mixed Environments”, we have been planning educational activities to promote student interest in the Science, Technology and Mathematics (STEM) fields. The need for promoting STEM related education to middle- high school students in the STEM fields has been widely documented [7, 11, 5] and can be summarized as highlight- ing the need for the United States to prepare a sufficient number of STEM professionals capable of innovation. As described in [6], STEM education can be visualized as a pipeline that begins in early education, extends through college and ends with employment with critical transition points that includes the high school to college transition. The CPS group at Ohio State has significant experience working designing K-12 education related activities (in addi- tion to college undergraduate and graduate student courses). In [8], the authors discuss a project designed for middle school girls as a part of a week-long workshop, entitled “Fu- ture Engineers’ Summer Camp”held at The Ohio State Uni- versity. The authors describe their approach to introducing middle school girls to fault tolerant computing through a va- riety of kinesthetic learning activities. Kinesthetic learning activities [10], are proposed by the authors as a process by which students learn about theoretical concepts by carry- ing out physical activities, as opposed to passively listening to lectures. The authors describe their success using kines- thetic learning activities to explain complex algorithms, such as sorting, to younger audiences. In [9], the authors discuss coursework developed at the undergraduate level to teach students the important concept of abstraction. In this paper, we present a two-week educational pro- gram for high school students that introduces them to Cy- ber Physical Systems, and the design and development of such systems through the modeling and simulation at dif- fering levels of abstraction. Students are introduced to CPS through the engineering of autonomous vehicles or driverless cars. In particular, students are asked to develop algorithms for a vehicle (in this case, a Roomba) that can avoid obsta- cles. The aim of the program is to help students emulate the scientific process employed by CPS researchers while learn- ing to use common techniques and tools. This paper aims to describe the activities and provide sufficient resources to facilitate the emulation of such a program. CPS design, due to the cost and difficulty of direct phys- ical testing, typically goes through four phases in system design: 1. Conceptual Modeling: Understand the mathemat- ics of the problem, and propose a theoretical solution (develop equations of motion, develop analytical solu- tions where possible.) 2. Simulated Testing: Use computer simulations to validate algorithms (use a software package with a sim- ulated test bed to test obstacle avoidance algorithms.) 3. Controlled Environment Testing: Use a physical test-bed of a simulated environment to validate al- gorithms (use the developed algorithm on a physical Roomba within a simulated environment.) 4. Real World Deployment: Test the algorithm in the real world (use the developed algorithm on a physical vehicle on actual city streets.) The activities described in this paper are conducted as a part of the Summer Institute (SI) held at the Ohio Super- computer Center (OSC). SI is a two-week residential pro- gram for gifted highschool freshman, sophomores, and ju- niors designed to raise students’ interest and awareness of the STEM fields. SI challenges students to cultivate their research ability through the use of cutting-edge tools, model- ing and simulation, and interaction with active researchers. Students are also encouraged to develop interpersonal skills through presentations and participation in a variety of sci- ence related field trips, and teambuilding activities. The CPS project developed for this purpose is called “Ob- stacle Avoidance Roombas,” and is a direct product of au- tonomous vehicle research carried out by CPS researchers at Ohio State. Over two years, 2010 and 2011, eight mo- tivated students were chosen to participate in the project. These students were introduced to real-life aspects of CPS designs, trained in C/C++ programming, and taught rele- vant mathematics and physics concepts. Students were then asked to use a simulator, called Player/Stage, to program (in C/C++) Roombas (as shown in Figure 1) to complete the project. The project was divided into a sequence of four subproblems to help students understand the logical project progression. 1. Program a Roomba to follow a set of coordinates en- tered by a user 2. Program a Roomba to acquire a target, and plan the optimum path to reach the target 3. Program a Roomba to acquire a target, and avoid a single obstacle to reach the target 4. Program a Roomba to acquire a target, and avoid mul- tiple obstacles to reach the target Students are taught how simulations can provide a path to real world implementation, and use developed code on a set of robots and obstacles in a laboratory setting at Ohio State University. Figure 1: Roomba fitted with GPS tag In this article, we present details of this project, the educa- tional materials developed, and results obtained. We begin by giving an overview of the SI program, the CPS related project, and the intended competencies. We present the log- ical progression of the project through the four step process taken by CPS researchers. We conclude the project descrip- tion with student feedback and lessons learned by the CPS staff. In order to facilitate similar projects, we end with a list of the resources that were used in developing this project. 2. ABOUT OSC’S SUMMER INSTITUTE For over 20 years, the Ohio Supercomputer Center (lo- cated in Columbus,OH) has offered the Summer Institute (SI) to Ohio’s gifted students entering their sophomore, ju- nior or senior years of high school and their teachers. SI is a two-week residential program designed to raise students’ interest in the Science, Technology, Engineering and Mathe- matics (STEM) fields through a collaborative and dynamic research environment and hands on experience with the lat- est in cutting edge technology. The program is held in Columbus, OH and students live in the dormitories of The Ohio State University for this two-week period. Students typically arrive at OSC by 9 AM every morning, and work on their chosen projects until 5 PM when they are taken back to their dorm rooms and take part in a variety of so- cial activities. Each year, a number of projects are chosen by SI staffthat appeal to students. Projects are decided taking into account previous student feedback, real-world applicability of project, staffexpertise and funding. The program begins by teaching students UNIX, the oper- ating system of the computers they use. Next, students learn a programming language (C/C++/MATLAB) and any soft- ware required to complete their projects. Students are re- quired to do their own work from code implementation to final presentations. The ability to develop algorithms and an understanding of the project’s science/engineering basis are needed. 2.1 SI 2010 and 2011 Thirty two students, and four teachers participated in the SI’s held in 2010 and 2011. In SI 2010 and 2011, there were four projects ranging from robotics to medical imaging. The four projects with descriptions (as given to students) are given in [1]. The project described in this paper, Obstacle Avoidance Roombas, was presented to SI participants as follows: Obstacle Avoidance Roombas: Many organizations, such as the US Army, require vehi- cles that are capable of avoiding dangerous objects. These objects may be explosive obstacles, booby trapped buildings, or armed personnel. This sponsored project involves students using robots and robotic simulators to design an “Obstacle Avoidance Roomba.” The project uses a Roomba, an autonomous robotic vac- uum cleaner, fitted with LIDAR (a light based ranging de- vice). The goal of the project is to program the Roombas to avoid randomly placed obstacles to reach a destination. Stu- dents work with a vehicle simulator, called Player/Stage, to design “the brains” of a Roomba . After successfully simulat- ing the behavior, the research group will do “real-life” tests of the Roomba in a specially fitted laboratory. The SI program began with a presentation of four projects and students were allowed to choose one based on their in- terests. 2.2 Project: Obstacle Avoidance Roombas The project involves the design of algorithms and code that directs a Roomba to avoid obstacles and reach a tar- get or goal. Initial programming and testing of code is done using the Player/Stage [3] simulator. Player is a network server for robot control that supports a variety of robot hardware. Stage simulates (in 2.5D) a population of mo- bile robots, sensors and objects. The Player/Stage pack- age allows quick prototyping of algorithms for implementing embedded computers. The Player/Stage environment is de- signed to simulate a set of roads and intersections set up in the Control and Transportation Laboratory (CTL) testbed, at The Ohio State University. Sensors used in the testbed are simulated in the Player/Stage environment. Thus, the students see how a ”real-world” laboratory environment can be abstracted and modeled in a simulated environment. The necessity of a “cyber” environment is further demonstrated by the ease with which code prototyped in the simulator can be transferred to testbed equipment. Students are also introduced to limitations of the simulated world, and situa- tions in which the simulator may allow a violation of physics or mathematical possibilities in the real world such as a sim- ulator valid Roomba position that translates to a Roomba hovering above the ground that cannot be attained physi- cally. In general, the two weeks of SI are divided into training and project components. The first week consists primar- ily of providing students with tools and any mathematical or physical foundations required to complete their projects. Students also make multiple laboratory visits to gain an un- derstanding of the environment that they are simulating. 2.3 Competencies The CPS research team decided on various competencies that would need to be taught to students. 2.3.1 Mathematics Students were given a two hour interactive lecture that introduced them to the mathematical concepts required to complete Obstacle Avoidance Roomba project. The lecture began with a refresher on coordinate geometry and covered Figure 2: OSU ACT Vehicle and Sensors concepts such as: frames of reference, coordinate and homo- geneous transformations. Student competency was tested with simple mathematical problems such as: “The roomba is facing 45 ◦in the Roomba frame, what would be the cor- responding angle in the Earth frame?” 2.3.2 Physics Students were given a guest lecture about the physics be- hind CPS fundamentals. Students were taught that vehicles are often modeled as a point-mass or a bicycle to simplify calculations. Students were then taught about the point- mass model and Bicycle model of vehicles. Students also re- viewed Newton’s laws, friction, and simple dynamics. Stu- dent competency was tested informally through questions and answers. 2.3.3 Tools Students were introduced to various tools used by CPS researchers in the design and deployment of autonomous ve- hicles. Students were given a tour of Ohio State’s Center for Automotive Research and one of the autonomous vehi- cles as shown in Figure 2. Instruction concentrated on the sensors used in the vehicle, namely the GPS systems, Laser Rangefinder and Radar systems. Student competency was tested informally through questions and answers. 2.3.4 Programming Students were introduced to programming of different lan- guages used in CPS design. Instruction concentrated on C/C++ (two popular programming languages) and MAT- LAB (a very high level programming language popular with engineers). Students were given a two hour lecture on pro- gramming basics, that concentrated on syntax, and com- mands. Training materials was taken largely from previ- ously developed training material available at [2]. Student competency was tested throughout the project. 2.3.5 Scientific Process The scientific process employed by CPS researchers, de- scribed in Section 1, was the central theme of the Obsta- cle Avoidance Roomba project. Students were reminded throughout the project of the process and that the logical progression of the project followed this process. 3. PHASE 1: CONCEPTUAL MODELING In the first phase, students are provided with details of the problem to be solved and asked to develop algorithms for each sub-part of the problem. The goal of this phase is to introduce students to the process of learning the mathe- matical and physical competencies described in section 2.3 and turning them into a proposed algorithm. Another goal is to introduce students to the concept of peer review. Students are also given real life examples of autonomous vehicles performing obstacle avoidance. Student also learned about the sensors used in Roombas, giving them an under- standing of the type of data that they can use for develop- ing their algorithms. Student learning is tested continuously through simple exercises. Once students are comfortable with the competencies re- quired for project completion, they are split into two groups of two student each. Students then work in their sub-group collaboratively develop high level algorithms for the four parts of the problem. In order to simulate the peer-review process of scientific development, students are asked to present their algorithms for each of the problem parts to the other group and instructor for comments and feedback. 4. PHASE 2: SIMULATED TESTING Once students have developed algorithms that pass the peer review process, they are asked to use computer sim- ulations to validate their algorithms for each of the sub- problems. The goal of this phase is to provide students with hand-on experience with the simulation tools (one of the in- tended competencies) used by CPS researchers, in addition to introducing students to the process of simulated valida- tion of algorithms. 4.1 Training and Tools Students use the Player/Stage package, a commonly used robot simulation program. Player provides a network inter- face for a variety of robot hardware, such as the Roomba. Stage is a mobile robot simulator that provides handles to a variety of sensor models. The environment used within Player/Stage has been developed by the Center for Intel- ligent Transportation Research (CITR), and simulates the physical testbed, called SimVille, available for laboratory testing at CITR. SimVille is described later in this paper. The Player/Stage program uses the C/C++ programming language to control the simulated Roombas movements. De- veloped code can be transferred directly to the actual Room- bas in the physical testbed. To introduce students to the Player/Stage syntax, stu- dents are walked through the solution of the first problem. Students are then asked to convert the algorithms developed in Phase 1 into Player/Stage compatible C/C++ code. 4.2 Activities Students spent approximately twenty hours programming in C/C++ with the Player/Stage environment. Their goal was to solve the remaining three parts of the problem as mentioned in section 2.2. At the end of each problem, stu- dents are asked to present their code (to emulate the code Figure 3: Simulated Version of Third Part of Project (Red Circle represents the Roomba, Black Squares Represent Obstacles) Figure 4: Code Sample of Group 1 review process), and simulations to other students and the project lead (for peer review). In order to promote the development of robust algorithms and code, students try to provide conditions that may“break” the code or algorithm. Further, the instructor may modify the environment, such as moving the obstacle. The aim of this task is to teach students the fundamentals of designing robust code, and the fact that research and development is an iterative process. Once students and instructor are satis- fied with the robustness of code and algorithm, they proceed to the next part of the problem. An example of the simulated output for Problem 4 is given in Figure 3. For this part, stu- dents use Player/Stage to program the Roomba (red circle) to pass through all the Obstacles (black squares). 4.3 Difference in Student Approaches Students were encouraged to use the the math and physics they were taught to develop their own algorithm for con- trolling the Roomba. For example, in the third part of the project, where students were asked to program a Roomba to reach a target by avoiding a single obstacle, one group ap- proached the problem by coding a set of switch statements that would move the Roomba in a deterministic manner de- pending on which quadrant of the screen the obstacle is in. Another group programmed the Roomba to travel to a fixed point away from the obstacle. The two code samples of Figures 4 and 5 show one such difference in approach. 5. PHASE 3: CONTROLLED ENVIRONMENT TESTING Once students have sufficiently robust code, they are asked to use a controlled representation (laboratory setting) of the real world - a testbed, called SimVille. SimVille was cre- ated in 2007 in order to expedite research efforts in urban environment scenarios. SimVille [12] is a 1/7 scale road net- work that is designed to provide easy access to a road net- work. Additionally ceiling mounted cameras provide a “Vir- Figure 5: Code Sample of Group 2 tual GPS”system that robots (Roombas) using SimVille can get information about their location, location of obstacles, etc. The Player program works as the network interface to communicate between Roombas, GPS sensors, and control code. Control code is a slightly modified version of code written for the Stage simulator. A sample configuration of SimVille is given in Figure 6. The goal of this phase is to in- troduce students to the concept of a controlled (laboratory) environment, and illustrate the parallels between code de- veloped for the simulated environment and code needed for the testbed environment. Students also learn the difference between these settings. For example, some of the Roomba speed values used in the simulated environment cannot be physically realized in the testbed environment because of physical limitations of the Roomba motors, and floor mate- rial which are approximated in the simulator. 5.1 Presentation and Tools Students are given multiple tours of the testbed, over the course of the algorithm development and simulator proof- of-concept phases, to give them an understanding of the lab capabilities, and physical constraints. Additionally, students are allowed to play with the roombas to understand the dy- namics of movement. Students are shown how to translate code written in Stage to the actual Roombas, through a var- ied compilation technique. Student are also given a detailed view of the sensors present in the testbed. Once students have programmed their algorithms for the four problems, they are asked to implement their code on the testbed. Students are able to modify the code they have written for Stage and use their algorithms on the actual Roombas. 5.2 Activities Figure 6: Testbed While students are testing their code with the Roombas in SimVille, SI staffintroduce perturbations to the environ- ment by moving obstacles to give students an understand- ing of working with moving obstacles. Students are asked to modify their code, if necessary, to solve any issues that are brought about by these perturbations. Students complete their testing for all four parts of the problem by the end of the second week 6. PHASE 4: REAL WORLD DEPLOYMENT While deploying the developed code on an actual vehicle is not feasible, given the short time span, students are in- troduced to this important phase through tours of several laboratories, including the Center for Automotive Research (CAR), which houses the OSU Autonomous Vehicle. Stu- dents also have an opportunity to visit other laboratories at The Ohio State University such as: a Bio-dynamics Labora- tory, and a Virtual Reality Laboratory. The goals of these laboratory visits is to show students the practical aspects of their work. The goal of this phase is to show students the final phase of the CPS research process - real world deploy- ment. 7. CLOSING AND FEEDBACK At the end of the two-week period, students are asked to present their research, and results to all of the SI stu- dents, Ohio State University faculty, SI Staff, and parents. Students are also asked to give their feedback, and any sug- gestions for future SI programs. 7.1 Participant Feedback Upon completion of the Summer Institute program in 2010 and 2011, students were asked for their feedback of the project, and suggestions for how to improve the project in subsequent years. Excerpts from their comments are given below: 7.1.1 Student 1 “For the past two weeks, I have been enrolled in the Ob- stacle Avoidance Roomba project at the OSC Summer Insti- tute. I have found it both informative and entertaining, and strongly urge that it be offered again next year. Learning C and the rudiments of autonomous-vehicle programming is engaging, and I enjoy the relaxed and informal working en- vironment. However, I felt that the competitive arrangement of two pairs of programmers against one another was some- what counterproductive: we probably would have been able to accomplish considerably more if we had pooled all of our resources.” Video feedback can be found at [4]. 7.1.2 Student 2 “At first I was really just looking forward to an easy project with roombas since I’ve used them before. Not using any other sensors was a bummer, but I realize now that it’d be impossible to incorporate the sensors in our time frame. I liked working in a big group better than in our teams of 2, because it got really competitive at times. My favorite parts of the project were when the program actually worked when compiled and driving the roombas at Dreese labs. I’ve actu- ally learned a lot about psuedocode, high level coding, and dif- ferent approaches to obstacle avoidance and using the GPS sensors. Overall I really enjoyed working on the project, and it’s definitely the highlight of my summer.” 7.1.3 Student 3 “During the past two weeks I had lots of fun learning about Roombas, C Programming, and Quake 3. I thought that the pace of the project was slow enough that I did not feel rushed, yet fast enough to allow us to be productive. I think that it might have been interesting to replace the multi-obstacle lab with a lab having to do with sensors. We talked a lot about the importance of sensors, so I was a bit disappointed to discover that we would not be using them in our project. The camp was extremely fun because of all of the participating students and staff. This was probably one of the best two weeks I have had in a while.” 7.1.4 Student 4 “When I was first assigned this project, my head was in- trigued by the possibilities of what we could program the Roomba to do. Shortly after we started programming, how- ever, we ran face to face to the difficulties of using C to tell the Roomba where and how to move. Project Obstacle Avoid- ance Roomba is an great assignment to enlighten those un- familiar with Autonomous Vehicles. The Roomba Project il- lustrates the challenges of avoiding the walls, moving around the obstacles, even turning the Roomba. Although I had no part in writing the functions of controlling the Roomba, there was plenty of work of just coding in an algorithm the robot can follow to drive itself. Obstacle Avoidance Roomba Project would be a great stepping-stone to help interested newcomers step into the field of Autonomous Driving.” 7.2 Lessons and Future Projects The SI Stafflearned many valuable lessons from students, and will use these to provide improved iterations of the project in subsequent years. 7.2.1 Scope Students particularly enjoy the coding components of the project. The scope of the project is sufficient for students to have an understanding of CPS fundamentals without ex- cessive training. Coding training given in C/C++ and is in- tended to help students with the Player/Stage programming. Basic mathematical training in coordinate transformations, homogeneous transformations in addition to basic physics is also provided to give students further understanding of the Roombas. Students expressed interest in using a larger set of sensors (as opposed to purely GPS coordinates). Inclu- sion of further sensors may be difficult within the 2 week length of the program. 7.2.2 Competition Students at times felt that the competitive process was counterproductive and that they would rather that compo- nent not be in the next iteration of the project. Students indicated a preference for group based work - something they felt would be more productive. This modification was made in SI 2011 and groups worked in a collaborative manner while maintaining the peer review process. Students were also allowed to switch groups based on approaches or ar- eas of interest. The collaborative group structure was more successful than the competing group structure. 7.2.3 Working with varying student capabilities One of the difficulties faced by the project teams was in- structing students with differing technical capabilities, es- pecially in knowledge of programming. In SI 2010 students were paired such that each group would have one student proficient in programming working alongside a student who was not as familiar with programming. With student feed- back that they felt this process required them to “carry” another student, in SI 2011, an additional instructor (who was also a SI 2010 student) was brought in to give person- alized attention to students who required technical help - so as to ensure proficient students were not slowed down. 7.2.4 Metrics to Judge Project One metric used to judge program success in SI 2010 and 2011 is student willingness to participate in future robotics related activities after the Summer Institute program. An- other metric, student learning of competencies, was tested through informal systems. In future iterations, the authors wish to devise a formal evaluation to judge student compe- tencies. 7.2.5 Project Evaluation In SI 2010 and 2011, evaluation was collected through a daily online journal that asked students the following ques- tions: 1. What did you learn today? 2. Who did you help out today and how? 3. Who helped you out today and how? 4. What did you like best about today’s activities? 5. What did you like least about today’s activities? Such information was collected over eight days culminat- ing in a final comprehensive survey about the overall experi- ence. Data was also collected about student-instructor inter- actions and improvements that could be made to the overall program and particular project. In the final survey, 100% of the students “Strongly Agree” that the instructors were helpful. Multiple students cited that the “High Point” of the experience was in the Roomba testbed. One student cited a “Low Point” when they had difficulty with the coding com- ponent of the project. Overall, 75% of the students felt that the programming portion of the project was enjoyable with 25% feeling that they needed greater prior programming ex- perience. Students were also asked to comment about the experience such as lab tours, residence halls, etc. As a mea- sure of being taught in a way that corresponds to learning style, 36% said “Strongly Agree”, 43% said “Agree” and 21% said “Neutral.” 100% of the students said that the project has deepend their desire to work in the field of robotics or engineering. 8. TOOLS AND RESOURCES The aim of this paper is to present a CPS related study that can be recreated. This section outlines the tools/material used and basic instructions on creating a similar project. • The first step is to download and install the Player/Stage project from http://playerstage.sourceforge.net. Down- load and installation instructions for a variety of hard- ware configurations is included in the instruction man- ual. • The programmable roombas used in the testbed com- ponent of the project can be purchased from http://store.irobot.com. The Player/Stage simulator can be configured to work with this Roomba. • To view and download the SI 2011 Source Code: http://dl.dropbox.com/u/1268613/codesamples.zip • To view and/or download the SI 2010 Student Presen- tation and Videos: http://dl.dropbox.com/u/1268613/RoombaProject.zip Other related links and resources: 1. Student Feedback Video: http://www.youtube.com/watch?v=Ke8ONfF-Q64 2. NSF CPS Program: http://www.nsf.gov/funding/pgm summ.jsp?pims id=503286 3. C/C++ Training Material: http://www.osc.edu/supercomputing/training/ 9. CONCLUSIONS We present a two week educational program for High School students as a part of the Summer Institute program at the Ohio Supercomputer Center. Students are introduced to CPS related fundamentals, and develop the algorithm and code for an obstacle avoidance Roomba. Students are taught the scientific process of moving from simulated to real world testing, and are taught the CPS core competencies of math- ematics, physics, programming languages, and other tools. Additionally, students are introduced to the concepts of peer review, and iterative development. Student feedback showed that students greatly enjoy the program, and students indi- cate interest in future participation in CPS related research activities. We also give the reader the tools and resources required to recreate the summer educational program. 10. ACKNOWLEDGMENTS This work was supported by a National Science Foun- dation Grant. The authors would also like to thank Paul Sivilotti, Keith Redmill, Scott Biddlestone, Arda Kurt, and Micheal Vernier for their support in developing the educa- tion activities. 11. REFERENCES [1] Ohio supercomputer center, si 2010 project listing: http://www.osc.edu/education/si/projects/index.shtml. [2] The ohio supercomputer center, training material: http://www.osc.edu/supercomputing/training/. [3] The player/stage project: http://playerstage.sourceforge.net/. [4] Upper arlington student discusses osc’s 2010 summer institute and computational science: http://www.youtube.com/watch?v=ke8onff-q64. [5] J. Kuenzi. Science, technology, engineering, and mathematics (STEM) education issues and legislative options. In Library of Congress, Washington DC Congressional Research Office, 2006. [6] B. Lowell, H. Salzman, H. Bernstein, and E. Henderson. Steady as she goes? Three generations of students through the science and engineering pipeline. In Annual Meetings of the Association for Public Policy Analysis and Management Washington, DC on November, volume 7, pages 9–10, 2009. [7] L. Perez-Felkner, S. McDonald, and B. Schneider. What Happens to High-Achieving Females after High School? Gender and Persistence on the Postsecondary STEM Pipeline. [8] P. Sivilotti and M. Demirbas. Introducing middle school girls to fault tolerant computing. In Proceedings of the 34th SIGCSE technical symposium on Computer science education, pages 327–331. ACM, 2003. [9] P. Sivilotti and M. Lang. Interfaces first (and foremost) with Java. In Proceedings of the 41st ACM technical symposium on Computer science education, pages 515–519. ACM, 2010. [10] P. Sivilotti and S. Pike. The suitability of kinesthetic learning activities for teaching distributed algorithms. ACM SIGCSE Bulletin, 39(1):362–366, 2007. [11] W. Tyson, R. Lee, K. Borman, and M. Hanson. Science, Technology, Engineering, and Mathematics (STEM) Pathways: High School Science and Math Coursework and Postsecondary Degree Attainment. Journal of Education for Students Placed at Risk (JESPAR), 12(3):28, 2007. [12] M. Vernier. Virtual sensor system: Merging the real world with a simulation environment, 2010. arXiv:1408.0521v1 [cs.CY] 3 Aug 2014 A Hands-on Education Program on Cyber Physical Systems for High School Students Vijay Gadepally ∗ Ohio Supercomputer Center 1224 Kinnear Road Columbus, Ohio vijayg@osc.edu Ashok Krishnamurthy Ohio Supercomputer Center 1224 Kinnear Road Columbus, Ohio ashok@osc.edu Umit Ozguner The Ohio State University Electrical and Computer Engineering umit@ece.osu.edu ABSTRACT Cyber Physical Systems (CPS) are the conjoining of an enti- ties’ physical and computational elements. The development of a typical CPS system follows a sequence from concep- tual modeling, testing in simulated (virtual) worlds, testing in controlled (possibly laboratory) environments and finally deployment. Throughout each (repeatable) stage, the be- havior of the physical entities, the sensing and situation as- sessment, and the computation and control options have to be understood and carefully represented through abstrac- tion. The CPS Group at the Ohio State University, as part of an NSF funded CPS project on “Autonomous Driving in Mixed Environments”, has been developing CPS related ed- ucational activities at the K-12, undergraduate and gradu- ate levels. The aim of these educational activities is to train students in the principles and design issues in CPS and to broaden the participation in science and engineering. The project team has a strong commitment to impact STEM education across the entire K-20 community. In this paper, we focus on the K-12 community and present a two-week Summer Program for high school juniors and se- niors that introduces them to the principles of CPS design and walks them through several of the design steps. We also provide an online repository that aids CPS researchers in providing a similar educational experience. Categories and Subject Descriptors K.3.2 [Computers and Education]: Computer and Infor- mation Science Education – computer science education General Terms Education, Design ∗Vijay Gadepally is a PhD candidate at The Ohio State University and corresponding author 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 not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. To copy otherwise, to republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Copyright 20XX ACM X-XXXXX-XX-X/XX/XX ...$10.00. Keywords Education, Supercomputing, Human Factors, Cyber Physi- cal Systems 1. INTRODUCTION As the Cyber-Physical Systems Group (CPS) at The Ohio State University, under an NSF funded project entitled “Au- tonomous Driving in Mixed Environments”, we have been planning educational activities to promote student interest in the Science, Technology and Mathematics (STEM) fields. The need for promoting STEM related education to middle- high school students in the STEM fields has been widely documented [7, 11, 5] and can be summarized as highlight- ing the need for the United States to prepare a sufficient number of STEM professionals capable of innovation. As described in [6], STEM education can be visualized as a pipeline that begins in early education, extends through college and ends with employment with critical transition points that includes the high school to college transition. The CPS group at Ohio State has significant experience working designing K-12 education related activities (in addi- tion to college undergraduate and graduate student courses). In [8], the authors discuss a project designed for middle school girls as a part of a week-long workshop, entitled “Fu- ture Engineers’ Summer Camp”held at The Ohio State Uni- versity. The authors describe their approach to introducing middle school girls to fault tolerant computing through a va- riety of kinesthetic learning activities. Kinesthetic learning activities [10], are proposed by the authors as a process by which students learn about theoretical concepts by carry- ing out physical activities, as opposed to passively listening to lectures. The authors describe their success using kines- thetic learning activities to explain complex algorithms, such as sorting, to younger audiences. In [9], the authors discuss coursework developed at the undergraduate level to teach students the important concept of abstraction. In this paper, we present a two-week educational pro- gram for high school students that introduces them to Cy- ber Physical Systems, and the design and development of such systems through the modeling and simulation at dif- fering levels of abstraction. Students are introduced to CPS through the engineering of autonomous vehicles or driverless cars. In particular, students are asked to develop algorithms for a vehicle (in this case, a Roomba) that can avoid obsta- cles. The aim of the program is to help students emulate the scientific process employed by CPS researchers while learn- ing to use common techniques and tools. This paper aims to describe the activities and provide sufficient resources to facilitate the emulation of such a program. CPS design, due to the cost and difficulty of direct phys- ical testing, typically goes through four phases in system design: 1. Conceptual Modeling: Understand the mathemat- ics of the problem, and propose a theoretical solution (develop equations of motion, develop analytical solu- tions where possible.) 2. Simulated Testing: Use computer simulations to validate algorithms (use a software package with a sim- ulated test bed to test obstacle avoidance algorithms.) 3. Controlled Environment Testing: Use a physical test-bed of a simulated environment to validate al- gorithms (use the developed algorithm on a physical Roomba within a simulated environment.) 4. Real World Deployment: Test the algorithm in the real world (use the developed algorithm on a physical vehicle on actual city streets.) The activities described in this paper are conducted as a part of the Summer Institute (SI) held at the Ohio Super- computer Center (OSC). SI is a two-week residential pro- gram for gifted highschool freshman, sophomores, and ju- niors designed to raise students’ interest and awareness of the STEM fields. SI challenges students to cultivate their research ability through the use of cutting-edge tools, model- ing and simulation, and interaction with active researchers. Students are also encouraged to develop interpersonal skills through presentations and participation in a variety of sci- ence related field trips, and teambuilding activities. The CPS project developed for this purpose is called “Ob- stacle Avoidance Roombas,” and is a direct product of au- tonomous vehicle research carried out by CPS researchers at Ohio State. Over two years, 2010 and 2011, eight mo- tivated students were chosen to participate in the project. These students were introduced to real-life aspects of CPS designs, trained in C/C++ programming, and taught rele- vant mathematics and physics concepts. Students were then asked to use a simulator, called Player/Stage, to program (in C/C++) Roombas (as shown in Figure 1) to complete the project. The project was divided into a sequence of four subproblems to help students understand the logical project progression. 1. Program a Roomba to follow a set of coordinates en- tered by a user 2. Program a Roomba to acquire a target, and plan the optimum path to reach the target 3. Program a Roomba to acquire a target, and avoid a single obstacle to reach the target 4. Program a Roomba to acquire a target, and avoid mul- tiple obstacles to reach the target Students are taught how simulations can provide a path to real world implementation, and use developed code on a set of robots and obstacles in a laboratory setting at Ohio State University. Figure 1: Roomba fitted with GPS tag In this article, we present details of this project, the educa- tional materials developed, and results obtained. We begin by giving an overview of the SI program, the CPS related project, and the intended competencies. We present the log- ical progression of the project through the four step process taken by CPS researchers. We conclude the project descrip- tion with student feedback and lessons learned by the CPS staff. In order to facilitate similar projects, we end with a list of the resources that were used in developing this project. 2. ABOUT OSC’S SUMMER INSTITUTE For over 20 years, the Ohio Supercomputer Center (lo- cated in Columbus,OH) has offered the Summer Institute (SI) to Ohio’s gifted students entering their sophomore, ju- nior or senior years of high school and their teachers. SI is a two-week residential program designed to raise students’ interest in the Science, Technology, Engineering and Mathe- matics (STEM) fields through a collaborative and dynamic research environment and hands on experience with the lat- est in cutting edge technology. The program is held in Columbus, OH and students live in the dormitories of The Ohio State University for this two-week period. Students typically arrive at OSC by 9 AM every morning, and work on their chosen projects until 5 PM when they are taken back to their dorm rooms and take part in a variety of so- cial activities. Each year, a number of projects are chosen by SI staffthat appeal to students. Projects are decided taking into account previous student feedback, real-world applicability of project, staffexpertise and funding. The program begins by teaching students UNIX, the oper- ating system of the computers they use. Next, students learn a programming language (C/C++/MATLAB) and any soft- ware required to complete their projects. Students are re- quired to do their own work from code implementation to final presentations. The ability to develop algorithms and an understanding of the project’s science/engineering basis are needed. 2.1 SI 2010 and 2011 Thirty two students, and four teachers participated in the SI’s held in 2010 and 2011. In SI 2010 and 2011, there were four projects ranging from robotics to medical imaging. The four projects with descriptions (as given to students) are given in [1]. The project described in this paper, Obstacle Avoidance Roombas, was presented to SI participants as follows: Obstacle Avoidance Roombas: Many organizations, such as the US Army, require vehi- cles that are capable of avoiding dangerous objects. These objects may be explosive obstacles, booby trapped buildings, or armed personnel. This sponsored project involves students using robots and robotic simulators to design an “Obstacle Avoidance Roomba.” The project uses a Roomba, an autonomous robotic vac- uum cleaner, fitted with LIDAR (a light based ranging de- vice). The goal of the project is to program the Roombas to avoid randomly placed obstacles to reach a destination. Stu- dents work with a vehicle simulator, called Player/Stage, to design “the brains” of a Roomba . After successfully simulat- ing the behavior, the research group will do “real-life” tests of the Roomba in a specially fitted laboratory. The SI program began with a presentation of four projects and students were allowed to choose one based on their in- terests. 2.2 Project: Obstacle Avoidance Roombas The project involves the design of algorithms and code that directs a Roomba to avoid obstacles and reach a tar- get or goal. Initial programming and testing of code is done using the Player/Stage [3] simulator. Player is a network server for robot control that supports a variety of robot hardware. Stage simulates (in 2.5D) a population of mo- bile robots, sensors and objects. The Player/Stage pack- age allows quick prototyping of algorithms for implementing embedded computers. The Player/Stage environment is de- signed to simulate a set of roads and intersections set up in the Control and Transportation Laboratory (CTL) testbed, at The Ohio State University. Sensors used in the testbed are simulated in the Player/Stage environment. Thus, the students see how a ”real-world” laboratory environment can be abstracted and modeled in a simulated environment. The necessity of a “cyber” environment is further demonstrated by the ease with which code prototyped in the simulator can be transferred to testbed equipment. Students are also introduced to limitations of the simulated world, and situa- tions in which the simulator may allow a violation of physics or mathematical possibilities in the real world such as a sim- ulator valid Roomba position that translates to a Roomba hovering above the ground that cannot be attained physi- cally. In general, the two weeks of SI are divided into training and project components. The first week consists primar- ily of providing students with tools and any mathematical or physical foundations required to complete their projects. Students also make multiple laboratory visits to gain an un- derstanding of the environment that they are simulating. 2.3 Competencies The CPS research team decided on various competencies that would need to be taught to students. 2.3.1 Mathematics Students were given a two hour interactive lecture that introduced them to the mathematical concepts required to complete Obstacle Avoidance Roomba project. The lecture began with a refresher on coordinate geometry and covered Figure 2: OSU ACT Vehicle and Sensors concepts such as: frames of reference, coordinate and homo- geneous transformations. Student competency was tested with simple mathematical problems such as: “The roomba is facing 45 ◦in the Roomba frame, what would be the cor- responding angle in the Earth frame?” 2.3.2 Physics Students were given a guest lecture about the physics be- hind CPS fundamentals. Students were taught that vehicles are often modeled as a point-mass or a bicycle to simplify calculations. Students were then taught about the point- mass model and Bicycle model of vehicles. Students also re- viewed Newton’s laws, friction, and simple dynamics. Stu- dent competency was tested informally through questions and answers. 2.3.3 Tools Students were introduced to various tools used by CPS researchers in the design and deployment of autonomous ve- hicles. Students were given a tour of Ohio State’s Center for Automotive Research and one of the autonomous vehi- cles as shown in Figure 2. Instruction concentrated on the sensors used in the vehicle, namely the GPS systems, Laser Rangefinder and Radar systems. Student competency was tested informally through questions and answers. 2.3.4 Programming Students were introduced to programming of different lan- guages used in CPS design. Instruction concentrated on C/C++ (two popular programming languages) and MAT- LAB (a very high level programming language popular with engineers). Students were given a two hour lecture on pro- gramming basics, that concentrated on syntax, and com- mands. Training materials was taken largely from previ- ously developed training material available at [2]. Student competency was tested throughout the project. 2.3.5 Scientific Process The scientific process employed by CPS researchers, de- scribed in Section 1, was the central theme of the Obsta- cle Avoidance Roomba project. Students were reminded throughout the project of the process and that the logical progression of the project followed this process. 3. PHASE 1: CONCEPTUAL MODELING In the first phase, students are provided with details of the problem to be solved and asked to develop algorithms for each sub-part of the problem. The goal of this phase is to introduce students to the process of learning the mathe- matical and physical competencies described in section 2.3 and turning them into a proposed algorithm. Another goal is to introduce students to the concept of peer review. Students are also given real life examples of autonomous vehicles performing obstacle avoidance. Student also learned about the sensors used in Roombas, giving them an under- standing of the type of data that they can use for develop- ing their algorithms. Student learning is tested continuously through simple exercises. Once students are comfortable with the competencies re- quired for project completion, they are split into two groups of two student each. Students then work in their sub-group collaboratively develop high level algorithms for the four parts of the problem. In order to simulate the peer-review process of scientific development, students are asked to present their algorithms for each of the problem parts to the other group and instructor for comments and feedback. 4. PHASE 2: SIMULATED TESTING Once students have developed algorithms that pass the peer review process, they are asked to use computer sim- ulations to validate their algorithms for each of the sub- problems. The goal of this phase is to provide students with hand-on experience with the simulation tools (one of the in- tended competencies) used by CPS researchers, in addition to introducing students to the process of simulated valida- tion of algorithms. 4.1 Training and Tools Students use the Player/Stage package, a commonly used robot simulation program. Player provides a network inter- face for a variety of robot hardware, such as the Roomba. Stage is a mobile robot simulator that provides handles to a variety of sensor models. The environment used within Player/Stage has been developed by the Center for Intel- ligent Transportation Research (CITR), and simulates the physical testbed, called SimVille, available for laboratory testing at CITR. SimVille is described later in this paper. The Player/Stage program uses the C/C++ programming language to control the simulated Roombas movements. De- veloped code can be transferred directly to the actual Room- bas in the physical testbed. To introduce students to the Player/Stage syntax, stu- dents are walked through the solution of the first problem. Students are then asked to convert the algorithms developed in Phase 1 into Player/Stage compatible C/C++ code. 4.2 Activities Students spent approximately twenty hours programming in C/C++ with the Player/Stage environment. Their goal was to solve the remaining three parts of the problem as mentioned in section 2.2. At the end of each problem, stu- dents are asked to present their code (to emulate the code Figure 3: Simulated Version of Third Part of Project (Red Circle represents the Roomba, Black Squares Represent Obstacles) Figure 4: Code Sample of Group 1 review process), and simulations to other students and the project lead (for peer review). In order to promote the development of robust algorithms and code, students try to provide conditions that may“break” the code or algorithm. Further, the instructor may modify the environment, such as moving the obstacle. The aim of this task is to teach students the fundamentals of designing robust code, and the fact that research and development is an iterative process. Once students and instructor are satis- fied with the robustness of code and algorithm, they proceed to the next part of the problem. An example of the simulated output for Problem 4 is given in Figure 3. For this part, stu- dents use Player/Stage to program the Roomba (red circle) to pass through all the Obstacles (black squares). 4.3 Difference in Student Approaches Students were encouraged to use the the math and physics they were taught to develop their own algorithm for con- trolling the Roomba. For example, in the third part of the project, where students were asked to program a Roomba to reach a target by avoiding a single obstacle, one group ap- proached the problem by coding a set of switch statements that would move the Roomba in a deterministic manner de- pending on which quadrant of the screen the obstacle is in. Another group programmed the Roomba to travel to a fixed point away from the obstacle. The two code samples of Figures 4 and 5 show one such difference in approach. 5. PHASE 3: CONTROLLED ENVIRONMENT TESTING Once students have sufficiently robust code, they are asked to use a controlled representation (laboratory setting) of the real world - a testbed, called SimVille. SimVille was cre- ated in 2007 in order to expedite research efforts in urban environment scenarios. SimVille [12] is a 1/7 scale road net- work that is designed to provide easy access to a road net- work. Additionally ceiling mounted cameras provide a “Vir- Figure 5: Code Sample of Group 2 tual GPS”system that robots (Roombas) using SimVille can get information about their location, location of obstacles, etc. The Player program works as the network interface to communicate between Roombas, GPS sensors, and control code. Control code is a slightly modified version of code written for the Stage simulator. A sample configuration of SimVille is given in Figure 6. The goal of this phase is to in- troduce students to the concept of a controlled (laboratory) environment, and illustrate the parallels between code de- veloped for the simulated environment and code needed for the testbed environment. Students also learn the difference between these settings. For example, some of the Roomba speed values used in the simulated environment cannot be physically realized in the testbed environment because of physical limitations of the Roomba motors, and floor mate- rial which are approximated in the simulator. 5.1 Presentation and Tools Students are given multiple tours of the testbed, over the course of the algorithm development and simulator proof- of-concept phases, to give them an understanding of the lab capabilities, and physical constraints. Additionally, students are allowed to play with the roombas to understand the dy- namics of movement. Students are shown how to translate code written in Stage to the actual Roombas, through a var- ied compilation technique. Student are also given a detailed view of the sensors present in the testbed. Once students have programmed their algorithms for the four problems, they are asked to implement their code on the testbed. Students are able to modify the code they have written for Stage and use their algorithms on the actual Roombas. 5.2 Activities Figure 6: Testbed While students are testing their code with the Roombas in SimVille, SI staffintroduce perturbations to the environ- ment by moving obstacles to give students an understand- ing of working with moving obstacles. Students are asked to modify their code, if necessary, to solve any issues that are brought about by these perturbations. Students complete their testing for all four parts of the problem by the end of the second week 6. PHASE 4: REAL WORLD DEPLOYMENT While deploying the developed code on an actual vehicle is not feasible, given the short time span, students are in- troduced to this important phase through tours of several laboratories, including the Center for Automotive Research (CAR), which houses the OSU Autonomous Vehicle. Stu- dents also have an opportunity to visit other laboratories at The Ohio State University such as: a Bio-dynamics Labora- tory, and a Virtual Reality Laboratory. The goals of these laboratory visits is to show students the practical aspects of their work. The goal of this phase is to show students the final phase of the CPS research process - real world deploy- ment. 7. CLOSING AND FEEDBACK At the end of the two-week period, students are asked to present their research, and results to all of the SI stu- dents, Ohio State University faculty, SI Staff, and parents. Students are also asked to give their feedback, and any sug- gestions for future SI programs. 7.1 Participant Feedback Upon completion of the Summer Institute program in 2010 and 2011, students were asked for their feedback of the project, and suggestions for how to improve the project in subsequent years. Excerpts from their comments are given below: 7.1.1 Student 1 “For the past two weeks, I have been enrolled in the Ob- stacle Avoidance Roomba project at the OSC Summer Insti- tute. I have found it both informative and entertaining, and strongly urge that it be offered again next year. Learning C and the rudiments of autonomous-vehicle programming is engaging, and I enjoy the relaxed and informal working en- vironment. However, I felt that the competitive arrangement of two pairs of programmers against one another was some- what counterproductive: we probably would have been able to accomplish considerably more if we had pooled all of our resources.” Video feedback can be found at [4]. 7.1.2 Student 2 “At first I was really just looking forward to an easy project with roombas since I’ve used them before. Not using any other sensors was a bummer, but I realize now that it’d be impossible to incorporate the sensors in our time frame. I liked working in a big group better than in our teams of 2, because it got really competitive at times. My favorite parts of the project were when the program actually worked when compiled and driving the roombas at Dreese labs. I’ve actu- ally learned a lot about psuedocode, high level coding, and dif- ferent approaches to obstacle avoidance and using the GPS sensors. Overall I really enjoyed working on the project, and it’s definitely the highlight of my summer.” 7.1.3 Student 3 “During the past two weeks I had lots of fun learning about Roombas, C Programming, and Quake 3. I thought that the pace of the project was slow enough that I did not feel rushed, yet fast enough to allow us to be productive. I think that it might have been interesting to replace the multi-obstacle lab with a lab having to do with sensors. We talked a lot about the importance of sensors, so I was a bit disappointed to discover that we would not be using them in our project. The camp was extremely fun because of all of the participating students and staff. This was probably one of the best two weeks I have had in a while.” 7.1.4 Student 4 “When I was first assigned this project, my head was in- trigued by the possibilities of what we could program the Roomba to do. Shortly after we started programming, how- ever, we ran face to face to the difficulties of using C to tell the Roomba where and how to move. Project Obstacle Avoid- ance Roomba is an great assignment to enlighten those un- familiar with Autonomous Vehicles. The Roomba Project il- lustrates the challenges of avoiding the walls, moving around the obstacles, even turning the Roomba. Although I had no part in writing the functions of controlling the Roomba, there was plenty of work of just coding in an algorithm the robot can follow to drive itself. Obstacle Avoidance Roomba Project would be a great stepping-stone to help interested newcomers step into the field of Autonomous Driving.” 7.2 Lessons and Future Projects The SI Stafflearned many valuable lessons from students, and will use these to provide improved iterations of the project in subsequent years. 7.2.1 Scope Students particularly enjoy the coding components of the project. The scope of the project is sufficient for students to have an understanding of CPS fundamentals without ex- cessive training. Coding training given in C/C++ and is in- tended to help students with the Player/Stage programming. Basic mathematical training in coordinate transformations, homogeneous transformations in addition to basic physics is also provided to give students further understanding of the Roombas. Students expressed interest in using a larger set of sensors (as opposed to purely GPS coordinates). Inclu- sion of further sensors may be difficult within the 2 week length of the program. 7.2.2 Competition Students at times felt that the competitive process was counterproductive and that they would rather that compo- nent not be in the next iteration of the project. Students indicated a preference for group based work - something they felt would be more productive. This modification was made in SI 2011 and groups worked in a collaborative manner while maintaining the peer review process. Students were also allowed to switch groups based on approaches or ar- eas of interest. The collaborative group structure was more successful than the competing group structure. 7.2.3 Working with varying student capabilities One of the difficulties faced by the project teams was in- structing students with differing technical capabilities, es- pecially in knowledge of programming. In SI 2010 students were paired such that each group would have one student proficient in programming working alongside a student who was not as familiar with programming. With student feed- back that they felt this process required them to “carry” another student, in SI 2011, an additional instructor (who was also a SI 2010 student) was brought in to give person- alized attention to students who required technical help - so as to ensure proficient students were not slowed down. 7.2.4 Metrics to Judge Project One metric used to judge program success in SI 2010 and 2011 is student willingness to participate in future robotics related activities after the Summer Institute program. An- other metric, student learning of competencies, was tested through informal systems. In future iterations, the authors wish to devise a formal evaluation to judge student compe- tencies. 7.2.5 Project Evaluation In SI 2010 and 2011, evaluation was collected through a daily online journal that asked students the following ques- tions: 1. What did you learn today? 2. Who did you help out today and how? 3. Who helped you out today and how? 4. What did you like best about today’s activities? 5. What did you like least about today’s activities? Such information was collected over eight days culminat- ing in a final comprehensive survey about the overall experi- ence. Data was also collected about student-instructor inter- actions and improvements that could be made to the overall program and particular project. In the final survey, 100% of the students “Strongly Agree” that the instructors were helpful. Multiple students cited that the “High Point” of the experience was in the Roomba testbed. One student cited a “Low Point” when they had difficulty with the coding com- ponent of the project. Overall, 75% of the students felt that the programming portion of the project was enjoyable with 25% feeling that they needed greater prior programming ex- perience. Students were also asked to comment about the experience such as lab tours, residence halls, etc. As a mea- sure of being taught in a way that corresponds to learning style, 36% said “Strongly Agree”, 43% said “Agree” and 21% said “Neutral.” 100% of the students said that the project has deepend their desire to work in the field of robotics or engineering. 8. TOOLS AND RESOURCES The aim of this paper is to present a CPS related study that can be recreated. This section outlines the tools/material used and basic instructions on creating a similar project. • The first step is to download and install the Player/Stage project from http://playerstage.sourceforge.net. Down- load and installation instructions for a variety of hard- ware configurations is included in the instruction man- ual. • The programmable roombas used in the testbed com- ponent of the project can be purchased from http://store.irobot.com. The Player/Stage simulator can be configured to work with this Roomba. • To view and download the SI 2011 Source Code: http://dl.dropbox.com/u/1268613/codesamples.zip • To view and/or download the SI 2010 Student Presen- tation and Videos: http://dl.dropbox.com/u/1268613/RoombaProject.zip Other related links and resources: 1. Student Feedback Video: http://www.youtube.com/watch?v=Ke8ONfF-Q64 2. NSF CPS Program: http://www.nsf.gov/funding/pgm summ.jsp?pims id=503286 3. C/C++ Training Material: http://www.osc.edu/supercomputing/training/ 9. CONCLUSIONS We present a two week educational program for High School students as a part of the Summer Institute program at the Ohio Supercomputer Center. Students are introduced to CPS related fundamentals, and develop the algorithm and code for an obstacle avoidance Roomba. Students are taught the scientific process of moving from simulated to real world testing, and are taught the CPS core competencies of math- ematics, physics, programming languages, and other tools. Additionally, students are introduced to the concepts of peer review, and iterative development. Student feedback showed that students greatly enjoy the program, and students indi- cate interest in future participation in CPS related research activities. We also give the reader the tools and resources required to recreate the summer educational program. 10. ACKNOWLEDGMENTS This work was supported by a National Science Foun- dation Grant. The authors would also like to thank Paul Sivilotti, Keith Redmill, Scott Biddlestone, Arda Kurt, and Micheal Vernier for their support in developing the educa- tion activities. 11. REFERENCES [1] Ohio supercomputer center, si 2010 project listing: http://www.osc.edu/education/si/projects/index.shtml. [2] The ohio supercomputer center, training material: http://www.osc.edu/supercomputing/training/. [3] The player/stage project: http://playerstage.sourceforge.net/. [4] Upper arlington student discusses osc’s 2010 summer institute and computational science: http://www.youtube.com/watch?v=ke8onff-q64. [5] J. Kuenzi. Science, technology, engineering, and mathematics (STEM) education issues and legislative options. In Library of Congress, Washington DC Congressional Research Office, 2006. [6] B. Lowell, H. Salzman, H. Bernstein, and E. Henderson. Steady as she goes? Three generations of students through the science and engineering pipeline. In Annual Meetings of the Association for Public Policy Analysis and Management Washington, DC on November, volume 7, pages 9–10, 2009. [7] L. Perez-Felkner, S. McDonald, and B. Schneider. What Happens to High-Achieving Females after High School? Gender and Persistence on the Postsecondary STEM Pipeline. [8] P. Sivilotti and M. Demirbas. Introducing middle school girls to fault tolerant computing. In Proceedings of the 34th SIGCSE technical symposium on Computer science education, pages 327–331. ACM, 2003. [9] P. Sivilotti and M. Lang. Interfaces first (and foremost) with Java. In Proceedings of the 41st ACM technical symposium on Computer science education, pages 515–519. ACM, 2010. [10] P. Sivilotti and S. Pike. The suitability of kinesthetic learning activities for teaching distributed algorithms. ACM SIGCSE Bulletin, 39(1):362–366, 2007. [11] W. Tyson, R. Lee, K. Borman, and M. Hanson. Science, Technology, Engineering, and Mathematics (STEM) Pathways: High School Science and Math Coursework and Postsecondary Degree Attainment. Journal of Education for Students Placed at Risk (JESPAR), 12(3):28, 2007. [12] M. Vernier. Virtual sensor system: Merging the real world with a simulation environment, 2010.