2017-12-28 21:38:10 -08:00
|
|
|
(module AiState racket
|
|
|
|
(provide (all-defined-out))
|
|
|
|
|
|
|
|
(struct AiState (chunks
|
|
|
|
chunksLookup
|
|
|
|
minMaxes)
|
2018-09-25 22:14:13 -07:00
|
|
|
#:transparent)
|
2017-12-28 21:38:10 -08:00
|
|
|
|
|
|
|
(struct MinMax (min max)
|
|
|
|
#:transparent)
|
|
|
|
|
|
|
|
(struct ChunkRange (x
|
|
|
|
y
|
|
|
|
movement
|
|
|
|
base
|
|
|
|
player
|
|
|
|
resource
|
|
|
|
passable
|
|
|
|
tick
|
2017-12-31 21:49:36 -08:00
|
|
|
rating
|
|
|
|
nests
|
|
|
|
worms
|
|
|
|
rally
|
|
|
|
retreat
|
|
|
|
resourceGen
|
2018-09-25 22:14:13 -07:00
|
|
|
playerGen
|
|
|
|
deathGen
|
|
|
|
attackScore
|
|
|
|
settleScore
|
2019-02-05 22:25:43 -08:00
|
|
|
siegeScore)
|
2017-12-28 21:38:10 -08:00
|
|
|
#:transparent)
|
2019-02-05 22:25:43 -08:00
|
|
|
|
|
|
|
(struct Chunk (siegeScore
|
2018-09-25 22:14:13 -07:00
|
|
|
settleScore
|
|
|
|
attackScore
|
|
|
|
x
|
2017-12-28 21:38:10 -08:00
|
|
|
y
|
|
|
|
movement
|
|
|
|
base
|
|
|
|
player
|
|
|
|
resource
|
|
|
|
passable
|
|
|
|
tick
|
2017-12-31 21:49:36 -08:00
|
|
|
rating
|
|
|
|
nests
|
|
|
|
worms
|
|
|
|
rally
|
|
|
|
retreat
|
|
|
|
resourceGen
|
2018-09-25 22:14:13 -07:00
|
|
|
playerGen
|
|
|
|
deathGen)
|
2017-12-28 21:38:10 -08:00
|
|
|
#:transparent)
|
2019-02-05 22:25:43 -08:00
|
|
|
|
2017-12-28 21:38:10 -08:00
|
|
|
(require threading)
|
|
|
|
|
|
|
|
(define (getFile filePath)
|
|
|
|
(call-with-input-file filePath
|
|
|
|
(lambda (port)
|
|
|
|
(port->string port))))
|
|
|
|
|
|
|
|
(define (stringToChunk str)
|
2018-09-25 22:14:13 -07:00
|
|
|
(match-let (((list movement base player resource passable tick rating x y nest
|
|
|
|
worms rally retreat resourceGen playerGen deathGen) (string-split str ",")))
|
2017-12-28 21:38:10 -08:00
|
|
|
(apply Chunk
|
2018-09-25 22:14:13 -07:00
|
|
|
(cons (+ (* 2 (string->number movement))
|
|
|
|
(string->number resource)
|
|
|
|
(string->number base)
|
|
|
|
(* (string->number player) 500))
|
|
|
|
(cons (+ (* 2 (string->number movement))
|
|
|
|
(string->number resource))
|
|
|
|
(cons (+ (* 2 (string->number movement))
|
|
|
|
(string->number base)
|
|
|
|
(* (string->number player) 500))
|
|
|
|
(map string->number
|
|
|
|
(list x y movement base player resource passable tick rating nest
|
|
|
|
worms rally retreat resourceGen playerGen deathGen))))))))
|
2017-12-28 21:38:10 -08:00
|
|
|
|
|
|
|
(define (chunk->string chunk)
|
|
|
|
(string-append "x: " (~v (Chunk-x chunk)) "\n"
|
|
|
|
"y: " (~v (Chunk-y chunk)) "\n"
|
2017-12-31 21:49:36 -08:00
|
|
|
"m: " (~v (Chunk-movement chunk)) "\n"
|
|
|
|
"b: " (~v (Chunk-base chunk)) "\n"
|
|
|
|
"p: " (~v (Chunk-player chunk)) "\n"
|
|
|
|
"r: " (~v (Chunk-resource chunk)) "\n"
|
|
|
|
"pass: " (~v (Chunk-passable chunk)) "\n"
|
|
|
|
"tic: " (~v (Chunk-tick chunk)) "\n"
|
|
|
|
"rat: " (~v (Chunk-rating chunk)) "\n"
|
|
|
|
"ne: " (~v (Chunk-nests chunk)) "\n"
|
|
|
|
"wo: " (~v (Chunk-worms chunk)) "\n"
|
|
|
|
"rall: " (~v (Chunk-rally chunk)) "\n"
|
|
|
|
"retr: " (~v (Chunk-retreat chunk)) "\n"
|
2018-09-25 22:14:13 -07:00
|
|
|
"rGen: " (~v (Chunk-resourceGen chunk)) "\n"))
|
|
|
|
|
|
|
|
(define (chunk->string2 chunk)
|
|
|
|
(string-append "pGen: " (~v (Chunk-playerGen chunk)) "\n"
|
|
|
|
"dGen: " (~v (Chunk-deathGen chunk)) "\n"
|
|
|
|
"aSco: " (~v (Chunk-attackScore chunk)) "\n"
|
|
|
|
"sSco: " (~v (Chunk-settleScore chunk)) "\n"
|
2019-02-05 22:25:43 -08:00
|
|
|
"sSei: " (~v (Chunk-siegeScore chunk)) "\n"))
|
2018-09-25 22:14:13 -07:00
|
|
|
|
2017-12-28 21:38:10 -08:00
|
|
|
(define (findChunkPropertiesMinMax chunks)
|
|
|
|
(let ((xs (map Chunk-x chunks))
|
|
|
|
(ys (map Chunk-y chunks))
|
|
|
|
(movements (map Chunk-movement chunks))
|
|
|
|
(bases (map Chunk-base chunks))
|
|
|
|
(players (map Chunk-player chunks))
|
|
|
|
(resources (map Chunk-resource chunks))
|
|
|
|
(passables (map Chunk-passable chunks))
|
|
|
|
(ticks (map Chunk-tick chunks))
|
2017-12-31 21:49:36 -08:00
|
|
|
(ratings (map Chunk-rating chunks))
|
|
|
|
(nests (map Chunk-nests chunks))
|
|
|
|
(worms (map Chunk-worms chunks))
|
|
|
|
(rallys (map Chunk-rally chunks))
|
|
|
|
(retreats (map Chunk-retreat chunks))
|
|
|
|
(rGens (map Chunk-resourceGen chunks))
|
2018-09-25 22:14:13 -07:00
|
|
|
(pGens (map Chunk-playerGen chunks))
|
|
|
|
(dGens (map Chunk-deathGen chunks))
|
|
|
|
(aSco (map Chunk-attackScore chunks))
|
|
|
|
(sSco (map Chunk-settleScore chunks))
|
2019-02-05 22:25:43 -08:00
|
|
|
(sSei (map Chunk-siegeScore chunks)))
|
2017-12-28 21:38:10 -08:00
|
|
|
(ChunkRange (MinMax (apply min xs) (apply max xs))
|
|
|
|
(MinMax (apply min ys) (apply max ys))
|
|
|
|
(MinMax (apply min movements) (apply max movements))
|
|
|
|
(MinMax (apply min bases) (apply max bases))
|
|
|
|
(MinMax (apply min players) (apply max players))
|
|
|
|
(MinMax (apply min resources) (apply max resources))
|
|
|
|
(MinMax (apply min passables) (apply max passables))
|
|
|
|
(MinMax (apply min ticks) (apply max ticks))
|
2017-12-31 21:49:36 -08:00
|
|
|
(MinMax (apply min ratings) (apply max ratings))
|
|
|
|
(MinMax (apply min nests) (apply max nests))
|
|
|
|
(MinMax (apply min worms) (apply max worms))
|
|
|
|
(MinMax (apply min rallys) (apply max rallys))
|
|
|
|
(MinMax (apply min retreats) (apply max retreats))
|
|
|
|
(MinMax (apply min rGens) (apply max rGens))
|
2018-09-25 22:14:13 -07:00
|
|
|
(MinMax (apply min pGens) (apply max pGens))
|
|
|
|
(MinMax (apply min dGens) (apply max dGens))
|
|
|
|
(MinMax (apply min aSco) (apply max aSco))
|
|
|
|
(MinMax (apply min sSco) (apply max sSco))
|
|
|
|
(MinMax (apply min sSei) (apply max sSei)))))
|
|
|
|
|
2017-12-28 21:38:10 -08:00
|
|
|
(define (readState filePath)
|
|
|
|
(let* ((replayChunks (getFile filePath))
|
|
|
|
(chunks (map stringToChunk (string-split replayChunks "\n")))
|
|
|
|
(minMaxes (findChunkPropertiesMinMax chunks)))
|
|
|
|
(AiState chunks
|
|
|
|
(apply hash
|
|
|
|
(apply append
|
|
|
|
(map (lambda (chunk)
|
|
|
|
(list (list (Chunk-x chunk)
|
|
|
|
(Chunk-y chunk))
|
|
|
|
chunk))
|
|
|
|
chunks)))
|
|
|
|
minMaxes)))
|
|
|
|
|
|
|
|
(define (test)
|
|
|
|
(readState "/data/games/factorio/script-output/rampantState.txt")))
|