169 похожих чатов

В Haskell есть функция (.) :: (b -> c) ->

(a -> b) -> a -> c. Есть такая вещь, как Curry-Howard correspondence, благодаря которой высказывания можно сопоставить типам, а импликацию следующему типу a -> b.

И импликация вида a => b читается так: если a, то b.

Можно ли таким образом "прочитать" функцию композиции?

Я понимаю, как можно было бы прочитать следующее f :: ((a -> b), (b -> c)) -> a -> c (если из a следует b и из b следует c, то из a следует c)

11 ответов

22 просмотра

так это же транзитивность импликации. если у нас есть способ из А вывести Б и из Б вывести Ц, то композиция даёт нам способ из А вывести Ц

ㅤ-Атеист Автор вопроса
Cheese Syrowiecki
так это же транзитивность импликации. если у нас е...

https://plfa.github.io/Connectives/ Вот здесь написано, что (a * b) -> c изоморфна a -> (b -> c) в силу закона (p ^ n) ^ m ≡ p ^ (n * m) (осталось лишь понять, почему этот закон работает, и как мы от закона переходим к изоморфизму)

нельзя сказать «в силу», потому что вы фактически одну формулу записали на разных языках. получилось «доброе утро в силу good morning»

ㅤ-Атеист Автор вопроса
Cheese Syrowiecki
нельзя сказать «в силу», потому что вы фактически ...

А, ну я просто пересказал, что написано в книге: > Corresponding to the law > (p * n) ^ m = (p ^ m) * (n ^ m) > we have the isomorphism: > A → B × C ≃ (A → B) × (A → C) Может, я неправильно пересказал

ㅤ Атеист
А, ну я просто пересказал, что написано в книге: >...

да, это соответствие Карри—Говарда, но это не доказательство

ㅤ Атеист
https://plfa.github.io/Connectives/ Вот здесь нап...

уточните, от чего к чему переход интересует

ㅤ-Атеист Автор вопроса
Cheese Syrowiecki
уточните, от чего к чему переход интересует

Почему справедливо ((a * b) → c) \iff (a →(b →c)) в логике?

ㅤ-Атеист Автор вопроса
ㅤ Атеист
Почему справедливо ((a * b) → c) \iff (a →(b →c)) ...

Наверное, через законы какие-то можно вывести. (~(a * b) + c) \iff (~a + (~b + c)) (~a + ~b + c) \iff (~a + ~b + c) ((a -> b) \iff (~a + b)) (~(a * b) \iff (~a + ~b))

ㅤ Атеист
А, ну я просто пересказал, что написано в книге: >...

может, тебе пооможет то, что в булевой алгебре кодируют P → Q как ¬P ∨ Q ?

ㅤ Атеист
Наверное, через законы какие-то можно вывести. (~...

во двоичной логике можно таблицей истинности доказать, а в интуиционистской без отрицания — непосредственно построением функций

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Ребят в СИ можно реализовать ООП?
Николай
33
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
у вас два процесса. один посылает другому сигнал. у вас есть код обоих процессов? если всё не так - расскажите как оно на самом деле. а именно кто кому чего, есть-ли консоли,...
Karagy
6
Карта сайта