<del id="d4fwx"><form id="d4fwx"></form></del>
      <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

            <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
          • python中函數(shù)繪圖 用python畫函數(shù)圖

            Python氣象數(shù)據(jù)處理與繪圖(2):常用數(shù)據(jù)計(jì)算方法

            對(duì)于氣象繪圖來(lái)講,第一步是對(duì)數(shù)據(jù)的處理,通過(guò)各類公式,或者統(tǒng)計(jì)方法將原始數(shù)據(jù)處理為目標(biāo)數(shù)據(jù)。

            目前成都創(chuàng)新互聯(lián)公司已為上千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、成都網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計(jì)、淮陽(yáng)網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

            按照氣象統(tǒng)計(jì)課程的內(nèi)容,我給出了一些常用到的統(tǒng)計(jì)方法的對(duì)應(yīng)函數(shù):

            在計(jì)算氣候態(tài),區(qū)域平均時(shí)均要使用到求均值函數(shù),對(duì)應(yīng)NCL中的dim_average函數(shù),在python中通常使用np.mean()函數(shù)

            numpy.mean(a, axis, dtype)

            假設(shè)a為[time,lat,lon]的數(shù)據(jù),那么

            需要特別注意的是,氣象數(shù)據(jù)中常有缺測(cè),在NCL中,使用求均值函數(shù)會(huì)自動(dòng)略過(guò),而在python中,當(dāng)任意一數(shù)與缺測(cè)(np.nan)計(jì)算的結(jié)果均為np.nan,比如求[1,2,3,4,np.nan]的平均值,結(jié)果為np.nan

            因此,當(dāng)數(shù)據(jù)存在缺測(cè)數(shù)據(jù)時(shí),通常使用np.nanmean()函數(shù),用法同上,此時(shí)[1,2,3,4,np.nan]的平均值為(1+2+3+4)/4 = 2.5

            同樣的,求某數(shù)組最大最小值時(shí)也有np.nanmax(), np.nanmin()函數(shù)來(lái)補(bǔ)充np.max(), np.min()的不足。

            其他很多np的計(jì)算函數(shù)也可以通過(guò)在前邊加‘nan’來(lái)使用。

            另外,

            也可以直接將a中缺失值全部填充為0。

            np.std(a, axis, dtype)

            用法同np.mean()

            在NCL中有直接求數(shù)據(jù)標(biāo)準(zhǔn)化的函數(shù)dim_standardize()

            其實(shí)也就是一行的事,根據(jù)需要指定維度即可。

            皮爾遜相關(guān)系數(shù):

            相關(guān)可以說(shuō)是氣象科研中最常用的方法之一了,numpy函數(shù)中的np.corrcoef(x, y)就可以實(shí)現(xiàn)相關(guān)計(jì)算。但是在這里我推薦scipy.stats中的函數(shù)來(lái)計(jì)算相關(guān)系數(shù):

            這個(gè)函數(shù)缺點(diǎn)和有點(diǎn)都很明顯,優(yōu)點(diǎn)是可以直接返回相關(guān)系數(shù)R及其P值,這避免了我們進(jìn)一步計(jì)算置信度。而缺點(diǎn)則是該函數(shù)只支持兩個(gè)一維數(shù)組的計(jì)算,也就是說(shuō)當(dāng)我們需要計(jì)算一個(gè)場(chǎng)和一個(gè)序列的相關(guān)時(shí),我們需要循環(huán)來(lái)實(shí)現(xiàn)。

            其中a[time,lat,lon],b[time]

            (NCL中為regcoef()函數(shù))

            同樣推薦Scipy庫(kù)中的stats.linregress(x,y)函數(shù):

            slop: 回歸斜率

            intercept:回歸截距

            r_value: 相關(guān)系數(shù)

            p_value: P值

            std_err: 估計(jì)標(biāo)準(zhǔn)誤差

            直接可以輸出P值,同樣省去了做置信度檢驗(yàn)的過(guò)程,遺憾的是仍需同相關(guān)系數(shù)一樣循環(huán)計(jì)算。

            python函數(shù)圖的繪制

            pre

            import numpy as np

            import matplotlib.pyplot as plt

            from matplotlib.patches import Polygon

            def func(x):

            return -(x-2)*(x-8)+40

            x=np.linspace(0,10)

            y=func(x)

            fig,ax = plt.subplots()

            plt.plot(x,y,'r',linewidth=2)

            plt.ylim(ymin=20)

            a=2

            b=9

            ax.set_xticks([a,b])

            ax.set_xticklabels(['$a$','$b$'])

            ax.set_yticks([])

            plt.figtext(0.9,0.05,'$x$')

            plt.figtext(0.1,0.9,'$y$')

            ix=np.linspace(a,b)

            iy=func(ix)

            ixy=zip(ix,iy)

            verts=[(a,0)]+list(ixy)+[(b,0)]

            poly = Polygon(verts,facecolor='0.9',edgecolor='0.5')

            ax.add_patch(poly)

            x_math=(a+b)*0.5

            y_math=35

            plt.text(x_math,y_math,r"$\int_a^b(-(x-2)*(x-8)+40)dx$",horizontalalignment='center',size=12)

            plt.show()

            /pre

            python繪圖篇

            1,xlable,ylable設(shè)置x,y軸的標(biāo)題文字。

            2,title設(shè)置標(biāo)題。

            3,xlim,ylim設(shè)置x,y軸顯示范圍。

            plt.show()顯示繪圖窗口,通常情況下,show()會(huì)阻礙程序運(yùn)行,帶-wthread等參數(shù)的環(huán)境下,窗口不會(huì)關(guān)閉。

            plt.saveFig()保存圖像。

            面向?qū)ο罄L圖

            1,當(dāng)前圖表和子圖可以用gcf(),gca()獲得。

            subplot()繪制包含多個(gè)圖表的子圖。

            configure subplots,可調(diào)節(jié)子圖與圖表邊框距離。

            可以通過(guò)修改配置文件更改對(duì)象屬性。

            圖標(biāo)顯示中文

            1,在程序中直接指定字體。

            2, 在程序開始修改配置字典reParams.

            3,修改配置文件。

            Artist對(duì)象

            1,圖標(biāo)的繪制領(lǐng)域。

            2,如何在FigureCanvas對(duì)象上繪圖。

            3,如何使用Renderer在FigureCanvas對(duì)象上繪圖。

            FigureCanvas和Render處理底層圖像操作,Artist處理高層結(jié)構(gòu)。

            分為簡(jiǎn)單對(duì)象和容器對(duì)象,簡(jiǎn)單的Aritist是標(biāo)準(zhǔn)的繪圖元件,例如Line 2D,Rectangle,Text,AxesImage等,而容器類型包含許多簡(jiǎn)單的的 Aritist對(duì)象,使他們構(gòu)成一個(gè)整體,例如Axis,Axes,Figure等。

            直接創(chuàng)建Artist對(duì)象進(jìn)項(xiàng)繪圖操作步奏:

            1,創(chuàng)建Figure對(duì)象(通過(guò)figure()函數(shù),會(huì)進(jìn)行許多初始化操作,不建議直接創(chuàng)建。)

            2,為Figure對(duì)象創(chuàng)建一個(gè)或多個(gè)Axes對(duì)象。

            3,調(diào)用Axes對(duì)象的方法創(chuàng)建各類簡(jiǎn)單的Artist對(duì)象。

            Figure容器

            如何找到指定的Artist對(duì)象。

            1,可調(diào)用add_subplot()和add_axes()方法向圖表添加子圖。

            2,可使用for循環(huán)添加?xùn)鸥瘛?/p>

            3,可通過(guò)transform修改坐標(biāo)原點(diǎn)。

            Axes容器

            1,patch修改背景。

            2,包含坐標(biāo)軸,坐標(biāo)網(wǎng)格,刻度標(biāo)簽,坐標(biāo)軸標(biāo)題等內(nèi)容。

            3,get_ticklabels(),,get-ticklines獲得刻度標(biāo)簽和刻度線。

            1,可對(duì)曲線進(jìn)行插值。

            2,fill_between()繪制交點(diǎn)。

            3,坐標(biāo)變換。

            4,繪制陰影。

            5,添加注釋。

            1,繪制直方圖的函數(shù)是

            2,箱線圖(Boxplot)也稱箱須圖(Box-whisker Plot),是利用數(shù)據(jù)中的五個(gè)統(tǒng)計(jì)量:最小值、第一四分位

            數(shù)、中位數(shù)、第三四分位數(shù)與最大值來(lái)描述數(shù)據(jù)的一種方法,它可以粗略地看出數(shù)據(jù)是否具有對(duì)稱性以及分

            布的分散程度等信息,特別可以用于對(duì)幾個(gè)樣本的比較。

            3,餅圖就是把一個(gè)圓盤按所需表達(dá)變量的觀察數(shù)劃分為若干份,每一份的角度(即面積)等價(jià)于每個(gè)觀察

            值的大小。

            4,散點(diǎn)圖

            5,QQ圖

            低層繪圖函數(shù)

            類似于barplot(),dotchart()和plot()這樣的函數(shù)采用低層的繪圖函數(shù)來(lái)畫線和點(diǎn),來(lái)表達(dá)它們?cè)陧?yè)面上放置的位置以及其他各種特征。

            在這一節(jié)中,我們會(huì)描述一些低層的繪圖函數(shù),用戶也可以調(diào)用這些函數(shù)用于繪圖。首先我們先講一下R怎么描述一個(gè)頁(yè)面;然后我們講怎么在頁(yè)面上添加點(diǎn),線和文字;最后講一下怎么修改一些基本的圖形。

            繪圖區(qū)域與邊界

            R在繪圖時(shí),將顯示區(qū)域劃分為幾個(gè)部分。繪制區(qū)域顯示了根據(jù)數(shù)據(jù)描繪出來(lái)的圖像,在此區(qū)域內(nèi)R根據(jù)數(shù)據(jù)選擇一個(gè)坐標(biāo)系,通過(guò)顯示出來(lái)的坐標(biāo)軸可以看到R使用的坐標(biāo)系。在繪制區(qū)域之外是邊沿區(qū),從底部開始按順時(shí)針?lè)较蚍謩e用數(shù)字1到4表示。文字和標(biāo)簽通常顯示在邊沿區(qū)域內(nèi),按照從內(nèi)到外的行數(shù)先后顯示。

            添加對(duì)象

            在繪制的圖像上還可以繼續(xù)添加若干對(duì)象,下面是幾個(gè)有用的函數(shù),以及對(duì)其功能的說(shuō)明。

            ?points(x, y, ...),添加點(diǎn)

            ?lines(x, y, ...),添加線段

            ?text(x, y, labels, ...),添加文字

            ?abline(a, b, ...),添加直線y=a+bx

            ?abline(h=y, ...),添加水平線

            ?abline(v=x, ...),添加垂直線

            ?polygon(x, y, ...),添加一個(gè)閉合的多邊形

            ?segments(x0, y0, x1, y1, ...),畫線段

            ?arrows(x0, y0, x1, y1, ...),畫箭頭

            ?symbols(x, y, ...),添加各種符號(hào)

            ?legend(x, y, legend, ...),添加圖列說(shuō)明

            Python繪圖之(1)Turtle庫(kù)詳解

            Turtle庫(kù)是Python語(yǔ)言中一個(gè)很流行的繪制圖像的函數(shù)庫(kù),想象一個(gè)小烏龜,在一個(gè)橫軸為x、縱軸為y的坐標(biāo)系原點(diǎn),(0,0)位置開始,它根據(jù)一組函數(shù)指令的控制,在這個(gè)平面坐標(biāo)系中移動(dòng),從而在它爬行的路徑上繪制了圖形。

            畫布就是turtle為我們展開用于繪圖區(qū)域,我們可以設(shè)置它的大小和初始位置。

            設(shè)置畫布大小

            turtle.screensize(canvwidth=None, canvheight=None, bg=None),參數(shù)分別為畫布的寬(單位像素), 高, 背景顏色。

            如:turtle.screensize(800,600, "green")

            turtle.screensize() #返回默認(rèn)大小(400, 300)

            turtle.setup(width=0.5, height=0.75, startx=None, starty=None),參數(shù):width, height: 輸入寬和高為整數(shù)時(shí), 表示像素; 為小數(shù)時(shí), 表示占據(jù)電腦屏幕的比例,(startx, starty): 這一坐標(biāo)表示矩形窗口左上角頂點(diǎn)的位置, 如果為空,則窗口位于屏幕中心。

            如:turtle.setup(width=0.6,height=0.6)

            turtle.setup(width=800,height=800, startx=100, starty=100)

            2.1 畫筆的狀態(tài)

            在畫布上,默認(rèn)有一個(gè)坐標(biāo)原點(diǎn)為畫布中心的坐標(biāo)軸,坐標(biāo)原點(diǎn)上有一只面朝x軸正方向小烏龜。這里我們描述小烏龜時(shí)使用了兩個(gè)詞語(yǔ):坐標(biāo)原點(diǎn)(位置),面朝x軸正方向(方向), turtle繪圖中,就是使用位置方向描述小烏龜(畫筆)的狀態(tài)。

            2.2 畫筆的屬性

            畫筆(畫筆的屬性,顏色、畫線的寬度等)

            1) turtle.pensize():設(shè)置畫筆的寬度;

            2) turtle.pencolor():沒(méi)有參數(shù)傳入,返回當(dāng)前畫筆顏色,傳入?yún)?shù)設(shè)置畫筆顏色,可以是字符串如"green", "red",也可以是RGB 3元組。

            3) turtle.speed(speed):設(shè)置畫筆移動(dòng)速度,畫筆繪制的速度范圍[0,10]整數(shù),數(shù)字越大越快。

            2.3 繪圖命令

            操縱海龜繪圖有著許多的命令,這些命令可以劃分為3種:一種為運(yùn)動(dòng)命令,一種為畫筆控制命令,還有一種是全局控制命令。

            (1) 畫筆運(yùn)動(dòng)命令

            (2) 畫筆控制命令

            (3) 全局控制命令

            (4) 其他命令

            3. 命令詳解

            3.1 turtle.circle(radius, extent=None, steps=None)

            描述:以給定半徑畫圓

            參數(shù):

            radius(半徑):半徑為正(負(fù)),表示圓心在畫筆的左邊(右邊)畫圓;

            extent(弧度) (optional);

            steps (optional) (做半徑為radius的圓的內(nèi)切正多邊形,多邊形邊數(shù)為steps)。

            舉例:

            circle(50) # 整圓;

            circle(50,steps=3) # 三角形;

            circle(120, 180) # 半圓

            實(shí)例:

            1、太陽(yáng)花

            2、五角星

            3、時(shí)鐘程序

            網(wǎng)站題目:python中函數(shù)繪圖 用python畫函數(shù)圖
            文章位置:http://www.jbt999.com/article10/doosddo.html

            成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、網(wǎng)站營(yíng)銷、域名注冊(cè)、品牌網(wǎng)站建設(shè)、建站公司

            廣告

            聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

            成都定制網(wǎng)站建設(shè)

              <del id="d4fwx"><form id="d4fwx"></form></del>
              <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

                    <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
                  • 2022国产精品 | 88AV在线观看 | 国产精品豆花视频www | 黄色网久久 | 丁香婷婷五月天av |