gonum.org/v1/gonum@v0.14.0/num/quat/nan_test.go (about)

     1  // Copyright ©2018 The Gonum Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  package quat
     6  
     7  import (
     8  	"math"
     9  	"testing"
    10  )
    11  
    12  var nan = math.NaN()
    13  
    14  var nanTests = []struct {
    15  	q    Number
    16  	want bool
    17  }{
    18  	{q: NaN(), want: true},
    19  	{q: Number{Real: nan, Imag: nan, Jmag: nan, Kmag: nan}, want: true},
    20  	{q: Number{Real: nan, Imag: 0, Jmag: 0, Kmag: 0}, want: true},
    21  	{q: Number{Real: 0, Imag: nan, Jmag: 0, Kmag: 0}, want: true},
    22  	{q: Number{Real: 0, Imag: 0, Jmag: nan, Kmag: 0}, want: true},
    23  	{q: Number{Real: 0, Imag: 0, Jmag: 0, Kmag: nan}, want: true},
    24  	{q: Number{Real: inf, Imag: nan, Jmag: nan, Kmag: nan}, want: false},
    25  	{q: Number{Real: nan, Imag: inf, Jmag: nan, Kmag: nan}, want: false},
    26  	{q: Number{Real: nan, Imag: nan, Jmag: inf, Kmag: nan}, want: false},
    27  	{q: Number{Real: nan, Imag: nan, Jmag: nan, Kmag: inf}, want: false},
    28  	{q: Number{Real: -inf, Imag: nan, Jmag: nan, Kmag: nan}, want: false},
    29  	{q: Number{Real: nan, Imag: -inf, Jmag: nan, Kmag: nan}, want: false},
    30  	{q: Number{Real: nan, Imag: nan, Jmag: -inf, Kmag: nan}, want: false},
    31  	{q: Number{Real: nan, Imag: nan, Jmag: nan, Kmag: -inf}, want: false},
    32  	{q: Number{}, want: false},
    33  }
    34  
    35  func TestIsNaN(t *testing.T) {
    36  	t.Parallel()
    37  	for _, test := range nanTests {
    38  		got := IsNaN(test.q)
    39  		if got != test.want {
    40  			t.Errorf("unexpected result for IsNaN(%v): got:%t want:%t", test.q, got, test.want)
    41  		}
    42  	}
    43  }