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

📄 bes_02.cc

📁 这是一个从音频信号里提取特征参量的程序
💻 CC
字号:
// file: $isip/class/numeric/Bessel/bes_02.cc// version: $Id: bes_02.cc,v 1.3 2001/07/04 23:24:46 picone Exp $//// isip include files//#include <Console.h>#include "Bessel.h"// method: diagnose//// arguments://  Integral::DEBUG level: (input) debug level for diagnostics//// return: a boolean value indicating status//boolean Bessel::diagnose(Integral::DEBUG level_a) {    //---------------------------------------------------------------------  //  // 0. preliminaries  //  //---------------------------------------------------------------------  // output the class name  //  if (level_a > Integral::NONE) {    String output(L"diagnosing class ");    output.concat(CLASS_NAME);    output.concat(L": ");    Console::put(output);    Console::increaseIndention();  }   //--------------------------------------------------------------------  //  // 1. required public methods  //  //--------------------------------------------------------------------  // set indentation  //  if (level_a > Integral::NONE) {    Console::put(L"testing required public methods...\n");    Console::increaseIndention();  }  // test destructor/constructor(s) and memory management  //  Bessel bessel_fw;    Bessel::setGrowSize((long)500);  for (long j = 1; j <= 100; j++) {    Bessel** ml = new Bessel*[j * 100];        // create the objects    //    for (long i = 0; i < j * 100; i++) {      ml[i] = new Bessel();    }        // delete objects    //    for (long i = (j * 100) - 1; i >= 0; i--) {      delete ml[i];    }        delete [] ml;  }    // reset indentation  //  if (level_a > Integral::NONE) {    Console::decreaseIndention();  }    //--------------------------------------------------------------------------  //  // 2. class-specific public methods:  //     computational methods  //  //--------------------------------------------------------------------------  // set indentation  //  if (level_a > Integral::NONE) {    Console::put(L"testing class-specific public methods: computational methods...\n");    Console::increaseIndention();  }  // check the compute methods using the vector method (which in turn checks  // the scalar methods)  //  VectorFloat inp(L"1.0, 0.5, -0.5");  VectorFloat ans(L"1.26562, 1.063483, 1.063483");  VectorFloat out;    Bessel::compute(out, inp, 0, 2);  if (!ans.almostEqual(out)) {    ans.debug(L"expected result:");    out.debug(L"wrong result:");    return Error::handle(name(), L"compute", Error::TEST, __FILE__, __LINE__);  }  // reset indentation  //  if (level_a > Integral::NONE) {    Console::decreaseIndention();  }    //--------------------------------------------------------------------  //  // 4. print completion message  //  //--------------------------------------------------------------------  // reset indentation  //  if (level_a > Integral::NONE) {    Console::decreaseIndention();  }    if (level_a > Integral::NONE) {    String output(L"diagnostics passed for class ");    output.concat(name());    output.concat(L"\n");    Console::put(output);  }    // exit gracefully  //  return true;}

⌨️ 快捷键说明

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