Чтение децибел микрофона и высоты тона / частоты - PullRequest
0 голосов
/ 28 октября 2018

Я пытаюсь создать игру, в которой мой персонаж стреляет, когда слышен достаточно громкий звук с микрофона (в Unity ).Однако я не знаю, с чего начать.

Спасибо за вашу помощь!

1 Ответ

0 голосов
/ 28 октября 2018

Вы можете получить децибелы с микрофона, получив блок выходных данных микрофона, воспроизводимого в данный момент, с помощью функции AudioSource.GetOutputData.Чтобы получить дБ из этих данных, вам необходимо сложить выборки данных, а затем вычислить среднеквадратичное значение.Это среднеквадратическое значение, которое вы можете использовать для расчета дБ с помощью 20 * Mathf.Log10 (RMS / refVal).

. Полный пример можно найти в сообщении Unity .Вы можете прочитать это для получения дополнительной информации, и код ниже основан на этом:

public float rmsVal;
public float dbVal;
public float pitchVal;

private const int QSamples = 1024;
private const float RefValue = 0.1f;
private const float Threshold = 0.02f;

float[] _samples;
private float[] _spectrum;
private float _fSample;

void Start()
{
    _samples = new float[QSamples];
    _spectrum = new float[QSamples];
    _fSample = AudioSettings.outputSampleRate;
}

void Update()
{
    AnalyzeSound();

    Debug.Log("RMS: " + rmsVal.ToString("F2"));
    Debug.Log(dbVal.ToString("F1") + " dB");
    Debug.Log(pitchVal.ToString("F0") + " Hz");
}

void AnalyzeSound()
{
    GetComponent<AudioSource>().GetOutputData(_samples, 0); // fill array with samples
    int i;
    float sum = 0;
    for (i = 0; i < QSamples; i++)
    {
        sum += _samples[i] * _samples[i]; // sum squared samples
    }
    rmsVal = Mathf.Sqrt(sum / QSamples); // rms = square root of average
    dbVal = 20 * Mathf.Log10(rmsVal / RefValue); // calculate dB
    if (dbVal < -160) dbVal = -160; // clamp it to -160dB min
                                    // get sound spectrum
    GetComponent<AudioSource>().GetSpectrumData(_spectrum, 0, FFTWindow.BlackmanHarris);
    float maxV = 0;
    var maxN = 0;
    for (i = 0; i < QSamples; i++)
    { // find max 
        if (!(_spectrum[i] > maxV) || !(_spectrum[i] > Threshold))
            continue;

        maxV = _spectrum[i];
        maxN = i; // maxN is the index of max
    }
    float freqN = maxN; // pass the index to a float variable
    if (maxN > 0 && maxN < QSamples - 1)
    { // interpolate index using neighbours
        var dL = _spectrum[maxN - 1] / _spectrum[maxN];
        var dR = _spectrum[maxN + 1] / _spectrum[maxN];
        freqN += 0.5f * (dR * dR - dL * dL);
    }
    pitchVal = freqN * (_fSample / 2) / QSamples; // convert index to frequency
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...