50 lines
2.6 KiB
Python
50 lines
2.6 KiB
Python
|
import sympy.physics.mechanics as _me
|
||
|
import sympy as _sm
|
||
|
import math as m
|
||
|
import numpy as _np
|
||
|
|
||
|
frame_a = _me.ReferenceFrame('a')
|
||
|
c1, c2, c3 = _sm.symbols('c1 c2 c3', real=True)
|
||
|
a = _me.inertia(frame_a, 1, 1, 1)
|
||
|
particle_p1 = _me.Particle('p1', _me.Point('p1_pt'), _sm.Symbol('m'))
|
||
|
particle_p2 = _me.Particle('p2', _me.Point('p2_pt'), _sm.Symbol('m'))
|
||
|
body_r_cm = _me.Point('r_cm')
|
||
|
body_r_f = _me.ReferenceFrame('r_f')
|
||
|
body_r = _me.RigidBody('r', body_r_cm, body_r_f, _sm.symbols('m'), (_me.outer(body_r_f.x,body_r_f.x),body_r_cm))
|
||
|
frame_a.orient(body_r_f, 'DCM', _sm.Matrix([1,1,1,1,1,0,0,0,1]).reshape(3, 3))
|
||
|
point_o = _me.Point('o')
|
||
|
m1 = _sm.symbols('m1')
|
||
|
particle_p1.mass = m1
|
||
|
m2 = _sm.symbols('m2')
|
||
|
particle_p2.mass = m2
|
||
|
mr = _sm.symbols('mr')
|
||
|
body_r.mass = mr
|
||
|
i1 = _sm.symbols('i1')
|
||
|
i2 = _sm.symbols('i2')
|
||
|
i3 = _sm.symbols('i3')
|
||
|
body_r.inertia = (_me.inertia(body_r_f, i1, i2, i3, 0, 0, 0), body_r_cm)
|
||
|
point_o.set_pos(particle_p1.point, c1*frame_a.x)
|
||
|
point_o.set_pos(particle_p2.point, c2*frame_a.y)
|
||
|
point_o.set_pos(body_r_cm, c3*frame_a.z)
|
||
|
a = _me.inertia_of_point_mass(particle_p1.mass, particle_p1.point.pos_from(point_o), frame_a)
|
||
|
a = _me.inertia_of_point_mass(particle_p2.mass, particle_p2.point.pos_from(point_o), frame_a)
|
||
|
a = body_r.inertia[0] + _me.inertia_of_point_mass(body_r.mass, body_r.masscenter.pos_from(point_o), frame_a)
|
||
|
a = _me.inertia_of_point_mass(particle_p1.mass, particle_p1.point.pos_from(point_o), frame_a) + _me.inertia_of_point_mass(particle_p2.mass, particle_p2.point.pos_from(point_o), frame_a) + body_r.inertia[0] + _me.inertia_of_point_mass(body_r.mass, body_r.masscenter.pos_from(point_o), frame_a)
|
||
|
a = _me.inertia_of_point_mass(particle_p1.mass, particle_p1.point.pos_from(point_o), frame_a) + body_r.inertia[0] + _me.inertia_of_point_mass(body_r.mass, body_r.masscenter.pos_from(point_o), frame_a)
|
||
|
a = body_r.inertia[0] + _me.inertia_of_point_mass(body_r.mass, body_r.masscenter.pos_from(point_o), frame_a)
|
||
|
a = body_r.inertia[0]
|
||
|
particle_p2.point.set_pos(particle_p1.point, c1*frame_a.x+c2*frame_a.y)
|
||
|
body_r_cm.set_pos(particle_p1.point, c3*frame_a.x)
|
||
|
body_r_cm.set_pos(particle_p2.point, c3*frame_a.y)
|
||
|
b = _me.functions.center_of_mass(point_o,particle_p1, particle_p2, body_r)
|
||
|
b = _me.functions.center_of_mass(point_o,particle_p1, body_r)
|
||
|
b = _me.functions.center_of_mass(particle_p1.point,particle_p1, particle_p2, body_r)
|
||
|
u1, u2, u3 = _me.dynamicsymbols('u1 u2 u3')
|
||
|
v = u1*frame_a.x+u2*frame_a.y+u3*frame_a.z
|
||
|
u = (v+c1*frame_a.x).normalize()
|
||
|
particle_p1.point.set_vel(frame_a, u1*frame_a.x)
|
||
|
a = particle_p1.point.partial_velocity(frame_a, u1)
|
||
|
m = particle_p1.mass+body_r.mass
|
||
|
m = particle_p2.mass
|
||
|
m = particle_p1.mass+particle_p2.mass+body_r.mass
|