


'The most important machine never built', Alan Turing and the Turing Machine
Calculation is a familiar concept that most of us understand intuitively. Let's take the function f (x) = x 3 as an example. When x is 3, f (3) = 3 3. The answer is 6, very simple. Obviously, this function is computable. But some functions are not that simple, and determining whether they can be calculated is not trivial, meaning they may never lead to a final answer.
In 1928, the German mathematicians David Hilbert and Wilhelm Ackermann proposed a method called Entscheidungsproblem (i.e. "deterministic problem"). question"). Over time, the question they asked would lead to a formal definition of computability, a definition that would enable mathematicians to answer a host of new questions and lay the foundation for theoretical computer science.
This definition was proposed by a 23-year-old graduate student named Alan Turing, who wrote a seminal paper in 1936 that not only formalized the concept of computing It also proved a basic problem in mathematics and created the knowledge basis for the invention of electronic computers. Turing's great vision was to provide concrete answers to computing problems in the form of an abstract machine, which was later named the Turing machine by his PhD supervisor Alonzo Church.
A Turing machine is abstract because it does not (and cannot) physically exist as a tangible device. Rather, it is a conceptual model of computation: if this machine can compute a function, then the function is computable.
##When Alan Turing invented the Turing Machine in 1936 At the time, modern computing was also created.
Alan Turing and his Turing MachineIts working principle is this: the Turing machine can follow the rules of the rule table Read and change symbols on infinitely long tapes. The tape is composed of "cells", and each cell can only store one symbol. Turing machines use tape heads to read and rewrite the contents of cells. Each rule in the rule table determines what the Turing machine should do based on its current state and the symbol it is reading. A Turing machine can enter a final state (an "accept state" or a "reject state") based on where it stopped, deciding to accept or reject the input. Or a Turing machine gets stuck in an infinite loop and never stops reading the tape.
The best way to understand a Turing machine is to think about a simple example like this. Let's imagine that a Turing machine is designed to tell us whether a given input is the number zero. We will enter the number 0001 with a whitespace symbol (#), meaning "#0001#" is the relevant part of our tape.
The Turing machine starts from an initial state, let's call it q0, where it reads the leftmost cell of the tape and finds a blank area. As a rule, when in state q0, if the sign is #, leave it as is, then move one cell to the right and change the machine state to q1. After this step, the machine is in state q1 and its head will be reading the second symbol 0.
Now we look for rules that apply to these conditions. We find a rule that says, "Keep state q1 and move the head one cell to the right." This leaves us in the same position (in state q1, the reading is still 0), so we continue to move right until the head finally A different number 1 is read.
When we consulted the rule table again, we found a new rule: "If 1 is encountered, transition to q2, which is the rejection state." The Turing machine stopped running and The initial question "Is 0001 zero?" is answered "No".
Conversely, if the input is "#0000#", the Turing machine will encounter # after all those zeros. When we consult the rule table, we find a rule that says this means the machine enters state q3, an "accepting" state. The machine now answers "yes" to the question "Is '0000' zero?"
Alan Turing helped define computation, algorithms, and Turing machines.
Use abstract machines to answer judgmental questions
Turing used his abstract machine to build a computational model to answer the Entscheidungs question, which Formally asked: Given a set of mathematical axioms, is there a mechanical process (i.e. a set of instructions, today we call it an algorithm) that can always determine whether a given statement is true?
Suppose we want to find an algorithm to tell us whether the position of the pieces in a certain chess game is feasible. Within this, the axioms are the rules that govern reasonable moves in chess. Can we get there by following a finite sequence of step-by-step processes? Although some chess positions may take longer than our lifetimes to analyze, an algorithm may generate all possible positions and compare them one by one to the input, such algorithms exist in the game of chess. Therefore, we say that chess is "decidable".
However, in 1936, the American mathematicians Church and Turing used different methods to prove that "there is no general method that can solve every instance of the Entscheidungs problem." For example, John Some games, such as Conway's Game of Life, are undecidable: no algorithm can determine whether a certain pattern will emerge from an initial pattern.
Turing showed that a function is computable if there is an algorithm that can perform the required task. At the same time, he also showed that the algorithm is a process that can be defined by a Turing machine. Therefore, a computable function is a function that can be computed by a Turing machine. This seems like a roundabout way of defining computability, but it's the best we have.
"It's not that you can choose to define it any other way," said Michael Sipser, a theoretical computer scientist at MIT. "I think there's a general consensus that Church - The Turing thesis proposes that the informal concept of an algorithm is anything that can be done by any reasonable model of computation." Other mathematicians have proposed different models of computation that, while superficially looking very different, are actually the same : they can do any computation that a Turing machine can do, and vice versa.
Just a few years after philosopher, logician, and mathematician Kurt Gödel proved that mathematics is incomplete, Church and Turing also passed this worksheet It shows that some problems in mathematics are undecidable. No matter how complex the algorithm is, it cannot tell us whether the answer is yes or no. Both events were devastating blows to Hilbert, who had hoped that mathematics would provide simple, idealized answers. But that's not bad: if there were a general solution to the Entscheidungsproblem, it would mean that all problems in mathematics could be reduced to simple mechanical calculations.
Universal and Probabilistic Turing Machines
In addition to answering these fundamental questions, Turing machines directly influenced modern computers through a variant called the Universal Turing Machine development of. It is a special Turing machine that can simulate any input from any other Turing machine. It could read the descriptions (and rules and input tapes) of other Turing machines and simulate their behavior on its own input tapes, producing the same output as the simulated machine, just as today's computers can read any program and execute it Same.
In 1945, the Hungarian-American mathematician, computer scientist, and physicist John von Neumann proposed a computer architecture—the von Neumann architecture. It makes it possible to turn the concept of a universal Turing machine into a real-life machine.
When Princeton University theoretical computer scientist Sanjeev Arora teaches this concept, he emphasizes the broader philosophical picture. He said, "There are two concepts of universal, one is that it can run any other Turing machine, but the other, bigger concept is that it can run any calculation you come up with in the universe." In classical physics In the world, any physical process can be modeled or simulated using algorithms, and algorithms can be simulated by Turing machines.
Another noteworthy and increasingly useful variant is the probabilistic Turing machine. Unlike conventional Turing machines, which have well-defined responses to each input, probabilistic Turing machines can make multiple responses based on probabilities. This means it can produce different results for the same input at different points in time. It is also surprising that for some problems this probabilistic strategy is more effective than a purely deterministic approach. The concept of probabilistic Turing machines has proven to be very useful in areas such as optimization and machine learning.
These abstract machines are perhaps the best evidence that asking fundamental questions can be one of the most useful things a scientist can do.
The above is the detailed content of 'The most important machine never built', Alan Turing and the Turing Machine. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The return value types of C language function include int, float, double, char, void and pointer types. int is used to return integers, float and double are used to return floats, and char returns characters. void means that the function does not return any value. The pointer type returns the memory address, be careful to avoid memory leakage.结构体或联合体可返回多个相关数据。

