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

📄 vcl_complex.h

📁 DTMK软件开发包,此为开源软件,是一款很好的医学图像开发资源.
💻 H
字号:
#ifndef vcl_stlport_complex_h_
#define vcl_stlport_complex_h_

#if VCL_VC60
#include <stl/_config.h> // stlport include: gives correct redefinition for std
#include <complex>

#define vcl_generic_complex_STD std
#include "generic/vcl_complex.h"

// the following functions are declared in both <cmath> and <complex>
#undef  vcl_abs
#define vcl_abs vcl_abs
template <typename T> inline T              vcl_abs(vcl_complex<T> z) { return std::abs(z); }

#undef  vcl_sqrt
#define vcl_sqrt vcl_sqrt
template <typename T> inline vcl_complex<T> vcl_sqrt(vcl_complex<T> z) { return std::sqrt(z); }

#undef  vcl_exp
#define vcl_exp vcl_exp
template <typename T> inline vcl_complex<T> vcl_exp(vcl_complex<T> z) { return std::exp(z); }

#undef  vcl_log
#define vcl_log vcl_log
template <typename T> inline vcl_complex<T> vcl_log(vcl_complex<T> z) { return std::log(z); }

#undef  vcl_log10
#define vcl_log10 vcl_log10
template <typename T> inline vcl_complex<T> vcl_log10(vcl_complex<T> z) { return std::log10(z); }

#undef  vcl_pow
#define vcl_pow vcl_pow
// this looks wrong... template <typename T> inline vcl_complex<T> vcl_pow(vcl_complex<T> z) { return std::pow(z); }

template<typename T> inline vcl_complex<T> vcl_pow(const vcl_complex<T>& x, int y) { return std::pow(x,y); }

template<typename T> inline vcl_complex<T> vcl_pow(const vcl_complex<T>& x, const T& y){ return std::pow(x,y); }
template<typename T> inline vcl_complex<T> vcl_pow(const vcl_complex<T>& x, const vcl_complex<T>& y){ return std::pow(x,y); }
template<typename T> inline vcl_complex<T> vcl_pow(const T& x, const vcl_complex<T>& y){ return std::pow(x,y); }


#undef  vcl_cos
#define vcl_cos vcl_cos
template <typename T> inline vcl_complex<T> vcl_cos(vcl_complex<T> z) { return std::cos(z); }

#undef  vcl_cosh
#define vcl_cosh vcl_cosh
template <typename T> inline vcl_complex<T> vcl_cosh(vcl_complex<T> z) { return std::cosh(z); }

#undef  vcl_sin
#define vcl_sin vcl_sin
template <typename T> inline vcl_complex<T> vcl_sin(vcl_complex<T> z) { return std::sin(z); }

#undef  vcl_sinh
#define vcl_sinh vcl_sinh
template <typename T> inline vcl_complex<T> vcl_sinh(vcl_complex<T> z) { return std::sinh(z); }

#undef  vcl_tan
#define vcl_tan vcl_tan
template <typename T> inline vcl_complex<T> vcl_tan(vcl_complex<T> z) { return std::tan(z); }

#undef  vcl_tanh
#define vcl_tanh vcl_tanh
template <typename T> inline vcl_complex<T> vcl_tanh(vcl_complex<T> z) { return std::tanh(z); }



inline bool operator!=(const vcl_complex<double>& a, const vcl_complex<double>& b) {
  return !(a == b);
}
inline bool operator!=(const vcl_complex<float>& a, const vcl_complex<float>& b) {
  return !(a == b);
}
#else
#include "../iso/vcl_complex.h"
#endif

#endif // vcl_stlport_complex_h_

⌨️ 快捷键说明

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