⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 amf_mixernxmsmoothed_ds.c

📁 ADI SHARC DSP 音频算法标准模块库
💻 C
字号:
// Copyright(c) 2005 Analog Devices, Inc. All Rights Reserved.
// This software is proprietary and confidential to Analog Devices, Inc. and its licensors.

// File    : $Id: //depot/development/visualaudio/modules/2.5.0/SHARC/Source/AMF_MixerNxMSmoothed_DS.c#3 $ 
// Part of : VisualAudio V2.5.0 
// Updated : $Date: 2006/10/12 $ by $Author: Fernando $



#include "AMF_MixerNxMSmoothed_DS.h"

void AMF_MixerNxMSmoothed_DS_Render(AMF_MixerNxMSmoothed_DS * restrict instance,float * restrict * buffers, int tickSize);


// NOTE: The C version of this function is for reference only (it is
//       intended just to show the general algorithm that the module
//       uses), and it may not have been fully tested
#if 0    // Example C code

#define EPSILON .0001

#pragma optimize_for_speed
SEG_MOD_FAST_CODE  void AMF_MixerNxMSmoothed_DS_Render(AMF_MixerNxMSmoothed_DS * restrict instance,float * restrict * buffers,int tickSize) {
    int i;
    int inputCount = instance->b.numInputs;
    int outputCount = instance->b.numOutputs;
    int outNum,inNum;
    float * restrict in;
    float * restrict out;
    float pm *ampsTargets = &instance->ampsTarget[0];
    float pm *ampss = &instance->amps[0];             
    float ampsSmoothing = instance->ampsSmoothing;
    float oneMinusRate = 1.0 - ampsSmoothing;
    float amps,ampsTarget;
    int outWritten;                 // Boolean
    
    for (outNum=0; outNum<outputCount; outNum++) {
        out = buffers[inputCount + outNum];
        outWritten = 0;
        for (inNum=0; inNum<inputCount; inNum++) {
            ampsTarget0 = ampsTargets[2*(inNum*outputCount+outNum)];
            ampsTarget1 = ampsTargets[2*(inNum*outputCount+outNum)];
            amps0 = ampss[2*(inNum*outputCount+outNum)];
            amps1 = ampss[2*(inNum*outputCount+outNum)+1];
            if (amps > EPSILON || ampsTarget > EPSILON) {
                in = buffers[inNum];
                if (!outWritten) {
                    outWritten = 1;
                    for (i=0; i<tickSize*2; i+=2) {
                        amps0 = amps0 * oneMinusRate + ampsTarget0 * ampsSmoothing;
                        amps1 = amps1 * oneMinusRate + ampsTarget1 * ampsSmoothing;
                         out[i]   = in[i]   * amps0;
                         out[i+1] = in[i+1] * amps1;
                    }
                } else 
                    for (i=0; i<tickSize*2; i+=2) {
                        amps0 = amps0 * oneMinusRate + ampsTarget0 * ampsSmoothing;
                        amps1 = amps1 * oneMinusRate + ampsTarget1 * ampsSmoothing;
                         out[i]   += in[i]   * amps0;
                         out[i+1] += in[i+1] * amps1;
                    }
            }
            ampss[2*(inNum*outputCount+outNum)]   = amps0;
            ampss[2*(inNum*outputCount+outNum)+1] = amps1;
        }
        if (!outWritten)
            for (i=0; i<tickSize*2; i++)
                 // Should be able to use SIMD here                       
                out[i] = 0.0;
    }
}
#endif

SEG_MOD_SLOW_CONST const AMF_ModuleVariableClass AMFClassMixerNxMSmoothed_DS = {
    
    /* Flags */
    AMFModuleClassFlag_VARIABLE_PIN_COUNT,
     
    /* Render function */
    (AMF_RenderFunction)AMF_MixerNxMSmoothed_DS_Render, 
    
    /* Default bypass */
    (void *)0
};






⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -