mirror of
https://github.com/mikeoliphant/neural-amp-modeler-lv2.git
synced 2026-05-09 20:29:12 +02:00
Fixed propagation of native arch optimizations
This commit is contained in:
Vendored
+1
-1
Submodule deps/NeuralAudio updated: 3ce06272eb...cd8f329630
+29
-29
@@ -1,8 +1,29 @@
|
|||||||
add_subdirectory(../deps/NeuralAudio NeuralAudio)
|
if (MSVC)
|
||||||
|
add_compile_options(
|
||||||
|
"$<$<CONFIG:DEBUG>:/W4>"
|
||||||
|
"$<$<CONFIG:RELEASE>:/O2>"
|
||||||
|
)
|
||||||
|
else()
|
||||||
|
add_compile_options(
|
||||||
|
-Wall
|
||||||
|
# -Wpedantic -Wextra -Wstrict-aliasing -Wunreachable-code -Weffc++ -Wno-unused-parameter
|
||||||
|
"$<$<CONFIG:DEBUG>:-Og;-ggdb>"
|
||||||
|
"$<$<CONFIG:RELWITHDEBINFO>:-Ofast>"
|
||||||
|
"$<$<CONFIG:RELEASE>:-Ofast>"
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
include_directories(SYSTEM ../deps/NeuralAudio)
|
|
||||||
include_directories(SYSTEM ../deps/lv2/include)
|
if (CMAKE_SYSTEM_PROCESSOR MATCHES "(amd64)|(AMD64)|(x86_64)")
|
||||||
include_directories(SYSTEM ../deps/denormal)
|
option(USE_NATIVE_ARCH "Enable architecture-specific optimizations" OFF)
|
||||||
|
|
||||||
|
if (USE_NATIVE_ARCH)
|
||||||
|
add_compile_options(-march=x86-64-v3)
|
||||||
|
message("Enabling -march=x86-64-v3")
|
||||||
|
endif (USE_NATIVE_ARCH)
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
add_subdirectory(../deps/NeuralAudio NeuralAudio)
|
||||||
|
|
||||||
set(SOURCES nam_lv2.cpp
|
set(SOURCES nam_lv2.cpp
|
||||||
nam_plugin.cpp
|
nam_plugin.cpp
|
||||||
@@ -12,6 +33,10 @@ set(NA_SOURCES ../deps/NeuralAudio/NeuralAudio/NeuralModel.h)
|
|||||||
|
|
||||||
add_library(neural_amp_modeler SHARED ${SOURCES} ${NA_SOURCES})
|
add_library(neural_amp_modeler SHARED ${SOURCES} ${NA_SOURCES})
|
||||||
|
|
||||||
|
target_include_directories(neural_amp_modeler PUBLIC ../deps/NeuralAudio)
|
||||||
|
target_include_directories(neural_amp_modeler PUBLIC ../deps/lv2/include)
|
||||||
|
target_include_directories(neural_amp_modeler PUBLIC ../deps/denormal)
|
||||||
|
|
||||||
target_link_libraries(neural_amp_modeler PRIVATE NeuralAudio)
|
target_link_libraries(neural_amp_modeler PRIVATE NeuralAudio)
|
||||||
|
|
||||||
source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} FILES ${SOURCES})
|
source_group(TREE ${CMAKE_CURRENT_SOURCE_DIR} FILES ${SOURCES})
|
||||||
@@ -35,16 +60,6 @@ if (WAVENET_PREFER_NAM)
|
|||||||
add_definitions(-DWAVENET_PREFER_NAM)
|
add_definitions(-DWAVENET_PREFER_NAM)
|
||||||
endif (WAVENET_PREFER_NAM)
|
endif (WAVENET_PREFER_NAM)
|
||||||
|
|
||||||
|
|
||||||
if (CMAKE_SYSTEM_PROCESSOR MATCHES "(amd64)|(AMD64)|(x86_64)")
|
|
||||||
option(USE_NATIVE_ARCH "Enable architecture-specific optimizations" OFF)
|
|
||||||
|
|
||||||
if (USE_NATIVE_ARCH)
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=x86-64-v3")
|
|
||||||
message("Enabling -march=x86-64-v3")
|
|
||||||
endif (USE_NATIVE_ARCH)
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
set_target_properties(neural_amp_modeler
|
set_target_properties(neural_amp_modeler
|
||||||
PROPERTIES
|
PROPERTIES
|
||||||
CXX_VISIBILITY_PRESET hidden
|
CXX_VISIBILITY_PRESET hidden
|
||||||
@@ -57,18 +72,3 @@ set_target_properties(neural_amp_modeler
|
|||||||
if (CMAKE_SYSTEM_NAME STREQUAL "Windows")
|
if (CMAKE_SYSTEM_NAME STREQUAL "Windows")
|
||||||
target_compile_definitions(neural_amp_modeler PRIVATE NOMINMAX WIN32_LEAN_AND_MEAN)
|
target_compile_definitions(neural_amp_modeler PRIVATE NOMINMAX WIN32_LEAN_AND_MEAN)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (MSVC)
|
|
||||||
target_compile_options(neural_amp_modeler PRIVATE
|
|
||||||
"$<$<CONFIG:DEBUG>:/W4>"
|
|
||||||
"$<$<CONFIG:RELEASE>:/O2>"
|
|
||||||
)
|
|
||||||
else()
|
|
||||||
target_compile_options(neural_amp_modeler PRIVATE
|
|
||||||
-Wall
|
|
||||||
# -Wpedantic -Wextra -Wstrict-aliasing -Wunreachable-code -Weffc++ -Wno-unused-parameter
|
|
||||||
"$<$<CONFIG:DEBUG>:-Og;-ggdb>"
|
|
||||||
"$<$<CONFIG:RELWITHDEBINFO>:-Ofast>"
|
|
||||||
"$<$<CONFIG:RELEASE>:-Ofast>"
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|||||||
+13
-5
@@ -11,15 +11,23 @@ namespace NAM {
|
|||||||
Plugin::Plugin()
|
Plugin::Plugin()
|
||||||
{
|
{
|
||||||
// prevent allocations on the audio thread
|
// prevent allocations on the audio thread
|
||||||
currentModelPath.reserve(MAX_FILE_NAME+1);
|
currentModelPath.reserve(MAX_FILE_NAME + 1);
|
||||||
|
|
||||||
#ifdef LSTM_PREFER_NAM // Use NAM Core for NAM LSTM models
|
NeuralAudio::NeuralModel::SetLSTMLoadMode(
|
||||||
NeuralAudio::NeuralModel::SetLSTMLoadMode(NeuralAudio::PreferNAMCore);
|
#ifdef LSTM_PREFER_NAM
|
||||||
|
NeuralAudio::PreferNAMCore
|
||||||
|
#else
|
||||||
|
NeuralAudio::PreferRTNeural
|
||||||
#endif
|
#endif
|
||||||
|
);
|
||||||
|
|
||||||
#ifdef WAVENET_PREFER_NAM // Use NAM Core for NAM WaveNet models
|
NeuralAudio::NeuralModel::SetWaveNetLoadMode(
|
||||||
NeuralAudio::NeuralModel::SetWaveNetLoadMode(NeuralAudio::PreferNAMCore);
|
#ifdef WAVENET_PREFER_NAM
|
||||||
|
NeuralAudio::PreferNAMCore
|
||||||
|
#else
|
||||||
|
NeuralAudio::PreferRTNeural
|
||||||
#endif
|
#endif
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
Plugin::~Plugin()
|
Plugin::~Plugin()
|
||||||
|
|||||||
Reference in New Issue
Block a user