All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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