/*------------------------------------------------------------------------- // UNCLASSIFIED /*------------------------------------------------------------------------- RAYTHEON PROPRIETARY: THIS DOCUMENT CONTAINS DATA OR INFORMATION PROPRIETARY TO RAYTHEON COMPANY AND IS RESTRICTED TO USE ONLY BY PERSONS AUTHORIZED BY RAYTHEON COMPANY IN WRITING TO USE IT. DISCLOSURE TO UNAUTHORIZED PERSONS WOULD LIKELY CAUSE SUBSTANTIAL COMPETITIVE HARM TO RAYTHEON COMPANY'S BUSINESS POSITION. NEITHER SAID DOCUMENT NOR ITS CONTENTS SHALL BE FURNISHED OR DISCLOSED TO OR COPIED OR USED BY PERSONS OUTSIDE RAYTHEON COMPANY WITHOUT THE EXPRESS WRITTEN APPROVAL OF RAYTHEON COMPANY. THIS PROPRIETARY NOTICE IS NOT APPLICABLE IF DELIVERED TO THE U.S. GOVERNMENT. UNPUBLISHED WORK - COPYRIGHT RAYTHEON COMPANY. -------------------------------------------------------------------------*/ using NLog; using ProgramGui; using ProgramGui.Model; using ProgramGui.ViewModel; using ProgramLib; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading; using System.Threading.Tasks; namespace ProgramLib { internal class PowerSupplyReadThread : BasicThread { private enum Events { GLOBAL_QUIT, UUT_POWER_ON, UUT_POWER_OFF, // DO NOT change the name // This must be the last member in the enum EVENT_TIMED_OUT } private ILogger _logger; private MainWindow _mainWindow; private string _powerSupplySystemName; private Dictionary _powerModuleToPowerDataModelDict = new Dictionary(); private PassthroughData _passthroughData = null; public PowerSupplyReadThread(string powerSupplySystemName) { _logger = LogManager.GetCurrentClassLogger(); _powerSupplySystemName = powerSupplySystemName; _mainWindow = (MainWindow)ProgramLib.Program.Instance().GetGuiManager()[ProgramGuiManager.WINDOWS.MAIN]; _powerModuleToPowerDataModelDict["UUT_P20V"] = new PowerModuleDataModel(); _powerModuleToPowerDataModelDict["UUT_N20V"] = new PowerModuleDataModel(); _passthroughData = new PassthroughData(_mainWindow.datagridPassthroughData.Columns.Count); ProgramLib.Program.Instance().GetGuiManager()[ProgramGuiManager.WINDOWS.MAIN].Dispatcher.Invoke((Action)delegate { _mainWindow._mainWindowViewModel.AddPowerData(_powerModuleToPowerDataModelDict); _mainWindow._mainWindowViewModel.AddPassthroughData(_passthroughData.GetPassthroughDataModelDict()); }); } ~PowerSupplyReadThread() { _logger?.Debug($"Entering {this.GetType().Name}::{System.Reflection.MethodBase.GetCurrentMethod().Name}() ..."); } protected override void DoWork() { _logger?.Debug($"{this.GetType().Name}::{System.Reflection.MethodBase.GetCurrentMethod().Name}() for {_powerSupplySystemName} is running..."); try { Dictionary eventDict = new Dictionary(); eventDict[Events.GLOBAL_QUIT] = Program.Instance()._eventManager[EventManager.Events.GLOBAL_QUIT]; eventDict[Events.UUT_POWER_ON] = Program.Instance()._eventManager[EventManager.Events.UUT_POWER_ON]; eventDict[Events.EVENT_TIMED_OUT] = null; EventGroup eventGroup = new EventGroup(eventDict); while (true) { Events id = eventGroup.WaitAny(); if (id == Events.UUT_POWER_ON) { ReadPowerSupplyData(); } else break; } } catch (Exception ex) { _logger?.Error(ex.Message + "\n" + ex.StackTrace); } _logger?.Debug($"{this.GetType().Name}::{System.Reflection.MethodBase.GetCurrentMethod().Name}() for {_powerSupplySystemName} is exiting..."); } private void ReadPowerSupplyData() { int pollRateMs = 1000; _logger?.Debug($"{this.GetType().Name}::{System.Reflection.MethodBase.GetCurrentMethod().Name}() for {_powerSupplySystemName} is running..."); try { Dictionary eventDict = new Dictionary(); eventDict[Events.GLOBAL_QUIT] = Program.Instance()._eventManager[EventManager.Events.GLOBAL_QUIT]; eventDict[Events.UUT_POWER_OFF] = Program.Instance()._eventManager[EventManager.Events.UUT_POWER_OFF]; eventDict[Events.EVENT_TIMED_OUT] = null; EventGroup eventGroup = new EventGroup(eventDict); Random rnd = new Random(); while (true) { Events id = eventGroup.WaitAny(pollRateMs); if (id == Events.EVENT_TIMED_OUT) { rnd = new Random(); _mainWindow._mainWindowViewModel.UutPowerLedImagePath = _mainWindow._mainWindowViewModel._imageToResourcePathDict[MainWindowViewModel.Images.LED_OFF]; float num = 20.0f + GenerateRandomFraction(); _powerModuleToPowerDataModelDict["UUT_P20V"].ActualVoltage = num.ToString("0.00"); _powerModuleToPowerDataModelDict["UUT_P20V"].ExpectedVoltage = "20.0"; Thread.Sleep(100); num = 1.0f + GenerateRandomFraction(); _powerModuleToPowerDataModelDict["UUT_P20V"].ActualCurrent = num.ToString("0.00"); _powerModuleToPowerDataModelDict["UUT_P20V"].ExpectedCurrent = "1.0"; Thread.Sleep(100); num = 20.0f + GenerateRandomFraction(); _powerModuleToPowerDataModelDict["UUT_N20V"].ActualVoltage = num.ToString("0.00"); _powerModuleToPowerDataModelDict["UUT_N20V"].ExpectedVoltage = "20.0"; Thread.Sleep(200); _mainWindow._mainWindowViewModel.UutPowerLedImagePath = _mainWindow._mainWindowViewModel._imageToResourcePathDict[MainWindowViewModel.Images.LED_ON]; num = 5.0f + GenerateRandomFraction(); _powerModuleToPowerDataModelDict["UUT_N20V"].ActualCurrent = num.ToString("0.00"); _powerModuleToPowerDataModelDict["UUT_N20V"].ExpectedCurrent = "1.0"; Thread.Sleep(100); num = 70.0f + GenerateRandomFraction(); _passthroughData.SetValue(PassthroughData.Variables.VAR1, num.ToString("0.00")); Thread.Sleep(100); num = 30.0f + GenerateRandomFraction(); _passthroughData.SetValue(PassthroughData.Variables.VAR2, num.ToString("0.00")); Thread.Sleep(200); _mainWindow._mainWindowViewModel.UutPowerLedImagePath = _mainWindow._mainWindowViewModel._imageToResourcePathDict[MainWindowViewModel.Images.LED_OFF]; num = 40.0f + GenerateRandomFraction(); _passthroughData.SetValue(PassthroughData.Variables.VAR3, num.ToString("0.00")); Thread.Sleep(100); num = 50.0f + GenerateRandomFraction(); _passthroughData.SetValue(PassthroughData.Variables.VAR4, num.ToString("0.00")); Thread.Sleep(100); num = 60.0f + GenerateRandomFraction(); _passthroughData.SetValue(PassthroughData.Variables.VAR5, num.ToString("0.00")); Thread.Sleep(200); _mainWindow._mainWindowViewModel.UutPowerLedImagePath = _mainWindow._mainWindowViewModel._imageToResourcePathDict[MainWindowViewModel.Images.LED_ON]; num = 10.0f + GenerateRandomFraction(); _passthroughData.SetValue(PassthroughData.Variables.VAR6, num.ToString("0.00")); } else break; } } catch (Exception ex) { _logger.Error(ex.Message + "\n" + ex.StackTrace); } _logger?.Debug($"{this.GetType().Name}::{System.Reflection.MethodBase.GetCurrentMethod().Name}() for {_powerSupplySystemName} is exiting..."); } static float GenerateRandomFraction() { Random rnd = new Random(); int randNum = 0; const int minimum = 1; randNum = rnd.Next(20); if (randNum <= minimum) { randNum += minimum; } return (float)(1.0 / (float)randNum); } } }