NP-COMPLETENESS - The Secret Link Between Thousands of Unsolved Math Problems

Поділитися
Вставка
  • Опубліковано 8 січ 2025

КОМЕНТАРІ • 1,2 тис.

  • @upandatom
    @upandatom  Рік тому +148

    Hi everyone! If you enjoy what we do here at Up and Atom, the best ways to support the creation of more educational videos are to sign up to Nebula with this link go.nebula.tv/upandatom, or to support me on Patreon www.patreon.com/upandatom. Thank you for watching :)

    • @AurelienCarnoy
      @AurelienCarnoy Рік тому +4

      One of the best video on the net.
      (In my humble opinion)

    • @pingnick
      @pingnick Рік тому +2

      Sign up and watch indeed! I’m so glad I did!! Thanks again Jade!!! 👁🎬🎬🎬🎬🎬🌈☮️💟😍🥰😘🚀🌌🗽♾💯🤯🤩🤩🤩…

    • @pingnick
      @pingnick Рік тому +1

      @@AurelienCarnoy 💯♾

    • @josephheslin822
      @josephheslin822 Рік тому +2

      I wonder if the answer to this question has to do with finding the shape of a positive configuration, based on the number of nodes required. If you then just could search for the shape rather than testing the connections between nodes, it feels like a logical best place to start as a guess. Though I'm sure I'm oversimplifying this.

    • @lorenzoblum868
      @lorenzoblum868 Рік тому +2

      Hello Jade. Clique comes from a french word which has both pejorative and military connotations... We're doomed.

  • @personwritingthings
    @personwritingthings Рік тому +554

    Jesus I've just gotta say this. I've tried and failed to understand the P = NP problem for literally years, almost a decade. I'm a biologist, so I never really had the time or mental tools to understand the various sources that tried to explain it in an accessible way. Jade, this is the FIRST time I feel like I actually understand the problem. You have an amazing talent, and I'll forever be grateful to Tom Scott for introducing me to your channel. Thank you!

    • @upandatom
      @upandatom  Рік тому +69

      Aww thank you so much for the kind words :)

    • @paulgoogol2652
      @paulgoogol2652 Рік тому +4

      If the np approach is really just guessing the entry values it may be easily compared to "solving" lottery. If millions of people apply truely random methods of choosing their numbers, it will be far easier to have someone get the right number. But if all used some brute force method, the input would have far less variation. So parallelization fails.

    • @Pseudify
      @Pseudify Рік тому +2

      I’m still fuzzy on something. There is the guessing aspect but there is also the parallel processing of those guesses. I’m not clear on which of these 2 aspects is the important one. Paul Googol seems to be suggesting that the trick is in guessing ALL possible combinations. I don’t understand why that aspect is the challenging part as I would think that you would simply take all possible inputs and randomly combine them as many times as necessary to get all possible combinations.

    • @paulgoogol2652
      @paulgoogol2652 Рік тому +1

      ​​@@Pseudify what you suggest is brute force. It is hard to parallelize so many computers or users may give their adapted input. You just cause lots of communication traffic. If just random input is chosen, you may just have infinite users giving their guess and just 1 has to be correct.
      "Guessing all right combinations" is not the goal as far as I understood. Just one. I guess the bottleneck there is the merhod for creating random input. People doing lottery often use similar patterns and rng has the same problem.

    • @AdrianBoyko
      @AdrianBoyko Рік тому +1

      I second Filippo’s comment! On a tangent, the nondeterministic model is very similar to how Prolog programs are executed. But I guess a Prolog program is pretty much just a bunch of predicate logic statements that need to be satisfied, so it’s analogous to the Boolean “sat” examples discussed in this video.
      Now you need to do a follow-up video on Prolog! 😂

  • @YoungGandalf2325
    @YoungGandalf2325 Рік тому +1113

    The Clique Problem is easy to solve in my case, as it's just a single point.

    • @joebaumgart1146
      @joebaumgart1146 Рік тому +15

      It's the time it takes, not the actual solving of the problem.

    • @qzbnyv
      @qzbnyv Рік тому +60

      dw Gandalf. I feel you, even if Joe doesn’t.
      I’m like that too as of now.

    • @orsonankers4127
      @orsonankers4127 Рік тому +10

      Just wait for Bilbo

    • @jaideepshekhar4621
      @jaideepshekhar4621 Рік тому

      ​@@joebaumgart1146r/whooosh

    • @jorriffhdhtrsegg
      @jorriffhdhtrsegg Рік тому +29

      If anyone asks why i dont go to parties, I'll just send them this video

  • @at0mly
    @at0mly Рік тому +39

    I'm a software architect who has been programming for 30 years and this is one of the clearest explanations of P=NP that I have ever encountered.

  • @Letsamplay
    @Letsamplay Рік тому +53

    This is genuinely the first time I've even come close to understanding P=NP. And I've tried many times! Your way of communicating complex problems is really something special.

  • @hunternelson7627
    @hunternelson7627 Рік тому +162

    Truly one of the most amazing videos I've ever seen on UA-cam. Out of all the videos I've seen trying to explain NP completeness, this is in a league of it's own for clarity and engagement. It's so good.

  • @victorcoscrato4899
    @victorcoscrato4899 Рік тому +61

    I got to say, as a CS PhD, this video is so well made and interesting that it could easily substitute the first module of any constrained programming course with ease. Very well done

    • @dirkbester9050
      @dirkbester9050 Рік тому +3

      As a CS BSc Peasant, I don't know why the computation part was not taught. It is the missing link between "Thou shall believe these are equivalence classes and nay varlet, no sensible logic will be provided, just abstract reasoning. Now clap your hands for me monkey."
      This video made me finally, retroactively, understand P=NP instead of having to blindly believe in it. Same way Neal Stephenson's Cryptonomicon made me understand the formerly cryptic introduction to AI course, but years too late. Teach me properly, don't make me clap my hands!

    • @garad123456
      @garad123456 Рік тому +5

      @@dirkbester9050 if P equals NP and you know it clap your hands

  • @lvmbk3755
    @lvmbk3755 Рік тому +29

    One of, if not the, best video you've ever done.
    Best compliments for such great passion and dedication. You do not flood the tube with many videos and this is the reason: quality needs time.

  • @SimonLanghof
    @SimonLanghof Рік тому +62

    Digging through the haystack and getting half of it in your hair for a few seconds in the final video - that's dedication.
    The video really filled some knowledge gaps and glued the details together for me.

    • @vigilantcosmicpenguin8721
      @vigilantcosmicpenguin8721 Рік тому

      But it was worth it to find that needle.

    • @DreadX10
      @DreadX10 10 місяців тому +1

      @@vigilantcosmicpenguin8721 The purpose of finding a needle in a haystack is not 'to have your needle back' but to be able to feed the hay to your livestock without risk of bodily harm to the animals caused by an ingested needle.

  • @rafaelcpatrao
    @rafaelcpatrao Рік тому +56

    This reminded me a lot about my Master's thesis on bi-level, optimisation. In any other case it would be a slightly traumatic experience, but since is Jade doing so in her typical amazing way, it was a joy to watch! Thanks and keep with the great work, I need to go back to my NP-hard problem now haha.

    • @NoNameAtAll2
      @NoNameAtAll2 Рік тому

      lucky you
      I'm dealing with PSPACE-complete nightmare

    • @chriswebster24
      @chriswebster24 Рік тому +1

      That’s neat. It reminded me of my kindergarten thesis.

    • @ChappalMarungi
      @ChappalMarungi 10 місяців тому

      Slightly traumatic 💀💀💀

  • @01binaryboy
    @01binaryboy 5 місяців тому +1

    Learnt many things . Thanks !

  • @charllandsberg
    @charllandsberg Рік тому +24

    "So did we just solve the clique problem? No continues..." LOL! This was the best moment of all of UA-cam this week. Thanks for an awesome video

  • @torsten_dev
    @torsten_dev Рік тому +38

    Nice.
    We didn't prove the NP-completeness of SAT in our CS lecture so I always wondered how they proved it.
    This video gave me enough of an idea on how they did it to no longer wonder about that and be happy to just reduce problems.

    • @magicmulder
      @magicmulder Рік тому

      We did that but that class (called Theoretical Computer Science) was just about the only one that was really interesting. I didn’t care that much about Operating Systems and Fuzzy Logic etc.
      Also I remember we had some cool DOS software that could throw two dozen different algorithms at a Traveling Salesman Problem and compare their performance, with graphical output showing how each gradually improved its results. Been trying for ages to get hold of a copy…

    • @justanotherhotguy
      @justanotherhotguy Рік тому

      Did you by any chance study at TUM or elsewhere in Germany?

    • @justanotherhotguy
      @justanotherhotguy Рік тому

      (comment in reply to @magicmulder)

  • @Rijnswaand
    @Rijnswaand Рік тому +25

    Thank you! I actually studied computer science and this is one of the issues I never really understood until your husband explained it in this video. Thank you very very much for this.
    The teachers at my university didn’t have a knack for explaining things in simple terms. They were more interested in using very fancy words to explain this problem to freshmen. Which is why I never understood this.

    • @nyet_maker7948
      @nyet_maker7948 Рік тому

      Why is this still a thing? (And i mean in most fields)

    • @Rijnswaand
      @Rijnswaand Рік тому +2

      @@nyet_maker7948 you mean the usage of very fancy words to explain things to freshmen?
      Well first of all I was a freshman in computer science over 20 years ago. I can’t say if that’s still a thing. Even back then some of the younger professors seemed to be more interested in actual teaching and getting their point across than their older colleagues. But certainly not all of them.
      Also I believe it has something to do with the fact that in order to teach at a university you just have to be good in your field but not actually a good teacher. You don’t have to study pedagogy or know anything about didactics.
      Understanding something and helping others to understand it are two different things.

    • @fackarov9412
      @fackarov9412 Рік тому +2

      @@Rijnswaand "Understanding something" is necessary to "helping others to understand it" otherwise end up "helping others to understand wrong things"

    • @Dunkelelf3
      @Dunkelelf3 Рік тому +2

      @@nyet_maker7948 because you go to a university to learn advanced topics and a lot of that by yourself. a professor is an expert in his field and not a teacher and doesn't care if you understand a term or not. you have the entire knowledge of the world at your fingertips now anyways and can just google what a term means and things will become clear. what's so hard about that?
      in first semester math a girl was like "prof. xxx i don't understand this" and he just turned around "and what am i supposed to do about that now?" and went back to the board and his equations. the prof is there to teach you yes but not to make you understand. if you don't get something you work on that in your own time. that's not what classes are for. they tell you what you need to know. how you aquire that knowledge is your own problem.

  • @tomasstana5423
    @tomasstana5423 Рік тому +112

    As someone with deep passion for computational complexity (and someone who actually studied it in depth), I had the honor to truly undertand what P vs NP is about and more importantly, how fundamental that question is. And adding that it also is quite popular, it left me wondering, why no one on youtube made a solid video about it. If I had time, video editing and presentation skills, I would be making videos about it all the time :D.
    Anyway, I am really glad to see a video diving relatively deep into the topic. And I think you've done quite well the balancing of two opposing aspects of this problem - keeping the necessary technical details at minimum while staying true to the essence of the issue 💪💪👍👍.

    • @krumpy8259
      @krumpy8259 Рік тому

      what books or software do you use to study that topic?

    • @tomasstana5423
      @tomasstana5423 Рік тому +2

      ​@@krumpy8259 That depends what you already know a where you aim and how much time and dedication do you have.
      TLDR, I do not have anything to recommend, sorry :(.
      I had it built piece by piece from many small fragments over a long period of time, most passed to me by professors at the university, and also a lot came from simple thinking (about opened questions, trying to find fast algorithms for SAT problems, even though you are destined to fail, but trying it gives you a lot of insight etc.). So no collection of available sources or courses I'd know about.

    • @sayamqazi
      @sayamqazi Рік тому

      Look up "P vs. NP and the Computational Complexity Zoo" on youtube. it is pretty good.

    • @aaAa-vq1bd
      @aaAa-vq1bd Рік тому +3

      @@krumpy8259 I like the book “introduction to algorithms” because it’s written with Rivest, the R in RSA. That book will explain a ton. However in general you should understand discrete mathematics I.e. sets, graphs, trees, combinatorics and probability. The P = NP problem is deep precisely because it relates seemingly different problems as well as individuating seemingly identical ones.

    • @firstdbzmaker
      @firstdbzmaker Рік тому +3

      @@krumpy8259 I recommend two books, 1) Theory of Computation, by Sipser; and 2) Algorithm Design by Kleinberg. Both were assigned to me during my cs degree and they each contain detailed information on the P vs NP problem. You will surely gain true understanding by working through some of their exercises.

  • @Pingviinimursu
    @Pingviinimursu Рік тому +4

    Phenomenal job Jade. For so long I've known that the NP stuff is something very complex and likely impossible, so I haven't even looked into it that much. Someone explained some of it to me, but I didn't really grasp it. You did a perfect job. Mentioning the people behind the discoveries and animating them was a good touch, it makes them feel more real for me, instead of dead names on old papers.
    If anyone asks me about this stuff, you can be sure that if I have a satisfactory answer, it's because of you making this video. And if I don't, I know now where to guide them.
    Amazing job, I absolutely think you're one of the best if not THE BEST science communicator on UA-cam. Thanks so much for doing what you do, and I hope it's fulfilling for you!

  • @joebaumgart1146
    @joebaumgart1146 Рік тому +99

    This problem actually occurs quite a bit in the popular trading card game Magic The Gathering. Infinite loops are not only possible but are actually game winning strategies. This means the game state must constantly check for these loops on each players playing field with each other.

    • @Fogmeister
      @Fogmeister Рік тому

      Did you see the video about MTG being Turing complete? Search for it.

    • @Fogmeister
      @Fogmeister Рік тому

      ua-cam.com/video/pdmODVYPDLA/v-deo.html

    • @Fadexpl
      @Fadexpl Рік тому +31

      Mfw you have to solve the halting problem to win a MTG game.

    • @KaiseruSoze
      @KaiseruSoze Рік тому +3

      I haven't played MTG, but if you track each "board state" in a map can't you detect prior moves and avoid repeating them or make a move to thwart your enemies attempts to create a loop? (see the A* algorithm)
      When I'm playing 8-ball and have an impossible shot, I'll try to place the cue ball where my opponent will face a shooting position that is at least more difficult than where it is.

    • @1vader
      @1vader Рік тому +20

      MTG is actually turing complete though (there's a paper and YT vid about it) so due to the halting problem, it's impossible in general to determine whether you are in an infinite loop. Though ofc this situation doesn't really come up in normal games.

  • @wk8219
    @wk8219 Рік тому +3

    Your P Vs NP video is something I've thought about at least once a week for years. Than you for the the amazing and thought provoking videos.

  • @davidf2244
    @davidf2244 Рік тому +43

    Albert Einstein famously said that the key to understanding is to make something as simple as possible, and no simpler. You've done that beautifully in this video. You organized the video just enough for it to make sense, and included just enough foreshadowing to help the viewer follow along. You didn't repeat yourself once unnecessarily. You built the explanation up piece by piece.
    Extraordinary work. Many of even the most successful and biggest content creators often struggle with this. I could name several that have millions or tens of millions of subscribers who have never succeeded in presenting on a single topic in such an effective manner. At best typically they either do a deep dive that is unbalanced between breadth and depth, or else they oversimplify or undersimplify along the way, utterly losing the cogent coherent thread of connection, insight, and understanding that they purported to be intending to evoke in their audience.
    It's as much about what you do say, as about what you don't say. Well done.

    • @upandatom
      @upandatom  Рік тому +7

      Thank you so much 🥲

    • @hopegold883
      @hopegold883 Рік тому +2

      Yes, yes, yes! Everything you said. Thanks for taking the time to write it out!

    • @davidf2244
      @davidf2244 Рік тому

      @@hopegold883 😅🤗

    • @davidf2244
      @davidf2244 Рік тому +2

      @@upandatom you're welcome! This ability to communicate understanding of a topic to laypeople outside of the field is much more rare I think than the ability to cultivate understanding itself for one's self, and more rare than the ability to teach other individuals. I suspect a lot of people who are good at this like you are divert their efforts more to either research/learning/understanding and/or teaching, which is understandable as those pursuits are fundamentally more productive. So I hope you continue to do this from time to time however focused you become on other endeavors, because while it's not the most productive thing, it's also very rare and creates an opportunity for people to gain a useful understanding of something that they never would otherwise without people like you taking the enormous time and effort it takes to synthesize something like this for them. Thanks!

    • @THeMin1000
      @THeMin1000 Рік тому +1

      I am only replying because you said that you haven't found any other channel that explains this stuff as well so you might be missing out on some great creators who specialize in different things (but mostly general science). Ofcourse there will be variations of quality and how easy to approach the stuff is, and this is just my list in no particular order:
      - 3blue1brown
      - Science Asylum
      - Arvin ash
      - Aleph 0
      - Alpha Pheonix
      - Branch Education
      - Computerphile
      - eigenchris
      - Fine Design
      - sabine hossenfelder
      - How money works
      - Joe scott
      - Newmind
      - Physics Explained
      - Robert Miles
      - ScienceClic
      - Sixty Symbols
      - Smarter Everyday
      - sudgylacmoe
      - Technology connections
      - The action lab
      - The thought Emporium
      This is not an exhaustive list by any means, and I did not add creators focused on more narrow fields like CS, Software development, FOSS, Music theory, mechanics etc.

  •  Рік тому +3

    Thank you. As a student I focused on mathematical analysis and never took the time to comprehend (N vs NP). Maybe I thought it was intended purely in the realm of Computer Science. This presentation was thoroughly enjoyable and at least cultivated a respect for it and humbled by the toughness of this millennium problem.
    Shout out to all the reinforcements - those guys are awesome.

  • @Ceelvain
    @Ceelvain Рік тому +2

    I'm so glad you made this video.
    Although I've been a computer scientist for two decades now, and am inclined in the theoretical aspect of things, I never quite knew understood how 3-SAT is NP-complete. Whenever I tried to look it up, people only ever talk about reducing SAT (directly or indirectly) to another problem to prove the other problem's NP-hardness. Never of the NP-hardness of SAT itself.

  • @Pseudify
    @Pseudify Рік тому +7

    Watching Jade play the zill is mesmerizing. I don’t want to stop looping that sequence. I doubt I will ever hear the end of the NP story. She said she prefers xylography and yarn crafting?! She missed her true calling…

  • @SaschaKersken
    @SaschaKersken Рік тому

    This is the best introduction to NP-completeness I've ever seen. Easy to understand for beginners and still exciting for nerds such as myself (40 years of programming experience, including the last 28 professionally).

  • @ThomasGodart
    @ThomasGodart Рік тому +8

    2:22 "Clique" is a French word, it's slang for your "group of close friends", ie. the people you click with. "Ramène ta clique" would be "Come and bring your group of close friends". It has to do with the fact that in French too, we say that two people "click" when they immediately like each other, so "your click" would be that group

    • @guidoferri8683
      @guidoferri8683 Рік тому

      Isn't it pronounced differently?

    • @ThomasGodart
      @ThomasGodart Рік тому +1

      @@guidoferri8683 It's really the same prononciation and the same word as "click". We "clique" on a computer mouse, for example

    • @guidoferri8683
      @guidoferri8683 Рік тому

      @@ThomasGodart I guess I confused it with cliché

    • @ThomasGodart
      @ThomasGodart Рік тому +1

      @@guidoferri8683 Maybe! "Cliché" means something like common knowledge, but it's the French word for a camera capture, so supposedly it's something that would be printed on an ad or something, which means that it can be exaggerated

  • @Double_T_G
    @Double_T_G 7 місяців тому

    @30:10. There's the point. Even if we never magically solve the guessing problem, we at least have a tool for measuring the solvability of a problem. Now I get it. Great video btw.

  • @markd.9538
    @markd.9538 Рік тому +3

    I remember sitting through Discrete Mathematics and CompSci lectures for the better part of a year getting my head around these topics. Your video crunches it into a perfect introduction. I wish I had seen this video as an introduction 20 years ago! It would have saved me many post-lecture headaches 😁

  • @albertwebster4795
    @albertwebster4795 Рік тому +1

    yes , we want more in-depth explanation of topics of computer science in an interactive way ! (Thanks for explaining)

  • @ChronosTachyon
    @ChronosTachyon Рік тому +6

    I'm currently working my way through some ideas involving information theory that might have something to say about NP completeness, especially why individual problem instances are often solvable in P time but the general case is not.
    In particular, there are 2**(2**k) boolean functions of k inputs, since there are 2**k distinct assignments to input variables and 2 possible outputs that that assignment might have, so you can imagine a guessing game in which Bob picks a boolean function and Alice has to guess which one it is, based on choosing some variable assignments and trying to reverse engineer the rules to gain enough Shannon entropy to identify the function. If the function is chosen uniformly, then you need 2**k bits, log2 of 2**(2**k), which sucks because the relationship between number of guesses and number of bits gained is linear.
    But every boolean function can be represented by a countably infinite set of boolean formulae. Each such formula is represented by a binary tree with input variables as leaves and 2-bit boolean gates as nodes, but the number of leaves in the minimum formula is *different* for different functions. What if the probability of each boolean function is determined by the number of leaves in the minimal formula(e)? You could take the logarithm of the number of leaves to transform it into a "function entropy", and use that plus information theory to compute a consistent probability distribution so that low entropy functions are more likely than high-entropy functions. The guessing game then becomes a matter of Alice constructing a series of function models and then using her questions to disprove them.
    That doesn't solve the problem of NP-completeness entirely, because I haven't figured out exactly how to relate the boolean function guessing game to the SAT problem yet. But it feels like a promising line of thought, since it's giving structure to the guessing step in NP's definition, and the intractability of P vs NP comes from the fact that we're treating NP instances as unstructured black boxes (which is a requirement for the standard proof technique, oracle relativization). In essence, SAT instances that are almost always true or almost always false are easy to solve because the boolean expressions involved are lower entropy, compared to SAT instances that are true or false with closer to 50/50 probability. Basically, the expression tree in the hard instances is full of XOR and XNOR operations, because those are the 2-bit boolean operations that have 50/50 truth tables, and 50/50 truth tables maximize the information entropy of the outputs over the input space.

    • @asdf8asdf8asdf8asdf
      @asdf8asdf8asdf8asdf Рік тому +1

      Have you published any papers of any type or quality anywhere? This is a genuine question; I’d like to read more of your thinking.

    • @drgocht
      @drgocht 10 місяців тому

      Except that if you have only XOR and XNOR constraints, then you have a formula the encodes a system of linear inequalities modulo 2, which can be solved in polynomial time using Gaussian elimination.

  • @johnlampe6785
    @johnlampe6785 9 днів тому

    Thanks Jade. I first saw this one a couple of months ago and was suitably perplexed. However watching it this time around I think I've understood it a letter better! Perhaps a third time around will be more revealing. Your videos are so educational and accessible for a curious beginner like myself!. More power to you! John lampe, sunny Perth, Western Australia

  • @glennpearson9348
    @glennpearson9348 Рік тому +5

    Fantastic video, Jade. Love your content.

  • @Kneedragon1962
    @Kneedragon1962 Рік тому

    1st ~ Thank you very much, I enjoyed that.
    2nd ~ When I studied this stuff, the way into it was looking at sorting algorithms. We did swap-sort, bubble-sort, merge-sort... and ended up with quick-sort, which on small N, didn't look quick at all. But once you get to N over perhaps 50, Q-Sort becomes radically faster & more efficient than the others.
    An excellent exercise for beginner programmers, is to write an implementation of each one, with a graphic representation, so the audience can see what a merge-sort does and how it differs from a bubble-sort.
    This group of exercises, leads naturally and logically into discussing complexity and completeness, and if done early in the course, it leaves the student with a clear idea that computers are fast, but that speed can be easily defeated by some kinds of logical problems. They then showed us the Traveling Salesman problem.
    We can dream up and implement fairly effective solutions to that, but those are not brute force solutions.
    They don't give a 'right answer' but they can pretty easily give one that's better than 95% or 97% of other possibilities.
    Another example, is the chess player. The key part, is you need to brute force maybe 5 ~ 6 moves ahead, and then branch. You abandon all play through of games / cases / situations that lead to very poor outcomes. The tricky part is knowing when to abandon a path and chop that branch off the decision tree. But the first trick, the main one, is you don't try and brute force the whole thing.
    This leads naturally into the story of Go, and the AI ~
    The way AI works, is like a blink reflex. It isn't a decision making process, it's a lightning fast 'instinctive' reaction ~ a reflex. At best, it is reminiscent of the kind of 'thought' we would call subconscious. But it can deal with some things subconsciously, that are a lot more complicated than what a human being can follow, consciously or not. Like the game of "Go".

  • @niklaskoskinen123
    @niklaskoskinen123 Рік тому +5

    Non-determinism reminds me of quantum bogosort. Randomly shuffle an array, and check if it is sorted. If it is sorted the algorithm halts. If it is not sorted the algorithm will destroy the universe. Assuming the many-worlds interpretation is true, only universes where the array is sorted will be left. This is of course assuming that the shuffling is truly random. You wouldn't want to accidentally use a shuffle that couldn't produce the sorted state.

    • @MrDoboz
      @MrDoboz Рік тому

      lol

    • @HungryTradie
      @HungryTradie Рік тому

      Or that the sorted state is not possible. So long, and thanks for all the fish.

  • @ryanraja5170
    @ryanraja5170 Рік тому +2

    You are so lovely and so is your way of explaining difficult issues in simplest way possible

  • @surajpatel3044
    @surajpatel3044 Рік тому +3

    This is the best video on this topic I have ever seen.

  • @zxuiji
    @zxuiji Рік тому

    5:30, (haven't finished watching) For the clique problem I think I would go through each node 1 by 1 and count the number of single link rules matched, then if it matched all the single link rules I would then do the same for the local nodes if they haven't already been visited and then count how many of them carry the same count and mark the original node with that count of local nodes matching. I would then add up all the counts for the local nodes and add them up and mark the original node with a total count, if the count is >= what wanted then no further is needed, otherwise I continue to the next node and do likewise, something like this:
    foo( node, *count, rulec, want )
    {
    if ( node.matched >= rulec ) { *count = node.linked_also_matched; return node.i; }
    if ( node.matched >= 0 ) { *count = 0; return -1; }
    // ... count matching rules
    if ( matched < rulec ) { *count = return -1; }
    for ( i = 0; i < nodes.count; ++i )
    {
    n = foo( nodes.linked[i], count );
    if ( n < 0 ) continue;
    total += *count;
    if ( total >= want ) break;
    }
    node.linked_also_matched = total;
    *count = total;
    return node.i;
    }
    While it would still be an exponential problem it should still be faster than always checking the local nodes against the rules

  • @DenizenoftheAges
    @DenizenoftheAges Рік тому +3

    Hi, Jade! First: Great video. More importantly, second: Thank you for making logic-problem-exploration understandable.
    I share your videos with my 10yo son and you #ScienceCommunicator so great that he is able to understand and share opinions on the idea with me.
    Please keep doing everything you're doing and be proud. Science communication is a necessity with the way/rate our American education system is failing.
    (Putting our son into an online academy next academic year)
    Edit: My understanding of the American education system is relatively unique. I graduated high school at 14 by completing a state test, and both my parents were teachers in the California school system from 1969-2004.
    I was an '82 baby, so I feel I qualify to give an accurate description on how the American education system changed over the past 40 years.
    Parental teachers at my birth + raised by teachers/"professional-student" in college from 1998-2012, then forced to choose a major and got bachelor's in 2016, and have a kiddo 10yo in the education system.
    Yeah. We've downgraded over and over and over again.
    Cogito ergo sum.

  • @hex9219
    @hex9219 Рік тому +2

    amazing, you did a great job in explaining it.
    especially the parts that didn't click well with me when i studied it in college ( the need for non deterministic model notation )
    keep it up( and atom )

  • @1234larry1
    @1234larry1 Рік тому +3

    To me, this is related to inductive reasoning or intuition. Example
    Captain Kirk is in his captain’s chair surrounded by enemy craft. He’s been in many similar situations before and executed evasive maneuvers that worked and even though this one is not exactly the same as any of those, it’s similar to several that he has grouped together in his memory as a “class” of problems. He knows that there is no 100% guarantee of success, he chooses the class of solution that has the highest degree of success. Some would call it inductive reasoning, others might call it intuition,but since non-acting means death or 0 success, he chooses a high probability.

  • @ygorgallina2691
    @ygorgallina2691 Рік тому

    Thanks you so much for this video ! I'm a computer scientist but did not study (or didn't listen ?!) the NP things, the problem is very well introduced !! Thank you so much !!

  • @SamThe42nd
    @SamThe42nd Рік тому +13

    I love your energy, makes these videos so fun to watch. 💜

  • @ellerylin7491
    @ellerylin7491 7 місяців тому

    Best video about NP problem I have ever seen. Thanks for the great work!

  • @BradRau
    @BradRau Рік тому +11

    This reminds me of a music problem one of my friends had. You had a find a major, minor, diminished, and augmented chord using all 12 notes without repeating notes. Before I solved the problem, I realized there must be 3 solutions ( in one key, there are 12 keys, so 12*3=36 solutions total). That is because an augmented is smmyetrical with 3 equally distant notes. All I had to do was find one solution, and I could figure out the other two solutions. I also did not have to solve the problem to know there were 3 different answers. If one of the elements is symmetrical, then this can save you a lot of time. Perhaps that can help.

  • @akshay-kumar-007
    @akshay-kumar-007 Рік тому +1

    Such a co-incidence. I saw your P vs NP video few hours back as a refresher

  • @aashsyed1277
    @aashsyed1277 Рік тому +9

    Not only is this video good , it is NP-good

  • @joel.ds.m
    @joel.ds.m Рік тому +1

    You mentioned in your video about the Principa Mathematica that you were going to make a video about Gödel's incompleteness theorems. I for one would love to see that video!

  • @EvanBerkowitz
    @EvanBerkowitz Рік тому +2

    SAT of course in general is NP-hard. But the example you showed is an example of a 2-SAT problem, where every ANDed clause contains only 2 variables. 2-SAT has a faster algorithm than pure brute force.

  • @govinddwivedi582
    @govinddwivedi582 Рік тому +1

    Your efforts to make us understand these important and exciting things are great. I am very thankful

  • @grantmnelson
    @grantmnelson Рік тому +3

    Minor correction- 2SAT is actually solvable in polynomial time. 3SAT is the one that is NP Complete.

    • @jazzman616
      @jazzman616 Рік тому

      Super late to the party here, but SAT reduces to 3SAT. 3SAT is easier to work with for reductions, which is why it's more commonly talked about, but SAT itself is also NP-complete. Did she talk about 2SAT at any point? I only heard her sat SAT.

    • @grantmnelson
      @grantmnelson Рік тому

      @@jazzman616 she used it for her example at one point

  • @tomharris8712
    @tomharris8712 Рік тому

    Great video. 29:38 - As you say, solving one NPC problem would solve them all, the opposite, proving that only one of them is intractable proves that they all are, is also true. They stand and fall together, but we do not yet know their status

  • @MaximumDracula
    @MaximumDracula Рік тому +4

    "But what if you were actually popular?"
    Hello, police? There's been a murder and it was me.

  • @_kopcsi_
    @_kopcsi_ Рік тому +9

    I remember when I did my electrical engineering BSc and in my first semester I had this course called "basics of computation science". as a guy who loves mathematics I really enjoyed it and my professor was a huge mind (he was a mathematician professor). we were studying about combinatorics, graph theory and discrete mathematics in general. at some point we arrived to this topic (P vs NP etc.) and we started to solve certain problems where the task was to determine if the given problem (that consisted of an input and a question) is an NP (or NP-complete) problem. so basically we had to reduce the given problems to some known NP-complete problems (we usually used the Hamiltonian circle problem for this) in order to prove that they are NP problems. and during these exercises I had an idea: what if the input is a problem's input and question, and the question is whether the provided problem is an NP problem? then the question: is this "meta-problem" an NP problem? after I asked the professor about this self-referential question he was just staring into the void for half a minute or so. then he admitted that he has absolutely no clue but he really liked my question.

    • @garyknight8966
      @garyknight8966 Рік тому +2

      What you asked the prof was equivalent to the Russell paradox, which stopped dead Bertrand and Alfred from completing Principia Mathematica. And of course that fed into Gödel, who demonstrated that they bloody well had to stop. ;-}

    • @_kopcsi_
      @_kopcsi_ Рік тому +2

      ​@@garyknight8966 well, I am not sure what you meant by that. what do you mean by "equivalent to the Russell paradox and Gödel's incompleteness theorems"? I am pretty informed in these topics so I would really appreciate if you could explain it in more detail.
      if you referred to the self-referential feature of my question, then yes, it is similar to the Russel paradox and Gödel's incompleteness theorems in this aspect, what is more, even the halting problem and the liar paradox (actually every mathematical paradox) are based on self-reference.
      but to be honest I wouldn't claim that these are "equivalent" problems just because they share a certain attribute (namely this self-reference nature), even though I do believe that this forms the core of these problems, because they have very different aspects as well (e.g. Russel's paradox and the liar paradox are contradictions, Gödel's theorems are fundamental limitations of formal axiomatic systems, the halting problem is a fundamental limitations of computability among Turing-machines and so on).
      so I think I partially understand what you meant, but please confirm what you mean by the equivalence you mentioned.
      ps: this NP-complete thing is also self-referential in a sense, as this video demonstrated. an NP-complete problem is actually a problem that can be both solved by non-deterministic Turing machines and can simulate, i.e. create, non-deterministic Turing machines. and this reflexive relation actually encodes a self-referentiality, which also means and guarantees that the solution of an NP-complete problem is a universal solution for an entire class of problems.

    • @garyknight8966
      @garyknight8966 Рік тому +1

      @@_kopcsi_ Ditto kop1k4 .. I agree that NP-completeness entails self-referentiality in a sense akin to Russell's paradox, because it means that the class of problems if solved requires a super-class of which little or nothing can be known in terms only of the solved class. This gives new meaning to the power or meaning of a truth and method that is to be guessed (and guessed just rightly). That feature is reminiscent of Feynman's parametric integration method, which some say he pulled out of the air.
      Likewise, demonstration (proof) that a Gödel sentence is true - like perhaps some of the famous unsolved mathematical conjectures, which may well be unprovable within consistent first-order mathematical logic - would require acting in a meta-logic that transcends the constraints of arithmetic (including the excluded middle) and whose own terms and rules could not be expressed in arithmetical (or indeed SAT or 3SAT) phrases. It would be a modal logic to be sure; but there is an unending genus of those yet to be discovered .. or should I say invented ?
      That mind is of just the right nature to do this was already demonstrated by Turing under a completely different hat: using a brand of modal logic he proved the soundness of the Anselm ontological statement. Best, Gary Knight

    • @_kopcsi_
      @_kopcsi_ Рік тому +2

      ​@@garyknight8966 thanks Gary for your reply. to be honest you mentioned many many things in a very compressed way, so it's pretty hard for me to extract from your reply what you meant by that my question is equivalent to the Russel paradox and Gödel's incompleteness theorems. I still cannot see why. I do see that there are some common characteristics like the already mentioned self-referentiality or the layered structure, but to be honest these are very general features. in reality almost everything is hierarchical.
      "I agree that NP-completeness entails self-referentiality in a sense akin to Russell's paradox, because it means that the class of problems if solved requires a super-class of which little or nothing can be known in terms only of the solved class." -- well, this is true for almost everything. e.g. development (in the broadest and most general term) is just like that: to exceed a certain stage or solve a problem you have to step to the next level, which is usually unsolvable by the tools of the current level. so yeah, this hierarchised, layered class structure might be seen as a manifestation of self-referentiality, but I find it a bit forced to say that. in general we could say that almost every process that encodes progression (development, evolution etc.) is like this. this is why a finite formal axiomatic system is unable to be consistent and complete at the same time (trade-off), otherwise a finite system could generate infinite truth. similarly, this is why we cannot create a real AI yet, because in order to copy or just to mimic a human mind, first we have to understand it and have a (mathematical) model about it (so we need to have a model about something that is able to make models about things, by the very thing we want to model). and this is why every development process is "generated", i.e. observable, because if progression was trivial then there were no different stages.
      "This gives new meaning to the power or meaning of a truth and method that is to be guessed (and guessed just rightly). That feature is reminiscent of Feynman's parametric integration method, which some say he pulled out of the air." -- well, if I understand you correctly here you actually talked about intuition and the heuristic nature of human cognition (and more precisely logical induction). I agree that on an abstract level this is equivalent to the guessing problem if NP problems. but to be honest considering this aspect I don't see connection and relationship with Russel's paradox or Gödel's theorems.
      "Likewise, demonstration (proof) that a Gödel sentence is true - like perhaps some of the famous unsolved mathematical conjectures, which may well be unprovable within consistent first-order mathematical logic - would require acting in a meta-logic that transcends the constraints of arithmetic (including the excluded middle) and whose own terms and rules could not be expressed in arithmetical (or indeed SAT or 3SAT) phrases. It would be a modal logic to be sure; but there is an unending genus of those yet to be discovered … or should I say invented ?" -- this is a bit confusing for me. so you say that in order to decide whether a Gödel sentence is true, we have to go to a higher level of logic? well, it actually makes sene that this layered/stacked/hierarchised structure in general encodes progression. as far as I know there are different orders of logic, but modal logic is another kind of extension of logic. so you say that without modal logic we cannot prove if a Gödel sentence is true? and that arithmetics cannot express it? I do see the analogy with Russel's paradox where the concept of set can have this layered/stacked/hierarchised structure that can lead to paradoxes through self-referentiality. but this topic can sometimes be a bit fuzzy for me. as regards the "discovered vs invented" topic: I think mathematics is both discovered and invented, since the things we represent (represented side) are discovered (e.g. fundamental features and symmetry properties of addition, multiplication and other operators), but the things by which we represent (representer side) are invented (e.g. symbols of numbers, operators, relations etc.).
      "That mind is of just the right nature to do this was already demonstrated by Turing under a completely different hat: using a brand of modal logic he proved the soundness of the Anselm ontological statement." -- earlier I read/heard about this ontological argument. is it related to the proof of God's existence, right? well, I do not really see how the concept of God is related to this topic (I don't think it is related). Turing was a great mind but he had huge mistakes (especially later, after the war), and even the greatest minds tend to commit mistakes when they start to deal with such fundamental questions like the existence of God.

    • @mishaerementchouk
      @mishaerementchouk Рік тому

      Most likely it’s not NP, as it looks too much as a non-trivial problem in Rice’s theorem. As a side example, for the prime factorization problem it is not known if it’s NP-complete or not.

  • @scaredyfish
    @scaredyfish Рік тому +2

    24:42 So the Sat problem is like listing all the states that your computer’s memory (and registers! could have.
    Obviously, since your computer can play every single frame of every movie, or hold every character of every book, or hold a spreadsheet of the traffic patterns of any city. This is an unfathomaby huge number of possible states, but it is finite, and the states that satisfy a particular requirement could, in theory at least, be listed.

    • @sdjhgfkshfswdfhskljh3360
      @sdjhgfkshfswdfhskljh3360 Рік тому

      There is slight difference between Turing machines and BSM (bounded-storage machine) by the way.

    • @deinauge7894
      @deinauge7894 День тому

      It's also crucial that the formula of the SAT problem does grow only polynomially with the size of the turing machine. This step is left out in the video because it's too tedious.

  • @jhonnyrock
    @jhonnyrock Рік тому +10

    Yes! This is always a fun topic that could use a more in-depth look! Thank you!

  • @prdoyle
    @prdoyle Рік тому

    Wow, what an ambitious topic for a lighthearted, engaging UA-cam video. This video is pretty amazing!

  • @raulsaavedra709
    @raulsaavedra709 Рік тому +5

    Explaining the hardest class of problems is quite tricky and difficult itself, this is one great video about it. I'd venture to say it's a better overview that the accounts given by some textbooks.

    • @upandatom
      @upandatom  Рік тому +1

      thank you :)

    • @raulsaavedra709
      @raulsaavedra709 Рік тому

      @@upandatom To paraphrase on my compliment: the venerable "Intro to Algorithms" 3rd. Edition book by Cormen et al. explains only in a footnote on p. 1064: 'The name "NP" stands for "nondeterministic polynomial time." The class NP was originally studied in the context of nondeterminism, but this book uses the somewhat simpler yet equivalent notion of verification.'
      So basically they have all of chapter 34 (more than 50 pages on its own) to go over NP completeness, yet they actually never directly explain why that N was chosen for that name, what it really entails, except as a side comment in that footnote. And I find quite questionable whether their notion of verification is "somewhat simpler," in fact I take their approach as a bit obfuscating. At least they added in their footnote a reference to Hopcroft and Ullman's "Introduction to Automata Theory, Languages, and Computation," where NP completeness did get presented in terms of Nondeterministic Models of Computation, and where they do have even a highlighted box elaborating the question "Is there anything between polynomials and exponentials?"
      All in all, imho your wonderful graph @ 8:02 alone is sorely missing, and would greatly improve quite a few textbooks that cover NP completeness.

  • @samarthtandale9121
    @samarthtandale9121 Рік тому +1

    Great Video 🤩!!! I have been waiting for this since long time .... Amazing !

  • @boazyeboah1824
    @boazyeboah1824 10 місяців тому +2

    I got the meaning of NP right away. I had "NO PROBLEM" figuring it out.

  • @CoreyMinter
    @CoreyMinter Рік тому

    This is so well made. I watched on nebula, but came here to write a comment.
    The finale showing SAT reduction of clique was so clear. I took a graph theory class in college and never understood that concept.

  • @stevepoper8073
    @stevepoper8073 Рік тому +1

    I got really interested in P vs NP when watching your other video. So excited with this video!

  • @darkphoenix68
    @darkphoenix68 Рік тому +1

    Y'know, it occurs to me that Matjaz Leonardis (at around 18:50) says our language ("English") has the ability to describe everything, and then he gives some examples, including "everything". But if there is something that English cannot describe ... would we even know it? Or would it be outside of the "everything"? I'm sure there are at least a few concepts that exist in other human languages which have no direct equivalent in English -- and some of them can be difficult to accurately describe. There are also concepts in science and mathematics that do not easily map into "natural" spoken and written language.
    But hey, maybe that's a question for the linguists, or the philosophers...? 🙂

  • @williamlangley1610
    @williamlangley1610 Рік тому

    I enjoyed your Turing video...I also had to use state machine diagrams to clarify functionality to clientele and to programmers.

  • @dansteryoo
    @dansteryoo Рік тому

    DAMN. This is totally not the video I was expecting and I'm blown away... THANKS!

  • @pesilaratnayake162
    @pesilaratnayake162 Рік тому

    Amazing video, Jade! I can see how much work you put into creating an engaging story and adding some entertaining transitions, and I think it's really paying off in terms of video quality.
    The completeness was most interesting (and previously poorly understood) to me, but I can see how many of these problems can be boiled down to a SAT type problem or a Clique problem, where a solution exists if all required Boolean relationships are satisfied.
    The best I can think of to simplify the computation is pruning Boolean values that are incompatible with known parts of the solution, and split possible solutions into groups based on which values are mutually incompatible, but that only goes so far and might just reduce some problems to NP problems of smaller order.

  • @MagnusRender
    @MagnusRender Рік тому +2

    I had no idea what I was watching, as I'm not into math, but this made a lot of sense and got me thinking in new ways. I like philosophy and personal development and had quite a blast imagining what it would be like to just intuit any problem I ran into and have it be correct. Just imagining that ONCE in an embodied way blew me away. A quasi-religious experience. Fun!

  • @ShershaahLionKing
    @ShershaahLionKing Рік тому

    I could never find such a great vidoe on this topic !!
    A huge thanks.
    Keep up the fascinating work.
    Cheers to Up and Atom :)

  • @justpaulo
    @justpaulo Рік тому +1

    Love your clarity and very refined humor! This video was on my watchlist and I almost skipped it, but I'm very happy I didn't.
    8:24 So why EXP isn't know as NN instead ?

  • @VuNguyen-mh4oo
    @VuNguyen-mh4oo Рік тому

    Beautiful and smart and very helpful and friendly, you are such a joy to watch and listen and to learn from, Jade. Simply the best ! Best wishes and hope to see more of your work.

  • @christianmartin8751
    @christianmartin8751 Рік тому

    A simple explanation to a problem I wanted to deeply understand for years. THANK YOU.

  • @anfarahat
    @anfarahat Рік тому

    Thanks for the attractive and fulfilling tutorial. As a side note, the example given for SAT is a 2-SAT, which is solvable in polynomial time.

  • @Hossak
    @Hossak Рік тому +1

    Holy moly, 33 minutes long! You are putting in some massive hours, Jade - well done! Loved the video!

  • @Flovus
    @Flovus Рік тому

    4:39 It is important to stress that the clique size also increases here. If the clique size is fixed, say k, then the runtime is polynomial (in the graph size) despite the algorithm being brute-force search.
    6:20 The sum, product and composition of polynomials are polynomials. This is important since algorithms are often built together like building blocks. The easiest case is when I run an algorithm and then another algorithm: the overall runtime is the sum of the two runtimes.
    I personally find nondeterministic Turing machines outdated. The definition by deterministic verifiers is more practical and easier to understand.

  • @kapilshenviamonkar4641
    @kapilshenviamonkar4641 Рік тому

    Thanks a lot! For the first time I understood what NP really is and the Non-deterministic part of it.

  • @bazsnell3178
    @bazsnell3178 Рік тому

    You brought joy to my heart when I saw the look on your face when you finally found that needle in the haystack!

  • @polychoron
    @polychoron Рік тому

    That is the clearest definition of algorithm I've ever seen. Thanx Jade 💗

  • @apophissoftware
    @apophissoftware Рік тому

    Very much enjoyed the video! Also, I have to say that I actually really like the SAT problem, and a very easy solution to it, is to use elimination. You can quickly figure out that Z is the odd one out. I realize that this is a simplified problem, and when things get more complex it becomes harder to see, but the elimination algorithm still hold up in that aspect. And, by eliminating different node variables, you make it less complex as you work through it, hence it scaling better than a brute force check.

  • @jones1351
    @jones1351 Рік тому

    Didn't get much of this. I'll need to watch it again - several times. Love the animations.

  • @Ailun__
    @Ailun__ Рік тому

    You’ve easily explained this way better than most professional computer scientists could have. Amazing job, wish I’d seen this while I was still in college.

  • @ahasdasetodu6304
    @ahasdasetodu6304 Рік тому

    5:30 correct me if I'm wrong but I'm pretty sure that scaling faster means running slower for large n so and such algorithm is always possible and in fact quite easy to find

  • @iwerning
    @iwerning Рік тому +1

    Outstanding video! Well thought out, well executed, interesting and serious but with just enough dashes of humor.

  • @omarradaro
    @omarradaro Рік тому

    Thanks!

  • @jp10a
    @jp10a Рік тому

    This was a great explanation. Lengthy but worthwhile. Allowed me to fill a few knowledge gaps on the topic.
    Also, the outro song is a banger!

  • @SantinoDeluxe
    @SantinoDeluxe Рік тому

    so happy to have an new science based channel to sub to, youre doing great work, keep it up

  • @Johncornwell103
    @Johncornwell103 Рік тому

    Love your videos

  • @GoldenAgeMath
    @GoldenAgeMath Рік тому

    Thank you for making these videos! I love the posters in the background

  • @jawadthabet
    @jawadthabet Рік тому +2

    I weirdly guessed the solution to the XYZ problem (SAT) right the first time, an educated guess though
    What I did was noting that X and Y (unlike Z) both occur three times, twice as they are and once negated.
    This implies that X and Y are more useful being ones rather than zeros (loosely speaking, 2/3 chance for each of them being ones), and by exploiting said symmetry between them I was pretty sure they're both ones. The last thing was to check whether Z is true or not, Z is the only variable occurring twice, once as is and once negated, so the situation is symmetric between these two solutions, and the symmetry-breaking part of the problem statement is the (-X or -Z) part, since X is probably one, Z is therefore zero

  • @rajeeshcm5938
    @rajeeshcm5938 Рік тому

    Jade, I subscribed to your channel after watching just one video, this one is really good the foundations of computer complexity theory

  • @KANA-rd8bz
    @KANA-rd8bz Рік тому

    nice, 33 minutes and I don't know when it all passed :)) thank you Jade

  • @punditgi
    @punditgi Рік тому +1

    Jade is back and better than ever! ❤😊🎉🥰💥💯💭

  • @EaglePicking
    @EaglePicking Рік тому

    I watched this video while refreshing my Rubik's cube skills. Good video. Thanks :)

  • @christianmuller2863
    @christianmuller2863 5 місяців тому

    Danke!

  • @shubhamsingh3290
    @shubhamsingh3290 Рік тому

    hy jade watching from India and I really like your video as you tell us about NP problem in a Polynomial time

  • @Skeithization
    @Skeithization Рік тому

    Thank you for a great video. Somehow you've managed to turn make a very challenging problem easier to understand.

  • @nithinkandula4346
    @nithinkandula4346 Рік тому

    Such a amazing video...very well explained and putting it simple at the same time...thank you for creating such a valuable and amazing content.

  • @tomhekker
    @tomhekker Рік тому

    Wow, thanks! As a computer scientist I always have issues explaining NP completeness to people, I’ll just link them your video next time!

  • @stoicc6510
    @stoicc6510 Рік тому +1

    Awesome video! Not only a very apt explanation of NP and NP-Completeness, but with excellent humor, too! Any chance you can do a hoodie or enamel pin of the quantum physics design for your merch store? I'd go for either in a heartbeat!

  • @FredBakker
    @FredBakker Рік тому

    And yet another brilliant video! Well done and well worth the wait

  • @tcast3r
    @tcast3r День тому

    Tremendous!

  • @polypro553
    @polypro553 Рік тому

    So here is my idea to solve the Clique Problem (Or at the least to possibly reduce the computational power to solve)
    I am still trying to create a full procedure, but let's get some of the basics out of the way.
    Let's refer to my scenario as asking if there is a clique of 4 or (x) the number of nodes (y) and number of connections each node has (z).
    First Algorithm: Easy (not all problems will be solved with this algorithm, but it's the fastest, plus any progress can be transferred to another algorithm)
    We can remove a node if Z is less than X-1. Any left will be referred to as possible nodes.
    We can determine if a clique DOES NOT exist, if possible nodes < clique of (x)
    We can determine a clique DOES EXIST, if all remaining nodes have x-1 connections
    After this go to the next algorithm.
    Second Algorithm: More advanced
    Search for an unlikely node - we can label a node as unlikely nodes if it is = X-1
    If the algorithm detects an unlikely node, immediately test it.
    If a clique forms, then the problem is solved.
    If a clique does not form, you can remove that node and any corresponding connections.
    Update the number of nodes and connections and see if the clique is still possible. (Go to first algorithm)
    In theory we could modify the second algorithm for more different amounts of connections ( ie 4, 5, 6, ect) but will require more brute force.
    If no nodes, exist go to the next algorithm.
    Algorithm 2.5 : Very computational
    Test if there are connections between the nodes with the lowest amounts of connections. (ie if there are 2 nodes with 4 connections each)
    If there are connections, then test if there are any possible cliques that forms with both nodes.
    If there is, then the problem is solved.
    If a clique does not form, then remove that connection and update the remaining nodes and corresponding connections. (Go back to the first algorithm)
    I don't know if algorithm 2.5 is computationally more efficient or not. However, the less connections in general, the quicker it would be to computer.
    Please reply if you have any ideas, I want that million dollars.

  • @carlosvigil1868
    @carlosvigil1868 Рік тому +1

    Wow! Finally, I understand what all NP-completeness business is about xD and everything is thanks to this wonderful video. Keep it up! (PD. This video, and the one saying: "imaginary numbers are just the roots of nothing, are the ones I love the most!)

  • @blahdelablah
    @blahdelablah Рік тому

    On the boolean logic problem around 17:50, there is a way to determine the answer with logic rather than brute force. If (X or !Y) and (X OR Y) have to both give a 1, then X has to be 1, as otherwise !Y and Y would both have to be 1 which is impossible. After you know X is 1 the rest falls into place. (!X OR !Z) means that !Z has to be 1, which means Z is 0, and if (Y OR Z) has to be 1 then Y also has to be 1.