- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 PortAudio 开发声音应用程序。我有一个结构数组,表示传递到主回调函数的各个振荡器的数据。
当我尝试在一条线上将两个波相加并播放时,它起作用了,但是当我尝试使用 for 循环来做到这一点时,我可以任意对振荡器求和,但它不起作用。
所以这是可行的:
*out = sinetable[(int)oscs[0].phase % TABLE_SIZE] * (oscs[0].amp/2) + sinetable[(int)oscs[1].phase % TABLE_SIZE] * (oscs[1].amp/2);
但这不是:
for(int j = 0; j < 2; j++ )
{
*out += sinetable[(int)oscs[j].phase % TABLE_SIZE] * (oscs[j].amp / 2);
}
我只需要一种方法来对任意数量的振荡器求和。我认为这两种方法等效,但显然它们不是。
非常感谢任何帮助。
编辑:完整代码在这里:
#include <stdio.h>
#include <math.h>
#include "portaudio.h"
#define NUM_SECONDS (2)
#define SAMPLE_RATE (44100)
#define FRAMES_PER_BUFFER (0) // PA will select in it's own..
#ifndef M_PI
#define M_PI (3.14159265)
#endif
#define TABLE_SIZE (4096) // < Hz / (sampling rate / table size ) [line 53]]
float sinetable[TABLE_SIZE];
typedef struct
{
float phase = 0;
float freq = 300;
float amp = 0.5;
}
Osc;
void initTable(){
for(int i = 0; i < TABLE_SIZE; i++){
sinetable[i] = sin(2 * M_PI * i/TABLE_SIZE);
}
}
/* This routine will be called by the PortAudio engine when audio is needed.
** It may called at interrupt level on some machines so don't do anything
** that could mess up the system like calling malloc() or free().
*/
static int patestCallback( const void *inputBuffer, void *outputBuffer,
unsigned long framesPerBuffer,
const PaStreamCallbackTimeInfo* timeInfo,
PaStreamCallbackFlags statusFlags,
void *userData )
{
Osc *oscs = (Osc*)userData;
float *out = (float*)outputBuffer;
unsigned long i;
(void) timeInfo; /* Prevent unused variable warnings. */
(void) statusFlags;
(void) inputBuffer;
for( i=0; i<framesPerBuffer; i++ )
{
/*
for(int j = 0; j < 2; j++ ){ //this won't work...
*out += sinetable[(int)oscs[j].phase % TABLE_SIZE] * (oscs[j].amp / 2);
}
*/
// but this does:
*out = sinetable[(int)oscs[0].phase % TABLE_SIZE] * (oscs[0].amp / 2) + sinetable[(int)oscs[1].phase % TABLE_SIZE] * ( oscs[1].amp / 2);
oscs[0].phase += oscs[0].freq / ( SAMPLE_RATE/(float)TABLE_SIZE );
oscs[1].phase += oscs[1].freq / ( SAMPLE_RATE/(float)TABLE_SIZE );
*out++;
}
return paContinue;
}
/*
* This routine is called by portaudio when playback is done.
*/
static void StreamFinished( void* userData )
{
Osc *oscs = (Osc *) userData;
// printf( "Stream Completed: %s\n", oscs->message );
}
/*******************************************************************/
int main(void);
int main(void)
{
PaStreamParameters outputParameters;
PaStream *stream;
PaError err;
Osc oscs[5];
int i;
oscs[1].freq = 400; oscs[2].freq = 500; oscs[3].freq = 600; oscs[4].freq = 700;
printf("PortAudio Test: output sine wave. SR = %d, BufSize = %d\n", SAMPLE_RATE, FRAMES_PER_BUFFER);
/* initialise sinusoidal wavetable */
for( i=0; i<TABLE_SIZE; i++ )
{
sinetable[i] = 2* M_PI * (i / TABLE_SIZE ); //using this global table
}
// oscs.phase = 0;
initTable();
err = Pa_Initialize();
if( err != paNoError ) goto error;
outputParameters.device = Pa_GetDefaultOutputDevice(); /* default output device */
if (outputParameters.device == paNoDevice) {
fprintf(stderr,"Error: No default output device.\n");
goto error;
}
outputParameters.channelCount = 1; /* mono output */
outputParameters.sampleFormat = paFloat32; /* 32 bit floating point output */
outputParameters.suggestedLatency = Pa_GetDeviceInfo( outputParameters.device )->defaultLowOutputLatency;
outputParameters.hostApiSpecificStreamInfo = NULL;
err = Pa_OpenStream(
&stream,
NULL, /* no input */
&outputParameters,
SAMPLE_RATE,
FRAMES_PER_BUFFER,
paClipOff, /* we won't output out of range samples so don't bother clipping them */
patestCallback,
&oscs );
if( err != paNoError ) goto error;
// sprintf( oscs.message, "No Message" );
err = Pa_SetStreamFinishedCallback( stream, &StreamFinished );
if( err != paNoError ) goto error;
err = Pa_StartStream( stream );
if( err != paNoError ) goto error;
printf("Play for %d seconds.\n", NUM_SECONDS );
Pa_Sleep( NUM_SECONDS * 1000 );
err = Pa_StopStream( stream );
if( err != paNoError ) goto error;
err = Pa_CloseStream( stream );
if( err != paNoError ) goto error;
Pa_Terminate();
printf("Test finished.\n");
return err;
error:
Pa_Terminate();
fprintf( stderr, "An error occured while using the portaudio stream\n" );
fprintf( stderr, "Error number: %d\n", err );
fprintf( stderr, "Error message: %s\n", Pa_GetErrorText( err ) );
return err;
}
最佳答案
我可以建议在求和之前将 *out
归零吗?
*out = 0;
for(int j = 0; j < 2; j++ )
{
*out += sinetable[(int)oscs[j].phase % TABLE_SIZE] * (oscs[j].amp / 2);
}
否则,由于 +=
,out
中的任何内容都会在总和中结束。
*out = sinetable[(int)oscs[0].phase % TABLE_SIZE] * (oscs[0].amp / 2) +
sinetable[(int)oscs[1].phase % TABLE_SIZE] * (oscs[1].amp / 2);
解决这个问题是因为 =
覆盖了 out
中的任何内容。
关于c++ - PortAudio 回调中的求和波,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37847854/
我在安装 PyAudio 和 portaudio 时遇到问题。 当我执行 python -m pip install pyaudio 时出现此错误: src/_portaudiomodule.
我有一个主要使用 PyAudio 的实验室项目,为了进一步了解其工作方式,我做了一些测量,在本例中是回调之间的时间(使用回调模式)。 我计时了,得到了一个有趣的结果 (@256 chunk size,
我目前正在使用 live555、mpg123 和 portaudio 构建一个 mp3 流媒体/接收器,并且刚刚开始流式传输、解码和播放 mp3 的概念。 我的问题是当我需要用 portaudio 播
我正在使用Portaudio以便将声音录制到.raw文件中,但是我想仅在有声音时才开始录制,而在无声时才停止录制。 有没有办法用Portaudio做到这一点? 如果没有,您是否知道我该怎么做? 提前致
我再次需要你的帮助。 短版: 您可以将声音片段导入 Portaudio 吗?如果没有,我在哪里可以获得“真实”的声音示例,这些示例被转换为可以存储到我的声音缓冲区中的离散值? 加长版: 作为一个小型项
我正在尝试学习 DSP 编程以尝试创建自己的吉他效果,并且我正在使用 Portaudio 库来实现它。我遇到的问题是,无论我做什么,每当我在回调中读取输入缓冲区时,它都是空的。我已经尝试了几个不同的
我大约一周前开始使用 PortAudio 库。我已经检查了大部分教程/测试示例,但没有看到我需要的解决方案。我正在制作简单的音序器 - 我已经在钢琴卷轴上绘制了作为 block 的声音,但现在我需要以
由于我是 PortAudio 的新手,所以我尝试了一个来自互联网的示例程序。该程序能够通过回调函数记录麦克风的输入。 我想获取录制音频的每个样本,以数值(例如 float )表示。我不知道麦克风的记录
我正在尝试在 portaudio 中创建多个流。这是打开流所需要的 PaError Pa_OpenDefaultStream( PaStream** stream,
我有类似钢琴的应用程序,当我按下钢琴键时,它会播放声音。在我的应用程序中,我编写了自己的正弦波发生器。应用程序是用 Qt 编写的。我认为问题出在 portAudio 上,但我找不到任何解决方案。 我已
我正在使用 PortAudio 开发声音应用程序。我有一个结构数组,表示传递到主回调函数的各个振荡器的数据。 当我尝试在一条线上将两个波相加并播放时,它起作用了,但是当我尝试使用 for 循环来做到这
我在使用此 cmake 列表时遇到的一个问题是我收到错误消息 error: undefined reference to 'Pa_GetVersion'对于这段代码: 记录.cpp: #include
我在使用 PortAudio 时遇到问题,我不确定是我不太了解回调的工作原理,还是我做错了什么。我的假设是回调应该连续“on tick”触发,包含当前样本,但似乎我在打开和启动流时只收到一些回调,然后
我正在使用 PortAudio,这就是我现在打开流进行阅读的方式。 Pa_OpenDefaultStream(&stream, 1, 0, paFloat32, SAMPLE_RATE, SAMPLE
我是 PortAudio 的新手。我的目的是不断从我的电脑上的线路输入中捕获数据并实时处理数据。 我使用的是 44100 的采样率和 11025 的缓冲区大小 (frameCount)。我能够成功地做
我目前正在使用带有录音应用程序的 portaudio,我似乎在收集样本时遇到了一些问题。据我所知,只有一个样本被存储,回调只被调用一次,仅此而已,即使变量 NUM_OF_SECONDS 设置为 30
我想制作一个吉他效果器程序,所以我尝试从 PORTAUDIO API 运行示例代码 pa_fuzz.c。 它适用于 paWDMKS 主机 api。但是当我使用 Behringer ucg 102(无延
我正在使用 PortAudio 来实现实时音频处理。 我的首要任务是连续采集mic数据,提供100个样本进行处理(each FRAME = 100 samples at a time)到其他一些处理线
我在编写 C++ 程序时遇到了这个问题,所以我创建了一个最小的代码实例来更好地阐明问题: #include #include int main() { Pa_Initialize();
我想知道,你们知道我可以使用的用于 portaudio 的 cmake 文件吗? 提前致谢! 最佳答案 这是一个: # - Try to find Portaudio # Once done this
我是一名优秀的程序员,十分优秀!