python 四元素_Python-四元数类 - 红尘潇洒,独自前行,但尽人事,莫问前程 - OSCHINA - 中文开源技术交流社区...

class Quaternion:

def __init__(self,array):

self.w=0

self.x=array[0]

self.y=array[1]

self.z=array[2]

self.array=array

def toArray():

return [x,y,z,w]

def __add__(self,quaternion):

result=Quaternion(self.array)

result.w+=quaternion.w

result.x+=quaternion.x

result.y+=quaternion.y

result.z+=quaternion.z

return result

def __sub__(self,quaternion):

result=Quaternion(self.array)

result.w-=quaternion.w

result.x-=quaternion.x

result.y-=quaternion.y

result.z-=quaternion.z

return result

def multiplication(self,quaternion):

result=Quaternion(self.array)

result.w=self.w*quaternion.w-self.x*quaternion.x-self.y*quaternion.y-self.z*quaternion.z

result.x=self.w*quaternion.x+self.x*quaternion.w+self.y*quaternion.z-self.z*quaternion.y

result.y=self.w*quaternion.y-self.x*quaternion.z+self.y*quaternion.w+self.z*quaternion.x

result.z=self.w*quaternion.z+self.x*quaternion.y-self.y*quaternion.x+self.z*quaternion.w

return result

def divides(quaternion):

result=Quaternion(self.array)

return result.multiplication(quaternion.inverse());

def mod(self):

return pow((pow(self.x,2)+pow(self.y,2)+pow(self.z,2)+pow(self.w,2)),1/2)

def star(self):

result=Quaternion(self.array)

result.w=self.w

result.x=-self.x

result.y=-self.y

result.z=-self.z

return result

def inverse(self):

result=Quaternion(self.array)

moder=self.mod()

result.w/=moder

result.x/=moder

result.y/=moder

result.z/=moder

return result

def __str__(self):

return str(self.x)+"i "+str(self.y)+"j "+str(self.z)+"k "+str(self.w)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值