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

edu.jas.ps.Pair Maven / Gradle / Ivy

The newest version!
/*
 * $Id: Pair.java 3994 2012-07-15 11:50:54Z kredel $
 */

package edu.jas.ps;


import java.io.Serializable;

import edu.jas.structure.RingElem;


/**
 * Serializable subclass to hold pairs of power series.
 * @param  coefficient type
 * @author Heinz Kredel.
 */
public class Pair> implements Serializable, Comparable {


    public final MultiVarPowerSeries pi;


    public final MultiVarPowerSeries pj;


    public final int i;


    public final int j;


    protected int n;


    protected boolean toZero = false;


    protected boolean useCriterion4 = false;


    protected boolean useCriterion3 = false;


    /**
     * Pair constructor.
     * @param a power series i.
     * @param b power series j.
     * @param i first index.
     * @param j second index.
     */
    public Pair(MultiVarPowerSeries a, MultiVarPowerSeries b, int i, int j) {
        pi = a;
        pj = b;
        this.i = i;
        this.j = j;
        this.n = 0;
        toZero = false; // ok
    }


    /**
     * toString.
     */
    @Override
    public String toString() {
        return "pair[" + n + "](" + i + j + ", r0=" + toZero + ", c4=" + useCriterion4 + ", c3="
                + useCriterion3 + ")";
    }


    /**
     * Set removed pair number.
     * @param n number of this pair generated in OrderedPairlist.
     */
    public void pairNumber(int n) {
        this.n = n;
    }


    /**
     * Get removed pair number.
     * @return n number of this pair generated in OrderedPairlist.
     */
    public int getPairNumber() {
        return n;
    }


    /**
     * Set zero reduction. The S-power-series of this Pair was reduced to zero.
     */
    public void setZero() {
        toZero = true;
    }


    /**
     * Is reduced to zero.
     * @return true if the S-power-series of this Pair was reduced to zero, else
     *         false.
     */
    public boolean isZero() {
        return toZero;
    }


    /**
     * equals.
     * @param ob an Object.
     * @return true if this is equal to o, else false.
     */
    @Override
    public boolean equals(Object ob) {
        if (!(ob instanceof Pair)) {
            return false;
            // throw new ClassCastException("Pair "+n+" o "+o);
        }
        return 0 == compareTo((Pair) ob);
    }


    /**
     * compareTo used in TreeMap // not used at moment. Comparison is based on
     * the number of the pairs.
     * @param p a Pair.
     * @return 1 if (this < o), 0 if (this == o), -1 if (this > o).
     */
    public int compareTo(Pair p) {
        int x = p.getPairNumber();
        if (n > x) {
            return 1;
        }
        if (n < x) {
            return -1;
        }
        return 0;
    }


    /**
     * Hash code for this Pair.
     * @see java.lang.Object#hashCode()
     */
    @Override
    public int hashCode() {
        return (i << 16) + j;
    }


    /**
     * Set useCriterion4.
     * @param c boolean value to set.
     */
    public void setUseCriterion4(boolean c) {
        this.useCriterion4 = c;
    }


    /**
     * Get useCriterion4.
     * @return boolean value.
     */
    public boolean getUseCriterion4() {
        return this.useCriterion4;
    }


    /**
     * Set useCriterion3.
     * @param c boolean value to set.
     */
    public void setUseCriterion3(boolean c) {
        this.useCriterion3 = c;
    }


    /**
     * Get useCriterion3.
     * @return boolean value.
     */
    public boolean getUseCriterion3() {
        return this.useCriterion3;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy