27 lines
859 B
Go
27 lines
859 B
Go
// Copyright ©2018 The Gonum Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// Copyright 2017 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package quat
|
|
|
|
import "math"
|
|
|
|
// IsNaN returns true if any of real(q), imag(q), jmag(q), or kmag(q) is NaN
|
|
// and none are an infinity.
|
|
func IsNaN(q Number) bool {
|
|
if math.IsInf(q.Real, 0) || math.IsInf(q.Imag, 0) || math.IsInf(q.Jmag, 0) || math.IsInf(q.Kmag, 0) {
|
|
return false
|
|
}
|
|
return math.IsNaN(q.Real) || math.IsNaN(q.Imag) || math.IsNaN(q.Jmag) || math.IsNaN(q.Kmag)
|
|
}
|
|
|
|
// NaN returns a quaternion “not-a-number” value.
|
|
func NaN() Number {
|
|
nan := math.NaN()
|
|
return Number{Real: nan, Imag: nan, Jmag: nan, Kmag: nan}
|
|
}
|