Yo de primeras lo haría así:
f <- function(x) return(x^2)
recursiva <- function(x, fun, k) {
if (k > 1) return(fun(recursiva(x, fun, k-1))) else return(fun(x))
}
> recursiva(2,f,1)
[1] 4
> recursiva(2,f,2)
[1] 16
> recursiva(2,f,3)
[1] 256
> f(f(f(2)))
[1] 256
Un saludo,
Rubén FC
El 12/05/2016 a las 10:29, Carlos Ortega escribió:
Hola Jorge,
Creo que la función que buscas está del lado de las varias implementaciones
que tiene "R" del lado de la "Programación Funcional".
En particular miraría la función "Reduce()".
Y también la función "accumulate()" del paquete de Hadley Wickham "purr"
(Functional Programming Tools).
Saludos,
Carlos Ortega
www.qualityexcellence.es
El 12 de mayo de 2016, 5:39, Jorge I Velez <jorgeivanve...@gmail.com>
escribió:
Hola a todos,
Quisiera aplicar una función f(x) un total de k veces de manera recursiva.
En pseudo código sería algo como
Si k = 1, calcular f(x);
Si k = 2, calcular f(f(x));
Si k = 3, calcular f(f(f(x))).
Al final me gustaria tener una función g cuyos argumentos sean x y el valor
de k. Así,
g(x, k = 2)
daría como resultado f(f(x)).
Cualquier ayuda y/o sugerencia será más que bienvenida.
Muchísimas gracias,
Jorge Velez.-
[[alternative HTML version deleted]]
_______________________________________________
R-help-es mailing list
R-help-es@r-project.org
https://stat.ethz.ch/mailman/listinfo/r-help-es
_______________________________________________
R-help-es mailing list
R-help-es@r-project.org
https://stat.ethz.ch/mailman/listinfo/r-help-es