Svn Commit Log


Commit Date  
[r570] by hermsen

1.1.1.4
FB_Edge_Of_Network_Node work in progress

2020-12-06 16:38:05 Tree
[r569] by hermsen

restructured project by deleting nonsense;
Created a rough EoNStateMachine, which needs to be instantiated into the FB_Edge_Of_Network_Node

2020-12-06 16:00:26 Tree
[r568] by hermsen

Created a rough EoNStateMachine, which needs to be instantiated into the FB_Edge_Of_Network_Node

2020-12-06 15:51:25 Tree
[r567] by i-campbell

messing around with broken /trunk/

2020-12-05 14:59:21 Tree
[r566] by hermsen

Starting point new EoN device v1.1.1.3

2020-12-04 10:39:09 Tree
[r565] by hermsen

Starting with v1.1.1.2 as base for the new EoN SFC State Machine implementation

2020-12-04 10:16:27 Tree
[r564] by hermsen

Starting with v1.1.1.2 as base for the new EoN SFC State Machine implementation

2020-12-04 10:04:32 Tree
[r563] by hermsen

As an EoN implementation has proven to be growing too complex too fast using a CASE construct,
I started experimenting with alternatives in a smaller setting, the device;

FB_DEVICE_ST_CASE: Showcases a StateMachine built usingthe CASE construct,
Plus: small / quick and fast, good for very simple state machines (at most 4 to 5 steps)
Min: The CASE construct requires self written burnerplate code to enable step enrty pulse, step exit pulses and lots of local variables to make stuff happen. The CASE quickly grows to 300+ lines of code and isn't nearly finished.

FB_DEVICE_ST_OOP: Showcases a StateMachine built using the State Design Pattern,
Plus: Very extensible, leverages the power of OOP really well. Combines interfaces, classes, inheritance and lots of other OOP tricks for ultimatly segmented code (DRY). Though I personnaly love it, it has some big downsides.
Min: The burnplate of this pattern is very big. Just to build a few stats you need to write lots of code. The State's are build into a separate FB's. This makes this pattern very usable foir highly complex machines!
Min: If the Statemachine is not too large this pattern shouldn't be used as it like shooting a cannon on a fly.
Because of the code high segmentation, overview is quickly lost without a proper diagram as this pattern isn't self describing and difficult to follow for someone who isn't into OOP.

FB_DEVICE_SFC: Showcases a StateMachine built using the SFC State Design Pattern
This language mixes the visual style of SFC with ST or any other IEC language. After some tinkering, I found that it can also be mixed with OOP very well. This pattern let me buid a statemachine with entry / exit code i n a few hours (2 a 3) so it is suited for our purpose!

Conclusion:
From what I see, the SFC is the best way to go as it mixes a visual style in combination with ST statements.
Therefore the Device will be put on HOLD as I will first rewrite the EoN using the SFC State design pattern
After introducttion of the state machine SFC pattern in the EoN, I can "extend" the EoN and the Device simultaniously with all goals in mind

2020-12-04 09:54:17 Tree
[r562] by hermsen

Branch lib v1.1.1.0
Completely revised FB_Device with OOP Statemachine

Todo
Implement OOP Statemachine into EoN
Publish DDEATH
Support of multiple Devices

2020-12-01 20:18:53 Tree
[r561] by hermsen

Branch lib v1.1.1.0
Completely revised FB_Device with OOP Statemachine

Todo
Implement OOP Statemachine into EoN
Publish DDEATH
Support of multiple Devices

2020-12-01 20:11:24 Tree
[r560] by i-campbell

branching library to branches/i-campbell/

2020-11-28 19:47:16 Tree
[r559] by i-campbell

tearing down branch

2020-11-28 19:45:56 Tree
[r558] by hermsen

copy trunk example to personal branch

2020-11-28 16:43:03 Tree
[r557] by hermsen

copy trunk to new personal branch

2020-11-28 16:36:32 Tree
[r556] by hermsen

sunk personal branch

2020-11-28 16:24:15 Tree
[r555] by hermsen

binary commit of example v1.1.1.0

2020-11-28 16:02:06 Tree
[r554] by hermsen

prepared/updated example to libray v1.1.1.0

2020-11-28 15:58:47 Tree
[r553] by hermsen

prepared/updated example to libray v1.1.1.0

2020-11-28 15:57:01 Tree
[r552] by hermsen

binary commits of library v1.1.1.0

2020-11-28 15:47:56 Tree
[r551] by hermsen

Version 1.1.1.0
merged hermsen branch 1.1.0.14 into trunk
Fixed the Rebirth publish issue for a connected device after the Server Node requests an EoN Rebirth
Fixed improved readability and control over the state entry, exit and continuous parts in EoN/Device
Fixed stable Device state

2020-11-28 14:54:24 Tree
[r550] by hermsen

update of branch

2020-11-28 14:00:55 Tree
[r549] by hermsen

Extended the example with a total of 3 devices

2020-11-26 21:42:02 Tree
[r548] by hermsen

Version 1.1.0.13
Fixed the Rebirth publish issue for a connected device after the Server Node requests an EoN Rebirth
Fixed improved readability and control over the state entry, exit and continuous parts in EoN/Device
Fixed stable Device state

2020-11-26 21:09:37 Tree
[r547] by hermsen

After a fierce fight with the code, we managed to get it working! Thx Ian
v1.1.0.11 features a working Device with a working DBIRTH /DDATA publish

Todo:
1) Refine the mechanism to allow for a DBIRTH after a Rebirth has been issued;
Hint: check the command chain and its feedback
_ItfCurDevice.NotifyBIRTHPublish := _ItfCurDevice.NotifyBIRTHPublish + 1;

2) Test/ check /refine to allow for more then 2 devices to publish MQTT wise

3) Implement DDEATH

2020-11-23 22:22:37 Tree
[r546] by hermsen

v1.1.0.10 Device DBIRTH and DDATA working with stable seqnums.

> Encoder init separated from .addSeq
> Some EoN methods moved to Functions
> EoN notifies Device(s) when to Publish
> GC_SparkplugB Global Constants list
> Improved EoN state machine

TODO;
DDEATH
NCMD
DCMD

2020-11-21 19:09:39 Tree
Older >