library(ggplot2) library(gganimate) linscale.initpopulation <- function(n) { return(runif(10)) } linscale.scale <- function(population, a, b) { return(a * population + b) } linscale.relfitness <- function(population) { return(population / sum(population)) } linscale.tracegens <- function(popul, a, b, n) { lenpopul <- length(popul) df <- data.frame( generation = 0 ,individual = 1:lenpopul ,fitness = popul ,relfitness = linscale.relfitness(popul) ) for(i in 1:n) { popul <- linscale.scale(popul, a, b) df <- rbind(df, data.frame( generation = i ,individual = 1:lenpopul ,fitness = popul ,relfitness = linscale.relfitness(popul))) } return(df) } linscale.experiment <- function(avals, bvals, n) { df <- data.frame( generation = integer() ,individual = integer() ,fitness = double() ,relfitness = double() ,a = double() ,b = double()) initpopul <- linscale.initpopulation(10) for(a in avals) { for(b in bvals) { dftmp <- linscale.tracegens(initpopul, a, b, n) dftmp["a"] <- a dftmp["b"] <- b df <- rbind(df, dftmp) } } return(df) } linscale.plot <- function(df) { pdf(file="linscale.pdf", onefile=TRUE) for(g in unique(df$generation)) { p <- ggplot(data=df[df$generation == g, ]) + geom_col(aes(x=individual, y=relfitness)) + facet_grid(b ~ a, labeller = label_both) + labs(title=sprintf("generation: %i", g)) print(p) } dev.off() } linscale.animate <- function(df) { anim <- ggplot(data=df) + geom_col(aes(x=individual, y=relfitness)) + facet_grid(b ~ a, labeller = label_both) + labs(title="generation: {closest_state}") + transition_states(generation) anim_save("linescale.gif", animation=anim) }