许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  MATLAB与Python程序互转:实例解析(二)

MATLAB与Python程序互转:实例解析(二)

阅读数 1201
点赞 26
article_banner

结果展示

结果图

信号滤波处理对比

代码对比

上图中左边是matlab代码,右侧是python代码,同一个框内的实现的作用是一样的可以对比来看,在写法上只有些许差异,大致还是一样的。主要是因为python中调用的numpy库对矩阵的处理方式与matlab相似,画图库matplotlib也是参考matlab而实现的。

有差异的地方

在矩阵/数组的处理上,

在for循环的处理上,

索引的处理上(matlab索引从1开始,python索引从0开始)

matlab代码

echo on
T=1;
Fs=2/T;
Ts=1/Fs;
c_opt=[-2.2 4.9 -3 4.9 -2.2];
t=-5*T:T/2:5*T;
x=1./(1+((2/T)*t).^2);		        % sampled pulse
equalized_x=filter(c_opt,1,[x 0 0]);	% since there will be a delay of two samples at the output
% to take care of the delay
equalized_x=equalized_x(3:length(equalized_x));
% Now, let us downsample the equalizer output
for i=1:2:length(equalized_x),
  downsampled_equalizer_output((i+1)/2)=equalized_x(i);
  echo off;
end;
figure(1)
stem(equalized_x)
figure(2)
stem(downsampled_equalizer_output)

python代码

import numpy as np
from scipy import signal
import matplotlib.pyplot as plt

T=1
Fs=2/T
Ts=1./Fs
c_opt=np.array([-2.2,4.9,-3,4.9,-2.2])

t=np.linspace(-5*T, 5*T, 21)
x=1./(1+(2/T*t)**2)
x_ = np.hstack((x,np.zeros((2,))))
print(c_opt,np.array([1]),x_)

equalized_x=signal.lfilter(c_opt,np.array([1]),x_);
equalized_x=equalized_x[2:equalized_x.size]
print(equalized_x)

downsampled_equalizer_output = np.zeros((int(equalized_x.size/2+1),))
#% Now, let us downsample the equalizer output
for i in range(0,equalized_x.size,2):
    downsampled_equalizer_output[int((i+1)/2)]=equalized_x[i];
print(downsampled_equalizer_output)

plt.figure(1)
plt.stem(equalized_x)
plt.figure(2)
plt.stem(downsampled_equalizer_output)
plt.show()


武汉格发信息技术有限公司,格发许可优化管理系统可以帮你评估贵公司软件许可的真实需求,再低成本合规性管理软件许可,帮助贵司提高软件投资回报率,为软件采购、使用提供科学决策依据。支持的软件有: CAD,CAE,PDM,PLM,Catia,Ugnx, AutoCAD, Pro/E, Solidworks ,Hyperworks, Protel,CAXA,OpenWorks LandMark,MATLAB,Enovia,Winchill,TeamCenter,MathCAD,Ansys, Abaqus,ls-dyna, Fluent, MSC,Bentley,License,UG,ug,catia,Dassault Systèmes,AutoDesk,Altair,autocad,PTC,SolidWorks,Ansys,Siemens PLM Software,Paradigm,Mathworks,Borland,AVEVA,ESRI,hP,Solibri,Progman,Leica,Cadence,IBM,SIMULIA,Citrix,Sybase,Schlumberger,MSC Products...

相关文章
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空