MATSIM
TransportModeFilter.java
Go to the documentation of this file.
1 /* *********************************************************************** *
2  * project: org.matsim.*
3  * TransportModeFilter.java
4  * *
5  * *********************************************************************** *
6  * *
7  * copyright : (C) 2012 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.withinday.replanning.identifiers.filter;
22 
23 import java.util.Iterator;
24 import java.util.Map;
25 import java.util.Set;
26 
27 import org.matsim.api.core.v01.Id;
31 
41 public class TransportModeFilter implements AgentFilter {
42 
43  private final Map<Id<Person>, MobsimAgent> agents;
44  private final Set<String> modes;
45 
46  // use the factory
47  /*package*/ TransportModeFilter(Map<Id<Person>, MobsimAgent> agents, Set<String> modes) {
48  this.agents = agents;
49  this.modes = modes;
50  }
51 
52  @Override
53  public void applyAgentFilter(Set<Id<Person>> set, double time) {
54  Iterator<Id<Person>> iter = set.iterator();
55 
56  while (iter.hasNext()) {
57  Id<Person> id = iter.next();
58  if (!this.applyAgentFilter(id, time)) iter.remove();
59  }
60  }
61 
62  @Override
63  public boolean applyAgentFilter(Id<Person> id, double time) {
64  MobsimAgent agent = this.agents.get(id);
65 
66  if (!(agent.getState() == MobsimAgent.State.LEG)) return false;
67  if (!(modes.contains(agent.getMode()))) return false;
68 
69  return true;
70  }
71 }