资源简介
代码验证请看我的博客: http://blog.csdn.net/zone53/article/details/78280901
代码片段和文件信息
//不会用的请参考我的博客:
#include “stdafx.h“
#include
#include
#include
//必需包含下面两个头文件
#include “complex.h“
#include
double pi = 3.1415926535897932384626433832795;
/*************************************************************************
* @brief : Butterworth filter prototype matlab函数
* @inparam : n 阶数
*
* @outparam: p 复矩阵
* k
* @author : zone53
* @date : 2017/10/18 15:40
* @version : ver 1.0
*************************************************************************/
static void mybuttap(int n _C_double_complex* p double *k)
{
int i = 0 j = 0;
int size = (n - 1) / 2;
int isodd = n % 2;
_C_double_complex temp;
for (i = 1 j = 0; i < n; j++)
{
temp._Val[0] = 0;
temp._Val[1] = pi * i / (2 * n) + pi / 2;
p[j * 2] = cexp(temp);
i += 2;
}
for (int m = 1 i = 0; i < j; i++)
{
p[m] = conj(p[m - 1]);
m += 2;
}
if (isodd)
{
p[size * 2]._Val[0] = -1.0;
p[size * 2]._Val[1] = 0.0;
}
_C_double_complex a = _Cmulcc(_Cmulcr(p[0] -1) _Cmulcr(p[1] -1));
for (int m = 2; m < size * 2 + isodd; m++)
{
a = _Cmulcc(a _Cmulcr(p[m] -1));
}
*k = creal(a);
}
/*************************************************************************
* @brief : Characteristic polynomial or polynomial with specified roots matlab函数
* @inparam : p 复矩阵
* np 复矩阵的大小
* @outparam: d 返回复矩阵
* @author : zone53
* @date : 2017/10/18 15:40
* @version : ver 1.0
*************************************************************************/
static void mypoly(_C_double_complex* p int np _C_double_complex *d)
{
_C_double_complex *c = (_C_double_complex *)malloc((np + 1) * sizeof(_C_double_complex));
c[0]._Val[0] = 1.0;
c[0]._Val[1] = 0.0;
d[0]._Val[0] = 1.0;
d[0]._Val[1] = 0.0;
for (int i = 1; i {
c[i]._Val[0] = 0.0;
c[i]._Val[1] = 0.0;
d[i]._Val[0] = 0.0;
d[i]._Val[1] = 0.0;
}
_C_double_complex temp;
for (int i = 0; i < np; i++)
{
for (int j = 1; j <= i + 1; j++)
{
temp = _Cmulcc(p[i] d[j - 1]);
c[j]._Val[0] = d[j]._Val[0] - temp._Val[0];
c[j]._Val[1] = d[j]._Val[1] - temp._Val[1];
}
for (int j = 1; j <= i + 1; j++)
{
d[j]._Val[0] = c[j]._Val[0];
d[j]._Val[1] = c[j]._Val[1];
}
}
free(c);
}
/*************************************************************************
* @brief : 实数矩阵相乘
* @inparam : a 矩阵A
* b 矩阵B
* m 矩阵A与乘积矩阵C的行数
* n 矩阵A的行数矩阵B的列数
* k 矩阵B与乘积矩阵C的列数
* @outparam: c 乘积矩阵 C=AB
* @author : zone53
* @date : 2017/10/18 15:40
* @version : ver 1.0
*************************************************************************/
static void mytrmul(double a[] double b[] int m int n int k double c[])
{
int i j l u;
for (i = 0; i <= m - 1; i++)
for (j = 0; j <= k - 1; j++)
{
u = i*k + j; c[u] = 0.0;
for (l = 0; l <= n - 1; l++)
c[u] = c[u] + a[i*
相关资源
- C语言编写modbus
- 字符串匹配算法详解 BM算法 c语言
- C语言和汇编语言的混合编程
- HMC830_HMC_MODE.rar
- c语言实现的发送邮件
- AES单片机加密解密 C语言源代码
- RC4加解密 C语言实现
- 原创:51单片机操作ds18b20ds1302,lcd1
- 清华 严蔚敏 《数据结构》代码全部实
- 矩阵满秩分解的C语言代码
- C++二级考试试题含答案和解析
- c语言关键字汇总
- C语言实现ARP攻击
- 声纹识别MATLAB源程序全代码
- 语种识别MATLAB程序
- 用C语言写的坡度算法
- c语言实现找零钱问题
- C语言课程设计-汉诺塔的演示
- C语言C++通用自定义log打印函数
- 基于c语言的图书管理系统毕业论文
- c语言 图书管理系统87261
- C语言实现心跳包Heart Beat
- Modbus源码(PIC单片机版)
- 表达式求值C语言实现
- PID算法Matlab仿真程序和C程序
- 井字棋用C语言写的源代码
- C语言画图程序代码
- 矩阵运算C语言实现
- Yuneec ST24解码器C语言源码
- 最新快速傅里叶计算,C语言的FFT程序
评论
共有 条评论