Skip to content

Instantly share code, notes, and snippets.

@justinmeiners
Created June 11, 2021 16:32
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save justinmeiners/c61c22c9f51211f0585a5ff43ec9620c to your computer and use it in GitHub Desktop.
Save justinmeiners/c61c22c9f51211f0585a5ff43ec9620c to your computer and use it in GitHub Desktop.
extension Sequence where Element == Float {
// average is a vector space operation
func average() -> Element {
let one = Float(1.0)
var mean = Element.zero
var n = Float(0.0)
for x in self {
n += one
mean = mean + (x - mean) / n
}
return mean
}
}
extension Sequence where Element: SIMD, Element.Scalar: FloatingPoint {
// average is a vector space operation
func average() -> Element {
let one = Element.one[0]
var mean = Element.zero
var n = mean[0]
for x in self {
n += one
mean = mean + (x - mean) / n
}
return mean
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment