Beating Connect 4 with Graph Theory

Поделиться
HTML-код
  • Опубликовано: 9 сен 2024
  • I had way too much fun with 3d graphics this time.
    Some references:
    Amount of nodes after n plies: oeis.org/A212693 / web.archive.or...
    Fhourstones, the first program to solve Connect 4 (to a depth of 8 plies,) which was also crucial for animating the graphs in this video: tromp.github.i...
    The first published (weak) solution to Connect 4: tromp.github.i...
    Rendered with github.com/2sw...
    A (brand new and totally undeveloped) discord server for my channel: / discord
    A nice discord community for Connect 4: / discord
    Thanks again for the tunes, Tim!

Комментарии • 153

  • @sorin_markov
    @sorin_markov Месяц назад +160

    In case you missed it, there are two communities you can join linked in the description! One is for 2swap the man himself and one is a connect four server that I totally have no vested interest in :)

  • @gridddo
    @gridddo Месяц назад +404

    guess its time to watch another really well made connect 4 video i dont understand

    • @twoswap
      @twoswap  Месяц назад +37

      :')

    • @neon_Nomad
      @neon_Nomad Месяц назад +2

      Graph Theory is just determining the set of all eventualities.

    • @CaptTerrific
      @CaptTerrific Месяц назад +12

      @@neon_Nomad ...are you saying Graph Theory is my ex-wife's lawyer!?

    • @JorgetePanete
      @JorgetePanete 28 дней назад

      it's*
      don't*

  • @tsanguine
    @tsanguine Месяц назад +88

    "So far we've been interested in strategies of connect 4," instant sub. straight to the point. i love you.

  • @rafthesheep
    @rafthesheep Месяц назад +147

    time for more "i don't remember this channel but i love past me for subscribing" content

  • @matthewlehner4747
    @matthewlehner4747 Месяц назад +44

    5:34 "we can now delete all other children"
    is hilarious out of context

    • @twoswap
      @twoswap  Месяц назад +9

      I knew someone would bring this up 🤣

    • @TheArtOfBeingANerd
      @TheArtOfBeingANerd Месяц назад +3

      Was about to comment this lmao

  • @MusicBent
    @MusicBent Месяц назад +28

    I built a solved connect 4 opponent on a raspberry pi, that would use image processing play you on a physical board. I used minimax with ab pruning. I could only go about 4 or 5 moves ahead within a reasonable amount of time. This is a really clever way to optimize the large tree of future moves. Wish I had thought of it then

    • @axa122
      @axa122 Месяц назад

      sounds neat. how much time did it take to process those moves?

  • @sorin_markov
    @sorin_markov Месяц назад +89

    As a connect four expert, I understood about 5 of these words.

    • @ethanchristensen7388
      @ethanchristensen7388 Месяц назад +13

      As a computer science/math student, I understood all but about 5 of these words.

    • @asheep7797
      @asheep7797 Месяц назад +6

      As a drunkard, I understood the part where he talked about dancing dinosaurs.

    • @lumiey
      @lumiey 27 дней назад +1

      connect + four

  • @jay-tbl
    @jay-tbl Месяц назад +12

    thinking of strategy in games as a compressed version for the actual solution is mind blowing

    • @twoswap
      @twoswap  Месяц назад +3

      That's exactly what it is!

    • @twoswap
      @twoswap  Месяц назад +9

      I really appreciate this comment lol, it's the first one to actually directly acknowledge the thesis of the video 😅

  • @axiezimmah
    @axiezimmah Месяц назад +7

    Therapist: left hand on top Mona Lisa doesn't exist, it can't hurt you.
    7:58

  • @twoswap
    @twoswap  Месяц назад +35

    I am sad, why are there so many yucky compression artifacts on the video :(
    I wonder if youtube is still doing some postprocessing or something... the black background behind the graphs doesn't look nearly as fuzzy or blocky on my end

    • @Ns-uo2um
      @Ns-uo2um Месяц назад +11

      I came to comment specifically to commend your animations, they look so clean and well thought out that it’s actually crazy. I am sorry it wasn’t exactly what you intended, but what it is is an amazingly crafted and beautiful video, so thank you so much for giving us quite possibly the best connect 4 video on the internet.

    • @twoswap
      @twoswap  Месяц назад +6

      Thank you 🥹 im glad you liked it!!!

    • @mathboy_
      @mathboy_ Месяц назад +7

      Ironic that a video about compression would suffer from it's own subject!
      It's possible that uploading the original video in 4k would increase the bitrate and decrease compression at higher resolutions. Something to maybe keep in mind for future videos.

    • @twoswap
      @twoswap  Месяц назад +9

      yeahhh. I'm gonna have to play around with it a lot. I'm passing a whole bunch of params into ffmpeg which seem relevant and are definitely tweakable, but I optimized that stuff ages ago up to how it looked on my end as opposed to youtubes end :/

    • @sabinrawr
      @sabinrawr Месяц назад +2

      If it helps, I watched on my phone, so much of the fine artistry was lost on me. 😭

  • @olliebop1
    @olliebop1 Месяц назад +23

    YES NEW 2SWAPPPPP I LOVE CONNECT 4 THEORY

  • @warguy6474
    @warguy6474 Месяц назад +7

    Every time i watch these game + graph theory type videos im always amazed and in awe of the beauty of such simple games. I really have to try implementing something like a basic minimax one day

    • @twoswap
      @twoswap  Месяц назад +1

      Definitely give it a shot!

  • @VivianAttler
    @VivianAttler Месяц назад +24

    HES BACK!!!!! LETS GOOOOOOOOOO

  • @SirLightfire
    @SirLightfire Месяц назад +2

    This video is only 10 minutes, yet it feels like a full lecture on advanced algorithms and data structures
    I'm gonna need some time to absorb this one

  • @an_asp
    @an_asp Месяц назад +5

    I used to be a teaching assistant for a class on search-based AI and minimax, so I am very happy to see such a well-made video on something so near to my heart. The visualizations of the state graphs showing the structure were extremely cool, and I'm excited for the insights you teased at the end! Connect four is way denser in transpositions than most games I'm used to like chess!

    • @twoswap
      @twoswap  Месяц назад +2

      Hell yeah, I'm glad you liked it!
      My initial reaction to your comment was to say, yeah, that's exactly right that connect 4 is oozing with transpositions in a way that chess isn't- but now I'm wondering if that's actually the case. I guess it depends on whether by transpositions you mean the strict notion of arriving at the same spot from 2 different paths, or in a looser sense of arriving at two positions whose continuation trees are isomorphic to each other. Honestly I am not so good at chess as to have a strong opinion, but I would be hesitant to say that chess doesn't manifest a bit of the latter kind of transposition. Maybe it's just harder to abstract out patterns from the noise in chess, and therefore harder to see the transpositions. Not sure!!

  • @andrewharrison8436
    @andrewharrison8436 Месяц назад +2

    The full tree is an example of data not information, colouring the nodes according to minimax starts to add information but it still isn't really the same as knowledge of the game's structure.
    For a practical learnable strategy there needs to be a "why" for each choice. Everybody who plays connect 4 will acknowledge situations where the next move is "forced" in that it gives a win or avoids a loss. Stronger players look further ahead so have more comples "why"s. To be expert you would need either a means of prunning the tree or strategies that avoid the tree altogether.

  • @fallenflame8678
    @fallenflame8678 Месяц назад +5

    This is an incredible video. For a while I have been thinking about a pretty similar thing (in the context of optimal rubik's cube solutions), but I haven't actually put this idea into practice. I'm very excited for the next video.
    Also very cool graphs. I recently wrote a program to draw graphs, but my simulation was limited to 2d. It's nice to see how much that kind of thing can be improved with 3d simulation.

    • @twoswap
      @twoswap  Месяц назад +2

      similar video on rubiks cubes coming soon-ish!

  • @lit_kzh
    @lit_kzh Месяц назад +3

    started this video and immediately went on a tangent to watch every other video on the channel to get caught up lol. watching it for real this time!

  • @ees4.
    @ees4. Месяц назад +3

    A new 2swap video! I used to watch these when they first came out while I was in school, before dropping out, these are so well-explained and easy to follow!

    • @sorin_markov
      @sorin_markov Месяц назад +5

      Goodness, has our little community been going long enough for people to be nostalgic about it now?

    • @ees4.
      @ees4. Месяц назад +1

      ​@@sorin_markov Seemingly so.

  • @viktorzzxz
    @viktorzzxz Месяц назад +5

    Let's fucking go another connect 4 dub for the boys

  • @SynchroFPS
    @SynchroFPS Месяц назад +5

    The goat has returned

    • @twoswap
      @twoswap  Месяц назад +1

      Quit my job so I have a lot more free time now 🐐😎

  • @anfrih
    @anfrih Месяц назад +6

    We are so back

  • @louisreinitz5642
    @louisreinitz5642 Месяц назад +7

    It's not actually a tree, two moves each can end up at the same place if moves are transposed.

    • @twoswap
      @twoswap  Месяц назад +2

      tree, dag, you get the idea 😅

  • @fatih3806
    @fatih3806 22 дня назад

    That Mona Lisa analogy is the best thing I’ve heard

  • @PunmasterSTP
    @PunmasterSTP Месяц назад +1

    Those graphics were incredible and so beautiful to watch! I also heard about the game of Connect 4 being solved back in the 80s, but didn't really know that much about its solution.

    • @twoswap
      @twoswap  Месяц назад +1

      Thank you!!

  • @Bleuthatup
    @Bleuthatup Месяц назад +15

    Based and 4pilled

  • @communist4trump
    @communist4trump Месяц назад +1

    hard to put into words how much i love + appreciate these videos, thanks a lot for making this

  • @haugenmitch
    @haugenmitch Месяц назад +3

    Another great video! I can't wait to see what's next!

  • @benruniko
    @benruniko Месяц назад

    That… that is incredibly clever!! I never considered weak solutions as a thing, and applied theories specifically for networks is pretty brilliant.

  • @christophergilbert5988
    @christophergilbert5988 Месяц назад +2

    this is actually insanely cool, subbed!

  • @danielhobbyist
    @danielhobbyist Месяц назад +1

    I did something like this for a variation of the 15 puzzle (with multiple solution states) once for a school project. Wish I saw this, it would have saved me a good bit of time with the ideas.

  • @MusicBent
    @MusicBent Месяц назад +1

    I built a solved connect 4 opponent on a raspberry pi, that would use image processing play you on a physical board. I used minimax with ab pruning. I could only go about 4 or 5 moves ahead within a reasonable amount of time. This was plenty to beat most human opponents. This is a really clever way to optimize the large tree of future moves. Wish I had thought of it then.
    I also played about 1000 games in the time, and studied James Allen and Victor Allis’ brilliant papers. Both are great reads in my opinion! 😉

    • @twoswap
      @twoswap  Месяц назад +1

      Thats super cool, especially with the image recognition!

  • @minikretz1
    @minikretz1 Месяц назад +2

    amazing graphics! keep it up!

  • @jacksonpope3473
    @jacksonpope3473 29 дней назад

    That Mona Lisa analogy was fucking awesome!

  • @andermium
    @andermium Месяц назад +1

    Okay fine I'll watch the previous parts too lmao. I kept ignoring this rabbit hole, but I've finally clicked on it at 2am now and it's totally worth it to watch without being tired

    • @twoswap
      @twoswap  Месяц назад +1

      mwahahahaha

    • @andermium
      @andermium Месяц назад

      @@twoswap alright, caught up. Can't wait for next episode!

  • @JohnMazz
    @JohnMazz Месяц назад +1

    Love this, yet another great one thank you! Keep it up

  • @toburr
    @toburr Месяц назад +2

    we are so back, we are the most back, the backest!!

  • @busy_beaver
    @busy_beaver Месяц назад +1

    Very cool visualisations!

    • @twoswap
      @twoswap  Месяц назад

      One of my next few videos is gonna be about the busy beaver function 👀

    • @busy_beaver
      @busy_beaver Месяц назад

      @@twoswap, that's nice! I actually named my channel after the BB function

  • @garryschniderham8291
    @garryschniderham8291 Месяц назад +3

    I made Connect 4 on my graphing calculator, I want to make it play against me but I'm too lazy, cool vid

  • @axa122
    @axa122 Месяц назад +1

    very clear explanation and visuals, nice channel

  • @CompanionCube
    @CompanionCube Месяц назад +3

    1:18 but there are duplicates? (exact duplicates, not mirrors like mentioned later)

    • @twoswap
      @twoswap  Месяц назад

      Those aren't double counted (which is the reason the table shown gets slower than 7^n at 3 moves.) Sequences 147 and 741 are (at least in this video) treated as the same node. That's also why some of the trees shown have loops in them :)

  • @hjaltetoes8837
    @hjaltetoes8837 Месяц назад +1

    wow, nice video. Very well made🙌🙌🙌

  • @Agadr
    @Agadr Месяц назад +1

    very underrated channel

  • @Noah-lj2sg
    @Noah-lj2sg 20 дней назад

    Awesome video. I love math visualization

  • @TheAntondi
    @TheAntondi Месяц назад +1

    Here it is, the generalisation I've been waiting for. Discrete mathematics rock!

  • @NightmareCourtPictures
    @NightmareCourtPictures Месяц назад +3

    Billy Butcher would like to know your location.

  • @alexsere3061
    @alexsere3061 13 дней назад

    Man, after learning about this solution for connect four, i dont even imagine how useless the solucion for chess will be. Probably completely unusable. Thanks for the video, as someone who participated in math competitions, this side of the "there is always a winning strategy" is a new perspective for me

  • @parsatalaie9892
    @parsatalaie9892 Месяц назад +2

    WOOOOOOOOOOOOOOOOOOO

  • @RPG_Guy-fx8ns
    @RPG_Guy-fx8ns Месяц назад +2

    To avoid combinatorial explosions, maybe try focusing on the end of the game, and forget about turn order. there are only 3 ways to win, horizontally, vertically, or diagonally, and those problems are transposed around the board. Your strategy to defend against these should not be in a global coordinate space, but local strategies relative to the dangerous arrangement. It should mix 2 strategies, defense and offense, depending on how dangerous the board is.

    • @twoswap
      @twoswap  Месяц назад +2

      This is very similar to the idea in Victor Allis's paper (the one linked in the description!) Unfortunately, or at least with respect to that paper, that thought process was only considered formally with regard to the defensive aspect on behalf of player 1, and was used to show formally without search that the game is _at least_ a tie or better for player 1. Further search was required to show that the offensive endeavor on behalf of player 1 bears fruit.

  • @stickpfp6347
    @stickpfp6347 24 дня назад +1

    Guys, I actually learned about Minimax in universal paper clips, please applaud me and give me a standing ovation 😎😎😎

  • @evidenceofgriefing4617
    @evidenceofgriefing4617 21 день назад

    I dont understand how but after about two years in middle school of playing the max difficulty connect 4 computers, I've become unbeatable (I always tie or win). I'm curious to see how this video deepens or changes my understanding of the game and my undetsanding of it.

  • @MickeJagger
    @MickeJagger Месяц назад

    Wow that's helps me understand graph theory

  • @fx-modding
    @fx-modding 19 дней назад

    My graphics card laughs at the thought of only calculating 4 trillion nodes. Time to spin up cuda xD

  • @NepYope
    @NepYope Месяц назад +1

    fantastic video

  • @Limofeus
    @Limofeus Месяц назад +1

    This is interesting, but yea, as people say it's pretty hard to wrap the head around all of that ha ha

  • @Jatd22
    @Jatd22 Месяц назад +1

    i dont know what Im watching but im interested

  • @Byron_Vega
    @Byron_Vega Месяц назад +1

    Awesome video!

  • @srengp3805
    @srengp3805 Месяц назад +3

    Now do it with chess

  • @adon155
    @adon155 Месяц назад +2

    3:30 animation looks cool but its kinda hard to see whats happening to actually understand it

    • @twoswap
      @twoswap  Месяц назад

      Ahh man, I did not appreciate until now how faint it looks on OLED screens. That's probably why? Rendered it on desktop.

  • @user-dp9dg4tb3i
    @user-dp9dg4tb3i Месяц назад +2

    for anyone who wanats to know geting rid of the bad options as seen at the beggining is called alpha beta pruning

  • @phailupe2941
    @phailupe2941 Месяц назад +1

    Hell yeah

  • @neioni
    @neioni Месяц назад +2

    mm yes i am going to forget all of this 30 minutes after closing the video

  • @juusot8859
    @juusot8859 Месяц назад +1

    Shouldn't the game tree actually be a DAG if we're talking about things like canonicalisation (elimination of mirror positions)? Never mind that you can reach the same position via many paths, i.e., the first optimization anyway is putting the positions in a hash table instead of storing them naively... maybe this was mentioned.

    • @twoswap
      @twoswap  Месяц назад

      It absolutely is a dag, canonicalized or not!

  • @willthompson6917
    @willthompson6917 18 дней назад

    "We can now delete all other children" - average computer scientist

  • @kevinhopper2493
    @kevinhopper2493 Месяц назад +1

    This is so impressive! Do you have any suggested reading/literature/channels that go into more detail on graph reduction?

    • @twoswap
      @twoswap  Месяц назад

      ...no, sorry :'|

  • @luisisaurio
    @luisisaurio Месяц назад +1

    You should be able to cut the # of games in half because of symmetry.
    Won't help at all, but I love symmetries :)

    • @luisisaurio
      @luisisaurio Месяц назад

      For any given board configuration, flipping the board 180 degrees gives you a new configuration which has the same outcome

  • @GordonThompson
    @GordonThompson 13 дней назад +1

    @2swap I'm really interested to see if you can prune enough via heuristics to create a human-learnable undefeatable strategy for the first player. Based on my own C4 experience I would guess that it is possible.

    • @twoswap
      @twoswap  13 дней назад +1

      thats what I'm aiming on here :) I've pulled it off for about ~15% of openings so far, and I suspect I can keep on chugging along. It will take time and work (hence the filler videos haha)

    • @GordonThompson
      @GordonThompson 13 дней назад +1

      ​@@twoswap you're killing it 🫡

  • @woekin
    @woekin Месяц назад +1

    are the nodes connected when they match another board exactly but the journey was in a different order? Also could you use TSNE?

    • @twoswap
      @twoswap  Месяц назад

      Yep, nodes correspond to board states, not move sequences, and thus transpositions form undirected cycles. Nothing is stopping you from using TSNE, but thats not what I'm going for here- I still want to be able to discern graph structure, not just identify subcomponents.

  • @mrpocock
    @mrpocock Месяц назад +1

    I don't think you mentioned transpositions, where different move orders reach the same game state. A lot of strategies rely upon these as a sort of knowledge compression trick.

    • @twoswap
      @twoswap  Месяц назад +1

      At least with respect to the representation im using here, transpositions are already diagrammed as (undirected) cycles in the graph. Super helpful, but at the same time, if your goal is to compress the graph itself, those transpositions are _already being taken into account_, in some sense!

    • @mrpocock
      @mrpocock Месяц назад +1

      @@twoswap out of interest, what are you using to plot those 3d graphs ?

    • @twoswap
      @twoswap  Месяц назад +1

      its all 100% custom, the repo is in the description! You are looking for the file called OrbitScene3D.cpp.

    • @mrpocock
      @mrpocock Месяц назад +1

      @@twoswap very nice work

  • @NesiAwesomeness
    @NesiAwesomeness Месяц назад +1

    How did you make the trees visualisation?

    • @twoswap
      @twoswap  Месяц назад

      my own tool! github.com/2swap/swaptube

  • @PremierSullivan
    @PremierSullivan Месяц назад +1

    Fyi the visualizations are hard to read on the phone screen.

    • @twoswap
      @twoswap  Месяц назад

      Yeah ;-; I only realized after posting how bad it looks on OLED

  • @gunaysoni6792
    @gunaysoni6792 Месяц назад +1

    4 trillion is fairly small right? You could brute force it

    • @twoswap
      @twoswap  Месяц назад

      Not without a/b pruning and fancier methods than pure minimax! Or maybe with some super super pricey compute...

  • @Ygenish1
    @Ygenish1 Месяц назад +1

    i find it funny how you're mentioning "in-reality a memory couldn't bare this task" while there are chess GM who are remembering thousands of endgame positions, and can recall games from a certain position without context... Magnus is said to remember more about 10,000 games and most GMs can play a near perfect endgame without seeing the board.
    So I think that yes, a human can be a master in connect four without realising the entire context of his play.

    • @twoswap
      @twoswap  Месяц назад

      there's a universe of difference between memorizing enough to be proficient vs memorizing enough to guarantee optimal play

  • @nadyanabahi8259
    @nadyanabahi8259 Месяц назад +1

    Why isn't this a SoMEpi submission?

    • @twoswap
      @twoswap  Месяц назад

      Don't know anything about SoME or the submission process, do I just slap the #SoMEPI in the title?

  • @NormieDead
    @NormieDead 29 дней назад

    can you teach.? how you make those cool things ?

  • @HelloIAmAnExist
    @HelloIAmAnExist Месяц назад +1

    1:30 why does the pattern not just continue as powers of 7? Other than 1 side being completely full or someone winning (both of which shouldn't be possible by the second move), how could the number of possible moves decrease?

    • @twoswap
      @twoswap  Месяц назад +4

      the same reason the graphs animated are DAGs and not strict trees (in the sense that undirected cycles can come up). you can get to the same position by several different ways. For example, red plays column 1, yellow column 4, and red column 7, or the other way around (7 4 1.) You land in the same spot.

    • @HelloIAmAnExist
      @HelloIAmAnExist Месяц назад +1

      @@twoswap ohhh that makes sense.

  • @kaya-sem
    @kaya-sem Месяц назад

    How are these graphs visualised? A game engine? Custom written program?

  • @bigzigtv706
    @bigzigtv706 Месяц назад +1

    Now do this but for go

    • @twoswap
      @twoswap  Месяц назад

      lots of go vids coming sooner or later

    • @bigzigtv706
      @bigzigtv706 Месяц назад +1

      @@twoswap 🔊📣📢

  • @ees4.
    @ees4. Месяц назад +1

    What did you use to animate this video?

    • @twoswap
      @twoswap  Месяц назад +1

      my own custom bespoke tool: github.com/2swap/swaptube

    • @ees4.
      @ees4. Месяц назад +1

      @@twoswap ooh, this tool is cool!
      I suppose I have a reason to learn c++ now (as I want to get into animating similar styles of videos) or just port it to java or rust (which I am already learning.)

    • @twoswap
      @twoswap  Месяц назад +1

      ​@@ees4. Man i need to learn rust lol.
      If you start doing anything of the sort, tell me about it before hand :D i might be able to help or something. I thought about porting to rust myself

    • @ees4.
      @ees4. Месяц назад

      @@twoswap i'll let you know when i stop procrastinating and start porting ;D

  • @API-Beast
    @API-Beast 20 дней назад

    You say that 4 trillion is too much to compute, but that's not really true. If you computed 1 million nodes per second (easily doable in a system language like C) you would need just 46 days for the computations to finish. An experienced programmer could probably go far beyond 1 million/s.

    • @twoswap
      @twoswap  20 дней назад

      ...i don't want to wait 46 days!

  • @w花b
    @w花b Месяц назад +2

    Nowadays, people would brute force everything with deep learning. That's how you actually solve problems. Only a very small amount should require hammering with deep learning. And the brain consumes much less energy than these data centers with thousands of GPUs so it's better for the environment.