Andy Melnikov (nponeccop) wrote,
Andy Melnikov
nponeccop

Нетипизируемые корректные выражения (загадка)

Вот примеры простых, имеющих смысл функций, которые отбраковываются Хаскелем как нарушающие типизацию:
x f = (f "2", f True)
y f = f ["2"] + f [True]
Однако понятно, что есть выражения с этими функциями, которые имеют смысл. Например,
x id == ("2", True), 
x (const 5) == (5, 5)

y length = 2
y (const 5) = 10
Каково в точности множества функций, которые можно передать в х? а в y? Есть ли системы типов, в которых подобные ограничения удается записать?
Subscribe

  • Post a new comment

    Error

    default userpic

    Your reply will be screened

    Your IP address will be recorded 

    When you submit the form an invisible reCAPTCHA check will be performed.
    You must follow the Privacy Policy and Google Terms of use.
  • 5 comments