-
Notifications
You must be signed in to change notification settings - Fork 4
/
doc.go
48 lines (48 loc) · 2.78 KB
/
doc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Package vecf64 provides common functions and methods for slices of float64.
//
// Name
//
// In the days of yore, scientists who computed with computers would use arrays to represent vectors, each value representing
// magnitude and/or direction. Then came the C++ Standard Templates Library, which sought to provide this data type in the standard
// library. Now, everyone conflates a term "vector" with dynamic arrays.
//
// In the C++ book, Bjarne Stroustrup has this to say:
// One could argue that valarray should have been called vector because is is a traditional mathematical vector
// and that vector should have been called array.
// However, this is not the way that the terminology evolved.
// A valarray is a vector optimized for numeric computation;
// a vector is a flexible container designed for holding and manipulating objects of a wide variety of types;
// and an array is a low-level built-in type
//
// Go has a better name for representing dynamically allocated arrays of any type - "slice". However, "slice" is both a noun and verb
// and many libraries that I use already use "slice"-as-a-verb as a name, so I had to settle for the second best name: "vector".
//
// It should be noted that while the names used in this package were definitely mathematically inspired, they bear only little resemblance
// the actual mathematical operations performed.
//
// Naming Convention
//
// The names of the operations assume you're working with slices of float64s. Hence `Add` performs elementwise addition between two []float64.
//
// Operations between []float64 and float64 are also supported, however they are differently named. Here are the equivalents:
/*
+------------------------+--------------------------------------+
| []float64-[]float64 Op | []float64-float64 Op |
+------------------------+--------------------------------------+
| Add(a, b []float64) | Trans(a float64, b []float64) |
| Sub(a, b []float64) | Trans/TransR(a float64, b []float64) |
| Mul(a, b []float64) | Scale(a float64, b []float64) |
| Div(a, b []float64) | Scale/DivR(a float64, b []float64) |
| Pow(a, b []float64) | PowOf/PowOfR(a float64, b []float64) |
+------------------------+--------------------------------------+
*/
// You may note that for the []float64 - float64 binary operations, the scalar (float64) is always the first operand. In operations
// that are not commutative, an additional function is provided, suffixed with "R" (for reverse)
//
// Range Check and BCE
//
// This package does not provide range checking. If indices are out of range, the functions will panic. This package should play well with BCE.
//
// TODO: provide SIMD vectorization for Incr and []float32-float64 functions.
// Pull requests accepted
package vecf64 // import "gorgonia.org/vecf64"