C++Now 2019: Conor Hoekstra “Algorithm Intuition”

Поделиться
HTML-код
  • Опубликовано: 26 янв 2025

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

  • @brainplot
    @brainplot 5 лет назад +30

    Not going to lie, probably one of the best talks I've ever watched. I'm also very impressed by the fact that it was his first talk at a conference. He sounded very confident for a first-timer.

    • @TheReferrer72
      @TheReferrer72 5 лет назад +3

      He is a natural speaker and an expert at algorithms with only 5 Years C++ experience, now let me go find his channel.

    • @systemdeadlock
      @systemdeadlock 2 года назад +1

      @@TheReferrer72 5 years is like no experience relatively speaking

  • @WaseemYusuf
    @WaseemYusuf 4 года назад +8

    "This is phenomenal, I want to write code like CONOR!!!!"

  • @Qazqi
    @Qazqi 5 лет назад +8

    One of my favourite additions to Kotlin was windowed() to have a nicely named alternative to zipping the start of a range with its tail. In range-v3, it's called view::sliding.

    • @code_report
      @code_report 5 лет назад +1

      I love sliding as well. It is covered in one of my recent videos: ruclips.net/video/cClOEG-_dns/видео.html

  • @JackAdrianZappa
    @JackAdrianZappa 5 лет назад +2

    Very good talk. Did anyone notice the slide code at 31:20 had used an undeclared var `v`? That must have meant to be `coins`. Slide code almost always has some bug.

  • @jjverce
    @jjverce 5 лет назад +1

    I think the difference between transform and reduce should be made explicit so as to avoid confusion. From my point of view, inclusive scan can be seen as both since it transforms each value into another one, but it also performs an accumulation since the new values depend on all the previous ones.

  • @IAGUITO95
    @IAGUITO95 2 года назад

    46:00 They totally should have not call it "zip_reduce" and specially not if i got this talk right.
    You ""could"" get that before, its comming in c++23 i think, you make a pair combining each elem, pass it to transform, and then unbind them inside. zip plus reduce is not what you want, is what you would had to do to overcome not having a way to transform_reduce in this way.
    You can use transform_reduce without ever knowing what zip is, it will still solve your problem -using this other range(vector) to transform this result/this one. Thinking of it as a zip is intuitive, but in the wrong way...

  • @phonlolol5153
    @phonlolol5153 5 лет назад +1

    At 1:22:38: He "invents" adjacent_inclusive_scan, doing some writeup and comes to the conclusion, that this algorithm is already in the std library under the name transform_inclusive_scan. I took several looks but i think this is wrong? transform_inclusive_scan takes "just" an unary operation for its transform part. In the "invented" adjacent_inclusive_scan we are using a binary operation for the transform part. Am i missing something? Great presentation tho!

    • @code_report
      @code_report 5 лет назад +3

      Wow, amazing catch. That is absolutely correct. That is definitely an oversight. transform_inclusive_scan definitely doesn't look at 2 indexes.

  • @ChandraShekhar-by3cd
    @ChandraShekhar-by3cd 5 лет назад +2

    Great Video!

  • @xor2003
    @xor2003 4 года назад

    Wow, it is like Mendeleev chemical elements table for algorithms. As far as I could understand. All is visible

  • @nathanesau1
    @nathanesau1 5 лет назад +1

    Excellent talk. That BlackMirror clip seems familiar :)

  • @SS-kg8rj
    @SS-kg8rj 3 года назад

    I do not see how the algorithm'ized versions are better than for loops, for the most part.

  • @BlackBeltMonkeySong
    @BlackBeltMonkeySong 5 лет назад +3

    "inner product" is the perfect name for the function. Look up "dot product" on wikipedia. And then "Hilbert space". Inner product is fundamentally the correct name.

  • @aniliitb10
    @aniliitb10 5 лет назад

    Where can we get the slides? Couldn't find it on cppnow.org!

    • @code_report
      @code_report 5 лет назад +2

      It doesn't look like they have uploaded them yet. I will try to post them to github later today.

    • @code_report
      @code_report 5 лет назад +4

      I have uploaded them to my github: github.com/codereport/Talks/blob/master/2019-05-CppNow/AlgorithmIntuition/AlgorithmIntuition%20-%20FINAL.pdf

  • @KobiCohenArazi
    @KobiCohenArazi 5 лет назад

    Would using reduce for any_of impl short circuit it? think this: stackoverflow.com/questions/47692180/is-stdany-of-required-to-follow-short-circuit-logic . thanks.

    • @code_report
      @code_report 5 лет назад

      Using reduce or accumulate for the impl would not. But the actual implementation of any_of definitely does short circuit.

  • @fburton8
    @fburton8 5 лет назад +5

    Interesting talk, but my goodness isn't C++ messy/irregular!

    • @manosriram
      @manosriram 5 лет назад

      But, Its blazingly Fast !

  • @dominikg544
    @dominikg544 5 лет назад

    he is a rebel:)

  • @yokozombie
    @yokozombie 5 лет назад +8

    hopefully, east const was a trolling

  • @micaevski
    @micaevski 5 лет назад +4

    FYI Conor, Simon Brand uses they/them pronouns not he/him. Great Talk!

    • @code_report
      @code_report 5 лет назад +7

      Thank you Michael! I realized this after the fact (I should have checked their Twitter bio as it is listed there), and I feel really bad about it. In my upcoming September CppCon talk I will make sure not to make the same mistake, and hopefully I will meet them in person and be able to apologize (probably Simon hasn't seen the talk though - but in case they ever do).