Toggle navigation
Home
8NOVELS
Search
Understanding Computation (59 page)
Read Understanding Computation Online
Authors:
Tom Stuart
Tags:
#COMPUTERS / Programming / General
BOOK:
Understanding Computation
11.36Mb size Format: txt, pdf, ePub
Read Book
Download Book
«
1
...
27
...
52
53
54
55
56
57
58
59
60
61
»
G
Game of Life,
Conway’s Game of Life
–
Conway’s Game of Life
GCC compiler,
Coping with Uncomputability
general-purpose machines
about,
General-Purpose Machines
–
General-Purpose Machines
encoding,
Encoding
simulation,
Simulation
universality of,
Universal Systems Can Loop Forever
generalized nondeterministic finite automaton (GNFA),
Just Add Power
Ghory, Imran,
The Problem
GNFA (generalized nondeterministic finite automaton),
Just Add Power
Gödel’s first incompleteness theorem,
Why Does This Happen?
Goldbach conjecture,
Too good to be true
Goldbach, Christian,
Too good to be true
greatest common divisor,
Universal Systems Can Perform Algorithms
guillemets,
Expressions
H
halting problem,
The Halting Problem
–
Fundamentally impossible
Hash class
about,
Enumerable
#merge method,
Statements
hashes,
Data Structures
Hofstadter, Douglas,
Programs Can Refer to Themselves
I
if expression,
Control Flow
,
Statements
inference rules
formal semantics in practice,
Formality
Simple example,
Small-Step Semantics
infinite loops,
Simulation
,
Numeric Operations
,
Universal Systems Can Loop Forever
–
Universal Systems Can Loop Forever
infinite streams,
Infinite streams
–
Infinite streams
inheritance,
Classes and Modules
input
deterministic finite automata,
States, Rules, and Input
nondeterministic finite automata,
Nondeterminism
inspecting objects,
Inspecting Objects
instances
classes and,
Classes and Modules
,
Expressions
methods and,
Classes and Modules
virtual machines,
Expressions
Integer#gcd method,
Universal Systems Can Perform Algorithms
Interactive Ruby Shell (IRB),
Interactive Ruby Shell
interpreters, operational semantics and,
Applications
,
Finding Meaning
IRB (Interactive Ruby Shell),
Interactive Ruby Shell
ISO/IEC 30170 standard,
The Meaning of “Meaning”
K
Kernel module
#eval method,
Expressions
#puts method,
Code Is Data
key-value pairs,
Data Structures
L
lambda calculus
about,
Programming with Nothing
avoiding arbitrary recursion,
Avoiding arbitrary recursion
–
Avoiding arbitrary recursion
constants and,
Impersonating the Lambda Calculus
FizzBuzz problem,
The Problem
FizzBuzz solution,
The Solution
–
The Solution
impersonating,
Impersonating the Lambda Calculus
implementing,
Implementing the Lambda Calculus
–
Parsing
implementing Booleans,
Booleans
–
Booleans
implementing lists,
Lists
–
Lists
implementing numbers,
Numbers
–
Numbers
implementing numeric operations,
Numeric Operations
–
Numeric Operations
implementing pairs,
Pairs
implementing predicates,
Predicates
implementing strings,
Strings
infinite streams,
Infinite streams
–
Infinite streams
parsing,
Parsing
–
Parsing
procs and,
Working with Procs
–
Syntax
semantics,
Semantics
–
Reducing expressions
SKI combinator calculus and,
SKI Combinator Calculus
–
Iota
syntax,
Syntax
–
Syntax
Turing machines and,
Lambda Calculus
–
Lambda Calculus
Lee, Bruce,
The Meaning of Programs
lexical analysis
about,
Parsing with Pushdown Automata
parsing with PDA,
Lexical Analysis
–
Lexical Analysis
Lisp programming languages,
Code Is Data
lists
in FizzBuzz example,
Lists
–
Lists
infinite streams,
Infinite streams
–
Infinite streams
local variables,
Local Variables and Assignment
lookahead technique,
Practicalities
looping constructs
big-step semantics,
Statements
,
Statements
denotational semantics,
Statements
,
Statements
infinite loops,
Simulation
,
Numeric Operations
,
Universal Systems Can Loop Forever
–
Universal Systems Can Loop Forever
small-step semantics,
Statements
,
Statements
Lovecraft, H. P.,
Impossible Programs
M
machines (see computing machines)
main object,
Objects and Methods
mathematical semantics (see denotational semantics)
Matz’s Ruby Interpreter (MRI),
The Meaning of “Meaning”
,
Statements
meaning
finding,
Finding Meaning
meaning of,
The Meaning of “Meaning”
&:message shorthand,
Enumerable
messages
arguments and,
Objects and Methods
components of,
Objects and Methods
methods and,
Objects and Methods
objects and,
Objects and Methods
Ruby shorthand,
Enumerable
metalanguage,
Small-Step Semantics
,
Expressions
methods
classes and,
Classes and Modules
,
Classes and Modules
,
Monkey Patching
defining,
Objects and Methods
inheritance and,
Classes and Modules
instances and,
Classes and Modules
messages and,
Objects and Methods
modules and,
Classes and Modules
,
Monkey Patching
objects and,
Objects and Methods
passing arguments to,
Expressions
private,
Removing Constants
return constraints,
Statements
variadic,
Variadic Methods
ML programming language,
Applications
modules
constants and,
Defining Constants
,
Defining Constants
methods and,
Classes and Modules
,
Monkey Patching
modulo operator,
Numeric Operations
monkey patching,
Monkey Patching
MRI (Matz’s Ruby Interpreter),
The Meaning of “Meaning”
,
Statements
mruby project,
The Meaning of “Meaning”
N
natural semantics (see big-step semantics)
nested strings,
Just Add Power
nesting levels in balanced brackets example,
Just Add Power
–
Just Add Power
NFA (nondeterministic finite automata)
about,
Nondeterministic Finite Automata
balanced bracket example,
Just Add Power
–
Just Add Power
converting to DFA,
Equivalence
–
Equivalence
converting to regular expressions,
Just Add Power
free moves feature,
Free Moves
–
Free Moves
input,
Nondeterminism
nondeterminism,
Nondeterminism
–
Nondeterminism
regular expressions and,
Semantics
–
Semantics
rules,
Nondeterminism
simulation,
Nondeterminism
states,
Nondeterminism
,
Semantics
storage,
Nondeterminism
nondeterminism,
Nondeterminism
–
Nondeterminism
nondeterministic finite automata (see NFA)
nondeterministic pushdown automaton (see NPDA)
nondeterministic Turing machines,
Nondeterministic Turing Machines
nonequivalence, NPDA and,
Nonequivalence
NPDA (nondeterministic pushdown automaton)
about,
Nondeterministic Pushdown Automata
–
Nondeterministic Pushdown Automata
nonequivalence,
Nonequivalence
palindrome recognition example,
Nondeterministic Pushdown Automata
–
Nondeterministic Pushdown Automata
simulation,
Simulation
–
Simulation
numbers
absolute values,
Abstraction: Multiplying Signs
in FizzBuzz example,
Numbers
–
Numbers
numeric operations in FizzBuzz example,
Numeric Operations
–
Numeric Operations
O
Object object
#inspect method,
Inspecting Objects
new method,
Objects and Methods
send method,
Removing Constants
#to_s method,
String Interpolation
objects
current object,
Objects and Methods
inspecting,
Inspecting Objects
messages and,
Objects and Methods
methods and,
Objects and Methods
string interpolation,
String Interpolation
values and,
Objects and Methods
OCaml programming language,
Applications
,
Applications
operational semantics
about,
Operational Semantics
big-step semantics,
Big-Step Semantics
–
Applications
,
Statements
interpreters and,
Applications
,
Finding Meaning
Simple programming language example,
Expressions
small-step semantics,
Small-Step Semantics
–
Applications
,
Statements
operator precedence,
Expressions
output, deterministic finite automata,
Output
–
Output
P
pairs in FizzBuzz example,
Pairs
palindrome recognition example,
Nondeterministic Pushdown Automata
–
Nondeterministic Pushdown Automata
parallel assignment,
Local Variables and Assignment
,
Variadic Methods
parsers and parsing process
about,
Syntax
,
Parsing with Pushdown Automata
implementing,
Implementing Parsers
–
Implementing Parsers
lambda calculus,
Parsing
–
Parsing
lexical analysis,
Lexical Analysis
–
Lexical Analysis
lookahead technique,
Practicalities
regular expressions,
Parsing
–
Parsing
syntactic analysis,
Syntactic Analysis
–
Syntactic Analysis
syntax and,
Syntax
parsing expression grammar (PEG),
Implementing Parsers
partial programming languages,
Universal Systems Can Loop Forever
partial recursive functions,
Partial Recursive Functions
–
Partial Recursive Functions
PDA (pushdown automaton)
about,
Storage
deterministic,
Deterministic Pushdown Automata
–
Simulation
nondeterministic,
Nondeterministic Pushdown Automata
–
Nonequivalence
parsing with,
Parsing with Pushdown Automata
–
Practicalities
PEG (parsing expression grammar),
Implementing Parsers
PLT Redex programming language,
Applications
power (computing)
about,
Just Add Power
–
Just Add Power
,
How Much Power?
deterministic pushdown automata,
Deterministic Pushdown Automata
–
Simulation
nondeterministic pushdown automata,
Nondeterministic Pushdown Automata
–
Nonequivalence
parsing with PDA,
Parsing with Pushdown Automata
–
Practicalities
Turing machines,
Maximum Power
–
Multidimensional Tape
predicates in FizzBuzz example,
Predicates
primitive recursive functions,
Partial Recursive Functions
printing
procs and,
The Problem
strings,
Printing Strings
private methods,
Removing Constants
procs,
Working with Procs
(see also FizzBuzz program)
about,
Procs
,
Working with Procs
arguments and,
Arguments
calling,
Procs
extensional equality,
Equality
implementing numbers,
Numbers
–
Numbers
lambda calculus and,
Working with Procs
printing and,
The Problem
reducing,
Applications
syntax for,
Syntax
programming languages
about,
The Meaning of Programs
abstract machines and,
Operational Semantics
denotational semantics,
Denotational Semantics
–
Applications
dynamic semantics,
Correctness
,
Static Semantics
essentials for specifying,
The Meaning of “Meaning”
formal semantics,
Formal Semantics in Practice
–
Alternatives
meaning of,
The Meaning of “Meaning”
metalanguage and,
Expressions
operational semantics,
Operational Semantics
–
Applications
parsing with PDA,
Parsing with Pushdown Automata
partial,
Universal Systems Can Loop Forever
semantics of,
The Meaning of “Meaning”
syntax of,
The Meaning of “Meaning”
,
Syntax
total,
Universal Systems Can Loop Forever
,
Depressing Implications
programs
about,
The Meaning of Programs
,
Syntax
abstract machines and,
Operational Semantics
denotational semantics,
Denotational Semantics
–
Applications
formal semantics,
Formal Semantics in Practice
–
Alternatives
meaning of,
The Meaning of “Meaning”
operational semantics,
Operational Semantics
–
Applications
parser,
Syntax
,
Implementing Parsers
–
Implementing Parsers
predicting behavior of,
Coping with Uncomputability
,
Programming in Toyland
self-referential,
Programs Can Refer to Themselves
–
Programs Can Refer to Themselves
,
Why Does This Happen?
standing in for Turing machines,
Programs Can Stand In for Turing Machines
sufficiently powerful,
Programming in Toyland
syntax and,
Syntax
unreachable code,
Coping with Uncomputability
pushdown automaton (see PDA)
#puts method,
Printing Strings
«
1
...
27
...
52
53
54
55
56
57
58
59
60
61
»
Other books
The Good Provider
by
Jessica Stirling
Shades of Gray
by
Maya Banks
The Boxcar Children Beginning: The Aldens of Fair Meadow Farm
by
Patricia MacLachlan
Quinn's Lady
by
Amanda Ashley
Brian Eno's Another Green World
by
Dayal, Geeta
Isis
by
Douglas Clegg
Activate
by
Crystal Perkins
Ghost in the Polka Dot Bikini: A Ghost of Granny Apples Mystery
by
Sue Ann Jaffarian
A Life for a Life
by
DeGaulle, Eliza
Unamused Muse (Mt. Olympus Employment Agency: Muse Book 2)
by
R.L. Naquin
Understanding Computation
You must be logged in to Read or Download
CONTINUE
SECURE VERIFIED
Close X