| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536 | using System;using System.Collections.Generic;using System.IO.Ports;using Aitex.Core.Common.DeviceData;using Aitex.Core.RT.DataCenter;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;namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.RFMatchs.MKSs{    public class MksRfMatch : RfMatchBase    {         public override EnumRfMatchTuneMode TuneMode1        {            get            {                return _statusData.Status2.Net1AutoMode ? EnumRfMatchTuneMode.Auto : EnumRfMatchTuneMode.Manual;            }        }        public override EnumRfMatchTuneMode TuneMode2        {            get            {                return _statusData.Status2.Net2AutoMode ? EnumRfMatchTuneMode.Auto : EnumRfMatchTuneMode.Manual;            }        }        public override float LoadPosition1        {            get { return _statusData.LoadPosi1; }        }        public override float LoadPosition2        {            get { return _statusData.LoadPosi2; }        }        public override float TunePosition1        {            get { return _statusData.TunePosi1; }        }        public override float TunePosition2        {            get { return _statusData.TunePosi2; }        }        public override float BiasPeak        {            get { return _statusData.BiasPeak; }        }        public override float DCBias        {            get { return _statusData.DCBias; }        }        public override AITRfMatchData DeviceData        {            get            {                AITRfMatchData data = new AITRfMatchData()                {                    DeviceName = Name,                    DeviceSchematicId = DeviceID,                    DisplayName = Display,                     LoadPosition1 = LoadPosition1,                    LoadPosition2 = LoadPosition2,                    TunePosition1 = TunePosition1,                    TunePosition2 = TunePosition2,                    TuneMode1 = TuneMode1,                    TuneMode2 = TuneMode2,                    BiasPeak = BiasPeak,                    DCBias = DCBias,                };                return data;            }        }        public MksRfMatchConnection Connection        {            get { return _connection; }        }        private MksRfMatchConnection _connection;        private byte _deviceAddress ;         private EnumRfMatchTuneMode _tuneMode1;        private EnumRfMatchTuneMode _tuneMode2;        private RD_TRIG _trigRfOnOff = new RD_TRIG();        private int _presetNumber;        private R_TRIG _trigError = new R_TRIG();         private R_TRIG _trigWarningMessage = new R_TRIG();         private R_TRIG _trigCommunicationError = new R_TRIG();        private R_TRIG _trigRetryConnect = new R_TRIG();        private PeriodicJob _thread;        private LinkedList<HandlerBase> _lstHandler = new LinkedList<HandlerBase>();        private object _locker = new object();        private bool _enableLog = true;         private MksStatusData _statusData;        public MksRfMatch(string module, string name) : base(module, name)        {        }        public override bool Initialize()        {            base.Initialize();             string portName = SC.GetStringValue($"{ScBasePath}.{Name}.Address");            int bautRate = SC.GetValue<int>($"{ScBasePath}.{Name}.BaudRate");            int dataBits = SC.GetValue<int>($"{ScBasePath}.{Name}.DataBits");            Enum.TryParse(SC.GetStringValue($"{ScBasePath}.{Name}.Parity"), out Parity parity);            Enum.TryParse(SC.GetStringValue($"{ScBasePath}.{Name}.StopBits"), out StopBits stopBits);            _deviceAddress = (byte)SC.GetValue<int>($"{ScBasePath}.{Name}.DeviceAddress");            _enableLog = SC.GetValue<bool>($"{ScBasePath}.{Name}.EnableLogMessage");            _connection = new MksRfMatchConnection(portName, bautRate, dataBits, parity, stopBits);            _connection.EnableLog(_enableLog);            if (_connection.Connect())            {                EV.PostInfoLog(Module, $"{Module}.{Name} connected");            }            _thread = new PeriodicJob(100, OnTimer, $"{Module}.{Name} MonitorHandler", true);            DATA.Subscribe($"{Module}.{Name}.IsConnected", () => IsConnected);            DATA.Subscribe($"{Module}.{Name}.Address", () => SC.GetStringValue($"{ScBasePath}.{Name}.Address"));            OP.Subscribe($"{Module}.{Name}.MatchMode1", (out string reason, int time, object[] args) =>            {                reason = "";                if (!Enum.TryParse((string)args[0], out EnumRfMatchTuneMode mode))                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} Can not mode, {args[0]} is not a valid mode value");                    return false;                }                if (!PerformMatchMode1(out reason, time, mode))                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} Can not set mode, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Module}.{Name} set match mode1 to {mode}");                return true;            });            OP.Subscribe($"{Module}.{Name}.SetMatchLoad1", (out string reason, int time, object[] args) =>            {                reason = "";                float value = Convert.ToSingle((string)args[0]);                if (!PerformSetMatchLoad1(out reason, time, value))                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} Can not set mode, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Module}.{Name} set match load1 to {value}");                return true;            });            OP.Subscribe($"{Module}.{Name}.SetMatchTune1", (out string reason, int time, object[] args) =>            {                reason = "";                float value = Convert.ToSingle((string)args[0]);                if (!PerformSetMatchTune1(out reason, time, value))                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} Can not set mode, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Module}.{Name} set match tune1 to {value}");                return true;            });            OP.Subscribe($"{Module}.{Name}.MatchMode2", (out string reason, int time, object[] args) =>            {                reason = "";                if (!Enum.TryParse((string)args[0], out EnumRfMatchTuneMode mode))                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} Can not mode, {args[0]} is not a valid mode value");                    return false;                }                if (!PerformMatchMode2(out reason, time, mode))                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} Can not set mode, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Module}.{Name} set match mode2 to {mode}");                return true;            });            OP.Subscribe($"{Module}.{Name}.SetMatchLoad2", (out string reason, int time, object[] args) =>            {                reason = "";                float value = Convert.ToSingle((string)args[0]);                if (!PerformSetMatchLoad2(out reason, time, value))                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} Can not set mode, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Module}.{Name} set match load2 to {value}");                return true;            });            OP.Subscribe($"{Module}.{Name}.SetMatchTune2", (out string reason, int time, object[] args) =>            {                reason = "";                float value = Convert.ToSingle((string)args[0]);                if (!PerformSetMatchTune2(out reason, time, value))                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} Can not set mode, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Module}.{Name} set match tune2 to {value}");                return true;            });            OP.Subscribe($"{Module}.{Name}.Reconnect", (string cmd, object[] args) =>            {                Disconnect();                Reset();                Connect();                return true;            });            return true;        }        private bool Connect()        {            return _connection.Connect();        }        private bool Disconnect()        {            return _connection.Disconnect();        }        private bool PerformSetMatchTune1(out string reason, int time, float value)        {            reason = string.Empty;            return true;        }        private bool PerformSetMatchLoad1(out string reason, int time, float value)        {            reason = string.Empty;            return true;        }        private bool PerformMatchMode1(out string reason, int time, EnumRfMatchTuneMode mode)        {            reason = string.Empty;            return true;        }        private bool PerformMatchMode2(out string reason, int time, EnumRfMatchTuneMode mode)        {            reason = string.Empty;            return true;        }        private bool PerformSetMatchLoad2(out string reason, int time, float value)        {            reason = string.Empty;            return true;        }        private bool PerformSetMatchTune2(out string reason, int time, float value)        {            reason = string.Empty;            return true;        }        private bool OnTimer()        {            try            {                _connection.MonitorTimeout();                if (!_connection.IsConnected || _connection.IsCommunicationError)                {                    lock (_locker)                    {                        _lstHandler.Clear();                    }                    _trigRetryConnect.CLK = !_connection.IsConnected;                    if (_trigRetryConnect.Q)                    {                        _connection.SetPortAddress(SC.GetStringValue($"{ScBasePath}.{Name}.Address"));                        if (!_connection.Connect())                        {                            EV.PostAlarmLog(Module, $"Can not connect with {_connection.Address}, {Module}.{Name}");                        }                     }                    return true;                }                HandlerBase handler = null;                if (!_connection.IsBusy)                {                    lock (_locker)                    {                        if (_lstHandler.Count == 0)                        {                            _lstHandler.AddLast(new MksRfMatchQueryStatusHandler(this, _deviceAddress));                        }                        if (_lstHandler.Count > 0)                        {                            handler = _lstHandler.First.Value;                            _lstHandler.RemoveFirst();                        }                    }                    if (handler != null)                    {                        _connection.Execute(handler);                    }                }            }            catch (Exception ex)            {                LOG.Write(ex);            }            return true;        }        public override void Monitor()        {            try            {                _connection.EnableLog(_enableLog);                 _trigCommunicationError.CLK = _connection.IsCommunicationError;                if (_trigCommunicationError.Q)                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} communication error, {_connection.LastCommunicationError}");                }            }            catch (Exception ex)            {                LOG.Write(ex);            }                    }        internal void NotePresetNumber(int presetNumber)        {            _presetNumber = presetNumber;        }        internal void NoteStatus(MksStatusData data)        {            _statusData = data;        }        public override void Reset()        {            _trigError.RST = true;             _trigWarningMessage.RST = true;            _connection.SetCommunicationError(false, "");            _trigCommunicationError.RST = true;            _enableLog = SC.GetValue<bool>($"{ScBasePath}.{Name}.EnableLogMessage");            _trigRetryConnect.RST = true;            base.Reset();        }         internal void NoteError(string reason)        {            _trigWarningMessage.CLK = true;            if (_trigWarningMessage.Q)            {                EV.PostWarningLog(Module, $"{Module}.{Name} error, {reason}");            }        }         public override void SetPreSetsAndTrajectories1(Presets presets)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetPresetHandler(this, _deviceAddress, 1, presets));            }        }        public override void SetPreSetsAndTrajectories2(Presets presets)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetPresetHandler(this, _deviceAddress, 2, presets));            }        }        public override void SetActivePresetNo1(int presetNumber)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetActivePresetHandler(this, _deviceAddress, 1, presetNumber));            }        }        public override void SetActivePresetNo2(int presetNumber)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetActivePresetHandler(this, _deviceAddress, 2, presetNumber));            }        }        public override void EnablePreset1(bool enable)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchEnablePresetHandler(this, _deviceAddress, 1, enable));            }        }        public override void EnablePreset2(bool enable)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchEnablePresetHandler(this, _deviceAddress, 2, enable));            }        }        public override void EnableCapacitorMove1(bool enable)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchEnableCapMoveHandler(this, _deviceAddress, 1, enable));            }        }        public override void EnableCapacitorMove2(bool enable)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchEnableCapMoveHandler(this, _deviceAddress, 2, enable));            }        }        public override void SetTuneMode1(EnumRfMatchTuneMode mode)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetControlModeHandler(this, _deviceAddress, 1, mode));            }        }        public override void SetTuneMode2(EnumRfMatchTuneMode mode)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetControlModeHandler(this, _deviceAddress, 2, mode));            }        }        public override void SetLoad1(float position)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetLoadPositionHandler(this, _deviceAddress, 1, position));            }        }        public override void SetLoad2(float position)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetLoadPositionHandler(this, _deviceAddress, 2, position));            }        }        public override void SetTune1(float position)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetTunePositionHandler(this, _deviceAddress, 1, position));            }        }        public override void SetTune2(float position)        {            lock (_locker)            {                _lstHandler.AddLast(new MksRfMatchSetTunePositionHandler(this, _deviceAddress, 2, position));            }        }    }}
 |