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


Java Monomial.exponent方法代碼示例

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


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

示例1: jasToPoly

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Transforms a JAS polynomial to a Polynomial object.
 * 
 * @param j JAS polynomial
 * @return polynomial of Polynomial class
 */
private Polynomial jasToPoly(GenPolynomial<BigInteger> j)
{
	int numVariables = j.numberOfVariables();
	Polynomial result = new Polynomial(numVariables, j.length());
	for (Monomial<BigInteger> jasMono : j) {
		java.math.BigInteger coeff = (jasMono.coefficient()).getVal();
		ExpVector jasExpo = jasMono.exponent();
		ArrayList<Integer> expo = new ArrayList<Integer>();
		for (int var = 0; var < numVariables; var++) {
			expo.add((int)jasExpo.getVal(var));
		}
		result.addTerm(coeff, expo);
	}
	
	return result;
}
 
開發者ID:musaeed,項目名稱:Prism-gsoc16,代碼行數:23,代碼來源:JasFunction.java

示例2: monomialListModulus

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Get the monomial list of a univariate polynomial with coefficients reduced by a modulo value.
 * 
 * @param polynomial
 * @param variable
 * @param termOrder
 *            the JAS term ordering
 * @param option
 *            the &quot;Modulus&quot; option
 * @return the list of monomials of the univariate polynomial.
 */
