| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- package resize
- import (
- "image"
- "image/color"
- "runtime"
- "testing"
- )
- var img = image.NewGray16(image.Rect(0, 0, 3, 3))
- func init() {
- runtime.GOMAXPROCS(runtime.NumCPU())
- img.Set(1, 1, color.White)
- }
- func Test_Nearest(t *testing.T) {
- m := Resize(6, 0, img, NearestNeighbor)
- if m.At(1, 1) == m.At(2, 2) {
- t.Fail()
- }
- }
- func Test_Param1(t *testing.T) {
- m := Resize(0, 0, img, NearestNeighbor)
- if m.Bounds() != img.Bounds() {
- t.Fail()
- }
- }
- func Test_Param2(t *testing.T) {
- m := Resize(100, 0, img, NearestNeighbor)
- if m.Bounds() != image.Rect(0, 0, 100, 100) {
- t.Fail()
- }
- }
- func Test_ZeroImg(t *testing.T) {
- zeroImg := image.NewGray16(image.Rect(0, 0, 0, 0))
- m := Resize(0, 0, zeroImg, NearestNeighbor)
- if m.Bounds() != zeroImg.Bounds() {
- t.Fail()
- }
- }
- func Test_CorrectResize(t *testing.T) {
- zeroImg := image.NewGray16(image.Rect(0, 0, 256, 256))
- m := Resize(60, 0, zeroImg, NearestNeighbor)
- if m.Bounds() != image.Rect(0, 0, 60, 60) {
- t.Fail()
- }
- }
- func Benchmark_BigResizeLanczos3(b *testing.B) {
- var m image.Image
- for i := 0; i < b.N; i++ {
- m = Resize(1000, 1000, img, Lanczos3)
- }
- m.At(0, 0)
- }
- func Benchmark_BigResizeLanczos3Lut(b *testing.B) {
- var m image.Image
- for i := 0; i < b.N; i++ {
- m = Resize(1000, 1000, img, Lanczos3Lut)
- }
- m.At(0, 0)
- }
- func Benchmark_Reduction(b *testing.B) {
- largeImg := image.NewRGBA(image.Rect(0, 0, 1000, 1000))
- var m image.Image
- for i := 0; i < b.N; i++ {
- m = Resize(300, 300, largeImg, Bicubic)
- }
- m.At(0, 0)
- }
|