declutter Topology code some more
This commit is contained in:
parent
107a439e44
commit
980b09ddb4
|
@ -205,7 +205,7 @@ internal static class Program
|
||||||
|
|
||||||
WriteControl(record);
|
WriteControl(record);
|
||||||
|
|
||||||
Topology.From(record).WriteLine();
|
record.CreateTopology().WriteLine();
|
||||||
|
|
||||||
//record.ToCsv().WriteLine();
|
//record.ToCsv().WriteLine();
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
|
using System.Diagnostics;
|
||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using InnovEnergy.App.SaliMax.Ess;
|
using InnovEnergy.App.SaliMax.Ess;
|
||||||
using InnovEnergy.Lib.Devices.Battery48TL;
|
using InnovEnergy.Lib.Devices.Battery48TL;
|
||||||
|
using InnovEnergy.Lib.StatusApi.Connections;
|
||||||
using InnovEnergy.Lib.Units;
|
using InnovEnergy.Lib.Units;
|
||||||
using InnovEnergy.Lib.Units.Power;
|
using InnovEnergy.Lib.Units.Power;
|
||||||
using InnovEnergy.Lib.Utils;
|
using InnovEnergy.Lib.Utils;
|
||||||
|
@ -10,61 +12,68 @@ namespace InnovEnergy.App.SaliMax;
|
||||||
|
|
||||||
public static class Topology
|
public static class Topology
|
||||||
{
|
{
|
||||||
public static TextBlock From(this StatusRecord s)
|
public static TextBlock CreateTopology(this StatusRecord status)
|
||||||
{
|
{
|
||||||
// Topology is built up from right to left
|
// Topology is built up from right to left
|
||||||
|
var islandTopology = status.CreateIslandTopology();
|
||||||
// Power Measurement Values
|
|
||||||
|
|
||||||
var inverterPower = s.AcDc.Ac.Power.Active;
|
// TODO: check ACDCs if AC is available and synced to find out if grid meter OR grid is unavailable
|
||||||
var islandLoadPower = s.LoadOnAcIsland is not null
|
|
||||||
? s.LoadOnAcIsland.Ac.Power.Active
|
|
||||||
: 0; // TODO
|
|
||||||
|
|
||||||
var islandTopology = CreateIslandTopology(s, islandLoadPower, inverterPower);
|
if (status.GridMeter is null) // no grid meter?
|
||||||
|
|
||||||
if (s.GridMeter is null) // no grid meter?
|
|
||||||
return islandTopology; // we're done
|
return islandTopology; // we're done
|
||||||
|
|
||||||
var gridBusColumn = GridBusColumn(s);
|
var gridTopology = status.CreateGridTopology();
|
||||||
var gridBox = CreateGridBox(s);
|
|
||||||
|
return status.ConnectGridToIslandTopology(gridTopology, islandTopology);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static TextBlock ConnectGridToIslandTopology(this StatusRecord status, TextBlock gridTopology, TextBlock islandTopology)
|
||||||
|
{
|
||||||
|
var inverterPower = status.AcDc.Ac.Power.Active;
|
||||||
|
var islandLoadPower = status.LoadOnAcIsland is not null
|
||||||
|
? status.LoadOnAcIsland.Ac.Power.Active
|
||||||
|
: 0; // TODO
|
||||||
|
|
||||||
ActivePower islandToGridBusPower = inverterPower + islandLoadPower;
|
ActivePower islandToGridBusPower = inverterPower + islandLoadPower;
|
||||||
|
|
||||||
// return TextBlock
|
|
||||||
// .AlignCenterVertical
|
|
||||||
// (
|
|
||||||
// gridBox , Flow.Horizontal(s.GridMeter.Ac.Power.Active),
|
|
||||||
// gridBusColumn, Flow.Horizontal(islandToGridBusPower),
|
|
||||||
// islandTopology
|
|
||||||
// );
|
|
||||||
|
|
||||||
var gridTopology = TextBlock
|
|
||||||
.AlignCenterVertical
|
|
||||||
(
|
|
||||||
gridBox,
|
|
||||||
Flow.Horizontal(s.GridMeter.Ac.Power.Active),
|
|
||||||
gridBusColumn
|
|
||||||
);
|
|
||||||
|
|
||||||
return TextBlock.AlignCenterVertical
|
return TextBlock.AlignCenterVertical
|
||||||
(
|
(
|
||||||
gridTopology,
|
gridTopology,
|
||||||
Flow.Horizontal(islandToGridBusPower),
|
Flow.Horizontal(islandToGridBusPower),
|
||||||
islandTopology
|
islandTopology
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TextBlock CreateIslandTopology(StatusRecord s, ActivePower islandLoadPower, ActivePower inverterPower)
|
private static TextBlock CreateGridTopology(this StatusRecord status)
|
||||||
{
|
{
|
||||||
var dcBatteryPower = s.DcDc.Dc.Battery.Power;
|
Debug.Assert(status.GridMeter is not null);
|
||||||
var dcdcPower = s.DcDc.Dc.Link.Power;
|
|
||||||
|
var gridBusColumn = status.CreateGridBusColumn();
|
||||||
|
var gridBox = status.GridMeter.CreateGridBox();
|
||||||
|
|
||||||
var batteries = CreateBatteryColumn(s);
|
return TextBlock
|
||||||
var dcBusColumn = CreateDcBusColumn(s);
|
.AlignCenterVertical
|
||||||
var islandBusColumn = CreateIslandBusColumn(s, islandLoadPower);
|
(
|
||||||
var inverterBox = CreateInverterBox(s);
|
gridBox,
|
||||||
var dcDcBox = CreateDcDcBox(s);
|
Flow.Horizontal(status.GridMeter.Ac.Power.Active),
|
||||||
|
gridBusColumn
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static TextBlock CreateIslandTopology(this StatusRecord status)
|
||||||
|
{
|
||||||
|
var dcBatteryPower = status.DcDc.Dc.Battery.Power;
|
||||||
|
var dcdcPower = status.DcDc.Dc.Link.Power;
|
||||||
|
var inverterPower = status.AcDc.Ac.Power.Active;
|
||||||
|
var islandLoadPower = status.LoadOnAcIsland is not null
|
||||||
|
? status.LoadOnAcIsland.Ac.Power.Active
|
||||||
|
: 0; // TODO
|
||||||
|
|
||||||
|
var batteries = status.CreateBatteryColumn();
|
||||||
|
var dcBusColumn = status.CreateDcBusColumn();
|
||||||
|
var islandBusColumn = status.CreateIslandBusColumn(islandLoadPower);
|
||||||
|
var inverterBox = status.CreateInverterBox();
|
||||||
|
var dcDcBox = status.CreateDcDcBox();
|
||||||
|
|
||||||
return TextBlock
|
return TextBlock
|
||||||
.AlignCenterVertical
|
.AlignCenterVertical
|
||||||
|
@ -77,27 +86,26 @@ public static class Topology
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TextBlock CreateGridBox(StatusRecord statusRecord)
|
private static TextBlock CreateGridBox(this IAc3Connection gridMeter)
|
||||||
{
|
{
|
||||||
return statusRecord
|
return gridMeter
|
||||||
.GridMeter!
|
|
||||||
.Ac
|
.Ac
|
||||||
.PhasePowersActive()
|
.PhasePowersActive()
|
||||||
.TitleBox("Grid");
|
.TitleBox("Grid");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TextBlock CreateDcDcBox(StatusRecord s)
|
private static TextBlock CreateDcDcBox(this StatusRecord status)
|
||||||
{
|
{
|
||||||
var dc48Voltage = s.DcDc.Dc.Battery.Voltage.ToDisplayString();
|
var dc48Voltage = status.DcDc.Dc.Battery.Voltage.ToDisplayString();
|
||||||
|
|
||||||
return TextBlock
|
return TextBlock
|
||||||
.AlignLeft(dc48Voltage)
|
.AlignLeft(dc48Voltage)
|
||||||
.TitleBox("DC/DC");
|
.TitleBox("DC/DC");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TextBlock CreateInverterBox(StatusRecord s)
|
private static TextBlock CreateInverterBox(this StatusRecord status)
|
||||||
{
|
{
|
||||||
var inverterAcPhases = s
|
var inverterAcPhases = status
|
||||||
.AcDc
|
.AcDc
|
||||||
.Devices
|
.Devices
|
||||||
.Select(d => d.Status.Ac.Power)
|
.Select(d => d.Status.Ac.Power)
|
||||||
|
@ -107,41 +115,57 @@ public static class Topology
|
||||||
.AlignLeft(inverterAcPhases)
|
.AlignLeft(inverterAcPhases)
|
||||||
.TitleBox("AC/DC");
|
.TitleBox("AC/DC");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static TextBlock CreateGridBusColumn(this StatusRecord status)
|
||||||
|
{
|
||||||
|
Debug.Assert(status.GridMeter is not null);
|
||||||
|
|
||||||
private static TextBlock CreateIslandBusColumn(StatusRecord s, ActivePower islandLoadPower)
|
var gridLoadPower = status.LoadOnAcGrid is not null
|
||||||
|
? status.LoadOnAcGrid.Power.Active
|
||||||
|
: 0; // TODO: show that LoadOnAcGrid is actually not available and not 0
|
||||||
|
|
||||||
|
return CreateTopologyColumn
|
||||||
|
(
|
||||||
|
"PV" , 0,
|
||||||
|
"Grid Bus", status.GridMeter.Ac.PhaseVoltages(),
|
||||||
|
"Load" , gridLoadPower
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static TextBlock CreateIslandBusColumn(this StatusRecord status, ActivePower islandLoadPower)
|
||||||
{
|
{
|
||||||
var islandBusPv = 0.W(); // TODO
|
var islandBusPv = 0.W(); // TODO
|
||||||
|
|
||||||
return ColumnBox
|
return CreateTopologyColumn
|
||||||
(
|
(
|
||||||
"Pv", islandBusPv,
|
"PV" , islandBusPv,
|
||||||
"Island Bus", s.AcDc.Ac.PhasePowersActive(),
|
"Island Bus", status.AcDc.Ac.PhaseVoltages(),
|
||||||
"Load", islandLoadPower
|
"Load" , islandLoadPower
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TextBlock CreateDcBusColumn(StatusRecord s)
|
private static TextBlock CreateDcBusColumn(this StatusRecord status)
|
||||||
{
|
{
|
||||||
var dcBusLoad = 0.W(); // TODO
|
var dcBusLoad = 0.W(); // TODO
|
||||||
var pvOnDcPower = s.PvOnDc.Dc!.Power; // TODO !
|
var pvOnDcPower = status.PvOnDc.Dc!.Power; // TODO !
|
||||||
var dcLinkVoltage = s.DcDc.Dc.Link.Voltage.ToDisplayString();
|
var dcLinkVoltage = status.DcDc.Dc.Link.Voltage.ToDisplayString();
|
||||||
|
|
||||||
return ColumnBox
|
return CreateTopologyColumn
|
||||||
(
|
(
|
||||||
"Pv" , pvOnDcPower,
|
"PV" , pvOnDcPower,
|
||||||
"Dc Bus", dcLinkVoltage,
|
"DC Bus" , dcLinkVoltage,
|
||||||
"Load" , dcBusLoad
|
"DC Load", dcBusLoad
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TextBlock CreateBatteryColumn(StatusRecord s)
|
private static TextBlock CreateBatteryColumn(this StatusRecord status)
|
||||||
{
|
{
|
||||||
var bat = s.Battery;
|
var bat = status.Battery;
|
||||||
var batteryAvgBox = CreateAveragedBatteryBox(bat);
|
var batteryAvgBox = CreateAveragedBatteryBox(bat);
|
||||||
|
|
||||||
var batteryBoxes = bat
|
var batteryBoxes = bat
|
||||||
.Devices
|
.Devices
|
||||||
.Select(CreateIndividualBattery)
|
.Select(CreateBatteryBox)
|
||||||
.ToReadOnlyList();
|
.ToReadOnlyList();
|
||||||
|
|
||||||
var individualBatteries = batteryBoxes.Any()
|
var individualBatteries = batteryBoxes.Any()
|
||||||
|
@ -158,42 +182,28 @@ public static class Topology
|
||||||
|
|
||||||
private static TextBlock CreateAveragedBatteryBox(Battery48TlRecords bat)
|
private static TextBlock CreateAveragedBatteryBox(Battery48TlRecords bat)
|
||||||
{
|
{
|
||||||
var batteryVoltage = bat.Dc.Voltage.ToDisplayString();
|
var voltage = bat.Dc.Voltage.ToDisplayString();
|
||||||
var batterySoc = bat.Devices.Any() ? bat.Devices.Average(b => b.Soc).Percent().ToDisplayString() : "0";
|
var soc = bat.Devices.Any() ? bat.Devices.Average(b => b.Soc).Percent().ToDisplayString() : "0";
|
||||||
var batteryCurrent = bat.Dc.Current.ToDisplayString();
|
var current = bat.Dc.Current.ToDisplayString();
|
||||||
var batteryTemp = bat.Temperature.ToDisplayString();
|
var temp = bat.Temperature.ToDisplayString();
|
||||||
var batteryHeatingCurrent = bat.HeatingCurrent.ToDisplayString();
|
var heatingCurrent = bat.HeatingCurrent.ToDisplayString();
|
||||||
var alarms = bat.Alarms.Count + " Alarms";
|
var alarms = bat.Alarms.Count + " Alarms";
|
||||||
var warnings = bat.Warnings.Count + " Warnings";
|
var warnings = bat.Warnings.Count + " Warnings";
|
||||||
|
|
||||||
return TextBlock
|
return TextBlock
|
||||||
.AlignLeft
|
.AlignLeft
|
||||||
(
|
(
|
||||||
batteryVoltage,
|
voltage,
|
||||||
batterySoc,
|
soc,
|
||||||
batteryCurrent,
|
current,
|
||||||
batteryTemp,
|
temp,
|
||||||
batteryHeatingCurrent,
|
heatingCurrent,
|
||||||
warnings,
|
warnings,
|
||||||
alarms
|
alarms
|
||||||
)
|
)
|
||||||
.TitleBox("Battery");
|
.TitleBox("Battery");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TextBlock GridBusColumn(StatusRecord s)
|
|
||||||
{
|
|
||||||
var gridLoadPower = s.LoadOnAcGrid is not null
|
|
||||||
? s.LoadOnAcGrid.Power.Active
|
|
||||||
: 0; // TODO: show that LoadOnAcGrid is actually not available and not 0
|
|
||||||
|
|
||||||
return ColumnBox
|
|
||||||
(
|
|
||||||
"Pv", 0,
|
|
||||||
"Grid Bus", s.GridMeter!.Ac.PhaseVoltages(),
|
|
||||||
"Load", gridLoadPower
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static TextBlock PhaseVoltages(this Ac3Bus ac)
|
private static TextBlock PhaseVoltages(this Ac3Bus ac)
|
||||||
{
|
{
|
||||||
return TextBlock.AlignLeft
|
return TextBlock.AlignLeft
|
||||||
|
@ -214,7 +224,7 @@ public static class Topology
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TextBlock CreateIndividualBattery(Battery48TlRecord battery, Int32 i)
|
private static TextBlock CreateBatteryBox(Battery48TlRecord battery, Int32 i)
|
||||||
{
|
{
|
||||||
var batteryWarnings = battery.Warnings.Any();
|
var batteryWarnings = battery.Warnings.Any();
|
||||||
var batteryAlarms = battery.Alarms.Any();
|
var batteryAlarms = battery.Alarms.Any();
|
||||||
|
@ -238,10 +248,9 @@ public static class Topology
|
||||||
}
|
}
|
||||||
|
|
||||||
[SuppressMessage("ReSharper", "SuggestBaseTypeForParameter")]
|
[SuppressMessage("ReSharper", "SuggestBaseTypeForParameter")]
|
||||||
|
private static TextBlock CreateTopologyColumn(String pvTitle , ActivePower pvPower,
|
||||||
private static TextBlock ColumnBox(String pvTitle , ActivePower pvPower,
|
String busTitle , Object busData,
|
||||||
String busTitle , Object busData,
|
String loadTitle, ActivePower loadPower)
|
||||||
String loadTitle, ActivePower loadPower)
|
|
||||||
{
|
{
|
||||||
var pvBox = TextBlock.FromString(pvTitle).Box();
|
var pvBox = TextBlock.FromString(pvTitle).Box();
|
||||||
var pvToBus = Flow.Vertical(pvPower);
|
var pvToBus = Flow.Vertical(pvPower);
|
||||||
|
@ -251,4 +260,4 @@ public static class Topology
|
||||||
|
|
||||||
return TextBlock.AlignCenterHorizontal(pvBox, pvToBus, busBox, busToLoad, loadBox);
|
return TextBlock.AlignCenterHorizontal(pvBox, pvToBus, busBox, busToLoad, loadBox);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue