-
-
Notifications
You must be signed in to change notification settings - Fork 252
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
High End Response #1198
Comments
Not sure if it is a good idea to use the internal dac for this purpose: I would have used a proper audio dac for this! With a sampling rate of 44100 you should be able to get frequencies up to 22050 hz. |
Hey thanks for the response. I'm using a frequency sweep to test, 20hz to 20khz. If I run below 88400 in 2.11 (say 44100), I start seeing a drop off of at around 10khz instead of 20khz. By dropping off I mean it starts getting recorded as a signal at half the hz. If I FFT you'll see it bounce from one end and the peak starts moving backwards. I was getting a lot of dropped packets, but upping the buffers sorted that out. I tested this with a lot of clicks at various bpms, then matching up the beats. If packets / samples are missing, they would go out of sync with the original. The current settings on wifi allow a consistent stream, occasional sample loss, but only after 30 mins recording. The file size and time also help with detecting loss of samples. Using both methods I'm confidant nothing is being lost in my short tests. I forgot to mention the analog signal is coming from a max9814 microphone module. |
Just out of curiosity: how does this compare if you do the recording directly in Audacity ? |
in my first post, if you take a look at the first image, the top was recorded directly in audacity from audio "desktop audio" , I'll see if I've got a mic somewhere to record line in into audacity. Or better yet, I'll rig up the MAX module I'm using to a line in on the pc. https://www.youtube.com/watch?v=PAsMlDptjx8 here is the freq sweep I used, I added a couple of kick drums to the start and end for sync reasons. |
OK, here is a simple endless Arduino sweep sketch: #include "AudioTools.h"
#include "AudioLibs/AudioKit.h"
AudioInfo info(44100, 1, 16);
SineWaveGenerator<int16_t> sineWave; // subclass of SoundGenerator with max amplitude of 32000
GeneratedSoundStream<int16_t> sound(sineWave); // Stream generated from sine wave
AudioKitStream out;
StreamCopy copier(out, sound, 512); // copies sound into i2s
float freq = 20;
// Arduino Setup
void setup(void) {
// Open Serial
Serial.begin(115200);
AudioLogger::instance().begin(Serial, AudioLogger::Warning);
// start I2S
Serial.println("starting I2S...");
auto config = out.defaultConfig(TX_MODE);
config.copyFrom(info);
out.begin(config);
// Setup sine wave
sineWave.begin(info, N_B4);
Serial.println("started...");
}
void sweep(){
freq += 20.0;
if (freq > 20000) {
freq = 20;
}
sineWave.setFrequency(freq);
}
// Arduino loop - copy sound to out
void loop() {
copier.copy();
sweep();
} |
Hey thanks, So, just to check, I should wire two esp32 together, one using i2s out to the other i2s inwards? Use that for testing, taking the mic out of the equation? If so that's a good idea, and probs help stop this headache I'm getting form listening to 15khz > at 50db all day lol |
No, I2S between two ESP32 is not working properly |
Interesting, thanks for info. What Chip versions of ESP32 are you trying with ? |
The AudioKit has a ESP32-A1S which comes with an ES8388 audio chip |
Problem Description
Hey All,
Thanks for all your work on these tools, very awesome of you!
On both the 3.0a version and 2.0.11 of ESP32 Arduino. I'm getting very weird results.
For 2.0.11
To capture a up to 20khz frequency range I need to set the samples to 88400. Anything below that it starts turning higher frequencies into lower ones, like I was only capturing at 20khz (for 44100hz)
Even though playback is fine at the given sample rate. E.g. 44100, e.g. the file is the correct speed when played back as if it was a 44100 sample rate, it misses all the top ends.
But setting to 88400hz samples, I do get all required frequencies, but double the file size needed.
For 3.0a
All hell breaks loose!
It throws :
Guru Meditation Error: Core 1 panic'ed (Cache disabled but cached memory region accessed).
But even when I re-flash a sketch at lower hz, it still throws the error. But... leaving the ESP32 alone for 10 to 20 mins(?!), coming back to it, seems to resolve the problem, and the lower hz sketch starts working again.... I can't work it out, but I've replicated the issue 20 times now. Set to 80kz samples, and it's sort of half bricked until I leave it alone, so weird.
Even more weird, sometimes just letting it restart itself after a panic, maybe 20-30 times, it will start working by it's self and the sketch runs.
Note: in all occasions I am using wifi at the same time. But I have had the Guru Mediation Error, even with wifi disabled on 3.0 with the samples set above 80,000, but it's less frequent.
Below is an image to highlight the issue.
Track1: Original source audio
Track2: 2.11 Audio using I2S : sample rate 88400 -> imported sample rate 88400hz
Track3: 3.0a Audio using continuous ADC : sample rate 70000 -> imported sample rate 57500hz
As you can see in track 3, it's picking up the high end frequency, but with strange amount of of banding(?) in there.
The issues are consistent across multiple chips I've tried, including one esp32 doit dev kit one. Although they are all older chips ESP32-D0WDQ6 rev1 chips.
Device Description
ESP32 wroom, on custom board.
Chip is ESP32-D0WDQ6 (revision v1.0)
Features: WiFi, BT, Dual Core, 240MHz, VRef calibration in efuse, Coding Scheme None
Sketch
Other Steps to Reproduce
No response
What is your development environment
Arduino IDE.
I have checked existing issues, discussions and online documentation
The text was updated successfully, but these errors were encountered: