|
本帖最后由 qiush1234 于 2011-9-20 16:14 编辑
8 M5 |! `" u! S: M
$ t; v) N& n9 Y, r如题:最近在做一个课题时。遇到一些问题。
8 ?, v- Y% Z* X$ p; ~: v行车将工件吊运到在等待中的运输车,运输车将工件送达处理区域。
5 P5 }- H1 b& X" n) u- J此时运输车不能离开处理区域。
/ G$ Z: L; ~. h ^8 |由顶升装置将运输车连同工件一起上升至处理位。
! H& X+ G& p; o1 I/ Q$ G+ _0 U等处理完成后,运输车再次运送工件到卸载位。
% t. V. Z! t! y8 G0 n仍然由行车将工件吊运到储存区。/ w. }3 `. m" }0 u
问题1:. J. Z# Q6 t2 \2 G. ? }+ Y7 a
下面是一段顶升装置上升下降的代码:$ U7 J" Z# G% Q# l1 l
if (msgparam(1)==1), p! m6 Y" U0 s& G
{' e% Q* |- @& X$ J" [2 |
initkinematics(ki,sup);+ q( r, N# a0 u* `& }0 J
double time1=addkinematic(ki,0,0,fl,1,0,0,0,0,time(),KINEMATIC_TRAVEL);& O% }" r0 A4 v4 n
senddelayedmessage(zzc,time1-time(),current,1,0,0);1 i* a7 A8 p- g1 j$ i+ y* m
double tiup=time1-time();' a L* l0 v& p- K5 {
}. P# b" @9 \6 R- S7 O
else if(msgparam(1)==2)9 @5 F# P/ \+ p3 }$ I" c5 }: Y
{8 a8 H6 B; v9 b# f, n/ k. E
initkinematics(ki,sup);
: j4 e9 e& o- m) C& Z6 B, P- ^double time1=addkinematic(ki,0,0,-fl,1,0,0,0,0,time(),KINEMATIC_TRAVEL);
7 u b4 x+ T4 D1 Sdouble tidown=time1-time();
! A' ]3 N; u% U8 r}
3 n1 N: C0 O- R8 o* ~如何计算下降完成时间点-上升起始点的时间段?- N1 f1 ~! M$ a- t8 }
我现在是将这两个数值输入到标签中来进行计算。应该可以直接在代码中将它们提取出来吧。
# g) i& G- E) s3 T2 Q. S问题2:仿真速度对比中,按500~1000倍的速度模拟没有出现问题,上升下降后Z轴回到0点。( \/ D$ `" @* p* ]- V$ g& r% P
当仿真速度调到1000倍以上时,动作出现错误,一直上升或是下降,不回到起始位置?
' j5 V8 ]- Z y- Q" Q- Q" U问题3:如何在临时物体不进入处理器的情况下触发处理器的处理行为? |
|