hyper-abstracted R contest
Dec. 2nd, 2009 09:44 pm
## `*` is the hyper of `+`, `^` is the hyper of `*`
> hyper <- function(fn) function(a,b) Reduce(fn, rep(a,b))
> compose <- function(fn1,fn2) function(x) fn1(fn2(x))
> hyperoperation <- function(n) Reduce(compose,listRep(hyper,n))(`+`)
('rep(obj,n)' and 'listRep(obj,n)' just return a list containing 'obj' n times. I had to invent 'listRep' for technical reasons, namely passing closures to 'rep' returns an error: "object of type 'closure' is not subsettable")
## 'hyper' clearly works:
> multiplication <- hyper(`+`)
> multiplication(2,3)
[1] 6
> exponential <- hyper(hyper(`+`))
> exponential(2,3)
[1] 8
> tetration <- hyper(hyper(hyper(`+`)))
> tetration(2,3) ##2^(2^2)
[1] 16
'compose' also works:
> compose(function(x) x^2, function(x) x+1)(4)
[1] 25
and so does 'hyperoperation', woohoo!
> hyperoperation(1)(2,3)
[1] 6
until R decided to be lame:
> hyperoperation(2)(2,3)
Error: evaluation nested too deeply: infinite recursion / options(expressions=)?
>
But I was impressed that I got this far with R! I suspect I could get further if I learn to use defmacro.
inspi#FF0000 by Scott Aaronson's essay, "Who Can Name the Bigger Number?"
(no subject)
Date: 2009-12-03 03:34 pm (UTC)P.S. that essay is great!
(no subject)
Date: 2009-12-03 08:28 pm (UTC)Have you seen the Gödel CAPTCHA: http://www.scottaaronson.com/writings/captcha.html
(no subject)
Date: 2009-12-04 02:11 am (UTC)> fact <- function(n) ifelse(n==1,1,n*fact(n-1))
> fact(7)
[1] 5040
I honestly don't know why it breaks down here.
(no subject)
Date: 2009-12-04 06:04 am (UTC)(no subject)
Date: 2009-12-04 08:22 am (UTC)fact(7) goes to depth 7.
hyperoperation(2) doesn't go that deep.
(no subject)
Date: 2009-12-05 01:12 am (UTC)(no subject)
Date: 2009-12-05 03:03 am (UTC)(no subject)
Date: 2009-12-05 05:22 am (UTC)(no subject)
Date: 2009-12-05 11:36 am (UTC)(no subject)
Date: 2009-12-05 11:41 am (UTC)> tetration <- hyper(hyper(hyper(`+`)))
> tetration(3,3) ##3^(3^3)
Error: cannot allocate vector of size 492.6 Mb
(this came back after a long time running)
however,
tetration(2,3) ##2^(2^2)works fast, no problem.
(btw, I have fixed the code to use foldr)
(no subject)
Date: 2009-12-04 08:26 am (UTC)hyper <- function(fn) function(a,b) Reduce(fn, rep(a,b), right=TRUE)
foldr, not foldl.
(no subject)
Date: 2009-12-05 04:51 am (UTC)(no subject)
Date: 2009-12-05 04:55 am (UTC)(no subject)
Date: 2009-12-05 11:41 am (UTC)