Add ffts as a submodule (because this is what ViPER used)

This commit is contained in:
Iscle 2023-03-02 02:37:55 +01:00
parent 942988d1b0
commit 8eed46db09
5 changed files with 27 additions and 24 deletions

6
.gitmodules vendored
View File

@ -1,3 +1,3 @@
[submodule "src/viper/kissfft"] [submodule "src/viper/ffts"]
path = src/viper/kissfft path = src/viper/ffts
url = git@github.com:mborgerding/kissfft.git url = git@github.com:anthonix/ffts.git

View File

@ -11,12 +11,8 @@ project("ViPER4Android")
add_compile_definitions(VERSION_CODE=20221231) add_compile_definitions(VERSION_CODE=20221231)
add_compile_definitions(VERSION_NAME="0.1.0") add_compile_definitions(VERSION_NAME="0.1.0")
## KISS FFT # FFTS
#set(KISSFFT_PKGCONFIG OFF) add_subdirectory(src/viper/ffts)
#set(KISSFFT_STATIC ON)
#set(KISSFFT_TEST OFF)
#set(KISSFFT_TOOLS OFF)
#add_subdirectory(src/cpp/viper/kissfft)
# ViPERFX # ViPERFX
include_directories(src/include) include_directories(src/include)

1
src/viper/ffts Submodule

@ -0,0 +1 @@
Subproject commit fe86885ecafd0d16eb122f3212403d1d5a86e24e

View File

@ -3,8 +3,8 @@
#include "PConvSingle.h" #include "PConvSingle.h"
PConvSingle::PConvSingle() { PConvSingle::PConvSingle() {
this->enabled = false; this->instanceUsable = false;
this->segments = 0; this->segmentCount = 0;
this->segmentSize = 0; this->segmentSize = 0;
// this->data = nullptr; // this->data = nullptr;
} }
@ -30,7 +30,7 @@ int PConvSingle::GetFFTSize() {
} }
int PConvSingle::GetSegmentCount() { int PConvSingle::GetSegmentCount() {
return this->segments; return this->segmentCount;
} }
int PConvSingle::GetSegmentSize() { int PConvSingle::GetSegmentSize() {
@ -38,18 +38,18 @@ int PConvSingle::GetSegmentSize() {
} }
bool PConvSingle::InstanceUsable() { bool PConvSingle::InstanceUsable() {
return this->enabled; return this->instanceUsable;
} }
int PConvSingle::LoadKernel(float *buf, int param_2, int segmentSize) { int PConvSingle::LoadKernel(float *buf, int param_2, int segmentSize) {
if (buf != nullptr && param_2 > 0 && segmentSize > 0 && segmentSize % 2 == 0) { if (buf != nullptr && param_2 > 0 && segmentSize > 0 && segmentSize % 2 == 0) {
this->enabled = false; this->instanceUsable = false;
ReleaseResources(); ReleaseResources();
// this->data = new PConvData(); //(PConvData *) malloc(0x140); // TODO: Sizeof this->data = new PConvData(); //(PConvData *) malloc(0x140); // TODO: Sizeof
this->segmentSize = segmentSize; this->segmentSize = segmentSize;
int n = ProcessKernel(buf, param_2, 1); int n = ProcessKernel(buf, param_2, 1);
if (n != 0) { if (n != 0) {
this->enabled = true; this->instanceUsable = true;
return n; return n;
} }
ReleaseResources(); ReleaseResources();
@ -84,18 +84,20 @@ int PConvSingle::ProcessKernel(int param_2, float *param_3, int param_4, int par
} }
void PConvSingle::ReleaseResources() { void PConvSingle::ReleaseResources() {
if (this->data != nullptr) {
// TODO // TODO
this->enabled = false; }
this->segments = 0; this->instanceUsable = false;
this->segmentCount = 0;
this->segmentSize = 0; this->segmentSize = 0;
} }
void PConvSingle::Reset() { void PConvSingle::Reset() {
if (!this->enabled) return; if (!this->instanceUsable) return;
// TODO // TODO
} }
void PConvSingle::UnloadKernel() { void PConvSingle::UnloadKernel() {
this->enabled = false; this->instanceUsable = false;
ReleaseResources(); ReleaseResources();
} }

View File

@ -1,6 +1,9 @@
#pragma once #pragma once
class PConvSingle { class PConvSingle {
struct PConvData {
};
public: public:
PConvSingle(); PConvSingle();
@ -34,7 +37,8 @@ public:
void UnloadKernel(); void UnloadKernel();
bool enabled; bool instanceUsable;
int segments, segmentSize; int segmentCount;
// PConvData *data; // TODO: Type int segmentSize;
PConvData *data;
}; };