Theory of Computation | Computer Science Fundamentals

Portland State University

Explore the theoretical foundations of computer science with this comprehensive course on regular languages, finite state machines, context-free grammars, and Turing machines.

University CoursesCompiler

Introduction

This course covers the fundamental concepts and theories of computation, including regular languages, finite state machines, context-free grammars, and Turing machines. The course provides a solid foundation in the theoretical aspects of computer science, which is essential for understanding the capabilities and limitations of computing systems.

screenshot

Highlights

  • Comprehensive coverage of regular languages and finite state machines
  • In-depth exploration of context-free grammars and pushdown automata
  • Detailed examination of Turing machines and the Church-Turing thesis
  • Discussions on decidability, Turing-recognizability, and the halting problem

Recommendation

This course is highly recommended for students interested in the theoretical foundations of computer science, as well as those pursuing careers in algorithm design, programming language theory, and other areas that require a deep understanding of the theoretical aspects of computation. The course is also valuable for students who want to develop strong problem-solving and analytical skills.

How GetVM Works

Learn by Doing from Your Browser Sidebar

Access from Browser Sidebar

Access from Browser Sidebar

Simply install the browser extension and click to launch GetVM directly from your sidebar.

Select Your Playground

Select Your Playground

Choose your OS, IDE, or app from our playground library and launch it instantly.

Learn and Practice Side-by-Side

Learn and Practice Side-by-Side

Practice within the VM while following tutorials or videos side-by-side. Save your work with Pro for easy continuity.

Explore Similar Hands-on Tutorials

Compiler Design in C (1990)

1
Technical TutorialsCCompiler
Comprehensive guide to understanding and implementing compilers using the C programming language. Covers fundamental concepts, syntax analysis, code generation, and optimization.

Compiler Design: Theory, Tools, and Examples, C/C++ Edition

2
Technical TutorialsCC++Compiler
Comprehensive course on compiler design, covering theory, tools, and practical C/C++ examples. Explore lexical analysis, syntax analysis, and code generation.

Compiler Design: Theory, Tools, and Examples, Java Edition

11
Technical TutorialsCompilerJava
Comprehensive guide to compiler design theory and tools, with practical Java examples. Covers lexical analysis, parsing, code generation, and optimization.

Crafting Interpreters | Programming Language Design & Implementation

10
Technical TutorialsCompiler
Comprehensive guide to designing and implementing programming language interpreters, covering scanning, parsing, evaluating expressions, and more.

EXPL NITC: Build your own Compiler

6
Technical TutorialsCompiler
Dive into the practical development of a compiler with the EXPL NITC: Build Your Own Compiler book. Gain hands-on experience in programming languages and compiler construction.

Introduction to Compilers and Language Design

5
Technical TutorialsCompiler
Comprehensive course on compiler design principles and techniques, including scanning, parsing, semantic analysis, code generation, and optimization. Hands-on experience in building a complete compiler.

Let's Build a Compiler | Compiler Design | Programming Language Implementation

22
Technical TutorialsCompiler
Comprehensive guide to understanding and building compilers, covering parsing, code generation, and language implementation. Practical insights for beginners and experienced programmers.

Basic Computer Architecture

5
Technical TutorialsCompilerComputer EngineeringComputer Science
Explore the fundamental concepts of computer architecture with this comprehensive book, now available under a Creative Commons license.

A journey explaining how to build a compiler from scratch

25
Technical TutorialsCompilerProgramming
Embark on a hands-on journey to build a compiler from scratch, covering lexical scanning, parsing, operator precedence, and assembly generation. Suitable for beginners and experienced developers.