GitXplorerGitXplorer
s

OpeningTech

public
9 stars
3 forks
0 issues

Commits

List of commits on branch master.
Unverified
296ac9b012a99d4de5d29cbf2747f6474776f3ed

small changes

ssyhw committed 13 years ago
Unverified
992b7740e67195ac0ab713f530feca6af7725bbb

scripts

ssyhw committed 13 years ago
Unverified
6bfcb49e961fa62a53cb9e6586b60fcde579c9b1

completing the clustering/labeling README

ssyhw committed 13 years ago
Unverified
f1495cd9116d2c3a4bfe6ae8a2d6b4dec0fde64d

correcting a bug in x_values (this TECH_TREES define should have been different)

ssyhw committed 13 years ago
Unverified
e5f49ac9a125066651189e1677c7e8e7cfcd94f6

correcting bug in learn_all target (Makefile)

ssyhw committed 13 years ago
Unverified
f5cd6a4ab6b265fdae38f0d9d428822f924326f5

correcting Makefile + new target learn all

ssyhw committed 13 years ago

README

The README file for this repository.

Opening/BuildTree prediction for StarCraft: Broodwar

Dependency:

ProBT
Boost.serialization (optional, note: compiled with ./bjam --with-serialization --build-type=complete --layout=versioned toolset=darwin architecture=x86 address-model=32)

Input format:

One replay/game per line, lines such as
First_Building_Name Time_Built; Second_Building_Name Time_Built2;

See the *v*.txt files

It does:

  1. Learn the possible tech trees (X) from replays (or you can generate them)
  2. Learn the distributions of P(Time | X, Opening) and P(X | Opening)
  3. Learn the distributions of P(Time | BuildTree) with TECH_TREES switched on
  4. Infer P(Opening | Observations, Time)

See model.pdf or CIG'11 publication for 1,2,4 and AIIDE'11 publication for 3.

Workflow:

  1. (Optional, our labels) Clusterize from clustering/launch_labeling.sh
  2. Transform (transmute) arff files into txt files with scripts/transmute.sh
  3. To perform evaluations, cut the txt files into learn and test files with the scripts/cut* scripts
  4. Compile (make) and test either with make targets or export (DY)LD_LIBRARY_PATH=<probt/lib(+boost/lib)> && ./model lXvX.txt tXvX.txt

More is more:

You will always need one runtime library: probt (probt22 in Makefile, any probt >= 2.2 should do). depending on how it was compiled, the main of model.cpp (model (Ben Weber openings), mymodel (my openings, c.f. clustering/), or tt (tech trees only) in the Makefile) will learn and exit from file (match-up) XvY.txt if given:

    ./model XvY.txt

or will learn on XvY and test on WvZ if given:

    ./model XvY.txt WvZ.txt

Example:

    ./model lZvT.txt tZvT.txt

The prediction will always be against X or W, for instance in ZvT, the predictions will be as a Terran player against a Zerg one (the learning is also of Zerg build/tech trees and openings).

  1. To just compile and run the Opening prediction model with Ben Weber's openings labels:

     make model
     make run OR (with appropriate DYLD_LIBRARY_PATH) ./model XvT.txt [WvZ.txt]
    
  2. To compile and run the Opening prediction model with Ben's openings labels and serialization, you need to be able to link to a boost >= 1.45 serialization dylib/dll/so:

     make model_with_serialization
     make run_with_serialization OR (with appropriate DYLD_LIBRARY_PATH) ./model XvT.txt [WvZ.txt]
     ex here: ./model PvT.txt
    
  3. The same with my openings (c.f. clustering/clustering.py):

     make mymodel[_with_serialization]
     make run[_with_serialization] OR (with appropriate DYLD_LIBRARY_PATH) ./mymodel XvY.txt [WvZ.txt]
     ex here: ./mymodel PvTx.txt
    
  4. To compile and run the (build/)tech trees prediction only:

     make tt
     make run_tt OR (with appropriate DYLD_LIBRARY_PATH) ./tt XvY.txt [WvZ.txt]
     ex here: ./tt PvT.txt
    
  5. A lot of plotting options, see Makefile