From d14602c85b81a3adc6de8ada20833864006bf8eb Mon Sep 17 00:00:00 2001 From: Adam Sampson Date: Mon, 25 May 2020 15:39:13 +0100 Subject: [PATCH] Add options for NTSC noise reduction levels. --- tools/ld-chroma-decoder/main.cpp | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/tools/ld-chroma-decoder/main.cpp b/tools/ld-chroma-decoder/main.cpp index c3f923bb3..0315e54da 100644 --- a/tools/ld-chroma-decoder/main.cpp +++ b/tools/ld-chroma-decoder/main.cpp @@ -181,6 +181,18 @@ int main(int argc, char *argv[]) QCoreApplication::translate("main", "NTSC: Use 75% white-point (default 100%)")); parser.addOption(whitePointOption); + // Option to set the chroma noise reduction level + QCommandLineOption chromaNROption(QStringList() << "chroma-nr", + QCoreApplication::translate("main", "NTSC: Chroma noise reduction level in dB (default 0.0)"), + QCoreApplication::translate("main", "number")); + parser.addOption(chromaNROption); + + // Option to set the luma noise reduction level + QCommandLineOption lumaNROption(QStringList() << "luma-nr", + QCoreApplication::translate("main", "NTSC: Luma noise reduction level in dB (default 1.0)"), + QCoreApplication::translate("main", "number")); + parser.addOption(lumaNROption); + // -- PAL decoder options -- // Option to use Simple PAL UV filter @@ -313,6 +325,26 @@ int main(int argc, char *argv[]) combConfig.showOpticalFlowMap = true; } + if (parser.isSet(chromaNROption)) { + combConfig.cNRLevel = parser.value(chromaNROption).toDouble(); + + if (combConfig.cNRLevel < 0.0) { + // Quit with error + qCritical("Chroma noise reduction cannot be negative"); + return -1; + } + } + + if (parser.isSet(lumaNROption)) { + combConfig.yNRLevel = parser.value(lumaNROption).toDouble(); + + if (combConfig.yNRLevel < 0.0) { + // Quit with error + qCritical("Luma noise reduction cannot be negative"); + return -1; + } + } + if (parser.isSet(transformModeOption)) { const QString name = parser.value(transformModeOption);