cs-mic/src/StandardLibrary/Functions/Trigonometry/Atan.cs
2026-06-24 14:17:32 -05:00

56 lines
1.8 KiB
C#

namespace CSMic.StandardLibrary.Functions.Trigonometry
{
/// <summary>
/// Represents the standard-library <c>atan</c> function.
/// </summary>
/// <remarks>
/// The <c>atan</c> function evaluates a numeric expression and returns its arctangent.
/// </remarks>
public class Atan : FunctionBase, ICodedFunction
{
/// <summary>
/// Gets the expression-language name used to invoke this function.
/// </summary>
/// <value><c>atan</c>.</value>
public string Name
{
get
{
return "atan";
}
}
/// <summary>
/// Gets the argument signature expected by the <c>atan</c> function.
/// </summary>
/// <value>A single numeric argument named <c>value</c>.</value>
public override IEnumerable<FunctionArgument> ExpectedArguments
{
get
{
yield return new FunctionArgument("value", FunctionValue.NUMBER);
}
}
/// <summary>
/// Executes the <c>atan</c> function.
/// </summary>
/// <param name="args">
/// The evaluated arguments supplied to the function. Exactly one numeric argument is expected.
/// </param>
/// <returns>
/// A numeric <see cref="FunctionValue"/> containing the arctangent of the input value.
/// </returns>
public FunctionValue Execute(params FunctionArgument[] args)
{
return Execute(args, (_args) =>
{
var input = _args[0].Value;
decimal value = Convert.ToDecimal(input.Value);
return new FunctionValue(FunctionValueType.Numeric, Math.Atan((double)value));
});
}
}
}