diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/ExciterStatic.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/ExciterStatic.drawio.svg index f754aecb10..307ffd55b8 100644 --- a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/ExciterStatic.drawio.svg +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/ExciterStatic.drawio.svg @@ -1,52 +1,52 @@ - + - - - - - - - - + + + + + + + + -
+
- - - - - + + + + + - + - + - + - + - + - + @@ -62,69 +62,69 @@
- + $$\frac{1}... - - - - + + + + -
+
- - - - - - + + + + + + - + - + - + - + - + - + - + - + - + - + @@ -138,40 +138,40 @@
- + $$\frac{1+... - - - - + + + + -
+
- - - + + + - + - + - + @@ -183,33 +183,33 @@
- + $$e_{... - + -
+
- - + + - + - + @@ -221,43 +221,43 @@
- + $$v_{... - - - + + + -
+
- - - - + + + + - + - + - + - + @@ -269,56 +269,56 @@
- + $$v_{... - + -
+
- - - - - - - + + + + + + + - + - + - + - + - + - + - + @@ -332,27 +332,27 @@
- + $$\frac{K_... - + -
+
- + - + @@ -362,55 +362,55 @@
- + $$-$$ - - - - - + + + + + -
+
- - - - - - + + + + + + - + - + - + - + - + - + @@ -422,51 +422,51 @@
- + $$e_{... - + -
+
- - - - - - + + + + + + - + - + - + - + - + - + @@ -478,33 +478,33 @@
- + $$e_{... - + -
+
- - + + - + - + @@ -516,37 +516,37 @@
- + $$v_{... - + -
+
- - - + + + - + - + - + @@ -558,33 +558,33 @@
- + $$v_{... - + -
+
- - + + - + - + @@ -596,7 +596,7 @@
- + $$v_{... diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor.drawio.svg new file mode 100644 index 0000000000..5a5948fa0b --- /dev/null +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor.drawio.svg @@ -0,0 +1,455 @@ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\De... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{K(... + +
+
+ + + + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$p$$ + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p^{... + +
+
+
+ + + + + Text is not SVG - cannot display + + + +
\ No newline at end of file diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor.jpg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor.jpg deleted file mode 100644 index 5a6714dc00..0000000000 Binary files a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor.jpg and /dev/null differ diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor_split.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor_split.drawio.svg new file mode 100644 index 0000000000..af784e08dc --- /dev/null +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroGovernor_split.drawio.svg @@ -0,0 +1,716 @@ + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\De... + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$x_{... + +
+
+ + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$x_{... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{T_... + +
+
+ + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{T_... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p^{... + +
+
+
+ + + + + Text is not SVG - cannot display + + + +
\ No newline at end of file diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine.drawio.svg new file mode 100644 index 0000000000..e6a47ce76f --- /dev/null +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine.drawio.svg @@ -0,0 +1,197 @@ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{(1... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{... + +
+
+
+ + + + + Text is not SVG - cannot display + + + +
\ No newline at end of file diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine.jpg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine.jpg deleted file mode 100644 index 5a7648168b..0000000000 Binary files a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine.jpg and /dev/null differ diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine_split.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine_split.drawio.svg new file mode 100644 index 0000000000..ed6a1de02a --- /dev/null +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/HydroTurbine_split.drawio.svg @@ -0,0 +1,279 @@ + + + + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$x_{... + +
+
+ + + + + + + +
+
+
+ -2 +
+
+
+
+ + -2 + +
+
+ + + + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$3$$ + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{... + +
+
+ + + + +
+
+
+ 3 +
+
+
+
+ + 3 + +
+
+
+ + + + + Text is not SVG - cannot display + + + +
\ No newline at end of file diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor.drawio.svg new file mode 100644 index 0000000000..541ad327d9 --- /dev/null +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor.drawio.svg @@ -0,0 +1,622 @@ + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\De... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{K(... + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\dot{P... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\dot{P... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$p$$ + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$-$$ + +
+
+
+ + + + + Text is not SVG - cannot display + + + +
\ No newline at end of file diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor.jpg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor.jpg deleted file mode 100644 index 9e9aae5c34..0000000000 Binary files a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor.jpg and /dev/null differ diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor_split.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor_split.drawio.svg new file mode 100644 index 0000000000..37aa1fba88 --- /dev/null +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor_split.drawio.svg @@ -0,0 +1,764 @@ + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\De... + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\dot{P... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\dot{P... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$p$$ + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$-$$ + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{T_... + +
+
+ + + + + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{T_... + +
+
+ + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ +
+ + + + + Text is not SVG - cannot display + + + +
\ No newline at end of file diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor_windup.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor_windup.drawio.svg new file mode 100644 index 0000000000..856aa30b0c --- /dev/null +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamGovernor_windup.drawio.svg @@ -0,0 +1,1015 @@ + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\De... + +
+
+ + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\dot{P... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\dot{P... + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$p$$ + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$-$$ + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{T_... + +
+
+ + + + + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{T_... + +
+
+ + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + + + + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$P_{m,m... + +
+
+ + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$-$$ + +
+
+ + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$K_{bc}$$ + +
+
+ + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\do... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p^{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + +
+
+
+
+ + $$-$$ + +
+
+
+ + + + + Text is not SVG - cannot display + + + +
\ No newline at end of file diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamTurbine.drawio.svg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamTurbine.drawio.svg new file mode 100644 index 0000000000..2afab5f26b --- /dev/null +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamTurbine.drawio.svg @@ -0,0 +1,558 @@ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$\frac{1}... + +
+
+ + + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$F_{HP}$$ + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$F_{IP}$$ + +
+
+ + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$F_{LP}$$ + +
+
+ + + + + + + + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+ + $$p_{... + +
+
+
+ + + + + Text is not SVG - cannot display + + + +
\ No newline at end of file diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamTurbine.jpg b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamTurbine.jpg deleted file mode 100644 index b2f5635e84..0000000000 Binary files a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/images/SteamTurbine.jpg and /dev/null differ diff --git a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/index.md b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/index.md index 4b8c0f5b57..8bffca3977 100644 --- a/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/index.md +++ b/docs/hugo/content/en/docs/Models/Synchronous Generator Regulators/index.md @@ -2,6 +2,7 @@ title: "Synchronous Generator Regulators" linkTitle: "Synchronous Generator Regulators" date: 2023-01-23 +author: Martin Moraga --- In DPSim, synchronous generator control systems are solved separately from the electric network. The outputs of the electric network (active and reactive power, node voltages, branch currents and rotor speed of synchronous generators) at time $k- \Delta t$ are used as the input of the controllers to calculate their states at time $k$. Because of the relatively slow response of the controllers, the error in the network solution due to the time delay $\Delta t$ introduced by this approach is negligible. @@ -12,7 +13,7 @@ In DPSim, synchronous generator control systems are solved separately from the e $$ v_{ref}(t) = v_{ref,0} + v_{pss}(t) $$ -where $v_{ref,0}$ is initialized after the power flow computations and $v_{pss}(t)$ is the output of the (optional) PSS connected to the exciter. The output of the exciter systems is the induced emf by the field current $v_{ef}$. +where $v_{ref,0}$ is initialized after the power flow computations and $v_{pss}(t)$ is the output of the (optional) PSS connected to the exciter. The output of the exciter systems is the induced emf by the field current at $t=k + \Delta t$: $v_{ef}(k + \Delta t)$ (sometimes the alternative notation $e_{fd}(k + \Delta t)$ is used). ### IEEE Type DC1 exciter model
@@ -207,14 +208,17 @@ Then, the set of differential equations are discretized using forward euler in o $$ v_r(k + \Delta t) = v_r(k) + \frac{\Delta t}{T_R} ( v_h(k) - v_r(k) ), $$ +$$ + v_{in}(k) = v_{ref}(k) - v_{r}(k), +$$ $$ X_b(k + \Delta t) = \frac{\Delta t}{T_{b}} (v_{in}(k) - x_{b}(k)) + x_{b}(k), $$ $$ - v_e(k + \Delta t) = K_{a} (C_{b} x_{b}(k + \Delta t) + C_{a} v_{in} (k + \Delta t)) , + v_e(k) = K_{a} (C_{b} x_{b}(k) + C_{a} v_{in} (k)) , $$ $$ - e_{fd}(k + \Delta t) = \frac{\Delta t}{T_{e}}(v_{e(k)} - e_{fd}(k)) + e_{fd}(k). + e_{fd}(k + \Delta t) = \frac{\Delta t}{T_{e}}(v_{e}(k) - e_{fd}(k)) + e_{fd}(k). $$ To consider the saturation of $e_{fd}$ there are two different implementations, which is automatically selected depending of value of the parameter $K_{bc}$: @@ -266,19 +270,19 @@ v_{ref}(t=0) = v_{in}(t=0) - v_{r}(t=0) $$ ## Power Systen Stabilizer (PSS) -PSS is a controller of synchonous generators used to enhance damping electromechanical oscillations. The input of the PSS implemented in DPSim is the rotor speed of the machine. The PSS output is a signal used to modify the reference voltage of the AVR. At present, only one PSS is implemented in DiPSim which is a simplified version of the IEEE PSS1A type model. +PSS is a controller of synchonous generators used to enhance damping electromechanical oscillations. The input of the PSS implemented in DPSim is the rotor speed of the machine. The PSS output $v_{pss}$ at time $t=k$ is a signal used as the input of the AVR to calculate the field voltage at $t=k+\Delta t$, $v_{fd}(k+\Delta t)$. At present, only one PSS is implemented in DiPSim which is a simplified version of the IEEE PSS1A type model. ### IEEE PSS1A type PSS
DC1_exciter -
Fig. 3: Control diagram of the PSS Type 1
+
Fig. 6: Control diagram of the PSS Type 1
Adapted from: Milano, Power System Modelling and Scripting
-The control diagram of this PSS is depicted in Fig. 3. It includes a washout filter and two lead-lag blocks and is described by the following set of differential equations: +The control diagram of this PSS is depicted in Fig. 6. It includes a washout filter and two lead-lag blocks and is described by the following set of differential equations: $$ T_w \frac{d}{dt} v_1(t) = -(K_w \omega (t) + v_1(t)), $$ @@ -296,13 +300,13 @@ where $\omega (t)$ is the input signal of the PSS (rotor speed) and $v_{pss}(t)$ The set of differential equations are discretized using forward euler in order to solve it numerically, which leads to the following set of algebraic equations: $$ - v_1(k+1) = v_1(k) - \frac{\Delta t}{T_w} (K_w \omega (k) + v_1(k)), + v_1(k + \Delta t) = v_1(k) - \frac{\Delta t}{T_w} (K_w \omega (k) + v_1(k)), $$ $$ - v_2(k+1) = v_2(k) + \frac{\Delta t}{T_2} ((1-\frac{T_1}{T_2})(K_w \omega (k) + v_1(k)) - v_2(k)), + v_2(k + \Delta t) = v_2(k) + \frac{\Delta t}{T_2} ((1-\frac{T_1}{T_2})(K_w \omega (k) + v_1(k)) - v_2(k)), $$ $$ - v_3(k+1) = v_3(k) + \frac{\Delta t}{T_4} ((1-\frac{T_3}{T_4})(v_2(k) + \frac{T_1}{T_2}(K_w \omega (k) + v_1(k))) - v_{pss}(k)), + v_3(k + \Delta t) = v_3(k) + \frac{\Delta t}{T_4} ((1-\frac{T_3}{T_4})(v_2(k) + \frac{T_1}{T_2}(K_w \omega (k) + v_1(k))) - v_{pss}(k)), $$ $$ v_{pss}(k) = v_3(k) + \frac{T_3}{T_4} (v_2(k) + \frac{T_1}{T_2} (K_w \omega (k) + v_1(k))) @@ -328,20 +332,22 @@ where $\omega(k=0)$ is calculated after the power flow analysis and after the in ## Turbine Governor Models -In DPsim there are two type of Turbine Governor implementations. The *Turbine Governor Type 1* implements both, the turbine and the governor, in one component. In difference to that, Steam Turbine and Steam Turbine Governor are implemented as two separate classes, therefore the objects are created separately. Steam/Hydro Turbine and Steam/Hydro Turbine Governor are two blocks that has to be connected in series. +In DPsim there are two types of Turbine Governor implementations. The *Turbine Governor Type 1* implements both, the turbine and the governor, in one component. In difference to that, Steam Turbine and Steam Turbine Governor are implemented as two separate classes, therefore the objects are created separately. Steam/Hydro Turbine and Steam/Hydro Turbine Governor are two blocks that has to be connected in series. + +The input of the turbine governos models is the mechanical omega at time $t=k-\Delta t$ and the output is the mechanical power at time $t=k$. This variable is the used by the SG to predict the mechanical omega at time $t=k+\Delta t$. ### Turbine Governor Type 1
DC1_exciter -

Fig. 4: Control diagram of the turbine governor type 1
+

Fig. 7: Control diagram of the turbine governor type 1
Source: Milano, Power System Modelling and Scripting

-This model includes a governor, a servo and a reheat block. The control diagram of this governor is depicted in Fig. 4 and it is described by the following set of differential-algebraic equations: +This model includes a governor, a servo and a reheat block. The control diagram of this governor is depicted in Fig. 7 and it is described by the following set of differential-algebraic equations: $$ p_{in}(t) = p_{ref} + \frac{1}{R} (\omega_{ref} - \omega(t)), $$ @@ -361,78 +367,241 @@ where $\omega (t)$ is the input signal and $\tau_{m}(t)$ is the output signal of The set of differential equations are discretized using forward euler in order to solve it numerically, which leads to the following set of algebraic equations: $$ - p_{in}(k) = p_{ref} + \frac{1}{R} (\omega_{ref} - \omega(k)), + p_{in}(k-\Delta t) = p_{ref} + \frac{1}{R} (\omega_{ref} - \omega(k-\Delta t)), +$$ +$$ + x_{g1}(k) = x_{g1}(k-\Delta t) + \frac{\Delta t}{T_s} (p_{in}(k-\Delta t) - x_{g1}(k-\Delta t)), +$$ +$$ + x_{g2}(k) = x_{g2}(k-\Delta t) + \frac{\Delta t}{T_c} ((1 - \frac{T_3}{T_c}) x_{g1}(k-\Delta t) - x_{g2}(k-\Delta t)), +$$ +$$ + x_{g3}(k) = x_{g3}(k-\Delta t) + \frac{\Delta t}{T_5} ((1 - \frac{T_4}{T_5}) (x_{g2}(k-\Delta t) + \frac{T_3}{T_c} x_{g1}(k-\Delta t)) - x_{g3}(k-\Delta t)), +$$ +$$ + \tau_m(k) = x_{g3}(k) + \frac{T_4}{T_3} (x_{g2}(k) + \frac{T_3}{T_c} x_{g1}(k)), +$$ +Since the values of all variables for $t=k-\Delta t$ are known, $\tau_m(k)$ can be easily calculated using the discretised equations, which is carried out in the `preStep` function of the generator connected to each governor. Then, $\tau_m(k)$ is used to approximate the mechanical differential equations of the generator at time $k+\Delta t$. + +### Steam Governor +
+
+ DC1_exciter +

Fig. 8: Control diagram of the steam turbine governor
+ Adapted from [7] +
+
+
+
+ +The control diagram of this model is depicted in Fig. 8. This model gets as input the frequency (rotational speed of the generator) deviation $\Delta\omega$ from the norminal frequency (normally $50 Hz$ or $60 Hz$) and gives the target value $p_{gv}$ to the turbine. $p_{ref}$ is the mechanical power that is produced at nominal frequency. The governor is implemented as a controller $\frac{K(1+sT_2)}{(1+sT_1)}$, where $K=1/R$ and $R$ it the droop coefficient, and a PT1 lag element with embedded limiters before and after the integrator. To avoid unnecessary dead beat behavior, complex transfer functions, with more then one pole and zero, are represented as a sum of multiple PT1 elements connected in parallel, via partial fracture decomposition, which leads to the control diagram depicted in Fig. 9. + +
+
+ DC1_exciter +

Fig. 9: Control diagram of the steam turbine governor
+
+
+
+
+ +Analog to the static exciter model, this model is implemented using a anti windup strategy as shown in Fig. 10. +
+
+ DC1_exciter +

Fig. 10: Control diagram of the steam turbine governor with anti windup strategy
+
+
+
+
+ +Finally, the discretized equations using forward euler of this model are given by: +$$ + \Delta \omega (k- \Delta t) = \omega_{ref} - \omega (k- \Delta t), +$$ +$$ + p_{1}(k) = p_{1}(k- \Delta t) + \frac{\Delta t}{T_{1}} (\Delta \omega (k- \Delta t) \cdot \frac{T_{1} - T_{2}}{T_{1}} - p_{1}(k- \Delta t)), +$$ +$$ + p(k - \Delta t) = \frac{1}{R} (p_{1}(k - \Delta t) + \Delta \omega(k- \Delta t) \cdot \frac{T_{2}}{T_{1}}), +$$ +$$ + \dot{p}(k-\Delta t) = \frac{1}{T_{3}}(p(k- \Delta t) + p_{ref} - p_{gv}(k- \Delta t)) - K_{bc} (P_{gv}^{*}(k- \Delta t) - P_{gv}(k- \Delta t)), +$$ +$$ + p_{gv}^{*}(k) = p_{gv}^{*}(k- \Delta t) + \Delta t \cdot \dot{p}(k- \Delta t), $$ + +and + +$$ +p_{gv}(k) = p_{gv}^{*}(k) \quad \quad if \quad \quad P_{m, min} <= p_{gv}^{*}(k) <= P_{m, min}, \\ +p_{gv}(k) = P_{m, max} \quad \quad if \quad \quad p_{gv}^{*}(k) > P_{m, max}, \\ +p_{gv}(k) = P_{m, min} \quad \quad if \quad \quad p_{gv}^{*}(k) > P_{m, min}. +$$ + +If $T1==0$ the equation for $p_{1}(k)$ is skipped and the equation for $p(k)$ is calculated as follows: +$$ + p(k - \Delta t) = \frac{1}{R} (\Delta \omega(k - \Delta t) + \frac{T_{2}}{\Delta t} (\Delta \omega(k - \Delta t) - \Delta \omega(k - 2\Delta t) )). $$ - x_{g1}(k+1) = x_{g1}(k) + \frac{\Delta t}{T_s} (p_{in}(k) - x_{g1}(k)), + +The initial values of all variables, which are used in the first simulation step, are calculated assuming that the simulation starts in the steady. This is equivalent to assume that all derivative are equal to zero and that $\Delta \omega(t=0)=0$, which leads to: + $$ + p_{1}(t=0) = 0, $$ - x_{g2}(k+1) = x_{g2}(k) + \frac{\Delta t}{T_c} ((1 - \frac{T_3}{T_c}) x_{g1}(k) - x_{g2}(k)), $$ + p(t=0) = 0, $$ - x_{g3}(k+1) = x_{g3}(k) + \frac{\Delta t}{T_5} ((1 - \frac{T_4}{T_5}) (x_{g2}(k) + \frac{T_3}{T_c} x_{g1}(k)) - x_{g3}(k)), $$ + p_{ref} = p_{gv}(t=0), $$ - \tau_m(k+1) = x_{g3}(k+1) + \frac{T_4}{T_3} (x_{g2}(k+1) + \frac{T_3}{T_c} x_{g1}(k+1)), $$ -Since the values of all variables for $t=k$ are known, $\tau_m(k+1)$ can be easily calculated using the discretised equations, which is carried out in the `preStep` function of the generator connected to each governor. Then, $\tau_m(k)$ is used to approximate the mechanical differential equations of the generator at time $k+1$. The valueof $\tau_m(k+1)$ is stored and used to approximate the machanical variables of the generator at time $k+2$, and so on. + p_{gv}^{*}(t=0) = p_{gv}(t=0), +$$ ### Steam Turbine -**Note 1**: In the step function of each PT1 lag element the integrator $\frac{1}{s}$ is simulated with Forward Euler Method, it the output value for $k$ calculated in the previous step and following the Forward Euler formula calculate the value for $k+1$. To avoid unnecessary dead beat behavior, complex transfer functions, with more then one pole and zero, are represented as a sum of multiple PT1 elements connected in parallel, via partial fracture decomposition. Parallel blocks are discretized separately with the same time step. +
+
+ Steam Turbine +

Fig. 9: Control diagram of the steam turbine
+ Adapted from [7] +
+
+
+
+ +The control diagram of this model is depicted in Fig. 9. It receives as input signal from the Steam Governor $p_{gv}$ and as output gives the mechanical power $p_{m}$ to a synchronous generator. Steam Turbine is divided in high-pressure, intermediate-pressure and low-pressure stages. Each of them is modeled as a first order lag element with time constants $T_{CH}, T_{RH}, T_{CO}$. If a time constant is chosen to be equal to zero, the according lag element is deactivated. The total turbine mechanical power is a sum of powers provided by each stage, each fraction can be modeled with corresponding gain-factors $F_{HP}, F_{IP}, F_{LP}$. Note that the sum of gain-factors should be equal to one $F_{HP}+F_{IP}+F_{LP} = 1$. The discretized equations of this model using forward euler are given by the following equations: -More information on below governors and turbines can be found in the book "Handbook of Electrical Power System Dynamics: Modeling, Stability, and Control", linked below in references. +$$ + p_{hp}(k) = p_{hp}(k - \Delta t) + \frac{\Delta t}{T_{CH}} (p_{gv}(k - \Delta t) - p_{hp}(k - \Delta t)), +$$ +$$ + p_{ip}(k) = p_{ip}(k - \Delta t) + \frac{\Delta t}{T_{RH}} (p_{hp}(k - \Delta t) - p_{ip}(k - \Delta t)), +$$ +$$ + p_{lp}(k) = p_{lp}(k - \Delta t) + \frac{\Delta t}{T_{CO}} (p_{ip}(k - \Delta t) - p_{lp}(k - \Delta t)), +$$ +$$ + p_{m}(k) = F_{FP} \cdot p_{hp}(k) + F_{ip} \cdot p_{ip}(k) + F_{LP} \cdot p_{lp}(k) +$$ + +The initial values of all variables, which are used in the first simulation step, are calculated assuming that the simulation starts in the steady. This is equivalent to assume that all derivative are equal to zero, which leads to: +$$ + p_{hp}(t=0) = p_{gv}(t=0), +$$ +$$ + p_{ip}(t=0) = p_{hp}(t=0), +$$ +$$ + p_{lp}(t=0) = p_{iv}(t=0), +$$ +$$ + p_{m}(t=0) = F_{FP} \cdot p_{hp}(t=0) + F_{ip} \cdot p_{ip}(t=0) + F_{LP} \cdot p_{lp}(t=0) +$$ -**Steam Turbine** receives as input signal from Steam Turbine Governor $p_{gv}$ and as output gives the mechanical power $p_{m}$ to a synchronous generator. Steam Turbine is divided in high-pressure, intermediate-pressure and low-pressure stages. Each of them is modeled as a first order lag element with time constants $T_{CH}, T_{RH}, T_{CO}$. If a time constant is chosen to be equal to zero, the according lag element is deactivated. The total turbine mechanical power is a sum of powers provided by each stage, each fraction can be modeled with corresponding gain-factors $F_{HP}, F_{IP}, F_{LP}$. Note that the sum of gain-factors should be equal to one $F_{HP}+F_{IP}+F_{LP} = 1$. +### Hydro Turbine Governor
- DC1_exciter -

Fig. 4: Diagram of the steam turbine
- Source: A. Roehder, B. Fuchs, J. Massman, M. Quester, A. Schnettler, "Transmission system stability assessment within an integrated grid development process" + Hydro Governor +

Fig. 11: Control diagram of a hydro turbine governor
+ Adapted from [7]

-### Steam Turbine and Steam Turbine Governor -**Steam turbine governor** get as input the frequency (rotational speed of the generator) deviation $\Delta\omega$ from set-frequency ($50 Hz$ or $60 Hz$) and gives target value $p_{gv}$ to the turbine , $p_0$ is mechanical power that is produced at set-frequency. The governor is implemented as a controller $\frac{K(1+sT_2)}{(1+sT_1)}$, where $K=1/R$ with $R$-droop coefficient, and a PT1 lag element with embedded limiters before and after the integrator. The Controller is Simulated as a gain parallel to a PT1 element $\frac{K(1+sT_2)}{(1+sT_1)}=K(\frac{T_2}{T_1}+\frac{T_1-T_2}{T_1} \frac{1}{1+sT_1})$. For safety reasons in the governor output signal is limited to the range [0 pu, 1 pu]. +Hydro Turbine Governor get as input the frequency (rotational speed of the generator) deviation $\Delta\omega$ from the nominal frequency (normally $50 Hz$ or $60 Hz$) and gives the target value $p_{gv}$ to the turbine , $p_{ref}$ is mechanical power that is produced at nominal frequency. The controller transfer function is defined as $K\frac{1+sT_2}{(1+sT_1)(1+sT_3)}$, where $K=\frac{1}{R}$ and $R$ is the droop coefficient. The transfer function can be split into two PT1 blocks as shown in Fig. 12.
- DC1_exciter -

Fig. 4: Control diagram of the steam turbine governor
- Source: A. Roehder, B. Fuchs, J. Massman, M. Quester, A. Schnettler, "Transmission system stability assessment within an integrated grid development process" + Hydro Governor split +

Fig. 12: Control diagram of a hydro turbine governor

+The discretized equations of this model using forward euler are given by the following equations: +$$ + x_{1}(k) = x_{1}(k - \Delta t) + \frac{\Delta t}{T_{1}} (\Delta \omega(k - \Delta t) - x_{1}(k - \Delta t)), +$$ +$$ + x_{2}(k) = x_{2}(k - \Delta t) + \frac{\Delta t}{T_{3}} (\Delta \omega(k - \Delta t) - x_{2}(k - \Delta t)), +$$ +$$ + p^{*}_{gv}(k) = \frac{1}{R}(A \cdot x_{1}(k) + B \cdot x_{2}(k)) + p_{ref}, +$$ + +where +$$ +A = \frac{T_{1}-T_{2}}{T_{1}-T_{3}}, \quad \quad B = \frac{T_{2}-T_{3}}{T_{1}-T_{3}}, +$$ + +and + +$$ +p_{gv}(k) = p_{gv}^{*}(k) \quad \quad if \quad \quad P_{m, min} <= p_{gv}^{*}(k) <= P_{m, min}, \\ +p_{gv}(k) = P_{m, max} \quad \quad if \quad \quad p_{gv}^{*}(k) > P_{m, max}, \\ +p_{gv}(k) = P_{m, min} \quad \quad if \quad \quad p_{gv}^{*}(k) > P_{m, min}. +$$ + +The initial values of all variables, which are used in the first simulation step, are calculated assuming that the simulation starts in the steady. This is equivalent to assume that all derivative are equal to zero and that $\Delta \omega(t=0)=0$, which leads to: + +$$ + x_{1}(t=0) = 0, +$$ +$$ + x_{2}(t=0) = 0, +$$ +$$ + p_{ref} = p_{gv}(t=0), +$$ +$$ + p_{gv}^{*}(t=0) = p_{gv}(t=0), +$$ + ### Hydro Turbine -**Hydro Turbine** receives as input signal from Hydro Turbine Governor $p_{gv}$ and as output gives the mechanical power $p_{m}$ to a synchronous generator. The transfer function is specified by water starting time parameter $T_{w}$. The transfer function is a sum of two parallel blocks $\frac{1-sT_w}{1+0.5sT_w}=-2+\frac{3}{1+0.5sT_w}$ which is discretized separately.
- DC1_exciter -

Fig. 4: Diagram of a hydro turbine
- Source: A. Roehder, B. Fuchs, J. Massman, M. Quester, A. Schnettler, "Transmission system stability assessment within an integrated grid development process" + DC1_exciter +

Fig. 12: Diagram of a hydro turbine
+ Adapted from [7]

-### Hydro Turbine Governor -**Hydro Turbine Governor** get as input the frequency (rotational speed of the generator) deviation $\Delta\omega$ from set-frequency ($50 Hz$ or $60 Hz$) and gives target value $p_{gv}$ to the turbine , $p_0$ is mechanical power that is produced at set-frequency. The controller transfer Function is defined as $K\frac{1+sT_2}{(1+sT_1)(1+sT_3)}=K(\frac{T_1-T_2}{T_1-T_3} \frac{1}{1+sT_1} + \frac{T_2-T_3}{T_1-T_3} \frac{1}{1+sT_3})$, where $K=\frac{1}{R}$ and $R$ is the droop coefficient. Two parallel PT1 blocks are discretized separately, their outputs are weighted by according factors and added. The disadvantage of the parallel block representation is the error the time constants are equal, that is why is should it must apply $T_1 \neq T_2$. The sum of both blocks, the output $p_{gv}$ is limited to the range [0pu, 1pu]. +The control diagram of this model is depicted in Fig. 12. It receives as input signal from Hydro Turbine Governor $p_{gv}$ and as output gives the mechanical power $p_{m}$ to a synchronous generator. The transfer function is specified by water starting time parameter $T_{w}$ and can be represented as the sum of two parallel blocks as shown in Fig. 13.
- DC1_exciter -

Fig. 4: Control diagram of a hydro turbine governor
- Source: A. Roehder, B. Fuchs, J. Massman, M. Quester, A. Schnettler, "Transmission system stability assessment within an integrated grid development process" + DC1_exciter +

Fig. 13: Diagram of a hydro turbine
+ Adapted from [7]

+The equations modelling this governor are discretized using forward euler and are given by the following equations: +$$ + x_{1}(k) = x_{1}(k - \Delta t) + \frac{\Delta t}{0.5 \cdot T_{W}} (p_{gv}(k - \Delta t) - x_{1}(k - \Delta t)), +$$ +$$ + p_{m}(k) = 3 x_{1}(k) - 2 p_{gv}(k), +$$ + +The initial values of the variables, which are used in the first simulation step, are calculated assuming that the simulation starts in the steady. This is equivalent to assume that all derivative are equal to zero, which leads to: +$$ + x_{1}(t=0) = p_{gv}(t=0), +$$ +$$ + p_{m}(t=0) = p_{gv}(t=0). +$$ + ## References - [1] "IEEE Recommended Practice for Excitation System Models for Power System Stability Studies," in IEEE Std 421.5-2016 (Revision of IEEE Std 421.5-2005) , vol., no., pp.1-207, 26 Aug. 2016, doi: 10.1109/IEEESTD.2016.7553421. - [2] F. Milano, “Power system modelling and scripting,” in Power System Modelling and Scripting. London: Springer-Verlag, 2010, ISBN: 978-3-642-13669-6. doi: 10.1007/978-3-642-13669-6. diff --git a/dpsim-models/include/dpsim-models/Signal/HydroTurbineGovernor.h b/dpsim-models/include/dpsim-models/Signal/HydroTurbineGovernor.h index 3db539a2e2..c196415c22 100644 --- a/dpsim-models/include/dpsim-models/Signal/HydroTurbineGovernor.h +++ b/dpsim-models/include/dpsim-models/Signal/HydroTurbineGovernor.h @@ -50,22 +50,25 @@ namespace Signal { //Setpoint for mechanical Power (pu) Real mPref; - // Delta Omega = Omega_ref-Omega_meas at k + // Delta Omega = Omega_ref-Omega_meas at k and at k-1 Real mDelOm; + Real mDelOm_prev; - // State Variable of T1 PT1 at k + // State Variable of T1 PT1 at k and at k-1 Real mX1; - // State Variable of T1 PT1 at k+1 - Real mX1_next; + Real mX1_prev; - // State Variable of T3 PT1 at k + // State Variable of T3 PT1 at k and at k-1 Real mX2; - // State Variable of T3 PT1 at k+1 - Real mX2_next; + Real mX2_prev; // The outpur of the Governor at k Real mPgv; + /// Auxiliar variables + Real mCa; + Real mCb; + public: /// explicit HydroTurbineGovernor(const String & name) : SimSignalComp(name, name) { } diff --git a/dpsim-models/include/dpsim-models/Signal/PSS1A.h b/dpsim-models/include/dpsim-models/Signal/PSS1A.h index 3c53abc452..1ae58970d3 100644 --- a/dpsim-models/include/dpsim-models/Signal/PSS1A.h +++ b/dpsim-models/include/dpsim-models/Signal/PSS1A.h @@ -69,6 +69,10 @@ namespace Signal { Real mVs_prev; /// Real mOmega_prev; + /// + Real mActivePower_prev; + /// + Real mVh_prev; protected: /// State Variables @@ -78,7 +82,7 @@ namespace Signal { Real mV2; /// Output of the second phase compensation block Real mV3; - /// PSS output + /// PSS output at t=k Real mVs; public: diff --git a/dpsim-models/include/dpsim-models/Signal/SteamTurbineGovernor.h b/dpsim-models/include/dpsim-models/Signal/SteamTurbineGovernor.h index cad13326f3..e1ec06075f 100644 --- a/dpsim-models/include/dpsim-models/Signal/SteamTurbineGovernor.h +++ b/dpsim-models/include/dpsim-models/Signal/SteamTurbineGovernor.h @@ -21,26 +21,29 @@ namespace Signal { public: /// Droop, the value 1/K in the controller K(1+sT_2) - Real R; + Real R = 0; /// T_1 related to the differentiator in the controlle K(1+sT_2)/(1+sT_1) - Real T1; + Real T1 = 0; /// T_2 related to the differentiator in the controlle K(1+sT_2) - Real T2; + Real T2 = 0; /// Time constant T_3 of the actuator in the Governor - Real T3; + Real T3 = 0; // ### Physical constraints ### /// Maximum growth rate - Real dPmax; + Real dPmax = 0; /// Minimum decay rate - Real dPmin; + Real dPmin = 0; /// Maximum mechanical power(pu) - Real Pmax; + Real Pmax = 0; /// Minimum mechanical power (pu) - Real Pmin; + Real Pmin = 0; /// Setpoint for omega (pu). It is adviced to choose Om_ref=1 - Real OmRef; + Real OmRef = 0; + + /// Proportional gain of anti-Windup + Real Kbc = 0; }; /// Steam turbine governor, where Omega_ref, P_ref are constant and T_1=0 @@ -58,30 +61,26 @@ namespace Signal { /// Setpoint for mechanical Power (pu) Real mPref; - /// ### Variables at time step k-1 ### - Real mDelOm_prev; - - // ### Variables at time step k ### - /// Delta Omega = Omega_ref-Omega_meas at k + // ### State Variables ### + /// Delta Omega = Omega_ref-Omega_meas at t=k, t=k-1 and t=k-2 Real mDelOm; - /// Variable after the rate limiter and before integrator at k - Real mDelPgv; - /// The outpur of the Governor at k - Real mPgv; - /// Windup variable + Real mDelOm_prev; + Real mDelOm_2prev; + /// Windup variable at t=k and t=k-1 Real mP1; - /// Windup variable + Real mP1_prev; + /// p at time t=k-1 Real mP; - /// Windup variable - Real mPlim_in; - - // ### Variables at time step k+1 ### - /// The outpur of the PT1 with limiters at k+1 (Governor output) - Real mPgv_next; - /// - Real mP1_next; - /// - Real mPlim_in_next; + /// Derivative of Pgv at time k-1 + Real mDerPgv; + /// The output of the Governor at k before the limiter + Real mPgvLim; + /// The output of the Governor at k after the limiter + Real mPgv; + + /// Auxiliar variables + Real mCa; + Real mCb; public: /// diff --git a/dpsim-models/src/Base/Base_ReducedOrderSynchronGenerator.cpp b/dpsim-models/src/Base/Base_ReducedOrderSynchronGenerator.cpp index 4df96c3e75..7876a9d7ca 100644 --- a/dpsim-models/src/Base/Base_ReducedOrderSynchronGenerator.cpp +++ b/dpsim-models/src/Base/Base_ReducedOrderSynchronGenerator.cpp @@ -477,12 +477,6 @@ void Base::ReducedOrderSynchronGenerator::initializeFromNodesAndTermina // set initial interface voltage (**mIntfVoltage)(0,0) = mInitVoltage * mBase_V_RMS; - // set initial value of current - (**mIntfCurrent)(0,0) = mInitCurrent * mBase_I_RMS; - - // set initial interface voltage - (**mIntfVoltage)(0,0) = mInitVoltage * mBase_V_RMS; - SPDLOG_LOGGER_DEBUG(this->mSLog, "\n--- Initialization from power flow ---" "\nInitial Vd (per unit): {:f}" @@ -526,7 +520,8 @@ template <> void Base::ReducedOrderSynchronGenerator::mnaCompPreStep(Real time, Int timeStepCount) { mSimTime = time; - // update governor variables + // Calculate mechanical torque at t=k + // input is omega at time t=k, output is mech. torque at time t=k if (mHasTurbine && mHasGovernor) { mMechTorque_prev = **mMechTorque; **mMechTorque = mTurbine->step(mGovernor->step(**mOmMech, mTimeStep), mTimeStep); @@ -536,22 +531,28 @@ void Base::ReducedOrderSynchronGenerator::mnaCompPreStep(Real time, Int **mMechTorque = mGovernor->step(**mOmMech, mTimeStep); } - // calculate mechanical variables at t=k+1 with forward euler + // Calculate electrical torque at t=k **mPower = Complex((**mVdq)(0,0) * (**mIdq)(0,0) + (**mVdq)(1,0) * (**mIdq)(1,0), (**mVdq)(1,0) * (**mIdq)(0,0) - (**mVdq)(0,0) * (**mIdq)(1,0)); **mElecTorque = (**mPower).real(); //**mElecTorque = (**mPower).real() / **mOmMech; - **mOmMech = **mOmMech + mTimeStep * (1. / (2. * mH) * (mMechTorque_prev - **mElecTorque)); - **mThetaMech = **mThetaMech + mTimeStep * (**mOmMech * mBase_OmMech); - **mDelta = **mDelta + mTimeStep * (**mOmMech - 1.) * mBase_OmMech; - - // update exciter and PSS variables + + // calculate v_pss at time k + // inputs are: mOmMech, mElecTorque, mVdq at time t=k if (mHasPSS) mVpss = mPSS->step(**mOmMech, **mElecTorque, (**mVdq)(0,0), (**mVdq)(1,0), mTimeStep); + + // calculate e_fd at time k+1, inputs are at t=k if (mHasExciter) { mEf_prev = **mEf; **mEf = mExciter->step((**mVdq)(0,0), (**mVdq)(1,0), mTimeStep, mVpss); } + + // calculate mechanical variables at t=k+1 with forward euler + **mOmMech = **mOmMech + mTimeStep * (1. / (2. * mH) * (mMechTorque_prev - **mElecTorque)); + //**mOmMech = **mOmMech + mTimeStep * (1. / (2. * mH) * (mMechTorque_prev - **mElecTorque) / **mOmMech); + **mThetaMech = **mThetaMech + mTimeStep * (**mOmMech * mBase_OmMech); + **mDelta = **mDelta + mTimeStep * (**mOmMech - 1.) * mBase_OmMech; stepInPerUnit(); (**mRightVector).setZero(); @@ -562,7 +563,8 @@ template <> void Base::ReducedOrderSynchronGenerator::mnaCompPreStep(Real time, Int timeStepCount) { mSimTime = time; - // update governor variables + // Calculate mechanical torque at t=k + // input is omega at time t=k, output is mech. torque at time t=k if (mHasTurbine && mHasGovernor) { mMechTorque_prev = **mMechTorque; **mMechTorque = mTurbine->step(mGovernor->step(**mOmMech, mTimeStep), mTimeStep); @@ -572,22 +574,28 @@ void Base::ReducedOrderSynchronGenerator::mnaCompPreStep(Real time, Int ti **mMechTorque = mGovernor->step(**mOmMech, mTimeStep); } - // calculate mechanical variables at t=k+1 with forward euler + // Calculate electrical torque at t=k **mPower = Complex((**mVdq0)(0,0) * (**mIdq0)(0,0) + (**mVdq0)(1,0) * (**mIdq0)(1,0), (**mVdq0)(1,0) * (**mIdq0)(0,0) - (**mVdq0)(0,0) * (**mIdq0)(1,0)); **mElecTorque = (**mPower).real(); //**mElecTorque = (**mPower).real() / **mOmMech; - **mOmMech = **mOmMech + mTimeStep * (1. / (2. * mH) * (mMechTorque_prev - **mElecTorque)); - **mThetaMech = **mThetaMech + mTimeStep * (**mOmMech * mBase_OmMech); - **mDelta = **mDelta + mTimeStep * (**mOmMech - 1.) * mBase_OmMech; - // update exciter and PSS variables + // calculate v_pss at time k + // inputs are: mOmMech, mElecTorque, mVdq at time t=k if (mHasPSS) mVpss = mPSS->step(**mOmMech, **mElecTorque, (**mVdq0)(0,0), (**mVdq0)(1,0), mTimeStep); + + // calculate e_fd at time k+1, inputs are at t=k if (mHasExciter) { mEf_prev = **mEf; **mEf = mExciter->step((**mVdq0)(0,0), (**mVdq0)(1,0), mTimeStep, mVpss); } + + // calculate mechanical variables at t=k+1 with forward euler + **mOmMech = **mOmMech + mTimeStep * (1. / (2. * mH) * (mMechTorque_prev - **mElecTorque)); + //**mOmMech = **mOmMech + mTimeStep * (1. / (2. * mH) * (mMechTorque_prev - **mElecTorque) / **mOmMech); + **mThetaMech = **mThetaMech + mTimeStep * (**mOmMech * mBase_OmMech); + **mDelta = **mDelta + mTimeStep * (**mOmMech - 1.) * mBase_OmMech; stepInPerUnit(); (**mRightVector).setZero(); diff --git a/dpsim-models/src/Signal/ExciterStatic.cpp b/dpsim-models/src/Signal/ExciterStatic.cpp index 6f12c19d92..55ce856267 100644 --- a/dpsim-models/src/Signal/ExciterStatic.cpp +++ b/dpsim-models/src/Signal/ExciterStatic.cpp @@ -66,7 +66,7 @@ void ExciterStatic::initialize(Real Vh_init, Real Ef_init) { mVin = mVe / (mCa + mCb); /// Initial reference value - mVref = mVin - mVr; + mVref = mVin + mVr; /// Initial value for auxilar state variable mXb = mVin; @@ -77,10 +77,10 @@ void ExciterStatic::initialize(Real Vh_init, Real Ef_init) { "\nExciter type: ExciterStatic" "\nInitially set excitation system initial values:" "\ninit Vh: {:e}" - "\ninit Ef: {:e}", + "\ninit Ef: {:e}" "\nCalculated set poit and auxilary state variables:" "\nVref : {:e}" - "\nXb : {:e}", + "\nXb : {:e}" "\nVin = {:e}", mVh, mEfd, mVref, mXb, mVin); @@ -103,15 +103,13 @@ Real ExciterStatic::step(Real mVd, Real mVq, Real dt, Real Vpss) { mVr = mVh; /// Compute Vin at time k - mVin = mVref - mVr + Vpss; + mVin = mVref - mVr_prev + Vpss; /// Compute Xb at time k+1 using euler forward mXb = mXb_prev + (mVin - mXb_prev) * dt / mParameters->Tb; - // Compute Efd at time k+1 using euler forward - mVe = mVin * mCa + mXb * mCb - mParameters->Kbc * (mEfd - mEfdLim); - - //Integrator for T_e time constant !with! Wind-up + // Compute Efd at time k using euler forward + mVe = mVin * mCa + mXb_prev * mCb - mParameters->Kbc * (mEfd - mEfdLim); mEfd = mEfd + (dt / mParameters->Te) * (mParameters->Ka * mVe - mEfd); if (mEfd > mParameters->MaxEfd) mEfdLim = mParameters->MaxEfd; diff --git a/dpsim-models/src/Signal/HydroTurbine.cpp b/dpsim-models/src/Signal/HydroTurbine.cpp index a66cc20a6b..b3db18ccbb 100644 --- a/dpsim-models/src/Signal/HydroTurbine.cpp +++ b/dpsim-models/src/Signal/HydroTurbine.cpp @@ -42,9 +42,12 @@ void HydroTurbine::initialize(Real Pminit) { Real HydroTurbine::step(Real Pgv, Real dt){ // the values pre calculated in the previous step are now actual values mX1 = mX1_next; + // Caltulating the value of the only state variable for the next step (integration) using the current - mX1_next = 2 * dt/mParameters->Tw * (Pgv-mX1) + mX1; + mX1_next = 2 * dt / mParameters->Tw * (Pgv - mX1) + mX1; + // Output is the value Pm(k) = -2*Pgv(k)+X1(k) mPm = 3 * mX1 - (2 * Pgv); + return mPm; } diff --git a/dpsim-models/src/Signal/HydroTurbineGovernor.cpp b/dpsim-models/src/Signal/HydroTurbineGovernor.cpp index 57e0529af0..95d4cd3246 100644 --- a/dpsim-models/src/Signal/HydroTurbineGovernor.cpp +++ b/dpsim-models/src/Signal/HydroTurbineGovernor.cpp @@ -28,6 +28,14 @@ void HydroTurbineGovernor::setParameters(std::shared_ptrname() << " has to be HydroGorvernorParameters!" << std::endl; throw CPS::TypeException(); } + // FIXME: Ein problem entsteht bei der Zerlegung wenn T1=t3 (gleiche polstellen, es muss eine andere Zerlegung benutzt werden) + if (mParameters->T1==mParameters->T3) { + SPDLOG_LOGGER_ERROR(mSLog, "T1 can not be equal to T3!!!"); + throw CPS::Exception(); + } + + mCa = (mParameters->T1 - mParameters->T2) / (mParameters->T1 - mParameters->T3); + mCb = (mParameters->T2 - mParameters->T3) / (mParameters->T1 - mParameters->T3); } void HydroTurbineGovernor::initialize(Real Pref){ @@ -36,10 +44,11 @@ void HydroTurbineGovernor::initialize(Real Pref){ mPgv=Pref; mPref=Pref; mDelOm = 0; + mDelOm_prev = 0; mX1 = 0; - mX1_next = 0; + mX1_prev = 0; mX2 = 0; - mX2_next = 0; + mX2_prev = 0; SPDLOG_LOGGER_INFO(mSLog, "Hydro Governor initial values: \n" "\nPref: {:f}" @@ -57,24 +66,20 @@ void HydroTurbineGovernor::initialize(Real Pref){ } Real HydroTurbineGovernor::step(Real Omega, Real dt){ - // FIXME: Ein problem entsteht bei der Zerlegung wenn T1=t3 (gleiche polstellen, es muss eine andere Zerlegung benutzt werden) - // TODO: move cA and cB to initialize() to avoid recomputation in each simulation step - const Real cA = (mParameters->T1 - mParameters->T2) / (mParameters->T1 - mParameters->T3); - const Real cB = (mParameters->T2 - mParameters->T3) / (mParameters->T1 - mParameters->T3); - - //Calculation of frequency deviation - mDelOm=mParameters->OmRef-Omega; + // write the values that were calculated in the previous step + mDelOm_prev = mDelOm; + mX1_prev = mX1; + mX2_prev = mX2; - // Set the values of state variables calculated in last step as atual values for k - mX1=mX1_next; - mX2=mX2_next; + // Calculate the input of the governor for time step k + mDelOm = mParameters->OmRef - Omega; // Calculation State variables for k+1 with integrators - mX1_next= mX1 + dt / mParameters->T1 * (mDelOm - mX1); - mX2_next= mX2 + dt / mParameters->T3 * (mDelOm - mX2); + mX1 = mX1_prev + dt / mParameters->T1 * (mDelOm_prev - mX1_prev); + mX2 = mX2_prev + dt / mParameters->T3 * (mDelOm_prev - mX2_prev); // Output of the governor before limiter, values from k are used to caltulate output Pgv(k) - mPgv = mPref + 1. / mParameters->R * ( mX1 * cA + mX2 * cB); + mPgv = mPref + 1. / mParameters->R * ( mX1 * mCa + mX2 * mCb); if (mPgv>mParameters->Pmax) mPgv = mParameters->Pmax; diff --git a/dpsim-models/src/Signal/PSS1A.cpp b/dpsim-models/src/Signal/PSS1A.cpp index 07bd42299f..9deab23429 100644 --- a/dpsim-models/src/Signal/PSS1A.cpp +++ b/dpsim-models/src/Signal/PSS1A.cpp @@ -55,6 +55,7 @@ void Signal::PSS1A::initialize(Real omega, Real activePower, Real Vd, Real Vq) { mVs = mV3 + (mParameters->T3 / mParameters->T4) * (mV2 + (mParameters->T1 / mParameters->T2) * (mParameters->Kw * omega + mParameters->Kp * activePower + mParameters->Kv * Vh + mV1)); mOmega_prev = omega; + mActivePower_prev = activePower; SPDLOG_LOGGER_INFO(mSLog, "\nInitial values: " @@ -67,24 +68,28 @@ void Signal::PSS1A::initialize(Real omega, Real activePower, Real Vd, Real Vq) { } Real Signal::PSS1A::step(Real omega, Real activePower, Real Vd, Real Vq, Real dt) { + // inputs are omega, Vd, Vq at and activePower at time k // Voltage magnitude calculation Real Vh = sqrt(pow(Vd, 2.) + pow(Vq, 2.)); + mVh_prev = Vh; - // + // update variables at t=k-1 mV1_prev = mV1; mV2_prev = mV2; mV3_prev = mV3; mVs_prev = mVs; // compute state variables at time k using euler forward - mV1 = mV1_prev - dt / mParameters->Tw * (mParameters->Kw * mOmega_prev + mParameters->Kp * activePower + mParameters->Kv * Vh + mV1_prev); - mV2 = mV2_prev + dt / mParameters->T2 * (mA * (mParameters->Kw * mOmega_prev + mParameters->Kp * activePower + mParameters->Kv * Vh + mV1_prev) - mV2_prev); - mV3 = mV3_prev + dt / mParameters->T4 * (mB * (mV2_prev + (mParameters->T1 / mParameters->T2) * (mParameters->Kw * mOmega_prev + mParameters->Kp * activePower + mParameters->Kv * Vh + mV1_prev)) - mV3_prev); + mV1 = mV1_prev - dt / mParameters->Tw * (mParameters->Kw * mOmega_prev + mParameters->Kp * mActivePower_prev + mParameters->Kv * mVh_prev + mV1_prev); + mV2 = mV2_prev + dt / mParameters->T2 * (mA * (mParameters->Kw * mOmega_prev + mParameters->Kp * mActivePower_prev + mParameters->Kv * mVh_prev + mV1_prev) - mV2_prev); + mV3 = mV3_prev + dt / mParameters->T4 * (mB * (mV2_prev + (mParameters->T1 / mParameters->T2) * (mParameters->Kw * mOmega_prev + mParameters->Kp * mActivePower_prev + mParameters->Kv * mVh_prev + mV1_prev)) - mV3_prev); // mVs = mV3 + (mParameters->T3 / mParameters->T4) * (mV2 + (mParameters->T1 / mParameters->T2) * (mParameters->Kw * omega + mParameters->Kp * activePower + mParameters->Kv * Vh + mV1)); mOmega_prev = omega; + mActivePower_prev = activePower; + mVh_prev = Vh; // check limints of mVs if (mVs > mParameters->Vs_max) diff --git a/dpsim-models/src/Signal/SteamTurbine.cpp b/dpsim-models/src/Signal/SteamTurbine.cpp index db80b4e86b..63ab307048 100644 --- a/dpsim-models/src/Signal/SteamTurbine.cpp +++ b/dpsim-models/src/Signal/SteamTurbine.cpp @@ -67,21 +67,21 @@ Real SteamTurbine::step(Real Pgv, Real dt) { // Calculate next values of state variables of turbine with forward euler high pressure if(mParameters->Tch == 0) - mPhp=Pgv; + mPhp = Pgv; else - mPhp_next= mPhp + dt/mParameters->Tch *(Pgv - mPhp); + mPhp_next= mPhp + dt / mParameters->Tch * (Pgv - mPhp); // intermidiat pressure if (mParameters->Trh == 0) mPip = mPhp; else - mPip_next=mPip + dt / mParameters->Trh * (mPhp - mPip); + mPip_next = mPip + dt / mParameters->Trh * (mPhp - mPip); // lower pressure if (mParameters->Tco == 0) mPlp = mPip; else - mPlp_next=mPlp + dt / mParameters->Tco *(mPip - mPlp); + mPlp_next = mPlp + dt / mParameters->Tco *(mPip - mPlp); // Output mPm = mPhp * mParameters->Fhp + mPip * mParameters->Fip + mPlp * mParameters->Flp; diff --git a/dpsim-models/src/Signal/SteamTurbineGovernor.cpp b/dpsim-models/src/Signal/SteamTurbineGovernor.cpp index 9ede27ddf1..c649274e0e 100644 --- a/dpsim-models/src/Signal/SteamTurbineGovernor.cpp +++ b/dpsim-models/src/Signal/SteamTurbineGovernor.cpp @@ -11,6 +11,10 @@ void SteamTurbineGovernor::setParameters(std::shared_ptr(parameters)){ mParameters = params; + if (mParameters->T2==0){ + SPDLOG_LOGGER_ERROR(mSLog, "The parameter T2 can not be equal to zero!"); + throw CPS::Exception(); + } SPDLOG_LOGGER_INFO(mSLog, "\nSteam Governor parameters:" "\nOmRef: {:e}" @@ -21,11 +25,13 @@ void SteamTurbineGovernor::setParameters(std::shared_ptrOmRef, mParameters->R, - mParameters->T1, mParameters->T2, - mParameters->T3, mParameters->dPmax, mParameters->dPmin, - mParameters->Pmax, mParameters->Pmin); + mParameters->T1, mParameters->T2, mParameters->T3, + mParameters->dPmax, mParameters->dPmin, + mParameters->Pmax, mParameters->Pmin, + mParameters->Kbc); mSLog->flush(); } else { std::cout << "Type of parameters class of " << this->name() << " has to be SteamGorvernorParameters!" << std::endl; @@ -35,21 +41,25 @@ void SteamTurbineGovernor::setParameters(std::shared_ptr=0 && Pref<=1) { - // Steady state at O equal to Om_ref (50Hz/60HZ) + // Steady state at t=0 equal to Om_ref (50Hz/60HZ) mPref = Pref; + mDelOm = 0; mDelOm_prev = 0; - mDelOm = 0; - mP1=0; - mP1_next=0; - mP=0; - mDelPgv = 0; - mPgv = Pref; - mPgv_next = Pref; - mPlim_in = Pref; - mPlim_in_next = Pref; + mDelOm_2prev = 0; mP1 = 0; - mP1_next = 0; + mP1_prev = 0; mP = 0; + mDerPgv = 0; + mPgvLim = Pref; + mPgv = Pref; + + if (mParameters->T1 == 0) { + mCa = 0; + mCb = 0; + } else { + mCa = mParameters->T2 / mParameters->T1; + mCb = (mParameters->T1 - mParameters->T2) / mParameters->T1; + } SPDLOG_LOGGER_INFO(mSLog, "\nSteam Governor initial values:" @@ -57,7 +67,7 @@ void SteamTurbineGovernor::initialize(Real Pref) { "\nDelOm: {:f}" "\nDelPgv: {:f}" "\nPgv: {:f}", - mPref, mDelOm, mDelPgv, mPgv); + mPref, mDelOm, mDerPgv, mPgv); mSLog->flush(); } else { SPDLOG_LOGGER_INFO(mSLog, @@ -69,56 +79,42 @@ void SteamTurbineGovernor::initialize(Real Pref) { Real SteamTurbineGovernor::step(Real Omega, Real dt) { - // WIndup is implemented to compare the models to IAEW. If no windup is desired set Kbc=0 - const Real cKbc=10; - - const Real cA=mParameters->T2/mParameters->T1; - const Real cB=(mParameters->T1 - mParameters->T2) / mParameters->T1; - // write the values that were calculated in the previous step + mDelOm_2prev = mDelOm_prev; mDelOm_prev = mDelOm; - mPgv = mPgv_next; - mPlim_in = mPlim_in_next; - mP1 = mP1_next; + mP1_prev = mP1; // Calculate the input of the governor for time step k - mDelOm = mParameters->OmRef-Omega; + mDelOm = mParameters->OmRef - Omega; // Transfer function 1/R (1+sT2)/(s+T1) = 1/R (T2/T1 + (T1-T2)/T1 *1/(1+sT1)) = P(s)/delOm(s) - if(mParameters->T1==0) { - mP = (1/mParameters->R) * (mDelOm + (mParameters->T2/dt) * (mDelOm-mDelOm_prev)); + if (mParameters->T1 == 0) { + mP = (1 / mParameters->R) * (mDelOm_prev + (mParameters->T2 / dt) * (mDelOm_prev - mDelOm_2prev)); } else { - mP1_next = mP1+(dt/mParameters->T1) * (mDelOm*cB-mP1); - mP = (1/mParameters->R) * (mP1+mDelOm * cA); + mP1 = mP1_prev + (dt / mParameters->T1) * (mDelOm_prev * mCb - mP1_prev); + mP = (1 / mParameters->R) * (mP1_prev + mDelOm_prev * mCa); } - // Calculate thee input of integrator in PT1 via values of controller and output of governor - mDelPgv = (mPref + mP - mPgv) / mParameters->T3; - if (mDelPgvdPmin) - mDelPgv = mParameters->dPmin; - if(mDelPgv>mParameters->dPmax) - mDelPgv = mParameters->dPmax; - - // Calculating output of PT1 actuator, the output of the governor, without windup - /* - mPgv_next = dt * mDelPgv + mPgv; - if(mPgv_nextPmin) - mPgv_next = mParameters->Pmin; - if(mPgv_next>mParameters->Pmax) - mPgv_next = mParameters->Pmax; */ - - // Calculating output of PT1 actuator, the output of the governor, including windup - - mPlim_in_next = dt *(mDelPgv - cKbc*(mPlim_in - mPgv)) + mPlim_in; - if(mPlim_in_nextPmin){ - mPgv_next = mParameters->Pmin; - } - else if(mPlim_in_next>mParameters->Pmax){ - mPgv_next = mParameters->Pmax; - } - else{ - mPgv_next=mPlim_in_next; - } + // Calculate the input of integrator + mDerPgv = 1. / mParameters->T3 * (mPref + mP - mPgv); + // TODO: use module of Pgv? + if (mDerPgv < mParameters->dPmin) + mDerPgv = mParameters->dPmin; + if(mDerPgv > mParameters->dPmax) + mDerPgv = mParameters->dPmax; + mDerPgv = mDerPgv - mParameters->Kbc * (mPgvLim - mPgv); + + // Calculate PgvLim (before the limiter) + // use Pgv instead? + mPgvLim = mPgvLim + dt * mDerPgv; + + // Calculating output of the governor + if (mPgvLim < mParameters->Pmin) + mPgv = mParameters->Pmin; + else if (mPgvLim > mParameters->Pmax) + mPgv = mParameters->Pmax; + else + mPgv = mPgvLim; return mPgv; } diff --git a/dpsim-models/src/Signal/TurbineGovernorType1.cpp b/dpsim-models/src/Signal/TurbineGovernorType1.cpp index 565f7278a9..d9e1ef7757 100644 --- a/dpsim-models/src/Signal/TurbineGovernorType1.cpp +++ b/dpsim-models/src/Signal/TurbineGovernorType1.cpp @@ -56,30 +56,31 @@ void TurbineGovernorType1::initialize(Real PmRef) { } Real TurbineGovernorType1::step(Real Omega, Real dt) { - - /// update state variables at time k-1 + /// output is Tm at t=k + + /// update state variables at time k mXg1_prev = mXg1; mXg2_prev = mXg2; mXg3_prev = mXg3; - /// Input of speed relay + /// Input of speed relay at t=k Real Pin = mPmRef + (mParameters->OmRef - Omega) / mParameters->R; if (Pin>mParameters->Pmax) Pin = mParameters->Pmax; if (PinPmin) Pin = mParameters->Pmin; - /// Governor + /// update Governor state variable at time k+1 mXg1 = mXg1_prev + dt / mParameters->Ts * (Pin - mXg1_prev); - /// Servo + /// update Servo state variable at time k+1 mXg2 = mXg2_prev + dt / mParameters->Tc * ((1 - mParameters->T3 / mParameters->Tc) * mXg1_prev - mXg2_prev); - /// Reheat + /// update reheat state variable at time k+1 mXg3 = mXg3_prev + dt / mParameters->T5 * ((1- mParameters->T4 / mParameters->T5) * (mXg2_prev + mParameters->T3 / mParameters->Tc * mXg1_prev) - mXg3_prev); - /// Mechanical torque - mTm = mXg3 + mParameters->T4 / mParameters->T5 * (mXg2 + mParameters->T3 / mParameters->Tc * mXg1); + /// Mechanical torque at time k + mTm = mXg3_prev + mParameters->T4 / mParameters->T5 * (mXg2_prev + mParameters->T3 / mParameters->Tc * mXg1_prev); return mTm; } diff --git a/dpsim/src/pybind/SignalComponents.cpp b/dpsim/src/pybind/SignalComponents.cpp index 5e115bca53..3babd64f56 100644 --- a/dpsim/src/pybind/SignalComponents.cpp +++ b/dpsim/src/pybind/SignalComponents.cpp @@ -116,8 +116,8 @@ void addSignalComponents(py::module_ mSignal) { py::class_, CPS::Base::GovernorParameters>(mSignal, "TurbineGovernorType1Parameters", py::multiple_inheritance()) .def(py::init()) - .def_readwrite("Pmax", &CPS::Signal::TurbineGovernorType1Parameters::Pmax) - .def_readwrite("Pmin", &CPS::Signal::TurbineGovernorType1Parameters::Pmin) + .def_readwrite("Tmax", &CPS::Signal::TurbineGovernorType1Parameters::Pmax) + .def_readwrite("Tmin", &CPS::Signal::TurbineGovernorType1Parameters::Pmin) .def_readwrite("R", &CPS::Signal::TurbineGovernorType1Parameters::R) .def_readwrite("T3", &CPS::Signal::TurbineGovernorType1Parameters::T3) .def_readwrite("T4", &CPS::Signal::TurbineGovernorType1Parameters::T4) @@ -144,7 +144,8 @@ void addSignalComponents(py::module_ mSignal) { .def_readwrite("dPmin", &CPS::Signal::SteamGorvernorParameters::dPmin) .def_readwrite("Pmax", &CPS::Signal::SteamGorvernorParameters::Pmax) .def_readwrite("Pmin", &CPS::Signal::SteamGorvernorParameters::Pmin) - .def_readwrite("OmRef", &CPS::Signal::SteamGorvernorParameters::OmRef); + .def_readwrite("OmRef", &CPS::Signal::SteamGorvernorParameters::OmRef) + .def_readwrite("Kbc", &CPS::Signal::SteamGorvernorParameters::Kbc); // Turbines py::class_, CPS::Base::Turbine>(mSignal, "HydroTurbine", py::multiple_inheritance()) diff --git a/examples/Notebooks/Circuits/DP_EMT_Validation_ReducedOrderSG_VBR_SMIB_Fault_withControllers.ipynb b/examples/Notebooks/Circuits/DP_EMT_Validation_ReducedOrderSG_VBR_SMIB_Fault_withControllers.ipynb index f85e740c22..9562de61ea 100644 --- a/examples/Notebooks/Circuits/DP_EMT_Validation_ReducedOrderSG_VBR_SMIB_Fault_withControllers.ipynb +++ b/examples/Notebooks/Circuits/DP_EMT_Validation_ReducedOrderSG_VBR_SMIB_Fault_withControllers.ipynb @@ -103,8 +103,8 @@ "governor_parameters = dpsimpy.signal.TurbineGovernorType1Parameters()\n", "governor_parameters.OmRef = 1.0\n", "governor_parameters.R = 0.02\n", - "governor_parameters.Pmax = 1.2\n", - "governor_parameters.Pmin = 0.3\n", + "governor_parameters.Tmax = 1.2\n", + "governor_parameters.Tmin = 0.3\n", "governor_parameters.Ts = 0.1\n", "governor_parameters.Tc = 0.45\n", "governor_parameters.T3 = 0.0\n", diff --git a/examples/Notebooks/Circuits/SP_Validation_ReducedOrderSG_VBR_SMIB_Fault_withControllers.ipynb b/examples/Notebooks/Circuits/SP_Validation_ReducedOrderSG_VBR_SMIB_Fault_withControllers.ipynb index 42c0fb6fa1..3e95779bed 100644 --- a/examples/Notebooks/Circuits/SP_Validation_ReducedOrderSG_VBR_SMIB_Fault_withControllers.ipynb +++ b/examples/Notebooks/Circuits/SP_Validation_ReducedOrderSG_VBR_SMIB_Fault_withControllers.ipynb @@ -309,8 +309,8 @@ "governor_parameters = dpsimpy.signal.TurbineGovernorType1Parameters()\n", "governor_parameters.OmRef = 1.0\n", "governor_parameters.R = 0.02\n", - "governor_parameters.Pmax = 1.2\n", - "governor_parameters.Pmin = 0.3\n", + "governor_parameters.Tmax = 1.2\n", + "governor_parameters.Tmin = 0.3\n", "governor_parameters.Ts = 0.1\n", "governor_parameters.Tc = 0.45\n", "governor_parameters.T3 = 0.0\n", diff --git a/python/src/dpsim/matpower.py b/python/src/dpsim/matpower.py index f26a138821..282a900ca8 100644 --- a/python/src/dpsim/matpower.py +++ b/python/src/dpsim/matpower.py @@ -403,7 +403,7 @@ def map_synchronous_machine(self, index, bus_index, bus_type=dpsimpy.PowerflowBu # --> two gens associated to one node... gen_model = self.mpc_dyn_gen_data['model'][gen_dyn_row_idx] - gen_model=4 + gen_model = 4 gen_baseS = self.mpc_dyn_gen_data['BaseS'][gen_dyn_row_idx] * mw_w H = self.mpc_dyn_gen_data['H'][gen_dyn_row_idx] Ra = self.mpc_dyn_gen_data['Ra'][gen_dyn_row_idx] @@ -499,7 +499,7 @@ def map_synchronous_machine(self, index, bus_index, bus_type=dpsimpy.PowerflowBu tg_row_idx = self.mpc_tg_data.index[self.mpc_tg_data['bus'] == int(bus_index)].tolist()[0] governor = dpsimpy.signal.TurbineGovernorType1("TG_Bus" + bus_index, self.log_level) governor_parameters = dpsimpy.signal.TurbineGovernorType1Parameters() - #governor_parameters.OmRef"] = self.mpc_tg_data['OmRef'][tg_row_idx] + #governor_parameters.OmRef = self.mpc_tg_data['OmRef'][tg_row_idx] governor_parameters.OmRef = 1 governor_parameters.R = self.mpc_tg_data['R'][tg_row_idx] governor_parameters.Tmax = self.mpc_tg_data['Tmax'][tg_row_idx]