Sic.Framework/MECF.Framework.RT.Equipment.../HardwareUnits/Robots/JEL/JELC500Flippe/JelC5000RobotFlippe.cs

1847 lines
84 KiB
C#
Raw Normal View History

2023-04-13 11:51:03 +08:00
using System;
using System.Collections.Generic;
using System.IO.Ports;
using System.Linq;
using System.Text;
using Aitex.Core.Common.DeviceData;
using Aitex.Core.RT.Device;
using Aitex.Core.RT.Device.Unit;
using Aitex.Core.RT.Event;
using Aitex.Core.RT.Log;
using Aitex.Core.RT.OperationCenter;
using Aitex.Core.RT.SCCore;
using Aitex.Core.Util;
using MECF.Framework.Common.Communications;
using MECF.Framework.Common.Device.Bases;
using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.Common;
using Newtonsoft.Json;
using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.Robots.RobotBase;
using MECF.Framework.Common.Equipment;
using MECF.Framework.Common.SubstrateTrackings;
using System.Threading;
using Aitex.Core.Common;
using Aitex.Core.RT.DataCenter;
using System.Text.RegularExpressions;
using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts;
using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.LoadPortBase;
using MECF.Framework.Common.CommonData;
using Aitex.Core.RT.IOCore;
namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.Robots.JEL
{
public class JelC5000RobotFlippe : RobotBaseDevice, IConnection
{
private int _bodyNumber;
private string _robotModel; //T-00902H
public int BodyNumber { get => _bodyNumber; }
private string _address = "";
public string Address { get => _address; }
private bool isSimulatorMode;
private string _scRoot;
private PeriodicJob _thread;
private JelC5000RobotFlippeConnection _connection;
private R_TRIG _trigError = new R_TRIG();
private R_TRIG _trigCommunicationError = new R_TRIG();
private R_TRIG _trigRetryConnect = new R_TRIG();
private R_TRIG _trigActionDone = new R_TRIG();
private LinkedList<HandlerBase> _lstMonitorHandler = new LinkedList<HandlerBase>();
private AOAccessor _aoBladeRegulator { get; set; }
private object _locker = new object();
private bool _enableLog;
public string PortName;
public bool IsConnected { get; }
public bool Connect()
{
return true;
}
private int _lowerArmWaferSensorIndex
{
get
{
if (SC.ContainsItem($"Robot.{RobotModuleName}.LowerArmWaferSensorIndex"))
return SC.GetValue<int>($"Robot.{RobotModuleName}.LowerArmWaferSensorIndex");
return 1;
}
}
public bool Disconnect()
{
return true;
}
public JelC5000RobotFlippe(string module, string name, string scRoot, AOAccessor aoBladeRegulator, string robotModel = "") : base(module, name)
{
_robotModel = robotModel;
isSimulatorMode = SC.ContainsItem("System.IsSimulatorMode") ? SC.GetValue<bool>("System.IsSimulatorMode") : false;
_scRoot = scRoot;
//base.Initialize();
ResetPropertiesAndResponses();
RegisterSpecialData();
_enableLog = SC.GetValue<bool>($"{_scRoot}.{Name}.EnableLogMessage");
_bodyNumber = SC.GetValue<int>($"{_scRoot}.{Name}.BodyNumber");
PortName = SC.GetStringValue($"{_scRoot}.{Name}.PortName");
_aoBladeRegulator = aoBladeRegulator;
_connection = new JelC5000RobotFlippeConnection(this,PortName);
_connection.EnableLog(_enableLog);
if (_connection.Connect())
{
EV.PostInfoLog(Module, $"{Module}.{Name} connected");
}
_thread = new PeriodicJob(100, OnTimer, $"{Module}.{Name} MonitorHandler", true);
}
#region Properties
public JelAxisStatus JelC5000RobotStatus { get; private set; }
public JelAxisStatus AxisStatus { get; private set; }
public float XAxisPostion { get; private set; }
public float ThetaAxisPostion { get; private set; }
public float YAxisPostion { get; private set; }
public float ZAxisPostion { get; private set; }
public Int32[] AData { get; private set; } = new Int32[1000];
public JelParameterData[] RobotParameters { get; private set; } = new JelParameterData[2000];
public string ReadBankNumber { get; private set; } = "";
public int ReadCassetNumber { get; private set; }
public int ReadSlotNumber { get; private set; }
public bool IsVacuumSensorON { get; private set; } = true;
public bool IsEchoBack { get; private set; }
public JelCommandStatus CurrentCompoundCommandStatus { get; set; }
public string StopPostionOfCompoundCommand { get; private set; }
public string[] MainRoutines { get; private set; } = new string[320];
public string[] SubRoutines { get; private set; } = new string[16];
public string CurrentReadRoutine { get; private set; }
public int HighSpeed { get; private set; }
public int LowSpeed { get; private set; }
public int DomainOfAccDec { get; private set; }
public int AccDecSpeed { get; private set; }
public int MagnificationOfFrequency { get; private set; }
public int PulsePostionOfManualSlowDown { get; private set; }
public int CurrentReadSpeedData { get; private set; }
public Int32 CurrentReadAData { get; private set; }
public Int32 ReadPosXAxisPostion { get; private set; }
public Int32 ReadPosYAxisPostion { get; private set; }
public Int32 ReadPosThetaAxisPostion { get; private set; }
public Int32 ReadPosZAxisPostion { get; private set; }
public float ReadParameterMin { get; private set; }
public float ReadParameterMax { get; private set; }
public float ReadParameterValue { get; private set; }
//Mapping Data
public float MappingFirstSlotPosition { get; private set; }
public float MappingTopSlotPostion { get; private set; }
public int MappingSlotsNumber { get; private set; }
public float MappingMinDetectWidth { get; private set; }
public float MappingMaxDetectWidth { get; private set; }
public float MappingGateWidth { get; private set; }
public float MappingStopPostion { get; private set; }
public float MappingSpeed { get; private set; }
public bool IsMappingSensorON { get; private set; }
public string MappingWaferResult { get; private set; } = string.Empty;
public string MappingWidthResult { get; private set; } = string.Empty;
public override bool Blade1Enable => true;
public override bool Blade2Enable => false;
private ModuleName LastTargeModule { get; set; }
#endregion
#region ParseHandler
public void ParseData(string command,string parameter,string data)
{
try
{
string datavalue = data.Replace($"${BodyNumber}", "").Replace("\r", "");
if(command == "SPA")
{
CurrentReadSpeedData = Convert.ToInt32(datavalue);
}
if (command == "") ParseRobotStatus(datavalue); // Read Robot Status
if (command == "6" || command == "6M") ParseRobotPostion(parameter, datavalue); //Read Postion Data
if (command == "A") // Read A data
{
int _index;
if (!int.TryParse(parameter.Replace("D", ""), out _index)) return;
AData[_index] = Convert.ToInt32(datavalue);
CurrentReadAData = Convert.ToInt32(datavalue);
}
if (command == "BC")
{
ReadBankNumber = datavalue;
}
if (command == "WCP")
{
string[] strvalues = datavalue.Split(',');
ReadCassetNumber = Convert.ToInt32(strvalues[0]);
ReadSlotNumber = Convert.ToInt32(strvalues[1]);
}
if (command == $"CS{_lowerArmWaferSensorIndex}")
{
IsVacuumSensorON = datavalue == "1";
}
if (command == "DTD")
{
int _index;
if (!int.TryParse(parameter, out _index)) return;
string[] paradata = datavalue.Split(',');
//if (paradata.Length < 3) return;
RobotParameters[_index].Value = paradata[0];
RobotParameters[_index].MinValue = paradata[1];
RobotParameters[_index].MaxValue = paradata[2];
}
if (command == "EE")
{
IsEchoBack = datavalue == "E";
}
if (command == "G")
{
if (datavalue == "0") CurrentCompoundCommandStatus = JelCommandStatus.NormalEnd;
if (datavalue == "1") CurrentCompoundCommandStatus = JelCommandStatus.InExecution;
if (datavalue == "P") CurrentCompoundCommandStatus = JelCommandStatus.InPause;
if (datavalue == "E") CurrentCompoundCommandStatus = JelCommandStatus.InError;
}
if (command == "GER")
{
LOG.Write("Compaund command stop postion:" + datavalue);
}
if (command == "IR")
{
int _index;
if (!int.TryParse(parameter, out _index)) return;
if (_index < 0 || _index > 319) return;
MainRoutines[_index] = datavalue;
CurrentReadRoutine = datavalue;
}
if (command == "IRS")
{
int _index = Convert.ToInt32(parameter, 16);
if (_index < 0 || _index > 15) return;
SubRoutines[_index] = datavalue;
CurrentReadRoutine = datavalue;
}
if (command == "O")
{
CurrentReadSpeedData = Convert.ToInt32(datavalue);
if (parameter == "H")
HighSpeed = Convert.ToInt32(datavalue);
if (parameter == "L")
LowSpeed = Convert.ToInt32(datavalue);
if (parameter == "S")
DomainOfAccDec = Convert.ToInt32(datavalue);
if (parameter == "G")
AccDecSpeed = Convert.ToInt32(datavalue);
if (parameter == "X")
MagnificationOfFrequency = Convert.ToInt32(datavalue);
if (parameter == "D")
PulsePostionOfManualSlowDown = Convert.ToInt32(datavalue);
}
if (command == "PSD")
{
string[] stradata = datavalue.Split(',');
ReadPosXAxisPostion = Convert.ToInt32(stradata[0].ToString());
ReadPosYAxisPostion = Convert.ToInt32(stradata[1].ToString());
ReadPosThetaAxisPostion = Convert.ToInt32(stradata[2].ToString());
ReadPosZAxisPostion = Convert.ToInt32(stradata[3].ToString());
}
if (command == "DTD")
{
string[] stradata = datavalue.Split(',');
ReadParameterValue = Convert.ToSingle(stradata[0].ToString());
ReadParameterMin = Convert.ToSingle(stradata[1].ToString());
ReadParameterMax = Convert.ToSingle(stradata[2].ToString());
}
if (command == "WLO") // Obtaining the postion data of mapping 1st slot detected
MappingFirstSlotPosition = Convert.ToSingle(datavalue);
if(command == "WHI")
MappingTopSlotPostion = Convert.ToSingle(datavalue);
if(command == "WFC")
MappingSlotsNumber = Convert.ToInt32(datavalue);
if(command == "WWN")
MappingMinDetectWidth = Convert.ToSingle(datavalue);
if(command == "WWM")
MappingMaxDetectWidth = Convert.ToSingle(datavalue);
if(command == "WWG")
MappingGateWidth = Convert.ToSingle(datavalue);
if(command == "WEND")
MappingStopPostion = Convert.ToSingle(datavalue);
if(command == "WSP")
MappingSpeed = Convert.ToSingle(datavalue);
if(command == "WFK")
{
MappingWaferResult = datavalue;
NotifySlotMapResult(CurrentInteractModule, datavalue.Replace(",", "").Replace("E", "?"));
}
if (command == "WFW")
MappingWidthResult = datavalue;
}
catch(Exception ex)
{
LOG.Write($"Parse {command}.{parameter??parameter} data {data} error:" + ex.ToString());
OnError($"Parse data error:{command}.{parameter ?? parameter} data {data}");
}
}
private void ParseRobotStatus(string data)
{
if (data.Length < 2) return;
int intRobostatus = Convert.ToInt16(data.ToArray()[0].ToString());
if (intRobostatus == 0)
JelC5000RobotStatus = (JelAxisStatus)Convert.ToInt16(data.ToArray()[0].ToString());
if((intRobostatus & 0x1) == 0x1)
{
JelC5000RobotStatus = JelAxisStatus.InOperation;
}
if ((intRobostatus & 0x2) == 0x2)
{
JelC5000RobotStatus = JelAxisStatus.SensorError;
OnError(JelC5000RobotStatus.ToString());
}
if ((intRobostatus & 0x4) == 0x4)
{
JelC5000RobotStatus = JelAxisStatus.SensorErrorOrStoppedByAlarm;
OnError(JelC5000RobotStatus.ToString());
}
if ((intRobostatus & 0x8) == 0x8)
{
JelC5000RobotStatus = JelAxisStatus.CommandError;
OnError(JelC5000RobotStatus.ToString());
}
if (data.ToArray()[1] == '0')
AxisStatus = JelAxisStatus.NormalEnd;
else
AxisStatus = JelAxisStatus.InOperation;
}
private void ParseRobotPostion(string axis,string data)
{
float _floatvalue;
if (!float.TryParse(data, out _floatvalue)) return;
if (axis == "1")
{
PositionAxis1 = _floatvalue;
}
if (axis == "2")
{
PositionAxis2 = _floatvalue;
}
if (axis == "3")
{
PositionAxis3 = _floatvalue;
}
if (axis == "4")
{
PositionAxis4 = _floatvalue;
}
if (axis == "X")
{
XAxisPostion = _floatvalue;
}
if (axis == "Y")
{
YAxisPostion = _floatvalue;
}
if (axis == "U")
{
ThetaAxisPostion = _floatvalue;
}
if (axis == "Z")
{
ZAxisPostion = _floatvalue;
}
}
#endregion
private bool OnTimer()
{
try
{
if (!_connection.IsConnected || _connection.IsCommunicationError)
{
lock (_locker)
{
_lstMonitorHandler.Clear();
}
_trigRetryConnect.CLK = !_connection.IsConnected;
if (_trigRetryConnect.Q)
{
_connection.SetPortAddress(SC.GetStringValue($"{_scRoot}.{Name}.PortName"));
if (!_connection.Connect())
{
EV.PostAlarmLog(Module, $"Can not connect with {_connection.Address}, {Module}.{Name}");
}
else
{
}
}
return true;
}
HandlerBase handler = null;
DateTime dtstart = DateTime.Now;
lock (_locker)
{
if(_lstMonitorHandler.Count > 0)
{
if (!_connection.IsBusy)
{
handler = _lstMonitorHandler.First.Value;
_connection.Execute(handler);
_lstMonitorHandler.RemoveFirst();
}
else
{
_connection.MonitorTimeout();
_trigCommunicationError.CLK = _connection.IsCommunicationError;
if (_trigCommunicationError.Q)
{
_lstMonitorHandler.Clear();
OnError($"{Module}.{Name} communication error, {_connection.LastCommunicationError}");
}
}
}
}
}
catch (Exception ex)
{
LOG.Write(ex);
}
return true;
}
private void RegisterSpecialData()
{
DATA.Subscribe($"{Module}.{Name}.CurrentReadRoutine", () => CurrentReadRoutine);
DATA.Subscribe($"{Module}.{Name}.CurrentReadSpeedData", () => CurrentReadSpeedData);
DATA.Subscribe($"{Module}.{Name}.CurrentReadAData", () => CurrentReadAData);
DATA.Subscribe($"{Module}.{Name}.IsVacuumSensorON", () => IsVacuumSensorON);
DATA.Subscribe($"{Module}.{Name}.JelC5000RobotStatus", () => JelC5000RobotStatus.ToString());
DATA.Subscribe($"{Module}.{Name}.AxisStatus", () => AxisStatus.ToString());
DATA.Subscribe($"{Module}.{Name}.CurrentCompoundCommandStatus", () => CurrentCompoundCommandStatus.ToString());
DATA.Subscribe($"{Module}.{Name}.ReadCassetNumber", () => ReadCassetNumber.ToString());
DATA.Subscribe($"{Module}.{Name}.ReadSlotNumber", () => ReadSlotNumber.ToString());
DATA.Subscribe($"{Module}.{Name}.ReadBankNumber", () => ReadBankNumber.ToString());
DATA.Subscribe($"{Module}.{Name}.ReadPosXAxisPostion", () => ReadPosXAxisPostion);
DATA.Subscribe($"{Module}.{Name}.ReadPosYAxisPostion", () => ReadPosYAxisPostion);
DATA.Subscribe($"{Module}.{Name}.ReadPosZAxisPostion", () => ReadPosZAxisPostion);
DATA.Subscribe($"{Module}.{Name}.ReadPosThetaAxisPostion", () => ReadPosThetaAxisPostion);
DATA.Subscribe($"{Module}.{Name}.ReadParameterMax", () => ReadParameterMax.ToString());
DATA.Subscribe($"{Module}.{Name}.ReadParameterMin", () => ReadParameterMin.ToString());
DATA.Subscribe($"{Module}.{Name}.ReadParameterValue", () => ReadParameterValue.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingFirstSlotPosition", () => MappingFirstSlotPosition.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingGateWidth", () => MappingGateWidth.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingMaxDetectWidth", () => MappingMaxDetectWidth.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingMinDetectWidth", () => MappingMinDetectWidth.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingSlotsNumber", () => MappingSlotsNumber.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingSpeed", () => MappingSpeed.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingStopPostion", () => MappingStopPostion.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingTopSlotPostion", () => MappingTopSlotPostion.ToString());
DATA.Subscribe($"{Module}.{Name}.IsMappingSensorON", () => IsMappingSensorON.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingWaferResult", () => MappingWaferResult.ToString());
DATA.Subscribe($"{Module}.{Name}.MappingWidthResult", () => MappingWidthResult.ToString());
DATA.Subscribe($"{Name}.RobotSpeed", () => CurrentReadSpeedData);
DATA.Subscribe($"{Name}.CurrentReadRoutine", () => CurrentReadRoutine);
DATA.Subscribe($"{Name}.CurrentReadSpeedData", () => CurrentReadSpeedData);
DATA.Subscribe($"{Name}.CurrentReadAData", () => CurrentReadAData);
DATA.Subscribe($"{Name}.IsVacuumSensorON", () => IsVacuumSensorON);
DATA.Subscribe($"{Name}.JelC5000RobotStatus", () => JelC5000RobotStatus.ToString());
DATA.Subscribe($"{Name}.AxisStatus", () => AxisStatus.ToString());
DATA.Subscribe($"{Name}.CurrentCompoundCommandStatus", () => CurrentCompoundCommandStatus.ToString());
DATA.Subscribe($"{Name}.ReadCassetNumber", () => ReadCassetNumber.ToString());
DATA.Subscribe($"{Name}.ReadSlotNumber", () => ReadSlotNumber.ToString());
DATA.Subscribe($"{Name}.ReadBankNumber", () => ReadBankNumber.ToString());
DATA.Subscribe($"{Name}.ReadPosXAxisPostion", () => ReadPosXAxisPostion.ToString());
DATA.Subscribe($"{Name}.ReadPosYAxisPostion", () => ReadPosYAxisPostion.ToString());
DATA.Subscribe($"{Name}.ReadPosZAxisPostion", () => ReadPosZAxisPostion.ToString());
DATA.Subscribe($"{Name}.ReadPosThetaAxisPostion", () => ReadPosThetaAxisPostion.ToString());
DATA.Subscribe($"{Name}.XAxisPostion", () => XAxisPostion.ToString());
DATA.Subscribe($"{Name}.YAxisPostion", () => YAxisPostion.ToString());
DATA.Subscribe($"{Name}.ZAxisPostion", () => ZAxisPostion.ToString());
DATA.Subscribe($"{Name}.ThetaAxisPostion", () => ThetaAxisPostion.ToString());
DATA.Subscribe($"{Name}.ReadParameterMax", () => ReadParameterMax.ToString());
DATA.Subscribe($"{Name}.ReadParameterMin", () => ReadParameterMin.ToString());
DATA.Subscribe($"{Name}.ReadParameterValue", () => ReadParameterValue.ToString());
DATA.Subscribe($"{Name}.MappingFirstSlotPosition", () => MappingFirstSlotPosition.ToString());
DATA.Subscribe($"{Name}.MappingGateWidth", () => MappingGateWidth.ToString());
DATA.Subscribe($"{Name}.MappingMaxDetectWidth", () => MappingMaxDetectWidth.ToString());
DATA.Subscribe($"{Name}.MappingMinDetectWidth", () => MappingMinDetectWidth.ToString());
DATA.Subscribe($"{Name}.MappingSlotsNumber", () => MappingSlotsNumber.ToString());
DATA.Subscribe($"{Name}.MappingSpeed", () => MappingSpeed.ToString());
DATA.Subscribe($"{Name}.MappingStopPostion", () => MappingStopPostion.ToString());
DATA.Subscribe($"{Name}.MappingTopSlotPostion", () => MappingTopSlotPostion.ToString());
DATA.Subscribe($"{Name}.IsMappingSensorON", () => IsMappingSensorON.ToString());
DATA.Subscribe($"{Name}.MappingWaferResult", () => MappingWaferResult.ToString());
DATA.Subscribe($"{Name}.MappingWidthResult", () => MappingWidthResult.ToString());
DATA.Subscribe($"{Name}.BladeRegulatorRatio", () => BladeRegulatorRatio);
OP.Subscribe(String.Format("{0}.{1}", Name, "FlippeTo0Degree"), (out string reason, int time, object[] param) =>
{
bool ret = ExecuteCommand(param);
if (ret)
{
reason = string.Format("{0} {1}", Name, "Execute command succesfully");
return true;
}
reason = $"{Name} execute failed";
return false;
});
}
private int BladeRegulatorRatio
{
get
{
if (_aoBladeRegulator == null)
return 0;
return (int)(_aoBladeRegulator.Value / 100);
}
}
private void ResetPropertiesAndResponses()
{
}
protected override bool fReset(object[] param)
{
_trigError.RST = true;
_connection.SetCommunicationError(false, "");
_trigCommunicationError.RST = true;
_enableLog = SC.GetValue<bool>($"{_scRoot}.{Name}.EnableLogMessage");
_connection.EnableLog(_enableLog);
_trigRetryConnect.RST = true;
_lstMonitorHandler.Clear();
//_lstMonitorHandler.Clear();
_connection.ForceClear();
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeRawCommandHandler(this, $"RD"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
}
return true;
}
protected override bool fMonitorReset(object[] param)
{
IsBusy = false;
if (JelC5000RobotStatus == JelAxisStatus.NormalEnd
&& (AxisStatus == JelAxisStatus.NormalEnd)
&& _lstMonitorHandler.Count == 0
&& !_connection.IsBusy)
{
IsBusy = false;
return true;
}
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
_connection.Execute(new JelC5000RobotFlippeReadHandler(this, ""));
return false;
}
protected override bool fStartMove(object[] param)
{
if (param.Length < 4) return false;
int axis,intdirect;
if (!int.TryParse(param[0].ToString(), out axis)) return false;
if (axis > 4 || axis < 0) return false;
if (!int.TryParse(param[1].ToString(), out intdirect)) return false;
if (intdirect > 1 || intdirect < 0) return false;
RobotMoveDirectionEnum direction = (RobotMoveDirectionEnum)Convert.ToInt16(param[1].ToString());
uint instance;
if (!uint.TryParse(param[2].ToString(), out instance)) return false;
if (instance > 8388607) instance = 8388607;
string movebasetype = Regex.Replace(param[3].ToString().Replace("", "(").Replace("", ")"), @"\([^\(]*\)", "");
if (movebasetype != "0" && movebasetype != "1") return false;
string commandstr = "";
if (movebasetype == "0") commandstr = "3";
if(movebasetype == "1")
{
if (direction == RobotMoveDirectionEnum.Fwd) commandstr = "4";
else commandstr = "5";
}
if (string.IsNullOrEmpty(commandstr)) return false;
string speedtype = string.Empty;
if (param.Length > 4)
speedtype = Regex.Replace(param[4].ToString().Replace("", "(").Replace("", ")"), @"\([^\(]*\)", "");
if (speedtype != "" && speedtype != "M" && speedtype != "L") return false;
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "2", instance.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeMoveHandler(this, commandstr + "M", axis.ToString() + speedtype));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
}
return true;
}
protected override bool fMonitorMoving(object[] param)
{
if (JelC5000RobotStatus == JelAxisStatus.NormalEnd
&& (AxisStatus == JelAxisStatus.NormalEnd)
&& _lstMonitorHandler.Count == 0
&& !_connection.IsBusy)
{
IsBusy = false;
return true;
}
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
_connection.Execute(new JelC5000RobotFlippeReadHandler(this, ""));
return false;
}
protected override bool fMonitorGoTo(object[] param)
{
if (JelC5000RobotStatus == JelAxisStatus.NormalEnd
&& (AxisStatus == JelAxisStatus.NormalEnd)
&& _lstMonitorHandler.Count == 0
&& !_connection.IsBusy)
{
IsBusy = false;
return true;
}
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
_connection.Execute(new JelC5000RobotFlippeReadHandler(this, ""));
return false;
}
protected override bool fStartInit(object[] param)
{
//string speedtype = string.Empty;
//if (param != null && param.Length >0)
// speedtype = Regex.Replace(param[0].ToString().Replace("", "(").Replace("", ")"), @"\([^\(]*\)", "");
//if (speedtype != "" && speedtype != "M" && speedtype != "L") return false;
_dtActionStart = DateTime.Now;
int compaundcmdNO = SC.GetValue<int>($"Robot.{Name}.InitCmdNO");
int Robotspeed = SC.GetValue<int>($"Robot.{Name}.RobotSpeed");
if (Robotspeed < 0)
Robotspeed = 0;
if (Robotspeed > 99)
Robotspeed = 99;
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeCompaundCommandHandler(this, compaundcmdNO.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, $"CS{_lowerArmWaferSensorIndex}"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "BC")); // Read bank number
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WCP")); // Read Cassette Number
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "1"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "2"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "3"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "4"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "X"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "Y"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "U"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "Z"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "SPA", Robotspeed.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "SPA"));
}
return true;
}
protected override bool fMonitorInit(object[] param)
{
IsBusy = false;
if (DateTime.Now - _dtActionStart > TimeSpan.FromSeconds(RobotCommandTimeout))
{
HandlerError("InitTimeout");
return true;
}
if (_lstMonitorHandler.Count ==0 && !_connection.IsBusy)
{
if (CurrentCompoundCommandStatus == JelCommandStatus.NormalEnd &&
JelC5000RobotStatus == JelAxisStatus.NormalEnd
&& AxisStatus == JelAxisStatus.NormalEnd)
{
Blade1Target = ModuleName.System;
Blade2Target = ModuleName.System;
CmdTarget = ModuleName.System;
LastTargeModule = ModuleName.System;
MoveInfo = new RobotMoveInfo()
{
Action = RobotAction.Picking,
ArmTarget = CmdRobotArm == RobotArmEnum.Lower ? RobotArm.ArmA : RobotArm.ArmB,
BladeTarget = BuildBladeTarget(),
};
if(IsVacuumSensorON && WaferManager.Instance.CheckNoWafer(RobotModuleName,0))
{
EV.PostAlarmLog("Robot", $"There's unknown wafer on {RobotModuleName}.");
WaferManager.Instance.CreateWafer(RobotModuleName, 0, WaferStatus.Normal);
}
if (!IsVacuumSensorON && WaferManager.Instance.CheckHasWafer(RobotModuleName, 0))
{
EV.PostAlarmLog("Robot", $"There's a wafer on {RobotModuleName} but robot didn't detect.");
}
return true;
}
if (CurrentCompoundCommandStatus != JelCommandStatus.NormalEnd)
{
if (CurrentCompoundCommandStatus == JelCommandStatus.InError)
{
OnError("Init Compaund command execution error");
return false;
}
}
}
return false;
}
protected override bool fStartReadData(object[] param)
{
if(param.Length <1) return false;
string readcommand = param[0].ToString();
switch(readcommand)
{
case "CurrentStatus":
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, $"CS{_lowerArmWaferSensorIndex}"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G")); // Read out the compaund command status
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "BC")); // Read bank number
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WCP")); // Read Cassette Number
}
break;
case "CurrentPositionData":
lock(_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "1"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "2"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "3"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "4"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "X"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "Y"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "U"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "6", "Z"));
}
break;
case "CompaundCommand":
if (param.Length < 3) return false;
string routineselction = param[1].ToString();
if(routineselction == "MainRoutine")
{
int routineno;
if (!int.TryParse(param[2].ToString(), out routineno)) return false;
if (routineno > 319 || routineno < 1) return false;
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "IR",routineno.ToString().PadLeft(3,'0')));
}
if (routineselction == "SubRoutine")
{
char routineno;
if (!char.TryParse(param[2].ToString(), out routineno)) return false;
if (routineno > 'F' || routineno < 1) return false;
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "IRS", routineno.ToString()));
}
break;
case "RobotSpeed":
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "SPA"));
break;
case "AData":
if (param.Length < 2) return false;
int datano;
if (!int.TryParse(param[1].ToString(), out datano)) return false;
if (datano < 0 || datano > 999) return false;
lock(_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "A", datano.ToString("D3")+"D"));
}
break;
case "EPData":
if (param.Length < 2) return false;
if (param[1].ToString() == "AData")
{
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeRawCommandHandler (this, $"AL"));
}
}
break;
case "PositionData":
if (param.Length < 2) return false;
int posNO;
if (!int.TryParse(param[1].ToString(), out posNO)) return false;
if (posNO > 999 || posNO < 0) return false;
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "PSD", posNO.ToString("D3")));
}
break;
case "RobotParameter":
if (param.Length < 2) return false;
uint parano;
if(!uint.TryParse(param[1].ToString(), out parano)) return false;
lock(_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "DTD", parano.ToString()));
}
break;
case "MappingData":
lock(_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WLO"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WHI"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WFC"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WWN"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WWM"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WWG"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WEND"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WSP"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WFK"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WFW"));
}
break;
}
return true;
}
protected override bool fMonitorReadData(object[] param)
{
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
{
IsBusy = false;
return true;
}
return false;
}
protected override bool fStartSetParameters(object[] param)
{
try
{
string setcommand = param[0].ToString();
switch (setcommand)
{
case "CompaundCommand":
if (param.Length < 4) return false;
string routineselction = param[1].ToString();
if (routineselction == "MainRoutine")
{
int routineno;
if (!int.TryParse(param[2].ToString(), out routineno)) return false;
if (routineno > 319 || routineno < 1) return false;
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "I", routineno.ToString().PadLeft(3, '0')));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeRawCommandHandler(this, param[3].ToString()));
}
if (routineselction == "SubRoutine")
{
char routineno;
if (!char.TryParse(param[2].ToString(), out routineno)) return false;
if (routineno > 'F' || routineno < 1) return false;
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "IS", routineno.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeRawCommandHandler(this, param[3].ToString()));
}
break;
case "RobotSpeed":
//if (param.Length < 3) return false;
//string speedtype = param[1].ToString().Split('(')[0];
//Int32 speedvalue;
//if (!Int32.TryParse(param[2].ToString(), out speedvalue)) return false;
//_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "O" + speedtype, speedvalue.ToString().PadLeft(5, '0')));
Int32 speedvalue;
if (!Int32.TryParse(param[2].ToString(), out speedvalue)) return false;
if(SC.ContainsItem($"Robot.{RobotModuleName}.RobotSpeed"))
{
SC.SetItemValue($"Robot.{RobotModuleName}.RobotSpeed", speedvalue);
}
if (speedvalue < 0)
speedvalue = 0;
if (speedvalue > 99)
speedvalue = 99;
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "SPA" , speedvalue.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "SPA"));
break;
case "AData":
if (param.Length < 3) return false;
Int32 datano, datavalue;
if (!Int32.TryParse(param[1].ToString(), out datano)) return false;
if (!Int32.TryParse(param[2].ToString(), out datavalue)) return false;
if (datano > 999 || datano < 0) return false;
if (datavalue > 8388607 || datavalue < -8388608) return false;
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "A", datano.ToString("D3") + datavalue.ToString()));
}
break;
case "EPData":
if (param.Length < 2) return false;
if (param[1].ToString() == "AData")
{
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "AW"));
}
}
break;
case "PositionData":
if (param.Length < 6) return false;
Int32 posno, rightarmpos, thetapos, leftarmpos, zpos;
if (!Int32.TryParse(param[1].ToString(), out posno)) return false;
if (!Int32.TryParse(param[2].ToString(), out rightarmpos)) return false;
if (!Int32.TryParse(param[3].ToString(), out thetapos)) return false;
if (!Int32.TryParse(param[4].ToString(), out leftarmpos)) return false;
if (!Int32.TryParse(param[5].ToString(), out zpos)) return false;
if (posno > 999 || posno < 0) return false;
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "PS",
$"{posno.ToString("D3")}{rightarmpos},{thetapos},{leftarmpos},{zpos}"));
}
return true;
case "CurrentPositionData":
Int32 currentpos = Int32.Parse(param[1].ToString());
if (currentpos > 999 || currentpos < 0) return false;
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "PS",
$"{currentpos.ToString("D3")}"));
}
break;
case "RobotParameter":
if (param.Length < 3) return false;
Int32 parano, paravalue;
if (!Int32.TryParse(param[1].ToString(), out parano)) return false;
if (!Int32.TryParse(param[2].ToString(), out paravalue)) return false;
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "DTSVAL", $"{parano},{paravalue}"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "DW"));
}
break;
case "MappingData":
lock(_locker)
{
if (!string.IsNullOrEmpty(param[1].ToString()))
{
float tempvalue = float.Parse(param[1].ToString());
string strtempvalue;
if (tempvalue <0)
{
strtempvalue = "-" +(-tempvalue).ToString().PadLeft(7, '0');
}
else
strtempvalue = tempvalue.ToString().PadLeft(8, '0');
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WLO",strtempvalue));
}
if (!string.IsNullOrEmpty(param[2].ToString()))
{
float tempvalue = float.Parse(param[2].ToString());
string strtempvalue;
if (tempvalue < 0)
{
strtempvalue = "-" + (-tempvalue).ToString().PadLeft(7, '0');
}
else
strtempvalue = tempvalue.ToString().PadLeft(8, '0');
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WHI",strtempvalue));
}
if (!string.IsNullOrEmpty(param[3].ToString()))
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WFC",
(Convert.ToInt16(param[3].ToString()).ToString("D2"))));
if (!string.IsNullOrEmpty(param[4].ToString()))
{
float tempvalue = float.Parse(param[4].ToString());
string strtempvalue;
if (tempvalue < 0)
{
strtempvalue = "-" + (-tempvalue).ToString().PadLeft(7, '0');
}
else
strtempvalue = tempvalue.ToString().PadLeft(8, '0');
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WWN", strtempvalue));
}
if (!string.IsNullOrEmpty(param[5].ToString()))
{
float tempvalue = float.Parse(param[5].ToString());
string strtempvalue;
if (tempvalue < 0)
{
strtempvalue = "-" + (-tempvalue).ToString().PadLeft(7, '0');
}
else
strtempvalue = tempvalue.ToString().PadLeft(8, '0');
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WWM", strtempvalue));
}
if (!string.IsNullOrEmpty(param[6].ToString()))
{
float tempvalue = float.Parse(param[6].ToString());
string strtempvalue;
if (tempvalue < 0)
{
strtempvalue = "-" + (-tempvalue).ToString().PadLeft(7, '0');
}
else
strtempvalue = tempvalue.ToString().PadLeft(8, '0');
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WWG", strtempvalue));
}
if (!string.IsNullOrEmpty(param[7].ToString()))
{
float tempvalue = float.Parse(param[7].ToString());
string strtempvalue;
if (tempvalue < 0)
{
strtempvalue = "-" + (-tempvalue).ToString().PadLeft(7, '0');
}
else
strtempvalue = tempvalue.ToString().PadLeft(8, '0');
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WEND", strtempvalue));
}
if (!string.IsNullOrEmpty(param[8].ToString()))
{
float tempvalue = float.Parse(param[8].ToString());
string strtempvalue;
if (tempvalue < 0)
{
strtempvalue = "-" + (-tempvalue).ToString().PadLeft(7, '0');
}
else
strtempvalue = tempvalue.ToString().PadLeft(8, '0');
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WSP", strtempvalue));
}
}
break;
case "MappingCommand":
lock(_locker)
{
//_lstMonitorHandler.AddLast(new JelC5000RobotMoveHandler(this, "WFS"));
//_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WFK"));
//_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WFW"));
}
break;
case "BankNumber":
lock (_locker)
{
if (param.Length > 1 && !string.IsNullOrEmpty(param[1].ToString()))
{
int bankno = Convert.ToInt16(param[1].ToString());
if (bankno <= 15 && bankno >= 0)
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "BC", bankno.ToString("X")));
}
if (param.Length > 2 && !string.IsNullOrEmpty(param[2].ToString()))
{
int cassetteno = Convert.ToInt16(param[2].ToString());
if (cassetteno <=5 && cassetteno <= 1)
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WCP", cassetteno.ToString()));
}
if (param.Length > 3 && !string.IsNullOrEmpty(param[3].ToString()))
{
int slotno = Convert.ToInt16(param[3].ToString());
if (slotno <= 25 && slotno >= 1)
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WCD", slotno.ToString()));
}
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "BC"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WCP"));
}
break;
}
}
catch (Exception )
{
string reason = "";
if(param!=null)
{
foreach(var para in param)
{
reason += para.ToString() + ",";
}
}
EV.PostAlarmLog(Name, "Set command parameter valid:" + reason);
return false;
}
return true;
}
protected override bool fMonitorSetParamter(object[] param)
{
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
{
IsBusy = false;
return true;
}
return base.fMonitorSetParamter(param);
}
public override bool IsReady()
{
return RobotState == RobotStateEnum.Idle && !IsBusy;
}
protected override bool fClear(object[] param)
{
return true;
}
protected override bool fStartTransferWafer(object[] param)
{
return false;
}
protected override bool fStartUnGrip(object[] param)
{
if (param == null || param.Length < 1) return false;
RobotArmEnum arm = (RobotArmEnum)((int)param[0]);
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "DS", "10"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
}
return true;
}
protected override bool fMonitorUnGrip(object[] param)
{
IsBusy = false;
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
{
if (JelC5000RobotStatus != JelAxisStatus.NormalEnd
|| AxisStatus != JelAxisStatus.NormalEnd)
{
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, $"CS{_lowerArmWaferSensorIndex}"));
}
return false;
}
RobotArmEnum arm = (RobotArmEnum)((int)CurrentParamter[0]);
//if(IsVacuumSensorON)
// HandlerError("UnGrip wafer failed!");
IsBusy = false;
return true;
}
return false;
}
protected override bool fStartGrip(object[] param)
{
if(param == null || param.Length <1) return false;
RobotArmEnum arm = (RobotArmEnum)((int)param[0]);
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "DS", "11"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
}
return true;
}
protected override bool fMonitorGrip(object[] param)
{
IsBusy = false;
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
{
if (JelC5000RobotStatus != JelAxisStatus.NormalEnd
|| AxisStatus != JelAxisStatus.NormalEnd)
{
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, $"CS{_lowerArmWaferSensorIndex}"));
}
return false;
}
//if (!IsVacuumSensorON)
// HandlerError("UnGrip wafer failed!");
IsBusy = false;
return true;
}
return false;
}
protected override bool fStop(object[] param)
{
IsBusy = false;
_lstMonitorHandler.Clear();
_connection.ForceClear();
_connection.Execute(new JelC5000RobotFlippeSetHandler(this, "S"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "GE"));
return ReadStatus();
}
protected override bool fStartGoTo(object[] param)
{
return false;
}
protected override bool fStartMapWafer(object[] param)
{
IsBusy = false;
try
{
_dtActionStart = DateTime.Now;
ModuleName tempmodule = (ModuleName)Enum.Parse(typeof(ModuleName), param[0].ToString());
int carrierindex = 0;
if (ModuleHelper.IsLoadPort(tempmodule))
{
LoadPortBaseDevice lp = DEVICE.GetDevice<LoadPortBaseDevice>(tempmodule.ToString());
carrierindex = lp.InfoPadCarrierIndex;
}
else
{
WaferSize wz = WaferManager.Instance.GetWaferSize(tempmodule, 0);
if (wz == WaferSize.WS12) carrierindex = 12;
if (wz == WaferSize.WS8) carrierindex = 8;
if (wz == WaferSize.WS6) carrierindex = 6;
if (wz == WaferSize.WS4) carrierindex = 4;
if (wz == WaferSize.WS3) carrierindex = 3;
}
int bankno = SC.GetValue<int>($"CarrierInfo.{tempmodule}BankNumber{carrierindex}");
int cassetteNO = SC.GetValue<int>($"CarrierInfo.{tempmodule}CassetteNumber{carrierindex}");
int compaundcmdNO = SC.GetValue<int>($"Robot.{Name}.MapCmdNO");
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "BC", bankno.ToString("X")));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WCP", cassetteNO.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WCD", "1"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "BC"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WCP"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeRawCommandHandler(this, $"RD"));
}
DateTime readstarttime = DateTime.Now;
while (_lstMonitorHandler.Count != 0 || _connection.IsBusy)
{
if (DateTime.Now - readstarttime > TimeSpan.FromSeconds(20))
{
OnError("Set Timeout.");
return false;
}
}
if (ReadBankNumber != bankno.ToString("X") || cassetteNO != ReadCassetNumber)
{
OnError("Set data failed.");
return false;
}
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeCompaundCommandHandler(this, compaundcmdNO.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WFK"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WFW"));
}
}
catch (Exception ex)
{
string reason = "";
if (param != null)
foreach (var strpara in param)
reason += strpara.ToString();
OnError($"{Name} Map command valid:" + reason);
LOG.Write(ex);
return false;
}
return true;
}
protected override bool fMonitorMap(object[] param)
{
return true;
//if(_lstMonitorHandler.Count == 0 && _lstMoveHandler.Count == 0 && !_connection.IsBusy)
//{
// IsBusy = false;
// return true;
//}
//return false;
}
protected override bool fStartSwapWafer(object[] param)
{
return false;
}
private DateTime _dtActionStart;
protected override bool fMonitorSwap(object[] param)
{
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
{
if (CurrentCompoundCommandStatus == JelCommandStatus.NormalEnd)
{
RobotArmEnum arm = (RobotArmEnum)CurrentParamter[0];
ModuleName sourcemodule;
if (!Enum.TryParse(CurrentParamter[1].ToString(), out sourcemodule)) return false;
int Sourceslotindex;
if (!int.TryParse(CurrentParamter[2].ToString(), out Sourceslotindex)) return false;
if (arm == RobotArmEnum.Lower)
{
WaferManager.Instance.WaferMoved(sourcemodule, Sourceslotindex, RobotModuleName, 0);
WaferManager.Instance.WaferMoved(RobotModuleName, 1, sourcemodule, Sourceslotindex);
}
if (arm == RobotArmEnum.Upper)
{
WaferManager.Instance.WaferMoved(sourcemodule, Sourceslotindex, RobotModuleName, 1);
WaferManager.Instance.WaferMoved(RobotModuleName, 0, sourcemodule, Sourceslotindex);
}
if (arm == RobotArmEnum.Both)
{
}
IsBusy = false;
return true;
}
if (CurrentCompoundCommandStatus == JelCommandStatus.InExecution ||
CurrentCompoundCommandStatus == JelCommandStatus.None)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
}
if (CurrentCompoundCommandStatus == JelCommandStatus.InError)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "GER"));
OnError("Compaund Comand execution failed");
}
}
return false;
}
protected override bool fStartPlaceWafer(object[] param)
{
_dtActionStart = DateTime.Now;
try
{
RobotArmEnum arm = (RobotArmEnum)param[0];
ModuleName tempmodule = (ModuleName)Enum.Parse(typeof(ModuleName), param[1].ToString());
int slotindex = int.Parse(param[2].ToString());
//JelC5000RobotArm jelarm = (JelC5000RobotArm)(int)arm;
var wz = WaferManager.Instance.GetWaferSize(RobotModuleName, arm == RobotArmEnum.Both ? 0 : (int)arm);
int wzindex = 0;
if (wz == WaferSize.WS12) wzindex = 12;
if (wz == WaferSize.WS8) wzindex = 8;
if (wz == WaferSize.WS6) wzindex = 6;
if (wz == WaferSize.WS5) wzindex = 5;
if (wz == WaferSize.WS4) wzindex = 4;
if (wz == WaferSize.WS3) wzindex = 3;
if (wz == WaferSize.WS2) wzindex = 2;
if (ModuleHelper.IsLoadPort(tempmodule))
{
var lp = DEVICE.GetDevice<LoadPortBaseDevice>(tempmodule.ToString());
if (lp != null)
lp.NoteTransferStart();
wzindex = DEVICE.GetDevice<LoadPortBaseDevice>(tempmodule.ToString()).InfoPadCarrierIndex;
}
int bankno = SC.GetValue<int>($"CarrierInfo.{tempmodule}BankNumber{wzindex}");
int cassetteNO = SC.GetValue<int>($"CarrierInfo.{tempmodule}CassetteNumber{wzindex}");
int compaundcmdNO = SC.GetValue<int>($"Robot.{Name}.PlaceCmdNO");
int compaundcmdNOforSafe = SC.GetValue<int>($"Robot.{Name}.SafeCmdNO");
if (!ModuleHelper.IsLoadPort(tempmodule) && Blade1ActionPosture == BladePostureEnum.Degree180)
{
bankno = SC.GetValue<int>($"CarrierInfo.Over{tempmodule}BankNumber{wzindex}");
cassetteNO = SC.GetValue<int>($"CarrierInfo.Over{tempmodule}CassetteNumber{wzindex}");
compaundcmdNO = SC.GetValue<int>($"Robot.{Name}.OverPlaceCmdNO");
compaundcmdNOforSafe = SC.GetValue<int>($"Robot.{Name}.SafeCmdNO");
}
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "BC"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WCP"));
}
DateTime readstarttime = DateTime.Now;
while (_lstMonitorHandler.Count != 0 || _connection.IsBusy)
{
if (DateTime.Now - readstarttime > TimeSpan.FromSeconds(10))
{
OnError("Read bankno and cassette no for place Timeout.");
return false;
}
}
lock (_locker)
{
if(LastTargeModule != tempmodule) //(ReadBankNumber != bankno.ToString("X") || cassetteNO != ReadCassetNumber)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeCompaundCommandHandler(this, compaundcmdNOforSafe.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
}
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "BC", bankno.ToString("X")));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WCP", cassetteNO.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WCD", (slotindex+1).ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "BC"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WCP"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeCompaundCommandHandler(this, compaundcmdNO.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, $"CS{_lowerArmWaferSensorIndex}"));
}
Blade1Target = tempmodule;
Blade2Target = tempmodule;
CmdTarget = tempmodule;
LastTargeModule = tempmodule;
MoveInfo = new RobotMoveInfo()
{
Action = RobotAction.Placing,
ArmTarget = RobotArm.Both, // CmdRobotArm == RobotArmEnum.Lower ? RobotArm.ArmA : RobotArm.ArmB,
BladeTarget = BuildBladeTarget(),
};
}
catch (Exception ex)
{
string reason = "";
if (param != null)
foreach (var strpara in param)
reason += strpara.ToString();
OnError($"{Name} Pick command valid:" + reason);
LOG.Write(ex);
return false;
}
return true;
}
protected override bool fStartPickWafer(object[] param)
{
_dtActionStart = DateTime.Now;
try
{
//RobotArmEnum arm = (RobotArmEnum)param[0];
ModuleName tempmodule = (ModuleName)Enum.Parse(typeof(ModuleName), param[1].ToString());
int slotindex = int.Parse(param[2].ToString());
//JelC5000RobotArm jelarm = (JelC5000RobotArm)(int)arm;
var wz = WaferManager.Instance.GetWaferSize(tempmodule, slotindex);
int wzindex = 0;
if (wz == WaferSize.WS12) wzindex = 12;
if (wz == WaferSize.WS8) wzindex = 8;
if (wz == WaferSize.WS6) wzindex = 6;
if (wz == WaferSize.WS5) wzindex = 5;
if (wz == WaferSize.WS4) wzindex = 4;
if (wz == WaferSize.WS3) wzindex = 3;
if (wz == WaferSize.WS2) wzindex = 2;
if (ModuleHelper.IsLoadPort(tempmodule))
{
var lp = DEVICE.GetDevice<LoadPortBaseDevice>(tempmodule.ToString());
if (lp != null && !lp.NoteTransferStart())
return false;
wzindex = lp.InfoPadCarrierIndex;
}
int bankno = SC.GetValue<int>($"CarrierInfo.{tempmodule}BankNumber{wzindex}");
int cassetteNO = SC.GetValue<int>($"CarrierInfo.{tempmodule}CassetteNumber{wzindex}");
int compaundcmdNO = SC.GetValue<int>($"Robot.{Name}.PickCmdNO");
int compaundcmdNOforSafe = SC.GetValue<int>($"Robot.{Name}.SafeCmdNO");
if(!ModuleHelper.IsLoadPort(tempmodule) && Blade1ActionPosture == BladePostureEnum.Degree180)
{
bankno = SC.GetValue<int>($"CarrierInfo.Over{tempmodule}BankNumber{wzindex}");
cassetteNO = SC.GetValue<int>($"CarrierInfo.Over{tempmodule}CassetteNumber{wzindex}");
compaundcmdNO = SC.GetValue<int>($"Robot.{Name}.OverPickCmdNO");
compaundcmdNOforSafe = SC.GetValue<int>($"Robot.{Name}.SafeCmdNO");
}
lock (_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "BC"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WCP"));
}
DateTime readstarttime = DateTime.Now;
while (_lstMonitorHandler.Count != 0 || _connection.IsBusy)
{
if (DateTime.Now - readstarttime > TimeSpan.FromSeconds(20))
{
OnError("Read bankno and cassette no for pick Timeout.");
return false;
}
}
lock (_locker)
{
if(LastTargeModule != tempmodule)//(ReadBankNumber != bankno.ToString("X") || cassetteNO != ReadCassetNumber)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeCompaundCommandHandler(this, compaundcmdNOforSafe.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
}
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "BC", bankno.ToString("X")));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WCP", cassetteNO.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeSetHandler(this, "WCD", (slotindex+1).ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "BC"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "WCP"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeCompaundCommandHandler(this,compaundcmdNO.ToString()));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, $"CS{_lowerArmWaferSensorIndex}"));
}
Blade1Target = tempmodule;
Blade2Target = tempmodule;
CmdTarget = tempmodule;
LastTargeModule = tempmodule;
MoveInfo = new RobotMoveInfo()
{
Action = RobotAction.Picking,
ArmTarget = CmdRobotArm == RobotArmEnum.Lower ? RobotArm.ArmA : RobotArm.ArmB,
BladeTarget = BuildBladeTarget(),
};
}
catch (Exception ex)
{
string reason = "";
if (param != null)
{
foreach (var strpara in param)
reason += strpara.ToString();
}
LOG.Write(ex);
OnError($"{Name} Pick command valid:" + reason);
return false;
}
return true;
}
protected override bool fMonitorPlace(object[] param)
{
if(DateTime.Now - _dtActionStart > TimeSpan.FromSeconds(RobotCommandTimeout))
{
OnError("Place wafer timeout");
return true;
}
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
{
if (CurrentCompoundCommandStatus == JelCommandStatus.NormalEnd)
{
RobotArmEnum arm = (RobotArmEnum)CurrentParamter[0];
ModuleName sourcemodule;
if (!Enum.TryParse(CurrentParamter[1].ToString(), out sourcemodule)) return false;
int Sourceslotindex;
if (!int.TryParse(CurrentParamter[2].ToString(), out Sourceslotindex)) return false;
if (IsVacuumSensorON)
{
OnError("Vacuum sensor on blade is ON");
return false;
}
if (arm == RobotArmEnum.Lower)
WaferManager.Instance.WaferMoved(RobotModuleName, 0, sourcemodule, Sourceslotindex);
if (arm == RobotArmEnum.Upper)
WaferManager.Instance.WaferMoved(RobotModuleName, 1, sourcemodule, Sourceslotindex);
if (arm == RobotArmEnum.Both)
{
WaferManager.Instance.WaferMoved(RobotModuleName, 0, sourcemodule, Sourceslotindex);
WaferManager.Instance.WaferMoved(RobotModuleName, 1, sourcemodule, Sourceslotindex);
}
Blade1Target = ModuleName.System;
Blade2Target = ModuleName.System;
if (ModuleHelper.IsLoadPort(sourcemodule))
{
var lp = DEVICE.GetDevice<LoadPortBaseDevice>(sourcemodule.ToString());
if (lp != null)
lp.NoteTransferStop();
}
IsBusy = false;
CmdTarget = ModuleName.System;
MoveInfo = new RobotMoveInfo()
{
Action = RobotAction.Picking,
ArmTarget = CmdRobotArm == RobotArmEnum.Lower ? RobotArm.ArmA : RobotArm.ArmB,
BladeTarget = BuildBladeTarget(),
};
return true;
}
if (CurrentCompoundCommandStatus == JelCommandStatus.InError)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "GER"));
HandlerError("PlaceFailed");
}
}
return false;
}
protected override bool fMonitorPick(object[] param)
{
if (DateTime.Now - _dtActionStart > TimeSpan.FromSeconds(RobotCommandTimeout))
{
OnError("Pick wafer timeout");
return true;
}
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
{
if (CurrentCompoundCommandStatus == JelCommandStatus.NormalEnd)
{
RobotArmEnum arm = (RobotArmEnum)CurrentParamter[0];
ModuleName sourcemodule;
if (!Enum.TryParse(CurrentParamter[1].ToString(), out sourcemodule)) return false;
int SourceslotIndex;
if (!int.TryParse(CurrentParamter[2].ToString(), out SourceslotIndex)) return false;
if(!IsVacuumSensorON)
{
OnError("Vacuum sensor is not ON");
return false;
}
if (arm == RobotArmEnum.Lower)
WaferManager.Instance.WaferMoved(sourcemodule, SourceslotIndex, RobotModuleName, 0);
if (arm == RobotArmEnum.Upper)
WaferManager.Instance.WaferMoved(sourcemodule, SourceslotIndex, RobotModuleName, 1);
if(arm == RobotArmEnum.Both)
{
WaferManager.Instance.WaferMoved(sourcemodule, SourceslotIndex, RobotModuleName, 0);
WaferManager.Instance.WaferMoved(sourcemodule, SourceslotIndex, RobotModuleName, 1);
}
Blade1Target = ModuleName.System;
Blade2Target = ModuleName.System;
if (ModuleHelper.IsLoadPort(sourcemodule))
{
var lp = DEVICE.GetDevice<LoadPortBaseDevice>(sourcemodule.ToString());
if (lp != null)
lp.NoteTransferStop();
}
IsBusy = false;
CmdTarget = ModuleName.System;
MoveInfo = new RobotMoveInfo()
{
Action = RobotAction.Picking,
ArmTarget = CmdRobotArm == RobotArmEnum.Lower ? RobotArm.ArmA : RobotArm.ArmB,
BladeTarget = BuildBladeTarget(),
};
return true;
}
if(CurrentCompoundCommandStatus == JelCommandStatus.InError)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "GER"));
OnError("Compaund Comand execution failed");
}
else
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, $"CS{_lowerArmWaferSensorIndex}"));
}
}
return false;
}
protected override bool fStartExecuteCommand(object[] param)
{
string command = param[0].ToString();
if (string.IsNullOrEmpty(command))
return false;
_dtActionStart = DateTime.Now;
lock (_locker)
{
if(command == "RobotFlippe")
{
int compaundcmdNO = SC.GetValue<int>($"Robot.{Name}.FlippeTo0CmdNO");
if(!Convert.ToBoolean(param[1]))
compaundcmdNO = SC.GetValue<int>($"Robot.{Name}.FlippeTo180CmdNO");
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeCompaundCommandHandler(this, compaundcmdNO.ToString()));
return true;
}
if(command == "SetRegulator")
{
int ratio = Convert.ToInt32(param[1]);
if(_aoBladeRegulator != null)
_aoBladeRegulator.Value = (short)(100 * ratio);
_dtActionStart = DateTime.Now;
return true;
}
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeRawCommandHandler(this, command));
}
_dtActionStart = DateTime.Now;
return true;
}
protected override bool fMonitorExecuting(object[] param)
{
IsBusy = false;
if (DateTime.Now - _dtActionStart > TimeSpan.FromSeconds(RobotCommandTimeout))
{
OnError("Command execution timeout");
return true;
}
if (_lstMonitorHandler.Count == 0 && !_connection.IsBusy)
return true;
return false;
}
public override bool RobotFlippe(bool to0degree)
{
return CheckToPostMessage(RobotMsg.ExecuteCommand, new object[] { "RobotFlippe", to0degree });
}
protected override bool fResetToReady(object[] param)
{
return true;
}
protected override bool fError(object[] param)
{
return true;
}
protected override bool fStartExtendForPick(object[] param)
{
return true;
}
protected override bool fStartExtendForPlace(object[] param)
{
return true;
}
protected override bool fStartRetractFromPick(object[] param)
{
return true;
}
protected override bool fStartRetractFromPlace(object[] param)
{
return true;
}
public override RobotArmWaferStateEnum GetWaferState(RobotArmEnum arm)
{
bool ispresent = WaferManager.Instance.CheckHasWafer(RobotModuleName, 0);
if (IsVacuumSensorON == ispresent)
return ispresent ? RobotArmWaferStateEnum.Present : RobotArmWaferStateEnum.Absent;
return RobotArmWaferStateEnum.Unknown;
}
public bool ReadStatus()
{
lock(_locker)
{
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, ""));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, $"CS{_lowerArmWaferSensorIndex}"));
_lstMonitorHandler.AddLast(new JelC5000RobotFlippeReadHandler(this, "G"));
}
return true;
}
public override bool SetWaferSize(RobotArmEnum arm, WaferSize size)
{
if (WaferManager.Instance.CheckHasWafer(RobotModuleName, 0))
WaferManager.Instance.UpdateWaferSize(RobotModuleName, 0, size);
return true;
}
public override WaferSize GetCurrentWaferSize()
{
if (WaferManager.Instance.CheckHasWafer(RobotModuleName, 0))
return WaferManager.Instance.GetWaferSize(RobotModuleName, 0);
return WaferSize.WS0;
}
public void HandlerError(string errorMsg)
{
_lstMonitorHandler.Clear();
OnError(errorMsg);
}
private string BuildBladeTarget()
{
return (CmdRobotArm == RobotArmEnum.Upper ? "ArmB" : "ArmA") + "." + CmdTarget;
}
}
}