Haskell Amuse-Bouche

แชร์
ฝัง
  • เผยแพร่เมื่อ 25 ก.ย. 2024
  • Google Tech Talk (more info below)
    October 14, 2011
    Presented by Mark Lentczner.
    ABSTRACT
    Want to know a little more about programming Haskell than just the buzz-words? This talk will show you some of the joys coding in Haskell through lots and lots of code examples.
    No prior experience with Haskell or functional programming required. Just be ready for some strange and wondrous code!
    Slides: www.ozonehouse....
    Code: github.com/mze... (tag v2 matches the video)

ความคิดเห็น • 48

  • @valdsonfrancisco8836
    @valdsonfrancisco8836 8 ปีที่แล้ว +9

    the runLengthEncoding can be written like this:
    import Data.List (group)
    import Control.Arrow ((&&&))
    encode :: (Eq a) => [a] -> [(Int, a)]
    encode = fmap (length &&& head) . group
    decode :: [(Int, a)] -> [a]
    decode = concatMap (uncurry replicate)
    Just one (two if you count the signature) line of code that does all that... when I saw this piece of code I became in love with this language.

  • @CliffStamp
    @CliffStamp 6 ปีที่แล้ว +6

    The idea of "of that is horrible we don't look at it" is the fundamental mistake almost anyone does when trying to teach Haskell. If you can't sort out those error messages, then learning Haskell is way harder as you essentially then have a language which only says "wrong" when you make a mistake with no additional info.

  • @shishkabobby
    @shishkabobby 12 ปีที่แล้ว

    This talk is useful in helping to understand Scala - similar ideas, different syntax

  • @EnderMuabDib
    @EnderMuabDib 13 ปีที่แล้ว +1

    I learned some Haskell last year and is one of the most amazings languages I've ever seen (like APL, but I've never been able to code a single line).
    It includes other wonderful things such as list comprehensions, where you define a list just writing the conditions that every element must satisfy to be include in it.
    y = [ x | con1, cond2, ... condN]
    For example, x is an element of list y if it's included in the list of intergers 1 to 50, and also x is odd:
    y = [ x | x

  • @karllopes
    @karllopes 4 ปีที่แล้ว

    I had the same feeling when I first started programming in Haskell - The language is beautiful.

  • @petros_adamopoulos
    @petros_adamopoulos 13 ปีที่แล้ว +1

    @Nolansan It knows what to keep and what to forget, it's magic. For example tail recursion is internally treated as a loop and just overwrites all the values on each iteration. It looks like a function that's calling itself forever but actually it uses a fixed amount of memory since it "knows" that all the intermediate values are not accessible from anywhere else.

  • @masterxilo
    @masterxilo 9 ปีที่แล้ว +12

    9:40 instead of spawning another generation of programmers that is told to find these error messages cryptic (which they are in some probably measurable, UI (user interface)-technical sense (we should start to realize that programming languages and compilers are software with hopefully *human usable* UIs just like anything else)), can't we just go to that compiler and output nice error messages?
    How much harder would it be to make it write the following:
    'byLines' was given 'indent' which is a 'String -> String' when it expected a '[String] -> [String]'
    indent : *String -> String*
    byLines: (*[String] -> [String]*) -> String -> String
    in expression
    byLines *indent*
    at line ...
    (for the conservativists/backwards compatibility, we can still add the message in the current format after that)
    (by the way, what's with the Char [Char] business in the error message generated?)

    • @CliffStamp
      @CliffStamp 6 ปีที่แล้ว

      Languages are generally wrote by very high end programmers who read those error messages trivially and forget at one point they were not high end programmers.

  • @can.slaughter
    @can.slaughter 7 ปีที่แล้ว +1

    best talk ever

  • @jinilover
    @jinilover 10 ปีที่แล้ว +2

    understand fp is cool, just curious that haskell has been invented for 24 years, has it always been popular? If just popular these few years, why?

    • @katawatenshu
      @katawatenshu 10 ปีที่แล้ว +6

      As multicored processors are now standard and core counts will only be increasing with time, and also as software grows more complex, functional languages are becoming more popular because they're easier to maintain and much easier to program concurrently with. Concurrency is doing multiple things at once to make use of more computer cores.

  • @cmatt85
    @cmatt85 13 ปีที่แล้ว

    @AshtonK1816 Thanks for the reply. I look forward to learning more about Haskell.

  • @voideric
    @voideric 11 ปีที่แล้ว

    In my first impression Haskell looked criptic and weird. But I told myself "me shall learn dat". After reading some I went "wow that's amazing I luv it!"
    Now I'm trying to understand Monads - I think I'm going nuts.

  • @lekremyelsew
    @lekremyelsew 12 ปีที่แล้ว

    The phrase "sounds like Lisp" makes me giggle.

  • @JobvanderZwan
    @JobvanderZwan 13 ปีที่แล้ว

    Impressive, this actually made me interested in Haskell! Could the questions be added as subtitles? Makes it easier to figure out what is actually being answered :)

  • @stvienna
    @stvienna 13 ปีที่แล้ว

    if you are fine with haskell, master the next step and use the coq programming language oder the agda programming language.

  • @sufficientlyoldskool
    @sufficientlyoldskool 12 ปีที่แล้ว +1

    Ugh, my head hurts. I think I'm gonna go take a nap.

  • @someman7
    @someman7 12 ปีที่แล้ว

    @noobyfromhell where did you learn it? i wish you'd say "an essay".

  • @narucy56
    @narucy56 10 ปีที่แล้ว

    We hope all the replace Android APIs and Web browser control APIs to Haskell optimized.

  • @heavensrevenge
    @heavensrevenge 13 ปีที่แล้ว

    Code samples=great, Functional=great, Haskell should be used a lot more inside ChromeOS and Chrome as a better way for the internals to be architected and strictly controlled. Great presentation since Haskell content is ALWAYS desired, enjoyed, and overly welcome to me and for use at Google itself.

  • @Nolansan
    @Nolansan 13 ปีที่แล้ว

    if there is no state change, after a program is running for a long time don't you just accumulate a ton of data and then run out of memory?

    • @TanmayPatil37
      @TanmayPatil37 7 ปีที่แล้ว +1

      Since there is no state change, you can share memory across multiple references without fear. Only changes require new memory, deep copy is unnecessary.

  • @Enaku
    @Enaku 12 ปีที่แล้ว

    Turns video on. Bleeds from eyes.

  • @bireswardas4920
    @bireswardas4920 12 ปีที่แล้ว

    23.20, ghc does not catch it at compile time.

  • @georgH
    @georgH 5 ปีที่แล้ว

    56:20 Now we can use Elm for web frontend in functional style :)

  • @thesaifmustafa
    @thesaifmustafa 11 ปีที่แล้ว

    I dont understand a thing! I want to learn a functional programming language but it seems so hard!

  • @TankdozerCavalry
    @TankdozerCavalry 11 ปีที่แล้ว

    Programming in Haskell isn't normal, but on math it is.

  • @marksaving756
    @marksaving756 6 ปีที่แล้ว

    It's funny watching a non-mathematician be awed by the concept of disjoint union.

  • @RossCourtright
    @RossCourtright 12 ปีที่แล้ว +1

    I Wanna learn me a haskell for great good

  • @Philbertsroom
    @Philbertsroom 11 ปีที่แล้ว +1

    in french it's actually amuse-gueule!

    • @kboite
      @kboite 4 ปีที่แล้ว

      Amuse-gueule is a bit colloquial. Les deux se disent ;)

  • @MartyGlaubitz
    @MartyGlaubitz 11 ปีที่แล้ว

    your profile pic matches your comment :D

  • @adrianmaulanamuhammad7225
    @adrianmaulanamuhammad7225 5 ปีที่แล้ว

    Why we do not use python instead? What makes haskell/clojure special?

  • @AshtonK1816
    @AshtonK1816 13 ปีที่แล้ว

    @cmatt85 I dunno. I work with Lisp professionally, and Lisp really lacks any of the guarantees that Haskell provides. Although Haskell is definitely derived from a lot of concepts created in Lisp, the resulting language is a different beast all together.

  • @6006133
    @6006133 13 ปีที่แล้ว

    This guy is win :D

  • @RogerKeulen
    @RogerKeulen 11 ปีที่แล้ว

    Hmmm, i can do that in Visual Basic.... i think.....

  • @cmatt85
    @cmatt85 13 ปีที่แล้ว

    So much of this sounds like lisp to me.

    • @TanmayPatil37
      @TanmayPatil37 7 ปีที่แล้ว

      Without explicit guarantees and speed that come from static strong typing

  • @voideric
    @voideric 11 ปีที่แล้ว

    Get a book, it's easier than you think (If you already can write programs). haskell.org/haskellwiki/Books

  • @jamesc313
    @jamesc313 10 ปีที่แล้ว

    haskell is popular? there is only one haskell job available throughout the whole country.

  • @JUICEPPL1
    @JUICEPPL1 11 ปีที่แล้ว

    I've been programming in Haskell for months now and I'm honestly disappointing in this talk. It's confusing even for me to follow.

  • @Ottow102
    @Ottow102 11 ปีที่แล้ว

    6 people think java is the best programming language....

  • @rpwarp
    @rpwarp 12 ปีที่แล้ว

    hahaha :D

  • @e10byagrue
    @e10byagrue 11 ปีที่แล้ว

    I am catching about half of what he is saying... I feel like he steamrolls over stuff far too quickly. This would work fine as an introduction, but none of the details or real explanations are there. Also, why is he laughing at the questions people ask?