當前位置: 首頁>>代碼示例>>Java>>正文


Java ExpVector.equals方法代碼示例

本文整理匯總了Java中edu.jas.poly.ExpVector.equals方法的典型用法代碼示例。如果您正苦於以下問題:Java ExpVector.equals方法的具體用法?Java ExpVector.equals怎麽用?Java ExpVector.equals使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在edu.jas.poly.ExpVector的用法示例。


在下文中一共展示了ExpVector.equals方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: recursivePseudoQuotientRemainder

import edu.jas.poly.ExpVector; //導入方法依賴的package包/類
/**
 * GenSolvablePolynomial recursive pseudo quotient and remainder for
 * recursive polynomials.
 * @param <C> coefficient type.
 * @param P recursive GenSolvablePolynomial.
 * @param S nonzero recursive GenSolvablePolynomial.
 * @return [ quotient, remainder ] with ore(ldcf(S)<sup>m'</sup>) P =
 *         quotient * S + remainder.
 * @see edu.jas.poly.GenPolynomial#remainder(edu.jas.poly.GenPolynomial).
 */
@SuppressWarnings("unchecked")
public static <C extends GcdRingElem<C>> GenSolvablePolynomial<GenPolynomial<C>>[] recursivePseudoQuotientRemainder(
                GenSolvablePolynomial<GenPolynomial<C>> P, GenSolvablePolynomial<GenPolynomial<C>> S) {
    if (S == null || S.isZERO()) {
        throw new ArithmeticException(P + " division by zero " + S);
    }
    //if (S.ring.nvar != 1) { // ok if exact division
    //    throw new RuntimeException("univariate polynomials only");
    //}
    GenSolvablePolynomial<GenPolynomial<C>>[] ret = new GenSolvablePolynomial[2];
    if (P == null || P.isZERO()) {
        ret[0] = S.ring.getZERO();
        ret[1] = S.ring.getZERO();
        return ret;
    }
    if (S.isONE()) {
        ret[0] = P;
        ret[1] = S.ring.getZERO();
        return ret;
    }
    GenPolynomialRing<C> cofac = (GenPolynomialRing) P.ring.coFac;
    GreatestCommonDivisorAbstract<C> fd = new GreatestCommonDivisorSimple<C>(cofac.coFac);

    ExpVector e = S.leadingExpVector();
    GenSolvablePolynomial<GenPolynomial<C>> h;
    GenSolvablePolynomial<GenPolynomial<C>> r = P;
    GenSolvablePolynomial<GenPolynomial<C>> q = S.ring.getZERO().copy();
    while (!r.isZERO()) {
        ExpVector g = r.leadingExpVector();
        ExpVector f = g;
        if (f.multipleOf(e)) {
            f = f.subtract(e);
            h = S.multiplyLeft(f); // coeff c, exp (f/e) e
            GenSolvablePolynomial<C> a = (GenSolvablePolynomial<C>) r.leadingBaseCoefficient();
            GenSolvablePolynomial<C> d = (GenSolvablePolynomial<C>) h.leadingBaseCoefficient();
            GenSolvablePolynomial<C>[] oc = fd.leftOreCond(a, d);
            GenPolynomial<C> ga = oc[0]; // d
            GenPolynomial<C> gd = oc[1]; // a
            // ga a = gd d
            r = r.multiplyLeft(ga); // coeff ga a, exp f
            h = h.multiplyLeft(gd); // coeff gd d, exp f
            q = q.multiplyLeft(ga); // d
            q = (GenSolvablePolynomial<GenPolynomial<C>>) q.sum(gd, f); // a
            r = (GenSolvablePolynomial<GenPolynomial<C>>) r.subtract(h);
            if (!r.isZERO() && g.equals(r.leadingExpVector())) {
                throw new RuntimeException("degree not descending: r = " + r);
            }
        } else {
            break;
        }
    }
    int sp = P.signum();
    int ss = S.signum();
    int sq = q.signum();
    // sp = ss * sq
    if (sp != ss * sq) {
        q = (GenSolvablePolynomial<GenPolynomial<C>>) q.negate();
        r = (GenSolvablePolynomial<GenPolynomial<C>>) r.negate();
    }
    ret[0] = q;
    ret[1] = r;
    return ret;
}
 
開發者ID:kredel,項目名稱:java-algebra-system,代碼行數:74,代碼來源:FDUtil.java


注:本文中的edu.jas.poly.ExpVector.equals方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。