Algorithms for the Undecided WS2011/2012 | ||
News | Content | Grading | Time schedule | Material |
Note: This is an archvied version of our old webpage. Some links might be broken. The current one can be found here.
Content
In 1928 David Hilbert and Wilhelm Ackermann posed the fundamental question commonly known as the "Entscheidungsproblem" ("decision problem"): "Is there a finite procedure (=algorithm) that decides the validity of any given formula in first-order logic?" Hilbert called it the "main problem of mathematical logic" at that time. The question was answered negatively by Church and Turing (independently) only several years later. Thus the quest for the holy grail of logic --- an automated procedure to decide the validity of any given first-order formula --- was doomed to fail!But not all hope is lost --- there are many theories and fragments of first-order logic which
- are powerful enough to talk about interesting statements
- and at the same time admit an algorithm that decides the validity of these statements!
Examples of interesting Theories include:
- Propositional Logic + extensions (SAT-solving, QBF)
- Real closed Fields (seminal result by Tarski)
- Linear Arithmetic (any boolean combination of linear inequalities, -> more than just linear programming)
- Arrays (compiler optimization, verification)
- Strings (software-verification)
- Combinations of theories (nice theoretical results with direct practical applications)