Hi everyone! I can't believe it's been so long since the last video (4 months!) There's one point I gloss over in the video, hopefully it's not too confusing. I describe circuits as operating on a purely binary language, but around 7:00 while giving an overview of the conversion, I'm showing lots of other characters (like blanks, 1 with a Turing machine head, etc.) as an artifact of how a Turing machine works. In general, we can convert from a multi-character language into strictly binary one, and there are tricks we can do like representing the Turing machine head on the tape itself. You can imagine an intermediate conversion from a more human readable Turing machine to a strictly binary one, before going to the circuit.
Teja, from what I understand, the idea of "reduction" is a bit of a loaded term but in this context I think the aim is to "simplify" a problem into fundamental computational units of some variety (such as logic gates, variables as arguments etc) such that two seemingly different problems can be equated. if you can reduce them to the same elements, then they can be solved in the same way. alternatively, if you're able to successfully solve one, then the rest should be easier to solve. Undefined, I feel like I may be missing something here!
Interestingly, there are actually programs for solving SAT problems called SAT solvers. They still take exponential time, but they are able to locate and exploit many kinds of structure in the problem (real world SAT problems often have a lot of structure to them), allowing them to be solved very quickly. You can easily turn the SAT problem into a graph showing what kinds of constraints exist between different variables, and often times you'll find that these complex SAT problems are actually composed of a large number of much smaller, mostly independent SAT problems. A modern SAT solver can actually solve some problems with over a million variables in under an hour, though they can still struggle with problems with fewer than a hundred if there's not enough structure to exploit. There are also SMT solvers, or Satisfiability Modulo Theory solvers, which are basically SAT solvers with higher-level constructs bolted on. That way an arithmetic operation in your NP problem doesn't have to be transformed into hundreds of variables and constraints in the solver, and can often be solved faster with some simple math operations.
damn thanks man, i'm taking a theory of omputation course and struggling to understand the lectures because they speak in such high level terminology. i understand it perfectly from your video so its much appreciated.
I dont get your Turing machine model. The head has no state. And how can it be that the next manipulation only depends on the neighboring cells on the band? Can you elaborate?
While I appreciate the effort and the information, I think some of the animations are becoming excessive and kind of distracting. Lining up a roll of Sells from Dragon Ball because "Hahaha, cells!" didn't inform me of anything and it is not creative enough to be funny... I am probably sounding harsher than I meant, but I want your channel to grow, because you tackle on explaining some very hard stuff without hand-waving most of the details, which I totally appreaciate!
I very much agree with this. Stop it with the goofy animations, they're not funny and if anything are distracting. The main takeaway from these videos is how you guys explain things step-by-step, not the references to geekdom.
Personally I disagree, it helped me stay focused on the explanations because the concepts are difficult and trying to get through them when you are below a 80% understanding of what is going in is a struggle and a slug fest. So the stupid items popping up forced my brain to pay attention
The heart circuit actually represents every possible state the turing machine can go into. That makes it possible to check if the problem is solvable which is the case when the resulting circuit (or in case of SAT: the resulting formula) is satisfiable.
so if I can find a problem, prove it's easy to verify (meaning I can find a polynomial-time algorithm to verify whether a solution is valid or not) AND prove it's not easy to solve (meaning I can prove there does not exist a polynomial-time algorithm to solve this problem). What does this mean? I think this means this problem belongs to a specific complexity class, what is the name of this class?
Dear, there might be a bug in your explanation. The construction of the heart circuit is not only dependent on the symbols as shown in the video. It should be a combination of both symbols and states. Thanks
Hmm. Sure, it would be cool having a machine do the heavy lifting, but there would probably be some problem, like efficiency. Nevertheless, this is an interesting possibility, to make the laws of physics solve everything. Like a Quantum computer. Actually, a quantum computer would be a protein computer, as protein folding is just all of the atoms and their electrons interacting with each other, i.e. protein folding is a more specialized version of quantum problems. So, in a way, protein computers ARE being built.
why do we have used only one not and and gate??? is there a significance of 3 inputs? if we want 1 as an output when all input variables are assigned as 1 than why have we not used AND gate simply? please reply!!!
@@anand.suralkar yes, you explain the "how" part, but not the "where" part, you said "it has way to write..." thats what i'm asking, and yes program turing machine analogy with practical way like a code. we know how code in modern machine by translate to binary, but how in turing machine?
That problem with the gates seems easy though. Just reverse it. First tealising that the NOT gate flips it to the necessary 1 for the AND to function so you can reject all the 1s in the top like of the input data, then realising that a 1 in either of the OR gate inputs will output a 1 thus meaning you only need to check one. That makes it visually easy but to make it somewhat easier to code you could convert the imput number into a binary number and then filter them by 2 if statements. IF n>=100 reject. IF n=000 reject. IF ELSE n wil produce a 1. Or you could convert the 3D series of inputs into a 2D line and instruct a reader to read with the rules; algorithm 1: IF 1 output 0 and move 3 right and initate algorithm 1, IF 0 move 1 right and initiate algorithm 2 algorithm 2: IF 1 output 1 and move 2 right and initiate algorithm 1, IF 0 and move 1 right and initiate algorithm 3 algorithm 3: IF 1 output 1 and move 1 right and initiate algorithm 1, IF 0 output a 0 and move 1 right and initiate algorithm 1 This would generate a new string which you could use to check whether it outputs a 1 or 0. I guess thats still exponential tho because every new term takes you a maximum of 3 extra steps. Not saying I solved P = NP or anything just brain go brrrr and make a solution.
P = NP if you have a time machine. In fact all problem are instantaneously solved. There is no concept of complexity at that point. Complexity is a problem of time which is also a problem of state. You can simply jump to a state where the answer is solved. Since there are infinitely many states with infinitely different morphisms, all problems are solved.
I think the point was that this is a Turing machine specifically to solve an NP problem. NP problems won't have an infinite size, and as a result will place bounds on the size of the tape. Sure, the tape still can be infinite, but the point was that the rest of the tape doesn't matter because the problem is bounded.
Onesided and twosided Turing machines are easily convertible. Even the number of tapes does not matter if you do not differentiate between polynomial running times.
Hi everyone! I can't believe it's been so long since the last video (4 months!)
There's one point I gloss over in the video, hopefully it's not too confusing. I describe circuits as operating on a purely binary language, but around 7:00 while giving an overview of the conversion, I'm showing lots of other characters (like blanks, 1 with a Turing machine head, etc.) as an artifact of how a Turing machine works. In general, we can convert from a multi-character language into strictly binary one, and there are tricks we can do like representing the Turing machine head on the tape itself. You can imagine an intermediate conversion from a more human readable Turing machine to a strictly binary one, before going to the circuit.
What about the 'states' of Turing machines?
I understand that you explained everything very clearly, but I still don't get it.
lol. love that comment. so much agree
Teja, from what I understand, the idea of "reduction" is a bit of a loaded term but in this context I think the aim is to "simplify" a problem into fundamental computational units of some variety (such as logic gates, variables as arguments etc) such that two seemingly different problems can be equated. if you can reduce them to the same elements, then they can be solved in the same way. alternatively, if you're able to successfully solve one, then the rest should be easier to solve. Undefined, I feel like I may be missing something here!
Something something heart something?
this was a bs video , plagiarism like most of yt explanotry vids
@@adityaprasad465 XDDDD
What I learnt... Understanding np problems is an np problem.
Ahhh this feels like Math in school: First 5 mins: Too ez.
Afterwards: I will join Patrick Star unter his rock
Interestingly, there are actually programs for solving SAT problems called SAT solvers. They still take exponential time, but they are able to locate and exploit many kinds of structure in the problem (real world SAT problems often have a lot of structure to them), allowing them to be solved very quickly. You can easily turn the SAT problem into a graph showing what kinds of constraints exist between different variables, and often times you'll find that these complex SAT problems are actually composed of a large number of much smaller, mostly independent SAT problems.
A modern SAT solver can actually solve some problems with over a million variables in under an hour, though they can still struggle with problems with fewer than a hundred if there's not enough structure to exploit.
There are also SMT solvers, or Satisfiability Modulo Theory solvers, which are basically SAT solvers with higher-level constructs bolted on. That way an arithmetic operation in your NP problem doesn't have to be transformed into hundreds of variables and constraints in the solver, and can often be solved faster with some simple math operations.
Charles Rosenbauer Yeet boiii
Nice comment. Didn’t know that!
That's why they why theoretically it's pessimistic as in real world it could work at times. But no guarantee
Thank you for taking the time to make this. Keep up the good work! Subscribed !!
You explain the concept of NP-complete problems better than my professor.
I love this so much, please start making videos again!
The machine is an infinitely long tape, broken up into "Cells", which can only defeated by Son Gohan. Nice joke at 5:04 :D
damn thanks man, i'm taking a theory of omputation course and struggling to understand the lectures because they speak in such high level terminology. i understand it perfectly from your video so its much appreciated.
Hmm let me look up what a NP-Complete is... oh a problem that is in NP! Very helpful, thanks a lot.
I dont get your Turing machine model. The head has no state. And how can it be that the next manipulation only depends on the neighboring cells on the band? Can you elaborate?
I didn't get it either, I thought Turing machines can move as far as their inner state dictates them considering the last read input.
hello
thank you for this video, you have made me understand the gibberish of my profesor
now i actually understand what s going on
While I appreciate the effort and the information, I think some of the animations are becoming excessive and kind of distracting. Lining up a roll of Sells from Dragon Ball because "Hahaha, cells!" didn't inform me of anything and it is not creative enough to be funny...
I am probably sounding harsher than I meant, but I want your channel to grow, because you tackle on explaining some very hard stuff without hand-waving most of the details, which I totally appreaciate!
I very much agree with this. Stop it with the goofy animations, they're not funny and if anything are distracting. The main takeaway from these videos is how you guys explain things step-by-step, not the references to geekdom.
Personally I disagree, it helped me stay focused on the explanations because the concepts are difficult and trying to get through them when you are below a 80% understanding of what is going in is a struggle and a slug fest. So the stupid items popping up forced my brain to pay attention
But doesn't the state of the turing machine also affects the output of the heart circuit?
The heart circuit actually represents every possible state the turing machine can go into. That makes it possible to check if the problem is solvable which is the case when the resulting circuit (or in case of SAT: the resulting formula) is satisfiable.
finally another upload!!!
Uh I am probably going to have to watch this one again....and again. But I like the way it is explained.
People unfamiliar with dbz are probably very confused by 5:06
The only gate you need is Nand
This channel is the 3blue1brown of computer science
these video are so good why aren't there more views.
Are the heart circuits supposed to represent 3-SAT?
so if I can find a problem, prove it's easy to verify (meaning I can find a polynomial-time algorithm to verify whether a solution is valid or not) AND prove it's not easy to solve (meaning I can prove there does not exist a polynomial-time algorithm to solve this problem). What does this mean? I think this means this problem belongs to a specific complexity class, what is the name of this class?
np for the question
You are a god. i should have came here first
Dear, there might be a bug in your explanation.
The construction of the heart circuit is not only dependent on the symbols as shown in the video. It should be a combination of both symbols and states.
Thanks
wut?
Great channel very informative
Wait, protein structure prediction is not NP-complete. If it was, we would be developing protein computer now.
Hmm. Sure, it would be cool having a machine do the heavy lifting, but there would probably be some problem, like efficiency. Nevertheless, this is an interesting possibility, to make the laws of physics solve everything. Like a Quantum computer.
Actually, a quantum computer would be a protein computer, as protein folding is just all of the atoms and their electrons interacting with each other, i.e. protein folding is a more specialized version of quantum problems. So, in a way, protein computers ARE being built.
Can you prove that protein structure prediction is not NP-Complete?
Amazing video. Thank you.
why do we have used only one not and and gate??? is there a significance of 3 inputs? if we want 1 as an output when all input variables are assigned as 1 than why have we not used AND gate simply?
please reply!!!
Pumped to watch!
Just brilliant! Thank you so much
question. How do we program the turing machine, the machine follows set of rules that we defined. where and how to program that? many thanks.
u need to learn theory of computing for that i guess.
its just like the PDA or DFA.
just it has way to write on tape and move in both directions.
u can make turing machine by drawing the state diagram idk if u mean program turing machine in practical way like a code?
@@anand.suralkar yes, you explain the "how" part, but not the "where" part, you said "it has way to write..." thats what i'm asking, and yes program turing machine analogy with practical way like a code. we know how code in modern machine by translate to binary, but how in turing machine?
The “head” at 5:24 is from halo isn’t it
totally guilty spark, right?
He got me with the cells at 5:02
Great stuff!
That problem with the gates seems easy though.
Just reverse it. First tealising that the NOT gate flips it to the necessary 1 for the AND to function so you can reject all the 1s in the top like of the input data, then realising that a 1 in either of the OR gate inputs will output a 1 thus meaning you only need to check one.
That makes it visually easy but to make it somewhat easier to code you could convert the imput number into a binary number and then filter them by 2 if statements.
IF n>=100 reject.
IF n=000 reject.
IF ELSE n wil produce a 1.
Or you could convert the 3D series of inputs into a 2D line and instruct a reader to read with the rules;
algorithm 1:
IF 1 output 0 and move 3 right and initate algorithm 1, IF 0 move 1 right and initiate algorithm 2
algorithm 2:
IF 1 output 1 and move 2 right and initiate algorithm 1, IF 0 and move 1 right and initiate algorithm 3
algorithm 3:
IF 1 output 1 and move 1 right and initiate algorithm 1, IF 0 output a 0 and move 1 right and initiate algorithm 1
This would generate a new string which you could use to check whether it outputs a 1 or 0.
I guess thats still exponential tho because every new term takes you a maximum of 3 extra steps. Not saying I solved P = NP or anything just brain go brrrr and make a solution.
If something that's known to be hard seems easy, it just means something's missing :P
@@imaansayed8147 I made this comment 10 months ago and have no recollection of what this was even about to be quite honest.
Didn't expect the Gurren Lagann drill lol
0:30 NP complete
How can i do animation like this?
Very nice!
I love your v ideos and the animations used
how your videos circumvent copyright law is at least an NP-hard problem
lolz wasnt expecting a bonfire. Praise the sun.
NP-Heart problems, I get it.
Wow this is awesome
P = NP if you have a time machine. In fact all problem are instantaneously solved.
There is no concept of complexity at that point. Complexity is a problem of time which is also a problem of state.
You can simply jump to a state where the answer is solved.
Since there are infinitely many states with infinitely different morphisms, all problems are solved.
Analytic reduction to show that the problems are the same.
Amazing 👍
we need gohan to eleminate cell.
Metaheuristics next video please :D
….. what?
Hey, your depiction of the input tape in the Turing machine is wrong, it's supposed to be infinite on both sides according to the standard definition.
I think the point was that this is a Turing machine specifically to solve an NP problem. NP problems won't have an infinite size, and as a result will place bounds on the size of the tape. Sure, the tape still can be infinite, but the point was that the rest of the tape doesn't matter because the problem is bounded.
Onesided and twosided Turing machines are easily convertible. Even the number of tapes does not matter if you do not differentiate between polynomial running times.
Top class!
I understood nothing. Funny pictures are emphasizing surrealism of the topic
Too much unnecessary visual effects for a confusing concept
What ?
ceil hahahah. what about 17(Android 17).
wut
t h a n k y o u
I see pokemon, I click
m3m3z
чё он несёт?
Yo mo5eef
The pop culture references seem forced and almost condescending.
Nice!!
use it as a dislike button
cool
Bs
Really bad explanation. I don't think so you understand NP, NP-Hard, NP-Complete terms properly
The fuck?