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

gov.sandia.cognition.learning.data.DefaultValueDiscriminantPair Maven / Gradle / Ivy

/*
 * File:                DefaultValueDiscriminantPair.java
 * Authors:             Justin Basilico
 * Company:             Sandia National Laboratories
 * Project:             Cognitive Foundry Learning Core
 * 
 * Copyright February 02, 2011, Sandia Corporation.
 * Under the terms of Contract DE-AC04-94AL85000, there is a non-exclusive 
 * license for use of this work by or on behalf of the U.S. Government. Export 
 * of this program may require a license from the United States Government. 
 */

package gov.sandia.cognition.learning.data;

import gov.sandia.cognition.util.ObjectUtil;

/**
 * A default implementation of the {@code ValueDiscriminantPair} interface.
 * Stores the value and discriminant values as fields.
 *
 * @param   
 *      The general value stored in the pair.
 * @param   
 *      The discriminant comparable object used for ordering objects.
 * @author  Justin Basilico
 * @since   3.1
 */
public class DefaultValueDiscriminantPair>
    extends AbstractValueDiscriminantPair
{
    /** The value. */
    protected ValueType value;

    /** The discriminant. */
    protected DiscriminantType discriminant;

    /**
     * Creates a new {@code DefaultValueDiscriminantPair} with null value and
     * discriminant.
     */
    public DefaultValueDiscriminantPair()
    {
        this(null, null);
    }

    /**
     * Creates a new {@code DefaultValueDiscriminantPair} with the given value
     * and discriminant.
     *
     * @param   value
     *      The value.
     * @param   discriminant
     *      The discriminant.
     */
    public DefaultValueDiscriminantPair(
        final ValueType value,
        final DiscriminantType discriminant)
    {
        super();

        this.setValue(value);
        this.setDiscriminant(discriminant);
    }

    @Override
    public DefaultValueDiscriminantPair clone()
    {
        @SuppressWarnings("unchecked")
        final DefaultValueDiscriminantPair clone =
            (DefaultValueDiscriminantPair)
            super.clone();

        clone.value = ObjectUtil.cloneSmart(this.value);
        clone.discriminant = ObjectUtil.cloneSmart(this.discriminant);

        return clone;
    }

    @Override
    public ValueType getValue()
    {
        return this.value;
    }

    /**
     * Sets the value.
     *
     * @param   value
     *      The value.
     */
    public void setValue(
        final ValueType value)
    {
        this.value = value;
    }

    @Override
    public DiscriminantType getDiscriminant()
    {
        return this.discriminant;
    }

    /**
     * Sets the discriminant.
     *
     * @param   discriminant
     *      The discriminant.
     */
    public void setDiscriminant(
        final DiscriminantType discriminant)
    {
        this.discriminant = discriminant;
    }


    /**
     * Convenience method for creating a new
     * {@code DefaultValueDiscriminantPair} with the given value and
     * discriminant.
     *
     * @param   
     *      The general value stored in the pair.
     * @param   
     *      The discriminant comparable object used for ordering objects.
     * @param   value
     *      The value.
     * @param   discriminant
     *      The discriminant.
     * @return
     *      A new {@code DefaultValueDiscriminantPair}.
     */
    public static > DefaultValueDiscriminantPair create(
        final ValueType value,
        final DiscriminantType discriminant)
    {
        return new DefaultValueDiscriminantPair(
            value, discriminant);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy