资源简介
代码验证请看我的博客: 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语言模拟文件管理系统844
- C语言开发实战宝典
- C++中头文件与源文件的作用详解
- C语言代码高亮html输出工具
- 猜数字游戏 c语言代码
- C语言课程设计
- 数字电位器C语言程序
- CCS FFT c语言算法
- 使用C语言编写的病房管理系统
- 通信过程中的RS编译码程序(c语言)
- 计算机二级C语言上机填空,改错,编
- 用回溯法解决八皇后问题C语言实现
- 简易教务管理系统c语言开发文档
- 操作系统课设 读写者问题 c语言实现
- 小波变换算法 c语言版
- C流程图生成器,用C语言代码 生成C语
- 3des加密算法C语言实现
- 简单的C语言点对点聊天程序
- 单片机c语言源程序(51定时器 八个按
- 个人日常财务管理系统(C语言)
- c语言电子商务系统
- 小甲鱼C语言课件 源代码
- 将图片转换为C语言数组的程序
- C语言实现的一个内存泄漏检测程序
- DES加密算法C语言实现
- LINUX下命令行界面的C语言细胞游戏
- 用单片机控制蜂鸣器播放旋律程序(
- 学校超市选址问题(数据结构C语言版
- 电子时钟 有C语言程序,PROTEUS仿真图
- 尚观培训linux许巍老师关于c语言的课
评论
共有 条评论