// ******************************************************************************************* // ** ** // ** IDCPwr.cs // ** 4/14/2023 // ** ** // ** 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 2023. // ** ** // ** WARNING: THIS DOCUMENT CONTAINS TECHNICAL DATA AND / OR TECHNOLOGY WHOSE ** // ** EXPORT OR DISCLOSURE TO NON-U.S.PERSONS, WHEREVER LOCATED, IS RESTRICTED ** // ** BY THE INTERNATIONAL TRAFFIC IN ARMS REGULATIONS (ITAR) (22 C.F.R.SECTION ** // ** 120-130) OR THE EXPORT ADMINISTRATION REGULATIONS(EAR) (15 C.F.R.SECTION ** // ** 730-774). THIS DOCUMENT CANNOT BE EXPORTED(E.G., PROVIDED TO A SUPPLIER ** // ** OUTSIDE OF THE UNITED STATES) OR DISCLOSED TO A NON-U.S.PERSON, WHEREVER ** // ** LOCATED, UNTIL A FINAL JURISDICTION AND CLASSIFICATION DETERMINATION HAS ** // ** BEEN COMPLETED AND APPROVED BY RAYTHEON, AND ANY REQUIRED U.S.GOVERNMENT ** // ** APPROVALS HAVE BEEN OBTAINED. VIOLATIONS ARE SUBJECT TO SEVERE CRIMINAL ** // ** PENALTIES. ** // ** ** // ** CAPITAL EQUIPMENT/SOFTWARE: THIS TECHNICAL DATA WAS DEVELOPED OR ACQUIRED ** // ** EXCLUSIVELY AT CONTRACTOR EXPENSE AND IS INTENDED FOR USE ON MULTIPLE ** // ** PROJECTS/PROGRAMS. ** // ** ** // ******************************************************************************************* using System; using Raytheon.Communication; using Raytheon.Units; namespace Raytheon.Instruments { /// /// IDCPwr - simple dc power supply interface /// [UmsContract] public interface IDCPwr : IInstrument { /// /// Gets or sets the current limit. /// /// /// The current limit. /// Current CurrentLimit { [UmsCommand("IDCPwr.GetCurrentLimit")] get; [UmsCommand("IDCPwr.SetCurrentLimit")] set; } /// /// Gets or sets a value indicating whether this is enabled. /// /// /// true if enabled; otherwise, false. /// bool Enabled { [UmsCommand("IDCPwr.GetEnabled")] get; [UmsCommand("IDCPwr.SetEnabled")] set; } /// /// Measures the current. /// /// current within [UmsCommand("IDCPwr.MeasureCurrent")] Current MeasureCurrent(); /// /// Measures the voltage. /// /// voltage within [UmsCommand("IDCPwr.MeasureVoltage")] Voltage MeasureVoltage(); /// /// Gets or sets the output voltage. /// /// /// The output voltage within /// Voltage OutputVoltage { [UmsCommand("IDCPwr.GetOutputVoltage")] get; [UmsCommand("IDCPwr.SetOutputVoltage")] set; } /// /// Gets or sets the over voltage protection. /// /// /// The over voltage protection within /// Voltage OverVoltageProtection { [UmsCommand("IDCPwr.GetOverVoltageProtection")] get; [UmsCommand("IDCPwr.SetOverVoltageProtection")] set; } /// /// Gets or sets a value indicating whether [over voltage protection enabled]. /// /// /// true if [over voltage protection enabled]; otherwise, false. /// bool OverVoltageProtectionEnabled { [UmsCommand("IDCPwr.GetOverVoltageProtectionEnabled")] get; [UmsCommand("IDCPwr.SetOverVoltageProtectionEnabled")] set; } /// /// Gets or sets the voltage soft limit. /// /// /// The voltage soft limit within /// Voltage VoltageSoftLimit { [UmsCommand("IDCPwr.GetVoltageSoftLimit")] get; [UmsCommand("IDCPwr.SetVoltageSoftLimit")] set; } /// /// Gets or sets a value indicating whether the power supplies inhibit is enabled. /// /// /// true if [inhibit enabled]; otherwise, false. /// bool InhibitEnabled { [UmsCommand("IDCPwr.GetInhibitEnabled")] get; [UmsCommand("IDCPwr.SetInhibitEnabled")] set; } /// /// Occurs when the supply over currents. /// [UmsEvent("IDCPwr.OverCurrent")] event EventHandler OverCurrent; /// /// Occurs when the supply over voltages. /// [UmsEvent("IDCPwr.OverVoltage")] event EventHandler OverVoltage; /// /// reads protection status (fault register) of the power supply /// /// [UmsCommand("IDCPwr.ReadProtectionStatus")] int ReadProtectionStatus(); /// /// Control the power supply internal mechanical relay state /// /// True to connect, false to disconnect [UmsCommand( "IDCPwr.MechanicalRelayOutputControl" )] void MechanicalRelayOutputControl(bool shallWeConnect); //*** possible future enhancements //SetVoltageTriggerSource(…); //SetVoltageTriggerLevels(…); //InitiateVoltageTrigger(); //TriggerVoltage(); //SetMeasurementTriggerSource(…); //InitiateMeasurementTrigger(…); //TriggerMeasurement(); //AbortMeasurement(); } }