Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FEAT(client): Restore RNNoise for version 0.2 #6607

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

guillermofbriceno
Copy link

@guillermofbriceno guillermofbriceno commented Oct 13, 2024

Reverts #6364 and adds the xiph/rnnoise repository at main. This addresses #6395.

There were a couple of requirements for this PR set by @Hartmnt in #6395 (comment). I do not have multiple platforms to test the build, but it works on my Linux host. Regarding examples, there are some good examples posted on the regression item. A friend and I did some light testing on Mumble and had similar results. I do not have the hardware to test on multiple audio devices.

Other than that, I think this fulfills the other requirements, but please let me know. Since this reverts an old merge, forgive me if there are style issues.

Checks

@guillermofbriceno guillermofbriceno force-pushed the rnn2 branch 3 times, most recently from d5e9670 to 36e3c59 Compare October 14, 2024 00:43
@guillermofbriceno
Copy link
Author

Just noticed I forgot to enable rnnoise so it builds by default, since it was originally turned off before Mumble switched to ReNameNoise. I had it turned on manually. Sorry in advance for prompting another build check.

@Krzmbrzl
Copy link
Member

@guillermofbriceno Is there a good reason that this PR is still in draft mode?

@Hartmnt
Copy link
Member

Hartmnt commented Jan 11, 2025

@guillermofbriceno Is there a good reason that this PR is still in draft mode?

It does not compile. See the discussion in the original issue. (It seems to be abandoned at this point)

@guillermofbriceno
Copy link
Author

I had a possible solution to the platform problem, hesitated whether it would work, and never got around to cleaning it up. I'll take another crack at it.

@guillermofbriceno
Copy link
Author

guillermofbriceno commented Jan 12, 2025

Nice seeing the Windows build pass. FreeBSD failed from what looks like a Qt module version deprecation, rebased my commit to the latest master.

@guillermofbriceno guillermofbriceno marked this pull request as ready for review January 12, 2025 02:21
Copy link
Member

@Krzmbrzl Krzmbrzl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

3rdparty/rnnoise-build/CMakeLists.txt Outdated Show resolved Hide resolved
@guillermofbriceno guillermofbriceno force-pushed the rnn2 branch 2 times, most recently from 68d53c9 to 74ad84e Compare January 15, 2025 03:24
@davidebeatrici
Copy link
Member

@guillermofbriceno Could you rebase against master, please? We fixed the macOS build: #6703

Reverted the merge which added ReNameNoise as an RNNoise replacement.
Added the git submodule from xiph/rnnoise after removing ReNameNoise.
Chose to go with rnnoise's `main` here.

Resolves mumble-voip#6395
Reverts mumble-voip#6364
Copy link
Member

@Hartmnt Hartmnt left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Overall:

  • I guess this compiles on all platforms, which I find slightly surprising so hats off. I don't have a Windows system to test it nor do I want one. So I guess we will see, if any runtime issues arise.

  • This reintroduces our CMake glue, which is not ideal, but I guess it technically works with CMake. Fair enough.

  • But, most importantly and for the record, I personally think upstream has not sufficiently proven that the noise reduction quality is as good or better than v0.1.
    There seem to be a few issues floating around that show v0.2 has some quality regressions: e.g. it does not seem to filter keyboard clicks as good as v0.1 which may or may not be addressed by now.
    It would have been nice of upstream to provide samples and or show us downstream projects which already use v0.2 so we can experience it ourselves. Nothing of that happened. It seems to be more of a "trust me, bro".

But OK, I realize I might be biased because I spent so many hours on creating the ReNameNoise fork, so I don't plan on blocking this PR. If it turns out that any issues arise from this in the Mumble 1.6 RCs, I will not have any hesitation reverting this, though.


if(MSVC)
# Use malloc() and free() instead of variable length arrays (unsupported)
target_compile_definitions(rnnoise PRIVATE "USE_MALLOC")
Copy link
Member

@Hartmnt Hartmnt Jan 17, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

USE_MALLOC is not present in upstream RNNoise. Davide introduced it in our first fork, because RNNoise was doing VLAs which it now apparently does not anymore. We can remove this then.

The _USE_MATH_DEFINES I'm not sure. It might be a MSVC specific. If it was instead also introduced for our first fork, please also remove it.


file(READ "${RNNOISE_SRC_DIR}/model_version" rnnoise_model_hash)
string(STRIP ${rnnoise_model_hash} rnnoise_model_hash)
string(CONCAT rnnoise_model_url "${RNNOISE_MODEL_URL}" "${rnnoise_model_hash}" ".tar.gz")
Copy link
Member

@Hartmnt Hartmnt Jan 17, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I dislike the fact that we download the model from a random webserver at compile-time. My build process will not be affected but I strongly suspect this will most likely break the build process for some package maintainers on certain distros.
However, I have no immediate idea how to solve this. If this is not addressed before the merge, I advice downstream package maintainers (who have a problem with this) to just ship Mumble with ReNameNoise.

@@ -831,11 +839,11 @@ void AudioInput::selectNoiseCancel() {
iArg = 1;
break;
case Settings::NoiseCancelRNN:
qWarning("AudioInput: Using ReNameNoise as noise canceller");
qWarning("AudioInput: Using RNNoise as noise canceller");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please explicitly change this message to say RNNoise v0.2. That way we will know what version users are using when they file bug reports.

Also, please change this to use a Log::info() instead of a qWarning

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I assume log::info() is going to come from #6707, I'll wait for that to be merged in and rebase.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For the time being you can use qInfo(), we will eventually replace all calls with the new ones in a dedicated PR.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants