| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- /* Copyright 2018 The TensorFlow Authors. All Rights Reserved.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- ==============================================================================*/
- #include "tensorflow/lite/experimental/microfrontend/lib/fft_util.h"
- #include <stdio.h>
- #define FIXED_POINT 16
- #include "kiss_fft.h"
- #include "tools/kiss_fftr.h"
- int FftPopulateState(struct FftState* state, size_t input_size) {
- state->input_size = input_size;
- state->fft_size = 1;
- while (state->fft_size < state->input_size) {
- state->fft_size <<= 1;
- }
- state->input = reinterpret_cast<int16_t*>(
- malloc(state->fft_size * sizeof(*state->input)));
- if (state->input == nullptr) {
- fprintf(stderr, "Failed to alloc fft input buffer\n");
- return 0;
- }
- state->output = reinterpret_cast<complex_int16_t*>(
- malloc((state->fft_size / 2 + 1) * sizeof(*state->output) * 2));
- if (state->output == nullptr) {
- fprintf(stderr, "Failed to alloc fft output buffer\n");
- return 0;
- }
- // Ask kissfft how much memory it wants.
- size_t scratch_size = 0;
- kiss_fftr_cfg kfft_cfg = kiss_fftr_alloc(
- state->fft_size, 0, nullptr, &scratch_size);
- if (kfft_cfg != nullptr) {
- fprintf(stderr, "Kiss memory sizing failed.\n");
- return 0;
- }
- state->scratch = malloc(scratch_size);
- if (state->scratch == nullptr) {
- fprintf(stderr, "Failed to alloc fft scratch buffer\n");
- return 0;
- }
- state->scratch_size = scratch_size;
- // Let kissfft configure the scratch space we just allocated
- kfft_cfg = kiss_fftr_alloc(state->fft_size, 0,
- state->scratch, &scratch_size);
- if (kfft_cfg != state->scratch) {
- fprintf(stderr, "Kiss memory preallocation strategy failed.\n");
- return 0;
- }
- return 1;
- }
- void FftFreeStateContents(struct FftState* state) {
- free(state->input);
- free(state->output);
- free(state->scratch);
- }
|