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

📄 mcscl_03.cc

📁 这是一个从音频信号里提取特征参量的程序
💻 CC
字号:
// file: $isip/class/math/scalar/MComplexScalar/mcscl_03.cc// version: $Id: mcscl_03.cc,v 1.4 2001/10/14 04:25:58 bahety Exp $//// isip include files//#include "MComplexScalarMethods.h"#include "MComplexScalar.h"#include <typeinfo>// method: read//// arguments://  MComplexScalar<TIntegral, TSize>& this: (output) class operand//  Sof& sof: (input) sof file object//  long tag: (input) sof object instance tag//  const String& name: (input) sof object instance name//// return: a boolean indicating status//// this method has the object read itself from an Sof file//template<class TIntegral, class TSize>boolean MComplexScalarMethods::read(MComplexScalar<TIntegral, TSize>& this_a,			     Sof& sof_a, long tag_a, const String& name_a) {  // get the instance of the object from the Sof file  //  if (!sof_a.find(name_a, tag_a)) {    return false;  }  // read the actual data from the sof file  //  if (!this_a.readData(sof_a)) {    return false;  }  // exit gracefully  //  return true;}// method: readData//// arguments://  MComplexScalar<TIntegral, TSize>& this: (output) class operand//  Sof& sof: (input) sof file object//  const String& pname: (input) sof object instance name//  long size: (input) size in bytes of object (or FULL_SIZE)//  boolean param: (input) is the parameter specified?//  boolean nested: (input) is this nested?//// return: a boolean indicating status//// this method has the object read itself from an Sof file. it assumes// that the Sof file is already positioned correctly.//template<class TIntegral, class TSize>boolean MComplexScalarMethods::readData(MComplexScalar<TIntegral, TSize>& this_a,				 Sof& sof_a, const String& pname_a,				 long size_a, boolean param_a,				 boolean nested_a) {  // if ascii, read in a line, else binary read  //  if (sof_a.isText()) {        SofParser parser;    String buffer;    String pname;    Integral::DEBUG debug_level = Integral::NONE;        // set the parser debug level    //    parser.setDebug(debug_level);        // if param is false, this means implicit parameter    //    if (!param_a) {      if (!parser.setImplicitParam()) {	return Error::handle(name(), L"readData", Error::READ,			     __FILE__, __LINE__, Error::WARNING);      }      if (!pname.assign(parser.implicitPname())) {	return Error::handle(name(), L"readData", Error::READ,			     __FILE__, __LINE__, Error::WARNING);      }    }    else {      pname.assign(pname_a);    }        // are we nested?    //    if (nested_a) {      parser.setNest();    }        // size = -1 means this is the root object, load the parse    //    if (size_a < 0) {      if (!parser.load(sof_a, size_a)) {	return Error::handle(name(), L"readData", Error::READ,			     __FILE__, __LINE__, Error::WARNING);      }      // if param is false, this means implicit parameter      //      if (!param_a) {        if (!parser.setImplicitParam()) {	  return Error::handle(name(), L"readData", Error::READ,			     __FILE__, __LINE__, Error::WARNING);	}      }      // read the data from the default parameter      //      if (!parser.read(buffer, sof_a, parser.getEntry(sof_a, pname))) {        return Error::handle(name(), L"readData", Error::READ,			     __FILE__, __LINE__, Error::WARNING);      }          }    else {      // we are already positioned correctly, just read      //      if (!parser.read(buffer, sof_a, size_a)) {        return Error::handle(name(), L"readData", Error::READ,			     __FILE__, __LINE__, Error::WARNING);      }          }    // assign the value    //    buffer.trim();    this_a.assign(buffer);  }  // binary read, very simple  //  else {    // make sure we read data properly    //    TSize val;    if (sof_a.read(&val, sizeof(val), 1) != 1) {      return Error::handle(name(), L"readData", Error::READ,			     __FILE__, __LINE__, Error::WARNING);    }    // for complex we need to also read the imaginary component    //    TSize imag;    if (sof_a.read(&imag, sizeof(imag), 1) != 1) {      return Error::handle(name(), L"readData", Error::READ,			   __FILE__, __LINE__, Error::WARNING);    }        this_a.value_d = SysComplex<TIntegral>(val, imag);  }    // exit gracefully  //  return true;}// declare classes that need to inherit MComplexScalar//template booleanMComplexScalarMethods::read<ISIP_TEMPLATE_TARGET> (MComplexScalar<ISIP_TEMPLATE_TARGET>&, Sof&, long, const String&);template booleanMComplexScalarMethods::readData<ISIP_TEMPLATE_TARGET> (MComplexScalar<ISIP_TEMPLATE_TARGET>&, Sof&, const String&, long, boolean, boolean);

⌨️ 快捷键说明

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