Быстрое преобразование Фурье N-D
Y = fftn(
возвращает многомерное преобразование Фурье массива N-D с помощью алгоритма быстрого преобразования Фурье. N-D преобразовывают, эквивалентно вычислению 1D преобразования по каждому измерению X
)X
. Выход Y
одного размера с X
.
Y = fftn(
обрезает X
,sz
)X
или клавиатуры X
с конечными нулями прежде, чем взять преобразование согласно элементам векторного sz
. Каждый элемент sz
задает продолжительность соответствия, преобразовывают размерности. Например, если X
5 массивом 5 на 5, затем Y = fftn(X,[8 8 8])
клавиатуры каждая размерность с нулями, приводящими к 8 8 8, преобразовывают Y
.
Можно использовать fftn
функция, чтобы вычислить 1D быстрое преобразование Фурье в каждой размерности многомерного массива.
Создайте 3-D X
сигнала. Размер
X
20 20 20.
x = (1:20)'; y = 1:20; z = reshape(1:20,[1 1 20]); X = cos(2*pi*0.01*x) + sin(2*pi*0.02*y) + cos(2*pi*0.03*z);
Вычислите 3-D преобразование Фурье сигнала, который является также 20 20 20 массивами.
Y = fftn(X);
Заполните X
с нулями, чтобы вычислить 32 32 32 преобразовывают.
m = nextpow2(20); Y = fftn(X,[2^m 2^m 2^m]); size(Y)
ans = 1×3
32 32 32
X
— Входной массивВходной массив в виде матрицы или многомерного массива. Если X
имеет тип single
, затем fftn
исходно вычисляет в одинарной точности и Y
также имеет тип single
. В противном случае, Y
возвращен как тип double
.
Типы данных: double |
single
| int8
| int16
| int32
| uint8
| uint16
| uint32
| logical
Поддержка комплексного числа: Да
sz
— Длина размерностей преобразованияДлина размерностей преобразования в виде вектора из положительных целых чисел. Элементы sz
соответствуйте продолжительностям преобразования соответствующих размерностей X
. length(sz)
должен быть, по крайней мере, ndims(X)
.
Типы данных: single
| double
| int8
| int16
| int32
| uint8
| uint16
| uint32
| logical
Дискретное преобразование Фурье Y N-D массив X задано как
Каждая размерность имеет длину mk для k = 1,2..., N, и комплексные корни из единицы, где i является мнимой единицей.
Указания и ограничения по применению:
sz
аргумент должен иметь фиксированный размер.
Для MEX выход, MATLAB® Coder™ пользуется библиотекой, которой MATLAB пользуется для Алгоритмов бпф. Для автономного кода C/C++, по умолчанию, генератор кода производит код для Алгоритмов бпф вместо того, чтобы произвести вызовы библиотеки FFT. Чтобы сгенерировать вызовы определенной установленной библиотеки FFTW, обеспечьте класс коллбэка библиотеки FFT. Для получения дополнительной информации о классе коллбэка библиотеки FFT, смотрите coder.fftw.StandaloneFFTW3Interface
(MATLAB Coder).
Для симуляции блока MATLAB Function программное обеспечение симуляции пользуется библиотекой, которой MATLAB пользуется для Алгоритмов бпф. Для генерации кода C/C++, по умолчанию, генератор кода производит код для Алгоритмов бпф вместо того, чтобы произвести вызовы библиотеки FFT. Чтобы сгенерировать вызовы определенной установленной библиотеки FFTW, обеспечьте класс коллбэка библиотеки FFT. Для получения дополнительной информации о классе коллбэка библиотеки FFT, смотрите coder.fftw.StandaloneFFTW3Interface
(MATLAB Coder).
Используя Заменяющую библиотеку кода (CRL), можно сгенерировать оптимизированный код, который работает на ARM® Кора®- Процессоры с Неоновым расширением. Чтобы сгенерировать этот оптимизированный код, необходимо установить Embedded Coder® Пакет поддержки для процессоров ARM Cortex-A (Пакет поддержки Embedded Coder для процессоров ARM Cortex-A). Сгенерированный код для ARM Cortex-A пользуется библиотекой Ne10. Для получения дополнительной информации см. Условия Ne10 для функций MATLAB, чтобы Поддержать процессоры ARM Cortex-A (Пакет поддержки Embedded Coder для процессоров ARM Cortex-A).
Используя Заменяющую библиотеку кода (CRL), можно сгенерировать оптимизированный код, который работает на процессорах ARM Cortex-M. Чтобы сгенерировать этот оптимизированный код, необходимо установить Пакет поддержки Embedded Coder для процессоров ARM Cortex-M (Пакет поддержки Embedded Coder для процессоров ARM Cortex-M). Сгенерированный код для ARM Cortex-M пользуется библиотекой CMSIS. Для получения дополнительной информации см. Условия CMSIS для функций MATLAB, чтобы Поддержать процессоры ARM Cortex-M (Пакет поддержки Embedded Coder для процессоров ARM Cortex-M).
Указания и ограничения по применению:
sz
аргумент должен иметь фиксированный размер.
backgroundPool
или ускорьте код с Parallel Computing Toolbox™ ThreadPool
.Эта функция полностью поддерживает основанные на потоке среды. Для получения дополнительной информации смотрите функции MATLAB Запуска в Основанной на потоке Среде.
Указания и ограничения по применению:
Выход Y
является всегда комплексным, даже если все мнимые части являются нулем.
Для получения дополнительной информации смотрите функции MATLAB Запуска на графическом процессоре (Parallel Computing Toolbox).
Эта функция полностью поддерживает распределенные массивы. Для получения дополнительной информации смотрите функции MATLAB Запуска с Распределенными Массивами (Parallel Computing Toolbox).
У вас есть модифицированная версия этого примера. Вы хотите открыть этот пример со своими редактированиями?
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.