欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Matplotlib animation模塊實現(xiàn)動態(tài)圖

 更新時間:2021年02月25日 08:39:45   作者:門下平章  
這篇文章主要介紹了Matplotlib animation模塊實現(xiàn)動態(tài)圖,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

matplotlib 畫圖功能非常強(qiáng)大,目前也只能根據(jù)官網(wǎng) 提供的例子簡單地畫幾張圖。最近學(xué)習(xí)了能畫動態(tài)圖的animation模塊,作個簡單地記錄。

在matplotlib作圖中,比較常用的是matplotlib.pyplot模塊,這個模塊有非常多的屬性和方法,簡要列舉下這次用到的方法:
matplotlib.pyplot.subplots(nrows=1, ncols=1, sharex=False, sharey=False, squeeze=True, subplot_kw=None, gridspec_kw=None, **fig_kw)
返回fig和ax對象!

例子1. 動態(tài)畫出sin函數(shù)曲線

import numpy as np
import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation

fig, ax = plt.subplots()
xdata, ydata = [], []
ln, = ax.plot([], [], 'r-', animated=False)

def init():
  ax.set_xlim(0, 2*np.pi)
  ax.set_ylim(-1, 1)
  return ln,

def update(frame):
  xdata.append(frame)
  ydata.append(np.sin(frame))
  ln.set_data(xdata, ydata)
  return ln,

ani = FuncAnimation(fig, update, frames=np.linspace(0, 2*np.pi, 128),
          init_func=init, blit=True)
plt.show()

sin函數(shù)動態(tài)圖

畫這類圖的關(guān)鍵是要給出不斷更新的函數(shù),這里就是update 函數(shù)了。注意, line, = ax.plot([], [], 'r-', animated=False) 中的, 表示創(chuàng)建tuple類型。迭代更新的數(shù)據(jù)frame 取值從frames 取得。

例子2. 動態(tài)顯示一個動點,它的軌跡是sin函數(shù)。

import numpy as np 
import matplotlib.pyplot as plt
from matplotlib import animation

"""
animation example 2
author: Kiterun
"""

fig, ax = plt.subplots()
x = np.linspace(0, 2*np.pi, 200)
y = np.sin(x)
l = ax.plot(x, y)
dot, = ax.plot([], [], 'ro')

def init():
  ax.set_xlim(0, 2*np.pi)
  ax.set_ylim(-1, 1)
  return l

def gen_dot():
  for i in np.linspace(0, 2*np.pi, 200):
    newdot = [i, np.sin(i)]
    yield newdot

def update_dot(newd):
  dot.set_data(newd[0], newd[1])
  return dot,

ani = animation.FuncAnimation(fig, update_dot, frames = gen_dot, interval = 100, init_func=init)
ani.save('sin_dot.gif', writer='imagemagick', fps=30)

plt.show()

這里我們把生成的動態(tài)圖保存為gif圖片,前提要預(yù)先安裝imagemagic。

sin_dot

例子3. 單擺(沒阻尼&有阻尼)

無阻尼的單擺力學(xué)公式:

附加阻尼項:

這里需要用到scipy.integrate的odeint模塊,具體用法找時間再專門寫一篇blog吧,動態(tài)圖代碼如下:

# -*- coding: utf-8 -*-

from math import sin, cos
import numpy as np
from scipy.integrate import odeint
import matplotlib.pyplot as plt
import matplotlib.animation as animation

g = 9.8
leng = 1.0
b_const = 0.2

# no decay case:
def pendulum_equations1(w, t, l):
  th, v = w
  dth = v
  dv = - g/l * sin(th)
  return dth, dv

# the decay exist case:
def pendulum_equations2(w, t, l, b):
  th, v = w
  dth = v
  dv = -b/l * v - g/l * sin(th)
  return dth, dv

t = np.arange(0, 20, 0.1)
track = odeint(pendulum_equations1, (1.0, 0), t, args=(leng,))
#track = odeint(pendulum_equations2, (1.0, 0), t, args=(leng, b_const))
xdata = [leng*sin(track[i, 0]) for i in range(len(track))]
ydata = [-leng*cos(track[i, 0]) for i in range(len(track))]

fig, ax = plt.subplots()
ax.grid()
line, = ax.plot([], [], 'o-', lw=2)
time_template = 'time = %.1fs'
time_text = ax.text(0.05, 0.9, '', transform=ax.transAxes)

def init():
  ax.set_xlim(-2, 2)
  ax.set_ylim(-2, 2)
  time_text.set_text('')
  return line, time_text

def update(i):
  newx = [0, xdata[i]]
  newy = [0, ydata[i]]
  line.set_data(newx, newy)
  time_text.set_text(time_template %(0.1*i))
  return line, time_text

ani = animation.FuncAnimation(fig, update, range(1, len(xdata)), init_func=init, interval=50)
#ani.save('single_pendulum_decay.gif', writer='imagemagick', fps=100)
ani.save('single_pendulum_nodecay.gif', writer='imagemagick', fps=100)
plt.show()

無衰減 

衰減

例子4. 滾動的球

import numpy as np 
import matplotlib.pyplot as plt 
import matplotlib.animation as animation

fig = plt.figure(figsize=(6, 6))
ax = plt.gca()
ax.grid()
ln1, = ax.plot([], [], '-', lw=2)
ln2, = ax.plot([], [], '-', color='r', lw=2)
theta = np.linspace(0, 2*np.pi, 100)
r_out = 1
r_in = 0.5

def init():
  ax.set_xlim(-2, 2)
  ax.set_ylim(-2, 2)
  x_out = [r_out*np.cos(theta[i]) for i in range(len(theta))]
  y_out = [r_out*np.sin(theta[i]) for i in range(len(theta))]
  ln1.set_data(x_out, y_out)
  return ln1,

def update(i):
  x_in = [(r_out-r_in)*np.cos(theta[i])+r_in*np.cos(theta[j]) for j in range(len(theta))]
  y_in = [(r_out-r_in)*np.sin(theta[i])+r_in*np.sin(theta[j]) for j in range(len(theta))]
  ln2.set_data(x_in, y_in)
  return ln2,

ani = animation.FuncAnimation(fig, update, range(len(theta)), init_func=init, interval=30)
ani.save('roll.gif', writer='imagemagick', fps=100)

plt.show()

這里寫圖片描述

到此這篇關(guān)于Matplotlib animation模塊實現(xiàn)動態(tài)圖 的文章就介紹到這了,更多相關(guān)Matplotlib 動態(tài)圖 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python+radar實現(xiàn)隨機(jī)日期時間的生成

    Python+radar實現(xiàn)隨機(jī)日期時間的生成

    Python有廣泛豐富的第三方庫,在沒有特殊定制下,避免了重復(fù)造輪子。本文將利用radar庫實現(xiàn)生成隨機(jī)的日期或時間,文中的示例代碼講解詳細(xì),感興趣的可以了解一下
    2022-05-05
  • Python實現(xiàn)一鍵自動分類管理文件

    Python實現(xiàn)一鍵自動分類管理文件

    經(jīng)常雜亂無章的文件夾會讓我們找不到所想要的文件,所以本文小編特意為大家介紹了如何制作一個可視化GUI界面,通過輸入路徑一鍵點擊實現(xiàn)文件分門別類的歸檔,希望對大家有所幫助<BR>
    2024-01-01
  • 基于Python實現(xiàn)批量讀取大量nc格式文件并導(dǎo)出全部時間信息

    基于Python實現(xiàn)批量讀取大量nc格式文件并導(dǎo)出全部時間信息

    這篇文章主要為大家詳細(xì)介紹了如何基于Python語言,逐一讀取大量.nc格式的多時相柵格文件并導(dǎo)出其中所具有的全部時間信息的方法,需要的可以參考下
    2024-01-01
  • python3代碼中實現(xiàn)加法重載的實例

    python3代碼中實現(xiàn)加法重載的實例

    在本篇文章里小編給大家整理的是一篇關(guān)于python3代碼中實現(xiàn)加法重載的實例內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。
    2020-12-12
  • python排序函數(shù)sort()與sorted()的區(qū)別

    python排序函數(shù)sort()與sorted()的區(qū)別

    這篇文章主要介紹了python排序函數(shù)sort()與sorted()的區(qū)別,需要的朋友可以參考下
    2018-09-09
  • Django如何實現(xiàn)內(nèi)容緩存示例詳解

    Django如何實現(xiàn)內(nèi)容緩存示例詳解

    緩存對于大家來說應(yīng)該都不陌生,下面這篇文章主要給大家介紹了關(guān)于Django如何實現(xiàn)內(nèi)容緩存的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-09-09
  • Django?CSRF驗證失敗請求被中斷的問題

    Django?CSRF驗證失敗請求被中斷的問題

    這篇文章主要介紹了Django?CSRF驗證失敗請求被中斷的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 編寫Python爬蟲抓取暴走漫畫上gif圖片的實例分享

    編寫Python爬蟲抓取暴走漫畫上gif圖片的實例分享

    這篇文章主要介紹了編寫Python爬蟲抓取暴走漫畫上gif圖片的實例分享,示例代碼為Python3,利用到了urllib模塊、request模塊和BeautifulSoup模塊,需要的朋友可以參考下
    2016-04-04
  • django注冊用郵箱發(fā)送驗證碼的實現(xiàn)

    django注冊用郵箱發(fā)送驗證碼的實現(xiàn)

    這篇文章主要介紹了django注冊用郵箱發(fā)送驗證碼的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • golang/python實現(xiàn)歸并排序?qū)嵗a

    golang/python實現(xiàn)歸并排序?qū)嵗a

    這篇文章主要給大家介紹了關(guān)于golang/python實現(xiàn)歸并排序的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08

最新評論