Calculate power of a negative number

后端 未结 3 705
清酒与你
清酒与你 2021-01-23 03:23

I relatively new to C# and since Math.Pow(x,y) returns NaN for a negative number(read: not negative power), I want to know how to calculate result more efficiently. What I am do

相关标签:
3条回答
  • 2021-01-23 03:44

    I think you can use System.Numerics.Complex that can calculate Imaginary.

    See:https://msdn.microsoft.com/en-us/library/system.numerics.complex%28v=vs.110%29.aspx?f=255&MSPPError=-2147217396

    http://www.extremeoptimization.com/QuickStart/CSharp/ComplexNumbers.aspx

    https://www.codeproject.com/Tips/3370/Complex-Math-Library-for-Csharp-and-VB-NET

    0 讨论(0)
  • 2021-01-23 03:51

    Math.Pow(x,y) returns NaN for a negative number.

    That's because arbitrary exponentiation is not defined for a negative base:

    http://en.wikipedia.org/wiki/Exponentiation

    when the base b is a positive real number, b to the n can be defined for all real and even complex exponents n via the exponential function

    Now, exponentiation of negative numbers to get a real result is defined if the power is an integer, as in your case, but Pow will not calculate it for you. What you should do is:

    • Suppose you want to know Pow(-2, 5)
    • Give Pow the problem Pow(2, 5) instead.
    • Look at the exponent; if it is an even number then you've got the right answer. If it is an odd number, then make the answer negative.

    So in this case, Pow(2, 5) returns 32. The exponent 5 is odd, so make it -32, and you're done.

    0 讨论(0)
  • 2021-01-23 03:51

    in Pow(double base, double power), when base < 0 and power is fractional ( ex: power=0.5) , then NaN will be generated, because it is calculable in complex domain not in real domain. so may be you need to check the base and power of pow function before using them. in this case you should return your desired value as undefined value (instead of NaN).

    the bellow function performs this operation, and returns 0 instead of NaN:

    // pow with desired Nan
    public double Pow(double x,double y){
        double MyNaN = 0; // or any desired value for Nan
        double result = MyNaN; 
    
        if (Math.Floor (y) != y) { // if y is fractional number
            if (x < 0)  // if x is negative number
                return result;
        }
    
        result = Math.Pow (x, y);
        return result;
    
    }
    
    0 讨论(0)
提交回复
热议问题