• ú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í
    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