Комбинаторная логика: различия между версиями

Материал из Википедии — свободной энциклопедии
Перейти к навигации Перейти к поиску
[непроверенная версия][непроверенная версия]
Содержимое удалено Содержимое добавлено
м Литература: викификация
м типографика
Строка 1: Строка 1:
'''Комбина́торная ло́гика''' — раздел [[дискретная математика|дискретной математики]], который тесно связан с [[лямбда-исчисление|λ-исчислением]], т. к. описывает вычислительные процессы.
'''Комбина́торная ло́гика''' — раздел [[дискретная математика|дискретной математики]], который тесно связан с [[лямбда-исчисление|λ-исчислением]], т. к. описывает вычислительные процессы.


С момента своего возникновения комбинаторная логика и лямбда-исчисление были отнесены к ''неклассическим логикам''. Дело заключается в том, что комбинаторная логика возникла в 1920-х
С момента своего возникновения комбинаторная логика и лямбда-исчисление были отнесены к ''неклассическим логикам''. Дело заключается в том, что комбинаторная логика возникла в 1920-х годах, а лямбда-исчисление — в 1940-х годах как ветвь метаматематики с достаточно очерченным предназначением — дать основания математике. Это означает, что сконструировав требуемую «прикладную» математическую теорию — предметную теорию, — которая отражает процессы или явления в реальной внешней среде, можно воспользоваться «чистой» метатеорией как оболочкой для выяснения возможностей и свойств предметной теории.
годах, а лямбда-исчисление — в 1940-х годах как ветвь метаматематики с достаточно очерченным предназначением - дать основания математике. Это означает, что сконструировав требуемую «прикладную» математическую теорию - предметную теорию, - которая отражает процессы или явления в реальной внешней среде, можно воспользоваться «чистой» метатеорией как оболочкой для выяснения возможностей и свойств предметной теории.


Комбинаторная логика и лямбда-исчисление -- это такие формальные системы, в которых центральной разрабатываемой сущностью является представление об объекте. В первой из них -- комбинаторной логике,
Комбинаторная логика и лямбда-исчисление это такие формальные системы, в которых центральной разрабатываемой сущностью является представление об объекте. В первой из них комбинаторной логике, — механизм связывания переменных в явном виде отсутствует, а во второй он имеется. Наличие явного механизма связывания предполагает и наличие связанных переменных, но тогда есть и свободные переменные, а также механизмы замещения формальных параметров — связанных переменных, — на фактические параметры, то есть ''подстановка''.
-- механизм связывания переменных в явном виде отсутствует, а во второй он имеется. Наличие явного механизма связывания предполагает и наличие связанных переменных, но тогда есть и свободные переменные, а также механизмы замещения формальных параметров -- связанных переменных, -- на фактические параметры, то есть ''подстановка''.


Изначальным назначением комбинаторной логики был именно анализ ''процесса подстановки''. В качестве ее сущностей планировалось использовать объекты в виде ''комбинаций констант''. Лямбда-исчислению отводилась роль средства уточнения представлений об ''алгоритме'' и ''вычислимости''. Как следствие,
Изначальным назначением комбинаторной логики был именно анализ ''процесса подстановки''. В качестве ее сущностей планировалось использовать объекты в виде ''комбинаций констант''. Лямбда-исчислению отводилась роль средства уточнения представлений об ''алгоритме'' и ''вычислимости''. Как следствие, комбинаторная логика дает в руки инструмент для анализа процесса подстановки. Через короткий промежуток времени оказалось, что обе эти системы можно рассматривать как [[языки программирования]].
комбинаторная логика дает в руки инструмент для анализа процесса подстановки. Через короткий промежуток времени оказалось, что обе эти системы можно рассматривать как [[языки программирования]].


