您当前的位置: 首页 >  Python

星夜孤帆

暂无认证

  • 5浏览

    0关注

    626博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

python旋转坐标

星夜孤帆 发布时间:2018-08-08 11:21:36 ,浏览量:5

数据旋转公式 x1=cos(angle)*x-sin(angle)*y; y1=cos(angle)*y+sin(angle)*x;

从数学上来说,此公式可以用来计算某个点绕另外一点旋转一定角度后的坐标,例如:A(x,y)绕B(a,b)旋转β度后的位置为C(c,d),则x,y,a,b,β,c,d有如下关系式:

import matplotlib.pyplot as plt
import numpy as np
import math
a = [0,1,3,3,2,2]
b = [3,4,2,1]
c = [3,3,2,3]

a = np.array(a)
b = np.array(b)
c = np.array(c)

def rotate(angle,valuex,valuey):
    rotatex = math.cos(angle)*valuex -math.sin(angle)*valuey
    rotatey = math.cos(angle)*valuey + math.sin(angle)* valuex
    rotatex = rotatex.tolist()
    rotatey = rotatey.tolist()
    xy = rotatex + rotatey
    return xy
def getLen(x1,y1,x2,y2):
    diff_x = (x1-x2)**2
    diff_y = (y1-y2)**2
    length = np.sqrt(diff_x+diff_y)
    return length

lie = np.linspace(0,2,20) #画图时横纵坐标刻度,影响着它们的形状,可以设置一下刻度分布
for i in lie:
    t = math.pi*i
    a1 = rotate(t,a[0:3],a[3:6])
    b1 = rotate(t,b[0:2],b[2:4])
    c1 = rotate(t,c[0:2],c[2:4])
    len1 = getLen(a[0],a[3],a[1],a[4])
    len2 = getLen(a1[0],a1[3],a1[1],a1[4])
    print(len1)
    print(len2)
    print("旋转后长度是否相等",len1==len2)
    plt.plot(a[0:3],a[3:6],color='green')
    plt.plot(b[0:2],b[2:4],color='green')
    plt.plot(c[0:2],c[2:4],color='green')
    plt.plot(a1[0:3],a1[3:6],color='red')
    plt.plot(b1[0:2],b1[2:4],color='red')
    plt.plot(c1[0:2],c1[2:4],color='red')
    plt.xticks(np.arange(-5,5,0.5))
    plt.yticks(np.arange(-5,5,0.5))
  
    plt.show()

 

关注
打赏
1636984416
查看更多评论
立即登录/注册

微信扫码登录

0.0770s