Function Composition in Programming Languages - Conor Hoekstra - CppNorth 2023

Поділитися
Вставка
  • Опубліковано 28 сер 2024
  • www.cppnorth.ca​
    ---
    Function Composition in Programming Languages - Conor Hoekstra - CppNorth 2023
    Most people think of function composition as composing two unary functions together (the B combinator). However, this is only the tip of the proverbial "function composition" iceberg. This talk will be both an introduction and an overview of the world of combinatory logic and combinators. If you have ever wondered what the S, Phi, Psi, or B1 combinators are and why they are so useful, this is the talk for you. And even if you have never wondered that - I promise this talk will be worth your time. It will expand the limits of what you thought was possible with programming languages and give you the tools and knowledge to use combinators in your choice of programming language.
    ---
    Slides: github.com/Cpp...
    Sponsored By:
    think-cell: www.think-cell...
    JetBrains: www.jetbrains....
    ---
    Conor Hoekstra
    Conor (he/him) is a Research Scientist at NVIDIA working on array programming models and languages. He is extremely passionate about programming languages, algorithms and beautiful code. He is the founder and organizer of the Programming Languages Virtual Meetup, he has a UA-cam channel and is the host of two podcasts:
    ADSP: Algorithms + Data Structure = Programs
    ArrayCast
    Conor is also an avid conference speaker. You can find all of Conor's conference talks and podcast appearances (on other podcasts) here github.com/cod...
    ---
    CppNorth is an annual C++ conference held in Toronto, Canada.
    - Annual CppNorth C++ conference: cppnorth.ca/
    - CppNorth Twitter: / cppnorth
    ---
    UA-cam Videos Edited & Optimised by Digital Medium: events.digital...
    #cppnorth #cpp #programminglanguages

КОМЕНТАРІ • 20

  • @aMulliganStew
    @aMulliganStew 4 місяці тому +2

    With all humility, not wishing to imply that I have his greatness (or indeed anything more than glints of occasional competence)... Late in his career, Neil Peart took drum lessons -- in jazz. So it might also be for me, coming from a procedural/object-based background (heavy on the former), as I take the plunge into functional /combinatorial. I find it all very intriguing. Thanks to Conor and everyone for the talks.

  • @c4tubo
    @c4tubo 10 місяців тому +7

    Although the subject matter by itself may not draw much interest, your enthusiasm for it certainly does.

  • @michaelteter
    @michaelteter 11 місяців тому +4

    Regarding the light/dark mode change and comment at 46:30, it's worth noting that presentations given in dark mode are generally less visible than those in light mode. In the live room, any ambient light can wash out the "dim" image. And for UA-cam viewers in bright environments (such as outside or by a window), the same is true. In contrast (no pun intended), light mode content can always be dimmed at the display device. So those late night viewers can just turn their screen brightness down. Unless you know your current and future audience will be in low light environments, Light Mode is the safe choice.

  • @vldthdrgn
    @vldthdrgn 6 місяців тому +1

    Amazing!

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

    great talk. thanks

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

    Futhark sample:
    let SumOfSquares a = map2 (\x i -> if length a % (i+1) == 0 then x*x else 0) a (indices a) |> reduce_comm (+) 0
    This isn't point free but does use three different combinators. |> could be replaced by reordering with parenthesis, but the map-reduce array combinators are the expected way to handle arrays. The filter was avoided using a neutral element, because realizing the filtered list could cause multiple heavier passes.

  • @Roibarkan
    @Roibarkan 11 місяців тому +1

    51:03 I think contemporary c++ devs can think or appreciate “point free” because it typically corresponds to composing chains of operations in the same manner that std::ranges::views can be composed using the pipe operator

  • @sanjaygatne1424
    @sanjaygatne1424 11 місяців тому +2

    Moses Schönfinkel birth date is 1888 not 1988.(typo)

  • @MrAbrazildo
    @MrAbrazildo 8 місяців тому

    12:00, *1888.
    15:34, what?! Do you know any other kind of software they are willing to pay millions?
    38:30, to map true/false keeping their positions/indexes. If that's not required, std::partition puts all trues at the beginning, returning a pointer to where they finish and to where the falses start. And std::stable_partition, despite obviously not keeping their indexes, keep their positions related to each other, at each group.
    56:00, auto sum_of_squares (std::vector nums) {return std::accumulate (nums.begin(), nums.end(), 0, [](auto x, auto i) {return !(nums.size() % i)*x*x;});}

  • @mestar12345
    @mestar12345 11 місяців тому +1

    Is map a combinator? Is bind a combinator?

  • @SuchirKavi
    @SuchirKavi 11 місяців тому

    18:58 Futhark should be an array language, no?

  • @ujin981
    @ujin981 11 місяців тому +2

    46:50 does readability count?

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

    8:40 they did not fix it in post

  • @thomasmeslin8399
    @thomasmeslin8399 9 місяців тому

    :o 🎉

  • @user-tx4wj7qk4t
    @user-tx4wj7qk4t 6 місяців тому

    The definition of pure function and distinction isn't really correct. A combinator is a pure function that is not a closure, that's it.

  • @user-tx4wj7qk4t
    @user-tx4wj7qk4t 6 місяців тому

    That fromEnum solution is absolutely awful and haskell does have a count function... Not like you couldn't have defined it yourself