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

edu.jas.poly.PolynomialComparator Maven / Gradle / Ivy

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

package edu.jas.poly;


import java.io.Serializable;
import java.util.Comparator;

import edu.jas.structure.RingElem;


/**
 * Comparator for polynomials.
 * @param  coefficient type
 * @author Heinz Kredel.
 */
public class PolynomialComparator> implements Serializable,
                Comparator> {


    public final TermOrder tord;


    public final boolean reverse;


    /**
     * Constructor.
     * @param t TermOrder.
     * @param reverse flag if reverse ordering is requested.
     */
    public PolynomialComparator(TermOrder t, boolean reverse) {
        tord = t;
        this.reverse = reverse;
    }


    /**
     * Compare polynomials.
     * @param p1 first polynomial.
     * @param p2 second polynomial.
     * @return 0 if ( p1 == p2 ), -1 if ( p1 < p2 ) and +1 if ( p1 > p2 ).
     */
    public int compare(GenPolynomial p1, GenPolynomial p2) {
        // check if p1.tord = p2.tord = tord ?
        int s = p1.compareTo(p2);
        //System.out.println("p1.compareTo(p2) = " + s);
        if (reverse) {
            return -s;
        }
        return s;
    }


    /**
     * Equals test of comparator.
     * @param o other object.
     * @return true if this = o, else false.
     */
    @Override
    public boolean equals(Object o) {
        PolynomialComparator pc = null;
        try {
            pc = (PolynomialComparator) o;
        } catch (ClassCastException ignored) {
            return false;
        }
        if (pc == null) {
            return false;
        }
        return tord.equals(pc.tord);
    }


    /**
     * Hash code for this PolynomialComparator.
     * @see java.lang.Object#hashCode()
     */
    @Override
    public int hashCode() {
        return tord.hashCode();
    }


    /**
     * toString.
     */
    @Override
    public String toString() {
        return "PolynomialComparator(" + tord + ")";
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy