eu.stratosphere.api.common.JobExecutionResult Maven / Gradle / Ivy
/***********************************************************************************************************************
* Copyright (C) 2010-2013 by the Stratosphere project (http://stratosphere.eu)
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
* an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
**********************************************************************************************************************/
package eu.stratosphere.api.common;
import java.util.Map;
public class JobExecutionResult {
private long netRuntime;
private Map accumulatorResults;
public JobExecutionResult(long netRuntime, Map accumulators) {
this.netRuntime = netRuntime;
this.accumulatorResults = accumulators;
}
public long getNetRuntime() {
return this.netRuntime;
}
@SuppressWarnings("unchecked")
public T getAccumulatorResult(String accumulatorName) {
return (T) this.accumulatorResults.get(accumulatorName);
}
public Map getAllAccumulatorResults() {
return this.accumulatorResults;
}
/**
* @param accumulatorName
* Name of the counter
* @return Result of the counter, or null if the counter does not exist
*/
public Integer getIntCounterResult(String accumulatorName) {
Object result = this.accumulatorResults.get(accumulatorName);
if (result == null) {
return null;
}
if (!(result instanceof Integer)) {
throw new ClassCastException("Requested result of the accumulator '" + accumulatorName
+ "' should be Integer but has type " + result.getClass());
}
return (Integer) result;
}
// TODO Create convenience methods for the other shipped accumulator types
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy