-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathP3_es.html
132 lines (130 loc) · 592 KB
/
P3_es.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta name="generator" content="MATLAB R2018a"><meta http-equiv="X-UA-Compatible" content="IE=edge,IE=9,chrome=1"><title>Práctica 3: Diseño e implementación de Controladores PID</title><style type="text/css">
* {margin: 0; padding: 0;}
body {text-align: start; line-height: 17.2339992523193px; min-height: 0px; white-space: normal; color: rgb(0, 0, 0); font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-style: normal; font-size: 13.9999990463257px; font-weight: normal; text-decoration: none; white-space: normal; }
h1, h2 {font-weight: normal;}
.content { padding: 30px; }
.S0 { margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S1 { text-align: left; line-height: 26.3999977111816px; min-height: 24px; white-space: pre-wrap; color: rgb(213, 80, 0); font-family: Helvetica, Arial, sans-serif; font-size: 22px; white-space: pre-wrap; margin-left: 4px; margin-top: 3px; margin-bottom: 15px; margin-right: 10px; }
.S2 { min-height: 0px; margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S3 { font-weight: bold; margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S4 { text-align: left; line-height: 21px; min-height: 17px; white-space: pre-wrap; font-family: Helvetica, Arial, sans-serif; white-space: pre-wrap; margin-left: 4px; margin-top: 2px; margin-bottom: 9px; margin-right: 10px; }
.S5 { font-family: Helvetica, Arial, sans-serif; margin-left: 0px; margin-top: 10px; margin-bottom: 20px; margin-right: 0px; }
.S6 { text-align: left; line-height: 20.9999980926514px; white-space: pre-wrap; white-space: pre-wrap; margin-left: 55.9999961853027px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S7 { margin-left: 3px; margin-top: 10px; margin-bottom: 4px; margin-right: 3px; }
.S8 { min-height: 18px; white-space: nowrap; white-space: nowrap; margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S9 { min-height: 0px; white-space: pre; white-space: pre; margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S10 { color: rgb(34, 139, 34); margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S11 { margin-left: 3px; margin-top: 10px; margin-bottom: 10px; margin-right: 3px; }
.S12 { text-align: left; line-height: 21px; min-height: 17px; white-space: pre-wrap; font-family: Helvetica, Arial, sans-serif; white-space: pre-wrap; margin-left: 4px; margin-top: 10px; margin-bottom: 9px; margin-right: 10px; }
.S13 { color: rgb(0, 0, 255); margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S14 { color: rgb(160, 32, 240); margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S15 { color: rgb(64, 64, 64); margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S16 { font-style: italic; margin-left: 0px; margin-top: 0px; margin-bottom: 0px; margin-right: 0px; }
.S17 { text-align: center; line-height: 21px; min-height: 17px; white-space: pre-wrap; font-family: Helvetica, Arial, sans-serif; white-space: pre-wrap; margin-left: 4px; margin-top: 2px; margin-bottom: 9px; margin-right: 10px; }
.CodeBlock {margin: 10px 0 10px 0; background-color: #F7F7F7;}
.CodeBlock+.paragraphNode {margin-top: 10px;}
.lineNode {padding-left: 10px; border-left: 1px solid #E9E9E9; border-right: 1px solid #E9E9E9;}
.inlineWrapper:first-child .lineNode,.inlineWrapper.outputs+.inlineWrapper .lineNode {padding-top: 5px; border-top: 1px solid #E9E9E9;}
.inlineWrapper:last-child .lineNode,.inlineWrapper.outputs .lineNode {padding-bottom: 5px; border-bottom: 1px solid #E9E9E9;}
.lineNode .textBox {white-space: pre;}
.outputGroup {margin: 2px 0 2px 0; padding: 2px 2px 2px 4px;}
.outputRegion {}
.outputParagraph {color: rgba(64, 64, 64, 1); padding: 10px 0 6px 17px; background: white; overflow-x: hidden;}
.inlineWrapper:last-child .outputParagraph {border-bottom-left-radius: 4px; border-bottom-right-radius: 4px;}
.outputParagraph:empty {margin: 0;}
.inlineElement .symbolicElement {margin-top: 1px; margin-bottom: 1px;}
.embeddedOutputsSymbolicElement .MathEquation {margin-top: 4px; margin-bottom: 4px;}
.embeddedOutputsSymbolicElement .MathEquation.displaySymbolicElement {margin-left: 15px;}
.embeddedOutputsSymbolicElement .MathEquation.inlineSymbolicElement {}
.embeddedOutputsSymbolicElement {overflow-x: auto; overflow-y: auto;}
.embeddedOutputsSymbolicElement { overflow: initial !important;}
.embeddedOutputsSymbolicElement { width: 100% !important; }
.embeddedOutputsTextElement,.embeddedOutputsVariableStringElement {white-space: pre; word-wrap: initial; min-height: 18px; max-height: 250px; overflow: auto;}
.textElement,.rtcDataTipElement .textElement {padding-top: 3px;}
.embeddedOutputsTextElement.inlineElement,.embeddedOutputsVariableStringElement.inlineElement {}
.inlineElement .textElement {}
.embeddedOutputsTextElement,.embeddedOutputsVariableStringElement { max-height: none !important; overflow: initial !important;}
.veSpecifier {}
.veContainer {}
.veSpecifierBox {height: 400px; width: 500px;}
.veSpecifier .veTable {padding-top: 3px; padding-bottom: 4px;}
.veSpecifierBox .veSpecifier .veContainer {position: relative; width: 100%; height: 370px;}
.veSpecifierBox .dijitDialogPaneContent {width: 97% !important; height: 88% !important;}
.veSpecifier .veTable .rowHeadersWrapper {padding-bottom: 0;}
.veSpecifier .veTable .scroller .variableEditorRenderers {padding-right: 3px; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none;}
.veSpecifier .veTable .topHeaderWrapper,.veSpecifier .veTable .bottomRowHeaderWrapper {visibility: hidden; z-index: 0;}
.veMetaSummary {font-style: italic;}
.veSpecifier .veTable .scroller {overflow: hidden;}
.veSpecifier .veTable:hover .scroller {overflow: auto;}
.veSpecifier .veVariableName,.veSpecifier .veDimensionFont {font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 12px;}
.veSpecifier .veVariableName {padding-top: 2px;}
.veSpecifier .veDimensionFont {font-style: italic; color: #9A9A9A;}
.veSpecifier .scroller::-webkit-scrollbar-track {background-color: white;}
.veSpecifier .scroller::-webkit-scrollbar-corner {background-color: white;}
.veSpecifier .veTable .topRowHeaderWrapper {border: none; background-color: #F8F9FA;}
.veSpecifier .mw_type_ListBase.showCellBorders,.veSpecifier .veTable .topHeaderWrapper,.veSpecifier .veTable .bottomRowHeaderWrapper,.veSpecifier .veTable .verticalScrollSpacer,.veSpecifier .veTable .horizontalScrollSpacer {border: none;}
.veSpecifier .veTable .dataScrollerNode {border: 1px solid #BFBFBF;}
.veSpecifier .veTable .columnHeaderNode,.veSpecifier .veTable .rowHeaderNode,.veSpecifier .veTable .dataBody {font-family: Arial; font-size: 13px;}
.veSpecifier .veTable .columnHeaderNode,.veSpecifier .veTable .rowHeaderNode {color: #7F7F7F;}
.veSpecifier .veTable .dataBody {color: #000000;}
.veSpecifier .veTable .columnHeaderNode .cell .drag,.veSpecifier .veTable .columnHeaderNode .cell .header,.veSpecifier .veTable .topHeaderWrapper,.veSpecifier .veTable .bottomRowHeaderWrapper {background-color: #F8F9FA;}
.veSpecifier .veTable .columnHeaderNode .cell .dragBorder {border-right: 1px solid #F8F9FA;}
.veSpecifier .veTable .rowHeaderNode .cell {padding-top: 3px; text-align: center; border-bottom: 1px solid #F8F9FA;}
.veSpecifier .veTable .dataBody .cell .plainText {text-align: right;}
.veSpecifier .veTable .dataBody .row .cell {border-bottom: 1px solid #E9E9E9; border-right: 1px solid #E9E9E9;}
.embeddedOutputsVariableElement {white-space: pre-wrap; word-wrap: break-word; min-height: 18px; max-height: 250px; overflow: auto;}
.variableElement {}
.embeddedOutputsVariableElement.inlineElement {}
.inlineElement .variableElement {}
.variableNameElement {margin-bottom: 3px; display: inline-block;}
.variableValue { width: 100% !important; }
.embeddedOutputsMatrixElement,.eoOutputWrapper .matrixElement {min-height: 18px; box-sizing: border-box;}
.embeddedOutputsMatrixElement .matrixElement,.eoOutputWrapper .matrixElement,.rtcDataTipElement .matrixElement {position: relative;}
.matrixElement .variableValue,.rtcDataTipElement .matrixElement .variableValue {white-space: pre; display: inline-block; vertical-align: top; overflow: hidden;}
.embeddedOutputsMatrixElement.inlineElement {}
.embeddedOutputsMatrixElement.inlineElement .topHeaderWrapper {display: none;}
.embeddedOutputsMatrixElement.inlineElement .veTable .body {padding-top: 0 !important; max-height: 100px;}
.inlineElement .matrixElement {max-height: 300px;}
.embeddedOutputsMatrixElement .matrixElement .valueContainer,.eoOutputWrapper .matrixElement .valueContainer,.rtcDataTipElement .matrixElement .valueContainer {white-space: nowrap; margin-bottom: 3px;}
.embeddedOutputsMatrixElement .matrixElement .valueContainer .horizontalEllipsis.hide,.embeddedOutputsMatrixElement .matrixElement .verticalEllipsis.hide,.eoOutputWrapper .matrixElement .valueContainer .horizontalEllipsis.hide,.eoOutputWrapper .matrixElement .verticalEllipsis.hide,.rtcDataTipElement .matrixElement .valueContainer .horizontalEllipsis.hide,.rtcDataTipElement .matrixElement .verticalEllipsis.hide {display: none;}
.embeddedOutputsVariableMatrixElement .matrixElement .valueContainer.hideEllipses .verticalEllipsis, .embeddedOutputsVariableMatrixElement .matrixElement .valueContainer.hideEllipses .horizontalEllipsis {display:none;}
.embeddedOutputsMatrixElement .matrixElement .valueContainer .horizontalEllipsis,.eoOutputWrapper .matrixElement .valueContainer .horizontalEllipsis {margin-bottom: -3px;}
.eoOutputWrapper .embeddedOutputsVariableMatrixElement .matrixElement .valueContainer {cursor: default !important;}
.matrixElement { max-height: none !important; }
.embeddedOutputsVariableTableElement .ClientViewDiv table tr {height: 22px; white-space: nowrap;}
.embeddedOutputsVariableTableElement .ClientViewDiv table tr td,.embeddedOutputsVariableTableElement .ClientViewDiv table tr th {min-width : 75px; max-width : 75px; background-color:white; text-overflow: ellipsis; font-family: 'Arial', sans-serif; font-size: 12px; overflow : hidden;}
.embeddedOutputsVariableTableElement .ClientViewDiv table tbody tr th {width: 34px; max-width: 100px;}
.embeddedOutputsVariableTableElement .ClientViewDiv table tr span {text-overflow: ellipsis; padding: 3px;}
.embeddedOutputsVariableTableElement .ClientViewDiv table tr th {color: rgba(0,0,0,0.5); padding: 3px; font-size: 9px;}
.embeddedOutputsVariableTableElement .ClientViewDiv table tr th:first-child {min-width: 28px; max-width: 250px;}
.dijitTooltipDialog .dijitTooltipContainer .dijitTooltipContents .alertPlugin-alertMessage {min-width: 12px; max-width: 400px; max-height: 300px; overflow: auto;}
.dijitTooltipDialog .alertPlugin-alertMessage::-webkit-scrollbar {width: 11px; height: 11px;}
.dijitTooltipDialog .alertPlugin-alertMessage::-webkit-scrollbar-track {background-color: rgba(0, 0, 0, 0);}
.dijitTooltipDialog .alertPlugin-alertMessage::-webkit-scrollbar-corner {background-color: rgba(0, 0, 0, 0);}
.dijitTooltipDialog .alertPlugin-alertMessage::-webkit-scrollbar-thumb {border-radius: 7px; background-color: rgba(0, 0, 0, 0.1); border: 2px solid rgba(0, 0, 0, 0); background-clip: padding-box;}
.dijitTooltipDialog .alertPlugin-alertMessage::-webkit-scrollbar-thumb:hover {background-color: rgba(0, 0, 0, 0.2);}
.dijitTooltipDialog .alertPlugin-alertMessage::-webkit-scrollbar-thumb {background-color: rgba(0, 0, 0, 0);}
.dijitTooltipDialog .alertPlugin-alertMessage:hover::-webkit-scrollbar-thumb {background-color: rgba(0, 0, 0, 0.1);}
.dijitTooltipDialog .alertPlugin-alertMessage:hover::-webkit-scrollbar-thumb:hover {background-color: rgba(0, 0, 0, 0.2);}
.alertPlugin-alertLine {position: absolute; display: initial; width: 40px; text-align: right; cursor: text;}
.alertPlugin-onTextLine {visibility: hidden;}
.alertPlugin-hasTooltip .alertPlugin-warningImg,.alertPlugin-hasTooltip .alertPlugin-errorImg {cursor: pointer;}
.alertPlugin-alertLine .alertPlugin-warningElement,.alertPlugin-alertLine .alertPlugin-errorElement {display: inline-block; margin-right: 4px;}
.alertPlugin-isStale {-webkit-filter: opacity(0.4) grayscale(80%); filter: opacity(0.4) grayscale(80%);}
.diagnosticMessage-wrapper {font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 12px;}
.diagnosticMessage-wrapper.diagnosticMessage-warningType {color: rgb(255,100,0);}
.diagnosticMessage-wrapper.diagnosticMessage-warningType a {color: rgb(255,100,0); text-decoration: underline;}
.diagnosticMessage-wrapper.diagnosticMessage-errorType {color: rgb(230,0,0);}
.diagnosticMessage-wrapper.diagnosticMessage-errorType a {color: rgb(230,0,0); text-decoration: underline;}
.diagnosticMessage-wrapper .diagnosticMessage-messagePart {white-space: pre-wrap;}
.diagnosticMessage-wrapper .diagnosticMessage-stackPart {white-space: pre;}
.embeddedOutputsWarningElement{min-height: 18px; max-height: 250px; overflow: auto;}
.embeddedOutputsWarningElement.inlineElement {}
.embeddedOutputsErrorElement {min-height: 18px; max-height: 250px; overflow: auto;}
.embeddedOutputsErrorElement.inlineElement {}
.variableNameElement .headerElement {color: rgb(179, 179, 179); font-style: italic;}
.variableNameElement .headerElement .headerDataType {color: rgb(147, 176, 230);}
.matrixElement .horizontalEllipsis,.rtcDataTipElement .matrixElement .horizontalEllipsis {display: inline-block; margin-top: 3px; width: 30px; height: 12px; background-repeat: no-repeat; background-image: url("");}
.matrixElement .verticalEllipsis,.textElement .verticalEllipsis,.rtcDataTipElement .matrixElement .verticalEllipsis,.rtcDataTipElement .textElement .verticalEllipsis {margin-left: 35px; width: 12px; height: 30px; background-repeat: no-repeat; background-image: url("");}
</style></head><body><div class = "content"><div class = 'SectionBlock containment'><h1 class = "S1"><span class = "S2"><span class="S3">Práctica 3: Diseño e implementación de Controladores PID</span></span></h1><div class = "S4"><span class = "S2"><span class="S0">Las prácticas de la asignatura control por computador consisten en el estudio de un servomecanismo de posicionamiento angular (LJ Technical Systems) controlado por un PC. Las sesiones de laboratorio P1 y P2 se centran en el análisis experimental de las respuestas temporal y frecuencial del sistema respectivamente. Las sesiones P3 y P4 se dedican al diseño de controladores PID. Por último, en la práctica P5 se diseñarán controladores en campo frecuencial.</span></span></div><div class = "S4"><span class = "S2"><span class="S3">OBJETIVO: Diseñar un controlador PI de velocidad de salida para que el sistema de lazo cerrado tenga un error estacionario nulo. Diseñar un controlador PID de la posición del eje de salida para la planta estudiada en las sesiones anteriores para que el sistema en lazo cerrado cumpla unas ciertas especificaciones.</span></span></div><div class = "S4"><span class = "S2"><span class="S3">En esta sesión el estudiante ha de:</span></span></div><ul class = "S5"><li class = "S6"><span class = "S0"><span class="S3">Diseñar un PI y un PID por asignación de polos.</span></span></li><li class = "S6"><span class = "S0"><span class="S3">Verificar experimentalmente los sistemas de control diseñados.</span></span></li></ul><div class = 'CodeBlock contiguous'><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Alternar entre los datos del experimento y los del directorio Resultados</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Si desea usar los datos del directorio Resultados = false</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Si desea usar datos propios = true</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">useExperimentalData = </span></span><span>false</span><span class = "S9"><span class="S0">;</span></span></div></div></div></div><div class = "S0"></div><div class = 'SectionBlock containment active'><h1 class = "S1"><span class = "S2"><span class="S0">Ejercicio 11: Diseño e implementación de un PI por asignación de polos.</span></span></h1><div class = "S4"><span class = "S2"><span class="S0">Diseñar un PI de control de velocidad que haga que la respuesta temporal a una entrada escalón no presente sobreimpulsos y que el tiempo de establecimiento (con el criterio del 2%) sea de 0.8 segundos. Para la simulación del controlador PI digital, abrir y ejecutar el modelo P3_Ex11a.slx. Para su comprobación con el motor, abrir y ejecutar el modelo P3_Ex11b.slx.</span></span></div><div class = 'CodeBlock contiguous'><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Planta</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">K0=0.82;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">tau0=0.26;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Periodo de muestreo</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Ts=0.01;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Especificaciones</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">xi=1;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">ts_2=0.8; </span><span class="S10">% tiempo de establecimiento con el criterio de 2%</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Tdes=ts_2/4;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">wn=5.8/(xi*ts_2);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Diseño del controlador</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Zdes=exp(-Ts/Tdes);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">alpha=exp(-Ts/tau0);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">beta=-2*exp(-Ts*xi*wn)*cos(wn*Ts*sqrt(1-xi^2));</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">gamma=exp(-2*Ts*xi*wn);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Ki_star=(gamma-alpha+beta+(alpha+1))/(2*K0*(1-alpha));</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Ki</span><span class="S0">=(2/Ts)*Ki_star;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Kp</span><span class="S0">=((beta+alpha+1)/(K0*(1-alpha)))-Ki_star;</span></span></div></div></div><div class = "S12"><span class = "S2"><span class="S0">Para diseñar el controlador, se han seguido los siguientes pasos. Primeramente, se ha digitalizado la planta con un mantenedor de orden cero y se ha escogido un controlador PI discretizado mediante la aproximación trapezoidal.</span></span></div><div class = "S4"><span style="vertical-align:-15px"><img src="" width="308" height="49.5" /></span></div><div class = "S4"><span style="vertical-align:-15px"><img src="" width="454.5" height="37" /></span></div><div class = "S4"><span class = "S2"><span class="S0"></span></span></div><div class = "S4"><span class = "S2"><span class="S0">Con lo cual la función de transferencia del lazo cerrado:</span></span></div><div class = "S4"><span style="vertical-align:-43px"><img src="" width="463" height="82" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Igualando la ecuación caracteristica real, con la ideal, podremos sintonizar nuestros parámetros.</span></span></div><div class = "S4"><span style="vertical-align:-21px"><img src="" width="475.5" height="50" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Con lo cual, las ecuaciones de sintonía serían:</span></span></div><div class = "S4"><span style="vertical-align:-43px"><img src="" width="515.5" height="94.5" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Las respuestas ideal y real se pueden observar en la siguiente imagen.</span></span></div><div class = 'CodeBlock contiguous'><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Dibujar la respuesta del motor</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S13">if </span><span class="S0">useExperimentalData</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> </span><span class="S10">% Usar Simulink</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> addpath</span><span class="S0">(</span><span class="S0">[pwd filesep </span><span class="S14">'PIvel'</span><span class="S0">]);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> open </span><span class="S14">PI_experimental.slx</span><span class="S0">;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> run </span><span class="S14">PI_experimental.slx</span><span class="S0">;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S13">else</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> FileName = </span><span class="S14">'PI_real_experimental.mat'</span><span class="S0">;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> cd(</span><span class="S14">'..'</span><span class="S0">)</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> FolderName = [pwd filesep </span><span class="S14">'Common' </span><span class="S0">filesep </span><span class="S14">'Resultados' </span><span class="S0">filesep </span><span class="S14">'Prac3'</span><span class="S0">];</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> File = fullfile(FolderName, FileName);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> load(File); </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S13">end</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">figure</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">plot(PI_real_experimental.time,</span><span class="S0">[</span><span class="S0">PI_real_experimental.signals.values(:,1,:)],</span><span class="S14">'r'</span><span class="S0">)</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">hold </span><span class="S14">on</span><span class="S0">; grid </span><span class="S14">on</span><span class="S0">;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">plot(PI_real_experimental.time,</span><span class="S0">[</span><span class="S0">PI_real_experimental.signals.values(:,2,:)],</span><span class="S14">'b'</span><span class="S0">)</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">plot(PI_real_experimental.time,</span><span class="S0">[</span><span class="S0">PI_real_experimental.signals.values(:,3,:)],</span><span class="S14">'g'</span><span class="S0">)</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">xlim([18 60]); ylim([-2.3 2.3]);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">xlabel(</span><span class="S14">'Tiempo (s)'</span><span class="S0">);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">ylabel(</span><span class="S14">'Voltaje (V)'</span><span class="S0">);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">title(</span><span class="S14">'Vin y salida real e ideal'</span><span class="S0">);</span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">legend(</span><span class="S14">'Vin'</span><span class="S0">,</span><span class="S14">'Respuesta Real'</span><span class="S0">,</span><span class="S14">'Respuesta Ideal'</span><span class="S0">);</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsFigure" uid="4A58F884" data-testid="output_0" style="width: 931px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="figureElement" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><img class="figureImage figureContainingNode" src="" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"></div></div></div></div></div><div class = "S12"><span class = "S2"><span class="S0">Como se puede analizar, las dos respuestas son prácticamente iguales, pero si analizamos las especificaciones deseadas, podemos observar que estas no se cumplen. Esto ocurre porque el controlador PI junto con una planta de primer orden tienen como respuesta un sistema con dos polos y un cero. Este último, tiene un efecto negativo en la dinámica del sistema, normalmente haciéndola un poco más rápida de lo deseado, es por eso, que en este caso obtenemos un pequeño sobreimpulso. En la siguiente práctica se analizará como eliminar este efecto.</span></span></div></div><div class = "S0"></div><div class = 'SectionBlock containment'><h1 class = "S1"><span class = "S2"><span class="S0">Ejercicio 12: Diseño e implementación de un PID por asignación de polos.</span></span></h1><div class = "S4"><span class = "S2"><span class="S0">Diseñar un PID de control de posición que haga que la respuesta temporal a una entrada escalón presente un sobreimpulso del 80% y una frecuencia de las oscilaciones de 0,5 Hz.</span></span></div><div class = "S4"><span class = "S2"><span class="S0">Para conseguirlo calcule el valor de los dos polos dominantes que cumplen con estas especificaciones y considere un tercer polo en 0,01. Toma el periodo de muestreo Ts igual a 0,01s. Determinar el valor de </span></span><span style="vertical-align:-6px"><img src="" width="15.5" height="19.5" /></span><span class = "S2"><span class="S0">,</span></span><span style="vertical-align:-6px"><img src="" width="15.5" height="19.5" /></span><span class = "S2"><span class="S0"> y </span></span><span style="vertical-align:-6px"><img src="" width="15" height="19.5" /></span><span class = "S2"><span class="S0"> y del 4º polo. Verificar si se cumple la hipótesis de polos dominantes. </span></span></div><div class = 'CodeBlock contiguous'><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Parámetros de la planta </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">K0=0.82/0.017;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">tau0=0.26;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">N=9;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Kpot=1.62;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Periodo de muestreo</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Ts=0.01;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Especificaciones de control deseadas</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Sp=80; </span><span class="S10">% sobreimpulso</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Fd=0.5; </span><span class="S10">% frecuencia</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Polos de segundo orden continuo que cumpliran las especificaciones</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">wd=2*pi*Fd ;</span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">xi=sqrt((log(Sp/100))^2/(pi^2+log(Sp/100)^2))</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="B961D09A" data-testid="output_1" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">xi = 0.0709</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">wn=wd/ sqrt(1-xi^2)</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="9B8C2E40" data-testid="output_2" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">wn = 3.1495</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">s1=-xi*wn+</span><span class="S0">j</span><span class="S0">*wd</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="E5642D23" data-testid="output_3" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">s1 = -0.2231 + 3.1416i</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">s2=-xi*wn-</span><span class="S0">j</span><span class="S0">*wd</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="EE5E1D72" data-testid="output_4" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">s2 = -0.2231 - 3.1416i</div></div></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Polos de segundo orden discreto que cumpliran las especificaciones</span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">p1=exp(Ts* s1 )</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="9A179A4A" data-testid="output_5" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">p1 = 0.9973 + 0.0313i</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">p2=exp(Ts* s2 )</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="0E129657" data-testid="output_6" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">p2 = 0.9973 - 0.0313i</div></div></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Insertar el tercer polo</span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">p3=0.01</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="FD7ED811" data-testid="output_7" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">p3 = 0.0100</div></div></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Función de transferencia discreta de la planta </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Ptas=tf(</span><span class="S0">[</span><span class="S0">K0*(1/N)*Kpot],[tau0,1,0]);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Ptaz=c2d(Ptas,Ts,</span><span class="S14">'zoh'</span><span class="S0">);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Coeficientes del denominador y enumerador </span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">[Nz ,Dz]= tfdata(Ptaz,</span><span class="S14">'v'</span><span class="S0">)</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableMatrixElement" uid="D7A73A92" data-testid="output_8" data-width="901" style="width: 931px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableMatrixElement" uid="D7A73A92" data-testid="output_8" data-width="901" style="width: 931px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="matrixElement veSpecifier saveLoad" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="veVariableName variableNameElement double" style="width: 901px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><span style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">Nz = </span><span class="veVariableValueSummary veMetaSummary" style="white-space: normal; font-style: normal; color: rgb(179, 179, 179); font-size: 12px;">1×3</span></div><div class="valueContainer" data-layout="{"columnWidth":"66","totalColumns":"3","totalRows":"1","charsPerColumn":10}" style="white-space: nowrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableValue" style="width: 200px; white-space: pre; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"> 0 0.0016 0.0016<br></div><div class="horizontalEllipsis hide" style="white-space: nowrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"></div><div class="verticalEllipsis hide" style="white-space: nowrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"></div></div></div></div></div><div class="inlineElement eoOutputWrapper embeddedOutputsVariableMatrixElement" uid="A569B9C0" data-testid="output_9" data-width="901" style="width: 931px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableMatrixElement" uid="A569B9C0" data-testid="output_9" data-width="901" style="width: 931px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="matrixElement veSpecifier saveLoad" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="veVariableName variableNameElement double" style="width: 901px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><span style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">Dz = </span><span class="veVariableValueSummary veMetaSummary" style="white-space: normal; font-style: normal; color: rgb(179, 179, 179); font-size: 12px;">1×3</span></div><div class="valueContainer" data-layout="{"columnWidth":"66","totalColumns":"3","totalRows":"1","charsPerColumn":10}" style="white-space: nowrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableValue" style="width: 200px; white-space: pre; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"> 1.0000 -1.9623 0.9623<br></div><div class="horizontalEllipsis hide" style="white-space: nowrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"></div><div class="verticalEllipsis hide" style="white-space: nowrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"></div></div></div></div></div></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">a1=Nz(2);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">a0=Nz(3);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">b1=Dz(2);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">b0=Dz(3);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Definiciones de las matrices A y B</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">A=[-1 -a1 -a1 -a1 ; p2+p3+p1 a1-a0 -a1-a0 -a0+2*a1 ; </span><span class="S13">...</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> -p1*p2-p3*p1-p2*p3 a0 -a0 2*a0-a1 ; p1*p2*p3 0 0 -a0 ] ;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">b=[p1+p2+p3-1+b1 ; -p1*p2-p3*p1-p3*p2+b0-b1 ; p1*p2*p3-b0 ; 0 ] ;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Controlador </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">x=</span><span class="S0">inv</span><span class="S0">(A)*b ; </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">p4=x(1)</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="F4EED7BD" data-testid="output_10" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">p4 = 0.9475</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Kp=x(2)</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="6C85E8E6" data-testid="output_11" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">Kp = 0.3698</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Ki=(2/Ts)*x(3)</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="BCC91B26" data-testid="output_12" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">Ki = 1.5691</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Kd=Ts*x(4)</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="BCC40494" data-testid="output_13" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">Kd = 0.0580</div></div></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Anti-wind-up</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">pawd=0.2;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Kaw=1/Ki;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Calculo de dominancia de los polos</span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">dominancia=log(abs(p4))/log(abs(p1))</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableElement" uid="12986C2A" data-testid="output_14" style="width: 931px; white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="variableElement" style="white-space: pre-wrap; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;">dominancia = 24.1515</div></div></div></div></div><div class = "S12"><span class = "S2"><span class="S0">La función de transferencia del PID tiene la siguiente forma:</span></span></div><div class = "S4"><span style="vertical-align:-17px"><img src="" width="660" height="38" /></span></div><div class = "S4"><span style="vertical-align:-18px"><img src="" width="267" height="38" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Con lo cual la función de transferencia de lazo cerrado toma la forma:</span></span></div><div class = "S4"><span style="vertical-align:-15px"><img src="" width="210.5" height="34" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Se puede comprobar fácilmente que el denominador es:</span></span></div><div class = "S4"><span style="vertical-align:-19px"><img src="" width="642.5" height="46.5" /></span></div><div class = "S4"><span class = "S2"><span class="S0">El polinomio es de orden cuatro, con lo cual tendrá cuatro polos y la ecuación característica será:</span></span></div><div class = "S4"><span style="vertical-align:-30px"><img src="" width="426" height="67.5" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Como es un sistema de cuarto orden y tres incógnitas, no se podrán fijar todos los polos y quedando uno de ellos libre (</span></span><span style="vertical-align:-6px"><img src="" width="15.5" height="19.5" /></span><span class = "S2"><span class="S0">). La metodología será aceptable y adecuada si el polo libre es estable y no dominante.</span></span></div><div class = "S4"><span class = "S2"><span class="S0">Igualando los coeficientes y representándolo en forma matricial, el sistema en lazo cerrado seria:</span></span></div><div class = "S4"><span style="vertical-align:-43px"><img src="" width="582.5" height="96" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Este sistema lineal es fácilmente soluble utilizando MATLAB. La ecuación es </span></span><span style="vertical-align:-5px"><img src="" width="50" height="18" /></span><span class = "S2"><span class="S0">, donde </span></span><span style="font-family: STIXGeneral, STIXGeneral-webfont, serif; font-style: italic; font-weight: normal;">A</span><span class = "S2"><span class="S0"> es una matriz </span></span><span style="vertical-align:-5px"><img src="" width="31.5" height="18" /></span><span class = "S2"><span class="S0"> y </span></span><span style="font-family: STIXGeneral, STIXGeneral-webfont, serif; font-style: italic; font-weight: normal;">b</span><span class = "S2"><span class="S0"> es un vector columna con </span></span><span style="font-family: STIXGeneral, STIXGeneral-webfont, serif; font-style: italic; font-weight: normal;">n</span><span class = "S2"><span class="S0"> elementos, entonces, </span></span><span style="vertical-align:-5px"><img src="" width="88.5" height="18" /></span><span class = "S2"><span class="S0">.</span></span></div><div class = 'CodeBlock contiguous'><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S10">% Dibujar la respuesta del motor</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S13">if </span><span class="S0">useExperimentalData</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> </span><span class="S10">% Usar Simulink</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> addpath</span><span class="S0">(</span><span class="S0">[pwd filesep </span><span class="S14">'PIvel'</span><span class="S0">]);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> open </span><span class="S14">PID_experimental.slx</span><span class="S0">;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> run </span><span class="S14">PID_experimental.slx</span><span class="S0">;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S13">else</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> FileName = </span><span class="S14">'PID_real_ideal.mat'</span><span class="S0">;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> FolderName = [pwd filesep </span><span class="S14">'Common' </span><span class="S0">filesep </span><span class="S14">'Resultados' </span><span class="S0">filesep </span><span class="S14">'Prac3'</span><span class="S0">];</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> File = fullfile(FolderName, FileName);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> load(File); </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S13">end</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"></span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">figure</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">plot(PID_real_ideal.time,</span><span class="S0">[</span><span class="S0">PID_real_ideal.signals.values(:,1,:)],</span><span class="S14">'r'</span><span class="S0">)</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">hold </span><span class="S14">on</span><span class="S0">; grid </span><span class="S14">on</span><span class="S0">;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">plot(PID_real_ideal.time,</span><span class="S0">[</span><span class="S0">PID_real_ideal.signals.values(:,2,:)],</span><span class="S14">'b'</span><span class="S0">)</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">plot(PID_real_ideal.time,</span><span class="S0">[</span><span class="S0">PID_real_ideal.signals.values(:,3,:)],</span><span class="S14">'g'</span><span class="S0">)</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">xlim([30 60]); ylim([-6.5 6.5]);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">xlabel(</span><span class="S14">'Tiempo (s)'</span><span class="S0">);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">ylabel(</span><span class="S14">'Voltaje (V)'</span><span class="S0">);</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">title(</span><span class="S14">'Vin y salida real e ideal'</span><span class="S0">);</span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">legend(</span><span class="S14">'Vin'</span><span class="S0">,</span><span class="S14">'Respuesta Real'</span><span class="S0">,</span><span class="S14">'Respuesta Ideal'</span><span class="S0">);</span></span></div><div class="outputParagraph" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 13.9999990463257px;"><div class="inlineElement eoOutputWrapper embeddedOutputsFigure" uid="493B4948" data-testid="output_15" style="width: 931px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="figureElement" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><img class="figureImage figureContainingNode" src="" style="white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"></div></div></div></div></div><div class = "S12"><span class = "S2"><span class="S0">Como se puede observar, aunque el controlador sea capaz de establecer el sistema, las respuestas real e ideal no son parecidas. Esto ocurre porque uno de los polos se ha fijado libremente y aunque cumpla la metodología de ser libre y no dominante, esta afecta al sistema. Además de esto, el controlador añade dos ceros, los cuales también afectan a la dinámica del sistema. Junto a todo esto hay que añadir el efecto de que algunas dinámicas no han sido modeladas.</span></span></div></div><div class = "S0"></div><div class = 'SectionBlock containment'><h1 class = "S1"><span class = "S2"><span class="S0">Ejercicio 13: Diseñar los mismos controladores pero con el bloque PID de Simulink.</span></span></h1><div class = "S4"><span class = "S2"><span class="S0">Saber cómo se diseñan y diseñar controladores PID es muy importante, ya que seremos capaces de realizar un lazo de control para cualquier sistema. Pero además de esto, tenemos que saber que MATLAB/Simulink ofrecen herramientas que simplifican nuestro trabajo. Por ejemplo, con la herramienta "</span></span><span class = "S2"><span class="S16">pidTuner</span></span><span class = "S2"><span class="S0">" podemos obtener las ganancias </span></span><span style="vertical-align:-6px"><img src="" width="15.5" height="19.5" /></span><span class = "S2"><span class="S0">,</span></span><span style="vertical-align:-6px"><img src="" width="15.5" height="19.5" /></span><span class = "S2"><span class="S0"> y </span></span><span style="vertical-align:-6px"><img src="" width="15" height="19.5" /></span><span class = "S2"><span class="S0"> teniendo solamente la función de transferencia de la planta y las especificaciones deseadas. Por otro lado, Simulink tiene un bloque especifico llamado "</span></span><span class = "S2"><span class="S16">PID Controller</span></span><span class = "S2"><span class="S0">" en el cual podemos especificar las ganancias de cada acción, coeficiente del filtro de la parte derivativa y el periodo de muestreo.</span></span></div><div class = "S17"><img class="imageNode" width="569" height="378" style="vertical-align: baseline" src=""></div><div class = "S17"><span class = "S2"><span class="S0">Figure 1: Herramienta pidTuner</span></span></div><div class = "S17"><span class = "S2"><span class="S0"></span></span></div><div class = "S17"><img class="imageNode" width="150" height="158" style="vertical-align: baseline" src=""></div><div class = "S17"><span class = "S2"><span class="S0">Figure 2: Bloques PID de Simulink</span></span></div><div class = "S17"><span class = "S2"><span class="S0"></span></span></div><div class = "S4"><span class = "S2"><span class="S0">En este ejercicio se desea implementar los mismos controladores, pero usando este bloque especifico que ofrece Simulink. Para la simulación del PI abrir y ejecutar el modelo P3_Ex13a.slx. Para ejecutar este modelo en una planta abrir y ejecutar el modelo P3_Ex13b.slx. Para la simulación del PID, abrir y ejecutar el modelo P3_Ex13c.slx y para su comprobación usar el modelo P3_Ex13d.slx. Analizar que los resultados obtenidos en este ejercicio se asemejan a los resultados obtenidos en los ejercicios anteriores.</span></span></div></div></div><br><!-- <br>##### SOURCE BEGIN #####<br>%% *Práctica 3: Diseño e implementación de Controladores PID*<br>% Las prácticas de la asignatura control por computador consisten en el estudio <br>% de un servomecanismo de posicionamiento angular (LJ Technical Systems) controlado <br>% por un PC. Las sesiones de laboratorio P1 y P2 se centran en el análisis experimental <br>% de las respuestas temporal y frecuencial del sistema respectivamente. Las sesiones <br>% P3 y P4 se dedican al diseño de controladores PID. Por último, en la práctica <br>% P5 se diseñarán controladores en campo frecuencial.<br>% <br>% *OBJETIVO: Diseñar un controlador PI de velocidad de salida para que el <br>% sistema de lazo cerrado tenga un error estacionario nulo. Diseñar un controlador <br>% PID de la posición del eje de salida para la planta estudiada en las sesiones <br>% anteriores para que el sistema en lazo cerrado cumpla unas ciertas especificaciones.*<br>% <br>% *En esta sesión el estudiante ha de:*<br>% <br>% * *Diseñar un PI y un PID por asignación de polos.*<br>% * *Verificar experimentalmente los sistemas de control diseñados.*<br><br>% Alternar entre los datos del experimento y los del directorio Resultados<br>% Si desea usar los datos del directorio Resultados = false<br>% Si desea usar datos propios = true<br>useExperimentalData = false;<br>%% Ejercicio 11: Diseño e implementación de un PI por asignación de polos.<br>% Diseñar un PI de control de velocidad que haga que la respuesta temporal a <br>% una entrada escalón no presente sobreimpulsos y que el tiempo de establecimiento <br>% (con el criterio del 2%) sea de 0.8 segundos. Para la simulación del controlador <br>% PI digital, abrir y ejecutar el modelo P3_Ex11a.slx. Para su comprobación con <br>% el motor, abrir y ejecutar el modelo P3_Ex11b.slx.<br>%%<br>% Planta<br>K0=0.82;<br>tau0=0.26;<br><br>% Periodo de muestreo<br>Ts=0.01;<br><br>% Especificaciones<br>xi=1;<br>ts_2=0.8; % tiempo de establecimiento con el criterio de 2%<br>Tdes=ts_2/4;<br>wn=5.8/(xi*ts_2);<br><br>% Diseño del controlador<br>Zdes=exp(-Ts/Tdes);<br>alpha=exp(-Ts/tau0);<br>beta=-2*exp(-Ts*xi*wn)*cos(wn*Ts*sqrt(1-xi^2));<br>gamma=exp(-2*Ts*xi*wn);<br><br>Ki_star=(gamma-alpha+beta+(alpha+1))/(2*K0*(1-alpha));<br>Ki=(2/Ts)*Ki_star;<br>Kp=((beta+alpha+1)/(K0*(1-alpha)))-Ki_star;<br>%% <br>% Para diseñar el controlador, se han seguido los siguientes pasos. Primeramente, <br>% se ha digitalizado la planta con un mantenedor de orden cero y se ha escogido <br>% un controlador PI discretizado mediante la aproximación trapezoidal.<br>% <br>% $$\mathrm{motor}:G\left(z\right)=k_{\mathrm{mot}} \frac{1-\alpha }{z-\alpha <br>% }\;\;\;\;\;\;\;\;\;\mathrm{donde}\;\;\;\;\;\;\;\;\;\;\;\;\alpha =e^{-\frac{T_s <br>% }{\tau_0 }}$$<br>% <br>% $$\mathrm{controlador}\;\mathrm{PI}:\mathrm{PI}\left(z\right)=k_p +k_i <br>% \frac{T_s }{2}\frac{z+1}{z-1}=k_p +k_i^* \frac{z+1}{z-1}\;\;\;\;\;\;\mathrm{donde}\;\;\;\;k_i^* <br>% =k_i \frac{T_s }{2}$$<br>% <br>% <br>% <br>% Con lo cual la función de transferencia del lazo cerrado:<br>% <br>% $$\textrm{l}c\left(z\right)=\frac{\textrm{PI}\left(z\right)G\left(z\right)}{1+\textrm{PI}\left(z\right)G\left(z\right)}=\frac{k_{\mathrm{mot}} <br>% \left(k_p +k_i^* \right)\left(z+\frac{k_i^* -k_p }{k_i^* +k_p }\right)\left(1-\alpha <br>% \right)}{\left(z-1\right)\left(z-\alpha \right)+k_{\mathrm{mot}} \left(k_p +k_i^* <br>% \right)\left(z+\frac{k_i^* -k_p }{k_i^* +k_p }\right)\left(1-\alpha \right)}$$<br>% <br>% Igualando la ecuación caracteristica real, con la ideal, podremos sintonizar <br>% nuestros parámetros.<br>% <br>% $$\begin{array}{l}\mathrm{eq}\;\mathrm{real}:z^2 +\left\lbrack \left(k_p <br>% +k_i^* \right)k_{\mathrm{mot}} \left(1-\alpha \right)-\left(\alpha +1\right)\right\rbrack <br>% z+\alpha +k_{\mathrm{mot}} \left(k_i^* -k_p \right)\left(1-\alpha \right)=0\\\mathrm{eq}\;\mathrm{ideal}:z^2 <br>% -2e^{-T_s \xi \omega_n } \mathrm{cos}\left(\omega_n T_s \sqrt{1-\xi^2 }\right)z+e^{-2T_s <br>% \xi \omega_n } \end{array}$$<br>% <br>% Con lo cual, las ecuaciones de sintonía serían:<br>% <br>% $$\begin{array}{l}k_p =\frac{-\left(-2e^{-T_s \xi \omega_n } \mathrm{cos}\left(\omega_n <br>% T_s \sqrt{1-\xi^2 }\right)+e^{-2T_s \xi \omega_n } +1\right)}{T_s \;k_{\mathrm{mot}} <br>% \;\left(\alpha -1\right)}\\k_i =\frac{-2e^{-T_s \xi \omega_n } \mathrm{cos}\left(\omega_n <br>% T_s \sqrt{1-\xi^2 }\right)+e^{-2T_s \xi \omega_n } +1}{2{\;k}_{\mathrm{mot}} <br>% \;\left(\alpha -1\right)}-\frac{\alpha -2e^{-T_s \xi \omega_n } \mathrm{cos}\left(\omega_n <br>% T_s \sqrt{1-\xi^2 }\right)+1}{k_{\mathrm{mot}} \;\left(\alpha -1\right)}\end{array}$$<br>% <br>% Las respuestas ideal y real se pueden observar en la siguiente imagen.<br><br>% Dibujar la respuesta del motor<br>if useExperimentalData<br> % Usar Simulink<br> addpath([pwd filesep 'PIvel']);<br> open PI_experimental.slx;<br> run PI_experimental.slx;<br>else<br> FileName = 'PI_real_experimental.mat';<br> cd('..')<br> FolderName = [pwd filesep 'Common' filesep 'Resultados' filesep 'Prac3'];<br> File = fullfile(FolderName, FileName);<br> load(File); <br>end<br><br>figure<br>plot(PI_real_experimental.time,[PI_real_experimental.signals.values(:,1,:)],'r')<br>hold on; grid on;<br>plot(PI_real_experimental.time,[PI_real_experimental.signals.values(:,2,:)],'b')<br>plot(PI_real_experimental.time,[PI_real_experimental.signals.values(:,3,:)],'g')<br>xlim([18 60]); ylim([-2.3 2.3]);<br>xlabel('Tiempo (s)');<br>ylabel('Voltaje (V)');<br>title('Vin y salida real e ideal');<br>legend('Vin','Respuesta Real','Respuesta Ideal');<br>%% <br>% Como se puede analizar, las dos respuestas son prácticamente iguales, <br>% pero si analizamos las especificaciones deseadas, podemos observar que estas <br>% no se cumplen. Esto ocurre porque el controlador PI junto con una planta de <br>% primer orden tienen como respuesta un sistema con dos polos y un cero. Este <br>% último, tiene un efecto negativo en la dinámica del sistema, normalmente haciéndola <br>% un poco más rápida de lo deseado, es por eso, que en este caso obtenemos un <br>% pequeño sobreimpulso. En la siguiente práctica se analizará como eliminar este <br>% efecto.<br>%% Ejercicio 12: Diseño e implementación de un PID por asignación de polos.<br>% Diseñar un PID de control de posición que haga que la respuesta temporal a <br>% una entrada escalón presente un sobreimpulso del 80% y una frecuencia de las <br>% oscilaciones de 0,5 Hz.<br>% <br>% Para conseguirlo calcule el valor de los dos polos dominantes que cumplen <br>% con estas especificaciones y considere un tercer polo en 0,01. Toma el periodo <br>% de muestreo Ts igual a 0,01s. Determinar el valor de $k_p$,$\;k_i$ y $k_d$ y <br>% del 4º polo. Verificar si se cumple la hipótesis de polos dominantes. <br>%%<br>% Parámetros de la planta <br>K0=0.82/0.017;<br>tau0=0.26;<br>N=9;<br>Kpot=1.62;<br><br>% Periodo de muestreo<br>Ts=0.01;<br><br>% Especificaciones de control deseadas<br>Sp=80; % sobreimpulso<br>Fd=0.5; % frecuencia<br><br>% Polos de segundo orden continuo que cumpliran las especificaciones<br>wd=2*pi*Fd ;<br>xi=sqrt((log(Sp/100))^2/(pi^2+log(Sp/100)^2))<br>wn=wd/ sqrt(1-xi^2)<br>s1=-xi*wn+j*wd<br>s2=-xi*wn-j*wd<br>% Polos de segundo orden discreto que cumpliran las especificaciones<br>p1=exp(Ts* s1 )<br>p2=exp(Ts* s2 )<br>% Insertar el tercer polo<br>p3=0.01<br>% Función de transferencia discreta de la planta <br>Ptas=tf([K0*(1/N)*Kpot],[tau0,1,0]);<br>Ptaz=c2d(Ptas,Ts,'zoh');<br><br>% Coeficientes del denominador y enumerador <br>[Nz ,Dz]= tfdata(Ptaz,'v')<br>a1=Nz(2);<br>a0=Nz(3);<br>b1=Dz(2);<br>b0=Dz(3);<br><br>% Definiciones de las matrices A y B<br>A=[-1 -a1 -a1 -a1 ; p2+p3+p1 a1-a0 -a1-a0 -a0+2*a1 ; ...<br> -p1*p2-p3*p1-p2*p3 a0 -a0 2*a0-a1 ; p1*p2*p3 0 0 -a0 ] ;<br>b=[p1+p2+p3-1+b1 ; -p1*p2-p3*p1-p3*p2+b0-b1 ; p1*p2*p3-b0 ; 0 ] ;<br><br>% Controlador <br>x=inv(A)*b ; <br><br>p4=x(1)<br>Kp=x(2)<br>Ki=(2/Ts)*x(3)<br>Kd=Ts*x(4)<br>% Anti-wind-up<br>pawd=0.2;<br>Kaw=1/Ki;<br><br>% Calculo de dominancia de los polos<br>dominancia=log(abs(p4))/log(abs(p1))<br>%% <br>% La función de transferencia del PID tiene la siguiente forma:<br>% <br>% $$\textrm{controlador}\;\mathrm{PI}\textrm{D}:\textrm{P}\mathrm{ID}\left(z\right)=k_p <br>% +k_i \frac{T_s }{2}\frac{z+1}{z-1}+k_d \frac{z-1}{T_{s\;} z}=k_p +k_i^* \frac{z+1}{z-1}+k_d^* <br>% \;\frac{z-1}{z}\;\;\;\;\textrm{donde}\;\;\;\;k_i^* =k_i \frac{T_s }{2}\;\;y\;k_d^* <br>% =\frac{k_d }{T_s }$$<br>% <br>% $$\mathrm{planta}\;\mathrm{segundo}\;\mathrm{orden}:G\left(z\right)=\frac{a_{1\;} <br>% z+a_0 }{z^2 +b_{1\;} z+b_0 }$$<br>% <br>% Con lo cual la función de transferencia de lazo cerrado toma la forma:<br>% <br>% $$\mathrm{cl}\left(z\right)=\frac{\mathrm{PID}\left(z\right)G\left(z\right)}{1+\mathrm{PID}\left(z\right)G\left(z\right)}=\frac{\mathrm{Num}\left(z\right)}{\mathrm{Den}\left(z\right)}$$<br>% <br>% Se puede comprobar fácilmente que el denominador es:<br>% <br>% $$\begin{array}{l}\mathrm{Den}\left(z\right)=z^4 +\left(-1+k_i^* a_1 +b_1 <br>% +k_d^* a_1 +k_p a_1 \right)z^3 +\left(-b_1 -k_p a_1 +k_p a_0 +b_0 -2k_d^* a_1 <br>% +k_i^* a_0 +k_i^* a_1 +k_d^* a_0 \right)z^2 \\\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;+\left(k_i^* <br>% a_0 -b_0 -2k_d^* a_0 -k_p a_0 +k_d^* a_1 \right)z+k_d^* a_0 \end{array}$$<br>% <br>% El polinomio es de orden cuatro, con lo cual tendrá cuatro polos y la ecuación <br>% característica será:<br>% <br>% $$\begin{array}{l}\mathrm{Den}\left(z\right)=\left(z-p_1 \right)\left(z-p_2 <br>% \right)\left(z-p_3 \right)\left(z-p_4 \right)=z^4 +\left(-p_1 {-p}_2 -p_3 -p_4 <br>% \right)z^3 \\\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;+\left(p_1 p_2 -\left({-p}_1 <br>% -p_2 \right)p_3 -\left(-p_1 -p_2 -p_3 \right)p_4 \right)z^2 \\\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;+\left({-p}_1 <br>% p_2 p_3 -\left(p_1 p_2 -\left({-p}_1 -p_2 \right)p_3 \right)p_4 \right)z+p_1 <br>% p_2 p_3 p_4 \end{array}$$<br>% <br>% Como es un sistema de cuarto orden y tres incógnitas, no se podrán fijar <br>% todos los polos y quedando uno de ellos libre ($p_4$). La metodología será aceptable <br>% y adecuada si el polo libre es estable y no dominante.<br>% <br>% Igualando los coeficientes y representándolo en forma matricial, el sistema <br>% en lazo cerrado seria:<br>% <br>% $$\left\lbrack \begin{array}{cccc}-1 & -a_1 & -a_1 & -a_1 \\p_1 +p_2 <br>% +p_3 & a_1 -a_0 & -a_1 -a_0 & -a_0 +2a_1 \\-p_1 p_2 -p_3 p_1 -p_3 p_2 & <br>% a_0 & -a_0 & 2a_0 -a_1 \\p_1 p_2 p_3 & 0 & 0 & -a_0 \end{array}\right\rbrack <br>% \left\lbrack \begin{array}{c}p_4 \\k_p \\k_i^* \\k_d^* \end{array}\right\rbrack <br>% =\left\lbrack \begin{array}{c}p_1 +p_2 +p_3 -1+b_1 \\-p_1 p_2 -p_3 p_1 -p_3 <br>% p_2 +b_0 -b_1 \\p_1 p_2 p_3 -b_0 \\0\end{array}\right\rbrack$$<br>% <br>% Este sistema lineal es fácilmente soluble utilizando MATLAB. La ecuación <br>% es $A\;x=b$, donde $A$ es una matriz $n\;x\;n$ y $b$ es un vector columna con <br>% $n$ elementos, entonces, $x=\mathrm{inv}\left(A\right)·b$.<br><br>% Dibujar la respuesta del motor<br>if useExperimentalData<br> % Usar Simulink<br> addpath([pwd filesep 'PIvel']);<br> open PID_experimental.slx;<br> run PID_experimental.slx;<br>else<br> FileName = 'PID_real_ideal.mat';<br> FolderName = [pwd filesep 'Common' filesep 'Resultados' filesep 'Prac3'];<br> File = fullfile(FolderName, FileName);<br> load(File); <br>end<br><br>figure<br>plot(PID_real_ideal.time,[PID_real_ideal.signals.values(:,1,:)],'r')<br>hold on; grid on;<br>plot(PID_real_ideal.time,[PID_real_ideal.signals.values(:,2,:)],'b')<br>plot(PID_real_ideal.time,[PID_real_ideal.signals.values(:,3,:)],'g')<br>xlim([30 60]); ylim([-6.5 6.5]);<br>xlabel('Tiempo (s)');<br>ylabel('Voltaje (V)');<br>title('Vin y salida real e ideal');<br>legend('Vin','Respuesta Real','Respuesta Ideal');<br>%% <br>% Como se puede observar, aunque el controlador sea capaz de establecer <br>% el sistema, las respuestas real e ideal no son parecidas. Esto ocurre porque <br>% uno de los polos se ha fijado libremente y aunque cumpla la metodología de ser <br>% libre y no dominante, esta afecta al sistema. Además de esto, el controlador <br>% añade dos ceros, los cuales también afectan a la dinámica del sistema. Junto <br>% a todo esto hay que añadir el efecto de que algunas dinámicas no han sido modeladas.<br>%% Ejercicio 13: Diseñar los mismos controladores pero con el bloque PID de Simulink.<br>% Saber cómo se diseñan y diseñar controladores PID es muy importante, ya que <br>% seremos capaces de realizar un lazo de control para cualquier sistema. Pero <br>% además de esto, tenemos que saber que MATLAB/Simulink ofrecen herramientas que <br>% simplifican nuestro trabajo. Por ejemplo, con la herramienta "_pidTuner_" podemos <br>% obtener las ganancias $k_p$,$\;k_i$ y $k_d$ teniendo solamente la función de <br>% transferencia de la planta y las especificaciones deseadas. Por otro lado, Simulink <br>% tiene un bloque especifico llamado "_PID Controller_" en el cual podemos especificar <br>% las ganancias de cada acción, coeficiente del filtro de la parte derivativa <br>% y el periodo de muestreo.<br>% <br>% <br>% <br>% Figure 1: Herramienta pidTuner<br>% <br>% <br>% <br>% <br>% <br>% Figure 2: Bloques PID de Simulink<br>% <br>% <br>% <br>% En este ejercicio se desea implementar los mismos controladores, pero usando <br>% este bloque especifico que ofrece Simulink. Para la simulación del PI abrir <br>% y ejecutar el modelo P3_Ex13a.slx. Para ejecutar este modelo en una planta abrir <br>% y ejecutar el modelo P3_Ex13b.slx. Para la simulación del PID, abrir y ejecutar <br>% el modelo P3_Ex13c.slx y para su comprobación usar el modelo P3_Ex13d.slx. Analizar <br>% que los resultados obtenidos en este ejercicio se asemejan a los resultados <br>% obtenidos en los ejercicios anteriores.<br>##### SOURCE END #####<br>--></body></html>