当前位置: 首页>>代码示例>>C++>>正文


C++ FloatArray::getSize方法代码示例

本文整理汇总了C++中FloatArray::getSize方法的典型用法代码示例。如果您正苦于以下问题:C++ FloatArray::getSize方法的具体用法?C++ FloatArray::getSize怎么用?C++ FloatArray::getSize使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在FloatArray的用法示例。


在下文中一共展示了FloatArray::getSize方法的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: convolve

void FloatArray::convolve(FloatArray operand2, FloatArray destination, int offset, int samples){
  ASSERT(destination.size >= size + operand2.size -1, "Destination array too small"); //TODO: change this condition to the actual size being written(will be samples+ tail)
/// @note When built for ARM Cortex-M processor series, this method uses the optimized <a href="http://www.keil.com/pack/doc/CMSIS/General/html/index.html">CMSIS library</a>
#ifdef ARM_CORTEX
  //TODO: I suspect a bug in arm_conv_partial_f32
  //it seems that destination[n] is left unchanged for n<offset
  //and the result is actually stored from destination[offset] onwards
  //that is, in the same position where they would be if a full convolution was performed.
  //This requires (destination.size >= size + operand2.size -1). Ideally you would want destination to be smaller
  arm_conv_partial_f32(data, size, operand2.data, operand2.size, destination.getData(), offset, samples);
#else
  //this implementations reproduces the (buggy?) behaviour of arm_conv_partial (see comment above and inline comments below)
  /*
  This implementation is just a copy/paste/edit from the overloaded method
  */
  int size2=operand2.getSize();
  for (int n=offset; n<offset+samples; n++){
    int n1=n;
    destination[n] =0; //this should be [n-offset]
    for(int k=0; k<size2; k++){
      if(n1>=0 && n1<size)
        destination[n]+=data[n1]*operand2[k];//this should be destination[n-offset]
      n1--;
    }
  }
#endif /* ARM_CORTEX */
}
开发者ID:olilarkin,项目名称:OwlProgram,代码行数:27,代码来源:FloatArray.cpp

示例2: trigger

  void trigger(FloatArray samples){
    for(int i=0; i<samples.getSize(); ++i)
      if(volts.sampleToVolts(samples[i]) > threshold && !state){
	state = true;
	env->trigger(i);
      }else{
	state = false;
      }
  }
开发者ID:marsus,项目名称:MyPatches,代码行数:9,代码来源:DualDrumPatch.hpp

示例3: setMagnitude

void ComplexFloatArray::setMagnitude(FloatArray magnitude, int offset, int count, ComplexFloatArray destination){
  ASSERT(getSize()==magnitude.getSize(),"wrong size0");
  ASSERT(getSize()==destination.getSize(),"wrong size1");
  ASSERT(offset+count<=destination.getSize(), "Wrong size2");
  ASSERT(offset+count<=getSize(), "Wrong size3");
  for(int n=offset; n<count+offset; n++){
    destination.getData()[n].setPolar(magnitude[n], getData()[n].getPhase());
  }
}
开发者ID:smrq,项目名称:OwlProgram,代码行数:9,代码来源:ComplexFloatArray.cpp

示例4: rectify

void FloatArray::rectify(FloatArray& destination){ //this is actually "copy data with rectifify"
/// @note When built for ARM Cortex-M processor series, this method uses the optimized <a href="http://www.keil.com/pack/doc/CMSIS/General/html/index.html">CMSIS library</a>
#ifdef ARM_CORTEX   
  arm_abs_f32(data, destination.getData(), size);
#else
  int minSize= min(size,destination.getSize()); //TODO: shall we take this out and allow it to segfault?
  for(int n=0; n<minSize; n++){
    destination[n] = fabs(data[n]);
  }
#endif  
}
开发者ID:olilarkin,项目名称:OwlProgram,代码行数:11,代码来源:FloatArray.cpp

示例5: getSamples

  void getSamples(FloatArray samples){
    for(int i=0; i<samples.getSize(); ++i){
      if(volts.sampleToVolts(samples[i]) > threshold){
	if(!state){
	  state = true;
	  drum->trigger();
	}
      }else{
	state = false;
      }
      samples[i] = drum->getNextSample();
    }
  }
开发者ID:marsus,项目名称:MyPatches,代码行数:13,代码来源:DualDrumPatch.hpp

示例6: complexByRealMultiplication

void ComplexFloatArray::complexByRealMultiplication(FloatArray& operand2, ComplexFloatArray& result){
  int minSize= min(size,operand2.getSize()); //TODO: shall we take this out and allow it to segfault?
#ifdef ARM_CORTEX
  arm_cmplx_mult_real_f32 ( (float*)data, (float*)operand2, (float*)result, minSize );  
#else
  float *pSrcCmplx=(float*)data;
  float *pSrcReal=(float*)operand2;
  float *pCmplxDst=(float*)result;
  for(int n=0; n<size; n++) {        
      pCmplxDst[(2*n)+0] = pSrcCmplx[(2*n)+0] * pSrcReal[n];        
      pCmplxDst[(2*n)+1] = pSrcCmplx[(2*n)+1] * pSrcReal[n];        
  }        
#endif
}
开发者ID:smrq,项目名称:OwlProgram,代码行数:14,代码来源:ComplexFloatArray.cpp

示例7: gate

  void gate(FloatArray samples){
    for(int i=0; i<samples.getSize(); ++i){
      if(volts.sampleToVolts(samples[i]) > threshold){
	if(!state){
	  env->gate(true, i);
	  state = true;
	}
      }else{
	if(state){
	  env->gate(false, i);
	  state = false;
	}
      }
    }
  }
开发者ID:marsus,项目名称:MyPatches,代码行数:15,代码来源:DualDrumPatch.hpp

示例8: copyFrom

void FloatArray::copyFrom(FloatArray source){
/// @note When built for ARM Cortex-M processor series, this method uses the optimized <a href="http://www.keil.com/pack/doc/CMSIS/General/html/index.html">CMSIS library</a>
  copyFrom(source, min(size, source.getSize()));
}
开发者ID:olilarkin,项目名称:OwlProgram,代码行数:4,代码来源:FloatArray.cpp

示例9: copyTo

/* Copies real part to a FloatArray */
void ComplexFloatArray::copyTo(FloatArray destination){
  for(int n=0; n<min(size,destination.getSize()); n++){
    destination[n]=data[n].re;
  }
}
开发者ID:smrq,项目名称:OwlProgram,代码行数:6,代码来源:ComplexFloatArray.cpp

示例10: copyFrom

/* Copies real values from a FloatArray, sets imaginary values to 0
 */
void ComplexFloatArray::copyFrom(FloatArray source){
  for(int n=0; n<min(size,source.getSize()); n++){
    data[n].re=source[n];
    data[n].im=0;
  }
}
开发者ID:smrq,项目名称:OwlProgram,代码行数:8,代码来源:ComplexFloatArray.cpp


注:本文中的FloatArray::getSize方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。