Python全面分析系统的时域特性和频率域特性

时间:2021-05-22

在不使用matlab的情况下,可以选择用python来实现自动控制理论有关系统打时域分析和频率域分析等,安装的package是python-control,在windows的控制台(cmd)或者linux终端下输入pip install control 即可,注意,如果同时安装了2.7 和 3.x(3.4或者3.5或者3.6 版本,使用pip 命令打时候需要指定版本号,如pip2 install control 或者pip3.4 install control ,当然,常用打科学计算用的package也要安装,numpy,scipy,sympy,matplotlib,pandas 等。

下面是自己练习时写的代码,写在此作记录和分享用,因为函数语法和matlab相差无几,这里就没有写太多的注释了,有需要打话可以去python-control打官网查看相关文档。

#!/usr/bin/env python2# -*- coding: utf-8 -*-"""Created on Wed Nov 16 17:48:02 2016@author: kindy"""from control import *from scipy import signal as sglfrom matplotlib import pyplot as pltimport numpy as npT=np.mgrid[0:8:0.02]U1=TU2=T**2sys1 = tf([1],[0.5,1]) # sys2 = tf([2],[1,2,4]) # # Step Responsedef step_resp(): sout1,stime1 = step(sys1) sout2,stime2 = step(sys2) plt.plot(stime1,sout1,'b',linewidth=0.5) plt.plot(stime2,sout2,'b',linewidth=0.5) plt.xlabel("Time") plt.ylabel("Amplitude") plt.title("Step Resopnse",fontsize=12) #plt.legend() plt.show()# Impulse Responsedef impulse_resp(): iout1,itime1 = impulse(sys1) iout2,itime2 = impulse(sys2) plt.plot(itime1,iout1,'m',linewidth=0.8) plt.plot(itime2,iout2,'r',linewidth=0.8) plt.show()#impulse_resp()# 任意输入信号的输出,lsimdef lsim_plot(): yout1,Time1, xout1 = lsim(sys1, U1, T) yout2,Time2, xout2 = lsim(sys2, U1, T) plt.plot(Time1, yout1, 'b', linewidth=0.7) plt.plot(Time2, yout2, 'b', linewidth=0.7) plt.show()#lsim_plot()# 波特图def bode_plot(): bode(sys1) bode(sys2)#bode_plot()# Nyquist图def nyquist_plot(): nyquist(sys1) nyquist(sys2)#nyquist_plot() # 根轨迹def root_locus(): rlocus(sys1) rlocus(sys2)root_locus()

下面是运行打一些结果图:

以上这篇Python全面分析系统的时域特性和频率域特性就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章