sinc.cpp

来自「《无线通信系统仿真——c++使用模型》这本书的源代码」· C++ 代码 · 共 54 行

CPP
54
字号
//
//  File = sinc.cpp
//

#include <stdlib.h>
#include <math.h>
#include "sinc.h"
#include <iostream>
#ifndef PI
  #define PI 3.1415926535897932
#endif
using namespace std;
double sinc(double x)
{
  double val;
   if (x == 0.0)
   { 
      return( 1.0 ); 
   }
   else if(ceil(x) == floor(x))
   {
      return(0.0);
   }
   else
   { 
   val = sin(PI*x)/(PI*x);
   //val = sin(x)/x;
   if(val > 2.0)
    {
    cout << "val = " << val << endl;
    exit(-1);
    }
   return(val);
   }  
}
double sinc_sqrd(double x)
{
  double val;
 if (x == 0.0)
   { return( 1.0 ); }
 else
   { 
   val = sin(PI*x)/(PI*x);
   if(val > 2.0)
    {
    cout << "val = " << val << endl;
    exit(-1);
    }
   return(val*val);
   }  
}

//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 

⌨️ 快捷键说明

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