Jump to content

Talk:SKI combinator calculus: Difference between revisions

Page contents not supported in other languages.
From Wikipedia, the free encyclopedia
Content deleted Content added
mNo edit summary
mNo edit summary
Line 15: Line 15:
:On the iota page, translations for S, K and I to i are given. Performing these, we get
:On the iota page, translations for S, K and I to i are given. Performing these, we get
::<math> i = ***i*i*i*ii*ii***i*i*i*ii**i*i*ii*i*i*i*ii**i*i*ii*i*i*ii </math>
::<math> i = ***i*i*i*ii*ii***i*i*i*ii**i*i*ii*i*i*i*ii**i*i*ii*i*i*ii </math>
:I haven't checked this. There are other one combinator bases that give shorter translations for S and K. Two of these are <math>\lambda f.f\mathbf{S}(\lambda xyz.x)</math> and <math>\lambda f.f\mathbf{I(K(K(KS)))(KK)}</math>
:I haven't checked this to be correct. There are other one combinator bases that give shorter translations for S and K. Two of these are <math>\lambda f.f\mathbf{S}(\lambda xyz.x)</math> and <math>\lambda f.f\mathbf{I(K(K(KS)))(KK)}</math>
--[[User:Bsmntbombdood|Bsmntbombdood]] 05:40, 17 February 2007 (UTC)
--[[User:Bsmntbombdood|Bsmntbombdood]] 05:40, 17 February 2007 (UTC)
== Not ==
== Not ==

Revision as of 05:56, 17 February 2007

In fact, it is possible to define a complete system using only one combinator. An example is Chris Barker's iota combinator, defined as follows:

I find this unconvincing - is defined in terms of S and K, which means the system needs three combinators. If you could define i in terms of itself only, then I'd be convinced. I doubt this is possible, but I would be pleased if someone could prove me wrong! The iota language in the link uses S and K internally, it's just in the syntax that it is forbidden.

So I think this might mislead readers into thinking that single combinator systems are possible. Can anyone provide a more compelling example or clarify somehow?

Edwin 20:17, 14 May 2006 (UTC)[reply]

JA: The statement above is just the usual reduction of I to S and K, which gets it down to two. The reduction to one is rather artificial, but does it in terms of a combinator J. You can find that discussed in van Heijenoort's anthology. Jon Awbrey 20:40, 14 May 2006 (UTC)[reply]

Of course you can define in terms of .
By abstraction elimination,
On the iota page, translations for S, K and I to i are given. Performing these, we get
I haven't checked this to be correct. There are other one combinator bases that give shorter translations for S and K. Two of these are and

--Bsmntbombdood 05:40, 17 February 2007 (UTC)[reply]

Not

I'm probably missing something, but i'm confused by the postfix NOT in the article. it says "(T) NOT = T(F)(T) = F", but NOT is a unary function that applies its (binary function) argument to T and F, and T is a binary function that returns its first argument, so what we really want to do is apply NOT to T. Am I getting confused by the notation? Example in ML:

fun T x y = x;
fun F x y = y;
fun NOT x = x F T;

(NOT T) 1 2 -> 2 (it returned the second argument, so it's F)

Moe Aboulkheir 07:21, 18 August 2006 (UTC)[reply]

NOT is not really a unary function the way it's defined in the article, it's just a pair of arguments supplied to the function that appears to its left. For example, "T NOT" = "T F T" = "F" because "T x y = x". I don't really understand what you're asking. Jon Purdy 07:22, 27 September 2006 (EDT)