Flexible application of function pointers: use comparison functions to find the maximum value of an array. First, define the comparison function type CompareFunc, and then write the comparison function compareMax(a, b). The findMax function accepts array, array size, and comparison function parameters, and uses the comparison function to loop to compare array elements to find the maximum value. This method has strong code reusability, reflects the idea of higher-order programming, and is conducive to solving more complex problems.

Algorithms are the set of instructions to solve problems, and their execution speed and memory usage vary. In programming, many algorithms are based on data search and sorting. This article will introduce several data retrieval and sorting algorithms. Linear search assumes that there is an array [20,500,10,5,100,1,50] and needs to find the number 50. The linear search algorithm checks each element in the array one by one until the target value is found or the complete array is traversed. The algorithm flowchart is as follows: The pseudo-code for linear search is as follows: Check each element: If the target value is found: Return true Return false C language implementation: #include#includeintmain(void){i

The pointer parameters of C language function directly operate the memory area passed by the caller, including pointers to integers, strings, or structures. When using pointer parameters, you need to be careful to modify the memory pointed to by the pointer to avoid errors or memory problems. For double pointers to strings, modifying the pointer itself will lead to pointing to new strings, and memory management needs to be paid attention to. When handling pointer parameters to structures or arrays, you need to carefully check the pointer type and boundaries to avoid out-of-bounds access.

A function pointer is a pointer to a function, and a pointer function is a function that returns a pointer. Function pointers point to functions, used to select and execute different functions; pointer functions return pointers to variables, arrays or other functions; when using function pointers, pay attention to parameter matching and checking pointer null values; when using pointer functions, pay attention to memory management and free dynamically allocated memory; understand the differences and characteristics of the two to avoid confusion and errors.

The C language function returns a pointer to output a memory address. The pointing content depends on the operation inside the function, which may point to local variables (be careful, memory has been released after the function ends), dynamically allocated memory (must be allocated with malloc and free), or global variables.

The key elements of C function definition include: return type (defining the value returned by the function), function name (following the naming specification and determining the scope), parameter list (defining the parameter type, quantity and order accepted by the function) and function body (implementing the logic of the function). It is crucial to clarify the meaning and subtle relationship of these elements, and can help developers avoid "pits" and write more efficient and elegant code.

C language function calls can be divided into nested calls and recursive calls. Nested calls refer to calling other functions within a function, nesting them layer by layer. Recursive calls refer to the function itself calling itself, which can be used to deal with self-similar structure problems. The key difference is that the functions in nested calls are called in sequence, with independent interaction scopes, while the functions in recursive calls are constantly called, so you need to pay attention to the recursive basis and stack overflow issues. Which calling method to choose depends on the specific requirements and performance requirements of the problem.
