Child pages
  • Polynomial

Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Wiki Markup
{hiddendiv:style=display:none}
DO NOT EDIT THE CONTENT OF THIS PAGE DIRECTLY (EXCEPT INSIDE THE DIV BELOW WITH ID=DESCRIPTION), UNLESS YOU KNOW WHAT YOU'RE DOING.
		THE STRUCTURE OF THE CONTENT IS VITAL IN BEING ABLE TO EXTRACTAUTO CHANGESUPDATE FROM THE PAGECONTENT ANDTHROUGH MERGETHE THEM BACK INTO SERVOY SOURCE{hiddenDOC GENERATOR{div}
{sub-sectiondiv:id=description|text=}{sub-sectiondiv}\\ 

{table:id=|class=servoy sSummary}{colgroup}{column:width=80px|padding=0px}{column}{column}{column}{colgroup}{tr:style=height: 30px;}{th:colspan=2}Method Summary{th}{tr}{tbody}{tr}{td}void{td}{td}[#addPolynomial]\(polynomial)
Adds another polynomial to this polynomial.{td}{tr}{tbody}{tbody}{tr}{td}void{td}{td}[#addTerm]\(coefficient, exponent)
Adds a term to this polynomial.{td}{tr}{tbody}{tbody}{tr}{td}[Number]{td}{td}[#findRoot]\(startValue, error, iterations)
Finds a root of this polynomial using Newton's method, starting from an initial search value, and with a given precision.{td}{tr}{tbody}{tbody}{tr}{td}[Polynomial]{td}{td}[#getDerivative]\()
Returns a polynomial that holds the derivative of this polynomial.{td}{tr}{tbody}{tbody}{tr}{td}[Number]{td}{td}[#getDerivativeValue]\(x)
Returns the value of the derivative of this polynomial in a certain point.{td}{tr}{tbody}{tbody}{tr}{td}[Number]{td}{td}[#getValue]\(x)
Returns the value of this polynomial in a certain point.{td}{tr}{tbody}{tbody}{tr}{td}void{td}{td}[#multiplyByPolynomial]\(polynomial)
Multiplies this polynomial with another polynomial.{td}{tr}{tbody}{tbody}{tr}{td}void{td}{td}[#multiplyByTerm]\(coefficient, exponent)
Multiples this polynomial with a term.{td}{tr}{tbody}{tbody}{tr}{td}void{td}{td}[#setToZero]\()
Sets this polynomial to zero.{td}{tr}{tbody}{table}\\ 

{table:id=function|class=servoy sDetail}{colgroup}{column:width=100%|padding=0px}{column}{colgroup}{tr:style=height: 30px;}{th:colspan=1}Method Details{th}{tr}{tbody:id=addPolynomial-Polynomial|class=node}{tr:id=name}{td}h6.addPolynomial{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}void{span}{span:id=iets|style=float: left; font-weight: bold;}addPolynomial{span}{span:id=iets|style=float: left;}}\(polynomial){span}{td}{tr}{builder-show:permission=edit}{tr:id=desprs}{td}{sub-section:addPolynomial-Polynomial_des|trigger=button|text=}{sub-section}{sub-section:addPolynomial-Polynomial_des|trigger=none|class=sIndent}Replace with description{sub-section*Parameters*\\{div:class=sIndent}\{[Polynomial]} polynomial
{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=snc}{tr:id=ret}{td}*SinceReturns*\\{sub-section:addPolynomial-Polynomial_snc|trigger=button|text=}{sub-section}{sub-section:addPolynomial-Polynomial_snc|trigger=none|div:class=sIndent} Replace with version info{sub-sectionvoid{div}{td}{tr}{builder-show}{tr:id=prssam}{td}*ParametersSample*\\{sub-section:addPolynomial-Polynomial_prs|trigger=button|text=}{sub-section}{sub-section:addPolynomial-Polynomial_prs|trigger=none|class=sIndent}\{[Polynomial]} polynomial
{sub-section}{td}{tr}{tr:id=ret}{td}*Returns*\\{sub-section:addPolynomial-Polynomial_ret|trigger=button|text=}{sub-section}{sub-section:addPolynomial-Polynomial_ret|trigger=none|class=sIndent}void{sub-section}{td}{tr}{builder-show:permission=edit}{tr:id=see}{td}*Also see*\\{sub-section:addPolynomial-Polynomial_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:addPolynomial-Polynomial_see|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=link}{td}*External links*\\{sub-section:addPolynomial-Polynomial_link|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:addPolynomial-Polynomial_link|trigger=none}{sub-section}{divdiv:class=sIndent}{code:language=javascript}
// (x+1) + 2*(x+1)*x + 3*(x+1)*x^2 + 4*(x+1)*x^3
var eq = plugins.amortization.newPolynomial();
for (var i = 0; i < 4; i++)
{
	var base = plugins.amortization.newPolynomial();
	base.addTerm(1, 1);
	base.addTerm(1, 0);
	base.multiplyByTerm(1, i);
	base.multiplyByTerm(i + 1, 0);
	eq.addPolynomial(base);
}
application.output(eq.getValue(2));
{code}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=addTerm-Number_Number}{tr:id=name}{td}h6.addTerm{td}{tr}{tr:id=sig}{td}{span:style=margin-right: 5px;}void{span}{span:style=font-weight: bold;}addTerm{span}{span}\(coefficient, exponent){span}{td}{tr}{builder-show}{tr:id=samprs}{td}*SampleParameters*\\{sub-section:addPolynomial-Polynomial_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:addPolynomial-Polynomial_sam|trigger=none\{[Number]} coefficient
\{[Number]} exponent
{div}{td}{tr}{tr:id=ret}{td}*Returns*\\{div:class=sIndent}void{div}{td}{tr}{tr:id=sam}{td}*Sample*\\{div:class=sIndent}{code:language=javascript}
// (x+1) + 2*(x+1)*x + 3*(x+1)*x^2 + 4*(x+1)*x^3
var eq = plugins.amortization.newPolynomial();
for (var i = 0; i < 4; i++)
{
	var base = plugins.amortization.newPolynomial();
	base.addTerm(1, 1);
	base.addTerm(1, 0);
	base.multiplyByTerm(1, i);
	base.multiplyByTerm(i + 1, 0);
	eq.addPolynomial(base);
}
application.output(eq.getValue(2));
{code}{sub-sectiondiv}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=addTermfindRoot-Number_Number|class=node_Number}{tr:id=name}{td}h6.addTermfindRoot{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}void[Number]{span}{span:id=iets|style=float: left; font-weight: bold;}addTermfindRoot{span}{span:id=iets|style=float: left;}\(coefficientstartValue, error, exponentiterations){span}{td}{tr}{builder-show:permission=edit}{tr:id=desprs}{td}{sub-section:addTerm-Number_Number_des|trigger=button|text=}{sub-section}{sub-section:addTerm-Number_Number_des|trigger=none|class=sIndent}Replace with description{sub-section*Parameters*\\{div:class=sIndent}\{[Number]} startValue
\{[Number]} error
\{[Number]} iterations
{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=sncret}{td}*SinceReturns*\\{sub-section:addTerm-Number_Number_snc|trigger=button|text=}{sub-section}{sub-section:addTerm-Number_Number_snc|trigger=none|class=sIndent} Replace with version info{sub-section}{div:class=sIndent}[Number]{div}{td}{tr}{builder-show}{tr:id=prssam}{td}*ParametersSample*\\{sub-section:addTerm-Number_Number_prs|trigger=button|text=}{sub-section}{sub-section:addTerm-Number_Number_prs|trigger=none|class=sIndent}\{[Number]} coefficient
\{[Number]} exponent
{sub-section}{td}{tr}{tr:id=ret}{td}*Returns*\\{sub-section:addTerm-Number_Number_ret|trigger=button|text=}{sub-section}{sub-section:addTerm-Number_Number_ret|trigger=none|class=sIndent}void{sub-section}{td}{tr}{builder-show:permission=edit}{tr:id=see}{td}*Also see*\\{sub-section:addTerm-Number_Number_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:addTerm-Number_Number_see|trigger=none}{sub-section}{div:class=sIndent}{code:language=javascript}
// Model the quadratic equation -x^2 + 4x + 0.6 = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(-1, 2);
eq.addTerm(4, 1);
eq.addTerm(0.6, 0);
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
// Find the minimum/maximum point by zeroing the first derivative.
var deriv = eq.getDerivative();
rd = deriv.findRoot(0, 1E-5, 1000);
application.output("Min/max point: " + rd);
application.output("Min/max value: " + eq.getValue(rd));
if (deriv.getDerivativeValue(rd) < 0) application.output("Max point.");
else application.output("Min point.");
{code}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=linktr:class=lastDetailRow}{td}{td}*External links*\\{sub-section:addTerm-Number_Number_link|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:addTerm-Number_Number_link|trigger=none}{sub-section}{div}{tr}{tbody}{tbody:id=getDerivative}{tr:id=name}{td}h6.getDerivative{td}{tr}{builder-show}{tr:tr:id=samsig}{td}*Sample*\\{sub-section:addTerm-Number_Number_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:addTerm-Number_Number_sam|trigger=none}{code:language=javascript}
// (x+1) + 2*(x+1)*x + 3*(x+1)*x^2 + 4*(x+1)*x^3
var eq = plugins.amortization.newPolynomial();
for (var i = 0; i < 4; i++)
{
	var base{span:style=margin-right: 5px;}[Polynomial]{span}{span:style=font-weight: bold;}getDerivative{span}{span}\(){span}{td}{tr}{tr:id=ret}{td}*Returns*\\{div:class=sIndent}[Polynomial]{div}{td}{tr}{tr:id=sam}{td}*Sample*\\{div:class=sIndent}{code:language=javascript}
// Model the quadratic equation -x^2 + 4x + 0.6 = 0
var eq = plugins.amortization.newPolynomial();
	baseeq.addTerm(-1, 12);
	baseeq.addTerm(14, 01);
	baseeq.multiplyByTermaddTerm(10.6, i0);
	base.multiplyByTerm(i + 1, 0);
	eq.addPolynomial(base);
}
application.output(eq.getValue(2));
{code}{sub-section}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=findRoot-Number_Number_Number|class=node}{tr:id=name}{td}h6.findRoot{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}[Number]{span}{span:id=iets|style=float: left; font-weight: bold;}findRoot{span}{span:id=iets|style=float: left;}\(startValue, error, iterations){span}{td}{tr}{builder-show:permission=edit}{tr:id=des}{td}{sub-section:findRoot-Number_Number_Number_des|trigger=button|text=}{sub-section}{sub-section:findRoot-Number_Number_Number_des|trigger=none|class=sIndent}Replace with description{sub-section}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=snc}{td}*Since*\\{sub-section:findRoot-Number_Number_Number_snc|trigger=button|text=}{sub-section}{sub-section:findRoot-Number_Number_Number_snc|trigger=none|class=sIndent} Replace with version info{sub-section}{td}{tr}{builder-show}{tr:id=prs}{td}*Parameters*\\{sub-section:findRoot-Number_Number_Number_prs|trigger=button|text=}{sub-section}{sub-section:findRoot-Number_Number_Number_prs|trigger=none|class=sIndent}\{[Number]} startValue
\{[Number]} error
\{[Number]} iterations
{sub-section}{
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
// Find the minimum/maximum point by zeroing the first derivative.
var deriv = eq.getDerivative();
rd = deriv.findRoot(0, 1E-5, 1000);
application.output("Min/max point: " + rd);
application.output("Min/max value: " + eq.getValue(rd));
if (deriv.getDerivativeValue(rd) < 0) application.output("Max point.");
else application.output("Min point.");
{code}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=getDerivativeValue-Number}{tr:id=name}{td}h6.getDerivativeValue{td}{tr}{tr:id=sig}{td}{span:style=margin-right: 5px;}[Number]{span}{span:style=font-weight: bold;}getDerivativeValue{span}{span}\(x){span}{td}{tr}{tr:id=prs}{td}*Parameters*\\{div:class=sIndent}\{[Number]} x
{div}{td}{tr}{tr:id=ret}{td}*Returns*\\{div:class=sIndent}[Number]{div}{td}{tr}{tr:id=retsam}{td}*ReturnsSample*\\{sub-section:findRoot-Number_Number_Number_ret|trigger=button|text=}{sub-section}{sub-section:findRoot-Number_Number_Number_ret|trigger=none|class=sIndent}[Number]{sub-section}{td}{tr}{builder-show:permission=edit}{tr:id=see}{td}*Also see*\\{sub-section:findRoot-Number_Number_Number_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:findRoot-Number_Number_Number_see|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=link}{td}*External links*\\{sub-section:findRoot-Number_Number_Number_link|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:findRoot-Number_Number_Number_link|trigger=none}{sub-section}{div:class=sIndent}{code:language=javascript}
// Model the quadratic equation -x^2 + 4x + 0.6 = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(-1, 2);
eq.addTerm(4, 1);
eq.addTerm(0.6, 0);
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
// Find the minimum/maximum point by zeroing the first derivative.
var deriv = eq.getDerivative();
rd = deriv.findRoot(0, 1E-5, 1000);
application.output("Min/max point: " + rd);
application.output("Min/max value: " + eq.getValue(rd));
if (deriv.getDerivativeValue(rd) < 0) application.output("Max point.");
else application.output("Min point.");
{code}{div}{td}{tr}{builder-show}{tr:id=samclass=lastDetailRow}{td}{td}*Sample*\\{sub-section:findRoot-Number_Number_Number_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:findRoot-Number_Number_Number_sam|trigger=none}{code:language=javascript}
// Model the quadratic equation -x^2 + 4x + 0.6 = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(-1, 2);
eq.addTerm(4, 1);
eq.addTerm({tr}{tbody}{tbody:id=getValue-Number}{tr:id=name}{td}h6.getValue{td}{tr}{tr:id=sig}{td}{span:style=margin-right: 5px;}[Number]{span}{span:style=font-weight: bold;}getValue{span}{span}\(x){span}{td}{tr}{tr:id=prs}{td}*Parameters*\\{div:class=sIndent}\{[Number]} x
{div}{td}{tr}{tr:id=ret}{td}*Returns*\\{div:class=sIndent}[Number]{div}{td}{tr}{tr:id=sam}{td}*Sample*\\{div:class=sIndent}{code:language=javascript}
// Model the quadratic equation -x^2 + 4x + 0.6 = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(-1, 2);
eq.addTerm(4, 1);
eq.addTerm(0.6, 0);
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
// Find the minimum/maximum point by zeroing the first derivative.
var deriv = eq.getDerivative();
rd = deriv.findRoot(0, 1E-5, 1000);
application.output("Min/max point: " + rd);
application.output("Min/max value: " + eq.getValue(rd));
if (deriv.getDerivativeValue(rd) < 0) application.output("Max point.");
else application.output("Min point.");
{code}{sub-section}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=getDerivative|class=nodemultiplyByPolynomial-Polynomial}{tr:id=name}{td}h6.getDerivativemultiplyByPolynomial{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}[Polynomial]void{span}{span:id=iets|style=float: left; fontstyle=font-weight: bold;}getDerivativemultiplyByPolynomial{span}{span:id=iets|style=float: left;}\(polynomial){span}{td}{tr}{builder-show:permission=edit}{tr:id=desprs}{td}{sub-section:getDerivative_des|trigger=button|text=}{sub-section}{sub-section:getDerivative_des|trigger=none|class=sIndent}Replace with description{sub-section*Parameters*\\{div:class=sIndent}\{[Polynomial]} polynomial
{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=sncret}{td}*SinceReturns*\\{sub-section:getDerivative_snc|trigger=button|text=}{sub-section}{sub-section:getDerivative_snc|trigger=none|div:class=sIndent} Replace with version info{sub-sectionvoid{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=prssam}{td}*ParametersSample*\\{sub-section:getDerivative_prs|trigger=button|text=}{sub-section}{sub-section:getDerivative_prs|trigger=none|div:class=sIndent}{sub-section}{td}{tr}{builder-show}{tr:id=ret}{td}*Returns*\\{sub-section:getDerivative_ret|trigger=button|text=}{sub-section}{sub-section:getDerivative_ret|trigger=none|class=sIndent}[Polynomial]{sub-section}{td}{tr}{builder-show:permission=edit}{tr:id=see}{td}*Also see*\\{sub-section:getDerivative_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getDerivative_see|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=link}{td}*External links*\\{sub-section:getDerivative_link|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getDerivative_link|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{tr:id=sam}{td}*Sample*\\{sub-section:getDerivative_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getDerivative_sam|trigger=none}{code:language=javascript}
// Model the quadratic equation -x^2 + 4x + 0.6 = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(-1, 2);
eq.addTerm(4, 1);
eq.addTerm(0.6, 0);
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
// Find the minimum/maximum point by zeroing the first derivative.
var deriv = eq.getDerivative();
rd = deriv.findRoot(0, 1E-5, 1000);
application.output("Min/max point: " + rd);
application.output("Min/max value: " + eq.getValue(rd));
if (deriv.getDerivativeValue(rd) < 0) application.output("Max point.");
else application.output("Min point.");
{code}{sub-section}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=getDerivativeValue-Number|class=node}{tr:id=name}{td}h6.getDerivativeValue{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}[Number]{span}{span:id=iets|style=float: left; font-weight: bold;}getDerivativeValue{span}{span:id=iets|style=float: left;}\(x){span}{td}{tr}{builder-show:permission=edit}{tr:id=des}{td}{sub-section:getDerivativeValue-Number_des|trigger=button|text=}{sub-section}{sub-section:getDerivativeValue-Number_des|trigger=none|class=sIndent}Replace with description{sub-section}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=snc}{td}*Since*\\{sub-section:getDerivativeValue-Number_snc|trigger=button|text=}{sub-section}{sub-section:getDerivativeValue-Number_snc|trigger=none|class=sIndent} Replace with version info{sub-section}{td}{tr}{builder-show}{tr:id=prs}{td}*Parameters*\\{sub-section:getDerivativeValue-Number_prs|trigger=button|text=}{sub-section}{sub-section:getDerivativeValue-Number_prs|trigger=none|class=sIndent}\{[Number]} x
{sub-section}{td}{tr}{tr:id=ret}{td}*Returns*\\{sub-section:getDerivativeValue-Number_ret|trigger=button|text=}{sub-section}{sub-section:getDerivativeValue-Number_ret|trigger=none|class=sIndent}[Number]{sub-section}{td}{tr}{builder-show:permission=edit}{tr:id=see}{td}*Also see*\\{sub-section:getDerivativeValue-Number_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getDerivativeValue-Number_see|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=link}{td}*External links*\\{sub-section:getDerivativeValue-Number_link|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getDerivativeValue-Number_link|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{tr:id=sam}{td}*Sample*\\{sub-section:getDerivativeValue-Number_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getDerivativeValue-Number_sam|trigger=none}{code:language=javascript}
// Model the quadratic equation -x^2 + 4x + 0.6 = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(-1, 2);
eq.addTerm(4, 1);
eq.addTerm(0.6, 0);
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
// Find the minimum/maximum point by zeroing the first derivative.
var deriv = eq.getDerivative();
rd = deriv.findRoot(0, 1E-5, 1000);
application.output("Min/max point: " + rd);
application.output("Min/max value: " + eq.getValue(rd));
if (deriv.getDerivativeValue(rd) < 0) application.output("Max point.");
else application.output("Min point.");
{code}{sub-section}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=getValue-Number|class=node}{tr:id=name}{td}h6.getValue{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}[Number]{span}{span:id=iets|style=float: left; font-weight: bold;}getValue{span}{span:id=iets|style=float: left;}\(x){span}{td}{tr}{builder-show:permission=edit}{tr:id=des}{td}{sub-section:getValue-Number_des|trigger=button|text=}{sub-section}{sub-section:getValue-Number_des|trigger=none|class=sIndent}Replace with description{sub-section}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=snc}{td}*Since*\\{sub-section:getValue-Number_snc|trigger=button|text=}{sub-section}{sub-section:getValue-Number_snc|trigger=none|class=sIndent} Replace with version info{sub-section}{td}{tr}{builder-show}{tr:id=prs}{td}*Parameters*\\{sub-section:getValue-Number_prs|trigger=button|text=}{sub-section}{sub-section:getValue-Number_prs|trigger=none|class=sIndent}\{[Number]} x
{sub-section}{td}{tr}{tr:id=ret}{td}*Returns*\\{sub-section:getValue-Number_ret|trigger=button|text=}{sub-section}{sub-section:getValue-Number_ret|trigger=none|class=sIndent}[Number]{sub-section}{td}{tr}{builder-show:permission=edit}{tr:id=see}{td}*Also see*\\{sub-section:getValue-Number_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getValue-Number_see|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=link}{td}*External links*\\{sub-section:getValue-Number_link|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getValue-Number_link|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{tr:id=sam}{td}*Sample*\\{sub-section:getValue-Number_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:getValue-Number_sam|trigger=none}{code:language=javascript}
// Model the quadratic equation -x^2 + 4x + 0.6 = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(-1, 2);
eq.addTerm(4, 1);
eq.addTerm(0.6, 0);
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
// Find the minimum/maximum point by zeroing the first derivative.
var deriv = eq.getDerivative();
rd = deriv.findRoot(0, 1E-5, 1000);
application.output("Min/max point: " + rd);
application.output("Min/max value: " + eq.getValue(rd));
if (deriv.getDerivativeValue(rd) < 0) application.output("Max point.");
else application.output("Min point.");
{code}{sub-section}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=multiplyByPolynomial-Polynomial|class=node}{tr:id=name}{td}h6.multiplyByPolynomial{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}void{span}{span:id=iets|style=float: left; font-weight: bold;}multiplyByPolynomial{span}{span:id=iets|style=float: left;}\(polynomial){span}{td}{tr}{builder-show:permission=edit}{tr:id=des}{td}{sub-section:multiplyByPolynomial-Polynomial_des|trigger=button|text=}{sub-section}{sub-section:multiplyByPolynomial-Polynomial_des|trigger=none|class=sIndent}Replace with description{sub-section}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=snc}{td}*Since*\\{sub-section:multiplyByPolynomial-Polynomial_snc|trigger=button|text=}{sub-section}{sub-section:multiplyByPolynomial-Polynomial_snc|trigger=none|class=sIndent} Replace with version info{sub-section}{td}{tr}{builder-show}{tr:id=prs}{td}*Parameters*\\{sub-section:multiplyByPolynomial-Polynomial_prs|trigger=button|text=}{sub-section}{sub-section:multiplyByPolynomial-Polynomial_prs|trigger=none|class=sIndent}\{[Polynomial]} polynomial
{sub-section}{td}{tr}{tr:id=ret}{td}*Returns*\\{sub-section:multiplyByPolynomial-Polynomial_ret|trigger=button|text=}{sub-section}{sub-section:multiplyByPolynomial-Polynomial_ret|trigger=none|class=sIndent}void{sub-section}{td}{tr}{builder-show:permission=edit}{tr:id=see}{td}*Also see*\\{sub-section:multiplyByPolynomial-Polynomial_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:multiplyByPolynomial-Polynomial_see|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=link}{td}*External links*\\{sub-section:multiplyByPolynomial-Polynomial_link|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:multiplyByPolynomial-Polynomial_link|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{tr:id=sam}{td}*Sample*\\{sub-section:multiplyByPolynomial-Polynomial_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:multiplyByPolynomial-Polynomial_sam|trigger=none}{code:language=javascript}
// Model the quadratic equation (x+1)*(x+2) = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(1, 1);
eq.addTerm(1, 0);
var eq2 = plugins.amortization.newPolynomial();
eq2.addTerm(1, 1);
eq2.addTerm(2, 0);
eq.multiplyByPolynomial(eq2);
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
{code}{sub-section}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=multiplyByTerm-Number_Number|class=node}{tr:id=name}{td}h6.multiplyByTerm{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}void{span}{span:id=iets|style=float: left; font-weight: bold;}multiplyByTerm{span}{span:id=iets|style=float: left;}\(coefficient, exponent){span}{td}{tr}{builder-show:permission=edit}{tr:id=des}{td}{sub-section:multiplyByTerm-Number_Number_des|trigger=button|text=}{sub-section}{sub-section:multiplyByTerm-Number_Number_des|trigger=none|class=sIndent}Replace with description{sub-section}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=snc}{td}*Since*\\{sub-section:multiplyByTerm-Number_Number_snc|trigger=button|text=}{sub-section}{sub-section:multiplyByTerm-Number_Number_snc|trigger=none|class=sIndent} Replace with version info{sub-section}{td}{tr}{builder-show}{tr:id=prs}{td}*Parameters*\\{sub-section:multiplyByTerm-Number_Number_prs|trigger=button|text=}{sub-section}{sub-section:multiplyByTerm-Number_Number_prs|trigger=none|class=sIndent}\{[Number]} coefficient
\{[Number]} exponent
{sub-section}{td}{tr}{tr:id=ret}{td}*Returns*\\{sub-section:multiplyByTerm-Number_Number_ret|trigger=button|text=}{sub-section}{sub-section:multiplyByTerm-Number_Number_ret|trigger=none|class=sIndent}void{sub-section}{td}{tr}{builder-show:permission=edit}{tr:id=see}{td}*Also see*\\{sub-section:multiplyByTerm-Number_Number_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:multiplyByTerm-Number_Number_see|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=link}{td}*External links*\\{sub-section:multiplyByTerm-Number_Number_link|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:multiplyByTerm-Number_Number_link|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{tr:id=sam}{td}*Sample*\\{sub-section:multiplyByTerm-Number_Number_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:multiplyByTerm-Number_Number_sam|trigger=none}{code:language=javascript}
// (x+1) + 2*(x+1)*x + 3*(x+1)*x^2 + 4*(x+1)*x^3
var eq = plugins.amortization.newPolynomial();
for (var i = 0; i < 4; i++)
{
	var base = plugins.amortization.newPolynomial();
	base.addTerm(1, 1);
	base.addTerm(1, 0);
	base.multiplyByTerm(1, i);
	base.multiplyByTerm(i + 1, 0);
	eq.addPolynomial(base);
}
application.output(eq.getValue(2));
{code}{sub-sectioncode:language=javascript}
// Model the quadratic equation (x+1)*(x+2) = 0
var eq = plugins.amortization.newPolynomial();
eq.addTerm(1, 1);
eq.addTerm(1, 0);
var eq2 = plugins.amortization.newPolynomial();
eq2.addTerm(1, 1);
eq2.addTerm(2, 0);
eq.multiplyByPolynomial(eq2);
// Find the roots of the equation.
r1 = eq.findRoot(100, 1E-5, 1000);
r2 = eq.findRoot(-100, 1E-5, 1000);
application.output("eq(" + r1 + ")=" + eq.getValue(r1));
application.output("eq(" + r2 + ")=" + eq.getValue(r2));
{code}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{tbody:id=setToZero|class=nodemultiplyByTerm-Number_Number}{tr:id=name}{td}h6.setToZeromultiplyByTerm{td}{tr}{tr:id=sig}{td}{span:style=float: left; margin-right: 5px;}void{span}{span:id=iets|style=floatfont-weight: left; font-weight: bold;}setToZero{span}{span:id=iets|style=float: left;}\(){spanbold;}multiplyByTerm{span}{span}\(coefficient, exponent){span}{td}{tr}{tr:id=prs}{td}*Parameters*\\{div:class=sIndent}\{[Number]} coefficient
\{[Number]} exponent
{div}{td}{tr}{builder-show:permission=edit}{tr:id=desret}{td}{sub-section:setToZero_des|trigger=button|text=}{sub-section}{sub-section:setToZero_des|trigger=none|*Returns*\\{div:class=sIndent}Replace with description{sub-sectionvoid{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=sncsam}{td}*SinceSample*\\{sub-section:setToZero_snc|trigger=button|text=}{sub-section}{sub-section:setToZero_snc|trigger=none|class=sIndent} Replace with version info{sub-section}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=prs}{td}*Parameters*\\{sub-section:setToZero_prs|trigger=button|text=}{sub-section}{sub-section:setToZero_prs|trigger=none|class=sIndent}{sub-section}{td}{tr}{builder-show}{tr:id=ret}{td}*Returns*\\{sub-section:setToZero_ret|trigger=button|text=}{sub-section}{sub-section:setToZero_ret|trigger=none|class=sIndent}void{sub-sectiondiv:class=sIndent}{code:language=javascript}
// (x+1) + 2*(x+1)*x + 3*(x+1)*x^2 + 4*(x+1)*x^3
var eq = plugins.amortization.newPolynomial();
for (var i = 0; i < 4; i++)
{
	var base = plugins.amortization.newPolynomial();
	base.addTerm(1, 1);
	base.addTerm(1, 0);
	base.multiplyByTerm(1, i);
	base.multiplyByTerm(i + 1, 0);
	eq.addPolynomial(base);
}
application.output(eq.getValue(2));
{code}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{builder-show:permission=edittbody}{tbody:id=setToZero}{tr:id=seename}{td}*Also see*\\{sub-section:setToZero_see|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:setToZero_see|trigger=none}{sub-section}{div}{td}{tr}{builder-show}{builder-show:permission=edit}{tr:id=link}{td}*External links*\\{sub-section:setToZero_link|trigger=button|text=}{sub-section}h6.setToZero{td}{tr}{tr:id=sig}{td}{span:style=margin-right: 5px;}void{span}{span:style=font-weight: bold;}setToZero{span}{span}\(){span}{td}{tr}{tr:id=ret}{td}*Returns*\\{div:class=sIndent}{sub-section:setToZero_link|trigger=none}{sub-section}{void{div}{td}{tr}{builder-show}{tr:id=sam}{td}*Sample*\\{sub-section:setToZero_sam|trigger=button|text=}{sub-section}{div:class=sIndent}{sub-section:setToZero_sam|trigger=none}{code:language=javascript}
var eq = plugins.amortization.newPolynomial();
eq.addTerm(2, 3);
application.output(eq.getValue(1.1));
eq.setToZero();
application.output(eq.getValue(1.1));
{code}{sub-section}{div}{td}{tr}{tr:class=lastDetailRow}{td}{td}{tr}{tbody}{table}