mirror of
https://github.com/gonum/gonum.git
synced 2025-09-27 03:26:04 +08:00

Changes made in dsp/fourier/internal/fftpack break the formatting used there, so these are reverted. There will be complaints in CI. [git-generate] gofmt -w . go generate gonum.org/v1/gonum/blas go generate gonum.org/v1/gonum/blas/gonum go generate gonum.org/v1/gonum/unit go generate gonum.org/v1/gonum/unit/constant go generate gonum.org/v1/gonum/graph/formats/dot go generate gonum.org/v1/gonum/graph/formats/rdf go generate gonum.org/v1/gonum/stat/card git checkout -- dsp/fourier/internal/fftpack
86 lines
1.7 KiB
Go
86 lines
1.7 KiB
Go
// Copyright ©2016 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.
|
|
|
|
package c64
|
|
|
|
// ScalUnitary is
|
|
//
|
|
// for i := range x {
|
|
// x[i] *= alpha
|
|
// }
|
|
func ScalUnitary(alpha complex64, x []complex64) {
|
|
for i := range x {
|
|
x[i] *= alpha
|
|
}
|
|
}
|
|
|
|
// ScalUnitaryTo is
|
|
//
|
|
// for i, v := range x {
|
|
// dst[i] = alpha * v
|
|
// }
|
|
func ScalUnitaryTo(dst []complex64, alpha complex64, x []complex64) {
|
|
for i, v := range x {
|
|
dst[i] = alpha * v
|
|
}
|
|
}
|
|
|
|
// ScalInc is
|
|
//
|
|
// var ix uintptr
|
|
// for i := 0; i < int(n); i++ {
|
|
// x[ix] *= alpha
|
|
// ix += incX
|
|
// }
|
|
func ScalInc(alpha complex64, x []complex64, n, incX uintptr) {
|
|
var ix uintptr
|
|
for i := 0; i < int(n); i++ {
|
|
x[ix] *= alpha
|
|
ix += incX
|
|
}
|
|
}
|
|
|
|
// ScalIncTo is
|
|
//
|
|
// var idst, ix uintptr
|
|
// for i := 0; i < int(n); i++ {
|
|
// dst[idst] = alpha * x[ix]
|
|
// ix += incX
|
|
// idst += incDst
|
|
// }
|
|
func ScalIncTo(dst []complex64, incDst uintptr, alpha complex64, x []complex64, n, incX uintptr) {
|
|
var idst, ix uintptr
|
|
for i := 0; i < int(n); i++ {
|
|
dst[idst] = alpha * x[ix]
|
|
ix += incX
|
|
idst += incDst
|
|
}
|
|
}
|
|
|
|
// SscalUnitary is
|
|
//
|
|
// for i, v := range x {
|
|
// x[i] = complex(real(v)*alpha, imag(v)*alpha)
|
|
// }
|
|
func SscalUnitary(alpha float32, x []complex64) {
|
|
for i, v := range x {
|
|
x[i] = complex(real(v)*alpha, imag(v)*alpha)
|
|
}
|
|
}
|
|
|
|
// SscalInc is
|
|
//
|
|
// var ix uintptr
|
|
// for i := 0; i < int(n); i++ {
|
|
// x[ix] = complex(real(x[ix])*alpha, imag(x[ix])*alpha)
|
|
// ix += inc
|
|
// }
|
|
func SscalInc(alpha float32, x []complex64, n, inc uintptr) {
|
|
var ix uintptr
|
|
for i := 0; i < int(n); i++ {
|
|
x[ix] = complex(real(x[ix])*alpha, imag(x[ix])*alpha)
|
|
ix += inc
|
|
}
|
|
}
|