private static void NewAlarmAndSaveDatabase(out DeviceFaultRunModel deviceFaultRunModel, List <DeviceFaultRunModel> deviceFaultRunModels, RealDataModel realDataModel, AnalogPointModel analogPointModel, Func <PointState, bool> isAlarmState) { deviceFaultRunModel = NewDeviceFaultRunModel(realDataModel, analogPointModel); var newStartTime = deviceFaultRunModel.StartTime; var valueState = deviceFaultRunModel.PointState; var existSameStartTime = deviceFaultRunModels.Find(o => newStartTime.Subtract(o.StartTime).TotalSeconds < 1 && o.PointState == valueState); if (existSameStartTime != null) { // 只有当开始时间和结束时间不一致的时候, 排除初始化出现主键冲突问题. deviceFaultRunModels.Remove(existSameStartTime); LogD.Warn($"分站{deviceFaultRunModel.PointID} 状态{existSameStartTime.PointState}出现一秒内多次状态报警状态改变, 会发生主键冲突."); } if (isAlarmState((PointState)deviceFaultRunModel.PointState)) { deviceFaultRunModels.Add(deviceFaultRunModel.DeepClone()); // 直接写入数据库 } }
public static void UpdateDeviceFaultRun(ref DeviceFaultRunModel deviceFaultRunModel, List <DeviceFaultRunModel> deviceFaultRunModels, RealDataModel realDataModel, AnalogPointModel analogPointModel, Func <PointState, bool> isAlarmState) { if (deviceFaultRunModel == null) { NewAlarmAndSaveDatabase(out deviceFaultRunModel, deviceFaultRunModels, realDataModel, analogPointModel, isAlarmState); } else { deviceFaultRunModel.EndTime = realDataModel.RealDate; if (deviceFaultRunModel.IsRequireNew(realDataModel)) { // 有新的记录, 把老记录状态置1 deviceFaultRunModel.State = 1; } if (!deviceFaultRunModel.IsRequireNew(realDataModel)) { deviceFaultRunModel.PointState = realDataModel.RealState; } if (isAlarmState((PointState)deviceFaultRunModel.PointState) && (deviceFaultRunModel.IsTimeToSave(realDataModel) || deviceFaultRunModel.IsRequireNew(realDataModel))) { // 报警情况下, 写入数据库. var newM = deviceFaultRunModel.DeepClone(); DeviceFaultRunModel existM; if ((existM = deviceFaultRunModels.FirstOrDefault(o => o.PointID == newM.PointID && o.StartTime == newM.StartTime && o.PointState == newM.PointState)) != null) { existM.State = newM.State; existM.PointState = newM.PointState; existM.PointStateName = Alarm_TodayModel.GetAlarmStateName((PointState)newM.PointState); existM.EndTime = newM.EndTime; existM.SpanTime = (int)newM.EndTime.Subtract(newM.StartTime).TotalSeconds; } else { deviceFaultRunModels.Add(deviceFaultRunModel.DeepClone()); } } if (deviceFaultRunModel.IsRequireNew(realDataModel)) { // 有新记录. NewAlarmAndSaveDatabase(out deviceFaultRunModel, deviceFaultRunModels, realDataModel, analogPointModel, isAlarmState); } } }
private void UpdateAnalogOff(DateTime now) { LogD.Info($"传感器[{PointID}]状态为真正断线..."); var value = "模拟量断线"; var valueState = PointState.OFF; //是真正的断线 RealDataModel.Update(now, value, valueState); _analogRunModel.Update(RealDataModel); _analogRunModels.Add(_analogRunModel); AnalogStatisticModel.UpdateAnalogStatistic(ref _analogStatisticModel, _analogStatisticModels, RealDataModel, this); AnalogAlarmModel.UpdateAnalogAlarm(ref _analogAlarmModel, _analogAlarmModels, RealDataModel, this, IsAlarmState); Alarm_TodayModel.UpdateAlarmToday(ref _alarmTodayModel, _alarmTodayModels, RealDataModel, this, IsAlarmState); DeviceFaultRunModel.UpdateDeviceFaultRun(ref _deviceFaultRunModel, _deviceFaultRunModels, RealDataModel, this, IsAlarmState); }
private static DeviceFaultRunModel NewDeviceFaultRunModel(RealDataModel realDataModel, AnalogPointModel analogPointModel) { var model = new DeviceFaultRunModel(); model.PointID = analogPointModel.PointID; model.PointName = analogPointModel.PointName; model.SubStationID = analogPointModel.SubStationID; model.PortNO = analogPointModel.PortNO; model.PointType = (int)Models.PointType.Analog; model.Location = analogPointModel.Location; model.PointState = realDataModel.RealState; model.PointStateName = Alarm_TodayModel.GetAlarmStateName((PointState)realDataModel.RealState); model.FeedState = realDataModel.FeedState; model.StartTime = realDataModel.RealDate; model.EndTime = realDataModel.RealDate; model.SpanTime = 0; model.State = 0; return(model); }
internal void Update(DateTime now) { _analogOffCount++; if (new[] { PointState.UnKnow, PointState.Init }.All(o => o != (PointState)RealDataModel.RealState) && _analogOffCount <= DasConfig.SensorTimeoutCount) { LogD.Info($"传感器[{PointID}]处于断线屏蔽次数之内:当前屏蔽次数:{_analogOffCount}"); RealDataModel.Update(now); //处于屏蔽次数之内 _analogRunModels.Add(_analogRunModel); AnalogStatisticModel.UpdateAnalogStatistic(ref _analogStatisticModel, _analogStatisticModels, RealDataModel, this); AnalogAlarmModel.UpdateAnalogAlarm(ref _analogAlarmModel, _analogAlarmModels, RealDataModel, this, IsAlarmState); Alarm_TodayModel.UpdateAlarmToday(ref _alarmTodayModel, _alarmTodayModels, RealDataModel, this, IsAlarmState); DeviceFaultRunModel.UpdateDeviceFaultRun(ref _deviceFaultRunModel, _deviceFaultRunModels, RealDataModel, this, IsAlarmState); } else { UpdateAnalogOff(now); } }
internal void Update(DateTime now, List <SensorRealDataInfo> sensorRealDataInfos) { var sensorRealData = sensorRealDataInfos.FirstOrDefault(p => p.EquipCodes.Exists(q => q == EquipCode)); if (sensorRealData.IsAnalogOk) { _analogOffCount = 0; PointState valueState = PointState.OK; HandleAnalogAlarm(sensorRealData.Value, ref valueState); RealDataModel.Update(now, sensorRealData.Value.ToString("f2"), valueState); _analogRunModel.Update(RealDataModel); _analogRunModels.Add(_analogRunModel); AnalogStatisticModel.UpdateAnalogStatistic(ref _analogStatisticModel, _analogStatisticModels, RealDataModel, this); AnalogAlarmModel.UpdateAnalogAlarm(ref _analogAlarmModel, _analogAlarmModels, RealDataModel, this, IsAlarmState); Alarm_TodayModel.UpdateAlarmToday(ref _alarmTodayModel, _alarmTodayModels, RealDataModel, this, IsAlarmState); DeviceFaultRunModel.UpdateDeviceFaultRun(ref _deviceFaultRunModel, _deviceFaultRunModels, RealDataModel, this, IsAlarmState); } else { Update(now); } }