• úvod
  • témata
  • události
  • tržiště
  • diskuze
  • nástěnka
  • přihlásit
    registrace
    ztracené heslo?
    LUDWIG_Funkcionální programování (Haskell, LISP, XQuery, OCaml, F#, Scala, ...) - praxe, teorie a uplatnění

    Clojure's core typed vs Haskell

    8 hlasy od 8 respondentů
      A monad is just a monoid in the category of endofunctors, what's the problem? http://vimeo.com/38223410



      All programming languages evolve towards Lisp.

      Haskell is faster than C++, more concise than Perl, more regular than Python, more flexible than Ruby, more typeful than C#, more robust than Java, and has absolutely nothing in common with PHP. — Autrijus Tang

      There may, indeed, be other applications of the [lambda calculus] than its use as a logic. — Alonzo Church, 1932
      rozbalit záhlaví
      LISKNI_SI
      LISKNI_SI --- ---
      IRAVEN: To fakt obecně nejde, protože taková funkce není vyčíslitelná. Představ si, že ta vstupní "množina" jsou právě všechny dvojice turingův stroj a jeho akceptující běh (tj. ta fce A → bool ověřuje, zda je to korektní zadání a zda to je skutečně akceptující běh toho stroje) a že ta transformace z toho vymaže ten běh (tj. tu dvojici transformuje jenom na to zadání turingova stroje). Tohle obojí jsou vyčíslitelné funkce, ale výsledkem té funkce by měla být množina všech turingových strojů, které zastaví. A ta rozhodně vyčíslitelná není.
      IRAVEN
      IRAVEN --- ---
      Upřesním :). Mám definovaný datový typ "množina", který je daný pouze jako funkce A -> bool, která říká TRUE právě když prvek A do množiny patří. Potom mám funkci A -> A, která mi převádí prvky na jiné prvky, například násobí dvěma. No a cílem je napsat funkci, která vrací "množinu" (čili funkci A -> bool) která obsahuje prvky ze zadaná množiny transformované zadanou funkcí (je to funkce vyššího řádu).

      Bavil jsem se o tom s kamarádem a došli jsme k tomu, že to zřejmě nejde bez nějaké iterace nad množinou (je potřeba cosi jako "exists").
      KAMAHL
      KAMAHL --- ---
      IRAVEN: Moc nechápu zadání, nemohl bys dát příklady vstupu a požadovaného výstupu?
      LUDWIG_
      LUDWIG_ --- ---
      IRAVEN: "zda A do mnoziny patri" = typ A patri do mnoziny ruznych typu, nebo parametr :: A patri do mnoziny hodnot typu A?
      LISKNI_SI
      LISKNI_SI --- ---
      IRAVEN: Jakože (. filter) . (.) . map? (Má to ty parametry opačně.)
      IRAVEN
      IRAVEN --- ---
      jak byste napsali funkci map, ktera ma na vstupu tyto parametry: funkce A -> bool ktera rika, zda A do mnoziny patri, a A -> B pro transformaci? a jde to vubec? mne prijde, ze bez inverzu B -> A ne...
      LITTLELI
      LITTLELI --- ---
      LUDWIG_: jak už jsem tu psal, tohle typový peklo mi přijde naprosto nadbytečný
      LUDWIG_
      LUDWIG_ --- ---
      LITTLELI: proc?
      LITTLELI
      LITTLELI --- ---
      LUDWIG_: tohle je děsivý :)
      LUDWIG_
      LUDWIG_ --- ---
      Functional Programming is Terrible
      https://www.youtube.com/watch?v=hzf3hTUKk8U
      GARFIELD
      GARFIELD --- ---
      IRAVEN: Dik za info, ale ted uz jsem mimo CR
      IRAVEN
      IRAVEN --- ---
      GARFIELD: myslim, ze v et netera hledaji scalisty
      KAMAHL
      KAMAHL --- ---
      Kdyby to někoho zajímalo, bylo mi na Coq doporučeno http://www.cis.upenn.edu/~bcpierce/sf/ a http://adam.chlipala.net/cpdt/ ale ještě jsem se do toho pořádně nedíval, nechám si to tu jako poznámku pro sebe :D
      LUDWIG_
      LUDWIG_ --- ---
      KAMAHL: pokud ciste "dependent types", tak Agda ci Idris bude asi lepsi volba: [ LUDWIG_ @ Funkcionální programování (Haskell, LISP, XQuery, OCaml, F#, Scala, ...) - praxe, teorie a uplatnění ]

      Idris je prakticky programovaci jazyk, zatimco Coq a Agda jsou spis pomocny software pro matematicke dukazy :)
      Jinak tady je kdyztak nova prednaska o Idrisu:
      Edwin Brady - Idris: Programming with Dependent Types
      http://vimeo.com/83665028
      KAMAHL
      KAMAHL --- ---
      Inspiroval mě tenhle článek http://blog.ezyang.com/2014/03/haskell-for-coq-programmers/ ale chtěl bych to naopak :D
      KAMAHL
      KAMAHL --- ---
      Tak primárně by mě v tuhle chvíli zajímalo vyzkoušet si něco s "dependent types" (má to už ustálený český ekvivalent?) Na konkrétním jazyku vlastně až tak nezáleží.
      Víte o nějaké srozumitelně zpracované teorii přímo k tomuhle tématu? Tak nějak si to představuju, že type checking bude něco jako inference v prologu, ale to to je asi dost naivní, nebo ne?
      LUDWIG_
      LUDWIG_ --- ---
      KAMAHL: ja zkousim zacit Agdou, ktera je takova haskellovitejsi, a pak jit na to jednoduchyma dukazama v Coqu... nevim, jestli je to nejlepsi postup, jak se naucit Coq - takze mam stejny dotaz :)
      KAMAHL
      KAMAHL --- ---
      Nějaké tipy, kde začít, když se chci naučit Coq? A jakou teorii bych si před tím eventuálně měl nastudovat. Řekněme, že v se cítím docela sebevědomě v základech jazyků jako haskell nebo prolog, ale už ne v jejich pokročilejších aspektech.
      LUDWIG_
      LUDWIG_ --- ---
      WILD_A: "z toho co jsem mel moznost cist" je zbytecne mnoho pesimismu z tech novych Phillipsovo prednasek :)
      LUDWIG_
      LUDWIG_ --- ---
      jinak tady jsou ty alternativni kolekce pro scalu:

      paulp/psp-view · GitHub
      https://github.com/paulp/psp-view
      Kliknutím sem můžete změnit nastavení reklam