這篇文章給大家分享的是有關(guān)python如何畫出三角形外接圓和內(nèi)切圓的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
堅(jiān)守“ 做人真誠(chéng) · 做事靠譜 · 口碑至上 · 高效敬業(yè) ”的價(jià)值觀,專業(yè)網(wǎng)站建設(shè)服務(wù)10余年為成都石牌坊小微創(chuàng)業(yè)公司專業(yè)提供成都定制網(wǎng)站營(yíng)銷網(wǎng)站建設(shè)商城網(wǎng)站建設(shè)手機(jī)網(wǎng)站建設(shè)小程序網(wǎng)站建設(shè)網(wǎng)站改版,從內(nèi)容策劃、視覺(jué)設(shè)計(jì)、底層架構(gòu)、網(wǎng)頁(yè)布局、功能開(kāi)發(fā)迭代于一體的高端網(wǎng)站建設(shè)服務(wù)。先來(lái)畫畫外接圓和內(nèi)切圓,留個(gè)大坑后面來(lái)填。
外接圓圓心:三角形垂直平分線的交點(diǎn)。
內(nèi)切圓圓心:三角形角平分線的交點(diǎn)。
有了思路,就可以用萬(wàn)能的python來(lái)計(jì)算了
import matplotlib.pyplot as plt from scipy.linalg import solve import numpy as np from matplotlib.patches import Circle ''' 求三角形外接圓和內(nèi)切圓 ''' # 畫個(gè)三角形 def plot_triangle(A, B, C): x = [A[0], B[0], C[0], A[0]] y = [A[1], B[1], C[1], A[1]] ax = plt.gca() ax.plot(x, y, linewidth=2) # 畫個(gè)圓 def draw_circle(x, y, r): ax = plt.gca() cir = Circle(xy=(x, y), radius=r, alpha=0.5) ax.add_patch(cir) ax.plot() # 外接圓 def get_outer_circle(A, B, C): xa, ya = A[0], A[1] xb, yb = B[0], B[1] xc, yc = C[0], C[1] # 兩條邊的中點(diǎn) x1, y1 = (xa + xb) / 2.0, (ya + yb) / 2.0 x2, y2 = (xb + xc) / 2.0, (yb + yc) / 2.0 # 兩條線的斜率 ka = (yb - ya) / (xb - xa) if xb != xa else None kb = (yc - yb) / (xc - xb) if xc != xb else None alpha = np.arctan(ka) if ka != None else np.pi / 2 beta = np.arctan(kb) if kb != None else np.pi / 2 # 兩條垂直平分線的斜率 k1 = np.tan(alpha + np.pi / 2) k2 = np.tan(beta + np.pi / 2) # 圓心 y, x = solve([[1.0, -k1], [1.0, -k2]], [y1 - k1 * x1, y2 - k2 * x2]) # 半徑 r1 = np.sqrt((x - xa)**2 + (y - ya)**2) return(x, y, r1) # 內(nèi)切圓 def get_inner_circle(A, B, C): xa, ya = A[0], A[1] xb, yb = B[0], B[1] xc, yc = C[0], C[1] ka = (yb - ya) / (xb - xa) if xb != xa else None kb = (yc - yb) / (xc - xb) if xc != xb else None alpha = np.arctan(ka) if ka != None else np.pi / 2 beta = np.arctan(kb) if kb != None else np.pi / 2 a = np.sqrt((xb - xc)**2 + (yb - yc)**2) b = np.sqrt((xa - xc)**2 + (ya - yc)**2) c = np.sqrt((xa - xb)**2 + (ya - yb)**2) ang_a = np.arccos((b**2 + c**2 - a**2) / (2 * b * c)) ang_b = np.arccos((a**2 + c**2 - b**2) / (2 * a * c)) # 兩條角平分線的斜率 k1 = np.tan(alpha + ang_a / 2) k2 = np.tan(beta + ang_b / 2) kv = np.tan(alpha + np.pi / 2) # 求圓心 y, x = solve([[1.0, -k1], [1.0, -k2]], [ya - k1 * xa, yb - k2 * xb]) ym, xm = solve([[1.0, -ka], [1.0, -kv]], [ya - ka * xa, y - kv * x]) r1 = np.sqrt((x - xm)**2 + (y - ym)**2) return(x, y, r1) if __name__ == '__main__': A = (1., 1.) B = (5., 2.) C = (5., 5.) plt.axis('equal') plt.axis('off') plot_triangle(A, B, C) x, y, r1 = get_outer_circle(A, B, C) plt.plot(x, y, 'ro') draw_circle(x, y, r1) x_inner, y_inner, r_inner = get_inner_circle(A, B, C) plt.plot(x_inner, y_inner, 'ro') draw_circle(x_inner, y_inner, r_inner) plt.show()
下面看看兩個(gè)三角形的結(jié)果:
感謝各位的閱讀!關(guān)于“python如何畫出三角形外接圓和內(nèi)切圓”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。