import java.util.List; import uk.ac.imperial.lsds.seep.api.API; import uk.ac.imperial.lsds.seep.api.SeepTask; import uk.ac.imperial.lsds.seep.api.StatefulSeepTask; import uk.ac.imperial.lsds.seep.api.data.ITuple; import uk.ac.imperial.lsds.seep.api.data.OTuple; import uk.ac.imperial.lsds.seep.api.data.Schema; import uk.ac.imperial.lsds.seep.api.data.Type; import uk.ac.imperial.lsds.seep.api.data.Schema.SchemaBuilder; import uk.ac.imperial.lsds.seep.api.state.stateimpl.SeepMap; public class Processor implements StatefulSeepTask<SeepMap<Integer, String>> { private SeepMap<Integer, String> map; private Schema schema = SchemaBuilder.getInstance().newField(Type.INT, "userId").newField(Type.LONG, "ts").build(); @Override public void setUp() { // TODO Auto-generated method stub } @Override public void setState(SeepMap<Integer, String> map) { this.map = map; } @Override public void processData(ITuple data, API api) { int userId = data.getInt("userId"); long ts = data.getLong("ts"); userId = userId + userId; ts = ts - 1; System.out.println("myId: "+api.id()); byte[] processedData = OTuple.create(schema, new String[]{"userId", "ts"}, new Object[]{userId, ts}); api.send(processedData); } @Override public void close() { // TODO Auto-generated method stub } @Override public void processDataGroup(List<ITuple> arg0, API arg1) { // TODO Auto-generated method stub } }