| /* Copyright (C) 2011  Jan Källman | 
 |  * | 
 |  * This library is free software; you can redistribute it and/or | 
 |  * modify it under the terms of the GNU Lesser General Public | 
 |  * License as published by the Free Software Foundation; either | 
 |  * version 2.1 of the License, or (at your option) any later version. | 
 |  | 
 |  * This library is distributed in the hope that it will be useful, | 
 |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | 
 |  * See the GNU Lesser General Public License for more details. | 
 |  * | 
 |  * The GNU Lesser General Public License can be viewed at http://www.opensource.org/licenses/lgpl-license.php | 
 |  * If you unfamiliar with this license or have questions about it, here is an http://www.gnu.org/licenses/gpl-faq.html | 
 |  * | 
 |  * All code and executables are provided "as is" with no warranty either express or implied. | 
 |  * The author accepts no liability for any damage or loss of business that this product may cause. | 
 |  * | 
 |  * Code change notes: | 
 |  * | 
 |  * Author							Change						Date | 
 |  ******************************************************************************* | 
 |  * Mats Alm   		                Added		                2015-01-11 | 
 |  *******************************************************************************/ | 
 |  | 
 | using MathObj = System.Math; | 
 |  | 
 | namespace OfficeOpenXml.FormulaParsing.Excel.Functions.Math; | 
 |  | 
 | /// <summary> | 
 | /// Thanks to the guys in this thread: http://stackoverflow.com/questions/2840798/c-sharp-math-class-question | 
 | /// </summary> | 
 | public static class MathHelper { | 
 |   // Secant | 
 |   public static double Sec(double x) { | 
 |     return 1 / MathObj.Cos(x); | 
 |   } | 
 |  | 
 |   // Cosecant | 
 |   public static double Cosec(double x) { | 
 |     return 1 / MathObj.Sin(x); | 
 |   } | 
 |  | 
 |   // Cotangent | 
 |   public static double Cotan(double x) { | 
 |     return 1 / MathObj.Tan(x); | 
 |   } | 
 |  | 
 |   // Inverse Sine | 
 |   public static double Arcsin(double x) { | 
 |     return MathObj.Atan(x / MathObj.Sqrt(-x * x + 1)); | 
 |   } | 
 |  | 
 |   // Inverse Cosine | 
 |   public static double Arccos(double x) { | 
 |     return MathObj.Atan(-x / MathObj.Sqrt(-x * x + 1)) + 2 * MathObj.Atan(1); | 
 |   } | 
 |  | 
 |   // Inverse Secant | 
 |   public static double Arcsec(double x) { | 
 |     return 2 * MathObj.Atan(1) - MathObj.Atan(MathObj.Sign(x) / MathObj.Sqrt(x * x - 1)); | 
 |   } | 
 |  | 
 |   // Inverse Cosecant | 
 |   public static double Arccosec(double x) { | 
 |     return MathObj.Atan(MathObj.Sign(x) / MathObj.Sqrt(x * x - 1)); | 
 |   } | 
 |  | 
 |   // Inverse Cotangent | 
 |   public static double Arccotan(double x) { | 
 |     return 2 * MathObj.Atan(1) - MathObj.Atan(x); | 
 |   } | 
 |  | 
 |   // Hyperbolic Sine | 
 |   public static double HSin(double x) { | 
 |     return (MathObj.Exp(x) - MathObj.Exp(-x)) / 2; | 
 |   } | 
 |  | 
 |   // Hyperbolic Cosine | 
 |   public static double HCos(double x) { | 
 |     return (MathObj.Exp(x) + MathObj.Exp(-x)) / 2; | 
 |   } | 
 |  | 
 |   // Hyperbolic Tangent | 
 |   public static double HTan(double x) { | 
 |     return (MathObj.Exp(x) - MathObj.Exp(-x)) / (MathObj.Exp(x) + MathObj.Exp(-x)); | 
 |   } | 
 |  | 
 |   // Hyperbolic Secant | 
 |   public static double HSec(double x) { | 
 |     return 2 / (MathObj.Exp(x) + MathObj.Exp(-x)); | 
 |   } | 
 |  | 
 |   // Hyperbolic Cosecant | 
 |   public static double HCosec(double x) { | 
 |     return 2 / (MathObj.Exp(x) - MathObj.Exp(-x)); | 
 |   } | 
 |  | 
 |   // Hyperbolic Cotangent | 
 |   public static double HCotan(double x) { | 
 |     return (MathObj.Exp(x) + MathObj.Exp(-x)) / (MathObj.Exp(x) - MathObj.Exp(-x)); | 
 |   } | 
 |  | 
 |   // Inverse Hyperbolic Sine | 
 |   public static double HArcsin(double x) { | 
 |     return MathObj.Log(x + MathObj.Sqrt(x * x + 1)); | 
 |   } | 
 |  | 
 |   // Inverse Hyperbolic Cosine | 
 |   public static double HArccos(double x) { | 
 |     return MathObj.Log(x + MathObj.Sqrt(x * x - 1)); | 
 |   } | 
 |  | 
 |   // Inverse Hyperbolic Tangent | 
 |   public static double HArctan(double x) { | 
 |     return MathObj.Log((1 + x) / (1 - x)) / 2; | 
 |   } | 
 |  | 
 |   // Inverse Hyperbolic Secant | 
 |   public static double HArcsec(double x) { | 
 |     return MathObj.Log((MathObj.Sqrt(-x * x + 1) + 1) / x); | 
 |   } | 
 |  | 
 |   // Inverse Hyperbolic Cosecant | 
 |   public static double HArccosec(double x) { | 
 |     return MathObj.Log((MathObj.Sign(x) * MathObj.Sqrt(x * x + 1) + 1) / x); | 
 |   } | 
 |  | 
 |   // Inverse Hyperbolic Cotangent | 
 |   public static double HArccotan(double x) { | 
 |     return MathObj.Log((x + 1) / (x - 1)) / 2; | 
 |   } | 
 |  | 
 |   // Logarithm to base N | 
 |   public static double LogN(double x, double n) { | 
 |     return MathObj.Log(x) / MathObj.Log(n); | 
 |   } | 
 | } |