Teaching Formal Languages through Visualizations, Machine Simulations, Auto-Graded Exercises, and Programmed Instruction
dc.contributor.author | Mohammed, Mostafa Kamel Osman | en |
dc.contributor.committeechair | Shaffer, Clifford A. | en |
dc.contributor.committeemember | Rodger, Susan H. | en |
dc.contributor.committeemember | Heath, Lenwood S. | en |
dc.contributor.committeemember | Ernst, Jeremy V. | en |
dc.contributor.committeemember | Kafura, Dennis G. | en |
dc.contributor.department | Computer Science | en |
dc.date.accessioned | 2023-01-06T07:00:07Z | en |
dc.date.available | 2023-01-06T07:00:07Z | en |
dc.date.issued | 2021-07-14 | en |
dc.description.abstract | The material taught in a Formal Languages course is mathematical in nature and requires students to practice proofs and algorithms to understand the content. Traditional Formal Languages textbooks are heavy on prose, and homework typically consists of solving many paper exercises. Some instructors make use of finite state machine simulators like the JFLAP package. JFLAP helps students by allowing them to build models and apply various algorithms on these models, which improves student interaction with the studied material. However, students still need to read a significant amount of text and practice problems by hand to achieve understanding. Inspired by the principles of the Programmed Instruction (PI) teaching method, we seek to develop a new Formal Languages eTextbook capable of conveying these concepts more intuitively. The PI approach has students read a little, ideally a sentence or a paragraph, and then answer a question or complete an exercise related to that information. Based on the question response, students can continue to other information frames or retry to solve the exercise. Our goal is to present all algorithms using algorithm visualizations and produce proficiency exercises to let students demonstrate understanding. To evaluate the pedagogical effectiveness of our new eTextbook, we conduct time and performance evaluations across two offerings of the course CS4114 Formal Languages and Automata. In time evaluation, the time spent by students looking at instructional content with text and visualizations versus with PI frames is compared to determine levels of student engagement. In performance evaluation, students grades are compared to assess learning gains with text and paper exercises only, with text, visualizations with exercises, and with PI frames. | en |
dc.description.abstractgeneral | Theory textbooks in computer science are hard to read and understand. Traditionally, instructors use books that are heavy on mathematical prose and paper exercises. Sometimes, instructors use simulators to allow students to create, simulate, and test models. Previously, we found that students tend to skip reading the text presented in the books. This leads to less understanding of the topics taught in the course. To increase student engagement, we developed a new eTextbook for the Formal Languages course. We used pedagogy based on Programmed Instruction, presenting the content in the form of short bits of prose followed by the related question. If students can solve the question correctly, this means that they understood the content and are ready to move forward. To help both instructors and students, we developed a new Formal Languages simulator named OpenFLAP. OpenFLAP allows instructors to create many exercises, and OpenFLAP can grade these exercises automatically. | en |
dc.description.degree | Doctor of Philosophy | en |
dc.format.medium | ETD | en |
dc.identifier.other | vt_gsexam:31929 | en |
dc.identifier.uri | http://hdl.handle.net/10919/113061 | en |
dc.publisher | Virginia Tech | en |
dc.rights | In Copyright | en |
dc.rights.uri | http://rightsstatements.org/vocab/InC/1.0/ | en |
dc.subject | Formal Languages | en |
dc.subject | Programmed Instruction | en |
dc.subject | visualizations | en |
dc.subject | pedagogical evaluation | en |
dc.subject | automated assessment | en |
dc.subject | Turing Machines | en |
dc.subject | JFLAP | en |
dc.subject | OpenFLAP | en |
dc.subject | Engagement Taxonomy | en |
dc.subject | Auto-graded exercises | en |
dc.subject | Proficiency exercises | en |
dc.title | Teaching Formal Languages through Visualizations, Machine Simulations, Auto-Graded Exercises, and Programmed Instruction | en |
dc.type | Dissertation | en |
thesis.degree.discipline | Computer Science and Applications | en |
thesis.degree.grantor | Virginia Polytechnic Institute and State University | en |
thesis.degree.level | doctoral | en |
thesis.degree.name | Doctor of Philosophy | en |