Package cc.redberry.rings.poly.univar
Class HenselLifting.lQuadraticLift
- java.lang.Object
-
- cc.redberry.rings.poly.univar.HenselLifting.lQuadraticLift
-
- All Implemented Interfaces:
HenselLifting.LiftableQuintet<UnivariatePolynomialZp64>
- Enclosing class:
- HenselLifting
public static final class HenselLifting.lQuadraticLift extends Object
Quadratic Hensel lift for machine word arithmetics. On eachHenselLifting.LiftableQuintet.lift()operation modulus is raised asmodulus = modulus * modulus.
-
-
Field Summary
Fields Modifier and Type Field Description protected PolyZpaCoFactorxgcd coefficientsprotected PolyZpaFactorTwo factors of the initial Z[x] polyUnivariatePolynomialZ64baseInitial Z[x] polyprotected PolyZpbCoFactorxgcd coefficientsprotected PolyZpbFactorTwo factors of the initial Z[x] polylongmodulusThe modulus
-
Constructor Summary
Constructors Constructor Description lQuadraticLift(long modulus, UnivariatePolynomialZ64 base, UnivariatePolynomialZp64 aFactor, UnivariatePolynomialZp64 bFactor, UnivariatePolynomialZp64 aCoFactor, UnivariatePolynomialZp64 bCoFactor)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description PolyZpaCoFactorMod()Returns first co-factor liftedPolyZpaFactorMod()Returns first factor liftedPolyZpbCoFactorMod()Returns second co-factor liftedPolyZpbFactorMod()Returns second factor liftedvoidlift()Performs single lift step.voidliftLast()Performs single lift step but don't lift co-factors (xgcd coefficients).UnivariatePolynomialZp64polyMod()Returns initial Z[x] polynomial modulo lifted modulus-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface cc.redberry.rings.poly.univar.HenselLifting.LiftableQuintet
lift, liftWithCoFactors
-
-
-
-
Field Detail
-
modulus
public long modulus
The modulus
-
base
public final UnivariatePolynomialZ64 base
Initial Z[x] poly
-
aFactor
protected PolyZp extends IUnivariatePolynomial<PolyZp> aFactor
Two factors of the initial Z[x] poly
-
bFactor
protected PolyZp extends IUnivariatePolynomial<PolyZp> bFactor
Two factors of the initial Z[x] poly
-
aCoFactor
protected PolyZp extends IUnivariatePolynomial<PolyZp> aCoFactor
xgcd coefficients
-
bCoFactor
protected PolyZp extends IUnivariatePolynomial<PolyZp> bCoFactor
xgcd coefficients
-
-
Constructor Detail
-
lQuadraticLift
public lQuadraticLift(long modulus, UnivariatePolynomialZ64 base, UnivariatePolynomialZp64 aFactor, UnivariatePolynomialZp64 bFactor, UnivariatePolynomialZp64 aCoFactor, UnivariatePolynomialZp64 bCoFactor)
-
-
Method Detail
-
polyMod
public UnivariatePolynomialZp64 polyMod()
Description copied from interface:HenselLifting.LiftableQuintetReturns initial Z[x] polynomial modulo lifted modulus- Returns:
- initial Z[x] polynomial modulo lifted modulus
-
aFactorMod
public PolyZp aFactorMod()
Description copied from interface:HenselLifting.LiftableQuintetReturns first factor lifted- Specified by:
aFactorModin interfaceHenselLifting.LiftableQuintet<PolyZp extends IUnivariatePolynomial<PolyZp>>- Returns:
- first factor lifted
-
bFactorMod
public PolyZp bFactorMod()
Description copied from interface:HenselLifting.LiftableQuintetReturns second factor lifted- Specified by:
bFactorModin interfaceHenselLifting.LiftableQuintet<PolyZp extends IUnivariatePolynomial<PolyZp>>- Returns:
- second factor lifted
-
aCoFactorMod
public PolyZp aCoFactorMod()
Description copied from interface:HenselLifting.LiftableQuintetReturns first co-factor lifted- Specified by:
aCoFactorModin interfaceHenselLifting.LiftableQuintet<PolyZp extends IUnivariatePolynomial<PolyZp>>- Returns:
- first co-factor lifted
-
bCoFactorMod
public PolyZp bCoFactorMod()
Description copied from interface:HenselLifting.LiftableQuintetReturns second co-factor lifted- Specified by:
bCoFactorModin interfaceHenselLifting.LiftableQuintet<PolyZp extends IUnivariatePolynomial<PolyZp>>- Returns:
- second co-factor lifted
-
lift
public final void lift()
Description copied from interface:HenselLifting.LiftableQuintetPerforms single lift step.- Specified by:
liftin interfaceHenselLifting.LiftableQuintet<PolyZp extends IUnivariatePolynomial<PolyZp>>
-
liftLast
public final void liftLast()
Description copied from interface:HenselLifting.LiftableQuintetPerforms single lift step but don't lift co-factors (xgcd coefficients).- Specified by:
liftLastin interfaceHenselLifting.LiftableQuintet<PolyZp extends IUnivariatePolynomial<PolyZp>>
-
-