MATSIM
AbstractPersonAlgorithm.java
Go to the documentation of this file.
1 /* *********************************************************************** *
2  * project: org.matsim.*
3  * AbstractPersonAlgorithm.java
4  * *
5  * *********************************************************************** *
6  * *
7  * copyright : (C) 2007 by the members listed in the COPYING, *
8  * LICENSE and WARRANTY file. *
9  * email : info at matsim dot org *
10  * *
11  * *********************************************************************** *
12  * *
13  * This program is free software; you can redistribute it and/or modify *
14  * it under the terms of the GNU General Public License as published by *
15  * the Free Software Foundation; either version 2 of the License, or *
16  * (at your option) any later version. *
17  * See also COPYING, LICENSE and WARRANTY file *
18  * *
19  * *********************************************************************** */
20 
21 package org.matsim.core.population.algorithms;
22 
23 import org.apache.logging.log4j.LogManager;
24 import org.apache.logging.log4j.Logger;
28 
29 public abstract class AbstractPersonAlgorithm implements PersonAlgorithm {
30  // this is ok as non-final since methods that contain code are final. kai, may'17
31 
32  private final static Logger log = LogManager.getLogger(AbstractPersonAlgorithm.class);
33 
34  public final void run(final Population plans) {
35  log.info("running " + this.getClass().getName() + " algorithm...");
36  Counter counter = new Counter(" person # ");
37 
38  for (Person p : plans.getPersons().values()) {
39  counter.incCounter();
40  this.run(p);
41  }
42  counter.printCounter();
43  log.info("done running algorithm.");
44  }
45 
46  @Override
47  public abstract void run(Person person);
48 }
Map< Id< Person >,? extends Person > getPersons()