В обеих системах исчисляются объекты, они являются исчислениями или языками ''высших порядков'', то есть имеются средства описания отображений или операторов, которые определяются на отображениях или операторах, а в качестве результата вырабатывают также отображения или операторы. Самое существенное, что именно ''отображение'' считается объектом. В этом их принципиальное отличие от всего многообразия других систем, в которых первичной сущностью обычно считают представление о ''множестве'' и его элементах.
В обеих системах исчисляются объекты, они являются исчислениями или языками ''высших порядков'', то есть имеются средства описания отображений или операторов, которые определяются на отображениях или операторах, а в качестве результата вырабатывают также отображения или операторы. Самое существенное, что именно ''отображение'' считается объектом. В этом их принципиальное отличие от всего многообразия других систем, в которых первичной сущностью обычно считают представление о ''множестве'' и его элементах.


К настоящему времени оба эти языка не только стали основой для всей массы исследований в области компьютерных наук и компьютинга, но и широко используются в теории программирования. Развитие вычислительной мощности компьютеров привело к автоматизации значительной части теоретического -- логического и математического, -- знания, а комбинаторная логика вместе с ламбда-исчислением признаются основой для рассуждений в терминах объектов.
К настоящему времени оба эти языка не только стали основой для всей массы исследований в области компьютерных наук и компьютинга, но и широко используются в теории программирования. Развитие вычислительной мощности компьютеров привело к автоматизации значительной части теоретического логического и математического, знания, а комбинаторная логика вместе с лямбда-исчислением признаются основой для рассуждений в терминах объектов.


== Категориальная комбинаторная логика ==
== Категориальная комбинаторная логика ==
В рамках комбинаторной логики строится специальный вариант теории вычислений, называемый
В рамках комбинаторной логики строится специальный вариант теории вычислений, называемый
[[категориальная абстрактная машина|категориальной абстрактной машиной]]. Для этого вводится в
[[категориальная абстрактная машина|категориальной абстрактной машиной]]. Для этого вводится в
рассмотрение особый фрагмент комбинаторной логики -- категориальная комбинаторная логика<ref>''Curien P.-L.'' Categorical combinatory logic. -- LNCS, 194, 1985, pp.~139-151.</ref>. Она представлена набором комбинаторов, каждый из которых имеет самостоятельное значение как инструкция системы программирования. Тем самым в комбинаторную логику встраивается еще одно полезное приложение -- система программирования, основанная на [[декартово-замкнутая категория| декартово замкнутой категории]] (д.з.к.). Это позволяет еще раз на новом уровне переосмыслить связь операторного
рассмотрение особый фрагмент комбинаторной логики категориальная комбинаторная логика<ref>''Curien P.-L.'' Categorical combinatory logic. LNCS, 194, 1985, pp.~139-151.</ref>. Она представлена набором комбинаторов, каждый из которых имеет самостоятельное значение как инструкция системы программирования. Тем самым в комбинаторную логику встраивается еще одно полезное приложение система программирования, основанная на [[декартово-замкнутая категория| декартово замкнутой категории]] (д.з.к.). Это позволяет еще раз на новом уровне переосмыслить связь операторного и аппликативного стиля программирования.
и аппликативного стиля программирования.


== Иллативная комбинаторная логика ==
== Иллативная комбинаторная логика ==
Пользуясь представлениями об объектах как абстрактных математических сущностях, обладающих определенными подстановочными свойствами, можно строить системы ''логических рассуждений''. Наиболее известная среди таких систем основана на комбинаторах.
Пользуясь представлениями об объектах как абстрактных математических сущностях, обладающих определенными подстановочными свойствами, можно строить системы ''логических рассуждений''. Наиболее известная среди таких систем основана на комбинаторах.


[[Логика]], основанная на комбинаторах, или ''иллативная комбинаторная логика'', строится из теории комбинаторов или лямбда-исчисления, расширенного дополнительными константами -- ''экстра-константами'', -- вместе с соответствующими аксиомами и правилами вывода, которые обеспечивают средства дедуктивного вывода.
[[Логика]], основанная на комбинаторах, или ''иллативная комбинаторная логика'', строится из теории комбинаторов или лямбда-исчисления, расширенного дополнительными константами ''экстра-константами'', вместе с соответствующими аксиомами и правилами вывода, которые обеспечивают средства дедуктивного вывода.


