mirror of https://github.com/SixLabors/ImageSharp
Browse Source
Former-commit-id: dd83c793aea242e533c04f1ed0526319e3608c7b Former-commit-id: 27cfda9e96a3148eb9345992050880cfa830dbd5 Former-commit-id: 4d4eb638fed3de06a05eca59d161acdd2d389b7faf/merge-core
2 changed files with 34 additions and 0 deletions
@ -0,0 +1,33 @@ |
|||||
|
// <copyright file="Lanczos5Resampler.cs" company="James South">
|
||||
|
// Copyright © James South and contributors.
|
||||
|
// Licensed under the Apache License, Version 2.0.
|
||||
|
// </copyright>
|
||||
|
|
||||
|
namespace ImageProcessor.Samplers |
||||
|
{ |
||||
|
/// <summary>
|
||||
|
/// The function implements the Lanczos kernel algorithm as described on
|
||||
|
/// <see href="https://en.wikipedia.org/wiki/Lanczos_resampling#Algorithm">Wikipedia</see>
|
||||
|
/// </summary>
|
||||
|
public class Lanczos5Resampler : IResampler |
||||
|
{ |
||||
|
/// <inheritdoc/>
|
||||
|
public double Radius => 5; |
||||
|
|
||||
|
/// <inheritdoc/>
|
||||
|
public double GetValue(double x) |
||||
|
{ |
||||
|
if (x < 0) |
||||
|
{ |
||||
|
x = -x; |
||||
|
} |
||||
|
|
||||
|
if (x < 5) |
||||
|
{ |
||||
|
return ImageMaths.SinC(x) * ImageMaths.SinC(x / 5f); |
||||
|
} |
||||
|
|
||||
|
return 0; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
Loading…
Reference in new issue