mainExample.py 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. # main imports
  2. import logging
  3. import os
  4. # module imports
  5. from macop.algorithms.IteratedLocalSearch import IteratedLocalSearch as ILS
  6. from macop.solutions.BinarySolution import BinarySolution
  7. from macop.evaluators.EvaluatorExample import evaluatorExample
  8. from macop.operators.mutators.SimpleMutation import SimpleMutation
  9. from macop.operators.mutators.SimpleBinaryMutation import SimpleBinaryMutation
  10. from macop.operators.crossovers.SimpleCrossover import SimpleCrossover
  11. from macop.operators.crossovers.RandomSplitCrossover import RandomSplitCrossover
  12. from macop.operators.policies.RandomPolicy import RandomPolicy
  13. from macop.checkpoints.BasicCheckpoint import BasicCheckpoint
  14. if not os.path.exists('data'):
  15. os.makedirs('data')
  16. # logging configuration
  17. logging.basicConfig(format='%(asctime)s %(message)s', filename='data/example.log', level=logging.DEBUG)
  18. # default validator
  19. def validator(solution):
  20. return True
  21. # define init random solution
  22. def init():
  23. return BinarySolution([], 30).random(validator)
  24. filepath = "data/checkpoints.csv"
  25. def main():
  26. operators = [SimpleBinaryMutation(), SimpleMutation(), SimpleCrossover(), RandomSplitCrossover()]
  27. policy = RandomPolicy(operators)
  28. algo = ILS(init, evaluatorExample, operators, policy, validator, True)
  29. algo.addCheckpoint(_class=BasicCheckpoint, _every=5, _filepath=filepath)
  30. bestSol = algo.run(425)
  31. print("Found ", bestSol)
  32. if __name__ == "__main__":
  33. main()