Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Media";
Текущий архив: 2004.12.26;
Скачать: [xml.tar.bz2];

Вниз

Как определить частоту?   Найти похожие ветки 

 
Mitay   (2004-09-26 09:06) [0]

Народ помогите. Как мне определить частоту звука подоваемого на микрофон?


 
programania ©   (2004-09-26 20:29) [1]

Получить звук с микрофона в массив можно BASS.dll
массив амплитуд преобразовать в массив частот
быстрым преобразованием фурье: alglib.manual.org или ru
найти максимум и опытным путем перевести в значение частоты.
или перемножить элементы массива амплитуд с SIN
разных частот и сложить
где максимум это и есть основная частота
а звука одной частоты в природе не бывает
всегда есть искажения отражения и т.д.


 
newbie   (2004-09-29 15:02) [2]

1)Где найти bass.dll и доки по нему?
2)Есть ли другой способ?


 
programania ©   (2004-09-29 21:04) [3]

1) в Internete
2) есть примерно такой:

procedure TForm1.Button1Click(Sender: TObject);
var
header: TWaveFormatEx;
BufLen: word;
buf: pointer;
begin
//начало
BufSize := TrackBar1.Position * 500 + 100; Bits16 := CheckBox1.Checked;
with header do begin
  wFormatTag := WAVE_FORMAT_PCM;
  nChannels := 1;  
  nSamplesPerSec := 22050;
  wBitsPerSample := integer(Bits16) * 8 + 8; { 8 / 16 }
  nBlockAlign := nChannels * (wBitsPerSample div 8);
  nAvgBytesPerSec := nSamplesPerSec * nBlockAlign;
  cbSize := 0;
end;
WaveInOpen(Addr(WaveIn), WAVE_MAPPER, addr(header),
  Form1.Handle, 0, CALLBACK_WINDOW);
BufLen := header.nBlockAlign * BufSize;
hBuf := GlobalAlloc(GMEM_MOVEABLE and GMEM_SHARE, BufLen);
Buf := GlobalLock(hBuf);
with BufHead do begin
  lpData := Buf;
  dwBufferLength := BufLen;
  dwFlags := WHDR_BEGINLOOP;
end;
WaveInPrepareHeader(WaveIn, Addr(BufHead), sizeof(BufHead));
WaveInAddBuffer(WaveIn, addr(BufHead), sizeof(BufHead));
GetMem(p, BufSize * sizeof(TPoint));
stop := true;
WaveInStart(WaveIn);
end;
Procedure konec;
begin
WaveInReset(WaveIn);
WaveInUnPrepareHeader(WaveIn, addr(BufHead), sizeof(BufHead));
WaveInClose(WaveIn);
GlobalUnlock(hBuf);
GlobalFree(hBuf);
FreeMem(p, BufSize * sizeof(TPoint));
end;
procedure TForm1.OnWaveIn;
var
i: integer;
data8: PData8;
data16: PData16;
h: integer;
XScale, YScale: single;
begin
//обработка
h := PaintBox1.Height;
XScale := PaintBox1.Width / BufSize;
if Bits16 then begin
  data16 := PData16(PWaveHdr(Msg.lParam)^.lpData);
  YScale := h / (1 shl 16);
  for i := 0 to BufSize - 1 do
    p^[i] := Point(round(i * XScale),
      round(h / 2 - data16^[i] * YScale));
end else begin
  Data8 := PData8(PWaveHdr(Msg.lParam)^.lpData);
  YScale := h / (1 shl 8);
  for i := 0 to BufSize - 1 do
    p^[i] := Point(round(i * XScale),
      round(h - data8^[i] * YScale));
end;
end;



Страницы: 1 вся ветка

Форум: "Media";
Текущий архив: 2004.12.26;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.036 c
3-1101627994
MaxxSoft
2004-11-28 10:46
2004.12.26
Создание / изменение процедур


3-1101298230
keymaster
2004-11-24 15:10
2004.12.26
Client-Servet виснет


6-1097481189
Stef
2004-10-11 11:53
2004.12.26
Определение сетевых групп


1-1102498183
Dolphin001
2004-12-08 12:29
2004.12.26
WebBrowser charset


3-1101163399
GanibalLector
2004-11-23 01:43
2004.12.26
Запрос





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский