\( \DeclareMathOperator{\abs}{abs} \newcommand{\ensuremath}[1]{\mbox{$#1$}} \)
(%i1) | load ( "utilities.wxm" ) ; |
\[\tag{%o1} utilities.wxm\]
(%i2) | simp : false ; |
\[\tag{%o2} \mbox{false}\]
1 Definintion
(%i3) | tf : u ( s ) / e ( s ) = ( Kp + Ki / s + Kd · s ) · ( 1 / ( Tf · s + 1 ) ) ; |
\[\tag{%o3} \frac{\operatorname{u}(s)}{\operatorname{e}(s)}=\left( \mathit{Kp}+\frac{\mathit{Ki}}{s}+\mathit{Kd} s\right) \, \frac{1}{\mathit{Tf} s+1}\]
(%i4) | num_integrate : backward_euler ; |
\[\tag{%o4} \mathit{backward\_ euler}\]
(%i5) | simp : true ; |
\[\tag{%o5} \mbox{true}\]
(%i6) | num_integrate ( diff ( y ( t ) , t ) = f ( y ( t ) , t ) ) ; |
\[\tag{%o6} {y_k}=h \operatorname{f}\left( {y_k}\operatorname{,}h k\right) +{y_{k-1}}\]
2 Realization
(%i7) | tffr : partfrac ( tf · denom ( lhs ( tf ) ) , s ) ; |
\[\tag{%o7} \operatorname{u}(s)=-\frac{\left( \mathit{Ki}\, {{\mathit{Tf}}^{2}}-\mathit{Kp}\, \mathit{Tf}+\mathit{Kd}\right) \operatorname{e}(s)}{\mathit{Tf}\, \left( \mathit{Tf} s+1\right) }+\frac{\mathit{Ki} \operatorname{e}(s)}{s}+\frac{\mathit{Kd} \operatorname{e}(s)}{\mathit{Tf}}\]
(%i8) | tfD : D ( s ) = part ( tffr , 2 , 1 ) ; |
\[\tag{%o8} \operatorname{D}(s)=-\frac{\left( \mathit{Ki}\, {{\mathit{Tf}}^{2}}-\mathit{Kp}\, \mathit{Tf}+\mathit{Kd}\right) \operatorname{e}(s)}{\mathit{Tf}\, \left( \mathit{Tf} s+1\right) }\]
(%i9) | tfI : I ( s ) = part ( tffr , 2 , 2 ) ; |
\[\tag{%o9} \operatorname{I}(s)=\frac{\mathit{Ki} \operatorname{e}(s)}{s}\]
(%i10) | tfY : subst ( [ reverse ( tfD ) , reverse ( tfI ) ] , tffr ) ; |
\[\tag{%o10} \operatorname{u}(s)=\frac{\mathit{Kd} \operatorname{e}(s)}{\mathit{Tf}}+\operatorname{I}(s)+\operatorname{D}(s)\]
(%i11) | od : map ( ilp , [ tfD , tfI , tfY ] ) ; |
\[\tag{%o11} [\frac{d}{d t} \operatorname{D}(t)=-\frac{\left( \mathit{Ki}\, {{\mathit{Tf}}^{2}}-\mathit{Kp}\, \mathit{Tf}+\mathit{Kd}\right) \operatorname{e}(t)+\mathit{Tf} \operatorname{D}(t)}{{{\mathit{Tf}}^{2}}}\operatorname{,}\frac{d}{d t} \operatorname{I}(t)=\mathit{Ki} \operatorname{e}(t)\operatorname{,}\operatorname{u}(t)=\frac{\mathit{Kd} \operatorname{e}(t)+\mathit{Tf} \operatorname{I}(t)+\mathit{Tf} \operatorname{D}(t)}{\mathit{Tf}}]\]
(%i12) | pidk : [ num_integrate ( od [ 1 ] ) , num_integrate ( od [ 2 ] ) , discretize ( od [ 3 ] ) ] ; |
\[\tag{%o12} [{D_k}=-\frac{\left( \mathit{Ki}\, {{\mathit{Tf}}^{2}}-\mathit{Kp}\, \mathit{Tf}+\mathit{Kd}\right) h\, {e_k}-{{\mathit{Tf}}^{2}}\, {D_{k-1}}}{\mathit{Tf} h+{{\mathit{Tf}}^{2}}}\operatorname{,}{I_k}=\mathit{Ki} h\, {e_k}+{I_{k-1}}\operatorname{,}{u_k}=\frac{\mathit{Kd}\, {e_k}+\mathit{Tf}\, {I_k}+\mathit{Tf}\, {D_k}}{\mathit{Tf}}]\]
(%i13) | vin : [ D [ k − 1 ] , I [ k − 1 ] , e [ k ] , e [ k − 1 ] ] ; |
\[\tag{%o13} [{D_{k-1}}\operatorname{,}{I_{k-1}}\operatorname{,}{e_k}\operatorname{,}{e_{k-1}}]\]
(%i14) | vout : map ( lhs , pidk ) ; |
\[\tag{%o14} [{D_k}\operatorname{,}{I_k}\operatorname{,}{u_k}]\]
(%i15) | − augcoefmatrix ( solve ( pidk , vout ) [ 1 ] , vin ) ; |
\[\tag{%o15} \begin{pmatrix}\frac{\mathit{Tf}}{h+\mathit{Tf}} & 0 & -\frac{\left( \mathit{Ki}\, {{\mathit{Tf}}^{2}}-\mathit{Kp}\, \mathit{Tf}+\mathit{Kd}\right) h}{\mathit{Tf} h+{{\mathit{Tf}}^{2}}} & 0 & -{D_k}\\ 0 & 1 & \mathit{Ki} h & 0 & -{I_k}\\ \frac{\mathit{Tf}}{h+\mathit{Tf}} & 1 & \frac{\mathit{Ki}\, {{h}^{2}}+\mathit{Kp} h+\mathit{Kd}}{h+\mathit{Tf}} & 0 & -{u_k}\end{pmatrix}\]
(%i16) | M0 : − augcoefmatrix ( pidk , vin ) ; |
\[\tag{%o16} \begin{pmatrix}\frac{\mathit{Tf}}{h+\mathit{Tf}} & 0 & -\frac{\left( \mathit{Ki}\, {{\mathit{Tf}}^{2}}-\mathit{Kp}\, \mathit{Tf}+\mathit{Kd}\right) h}{\mathit{Tf} h+{{\mathit{Tf}}^{2}}} & 0 & -{D_k}\\ 0 & 1 & \mathit{Ki} h & 0 & -{I_k}\\ 0 & 0 & \frac{\mathit{Kd}}{\mathit{Tf}} & 0 & \frac{\mathit{Tf}\, {I_k}+\mathit{Tf}\, {D_k}}{\mathit{Tf}}-{u_k}\end{pmatrix}\]
(%i17) | constlist : delete ( false , list_matrix_entries ( genmatrix ( lambda ( [ r , c ] , if numberp ( M0 [ r , c ] ) then false else concat ( [ A , B , C ] [ r ] , c ) = M0 [ r , c ] ) , length ( vout ) , length ( vin ) ) ) ) ; |
\[\tag{%o17} [\mathit{A1}=\frac{\mathit{Tf}}{h+\mathit{Tf}}\operatorname{,}\mathit{A3}=-\frac{\left( \mathit{Ki}\, {{\mathit{Tf}}^{2}}-\mathit{Kp}\, \mathit{Tf}+\mathit{Kd}\right) h}{\mathit{Tf} h+{{\mathit{Tf}}^{2}}}\operatorname{,}\mathit{B3}=\mathit{Ki} h\operatorname{,}\mathit{C3}=\frac{\mathit{Kd}}{\mathit{Tf}}]\]
(%i33) | block ( [ ratfac : true ] , ratsimp ( constlist ) ) ; |
\[\tag{%o33} [\mathit{A1}=\frac{\mathit{Tf}}{h+\mathit{Tf}}\operatorname{,}\mathit{A3}=-\frac{\left( \mathit{Ki}\, {{\mathit{Tf}}^{2}}-\mathit{Kp}\, \mathit{Tf}+\mathit{Kd}\right) h}{\mathit{Tf}\, \left( h+\mathit{Tf}\right) }\operatorname{,}\mathit{B3}=\mathit{Ki} h\operatorname{,}\mathit{C3}=\frac{\mathit{Kd}}{\mathit{Tf}}]\]
(%i19) | M1 : subst ( map ( reverse , constlist ) , M0 ) ; |
\[\tag{%o19} \begin{pmatrix}\mathit{A1} & 0 & \mathit{A3} & 0 & -{D_k}\\ 0 & 1 & \mathit{B3} & 0 & -{I_k}\\ 0 & 0 & \mathit{C3} & 0 & \frac{\mathit{Tf}\, {I_k}+\mathit{Tf}\, {D_k}}{\mathit{Tf}}-{u_k}\end{pmatrix}\]
(%i20) | M2 : M1 . append ( vin , [ 1 ] ) ; |
\[\tag{%o20} \begin{pmatrix}\mathit{A3}\, {e_k}-{D_k}+\mathit{A1}\, {D_{k-1}}\\ \mathit{B3}\, {e_k}-{I_k}+{I_{k-1}}\\ -{u_k}+\mathit{C3}\, {e_k}+\frac{\mathit{Tf}\, {I_k}+\mathit{Tf}\, {D_k}}{\mathit{Tf}}\end{pmatrix}\]
(%i21) | f0 : flatten ( map ( solve , list_matrix_entries ( M2 ) , vout ) ) ; |
\[\tag{%o21} [{D_k}=\mathit{A3}\, {e_k}+\mathit{A1}\, {D_{k-1}}\operatorname{,}{I_k}=\mathit{B3}\, {e_k}+{I_{k-1}}\operatorname{,}{u_k}=\mathit{C3}\, {e_k}+{I_k}+{D_k}]\]
3 Initialization
3.1 Steady State Initialization
(%i22) | solve ( append ( f0 , [ I [ k ] = I [ k − 1 ] , D [ k ] = D [ k − 1 ] , e [ k ] = e [ k − 1 ] ] ) , [ I [ k ] , D [ k ] , D [ k − 1 ] , I [ k − 1 ] , e [ k ] , e [ k − 1 ] ] ) ; |
\[\tag{%o22} [[{I_k}={u_k}\operatorname{,}{D_k}=0\operatorname{,}{D_{k-1}}=0\operatorname{,}{I_{k-1}}={u_k}\operatorname{,}{e_k}=0\operatorname{,}{e_{k-1}}=0]]\]
3.2 Partial Re-Initialization
(%i23) | solve ( f0 , [ I [ k ] , I [ k − 1 ] , D [ k − 1 ] ] ) ; |
\[\tag{%o23} [[{I_k}={u_k}-\mathit{C3}\, {e_k}-{D_k}\operatorname{,}{I_{k-1}}={u_k}+\left( -\mathit{C3}-\mathit{B3}\right) \, {e_k}-{D_k}\operatorname{,}{D_{k-1}}=-\frac{\mathit{A3}\, {e_k}-{D_k}}{\mathit{A1}}]]\]
3.3 Initialization by Input and Output Data
(%i24) | f1 : subst ( k − 1 , k , f0 ) ; |
\[\tag{%o24} [{D_{k-1}}=\mathit{A3}\, {e_{k-1}}+\mathit{A1}\, {D_{k-2}}\operatorname{,}{I_{k-1}}=\mathit{B3}\, {e_{k-1}}+{I_{k-2}}\operatorname{,}{u_{k-1}}=\mathit{C3}\, {e_{k-1}}+{I_{k-1}}+{D_{k-1}}]\]
(%i25) | ratsimp ( solve ( append ( f0 , f1 ) , [ D [ k ] , I [ k ] , D [ k − 1 ] , I [ k − 1 ] , D [ k − 2 ] , I [ k − 2 ] ] ) [ 1 ] ) ; |
\[\tag{%o25} [{D_k}=\frac{\mathit{A1}\, {u_k}+\left( -\mathit{A1}\, \mathit{C3}-\mathit{A1}\, \mathit{B3}-\mathit{A3}\right) \, {e_k}-\mathit{A1}\, {u_{k-1}}+\mathit{A1}\, \mathit{C3}\, {e_{k-1}}}{\mathit{A1}-1}\operatorname{,}{I_k}=-\frac{{u_k}+\left( -\mathit{C3}-\mathit{A1}\, \mathit{B3}-\mathit{A3}\right) \, {e_k}-\mathit{A1}\, {u_{k-1}}+\mathit{A1}\, \mathit{C3}\, {e_{k-1}}}{\mathit{A1}-1}\operatorname{,}{D_{k-1}}=\frac{{u_k}+\left( -\mathit{C3}-\mathit{B3}-\mathit{A3}\right) \, {e_k}-{u_{k-1}}+\mathit{C3}\, {e_{k-1}}}{\mathit{A1}-1}\operatorname{,}{I_{k-1}}=-\frac{{u_k}+\left( -\mathit{C3}-\mathit{B3}-\mathit{A3}\right) \, {e_k}-\mathit{A1}\, {u_{k-1}}+\mathit{A1}\, \mathit{C3}\, {e_{k-1}}}{\mathit{A1}-1}\operatorname{,}{D_{k-2}}=\frac{{u_k}+\left( -\mathit{C3}-\mathit{B3}-\mathit{A3}\right) \, {e_k}-{u_{k-1}}+\left( \mathit{C3}+\left( 1-\mathit{A1}\right) \, \mathit{A3}\right) \, {e_{k-1}}}{{{\mathit{A1}}^{2}}-\mathit{A1}}\operatorname{,}{I_{k-2}}=-\frac{{u_k}+\left( -\mathit{C3}-\mathit{B3}-\mathit{A3}\right) \, {e_k}-\mathit{A1}\, {u_{k-1}}+\left( \mathit{A1}\, \mathit{C3}+\left( \mathit{A1}-1\right) \, \mathit{B3}\right) \, {e_{k-1}}}{\mathit{A1}-1}]\]
Created with wxMaxima.