private static IAST monomialListModulus(IExpr polynomial, List<IExpr> variablesList, final TermOrder termOrder,
		IExpr option) throws JASConversionException {
	try {
		// found "Modulus" option => use ModIntegerRing
		ModLongRing modIntegerRing = JASModInteger.option2ModLongRing((ISignedNumber) option);
		JASModInteger jas = new JASModInteger(variablesList, modIntegerRing);
		GenPolynomial<ModLong> polyExpr = jas.expr2JAS(polynomial);
		IASTAppendable list = F.ListAlloc(polyExpr.length());
		for (Monomial<ModLong> monomial : polyExpr) {
			ModLong coeff = monomial.coefficient();
			ExpVector exp = monomial.exponent();
			IASTAppendable monomTimes = F.TimesAlloc(exp.length() + 1);
			jas.monomialToExpr(F.integer(coeff.getVal()), exp, monomTimes);
			list.append(monomTimes);
		}
		return list;
	} catch (ArithmeticException ae) {
		// toInt() conversion failed
		if (Config.DEBUG) {
			ae.printStackTrace();
		}
	}
	return F.NIL;
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:36,代碼來源:MonomialList.java

示例3: isQuadratic

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Check if the polynomial has maximum degree 2 in 1 variable and return the coefficients.
 * 
 * @param poly
 * @return <code>false</code> if the polynomials degree > 2 and number of variables <> 1
 */
public static boolean isQuadratic(GenPolynomial<BigRational> poly, BigRational[] result) {
	if (poly.degree() <= 2 && poly.numberOfVariables() == 1) {
		result[0] = BigRational.ZERO;
		result[1] = BigRational.ZERO;
		result[2] = BigRational.ZERO;
		for (Monomial<BigRational> monomial : poly) {
			BigRational coeff = monomial.coefficient();
			ExpVector exp = monomial.exponent();
			for (int i = 0; i < exp.length(); i++) {
				result[(int) exp.getVal(i)] = coeff;
			}
		}
		return true;
	}
	return false;
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:23,代碼來源:Integrate.java

示例4: isQuadratic

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Check if the polynomial has maximum degree 2 in 1 variable and return the
 * coefficients.
 * 
 * @param poly
 * @return <code>null</code> if the polynomials degree > 2 and number of
 *         variables <> 1
 */
public static boolean isQuadratic(GenPolynomial<BigRational> poly, BigRational[] result) {
	if (poly.degree() <= 2 && poly.numberOfVariables() == 1) {
		result[0] = BigRational.ZERO;
		result[1] = BigRational.ZERO;
		result[2] = BigRational.ZERO;
		for (Monomial<BigRational> monomial : poly) {
			BigRational coeff = monomial.coefficient();
			ExpVector exp = monomial.exponent();
			for (int i = 0; i < exp.length(); i++) {
				result[(int) exp.getVal(i)] = coeff;
			}
		}
		return true;
	}
	return false;
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:25,代碼來源:PartialFractionIntegrateGenerator.java

示例5: integerPoly2Expr

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Convert a JAS integer polynomial to <code>IExpr</code>.
 * 
 * @param poly
 * @return
 * @throws ArithmeticException
 * @throws ClassCastException
 */
public IExpr integerPoly2Expr(final GenPolynomial<edu.jas.arith.BigInteger> poly)
		throws ArithmeticException, ClassCastException {
	if (poly.length() == 0) {
		return F.C0;
	}
	IASTAppendable result = F.PlusAlloc(poly.length());
	for (Monomial<edu.jas.arith.BigInteger> monomial : poly) {
		edu.jas.arith.BigInteger coeff = monomial.coefficient();
		ExpVector exp = monomial.exponent();
		IASTAppendable monomTimes = F.TimesAlloc(exp.length()+1);
		monomialToExpr(coeff, exp, monomTimes);
		result.append(monomTimes.getOneIdentity(F.C1));
	}
	return result.getOneIdentity(F.C0);
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:24,代碼來源:JASConvert.java

示例6: complexPoly2Expr

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Convert a JAS complex polynomial to <code>IExpr</code>.
 * 
 * @param poly
 * @return
 * @throws ArithmeticException
 * @throws ClassCastException
 */
public IExpr complexPoly2Expr(final GenPolynomial<Complex<BigRational>> poly)
		throws ArithmeticException, ClassCastException {
	if (poly.length() == 0) {
		return F.C0;
	}
	IASTAppendable result = F.PlusAlloc(poly.length());
	for (Monomial<Complex<BigRational>> monomial : poly) {
		Complex<BigRational> coeff = monomial.coefficient();
		ExpVector exp = monomial.exponent();
		IASTAppendable monomTimes = F.TimesAlloc(exp.length()+1);
		monomialToExpr(coeff, exp, monomTimes);
		result.append(monomTimes.getOneIdentity(F.C1));
	}
	return result.getOneIdentity(F.C0);
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:24,代碼來源:JASConvert.java

示例7: rationalPoly2Expr

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Converts a <a href="http://krum.rz.uni-mannheim.de/jas/">JAS</a>
 * polynomial to a MathEclipse AST with head <code>Plus</code>
 * 
 * @param poly
 *            a JAS polynomial
 * @param variable
 * @return
 * @throws ArithmeticException
 * @throws ClassCastException
 */
public IAST rationalPoly2Expr(final GenPolynomial<BigRational> poly)
		throws ArithmeticException, ClassCastException {
	if (poly.length() == 0) {
		return F.Plus(F.C0);
	}

	IASTAppendable result = F.PlusAlloc(poly.length());
	for (Monomial<BigRational> monomial : poly) {
		BigRational coeff = monomial.coefficient();
		ExpVector exp = monomial.exponent();
		IASTAppendable monomTimes = F.TimesAlloc(exp.length()+1);
		monomialToExpr(coeff, exp, monomTimes);
		result.append(monomTimes.getOneIdentity(F.C1));
	}
	return result;
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:28,代碼來源:JASConvert.java

示例8: exprPoly2Expr

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Converts a <a href="http://krum.rz.uni-mannheim.de/jas/">JAS</a> polynomial to a MathEclipse AST with head
 * <code>Plus</code>
 * 
 * @param poly
 *            a JAS polynomial
 * @param variable
 * @return
 * @throws ArithmeticException
 * @throws ClassCastException
 */
public IExpr exprPoly2Expr(final GenPolynomial<IExpr> poly, IExpr variable) {
	if (poly.length() == 0) {
		return F.C0;
	}

	IASTAppendable result = F.PlusAlloc(poly.length());
	for (Monomial<IExpr> monomial : poly) {
		IExpr coeff = monomial.coefficient();
		ExpVector exp = monomial.exponent();
		IASTAppendable monomTimes = F.TimesAlloc(exp.length() + 1);
		monomialToExpr(coeff, exp, monomTimes);
		result.append(monomTimes.getOneIdentity(F.C1));
	}
	return result.getOneIdentity(F.C0);
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:27,代碼來源:JASIExpr.java

示例9: coefficientRules

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Get exponent vectors and coefficients of monomials of a polynomial expression.
 * 
 * @param polynomial
 * @param variable
 * @param termOrder
 *            the JAS term ordering
 * @return the list of monomials of the univariate polynomial.
 */
public static IAST coefficientRules(IExpr polynomial, final List<IExpr> variablesList,
		final TermOrder termOrder) throws JASConversionException {
	JASIExpr jas = new JASIExpr(variablesList, ExprRingFactory.CONST, termOrder, false);
	GenPolynomial<IExpr> polyExpr = jas.expr2IExprJAS(polynomial);
	IASTAppendable resultList = F.ListAlloc(polyExpr.length());
	for (Monomial<IExpr> monomial : polyExpr) {

		IExpr coeff = monomial.coefficient();
		ExpVector exp = monomial.exponent();
		int len = exp.length();
		IASTAppendable ruleList = F.ListAlloc(len);
		for (int i = 0; i < len; i++) {
			ruleList.append(F.integer(exp.getVal(len - i - 1)));
		}
		resultList.append(F.Rule(ruleList, coeff));
	}
	return resultList;
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:28,代碼來源:PolynomialFunctions.java

示例10: complexPoly2Expr

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Convert a JAS complex polynomial to <code>IExpr</code>.
 * 
 * @param poly
 * @return
 * @throws ArithmeticException
 * @throws ClassCastException
 */
public IExpr complexPoly2Expr(final GenPolynomial<Complex<BigRational>> poly)
		throws ArithmeticException, ClassCastException {
	if (poly.length() == 0) {
		return F.C0;
	}
	IASTAppendable result = F.PlusAlloc(poly.length());
	for (Monomial<Complex<BigRational>> monomial : poly) {
		Complex<BigRational> coeff = monomial.coefficient();
		ExpVector exp = monomial.exponent();
		BigRational re = coeff.getRe();
		BigRational im = coeff.getIm();
		IASTAppendable monomTimes = F.Times(F.complex(F.fraction(re.numerator(), re.denominator()),
				F.fraction(im.numerator(), im.denominator())));
		long lExp;
		for (int i = 0; i < exp.length(); i++) {
			lExp = exp.getVal(i);
			if (lExp != 0) {
				monomTimes.append(F.Power(fVariables.get(i), F.integer(lExp)));
			}
		}
		if (monomTimes.isAST1()) {
			result.append(monomTimes.arg1());
		} else {
			result.append(monomTimes);
		}
	}
	if (result.isAST1()) {
		return result.arg1();
	} else {
		return result;
	}
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:41,代碼來源:JASIExpr.java

示例11: integerPoly2Expr

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Convert a JAS integer polynomial to <code>IExpr</code>.
 * 
 * @param poly
 * @return
 * @throws ArithmeticException
 * @throws ClassCastException
 */
public IExpr integerPoly2Expr(final GenPolynomial<edu.jas.arith.BigInteger> poly)
		throws ArithmeticException, ClassCastException {
	if (poly.length() == 0) {
		return F.C0;
	}
	IASTAppendable result = F.PlusAlloc(poly.length());
	for (Monomial<edu.jas.arith.BigInteger> monomial : poly) {
		edu.jas.arith.BigInteger coeff = monomial.coefficient();
		ExpVector exp = monomial.exponent();
		IInteger coeffValue = F.integer(coeff.getVal());
		IASTAppendable monomTimes = F.TimesAlloc(exp.length() + 1);
		monomTimes.append(coeffValue);
		long lExp;
		for (int i = 0; i < exp.length(); i++) {
			lExp = exp.getVal(i);
			if (lExp != 0) {
				monomTimes.append(F.Power(fVariables.get(i), F.integer(lExp)));
			}
		}
		if (monomTimes.isAST1()) {
			result.append(monomTimes.arg1());
		} else {
			result.append(monomTimes);
		}
	}
	if (result.isAST1()) {
		return result.arg1();
	} else {
		return result;
	}
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:40,代碼來源:JASIExpr.java

示例12: modLongPoly2Expr

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
public IExpr modLongPoly2Expr(final GenPolynomial<ModLong> poly) throws ArithmeticException, ClassCastException {
	if (poly.length() == 0) {
		return F.Plus(F.C0);
	}
	IASTAppendable result = F.PlusAlloc(poly.length());
	for (Monomial<ModLong> monomial : poly) {
		ModLong coeff = monomial.coefficient();
		ExpVector exp = monomial.exponent();
		IInteger coeffValue = F.integer(coeff.getVal());
		IASTAppendable monomTimes = F.TimesAlloc(exp.length() + 1);
		monomialToExpr(coeffValue, exp, monomTimes);
		result.append(monomTimes.getOneIdentity(F.C1));
	}
	return result.getOneIdentity(F.C0);
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:16,代碼來源:JASModInteger.java

示例13: coefficientRulesModulus

import edu.jas.poly.Monomial; //導入方法依賴的package包/類
/**
 * Get exponent vectors and coefficients of monomials of a polynomial expression.
 * 
 * @param polynomial
 * @param variable
 * @param termOrder
 *            the JAS term ordering
 * @param option
 *            the &quot;Modulus&quot; option
 * @return the list of monomials of the univariate polynomial.
 */
private static IAST coefficientRulesModulus(IExpr polynomial, List<IExpr> variablesList,
		final TermOrder termOrder, IExpr option) throws JASConversionException {
	try {
		// found "Modulus" option => use ModIntegerRing
		ModLongRing modIntegerRing = JASModInteger.option2ModLongRing((ISignedNumber) option);
		JASModInteger jas = new JASModInteger(variablesList, modIntegerRing);
		GenPolynomial<ModLong> polyExpr = jas.expr2JAS(polynomial);
		IASTAppendable resultList = F.ListAlloc(polyExpr.length());
		for (Monomial<ModLong> monomial : polyExpr) {
			ModLong coeff = monomial.coefficient();
			ExpVector exp = monomial.exponent();
			int len = exp.length();
			IASTAppendable ruleList = F.ListAlloc(len);
			for (int i = 0; i < len; i++) {
				ruleList.append(F.integer(exp.getVal(len - i - 1)));
			}
			resultList.append(F.Rule(ruleList, F.integer(coeff.getVal())));
		}
		return resultList;
	} catch (ArithmeticException ae) {
		// toInt() conversion failed
		if (Config.DEBUG) {
			ae.printStackTrace();
		}
	}
	return null;
}
 
開發者ID:axkr,項目名稱:symja_android_library,代碼行數:39,代碼來源:PolynomialFunctions.java


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