I'm trying to develop script that will generate random 5x5 matrices (see code), display via ggplot2, and export the object placements via png()
. I have the foundations down, but where (I think) I'm running into problems is exporting the images
library(ggplot2)
library(grid)
### 5x5 Array ###
for(d1l in c(12, 9, 7)) {
for(i in 1:20) {
a5 <- matrix(nrow = 5, ncol = 5) # Empty 5x5 matrix
a5l <- length(a5) # Number of cells in array
ind <- sample(x = length(a5), replace = F, size = a5l) # Rand. indexes
a5[ind[1:d1l]] <- "X" # Write objects to rand. indexes
a5[ind[d1l+1:24]] <- "O" # Write remaining obj to rand. indexes
a5[ind[25]] <- "T" # Place target
# Turn into data frame for ggplot2
testdf <- data.frame("row"=substr(levels(interaction(1:5, 1:5, sep="")),1,1),
"col"=substr(levels(interaction(1:5, 1:5, sep="")),2,2),
"val"=a5[1:25],
"colour"=ifelse(a5[1:25]=="X", "green", "red"))
# Initiate graphics device
png(paste0("figs/", d1l,"items-interation",i,".png") , height=1080, width=1920)
# Generate plot
ggplot(testdf, aes(x=row, y=col, shape=val, colour=colour))+
geom_point(position=position_jitter(width=.2, height=.2), size=15)+
scale_shape_manual(values=c("O"=1, "X"=4, "T"=4))+
scale_colour_manual(values=c("red"="red", "green"="green4"))+
theme_minimal()+
theme(panel.grid.major = element_blank(),
axis.text = element_blank(),
axis.title = element_blank(),
legend.position = "none")
# Force editing
grid.force()
# Changing thickness of shapes
grid.edit("geom_point.points", grep = TRUE, gp = gpar(lwd = 5))
# Turn off gr device
dev.off()
}
}
Depending on where I run the script, I run into different errors:
Error in (function (filename = "Rplot%03d.png", width = 480, height = 480, :
unable to start png() device
or
Error in editDLfromGPath(gPath, specs, strict, grep, global, redraw) :
'gPath' (geom_point.points) not found
I'm having a hard time troubleshooting what it is that's wrong with my format, so any help in understanding the errors is much appreciated.