mirror of https://github.com/liamg/aminal.git
239 lines
6.3 KiB
Go
239 lines
6.3 KiB
Go
package imaging
|
|
|
|
import (
|
|
"image"
|
|
"testing"
|
|
)
|
|
|
|
func TestBlur(t *testing.T) {
|
|
testCases := []struct {
|
|
name string
|
|
src image.Image
|
|
sigma float64
|
|
want *image.NRGBA
|
|
}{
|
|
{
|
|
"Blur 3x3 0",
|
|
&image.NRGBA{
|
|
Rect: image.Rect(-1, -1, 2, 2),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x66, 0xaa, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
},
|
|
},
|
|
0.0,
|
|
&image.NRGBA{
|
|
Rect: image.Rect(0, 0, 3, 3),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x66, 0xaa, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
"Blur 3x3 0.5",
|
|
&image.NRGBA{
|
|
Rect: image.Rect(-1, -1, 2, 2),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x66, 0xaa, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
},
|
|
},
|
|
0.5,
|
|
&image.NRGBA{
|
|
Rect: image.Rect(0, 0, 3, 3),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x66, 0xaa, 0xff, 0x04, 0x66, 0xaa, 0xff, 0x18, 0x66, 0xaa, 0xff, 0x04,
|
|
0x66, 0xaa, 0xff, 0x18, 0x66, 0xaa, 0xff, 0x9e, 0x66, 0xaa, 0xff, 0x18,
|
|
0x66, 0xaa, 0xff, 0x04, 0x66, 0xaa, 0xff, 0x18, 0x66, 0xaa, 0xff, 0x04,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
"Blur 3x3 10",
|
|
&image.NRGBA{
|
|
Rect: image.Rect(-1, -1, 2, 2),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x66, 0xaa, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
},
|
|
},
|
|
10,
|
|
&image.NRGBA{
|
|
Rect: image.Rect(0, 0, 3, 3),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x66, 0xaa, 0xff, 0x1c, 0x66, 0xaa, 0xff, 0x1c, 0x66, 0xaa, 0xff, 0x1c,
|
|
0x66, 0xaa, 0xff, 0x1c, 0x66, 0xaa, 0xff, 0x1c, 0x66, 0xaa, 0xff, 0x1c,
|
|
0x66, 0xaa, 0xff, 0x1c, 0x66, 0xaa, 0xff, 0x1c, 0x66, 0xaa, 0xff, 0x1c,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
for _, tc := range testCases {
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
got := Blur(tc.src, tc.sigma)
|
|
if !compareNRGBA(got, tc.want, 0) {
|
|
t.Fatalf("got result %#v want %#v", got, tc.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestBlurGolden(t *testing.T) {
|
|
for name, sigma := range map[string]float64{
|
|
"out_blur_0.5.png": 0.5,
|
|
"out_blur_1.5.png": 1.5,
|
|
} {
|
|
got := Blur(testdataFlowersSmallPNG, sigma)
|
|
want, err := Open("testdata/" + name)
|
|
if err != nil {
|
|
t.Fatalf("failed to open image: %v", err)
|
|
}
|
|
if !compareNRGBA(got, toNRGBA(want), 0) {
|
|
t.Fatalf("resulting image differs from golden: %s", name)
|
|
}
|
|
}
|
|
}
|
|
|
|
func BenchmarkBlur(b *testing.B) {
|
|
b.ReportAllocs()
|
|
for i := 0; i < b.N; i++ {
|
|
Blur(testdataBranchesJPG, 3)
|
|
}
|
|
}
|
|
|
|
func TestSharpen(t *testing.T) {
|
|
testCases := []struct {
|
|
name string
|
|
src image.Image
|
|
sigma float64
|
|
want *image.NRGBA
|
|
}{
|
|
{
|
|
"Sharpen 3x3 0",
|
|
&image.NRGBA{
|
|
Rect: image.Rect(-1, -1, 2, 2),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66,
|
|
0x66, 0x66, 0x66, 0x66, 0x77, 0x77, 0x77, 0x77, 0x66, 0x66, 0x66, 0x66,
|
|
0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66,
|
|
},
|
|
},
|
|
0,
|
|
&image.NRGBA{
|
|
Rect: image.Rect(0, 0, 3, 3),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66,
|
|
0x66, 0x66, 0x66, 0x66, 0x77, 0x77, 0x77, 0x77, 0x66, 0x66, 0x66, 0x66,
|
|
0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
"Sharpen 3x3 0.5",
|
|
&image.NRGBA{
|
|
Rect: image.Rect(-1, -1, 2, 2),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66,
|
|
0x66, 0x66, 0x66, 0x66, 0x77, 0x77, 0x77, 0x77, 0x66, 0x66, 0x66, 0x66,
|
|
0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66,
|
|
},
|
|
},
|
|
0.5,
|
|
&image.NRGBA{
|
|
Rect: image.Rect(0, 0, 3, 3),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x66, 0x66, 0x66, 0x66, 0x64, 0x64, 0x64, 0x64, 0x66, 0x66, 0x66, 0x66,
|
|
0x64, 0x64, 0x64, 0x64, 0x7d, 0x7d, 0x7d, 0x7e, 0x64, 0x64, 0x64, 0x64,
|
|
0x66, 0x66, 0x66, 0x66, 0x64, 0x64, 0x64, 0x64, 0x66, 0x66, 0x66, 0x66,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
"Sharpen 3x3 100",
|
|
&image.NRGBA{
|
|
Rect: image.Rect(-1, -1, 2, 2),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66,
|
|
0x66, 0x66, 0x66, 0x66, 0x77, 0x77, 0x77, 0x77, 0x66, 0x66, 0x66, 0x66,
|
|
0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66,
|
|
},
|
|
},
|
|
100,
|
|
&image.NRGBA{
|
|
Rect: image.Rect(0, 0, 3, 3),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64,
|
|
0x64, 0x64, 0x64, 0x64, 0x86, 0x86, 0x86, 0x86, 0x64, 0x64, 0x64, 0x64,
|
|
0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64, 0x64,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
"Sharpen 3x1 10",
|
|
&image.NRGBA{
|
|
Rect: image.Rect(-1, -1, 2, 0),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff,
|
|
},
|
|
},
|
|
10,
|
|
&image.NRGBA{
|
|
Rect: image.Rect(0, 0, 3, 1),
|
|
Stride: 3 * 4,
|
|
Pix: []uint8{
|
|
0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
for _, tc := range testCases {
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
got := Sharpen(tc.src, tc.sigma)
|
|
if !compareNRGBA(got, tc.want, 0) {
|
|
t.Fatalf("got result %#v want %#v", got, tc.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestSharpenGolden(t *testing.T) {
|
|
for name, sigma := range map[string]float64{
|
|
"out_sharpen_0.5.png": 0.5,
|
|
"out_sharpen_1.5.png": 1.5,
|
|
} {
|
|
got := Sharpen(testdataFlowersSmallPNG, sigma)
|
|
want, err := Open("testdata/" + name)
|
|
if err != nil {
|
|
t.Fatalf("failed to open image: %v", err)
|
|
}
|
|
if !compareNRGBA(got, toNRGBA(want), 0) {
|
|
t.Fatalf("resulting image differs from golden: %s", name)
|
|
}
|
|
}
|
|
}
|
|
|
|
func BenchmarkSharpen(b *testing.B) {
|
|
b.ReportAllocs()
|
|
for i := 0; i < b.N; i++ {
|
|
Sharpen(testdataBranchesJPG, 3)
|
|
}
|
|
}
|