|
本帖最后由 qiush1234 于 2011-9-20 16:14 编辑
; E" z) F! O2 M# K0 i( d- e: f- r. r4 v. Q/ H2 F( ]9 P
如题:最近在做一个课题时。遇到一些问题。6 M- V0 s$ t! j- _$ d0 `. Q5 \
行车将工件吊运到在等待中的运输车,运输车将工件送达处理区域。9 s6 g1 ]* x/ j" u) S3 P
此时运输车不能离开处理区域。
( L2 U, Z0 D' K# ~: N- v由顶升装置将运输车连同工件一起上升至处理位。
8 U2 t6 P0 H! P. z: l L# u5 ^等处理完成后,运输车再次运送工件到卸载位。
$ v+ w' D* ~0 q/ u$ O- I6 ^8 v仍然由行车将工件吊运到储存区。+ a( P% z8 |. I5 n b6 L) j
问题1:6 z) {) a4 D& E' z- X2 U
下面是一段顶升装置上升下降的代码: i. P" S0 Z) v- F
if (msgparam(1)==1)( X) \6 ~3 L: o; n! ]4 U, a
{
9 \$ k- F( q- {5 H8 sinitkinematics(ki,sup);1 V" J( F8 X: l# z9 x+ L/ j
double time1=addkinematic(ki,0,0,fl,1,0,0,0,0,time(),KINEMATIC_TRAVEL);8 t0 V+ v0 h" d; B
senddelayedmessage(zzc,time1-time(),current,1,0,0);
, [- D5 d: `) ^" B4 Z2 r* Zdouble tiup=time1-time();, N* [4 P' R* j4 M/ d) _
}1 |- ]( v6 |+ v% d( a* Z) q
else if(msgparam(1)==2)
8 [1 D, \, T0 w! ?$ x6 G3 a{
3 O$ }. A+ Q; S+ jinitkinematics(ki,sup);
( k6 |4 o6 ]& ~8 B1 a; [1 ~! idouble time1=addkinematic(ki,0,0,-fl,1,0,0,0,0,time(),KINEMATIC_TRAVEL);) e; e# ]% n b; [, {
double tidown=time1-time();
7 [0 f7 s2 \. y}
2 t( m) k) S$ j% \2 I如何计算下降完成时间点-上升起始点的时间段?: Z* k" _0 W2 z- W
我现在是将这两个数值输入到标签中来进行计算。应该可以直接在代码中将它们提取出来吧。2 N5 R9 V8 [ ^2 Z6 Y) }1 `
问题2:仿真速度对比中,按500~1000倍的速度模拟没有出现问题,上升下降后Z轴回到0点。0 `, _. B7 [& G
当仿真速度调到1000倍以上时,动作出现错误,一直上升或是下降,不回到起始位置?
# D8 Y' L& @4 ^问题3:如何在临时物体不进入处理器的情况下触发处理器的处理行为? |
|