GalilAxis.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375
  1. using Aitex.Core.RT.DataCenter;
  2. using Aitex.Core.RT.Event;
  3. using Aitex.Core.RT.Fsm;
  4. using Aitex.Core.RT.Log;
  5. using Aitex.Core.RT.Routine;
  6. using Aitex.Core.RT.SCCore;
  7. using Aitex.Core.Util;
  8. using MECF.Framework.Common.CommonData.PUF;
  9. using MECF.Framework.Common.TwinCat;
  10. using PunkHPX8_Core;
  11. using PunkHPX8_RT.Modules;
  12. using System;
  13. using System.Collections.Generic;
  14. using System.Data;
  15. using System.Linq;
  16. using System.Reflection;
  17. using System.Text;
  18. using System.Threading.Tasks;
  19. using PunkHPX8_RT.Devices.AXIS.Maxon;
  20. using MECF.Framework.Common.Device;
  21. using MECF.Framework.Common.Device.Galil;
  22. using static Mono.Security.X509.X520;
  23. namespace PunkHPX8_RT.Devices.AXIS.Galil
  24. {
  25. public class GalilAxis : JetAxisBase
  26. {
  27. #region 内部变量
  28. /// <summary>
  29. /// Home routine
  30. /// </summary>
  31. private GalilHomeRoutine _homeRoutine;
  32. /// <summary>
  33. /// 运动Routine
  34. /// </summary>
  35. private GalilProfilePositionRoutine _profilePositionRoutine;
  36. /// <summary>
  37. /// Switch On Routine
  38. /// </summary>
  39. private GalilSwitchOnRoutine _switchOnRoutine;
  40. /// <summary>
  41. /// Switch Off Routine
  42. /// </summary>
  43. private GalilSwitchOffRoutine _switchOffRoutine;
  44. /// <summary>
  45. /// Stop Position
  46. /// </summary>
  47. private GalilStopPositionRoutine _stopPositionRoutine;
  48. /// <summary>
  49. /// Galil共用对象
  50. /// </summary>
  51. private GalilCommonAxis _galilCommoAxis;
  52. #endregion
  53. /// <summary>
  54. /// 构造函数
  55. /// </summary>
  56. /// <param name="Module"></param>
  57. public GalilAxis(string module, string name) : base(module, name)
  58. {
  59. }
  60. /// <summary>
  61. /// 初始化参数
  62. /// </summary>
  63. protected override void InitializeParameter()
  64. {
  65. _accelerationRatio = 1;
  66. _speedRatio = 1;
  67. _galilCommoAxis = new GalilCommonAxis(Module, Name,this);
  68. }
  69. /// <summary>
  70. /// 初始化Routine
  71. /// </summary>
  72. protected override void InitializeRoutine()
  73. {
  74. _homeRoutine = new GalilHomeRoutine($"{Module}.{Name}", this,_galilCommoAxis);
  75. _profilePositionRoutine = new GalilProfilePositionRoutine($"{Module}.{Name}", this, _galilCommoAxis);
  76. _switchOnRoutine = new GalilSwitchOnRoutine($"{Module}.{Name}", this, _galilCommoAxis);
  77. _switchOffRoutine = new GalilSwitchOffRoutine($"{Module}.{Name}", this,_galilCommoAxis);
  78. _stopPositionRoutine = new GalilStopPositionRoutine($"{Module}.{Name}", this, _galilCommoAxis);
  79. }
  80. /// <summary>
  81. /// 中止操作
  82. /// </summary>
  83. /// <param name="cmd"></param>
  84. /// <param name="args"></param>
  85. /// <returns></returns>
  86. public override bool StopPositionOperation()
  87. {
  88. if (_profilePositionRoutine.Monitor() == RState.Running)
  89. {
  90. _profilePositionRoutine.Abort();
  91. }
  92. _status = _stopPositionRoutine.Start();
  93. _currentOperation = MotionOperation.StopPosition;
  94. return true;
  95. }
  96. /// <summary>
  97. /// 更新StatusWord
  98. /// </summary>
  99. /// <param name="status"></param>
  100. public override void UpdateStatusWord(ushort status)
  101. {
  102. }
  103. /// <summary>
  104. /// Home
  105. /// </summary>
  106. public override bool Home()
  107. {
  108. bool result = base.Home();
  109. if (!result)
  110. {
  111. return false;
  112. }
  113. MotionData.IsHomed = false;
  114. GalilAxisConfig galilAxisConfig=_axisConfig as GalilAxisConfig;
  115. _homeRoutine.Start(_homeTimeout,_axisConfig.HomingAcceleration,galilAxisConfig.HomingDeceleration,
  116. galilAxisConfig.HomingSpeed,galilAxisConfig.HomingOffset,galilAxisConfig.CNType);
  117. IsHomeSwitchedTriggered = false;
  118. return true;
  119. }
  120. /// <summary>
  121. /// 停止
  122. /// </summary>
  123. public override void Stop()
  124. {
  125. }
  126. /// <summary>
  127. /// SwitchOff
  128. /// </summary>
  129. public override bool SwitchOff()
  130. {
  131. if (_status == RState.Running)
  132. {
  133. EV.PostAlarmLog($"{Module}.{Name}", eEvent.ERR_AXIS, $"{Module}.{Name} current execute {_currentOperation},cannot switchoff");
  134. return false;
  135. }
  136. _currentOperation = MotionOperation.SwitchOff;
  137. _switchOffRoutine.Start();
  138. _status = RState.Running;
  139. return true;
  140. }
  141. /// <summary>
  142. /// SwitchOn
  143. /// </summary>
  144. public override bool SwitchOn()
  145. {
  146. if (_status == RState.Running)
  147. {
  148. EV.PostAlarmLog($"{Module}.{Name}", eEvent.ERR_AXIS, $"{Module}.{Name} current execute {_currentOperation},cannot SwitchOn");
  149. return false;
  150. }
  151. _currentOperation = MotionOperation.SwitchOn;
  152. _switchOnRoutine.Start();
  153. _status = RState.Running;
  154. return true;
  155. }
  156. /// <summary>
  157. /// 开始运动
  158. /// </summary>
  159. /// <returns></returns>
  160. public override bool StartMotion()
  161. {
  162. return _galilCommoAxis.WriteStartMotion();
  163. }
  164. /// <summary>
  165. /// 定时器
  166. /// </summary>
  167. /// <returns></returns>
  168. public override bool OnTimer()
  169. {
  170. if (_status == RState.Running)
  171. {
  172. if (_currentOperation == MotionOperation.Position)
  173. {
  174. RState state = _profilePositionRoutine.Monitor();
  175. if (state == RState.End)
  176. {
  177. _inTargetPosition = false;
  178. EndOperation();
  179. _status = RState.End;
  180. LOG.WriteLog(eEvent.INFO_AXIS, $"{Module}.{Name}", $"Position Complete,Current Position {MotionData.MotorPosition}");
  181. }
  182. else if (state == RState.Failed || state == RState.Timeout)
  183. {
  184. _inTargetPosition = false;
  185. EndOperation();
  186. _status = RState.Failed;
  187. LOG.WriteLog(eEvent.ERR_AXIS, $"{Module}.{Name}", $"Profile Position error {_profilePositionRoutine.ErrorMsg}");
  188. }
  189. }
  190. else if (_currentOperation == MotionOperation.Home)
  191. {
  192. RState state = _homeRoutine.Monitor();
  193. if (state == RState.End)
  194. {
  195. MotionData.IsHomed = true;
  196. IsHomed = true;
  197. EndOperation();
  198. _status = RState.End;
  199. }
  200. else if (state == RState.Failed || state == RState.Timeout)
  201. {
  202. EndOperation();
  203. _status = RState.Failed;
  204. LOG.WriteLog(eEvent.ERR_AXIS, $"{Module}.{Name}", "Home error");
  205. }
  206. }
  207. else if (_currentOperation == MotionOperation.SwitchOn)
  208. {
  209. RState state = _switchOnRoutine.Monitor();
  210. if (state == RState.End)
  211. {
  212. EndOperation();
  213. _status = RState.End;
  214. }
  215. else if (state == RState.Failed || state == RState.Timeout)
  216. {
  217. EndOperation();
  218. _status = RState.Failed;
  219. LOG.WriteLog(eEvent.ERR_AXIS, $"{Module}.{Name}", "Switch On error");
  220. }
  221. }
  222. else if (_currentOperation == MotionOperation.SwitchOff)
  223. {
  224. RState state = _switchOffRoutine.Monitor();
  225. if (state == RState.End)
  226. {
  227. EndOperation();
  228. _status = RState.End;
  229. }
  230. else if (state == RState.Failed || state == RState.Timeout)
  231. {
  232. EndOperation();
  233. _status = RState.Failed;
  234. LOG.WriteLog(eEvent.ERR_AXIS, $"{Module}.{Name}", "Switch Off error");
  235. }
  236. }
  237. else if (_currentOperation == MotionOperation.StopPosition)
  238. {
  239. RState state = _stopPositionRoutine.Monitor();
  240. if (state == RState.End)
  241. {
  242. EndOperation();
  243. _status = RState.End;
  244. }
  245. else if (state == RState.Failed || state == RState.Timeout)
  246. {
  247. EndOperation();
  248. _status = RState.Failed;
  249. LOG.WriteLog(eEvent.ERR_AXIS, $"{Module}.{Name}", "StopPosition error");
  250. }
  251. }
  252. }
  253. JudgeRunMonitor();
  254. return true;
  255. }
  256. /// <summary>
  257. /// 位置
  258. /// </summary>
  259. /// <param name="targetPoint"></param>
  260. public override bool ProfilePosition(int targetPoint, int profileVelocity, int profileAcceleration, int profileDeceleration, bool judgeTorqueLimit = true)
  261. {
  262. if (_status == RState.Running)
  263. {
  264. LOG.WriteLog(eEvent.WARN_AXIS, $"{Module}.{Name}", $"current execute {_currentOperation},cannot profile position");
  265. return false;
  266. }
  267. if (profileAcceleration == 0)
  268. {
  269. profileAcceleration = _profileAcceleration;
  270. }
  271. if (profileDeceleration == 0)
  272. {
  273. profileDeceleration = _profileDeceleration;
  274. }
  275. _status = _profilePositionRoutine.Start(targetPoint, profileVelocity, profileAcceleration, profileDeceleration, judgeTorqueLimit);
  276. _currentOperation = MotionOperation.Position;
  277. _inTargetPosition = false;
  278. return true;
  279. }
  280. /// <summary>
  281. /// 改变速度
  282. /// </summary>
  283. /// <param name="speed"></param>
  284. /// <returns></returns>
  285. public override bool ChangeSpeed(int speed)
  286. {
  287. return _galilCommoAxis.WriteSpeed(speed);
  288. }
  289. /// <summary>
  290. /// 改变速度加速度
  291. /// </summary>
  292. /// <param name="speed"></param>
  293. /// <returns></returns>
  294. public override bool ChangeSpeedAcceleration(int speed, int acceleration, int deceleration)
  295. {
  296. bool result = _galilCommoAxis.WriteSpeed(speed);
  297. if (result)
  298. {
  299. result = _galilCommoAxis.WriteAcceleration(acceleration);
  300. if (result)
  301. {
  302. result = _galilCommoAxis.WriteDeceleration(deceleration);
  303. }
  304. }
  305. return result;
  306. }
  307. /// <summary>
  308. /// KeyDown事件
  309. /// </summary>
  310. /// <param name="arg"></param>
  311. /// <param name="value"></param>
  312. protected override void AxisKeyDown(string arg, double value)
  313. {
  314. switch (arg)
  315. {
  316. case PROFILE_VELOCITY:
  317. _profileVelocity = CalculateMultiplySpeedRatio(CalculateValueMultiplyScale(value));
  318. _commandMotionData.FileProfileVelocity = value;
  319. BeckhoffAxisManager.Instance.WriteVariableValue($"{Module}.{Name}.{arg}", _profileVelocity);
  320. break;
  321. case PROFILE_ACCEL:
  322. _profileAcceleration = CalculateDivideAccelerationRatio(CalculateValueMultiplyScale(value));
  323. _commandMotionData.FileAcceleration = value;
  324. BeckhoffAxisManager.Instance.WriteVariableValue($"{Module}.{Name}.{arg}", _profileAcceleration);
  325. break;
  326. case PROFILE_DECEL:
  327. _profileDeceleration = CalculateDivideAccelerationRatio(CalculateValueMultiplyScale(value));
  328. _commandMotionData.FileDeceleration = value;
  329. BeckhoffAxisManager.Instance.WriteVariableValue($"{Module}.{Name}.{arg}", _profileDeceleration);
  330. break;
  331. case HOMING_VELOCITY:
  332. _profileHomingVelocity = CalculateMultiplySpeedRatio(CalculateValueMultiplyScale(value));
  333. _commandMotionData.FileHomingVelocity = value;
  334. TwincatCoeManager.Instance.WriteVariableValue($"{Module}.{Name}", arg, _profileHomingVelocity);
  335. break;
  336. case HOMING_VELOCITY_SLOW:
  337. _profileHomingVelocitySlow = CalculateMultiplySpeedRatio(CalculateValueMultiplyScale(value));
  338. _commandMotionData.FileHomingVelocitySlow = value;
  339. TwincatCoeManager.Instance.WriteVariableValue($"{Module}.{Name}", arg, _profileHomingVelocitySlow);
  340. break;
  341. case HOMING_ACCEL:
  342. _profileHomingAccel = CalculateDivideAccelerationRatio(CalculateValueMultiplyScale(value));
  343. _commandMotionData.FileHomingAccel = value;
  344. TwincatCoeManager.Instance.WriteVariableValue($"{Module}.{Name}", arg, _profileHomingAccel);
  345. break;
  346. }
  347. }
  348. /// <summary>
  349. /// 初始化Axis配置
  350. /// </summary>
  351. /// <returns></returns>
  352. /// <exception cref="NotImplementedException"></exception>
  353. protected override AxisConfig InitializeAxisConfig()
  354. {
  355. return GalilControllerCfgManager.Instance.GetGalilAxisConfig(Module.ToString(), Name);
  356. }
  357. /// <summary>
  358. /// 订阅变量
  359. /// </summary>
  360. protected override void SubscriptionVariable()
  361. {
  362. _galilCommoAxis.SubscriptionVariable();
  363. }
  364. }
  365. }