mirror of https://github.com/SixLabors/ImageSharp
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.
96 lines
4.0 KiB
96 lines
4.0 KiB
// Copyright (c) Six Labors.
|
|
// Licensed under the Apache License, Version 2.0.
|
|
|
|
using System;
|
|
using SixLabors.ImageSharp.Formats.Jpeg.Components;
|
|
using Xunit;
|
|
using Xunit.Abstractions;
|
|
|
|
using JpegQuantization = SixLabors.ImageSharp.Formats.Jpeg.Components.Quantization;
|
|
|
|
namespace SixLabors.ImageSharp.Tests.Formats.Jpg
|
|
{
|
|
[Trait("Format", "Jpg")]
|
|
public class QuantizationTests
|
|
{
|
|
public QuantizationTests(ITestOutputHelper output)
|
|
{
|
|
this.Output = output;
|
|
}
|
|
|
|
private ITestOutputHelper Output { get; }
|
|
|
|
[Fact]
|
|
public void QualityEstimationFromStandardEncoderTables_Luminance()
|
|
{
|
|
int firstIndex = JpegQuantization.QualityEstimationConfidenceLowerThreshold;
|
|
int lastIndex = JpegQuantization.QualityEstimationConfidenceUpperThreshold;
|
|
for (int quality = firstIndex; quality <= lastIndex; quality++)
|
|
{
|
|
Block8x8F table = JpegQuantization.ScaleLuminanceTable(quality);
|
|
bool isStrandard = JpegQuantization.EstimateLuminanceQuality(ref table, out int actualQuality);
|
|
|
|
Assert.True(isStrandard, $"Standard table is estimated to be non-spec complient at quality level {quality}");
|
|
Assert.Equal(quality, actualQuality);
|
|
}
|
|
}
|
|
|
|
[Fact]
|
|
public void QualityEstimationFromStandardEncoderTables_Chrominance()
|
|
{
|
|
int firstIndex = JpegQuantization.QualityEstimationConfidenceLowerThreshold;
|
|
int lastIndex = JpegQuantization.QualityEstimationConfidenceUpperThreshold;
|
|
for (int quality = firstIndex; quality <= lastIndex; quality++)
|
|
{
|
|
Block8x8F table = JpegQuantization.ScaleChrominanceTable(quality);
|
|
bool isStrandard = JpegQuantization.EstimateChrominanceQuality(ref table, out int actualQuality);
|
|
|
|
Assert.True(isStrandard, $"Standard table is estimated to be non-spec complient at quality level {quality}");
|
|
Assert.Equal(quality, actualQuality);
|
|
}
|
|
}
|
|
|
|
[Fact(Skip = "Debug only, enable manually!")]
|
|
public void PrintVariancesFromStandardTables_Luminance()
|
|
{
|
|
this.Output.WriteLine("Variances for Luminance table.\nQuality levels 25-100:");
|
|
|
|
double minVariance = double.MaxValue;
|
|
double maxVariance = double.MinValue;
|
|
|
|
for (int q = JpegQuantization.QualityEstimationConfidenceLowerThreshold; q <= JpegQuantization.MaxQualityFactor; q++)
|
|
{
|
|
Block8x8F table = JpegQuantization.ScaleLuminanceTable(q);
|
|
double variance = JpegQuantization.EstimateQuality(ref table, JpegQuantization.UnscaledQuant_Luminance, out int quality);
|
|
|
|
minVariance = Math.Min(minVariance, variance);
|
|
maxVariance = Math.Max(maxVariance, variance);
|
|
|
|
this.Output.WriteLine($"q={q}\t{variance}\test. q: {quality}");
|
|
}
|
|
|
|
this.Output.WriteLine($"Min variance: {minVariance}\nMax variance: {maxVariance}");
|
|
}
|
|
|
|
[Fact(Skip = "Debug only, enable manually!")]
|
|
public void PrintVariancesFromStandardTables_Chrominance()
|
|
{
|
|
this.Output.WriteLine("Variances for Chrominance table.\nQuality levels 25-100:");
|
|
|
|
double minVariance = double.MaxValue;
|
|
double maxVariance = double.MinValue;
|
|
for (int q = JpegQuantization.QualityEstimationConfidenceLowerThreshold; q <= JpegQuantization.MaxQualityFactor; q++)
|
|
{
|
|
Block8x8F table = JpegQuantization.ScaleChrominanceTable(q);
|
|
double variance = JpegQuantization.EstimateQuality(ref table, JpegQuantization.UnscaledQuant_Chrominance, out int quality);
|
|
|
|
minVariance = Math.Min(minVariance, variance);
|
|
maxVariance = Math.Max(maxVariance, variance);
|
|
|
|
this.Output.WriteLine($"q={q}\t{variance}\test. q: {quality}");
|
|
}
|
|
|
|
this.Output.WriteLine($"Min variance: {minVariance}\nMax variance: {maxVariance}");
|
|
}
|
|
}
|
|
}
|
|
|