|
@@ -96,6 +96,157 @@ func BenchmarkInvert(b *testing.B) {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+func TestAdjustSaturation(t *testing.T) {
|
|
|
+ testCases := []struct {
|
|
|
+ name string
|
|
|
+ src image.Image
|
|
|
+ p float64
|
|
|
+ want *image.NRGBA
|
|
|
+ }{
|
|
|
+ {
|
|
|
+ "AdjustSaturation 3x3 10",
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(-1, -1, 2, 2),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
+ 0x11, 0x22, 0x33, 0xff, 0x33, 0x22, 0x11, 0xff, 0xaa, 0x33, 0xbb, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ 10,
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(0, 0, 3, 3),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
+ 0x0f, 0x22, 0x35, 0xff, 0x35, 0x22, 0x0f, 0xff, 0xaf, 0x2c, 0xc2, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "AdjustSaturation 3x3 100",
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(-1, -1, 2, 2),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
+ 0x11, 0x22, 0x33, 0xff, 0x33, 0x22, 0x11, 0xff, 0xaa, 0x33, 0xbb, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ 100,
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(0, 0, 3, 3),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
+ 0x00, 0x22, 0x44, 0xff, 0x44, 0x22, 0x00, 0xff, 0xd0, 0x00, 0xee, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "AdjustSaturation 3x3 -10",
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(-1, -1, 2, 2),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
+ 0x11, 0x22, 0x33, 0xff, 0x33, 0x22, 0x11, 0xff, 0xaa, 0x33, 0xbb, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ -10,
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(0, 0, 3, 3),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xc2, 0x0a, 0x0a, 0x01, 0x0a, 0xc2, 0x0a, 0x02, 0x0a, 0x0a, 0xc2, 0x03,
|
|
|
+ 0x13, 0x22, 0x31, 0xff, 0x31, 0x22, 0x13, 0xff, 0xa5, 0x3a, 0xb4, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "AdjustSaturation 3x3 -100",
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(-1, -1, 2, 2),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
+ 0x11, 0x22, 0x33, 0xff, 0x33, 0x22, 0x11, 0xff, 0xaa, 0x33, 0xbb, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ -100,
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(0, 0, 3, 3),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0x66, 0x66, 0x66, 0x01, 0x66, 0x66, 0x66, 0x02, 0x66, 0x66, 0x66, 0x03,
|
|
|
+ 0x22, 0x22, 0x22, 0xff, 0x22, 0x22, 0x22, 0xff, 0x77, 0x77, 0x77, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ "AdjustSaturation 3x3 0",
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(-1, -1, 2, 2),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
+ 0x11, 0x22, 0x33, 0xff, 0x33, 0x22, 0x11, 0xff, 0xaa, 0x33, 0xbb, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ 0,
|
|
|
+ &image.NRGBA{
|
|
|
+ Rect: image.Rect(0, 0, 3, 3),
|
|
|
+ Stride: 3 * 4,
|
|
|
+ Pix: []uint8{
|
|
|
+ 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
+ 0x11, 0x22, 0x33, 0xff, 0x33, 0x22, 0x11, 0xff, 0xaa, 0x33, 0xbb, 0xff,
|
|
|
+ 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ }
|
|
|
+ for _, tc := range testCases {
|
|
|
+ t.Run(tc.name, func(t *testing.T) {
|
|
|
+ got := AdjustSaturation(tc.src, tc.p)
|
|
|
+ if !compareNRGBA(got, tc.want, 0) {
|
|
|
+ t.Fatalf("got result %#v want %#v", got, tc.want)
|
|
|
+ }
|
|
|
+ })
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+func TestAdjustSaturationGolden(t *testing.T) {
|
|
|
+ for name, p := range map[string]float64{
|
|
|
+ "out_saturation_m30.png": -30,
|
|
|
+ "out_saturation_p30.png": 30,
|
|
|
+ } {
|
|
|
+ got := AdjustSaturation(testdataFlowersSmallPNG, p)
|
|
|
+ want, err := Open("testdata/" + name)
|
|
|
+ if err != nil {
|
|
|
+ t.Fatalf("failed to open image: %v", err)
|
|
|
+ }
|
|
|
+ if !compareNRGBA(got, toNRGBA(want), 0) {
|
|
|
+ t.Errorf("resulting image differs from golden: %s", name)
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+func BenchmarkAdjustSaturation(b *testing.B) {
|
|
|
+ b.ReportAllocs()
|
|
|
+ for i := 0; i < b.N; i++ {
|
|
|
+ AdjustSaturation(testdataBranchesJPG, 10)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
func TestAdjustContrast(t *testing.T) {
|
|
|
testCases := []struct {
|
|
|
name string
|
|
@@ -669,123 +820,3 @@ func TestAdjustFunc(t *testing.T) {
|
|
|
})
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
-func TestAdjustSaturation(t *testing.T) {
|
|
|
- src := &image.NRGBA{
|
|
|
- Rect: image.Rect(-1, -1, 2, 2),
|
|
|
- Stride: 3 * 4,
|
|
|
- Pix: []uint8{
|
|
|
- 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
- 0x11, 0x22, 0x33, 0xff, 0x33, 0x22, 0x11, 0xff, 0xaa, 0x33, 0xbb, 0xff,
|
|
|
- 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
- },
|
|
|
- }
|
|
|
-
|
|
|
- testCases := []struct {
|
|
|
- name string
|
|
|
- src image.Image
|
|
|
- p float64
|
|
|
- want *image.NRGBA
|
|
|
- }{
|
|
|
- {
|
|
|
- "AdjustSaturation 3x3 10",
|
|
|
- src,
|
|
|
- 10,
|
|
|
- &image.NRGBA{
|
|
|
- Rect: image.Rect(0, 0, 3, 3),
|
|
|
- Stride: 3 * 4,
|
|
|
- Pix: []uint8{
|
|
|
- 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
- 0x0f, 0x21, 0x34, 0xff, 0x34, 0x21, 0x0f, 0xff, 0xad, 0x2d, 0xc0, 0xff,
|
|
|
- 0x00, 0x00, 0x00, 0xff, 0x38, 0x2d, 0x2d, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
- },
|
|
|
- },
|
|
|
- },
|
|
|
- {
|
|
|
- "AdjustSaturation 3x3 50",
|
|
|
- src,
|
|
|
- 50,
|
|
|
- &image.NRGBA{
|
|
|
- Rect: image.Rect(0, 0, 3, 3),
|
|
|
- Stride: 3 * 4,
|
|
|
- Pix: []uint8{
|
|
|
- 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
- 0x08, 0x21, 0x3b, 0xff, 0x3b, 0x21, 0x08, 0xff, 0xbd, 0x19, 0xd4, 0xff,
|
|
|
- 0x00, 0x00, 0x00, 0xff, 0x4c, 0x19, 0x19, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
- },
|
|
|
- },
|
|
|
- },
|
|
|
- {
|
|
|
- "AdjustSaturation 3x3 100",
|
|
|
- src,
|
|
|
- 100,
|
|
|
- &image.NRGBA{
|
|
|
- Rect: image.Rect(0, 0, 3, 3),
|
|
|
- Stride: 3 * 4,
|
|
|
- Pix: []uint8{
|
|
|
- 0xcc, 0x00, 0x00, 0x01, 0x00, 0xcc, 0x00, 0x02, 0x00, 0x00, 0xcc, 0x03,
|
|
|
- 0x00, 0x21, 0x44, 0xff, 0x44, 0x21, 0x00, 0xff, 0xd0, 0x00, 0xee, 0xff,
|
|
|
- 0x00, 0x00, 0x00, 0xff, 0x66, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
- },
|
|
|
- },
|
|
|
- },
|
|
|
- {
|
|
|
- "AdjustSaturation 3x3 -10",
|
|
|
- src,
|
|
|
- -10,
|
|
|
- &image.NRGBA{
|
|
|
- Rect: image.Rect(0, 0, 3, 3),
|
|
|
- Stride: 3 * 4,
|
|
|
- Pix: []uint8{
|
|
|
- 0xc1, 0x0a, 0x0a, 0x01, 0x0a, 0xc1, 0x0a, 0x02, 0x0a, 0x0a, 0xc1, 0x03,
|
|
|
- 0x12, 0x21, 0x31, 0xff, 0x31, 0x21, 0x12, 0xff, 0xa4, 0x39, 0xb4, 0xff,
|
|
|
- 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
- },
|
|
|
- },
|
|
|
- },
|
|
|
- {
|
|
|
- "AdjustSaturation 3x3 -50",
|
|
|
- src,
|
|
|
- -50,
|
|
|
- &image.NRGBA{
|
|
|
- Rect: image.Rect(0, 0, 3, 3),
|
|
|
- Stride: 3 * 4,
|
|
|
- Pix: []uint8{
|
|
|
- 0x99, 0x32, 0x32, 0x01, 0x32, 0x99, 0x32, 0x02, 0x32, 0x32, 0x99, 0x03,
|
|
|
- 0x19, 0x21, 0x2a, 0xff, 0x2a, 0x22, 0x19, 0xff, 0x90, 0x55, 0x99, 0xff,
|
|
|
- 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
- },
|
|
|
- },
|
|
|
- },
|
|
|
- {
|
|
|
- "AdjustSaturation 3x3 -100",
|
|
|
- src,
|
|
|
- -100,
|
|
|
- &image.NRGBA{
|
|
|
- Rect: image.Rect(0, 0, 3, 3),
|
|
|
- Stride: 3 * 4,
|
|
|
- Pix: []uint8{
|
|
|
- 0x66, 0x66, 0x66, 0x01, 0x66, 0x66, 0x66, 0x02, 0x66, 0x66, 0x66, 0x03,
|
|
|
- 0x22, 0x22, 0x22, 0xff, 0x22, 0x22, 0x22, 0xff, 0x77, 0x77, 0x77, 0xff,
|
|
|
- 0x00, 0x00, 0x00, 0xff, 0x33, 0x33, 0x33, 0xff, 0xff, 0xff, 0xff, 0xff,
|
|
|
- },
|
|
|
- },
|
|
|
- },
|
|
|
- }
|
|
|
-
|
|
|
- for _, tc := range testCases {
|
|
|
- t.Run(tc.name, func(t *testing.T) {
|
|
|
- got := AdjustSaturation(tc.src, tc.p)
|
|
|
- if !compareNRGBA(got, tc.want, 0) {
|
|
|
- t.Fatalf("got result %#v want %#v", got, tc.want)
|
|
|
- }
|
|
|
- })
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-func BenchmarkAdjustSaturation(b *testing.B) {
|
|
|
- b.ReportAllocs()
|
|
|
- for i := 0; i < b.N; i++ {
|
|
|
- AdjustSaturation(testdataBranchesJPG, 50)
|
|
|
- }
|
|
|
-}
|