Реализуйте дискретное преобразование Фурье (ДПФ) для последовательности любой длины. Это может быть реализовано как функция или программа, а последовательность может быть задана как аргумент или с использованием стандартного ввода.
Алгоритм вычислит результат на основе стандартного ДПФ в прямом направлении. Входная последовательность имеет длину N
и состоит из [x(0), x(1), ..., x(N-1)]
. Выходная последовательность будет иметь одинаковую длину и состоит из тех, [X(0), X(1), ..., X(N-1)]
где каждая X(k)
определяется соотношением ниже.
правила
- Это Код-гольф поэтому выигрывает самое короткое решение.
- Встроенные функции, которые вычисляют ДПФ в прямом или обратном (также называемом обратным) направлениях, не допускаются.
- Неточности с плавающей точкой не будут засчитаны против вас.
Тестовые случаи
DFT([1, 1, 1, 1]) = [4, 0, 0, 0]
DFT([1, 0, 2, 0, 3, 0, 4, 0]) = [10, -2+2j, -2, -2-2j, 10, -2+2j, -2, -2-2j]
DFT([1, 2, 3, 4, 5]) = [15, -2.5+3.44j, -2.5+0.81j, -2.5-0.81j, -2.5-3.44j]
DFT([5-3.28571j, -0.816474-0.837162j, 0.523306-0.303902j, 0.806172-3.69346j, -4.41953+2.59494j, -0.360252+2.59411j, 1.26678+2.93119j] = [2, -3j, 5, -7j, 11, -13j, 17]
Помогите
Ранее была проблема с поиском ДПФ с использованием алгоритма БПФ для последовательностей с длиной, равной степени 2. Здесь вы можете найти некоторые приемы, которые могут вам помочь. Имейте в виду, что эта задача не ограничивает вас какой-либо сложностью, а также требует, чтобы ваше решение работало для последовательностей любой длины.