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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
use RealNumber;
use std::mem;
use std::ptr;
use super::super::{ToTimeResult, DspVec, Vector, Buffer, ToSliceMut, RededicateForceOps, MetaData,
ComplexNumberSpace, Owner, FrequencyDomain, DataDomain};
pub trait FrequencyDomainOperations<S, T>
where S: ToSliceMut<T>,
T: RealNumber
{
fn mirror<B>(&mut self, buffer: &mut B) where B: Buffer<S, T>;
fn fft_shift<B>(&mut self, buffer: &mut B) where B: Buffer<S, T>;
fn ifft_shift<B>(&mut self, buffer: &mut B) where B: Buffer<S, T>;
}
impl<S, T, N, D> FrequencyDomainOperations<S, T> for DspVec<S, T, N, D>
where DspVec<S, T, N, D>: ToTimeResult,
<DspVec<S, T, N, D> as ToTimeResult>::TimeResult: RededicateForceOps<DspVec<S, T, N, D>>,
S: ToSliceMut<T> + Owner,
T: RealNumber,
N: ComplexNumberSpace,
D: FrequencyDomain
{
fn mirror<B>(&mut self, buffer: &mut B)
where B: Buffer<S, T>
{
if self.domain() != DataDomain::Frequency && !self.is_complex() {
self.valid_len = 0;
return;
}
let len = self.len();
let step = 2;
let temp_len = 2 * len - step;
let mut temp = buffer.get(temp_len);
{
let data = self.data.to_slice();
let mut temp = temp.to_slice_mut();
{
let data = &data[step] as *const T;
let target = &mut temp[step] as *mut T;
unsafe {
ptr::copy(data, target, len - step);
}
}
{
let data = &data[0] as *const T;
let target = &mut temp[0] as *mut T;
unsafe {
ptr::copy(data, target, step);
}
}
let mut j = step + 1;
let mut i = temp_len - 1;
while i >= len {
temp[i] = -data[j];
temp[i - 1] = data[j - 1];
i -= 2;
j += 2;
}
self.valid_len = temp_len;
}
mem::swap(&mut self.data, &mut temp);
buffer.free(temp);
}
fn fft_shift<B>(&mut self, _: &mut B)
where B: Buffer<S, T>
{
self.swap_halves_priv(true)
}
fn ifft_shift<B>(&mut self, _: &mut B)
where B: Buffer<S, T>
{
self.swap_halves_priv(false)
}
}