Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
compai [2024/10/13 00:50] – pedroortega | compai [2024/10/14 14:15] (current) – [Conclusions] pedroortega | ||
---|---|---|---|
Line 15: | Line 15: | ||
Like many, I believe that this **ability to recognize patterns is the hallmark of intelligence**. In fact, most of the other abilities commonly associated with intelligence such as learning, planning, analogical reasoning, and so on, can be seen as either directly connected to or dependent upon our capacity for pattern recognition. | Like many, I believe that this **ability to recognize patterns is the hallmark of intelligence**. In fact, most of the other abilities commonly associated with intelligence such as learning, planning, analogical reasoning, and so on, can be seen as either directly connected to or dependent upon our capacity for pattern recognition. | ||
+ | <WRAP info> | ||
+ | I would have preferred to use the term //AI// instead of //pattern recognition//, | ||
+ | </ | ||
===== Pattern recognition and computation ===== | ===== Pattern recognition and computation ===== | ||
Line 27: | Line 30: | ||
$$ | $$ | ||
- | In this sense, a pattern is a program, and **pattern recognition is program | + | In this sense, a pattern is a program, and **pattern recognition is program |
===== Computation is deduction, pattern recognition is induction ===== | ===== Computation is deduction, pattern recognition is induction ===== | ||
Line 41: | Line 45: | ||
</ | </ | ||
- | If we identify rules and premises with the information contained in a program, computation appears to correspond to a type of deduction restricted to processes that can be carried out through mechanical means. Induction, on the other hand, can be regarded as a process that finds rules and premises from conclusions. This suggests the following parallels: | + | If we identify rules and premises with the information contained in a program, computation appears to correspond to a type of deduction restricted to processes that can be carried out through mechanical means. Induction, on the other hand, can be regarded as a process that finds rules and premises from conclusions. This suggests the following parallels |
<WRAP center 40%> | <WRAP center 40%> | ||
Line 61: | Line 65: | ||
But **universal pattern recognition**—the inverse of universal computation—tells a different story. Unlike computation, | But **universal pattern recognition**—the inverse of universal computation—tells a different story. Unlike computation, | ||
- | + | A naive attempt to encapsulate universal pattern recognition could involve a cheat list: an infinite binary sequence where the bit in position $n$ indicates whether the $n$th-program would terminate. But this sequence contains incompressible information, | |
- | A naive attempt to encapsulate universal pattern recognition could involve a cheat list: an infinite binary sequence where the bit in position $n$ indicates whether the $n$th-program would terminate. But this sequence contains incompressible information, | + | |
Thus, while universal computation is simple, the infinite complexity of universal pattern recognition defies any finite rule set. | Thus, while universal computation is simple, the infinite complexity of universal pattern recognition defies any finite rule set. | ||
Line 79: | Line 82: | ||
===== Induction and the computational complexity classes ===== | ===== Induction and the computational complexity classes ===== | ||
- | The relationship between deterministic and nondeterministic complexity classes mirrors the divide between deduction and induction. | + | The above results apply to the limit case when we have unlimited resources to run and invert programs. But similar results hold when we take into account computational complexity. In fact, the relationship between deterministic and nondeterministic complexity classes mirrors the divide between deduction and induction. |
- | The **P vs NP** problem can be thought of as a question about pattern recognition. In P, you're given an input and tasked with computing the output efficiently, like running a program. In NP, it’s the reverse: you're given a desired output and need to find the input—or " | + | The **P vs NP** problem can be thought of as a question about pattern recognition. In P, you're given an input and tasked with computing the output efficiently—in polynomial time. In NP, it’s the reverse: you're given a desired output and need to find the input—or " |
For example, with NP problems like the Boolean satisfiability problem (SAT), verifying if a given solution works is easy (in P), but **finding** that solution is hard, much like trying to reverse-engineer a program to figure out what input created a specific result. | For example, with NP problems like the Boolean satisfiability problem (SAT), verifying if a given solution works is easy (in P), but **finding** that solution is hard, much like trying to reverse-engineer a program to figure out what input created a specific result. | ||
Line 93: | Line 96: | ||
I've highlighted that pattern recognition is fundamental to intelligence, | I've highlighted that pattern recognition is fundamental to intelligence, | ||
- | **Universal pattern recognition is non-computable, but feasible in restricted domains**: | + | **Universal pattern recognition is incomputable, but feasible in restricted domains**: |
Though universal pattern recognition is incomputable, | Though universal pattern recognition is incomputable, | ||
- | **The challenge of inverting computation**: | + | **The challenge of inverting computation |
- | The **P vs NP** problem | + | The **P vs NP** problem |
**AI as a core branch of computer science**: | **AI as a core branch of computer science**: | ||
AI isn't just an engineering branch about practical problem-solving—it' | AI isn't just an engineering branch about practical problem-solving—it' |