== Исторические комментарии ==
== Исторические комментарии ==
В 1920 году комбинаторы как специальные математические сущности<ref>''Cardone F., Hindley J.R.'' [http://www-maths.swan.ac.uk/staff/jrh/papers/JRHHislamWeb.pdf History of lambda calculus and combinators], in Handbook of the History of Logic, Volume 5, D M Gabbay and J Woods (eds) (Amsterdam: Elsevier Co., to appear). </ref> первоначально были установлены [[Шёнфинкель, Мозес| М. Шейнфинкелем]] (M. Schonfinkel)<ref>''Schonfinkel M.'' Uber die Baustein der mathematischen Logik. -- Math. Annalen, vol. 92, 1924, pp.~305-316. </ref>. Несколькими годами позже они независимо были переоткрыты [[Хаскелл Карри| Х.Карри]]<ref>''Curry H.B.'' Grundlagen der kombinatorischen Logik. American Journal of Mathematics, 52:509–536, 789–834, 1930.</ref>, благодаря которому с тех пор были выполнены основные продвижения в комбинаторной логике (хотя другие исследователи, например, Россер,
В 1920 году комбинаторы как специальные математические сущности<ref>''Cardone F., Hindley J.R.'' [http://www-maths.swan.ac.uk/staff/jrh/papers/JRHHislamWeb.pdf History of lambda calculus and combinators], in Handbook of the History of Logic, Volume 5, D M Gabbay and J Woods (eds) (Amsterdam: Elsevier Co., to appear). </ref> первоначально были установлены [[Шёнфинкель, Мозес| М. Шейнфинкелем]] (M. Schonfinkel)<ref>''Schonfinkel M.'' Uber die Baustein der mathematischen Logik. Math. Annalen, vol. 92, 1924, pp.~305-316. </ref>. Несколькими годами позже они независимо были переоткрыты [[Хаскелл Карри| Х.Карри]]<ref>''Curry H.B.'' Grundlagen der kombinatorischen Logik. American Journal of Mathematics, 52:509–536, 789–834, 1930.</ref>, благодаря которому с тех пор были выполнены основные продвижения в комбинаторной логике (хотя другие исследователи, например, Россер, в различное время также участвовали в этой работе). Почти в то же самое время Черчем, Россером и Клини было начато развитие <math>\lambda</math>-конверсии. С 1970-х гг. комбинаторы использовались в
в различное время также участвовали в этой работе). Почти в то же самое время Черчем, Россером и Клини было начато развитие <math>\lambda</math>-конверсии. С 1970-х гг. комбинаторы использовались в
трех главных аспектах: во-первых, для построения [[логика| логических систем]], основанных на абстрактной записи операции; во-вторых, в [[теория доказательств |теории доказательств]] как основа записи конструктивных функций различного вида; в-третьих, при построении и анализе некоторых [[языки программирования| языков программирования]] в [[компьютерные науки| компьютерных науках]].
трех главных аспектах: во-первых, для построения [[логика| логических систем]], основанных на абстрактной записи операции; во-вторых, в [[теория доказательств |теории доказательств]] как основа записи конструктивных функций различного вида; в-третьих, при построении и анализе некоторых [[языки программирования| языков программирования]] в [[компьютерные науки| компьютерных науках]].



Версия от 09:21, 22 апреля 2008

Комбина́торная ло́гика — раздел дискретной математики, который тесно связан с λ-исчислением, т. к. описывает вычислительные процессы.

С момента своего возникновения комбинаторная логика и лямбда-исчисление были отнесены к неклассическим логикам. Дело заключается в том, что комбинаторная логика возникла в 1920-х годах, а лямбда-исчисление — в 1940-х годах как ветвь метаматематики с достаточно очерченным предназначением — дать основания математике. Это означает, что сконструировав требуемую «прикладную» математическую теорию — предметную теорию, — которая отражает процессы или явления в реальной внешней среде, можно воспользоваться «чистой» метатеорией как оболочкой для выяснения возможностей и свойств предметной теории.

Комбинаторная логика и лямбда-исчисление — это такие формальные системы, в которых центральной разрабатываемой сущностью является представление об объекте. В первой из них — комбинаторной логике, — механизм связывания переменных в явном виде отсутствует, а во второй он имеется. Наличие явного механизма связывания предполагает и наличие связанных переменных, но тогда есть и свободные переменные, а также механизмы замещения формальных параметров — связанных переменных, — на фактические параметры, то есть подстановка.

Изначальным назначением комбинаторной логики был именно анализ процесса подстановки. В качестве ее сущностей планировалось использовать объекты в виде комбинаций констант. Лямбда-исчислению отводилась роль средства уточнения представлений об алгоритме и вычислимости. Как следствие, комбинаторная логика дает в руки инструмент для анализа процесса подстановки. Через короткий промежуток времени оказалось, что обе эти системы можно рассматривать как языки программирования.

В обеих системах исчисляются объекты, они являются исчислениями или языками высших порядков, то есть имеются средства описания отображений или операторов, которые определяются на отображениях или операторах, а в качестве результата вырабатывают также отображения или операторы. Самое существенное, что именно отображение считается объектом. В этом их принципиальное отличие от всего многообразия других систем, в которых первичной сущностью обычно считают представление о множестве и его элементах.

К настоящему времени оба эти языка не только стали основой для всей массы исследований в области компьютерных наук и компьютинга, но и широко используются в теории программирования. Развитие вычислительной мощности компьютеров привело к автоматизации значительной части теоретического — логического и математического, — знания, а комбинаторная логика вместе с лямбда-исчислением признаются основой для рассуждений в терминах объектов.

Категориальная комбинаторная логика

В рамках комбинаторной логики строится специальный вариант теории вычислений, называемый категориальной абстрактной машиной. Для этого вводится в рассмотрение особый фрагмент комбинаторной логики — категориальная комбинаторная логика[1]. Она представлена набором комбинаторов, каждый из которых имеет самостоятельное значение как инструкция системы программирования. Тем самым в комбинаторную логику встраивается еще одно полезное приложение — система программирования, основанная на декартово замкнутой категории (д.з.к.). Это позволяет еще раз на новом уровне переосмыслить связь операторного и аппликативного стиля программирования.

Иллативная комбинаторная логика

Пользуясь представлениями об объектах как абстрактных математических сущностях, обладающих определенными подстановочными свойствами, можно строить системы логических рассуждений. Наиболее известная среди таких систем основана на комбинаторах.

Логика, основанная на комбинаторах, или иллативная комбинаторная логика, строится из теории комбинаторов или лямбда-исчисления, расширенного дополнительными константами — экстра-константами, — вместе с соответствующими аксиомами и правилами вывода, которые обеспечивают средства дедуктивного вывода.

Исторические комментарии

В 1920 году комбинаторы как специальные математические сущности[2] первоначально были установлены М. Шейнфинкелем (M. Schonfinkel)[3]. Несколькими годами позже они независимо были переоткрыты Х.Карри[4], благодаря которому с тех пор были выполнены основные продвижения в комбинаторной логике (хотя другие исследователи, например, Россер, в различное время также участвовали в этой работе). Почти в то же самое время Черчем, Россером и Клини было начато развитие -конверсии. С 1970-х гг. комбинаторы использовались в трех главных аспектах: во-первых, для построения логических систем, основанных на абстрактной записи операции; во-вторых, в теории доказательств как основа записи конструктивных функций различного вида; в-третьих, при построении и анализе некоторых языков программирования в компьютерных науках.

Примечания

  1. Curien P.-L. Categorical combinatory logic. — LNCS, 194, 1985, pp.~139-151.
  2. Cardone F., Hindley J.R. History of lambda calculus and combinators, in Handbook of the History of Logic, Volume 5, D M Gabbay and J Woods (eds) (Amsterdam: Elsevier Co., to appear).
  3. Schonfinkel M. Uber die Baustein der mathematischen Logik. — Math. Annalen, vol. 92, 1924, pp.~305-316.
  4. Curry H.B. Grundlagen der kombinatorischen Logik. American Journal of Mathematics, 52:509–536, 789–834, 1930.

Литература

  • Вольфенгаген В.Э. Комбинаторная логика в программировании. Вычисления с объектами в примерах и задачах. -- М.: МИФИ, 1994. – 204 с.; 2-е изд., М.: АО "Центр ЮрИнфоР", 2003. – 336 с. ISBN 5-89158-101-9.