Adding upstream version 0.0~git20250520.a1d9079+dfsg.
Signed-off-by: Daniel Baumann <daniel@debian.org>
This commit is contained in:
parent
590ac7ff5f
commit
20149b7f3a
456 changed files with 70406 additions and 0 deletions
49
exp/f32/vec3.go
Normal file
49
exp/f32/vec3.go
Normal file
|
@ -0,0 +1,49 @@
|
|||
// Copyright 2014 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 f32
|
||||
|
||||
import "fmt"
|
||||
|
||||
type Vec3 [3]float32
|
||||
|
||||
func (v Vec3) String() string {
|
||||
return fmt.Sprintf("Vec3[% 0.3f, % 0.3f, % 0.3f]", v[0], v[1], v[2])
|
||||
}
|
||||
|
||||
func (v *Vec3) Normalize() {
|
||||
sq := v.Dot(v)
|
||||
inv := 1 / Sqrt(sq)
|
||||
v[0] *= inv
|
||||
v[1] *= inv
|
||||
v[2] *= inv
|
||||
}
|
||||
|
||||
func (v *Vec3) Sub(v0, v1 *Vec3) {
|
||||
v[0] = v0[0] - v1[0]
|
||||
v[1] = v0[1] - v1[1]
|
||||
v[2] = v0[2] - v1[2]
|
||||
}
|
||||
|
||||
func (v *Vec3) Add(v0, v1 *Vec3) {
|
||||
v[0] = v0[0] + v1[0]
|
||||
v[1] = v0[1] + v1[1]
|
||||
v[2] = v0[2] + v1[2]
|
||||
}
|
||||
|
||||
func (v *Vec3) Mul(v0, v1 *Vec3) {
|
||||
v[0] = v0[0] * v1[0]
|
||||
v[1] = v0[1] * v1[1]
|
||||
v[2] = v0[2] * v1[2]
|
||||
}
|
||||
|
||||
func (v *Vec3) Cross(v0, v1 *Vec3) {
|
||||
v[0] = v0[1]*v1[2] - v0[2]*v1[1]
|
||||
v[1] = v0[2]*v1[0] - v0[0]*v1[2]
|
||||
v[2] = v0[0]*v1[1] - v0[1]*v1[0]
|
||||
}
|
||||
|
||||
func (v *Vec3) Dot(v1 *Vec3) float32 {
|
||||
return v[0]*v1[0] + v[1]*v1[1] + v[2]*v1[2]
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue