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

weka.knowledgeflow.JobEnvironment Maven / Gradle / Ivy

/*
 *   This program is free software: you can redistribute it and/or modify
 *   it under the terms of the GNU General Public License as published by
 *   the Free Software Foundation, either version 3 of the License, or
 *   (at your option) any later version.
 *
 *   This program is distributed in the hope that it will be useful,
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *   GNU General Public License for more details.
 *
 *   You should have received a copy of the GNU General Public License
 *   along with this program.  If not, see .
 */

/*
 *    JobEnvironment.java
 *    Copyright (C) 2016 University of Waikato, Hamilton, New Zealand
 *
 */

package weka.knowledgeflow;

import weka.core.Environment;

import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

/**
 * Extended Environment with support for storing results and property values to
 * be set at a later date on the base schemes of WekaAlgorithmWrapper steps. The
 * latter is useful in the case where variables are not supported for properties
 * in a base scheme.
 *
 * @author Mark Hall (mhall{[at]}pentaho{[dot]}com)
 * @version $Revision: $
 */
public class JobEnvironment extends Environment {

  /** Map of non-incremental result data */
  protected Map> m_resultData = new ConcurrentHashMap<>();

  /**
   * Map of properties for various base schemes owned by scheme-specific
   * (WekaAlgorithmWrapper) steps. Outer map is keyed by step name, inner map by
   * property name
   */
  protected Map> m_stepProperties =
    new ConcurrentHashMap<>();

  /**
   * Constructor
   */
  public JobEnvironment() {
    super();
  }

  /**
   * Construct a JobEnvironment by copying the contents of a standard
   * Environment
   * 
   * @param env the Environment to copy into this JobEnvironment
   */
  public JobEnvironment(Environment env) {
    super(env);

    if (env instanceof JobEnvironment) {
      m_stepProperties.putAll(((JobEnvironment) env).m_stepProperties);
    }
  }

  /**
   * Add a non-incremental data object to the result
   * 
   * @param data the data to add
   */
  public void addToResult(Data data) {
    if (!data.isIncremental()) {
      LinkedHashSet dataList = m_resultData.get(data.getConnectionName());
      if (dataList == null) {
        dataList = new LinkedHashSet<>();
        m_resultData.put(data.getConnectionName(), dataList);
      }
      dataList.add(data);
    }
  }

  /**
   * Add all the results from the supplied map to this environment's results
   *
   * @param otherResults the results to add
   */
  public void addAllResults(Map> otherResults) {
    for (Map.Entry> e : otherResults.entrySet()) {
      if (!m_resultData.containsKey(e.getKey())) {
        m_resultData.put(e.getKey(), e.getValue());
      } else {
        LinkedHashSet toAddTo = m_resultData.get(e.getKey());
        toAddTo.addAll(e.getValue());
      }
    }
  }

  /**
   * Get a list of any result data objects of the supplied connection type
   * 
   * @param connName the name of the connection to get result data objects for
   * @return a list of result data objects for the specified connection type, or
   *         null if none exist
   */
  public LinkedHashSet getResultDataOfType(String connName) {
    LinkedHashSet results = m_resultData.remove(connName);
    return results;
  }

  /**
   * Returns true if the results contain data of a particular connection type
   *
   * @param connName the name of the connection to check for data
   * @return true if the results contain data of the supplied connection type
   */
  public boolean hasResultDataOfType(String connName) {
    return m_resultData.containsKey(connName);
  }

  /**
   * Get a map of all the result data objects
   * 
   * @return a map of all result data
   */
  public Map> getResultData() {
    return m_resultData;
  }

  public void clearResultData() {
    m_resultData.clear();
  }

  /**
   * Get the step properties for a named step
   * 
   * @param stepName the name of the step to get properties for
   * @return a map of properties for the named step
   */
  public Map getStepProperties(String stepName) {
    return m_stepProperties.get(stepName);
  }

  /**
   * Clear all step properties
   */
  public void clearStepProperties() {
    m_stepProperties.clear();
  }

  /**
   * Add the supplied map of step properties. The map contains properties for
   * various base schemes owned by scheme-specific (WekaAlgorithmWrapper) steps.
   * Outer map is keyed by step name, inner map by property name.
   * 
   * @param propsToAdd properties to add
   */
  public void addToStepProperties(Map> propsToAdd) {
    m_stepProperties.putAll(propsToAdd);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy