本文整理匯總了C#中YAMP.ScalarValue.Log方法的典型用法代碼示例。如果您正苦於以下問題:C# ScalarValue.Log方法的具體用法?C# ScalarValue.Log怎麽用?C# ScalarValue.Log使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類YAMP.ScalarValue
的用法示例。
在下文中一共展示了ScalarValue.Log方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: Polylog
public static ScalarValue Polylog(int n, ScalarValue z)
{
if (n == 2)
return SpenceFunction.DiLog(z);
if (n == -1)
return PolylogNeg1(z);
if (n == 0)
return PolylogZero(z);
if (n == 1)
return PolylogPos1(z);
if (n == -2)
return PolylogNeg2(z);
if (n == -3)
return PolylogNeg3(z);
if (n == -4)
return PolylogNeg4(z);
if (n < -4)
return PolylogNegative(n, z);
if (z == ScalarValue.One && n > 1)
return PolylogZetaPositive(n);
if (-z == ScalarValue.One && n > 1)
return PolylogZetaNegative(n);
/* This recurrence provides formulas for n < 2.
*
* d 1
* -- Li (x) = --- Li (x) .
* dx n x n-1
*
*/
var s = ScalarValue.Zero;
var ah = Math.Abs(z.Re) + Math.Abs(z.Im);
int i, j;
if (ah > 3.0)
return PolylogInversion(n, z);
else if (ah >= 0.75)
{
var ad = 0.0;
var x = z.Log();
var h = -((-x).Log());
for (i = 1; i < n; i++)
h += 1.0 / i;
var p = ScalarValue.One;
s = PolylogZetaPositive(n);
for (j = 1; j <= n + 1; j++)
{
p = p * x / j;
if (j == n - 1)
s += h * p;
else
s += PolylogZetaPositive(n - j) * p;
}
j = n + 3;
x = x * x;
for (; ; )
{
p = p * x / ((j - 1) * j);
h = PolylogZetaPositive(n - j);
h = h * p;
s += h;
ah = Math.Abs(h.Re) + Math.Abs(h.Im);
ad = Math.Abs(s.Re) + Math.Abs(s.Im);
if (ah < ad * double.Epsilon)
break;
j += 2;
}
return s;
}
else if(ah >= 1e-6)
{
var p = z * z * z;
var ad = 0.0;
var k = 3.0;
var h = ScalarValue.Zero;
do
{
p = p * z;
k += 1.0;
h = p / Math.Pow(k, n);
s += h;
//.........這裏部分代碼省略.........
示例2: GetValue
static ScalarValue GetValue(ScalarValue value, Double newBase)
{
return value.Log(newBase);
}