-
Notifications
You must be signed in to change notification settings - Fork 0
/
GenerateWindmillsFiles.R
78 lines (59 loc) · 3.6 KB
/
GenerateWindmillsFiles.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# GENERAL SETTINGS
args <- commandArgs(trailingOnly = TRUE)
general <- list()
if (length(args) < 2) {
if(.Platform$OS.type == "windows") {
general$application <- "testexample" # ...or myfish
general$main_path_gis <- file.path("C:","Users","fbas","Documents","GitHub","DISPLACE_input_gis", general$application)
general$main.path.ibm <- file.path("C:","Users","fbas","Documents","GitHub",paste("DISPLACE_input_", general$application, sep=''))
general$igraph <- 56 # caution: should be consistent with existing objects already built upon a given graph
do_plot <- TRUE
}
} else {
general$application <- args[1]
general$main_path_gis <- args[2]
general$main.path.ibm <- args[3]
general$igraph <- args[4] # caution: should be consistent with existing objects already built upon a given graph
do_plot <- FALSE
}
cat(paste("START\n"))
dir.create(file.path(general$main.path.ibm, paste("windmillsspe_", general$application, sep='')))
# load
coord <- read.table(file=file.path(general$main_path_gis, "GRAPH", paste("coord", general$igraph, ".dat", sep=""))) # build from the c++ gui
dd <- coord
coord <- as.matrix(as.vector(coord))
coord <- matrix(coord, ncol=3)
colnames(coord) <- c('x', 'y', 'harb')
if(do_plot) plot(coord[,1], coord[,2])
graph <- read.table(file=file.path(general$main_path_gis, "GRAPH", paste("graph", general$igraph, ".dat", sep=""))) # build from the c++ gui
graph <- as.matrix(as.vector(graph))
graph <- matrix(graph, ncol=3)
if(do_plot) segments(coord[graph[,1]+1,1], coord[graph[,1]+1,2], coord[graph[,2]+1,1], coord[graph[,2]+1,2], col=4) # CAUTION: +1, because c++ to R
cat(paste("Read graph...done\n"))
# read
windmills_features <- read.table(file.path(general$main_path_gis,"WINDMILLS", "windmills_features.csv"), sep=";", header=TRUE)
cat(paste("Read windmills specs...done\n"))
# find the nearest graph node
cat(paste("Finding neighbours....\n"))
library(spatstat)
an <- function(x) as.numeric(as.character(x))
coord_f <- coord[coord[,'harb']==0,]
X <- ppp(x=an(windmills_features$long), y=an(windmills_features$lat),
xrange=range(an(windmills_features$long)), yrange=range(an(windmills_features$lat)))
Y <- ppp(x=coord_f[,"x"], y=coord_f[,"y"],
xrange=range(coord_f[,"x"]), yrange=range(coord_f[,"y"]))
N <- nncross (X=X, Y=Y)$which # caution: just euclidean distance on coord
windmills_features <- cbind(windmills_features, pt_graph= N)
some_windmills_features <- windmills_features[,c('pt_graph', 'size_km2')]
colnames(some_windmills_features) <- c('idx_node', 'size_km2')
## aggregate per graph node given c++ object are created on nodes only
some_windmills_features <- tapply(some_windmills_features$size_km2, some_windmills_features$idx_node, sum)
some_windmills_features <- cbind.data.frame(rownames(some_windmills_features), some_windmills_features)
colnames(some_windmills_features) <- c('idx_node', 'size_km2')
# write
write.table(some_windmills_features,
file=file.path(general$main.path.ibm, paste("windmillsspe_", general$application, sep=''),
paste("size_per_windmill.dat",sep='')),
col.names=TRUE, row.names=FALSE, sep= ' ', quote=FALSE, append=FALSE)
cat(paste("Write windmills-related files...done\n"))
cat(paste("..........done\n"))