国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python+matplotlib實現動態繪制圖片實例代碼(交互式繪圖)

2020-02-22 22:55:12
字體:
來源:轉載
供稿:網友

本文研究的主要是python+matplotlib實現動態繪制圖片(交互式繪圖)的相關內容,具體介紹和實現代碼如下所示。

  最近在研究動態障礙物避障算法,在Python語言進行算法仿真時需要實時顯示障礙物和運動物的當前位置和軌跡,利用Anaconda的Python打包集合,在Spyder中使用Python3.5語言和matplotlib實現路徑的動態顯示和交互式繪圖(和Matlab功能類似)。

  Anaconda是一個用于科學計算的Python發行版,支持 Linux, Mac, Windows系統,提供了包管理與環境管理的功能,可以很方便地解決多版本python并存、切換以及各種第三方包安裝問題。Anaconda利用工具/命令conda來進行package和environment的管理,并且已經包含了Python和相關的配套工具。Anaconda官方地址:https://www.continuum.io/downloads/

  matplotlib 是python最著名的繪圖庫,它提供了一整套和matlab相似的命令API,十分適合交互式地進行制圖。而且也可以方便地將它作為繪圖控件,嵌入GUI應用程序中。其中,matplotlib的pyplot子庫提供了和matlab類似的繪圖API,方便用戶快速繪制2D圖表,它的文檔相當完備,并且 Gallery頁面中有上百幅縮略圖,打開之后都有源程序。matplotlib官方地址:http://matplotlib.org/

  在調研matplotlib動態繪制曲線方法中,和matlab相似有animation方法和交互式繪圖,但是animation方法靈活性不高,不太適合路徑的實時動態顯示,本文最后采用交互式繪圖模(interactive mode)。具體參見http://matplotlib.org/users/shell.html。

  The interactive property of the pyplot interface controls whether a figure canvas is drawn on every pyplot command. If interactive is False, then the figure state is updated on every plot command, but will only be drawn on explicit calls to draw(). When interactive is True, then every pyplot command triggers a draw.

  當繪圖語句中加入pl.ion()時,表示打開了交互模式。此時python解釋器解釋完所有命令后,給你出張圖,但不會結束會話,而是等著你跟他交流交流。如果你繼續往代碼中加入語句,run之后,你會實時看到圖形的改變。當繪圖語句中加入pl.ioff()時或不添加pl.ion()時,表示打關了交互模式。此時要在代碼末尾加入pl.show()才能顯示圖片。python解釋器解釋完所有命令后,給你出張圖,同時結束會話。如果你繼續往代碼中加入語句,再不會起作用,除非你關閉當前圖片,重新run。

  采用交互式繪圖模式后,可以方便地繪出障礙物的運動軌跡和當前位置,深切感覺matplotlib和matlab很類似,基本matlab的功能都可以在matplotlib中找到,所以matlab中的代碼也可以很快移植到python中!

代碼示例:

# -*- coding: utf-8 -*-"""Created on Sat Mar 25 23:28:29 2017@author: wyl"""import matplotlib.pyplot as pltfrom matplotlib.patches import Circleimport numpy as npimport math  plt.close() #clf() # 清圖 cla() # 清坐標軸 close() # 關窗口fig=plt.figure()ax=fig.add_subplot(1,1,1)ax.axis("equal") #設置圖像顯示的時候XY軸比例plt.grid(True) #添加網格plt.ion() #interactive mode onIniObsX=0000IniObsY=4000IniObsAngle=135IniObsSpeed=10*math.sqrt(2)  #米/秒print('開始仿真')try:  for t in range(180):    #障礙物船只軌跡    obsX=IniObsX+IniObsSpeed*math.sin(IniObsAngle/180*math.pi)*t    obsY=IniObsY+IniObsSpeed*math.cos(IniObsAngle/180*math.pi)*t    ax.scatter(obsX,obsY,c='b',marker='.') #散點圖    #ax.lines.pop(1) 刪除軌跡    #下面的圖,兩船的距離    plt.pause(0.001)except Exception as err:  print(err)            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜川县| 凌云县| 许昌县| 竹山县| 雅江县| 七台河市| 辽宁省| 天柱县| 汽车| 枞阳县| 开远市| 丰原市| 科技| 郁南县| 青岛市| 洪洞县| 行唐县| 中西区| 安仁县| 凤阳县| 文昌市| 黑龙江省| 渭源县| 桑植县| 资中县| 清水河县| 垫江县| 伊宁市| 哈尔滨市| 彭泽县| 镇坪县| 大化| 江华| 新泰市| 穆棱市| 西乌| 宁津县| 饶平县| 永仁县| 皋兰县| 新津县|