📷 A modern, cross-platform, 2D Graphics library for .NET
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.
 
 

56 lines
1.4 KiB

// <copyright file="ImageMaths.cs" company="James South">
// Copyright © James South and contributors.
// Licensed under the Apache License, Version 2.0.
// </copyright>
namespace ImageProcessor
{
using System;
/// <summary>
/// Provides common mathematical methods.
/// </summary>
internal static class ImageMaths
{
/// <summary>
/// Gets the result of a sine cardinal function for the given value.
/// </summary>
/// <param name="x">
/// The value to calculate the result for.
/// </param>
/// <returns>
/// The <see cref="double"/>.
/// </returns>
public static double SinC(double x)
{
const double Epsilon = .0001;
if (Math.Abs(x) > Epsilon)
{
x *= Math.PI;
return Clean(Math.Sin(x) / x);
}
return 1.0;
}
/// <summary>
/// Ensures that any passed double is correctly rounded to zero
/// </summary>
/// <param name="x">The value to clean.</param>
/// <returns>
/// The <see cref="double"/>
/// </returns>.
private static double Clean(double x)
{
const double Epsilon = .0001;
if (Math.Abs(x) < Epsilon)
{
return 0.0;
}
return x;
}
}
}