Skip to content

aureooms-ulb-2010-2015/2013-2014-infoh413-projects

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ULB 2013-2014 infoh413

First and second part of the project for the course Heuristic Optimization.

/!\ WARNING

  • compiles with g++ 4.8.1

      $ g++ -v
      Using built-in specs.
      COLLECT_GCC=g++
      COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/4.8/lto-wrapper
      Target: x86_64-linux-gnu
      Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.8.1-10ubuntu9' --with-bugurl=file:///usr/share/doc/gcc-4.8/README.Bugs --enable-languages=c,c++,java,go,d,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.8 --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.8 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --enable-plugin --with-system-zlib --disable-browser-plugin --enable-java-awt=gtk --enable-gtk-cairo --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-4.8-amd64/jre --enable-java-home --with-jvm-root-dir=/usr/lib/jvm/java-1.5.0-gcj-4.8-amd64 --with-jvm-jar-dir=/usr/lib/jvm-exports/java-1.5.0-gcj-4.8-amd64 --with-arch-directory=amd64 --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --enable-objc-gc --enable-multiarch --disable-werror --with-arch-32=i686 --with-abi=m64 --with-multilib-list=m32,m64,mx32 --with-tune=generic --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu
      Thread model: posix
      gcc version 4.8.1 (Ubuntu/Linaro 4.8.1-10ubuntu9)
    

files

  • data: instance files and output files

  • do : python3/shell scripts for benching, latex tables, etc.

  • h : header files

    • lib : library header files for useful things (array shuffling, io)

    • pfsp: library header files for PFSP

    • pfsp_commons : common data types + framework used for PFSP algorithms

    • pfsp_ii : configuration and global variables for pfsp-ii

    • pfsp_vnd : configuration and global variables for pfsp-vnd

    • pfsp_rii : configuration and global variables for pfsp-rii

    • pfsp_pii : configuration and global variables for pfsp-pii

    • pfsp_sa : configuration and global variables for pfsp-sa

    • pfsp_ig : configuration and global variables for pfsp-ig

    • pfsp_tabu : configuration and global variables for pfsp-tabu

  • pdf : implementation sheets + literature

  • src : the main program source code for all algorithms

  • tuning : contains configuration files for algorithm automatic tuning with irace

  • tmpl : contains a template for parrallel benching on hydra

  • json : contains option files for python scripts

  • report1.pdf : 1st implementation exercice pdf report with tables, explanations and notes

  • report2.pdf : 2nd implementation exercice pdf report with tables, explanations and notes

  • Makefile : makefile for the implementation in C++

  • README.md : this file

compile it

make clean all

run it

./run/pfsp-ii <filename> -i {random, slack} -n {(s)transpose, (s)exchange, (s)insert} -p {first, best} [--seed <seed>] [-v]

./run/pfsp-vnd <filename> -i {random, slack} -o {(s)tie, (s)tei} [-p {first, best}] [--seed <seed>] [-v]

./run/pfsp-ig <filename> -i {random, slack} --td <T_d> --tp <T_p> --ss <sample size> -t <max time (ms)> [-v]

./run/pfsp-tabu <filename> -i {random, slack} -n {stranspose, sexchange, sinsert} -r <restart wait> --ssmin <sample size min> --ssmax <sample size max> --ttmin <1st phase tabu tenure min> --ttmax <1st phase tabu tenure max> --tt2nd <2nd phase tabu tenure> --ph <phase repartition> -t <max time (ms)> [-v]

(explanation about options : ./run/pfsp-<alg> -h)

flags

-v, --verbose
-h, --help

output non-verbose format

<twt>
<running time> [ms]
<seed>