csharpfftfsharpintegrationinterpolationlinear-algebramathdifferentiationmatrixnumericsrandomregressionstatisticsmathnet
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
955 lines
30 KiB
955 lines
30 KiB
// <copyright file="Trigonometry.cs" company="Math.NET">
|
|
// Math.NET Numerics, part of the Math.NET Project
|
|
// http://mathnet.opensourcedotnet.info
|
|
// Copyright (c) 2009 Math.NET
|
|
// Permission is hereby granted, free of charge, to any person
|
|
// obtaining a copy of this software and associated documentation
|
|
// files (the "Software"), to deal in the Software without
|
|
// restriction, including without limitation the rights to use,
|
|
// copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
// copies of the Software, and to permit persons to whom the
|
|
// Software is furnished to do so, subject to the following
|
|
// conditions:
|
|
// The above copyright notice and this permission notice shall be
|
|
// included in all copies or substantial portions of the Software.
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
|
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
|
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
|
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
|
// OTHER DEALINGS IN THE SOFTWARE.
|
|
// </copyright>
|
|
|
|
namespace MathNet.Numerics
|
|
{
|
|
using System;
|
|
|
|
/// <summary>
|
|
/// Double-precision trigonometry toolkit.
|
|
/// </summary>
|
|
public static class Trig
|
|
{
|
|
/// <summary>
|
|
/// Constant to convert a degree to grad.
|
|
/// </summary>
|
|
private const double DegreeToGradConstant = 10.0 / 9.0;
|
|
|
|
/// <summary>
|
|
/// Trigonometric Cosecant of an angle in radian.
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian.
|
|
/// </param>
|
|
/// <returns>
|
|
/// Cosecant of an angle in radian.
|
|
/// </returns>
|
|
public static double Cosecant(double radian)
|
|
{
|
|
return 1 / Math.Sin(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Cosecant of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The cosecant of a complex number.
|
|
/// </returns>
|
|
public static Complex Cosecant(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(Cosecant(value.Real), 0d);
|
|
}
|
|
|
|
var sinr = Sine(value.Real);
|
|
var sinhi = HyperbolicSine(value.Imaginary);
|
|
var denom = (sinr * sinr) + (sinhi * sinhi);
|
|
|
|
return new Complex(sinr * HyperbolicCosine(value.Imaginary) / denom, -Cosine(value.Real) * sinhi / denom);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Cosine of an angle in radian.
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The cosine of an angle in radian.
|
|
/// </returns>
|
|
public static double Cosine(double radian)
|
|
{
|
|
return Math.Cos(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Cosine of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The cosine of a complex number.
|
|
/// </returns>
|
|
public static Complex Cosine(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(Cosine(value.Real), 0.0);
|
|
}
|
|
|
|
return new Complex(
|
|
Cosine(value.Real) * HyperbolicCosine(value.Imaginary),
|
|
-Sine(value.Real) * HyperbolicSine(value.Imaginary));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Cotangent of an angle in radian.
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The cotangent of an angle in radian.
|
|
/// </returns>
|
|
public static double Cotangent(double radian)
|
|
{
|
|
return 1 / Math.Tan(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Cotangent of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The cotangent of the complex number.
|
|
/// </returns>
|
|
public static Complex Cotangent(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(Cotangent(value.Real), 0d);
|
|
}
|
|
|
|
var sinr = Sine(value.Real);
|
|
var sinhi = HyperbolicSine(value.Imaginary);
|
|
var denom = (sinr * sinr) + (sinhi * sinhi);
|
|
|
|
return new Complex(sinr * Cosine(value.Real) / denom, -sinhi * HyperbolicCosine(value.Imaginary) / denom);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Converts a degree (360-periodic) angle to a grad (400-periodic) angle.
|
|
/// </summary>
|
|
/// <param name="degree">
|
|
/// The degree to convert.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The converted grad angle.
|
|
/// </returns>
|
|
public static double DegreeToGrad(double degree)
|
|
{
|
|
return degree * DegreeToGradConstant;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Converts a degree (360-periodic) angle to a radian (2*Pi-periodic) angle.
|
|
/// </summary>
|
|
/// <param name="degree">
|
|
/// The degree to convert.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The converted radian angle.
|
|
/// </returns>
|
|
public static double DegreeToRadian(double degree)
|
|
{
|
|
return degree * Constants.Degree;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Converts a grad (400-periodic) angle to a degree (360-periodic) angle.
|
|
/// </summary>
|
|
/// <param name="grad">
|
|
/// The grad to convert.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The converted degree.
|
|
/// </returns>
|
|
public static double GradToDegree(double grad)
|
|
{
|
|
return grad * 0.9;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Converts a grad (400-periodic) angle to a radian (2*Pi-periodic) angle.
|
|
/// </summary>
|
|
/// <param name="grad">
|
|
/// The grad to convert.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The converted radian.
|
|
/// </returns>
|
|
public static double GradToRadian(double grad)
|
|
{
|
|
return grad * Constants.Grad;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Cosecant
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic cosecant of the radian angle.
|
|
/// </returns>
|
|
public static double HyperbolicCosecant(double radian)
|
|
{
|
|
return 1 / HyperbolicSine(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Cosecant of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic cosecant of a complex number.
|
|
/// </returns>
|
|
public static Complex HyperbolicCosecant(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(HyperbolicCosecant(value.Real), 0.0);
|
|
}
|
|
|
|
var exp = value.Exponential();
|
|
|
|
if (exp.IsInfinity)
|
|
{
|
|
return Complex.Zero;
|
|
}
|
|
|
|
return 2 * exp / (exp.Square() - 1);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Cosine
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic Cosine of the radian angle.
|
|
/// </returns>
|
|
public static double HyperbolicCosine(double radian)
|
|
{
|
|
return (Math.Exp(radian) + Math.Exp(-radian)) / 2;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Cosine of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic cosine of a complex number.
|
|
/// </returns>
|
|
public static Complex HyperbolicCosine(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(HyperbolicCosine(value.Real), 0.0);
|
|
}
|
|
|
|
return new Complex(
|
|
HyperbolicCosine(value.Real) * Cosine(value.Imaginary),
|
|
HyperbolicSine(value.Real) * Sine(value.Imaginary));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Cotangent
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic cotangent of the radian angle.
|
|
/// </returns>
|
|
public static double HyperbolicCotangent(double radian)
|
|
{
|
|
if (radian > 19.115)
|
|
{
|
|
return 1.0;
|
|
}
|
|
|
|
if (radian < -19.115)
|
|
{
|
|
return -1;
|
|
}
|
|
|
|
var e1 = Math.Exp(radian);
|
|
var e2 = Math.Exp(-radian);
|
|
return (e1 + e2) / (e1 - e2);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Cotangent of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic cotangent of a complex number.
|
|
/// </returns>
|
|
public static Complex HyperbolicCotangent(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(HyperbolicCotangent(value.Real), 0.0);
|
|
}
|
|
|
|
var sini = Sine(value.Imaginary);
|
|
var sinhr = HyperbolicSine(value.Real);
|
|
|
|
if (double.IsInfinity(sinhr))
|
|
{
|
|
return new Complex(double.IsPositiveInfinity(sinhr) ? 1 : -1, 0.0);
|
|
}
|
|
|
|
var denom = (sini * sini) + (sinhr * sinhr);
|
|
|
|
return new Complex(sinhr * HyperbolicCosine(value.Real) / denom, sini * Cosine(value.Imaginary) / denom);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Secant
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic secant of the radian angle.
|
|
/// </returns>
|
|
public static double HyperbolicSecant(double radian)
|
|
{
|
|
return 1 / HyperbolicCosine(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Secant of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic secant of a complex number.
|
|
/// </returns>
|
|
public static Complex HyperbolicSecant(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(HyperbolicSecant(value.Real), 0.0);
|
|
}
|
|
|
|
var exp = value.Exponential();
|
|
|
|
if (exp.IsInfinity)
|
|
{
|
|
return Complex.Zero;
|
|
}
|
|
|
|
return 2 * exp / (exp.Square() + 1);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Sine
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic sine of the radian angle.
|
|
/// </returns>
|
|
public static double HyperbolicSine(double radian)
|
|
{
|
|
return (Math.Exp(radian) - Math.Exp(-radian)) / 2;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Sine of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic sine of a complex number.
|
|
/// </returns>
|
|
public static Complex HyperbolicSine(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(HyperbolicSine(value.Real), 0.0);
|
|
}
|
|
|
|
return new Complex(
|
|
HyperbolicSine(value.Real) * Cosine(value.Imaginary),
|
|
HyperbolicCosine(value.Real) * Sine(value.Imaginary));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Tangent in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic tangent of the radian angle.
|
|
/// </returns>
|
|
public static double HyperbolicTangent(double radian)
|
|
{
|
|
if (radian > 19.1)
|
|
{
|
|
return 1.0;
|
|
}
|
|
|
|
if (radian < -19.1)
|
|
{
|
|
return -1;
|
|
}
|
|
|
|
var e1 = Math.Exp(radian);
|
|
var e2 = Math.Exp(-radian);
|
|
return (e1 - e2) / (e1 + e2);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Tangent of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic tangent of a complex number.
|
|
/// </returns>
|
|
public static Complex HyperbolicTangent(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(HyperbolicTangent(value.Real), 0.0);
|
|
}
|
|
|
|
var cosi = Cosine(value.Imaginary);
|
|
var sinhr = HyperbolicSine(value.Real);
|
|
|
|
if (double.IsInfinity(sinhr))
|
|
{
|
|
return new Complex(double.IsPositiveInfinity(sinhr) ? 1 : -1, 0.0);
|
|
}
|
|
|
|
var denom = (cosi * cosi) + (sinhr * sinhr);
|
|
|
|
return new Complex(HyperbolicCosine(value.Real) * sinhr / denom, cosi * Sine(value.Imaginary) / denom);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Cosecant in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse cosecant of the radian angle.
|
|
/// </returns>
|
|
/// <exception cref="ArgumentOutOfRangeException">
|
|
/// if -1 < <paramref name="radian"/> < 1.
|
|
/// </exception>
|
|
public static double InverseCosecant(double radian)
|
|
{
|
|
return Math.Asin(1 / radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Cosecant of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The arc cosecant of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseCosecant(this Complex value)
|
|
{
|
|
var inv = 1 / value;
|
|
return -Complex.I * ((Complex.I * inv) + (1 - inv.Square()).SquareRoot()).NaturalLogarithm();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Cosine in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse cosine of the radian angle.
|
|
/// </returns>
|
|
/// <exception cref="ArgumentOutOfRangeException">
|
|
/// if 1 < <paramref name="radian"/> or <paramref name="radian"/> < -1.
|
|
/// </exception>
|
|
public static double InverseCosine(double radian)
|
|
{
|
|
return Math.Acos(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Cosine of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The arc cosine of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseCosine(this Complex value)
|
|
{
|
|
return -Complex.I * (value + (Complex.I * (1 - value.Square()).SquareRoot())).NaturalLogarithm();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Cotangent in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse cotangent of the radian angle.
|
|
/// </returns>
|
|
public static double InverseCotangent(double radian)
|
|
{
|
|
return Math.Atan(1 / radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Cotangent of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The arc cotangent of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseCotangent(this Complex value)
|
|
{
|
|
if (value.IsZero)
|
|
{
|
|
return Math.PI / 2.0;
|
|
}
|
|
|
|
var inv = Complex.I / value;
|
|
return (Complex.I * 0.5) * ((1.0 - inv).NaturalLogarithm() - (1.0 + inv).NaturalLogarithm());
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Arc Cosecant
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse hyperbolic cosecant of the radian angle.
|
|
/// </returns>
|
|
public static double InverseHyperbolicCosecant(double radian)
|
|
{
|
|
return InverseHyperbolicSine(1 / radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Arc Cosecant of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic arc cosecant of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseHyperbolicCosecant(this Complex value)
|
|
{
|
|
var inv = 1 / value;
|
|
return (inv + (inv.Square() + 1).SquareRoot()).NaturalLogarithm();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Area Cosine
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse hyperbolic cosine of the radian angle.
|
|
/// </returns>
|
|
public static double InverseHyperbolicCosine(double radian)
|
|
{
|
|
return Math.Log(radian + (Math.Sqrt(radian - 1) * Math.Sqrt(radian + 1)), Math.E);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Arc Cosine of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic arc cosine of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseHyperbolicCosine(this Complex value)
|
|
{
|
|
return (value + ((value - 1).SquareRoot() * (value + 1).SquareRoot())).NaturalLogarithm();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Arc Cotangent
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse hyperbolic cotangent of the radian angle.
|
|
/// </returns>
|
|
public static double InverseHyperbolicCotangent(double radian)
|
|
{
|
|
return 0.5 * Math.Log((radian + 1) / (radian - 1), Math.E);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Arc Cotangent of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic arc cotangent of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseHyperbolicCotangent(this Complex value)
|
|
{
|
|
var inv = 1.0 / value;
|
|
return 0.5 * ((1.0 + inv).NaturalLogarithm() - (1.0 - inv).NaturalLogarithm());
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Area Secant
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse hyperbolic secant of the radian angle.
|
|
/// </returns>
|
|
public static double InverseHyperbolicSecant(double radian)
|
|
{
|
|
return InverseHyperbolicCosine(1 / radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Arc Secant of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic arc secant of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseHyperbolicSecant(this Complex value)
|
|
{
|
|
var inv = 1 / value;
|
|
return (inv + ((inv - 1).SquareRoot() * (inv + 1).SquareRoot())).NaturalLogarithm();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Area Sine
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse hyperbolic sine of the radian angle.
|
|
/// </returns>
|
|
public static double InverseHyperbolicSine(double radian)
|
|
{
|
|
return Math.Log(radian + Math.Sqrt((radian * radian) + 1), Math.E);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Arc Sine of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic arc sine of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseHyperbolicSine(this Complex value)
|
|
{
|
|
return (value + (value.Square() + 1).SquareRoot()).NaturalLogarithm();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Area Tangent
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse hyperbolic tangent of the radian angle.
|
|
/// </returns>
|
|
public static double InverseHyperbolicTangent(double radian)
|
|
{
|
|
return 0.5 * Math.Log((1 + radian) / (1 - radian), Math.E);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Hyperbolic Arc Tangent of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The hyperbolic arc tangent of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseHyperbolicTangent(this Complex value)
|
|
{
|
|
return 0.5 * ((1 + value).NaturalLogarithm() - (1 - value).NaturalLogarithm());
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Secant in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse secant of the radian angle.
|
|
/// </returns>
|
|
public static double InverseSecant(double radian)
|
|
{
|
|
return Math.Acos(1 / radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Secant of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The arc secant of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseSecant(this Complex value)
|
|
{
|
|
var inv = 1 / value;
|
|
return -Complex.I * (inv + (Complex.I * (1 - inv.Square()).SquareRoot())).NaturalLogarithm();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Sine in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse sine of the radian angle.
|
|
/// </returns>
|
|
public static double InverseSine(double radian)
|
|
{
|
|
return Math.Asin(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Sine of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The arc sine of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseSine(this Complex value)
|
|
{
|
|
return -Complex.I * ((1 - value.Square()).SquareRoot() + (Complex.I * value)).NaturalLogarithm();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Tangent in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian angle.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The inverse tangent of the radian angle.
|
|
/// </returns>
|
|
public static double InverseTangent(double radian)
|
|
{
|
|
return Math.Atan(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Arc Tangent of this <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The arc tangent of a complex number.
|
|
/// </returns>
|
|
public static Complex InverseTangent(this Complex value)
|
|
{
|
|
var iz = new Complex(-value.Imaginary, value.Real); // I*this
|
|
return new Complex(0, 0.5) * ((1 - iz).NaturalLogarithm() - (1 + iz).NaturalLogarithm());
|
|
}
|
|
|
|
/// <summary>
|
|
/// Converts a radian (2*Pi-periodic) angle to a degree (360-periodic) angle.
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The radian to convert.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The converted degree.
|
|
/// </returns>
|
|
public static double RadianToDegree(double radian)
|
|
{
|
|
return radian / Constants.Degree;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Converts a radian (2*Pi-periodic) angle to a grad (400-periodic) angle.
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The radian to convert.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The converted grad.
|
|
/// </returns>
|
|
public static double RadianToGrad(double radian)
|
|
{
|
|
return radian / Constants.Grad;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Secant of an angle in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The secant of the radian angle.
|
|
/// </returns>
|
|
public static double Secant(double radian)
|
|
{
|
|
return 1 / Math.Cos(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Secant of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The secant of the complex number.
|
|
/// </returns>
|
|
public static Complex Secant(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(Secant(value.Real), 0d);
|
|
}
|
|
|
|
var cosr = Cosine(value.Real);
|
|
var sinhi = HyperbolicSine(value.Imaginary);
|
|
var denom = (cosr * cosr) + (sinhi * sinhi);
|
|
|
|
return new Complex(cosr * HyperbolicCosine(value.Imaginary) / denom, Sine(value.Real) * sinhi / denom);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Sine of an angle in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The sine of the radian angle.
|
|
/// </returns>
|
|
public static double Sine(double radian)
|
|
{
|
|
return Math.Sin(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Sine of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The sine of the complex number.
|
|
/// </returns>
|
|
public static Complex Sine(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(Sine(value.Real), 0.0);
|
|
}
|
|
|
|
return new Complex(
|
|
Sine(value.Real) * HyperbolicCosine(value.Imaginary),
|
|
Cosine(value.Real) * HyperbolicSine(value.Imaginary));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Tangent of an angle in radian
|
|
/// </summary>
|
|
/// <param name="radian">
|
|
/// The angle in radian.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The tangent of the radian angle.
|
|
/// </returns>
|
|
public static double Tangent(double radian)
|
|
{
|
|
return Math.Tan(radian);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Trigonometric Tangent of a <c>Complex</c> number.
|
|
/// </summary>
|
|
/// <param name="value">
|
|
/// The complex value.
|
|
/// </param>
|
|
/// <returns>
|
|
/// The tangent of the complex number.
|
|
/// </returns>
|
|
public static Complex Tangent(this Complex value)
|
|
{
|
|
if (value.IsReal)
|
|
{
|
|
return new Complex(Tangent(value.Real), 0.0);
|
|
}
|
|
|
|
var cosr = Cosine(value.Real);
|
|
var sinhi = HyperbolicSine(value.Imaginary);
|
|
var denom = (cosr * cosr) + (sinhi * sinhi);
|
|
|
|
return new Complex(Sine(value.Real) * cosr / denom, sinhi * HyperbolicCosine(value.Imaginary) / denom);
|
|
}
|
|
}
|
|
}
|