-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathP4_es.html
130 lines (128 loc) · 824 KB
/
P4_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
<!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 4: Mejora de los controladores PID implementados en la práctica 3</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; }
.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 4: Mejora de los controladores PID implementados en la práctica 3</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 I-P de velocidad de salida para que el sistema de lazo cerrado tenga un error estacionario nulo. Diseñar un controlador I-PD 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 I-P y un I-PD por asignación de polos.</span></span></li><li class = "S6"><span class = "S0"><span class="S3">Verificar experimentalmente el sistema de control diseñado.</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'><h1 class = "S1"><span class = "S2"><span class="S0">Ejercicio 14: Diseño e implementación de un I-P por asignación de polos.</span></span></h1><div class = "S4"><span class = "S2"><span class="S0">Como se puede observar en la práctica 3, al diseñar un controlador PI 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 obteníamos un pequeño sobreimpulso. Para eliminar el efecto del cero, se propone la siguiente alternativa de introducir las acciones proporcional e integral.</span></span></div><div class = "S4"><img class="imageNode" width="522" height="169" style="vertical-align: baseline" src=""></div><div class = "S4"><span class = "S2"><span class="S0">Esta estructura toma el nombre de controlador I-P, y como se puede observar, la acción integral se realimenta desde el error, mientras que la parte proporcional se realimenta desde la salida, es por esto, que la respuesta a un escalón del sistema con un controlador I-P será más suave que la de un sistema con un controlador PI. Como se ha hecho en el P3, se desea diseñar un I-P 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 I-P digital, abrir y ejecutar el modelo P4_Ex14a.slx. Para su comprobación con el motor, abrir y ejecutar el modelo P4_Ex14b.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=(2/Ts)*Ki_star;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">Kp=((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">En este caso, la función de transferencia de lazo cerrado:</span></span></div><div class = "S4"><span style="vertical-align:-43px"><img src="" width="463" height="62" /></span></div><div class = "S4"><span class = "S2"><span class="S0">En el caso del PI la función de transferencia de lazo cerrado era:</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">Como podemos observar, al fijar los polos mediante las ganancias del controlador, automáticamente se fija el cero de lazo cerrado. Sin embargo, si analizamos el cero de la arquitectura del I-P, podemos ver como el cero se fija en z=-1. Vale la pena comentar que la acción proporcional del controlador de IP no ve la referencia, por lo que la respuesta del sistema de lazo cerrado a una entrada por escalón de un controlador del IP es más suave que la del PI.</span></span></div><div class = "S4"><span class = "S2"><span class="S0">Como el denominador de lazo cerrado es el mismo que el obtenido en la práctica 3, las ecuaciones utilizadas para ajustar los parámetros del controlador son exactamente las mismas que las utilizadas para el controlador PI.</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 del controlador I-P 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">'IPvel'</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">IP_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">IP_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">'IP_ideal.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="S0"> </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> FileName = </span><span class="S14">'IP_real.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(IP_ideal.time,</span><span class="S0">[</span><span class="S0">IP_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(IP_real.time,</span><span class="S0">[</span><span class="S0">IP_real.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(IP_ideal.time,</span><span class="S0">[</span><span class="S0">IP_ideal.signals.values(:,2,:)],</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">'Referencia, simulación y salida real'</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">'Referencia'</span><span class="S0">,</span><span class="S14">'Respuesta Real'</span><span class="S0">,</span><span class="S14">'Siumulación'</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="2A56047B" data-testid="output_0" style="width: 1076px; 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 y con lo cual, el sistema real cumple las especificaciones deseadas.</span></span></div></div><div class = "S0"></div><div class = 'SectionBlock containment active'><h1 class = "S1"><span class = "S2"><span class="S0">Ejercicio 15: Diseño e implementación de un I-PD por asignación de polos.</span></span></h1><div class = "S4"><span class = "S2"><span class="S0">Como se puede observar en la práctica 3, al diseñar un controlador PID con una planta de segundo orden tienen como respuesta un sistema con cuatro polos y tres cero. Para poder diseñar un controlador PID donde se cumplan las especificaciones, hay que hacer dos modificaciones principales, la primera, añadir un nuevo parámetro al controlador para poder fijar los cuatro polos del sistema, y el segundo, modificar la estructura para eliminar el efecto de los ceros.</span></span></div><div class = "S4"><span class = "S2"><span class="S0">Con lo cual, el nuevo controlador, tendrá la siguiente estructura:</span></span></div><div class = "S4"><span style="vertical-align:-17px"><img src="" width="493.5" height="37.5" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Para eliminar el efecto de los ceros, se propone la siguiente alternativa de introducir las acciones proporcional, integral y derivativa.</span></span></div><div class = "S4"><img class="imageNode" width="633" height="204" style="vertical-align: baseline" src=""></div><div class = "S4"><span class = "S2"><span class="S0">Esta estructura toma el nombre de controlador I-PD, y como se puede observar, la acción integral se realimenta desde el error, mientras que las acciones proporcional y derivativa se realimentan desde la salida.</span></span></div><div class = "S4"><span class = "S2"><span class="S0">En este ejercicio se desea diseñar un I-PD 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 oscilación de 0,5 Hz.</span></span></div><div class = "S4"><span class = "S2"><span class="S0">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 </span></span><span style="font-family: STIXGeneral, STIXGeneral-webfont, serif; font-style: italic; font-weight: normal;">α</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">% 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 cumplirán 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="392DA83A" data-testid="output_1" style="width: 1076px; 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="0D723E5C" data-testid="output_2" style="width: 1076px; 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="E72155A0" data-testid="output_3" style="width: 1076px; 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="1709566B" data-testid="output_4" style="width: 1076px; 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="23F2D73B" data-testid="output_5" style="width: 1076px; 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="2BF37888" data-testid="output_6" style="width: 1076px; 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 y cuarto polo </span></span></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">p3=0.8</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="85F9B72E" data-testid="output_7" style="width: 1076px; 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.8000</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">p4=0.8</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="143A007C" data-testid="output_8" style="width: 1076px; 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.8000</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="7D8C7304" data-testid="output_9" data-width="1046" style="width: 1076px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableMatrixElement" uid="7D8C7304" data-testid="output_9" data-width="1046" style="width: 1076px; 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: 1046px; 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="893C4171" data-testid="output_10" data-width="1046" style="width: 1076px; white-space: normal; font-style: normal; color: rgb(64, 64, 64); font-size: 12px;"><div class="inlineElement eoOutputWrapper embeddedOutputsVariableMatrixElement" uid="893C4171" data-testid="output_10" data-width="1046" style="width: 1076px; 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: 1046px; 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 0 0; </span><span class="S13">...</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> b1-1 a0 a1 0; </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> b0-b1 0 a0 a1; </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> -b0 0 0 a0] ;</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">b=[-b1+1-p1-p2-p3-p4; </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> -b0+b1+p1*p2-(-p1-p2)*p3-(-p1-p2-p3)*p4; </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> b0-p1*p2*p3-(p1*p2-(-p1-p2)*p3)*p4; </span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0"> p1*p2*p3*p4] ;</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">alpha=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="4C4B7BD3" data-testid="output_11" style="width: 1076px; 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;">alpha = -0.6472</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">c2=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="DF75969D" data-testid="output_12" style="width: 1076px; 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;">c2 = 9.0217</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">c1=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="69FE6D9B" data-testid="output_13" style="width: 1076px; 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;">c1 = -17.8623</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">c0=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="5B44C2D4" data-testid="output_14" style="width: 1076px; 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;">c0 = 8.8526</div></div></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">A2=[1 1 1; alpha-1 alpha+1 -2; -alpha alpha 1];</span></span></div></div><div class = 'inlineWrapper'><div class = "S8 lineNode"><span class = "S9"><span class="S0">B2=[c2;c1;c0];</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">x2=</span><span class="S0">inv</span><span class="S0">(A2)*B2;</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">kp = x2(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="FAFBC33C" data-testid="output_15" style="width: 1076px; 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.3994</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">ki = (2/Ts)*x2(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="1631B65E" data-testid="output_16" style="width: 1076px; 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 = 3.4247</div></div></div></div><div class = 'inlineWrapper outputs'><div class = "S8 lineNode"><span class = "S9"><span class="S0">kd = Ts*x2(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="87156200" data-testid="output_17" style="width: 1076px; 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.0861</div></div></div></div></div><div class = "S12"><span class = "S2"><span class="S0">En el caso de la práctica 3 la función de transferencia obtenida tenía la siguiente estructura:</span></span></div><div class = "S4"><span style="vertical-align:-20px"><img src="" width="894.5" height="43" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Como podemos observar, al fijar los polos mediante las ganancias del controlador, automáticamente se fijan los ceros de lazo cerrado. Las expresiones de los polos de lazo cerrado son los siguientes:</span></span></div><div class = "S4"><span style="vertical-align:-20px"><img src="" width="454.5" height="50" /></span></div><div class = "S4"><span class = "S2"><span class="S0">En el caso del I-PD sin embargo, la función de transferencia de lazo cerrado es la siguiente:</span></span></div><div class = "S4"><span style="vertical-align:-20px"><img src="" width="1464" height="42.5" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Como podemos observar, en este caso, los ceros estan fijados en:</span></span></div><div class = "S4"><span style="vertical-align:-17px"><img src="" width="163" height="37.5" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Para obtener las ecuaciones de sintonía, sin embargo, como podemos ver, la ecuación obtenida no es lineal, con lo cual substituiremos el controlador con la forma canónica del PID y después los relacionaremos con el PID implementado.</span></span></div><div class = "S4"><span class = "S2"><span class="S0">La función de transferencia canónica del PID tiene la siguiente forma:</span></span></div><div class = "S4"><span style="vertical-align:-15px"><img src="" width="257.5" height="37" /></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 el denominador de la función de transferencia de lazo cerrado con el controlador canónico toma la forma:</span></span></div><div class = "S4"><span style="vertical-align:-6px"><img src="" width="739" height="20" /></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 cuatro incógnitas, igualando los coeficientes y representándolo en forma matricial, el sistema en lazo cerrado sería:</span></span></div><div class = "S4"><span style="vertical-align:-41px"><img src="" width="509.5" height="91.5" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Este sistema lineal es fácilmente resoluble 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 = "S4"><span class = "S2"><span class="S0">Por último, para obtener los parámetros </span></span><span style="vertical-align:-6px"><img src="" width="60.5" height="19.5" /></span><span class = "S2"><span class="S0"> obtendremos la relación entre nuestro controlador y el modelo canónico.</span></span></div><div class = "S4"><span class = "S2"><span class="S0">Nuestro controlador, se puede representar también de la siguiente manera:</span></span></div><div class = "S4"><span style="vertical-align:-15px"><img src="" width="468" height="39" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Con lo cual, igualando los coeficientes y representándolo en forma matricial:</span></span></div><div class = "S4"><span style="vertical-align:-31px"><img src="" width="213" height="71.5" /></span></div><div class = "S4"><span class = "S2"><span class="S0">Como se ha hecho anteriormente, este sistema es fácilmente soluble mediante MATLAB, siendo la solución </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">'IPDpos'</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">IPD_real_ideal.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">IPD_real_ideal.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">'IPD_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">'Prac4'</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(IPD_real_ideal.time,</span><span class="S0">[</span><span class="S0">IPD_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(IPD_real_ideal.time,</span><span class="S0">[</span><span class="S0">IPD_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(IPD_real_ideal.time,</span><span class="S0">[</span><span class="S0">IPD_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([16 48]);</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">'Referencia, simulación y salida real'</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">'Referencia'</span><span class="S0">,</span><span class="S14">'Respuesta Real'</span><span class="S0">,</span><span class="S14">'Siumulación'</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="829CC65B" data-testid="output_18" style="width: 1076px; 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 podemos observar, en este caso, las especificaciones se cumplen en el caso ideal (simulación con el modelo de la planta), pero a la hora de controlar la planta real con esta simulación, podemos observar que, aunque el controlador sea capaz de controlar la planta, las respuestas son bastante distintas. Esto es porque el modelo de la planta no representa fielmente la planta real, ya que hay dinámicas no modeladas.</span></span></div></div></div><br><!-- <br>##### SOURCE BEGIN #####<br>%% *Práctica 4: Mejora de los controladores PID implementados en la práctica 3*<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 I-P de velocidad de salida para que el <br>% sistema de lazo cerrado tenga un error estacionario nulo. Diseñar un controlador <br>% I-PD 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 I-P y un I-PD por asignación de polos.*<br>% * *Verificar experimentalmente el sistema de control diseñado.*<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 14: Diseño e implementación de un I-P por asignación de polos.<br>% Como se puede observar en la práctica 3, al diseñar un controlador PI con <br>% una planta de primer orden tienen como respuesta un sistema con dos polos y <br>% un cero. Este último, tiene un efecto negativo en la dinámica del sistema, normalmente <br>% haciéndola un poco más rápida de lo deseado, es por eso, que obteníamos un pequeño <br>% sobreimpulso. Para eliminar el efecto del cero, se propone la siguiente alternativa <br>% de introducir las acciones proporcional e integral.<br>% <br>% <br>% <br>% Esta estructura toma el nombre de controlador I-P, y como se puede observar, <br>% la acción integral se realimenta desde el error, mientras que la parte proporcional <br>% se realimenta desde la salida, es por esto, que la respuesta a un escalón del <br>% sistema con un controlador I-P será más suave que la de un sistema con un controlador <br>% PI. Como se ha hecho en el P3, se desea diseñar un I-P de control de velocidad <br>% que haga que la respuesta temporal a una entrada escalón no presente sobreimpulsos <br>% y que el tiempo de establecimiento (con el criterio del 2%) sea de 0.8 segundos. <br>% Para la simulación del controlador I-P digital, abrir y ejecutar el modelo P4_Ex14a.slx. <br>% Para su comprobación con el motor, abrir y ejecutar el modelo P4_Ex14b.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>% En este caso, la función de transferencia de lazo cerrado:<br>% <br>% $$\mathrm{l}c\left(z\right)=\frac{\mathrm{IP}\left(z\right)G\left(z\right)}{1+\mathrm{IP}\left(z\right)G\left(z\right)}=\frac{k_{\textrm{mot}} <br>% k_i^* \left(z+1\right)\left(1-\alpha \right)}{\left(z-1\right)\left(z-\alpha <br>% \right)+k_{\textrm{mot}} \left(k_p +k_i^* \right)\left(z+\frac{k_i^* -k_p }{k_i^* <br>% +k_p }\right)\left(1-\alpha \right)}$$<br>% <br>% En el caso del PI la función de transferencia de lazo cerrado era:<br>% <br>% $$\mathrm{l}c\left(z\right)=\frac{\mathrm{PI}\left(z\right)G\left(z\right)}{1+\mathrm{PI}\left(z\right)G\left(z\right)}=\frac{k_{\textrm{mot}} <br>% k_i^* \left(z+\frac{k_i^* -k_p }{k_i^* +k_p }\right)\left(1-\alpha \right)}{\left(z-1\right)\left(z-\alpha <br>% \right)+k_{\textrm{mot}} \left(k_p +k_i^* \right)\left(z+\frac{k_i^* -k_p }{k_i^* <br>% +k_p }\right)\left(1-\alpha \right)}$$<br>% <br>% Como podemos observar, al fijar los polos mediante las ganancias del controlador, <br>% automáticamente se fija el cero de lazo cerrado. Sin embargo, si analizamos <br>% el cero de la arquitectura del I-P, podemos ver como el cero se fija en z=-1. <br>% Vale la pena comentar que la acción proporcional del controlador de IP no ve <br>% la referencia, por lo que la respuesta del sistema de lazo cerrado a una entrada <br>% por escalón de un controlador del IP es más suave que la del PI.<br>% <br>% Como el denominador de lazo cerrado es el mismo que el obtenido en la práctica <br>% 3, las ecuaciones utilizadas para ajustar los parámetros del controlador son <br>% exactamente las mismas que las utilizadas para el controlador PI.<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 del controlador I-P se pueden observar en la <br>% siguiente imagen.<br><br>% Dibujar la respuesta del motor<br>if useExperimentalData<br> % Usar Simulink<br> addpath([pwd filesep 'IPvel']);<br> open IP_experimental.slx;<br> run IP_experimental.slx;<br>else<br> FileName = 'IP_ideal.mat';<br> cd('..')<br> FolderName = [pwd filesep 'Common' filesep 'Resultados' filesep 'Prac3'];<br> File = fullfile(FolderName, FileName);<br> load(File); <br> <br> FileName = 'IP_real.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(IP_ideal.time,[IP_ideal.signals.values(:,1,:)],'r')<br>hold on; grid on;<br>plot(IP_real.time,[IP_real.signals.values(:,2,:)],'b')<br>plot(IP_ideal.time,[IP_ideal.signals.values(:,2,:)],'g')<br>xlim([18 60]); ylim([-2.3 2.3]);<br>xlabel('Tiempo (s)');<br>ylabel('Voltaje (V)');<br>title('Referencia, simulación y salida real');<br>legend('Referencia','Respuesta Real','Siumulación');<br>%% <br>% Como se puede analizar, las dos respuestas son prácticamente iguales y <br>% con lo cual, el sistema real cumple las especificaciones deseadas.<br>%% Ejercicio 15: Diseño e implementación de un I-PD por asignación de polos.<br>% Como se puede observar en la práctica 3, al diseñar un controlador PID con <br>% una planta de segundo orden tienen como respuesta un sistema con cuatro polos <br>% y tres cero. Para poder diseñar un controlador PID donde se cumplan las especificaciones, <br>% hay que hacer dos modificaciones principales, la primera, añadir un nuevo parámetro <br>% al controlador para poder fijar los cuatro polos del sistema, y el segundo, <br>% modificar la estructura para eliminar el efecto de los ceros.<br>% <br>% Con lo cual, el nuevo controlador, tendrá la siguiente estructura:<br>% <br>% $$\textrm{controlador}\;\textrm{PI}\mathrm{D}:\mathrm{P}\textrm{ID}\left(z\right)=k_p <br>% +k_i^* \frac{z+1}{z-1}+k_d^* \;\frac{z-1}{z+\alpha }\;\;\;\;\textrm{donde}\;\;\;\;k_i^* <br>% =k_i \frac{T_s }{2}\;\;y\;k_d^* =\frac{k_d }{T_s }$$<br>% <br>% Para eliminar el efecto de los ceros, se propone la siguiente alternativa <br>% de introducir las acciones proporcional, integral y derivativa.<br>% <br>% <br>% <br>% Esta estructura toma el nombre de controlador I-PD, y como se puede observar, <br>% la acción integral se realimenta desde el error, mientras que las acciones proporcional <br>% y derivativa se realimentan desde la salida.<br>% <br>% En este ejercicio se desea diseñar un I-PD de control de posición que haga <br>% que la respuesta temporal a una entrada escalón presente un sobreimpulso del <br>% 80% y una frecuencia de oscilación de 0,5 Hz.<br>% <br>% Toma el periodo de muestreo Ts igual a 0,01s. Determinar el valor de $k_p$,$\;k_i$ <br>% y $k_d$ y $\alpha$. <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 cumplirán 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 y cuarto polo <br>p3=0.8<br>p4=0.8<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 0 0; ...<br> b1-1 a0 a1 0; <br> b0-b1 0 a0 a1; <br> -b0 0 0 a0] ;<br>b=[-b1+1-p1-p2-p3-p4; <br> -b0+b1+p1*p2-(-p1-p2)*p3-(-p1-p2-p3)*p4; <br> b0-p1*p2*p3-(p1*p2-(-p1-p2)*p3)*p4; <br> p1*p2*p3*p4] ;<br><br>% Controlador <br>x=inv(A)*b ; <br><br>alpha=x(1)<br>c2=x(2)<br>c1=x(3)<br>c0=x(4)<br>A2=[1 1 1; alpha-1 alpha+1 -2; -alpha alpha 1];<br>B2=[c2;c1;c0];<br><br>x2=inv(A2)*B2;<br><br>kp = x2(1)<br>ki = (2/Ts)*x2(2)<br>kd = Ts*x2(3)<br>%% <br>% En el caso de la práctica 3 la función de transferencia obtenida tenía <br>% la siguiente estructura:<br>% <br>% $$\mathrm{cl}\left(z\right)=\frac{a_1 \left(k_p +k_i^* {+k}_d^* \right)z^3 <br>% +\left\lbrack a_1 \left(k_i^* -k_p -2k_d^* \right)+a_0 \left(k_p +k_i^* {+k}_d^* <br>% \right)\right\rbrack z^2 +\left\lbrack a_1 k_d^* +a_0 \left(k_i^* -k_p -2k_d^* <br>% \right)\right\rbrack z+a_0 k_d^* }{z^4 +\left(-1+k_i^* a_1 +b_1 +k_d^* a_1 +k_p <br>% a_1 \right)z^3 +\left(-b_1 -k_p a_1 +k_p a_0 +b_0 -2k_d^* a_1 +k_i^* a_0 +k_i^* <br>% a_1 +k_d^* a_0 \right)z^2 +\left(k_i^* a_0 -b_0 -2k_d^* a_0 -k_p a_0 +k_d^* <br>% a_1 \right)z+k_d^* a_0 }$$<br>% <br>% Como podemos observar, al fijar los polos mediante las ganancias del controlador, <br>% automáticamente se fijan los ceros de lazo cerrado. Las expresiones de los polos <br>% de lazo cerrado son los siguientes:<br>% <br>% $$z_{1,2} =\frac{-\left(k_i^* -k_p -2k_d^* \right)\pm \sqrt{-4k_d^* \left(k_p <br>% +k_i^* {+k}_d^* \right)+{\left(k_i^* -k_p -2k_d^* \right)}^2 }}{2\left(k_p +k_i^* <br>% {+k}_d^* \right)}\;,\;z_3 =\frac{a_0 }{a_1 }$$<br>% <br>% En el caso del I-PD sin embargo, la función de transferencia de lazo cerrado <br>% es la siguiente:<br>% <br>% $$\textrm{cl}\left(z\right)=\frac{k_i^* \left(z+1\right)\left(a_1 z+a_0 <br>% \right)\left(z+\alpha \right)}{z^4 +\left(b_1 -1+\alpha +k_i^* a_1 +k_d^* a_1 <br>% +k_p a_1 \right)z^3 +\left(b_0 -b_1 +b_1 \alpha -\alpha +k_p a_1 \left(\alpha <br>% -1\right)+k_p a_0 -2k_d^* a_1 +k_i^* a_0 +k_i^* a_1 \left(\alpha +1\right)+k_d^* <br>% a_0 \right)z^2 +\left(-b_0 +b_0 \alpha -b_1 \alpha +k_p a_0 \left(\alpha -1\right)-k_p <br>% a_1 \alpha +k_i^* a_0 \left(\alpha +1\right)+k_i^* a_1 \alpha -2k_d^* a_0 +k_d^* <br>% a_1 \right)z+k_d^* a_0 +k_i^* a_0 \alpha -k_p a_0 \alpha -b_0 \alpha }$$<br>% <br>% Como podemos observar, en este caso, los ceros estan fijados en:<br>% <br>% $$z_1 =-1,z_2 =-\alpha ,z_3 =\frac{-a_0 }{a_1 }$$<br>% <br>% Para obtener las ecuaciones de sintonía, sin embargo, como podemos ver, <br>% la ecuación obtenida no es lineal, con lo cual substituiremos el controlador <br>% con la forma canónica del PID y después los relacionaremos con el PID implementado.<br>% <br>% La función de transferencia canónica del PID tiene la siguiente forma:<br>% <br>% $$\textrm{controlador}\;\textrm{PI}\mathrm{D}:\mathrm{P}\textrm{ID}\left(z\right)=\frac{c_2 <br>% z^2 +c_1 z+c_0 }{\left(z-1\right)\left(z+\alpha \right)}$$<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 el denominador de la función de transferencia de lazo cerrado <br>% con el controlador canónico toma la forma:<br>% <br>% $$\textrm{Den}\left(z\right)=z^4 +\left\lbrack \alpha -1+b_1 +c_2 a_1 \right\rbrack <br>% z^3 +\left\lbrack \left(b_1 -1\right)\alpha -b_1 +b_0 +a_1 c_1 +a_0 c_2 \right\rbrack <br>% z^2 +\left\lbrack \left(b_0 -b_1 \right)\alpha -b_0 +a_0 c_1 +c_0 a_1 \right\rbrack <br>% z+c_0 a_0 -\alpha b_0$$<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 cuatro incógnitas, igualando los coeficientes <br>% y representándolo en forma matricial, el sistema en lazo cerrado sería:<br>% <br>% $$\left\lbrack \begin{array}{cccc}1 & a_1 & 0 & 0\\b_1 -1 & a_0 & a_1 <br>% & 0\\b_0 -b_1 & 0 & a_0 & a_1 \\-b_0 & 0 & 0 & a_0 \end{array}\right\rbrack <br>% \left\lbrack \begin{array}{c}\alpha \\c_2 \\c_1 \\c_0 \end{array}\right\rbrack <br>% =\left\lbrack \begin{array}{c}1-b_1 -p_1 {-p}_2 -p_3 -p_4 \\b_1 -b_0 +p_1 p_2 <br>% -\left({-p}_1 -p_2 \right)p_3 -\left(-p_1 -p_2 -p_3 \right)p_4 \\b_0 {-p}_1 <br>% p_2 p_3 -\left(p_1 p_2 -\left({-p}_1 -p_2 \right)p_3 \right)p_4 \\p_1 p_2 p_3 <br>% p_4 \end{array}\right\rbrack$$<br>% <br>% Este sistema lineal es fácilmente resoluble 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>% Por último, para obtener los parámetros $k_p {,\;k}_i \;y\;k_d$ obtendremos <br>% la relación entre nuestro controlador y el modelo canónico.<br>% <br>% Nuestro controlador, se puede representar también de la siguiente manera:<br>% <br>% $$\mathrm{P}\textrm{ID}\left(z\right)=\frac{\left(k_p +k_i^* +k_d^* \right)z^2 <br>% +\left(k_p \left(\alpha -1\right)+k_i^* \left(\alpha +1\right)-2k_d^* \right)z-k_p <br>% \alpha +k_i^* \alpha +k_d^* }{\left(z-1\right)\left(z+\alpha \right)}$$<br>% <br>% Con lo cual, igualando los coeficientes y representándolo en forma matricial:<br>% <br>% $$\left\lbrack \begin{array}{ccc}1 & 1 & 1\\\alpha -1 & \alpha +1 & -2\\-\alpha <br>% & \alpha & 1\end{array}\right\rbrack \left\lbrack \begin{array}{c}k_p \\k_i^* <br>% \\k_d^* \end{array}\right\rbrack =\left\lbrack \begin{array}{c}c_2 \\c_1 \\c_0 <br>% \end{array}\right\rbrack$$<br>% <br>% Como se ha hecho anteriormente, este sistema es fácilmente soluble mediante <br>% MATLAB, siendo la solución $x=\textrm{inv}\left(A\right)·b$.<br><br>% Dibujar la respuesta del motor<br>if useExperimentalData<br> % Usar Simulink<br> addpath([pwd filesep 'IPDpos']);<br> open IPD_real_ideal.slx;<br> run IPD_real_ideal.slx;<br>else<br> FileName = 'IPD_real_ideal.mat';<br> FolderName = [pwd filesep 'Common' filesep 'Resultados' filesep 'Prac4'];<br> File = fullfile(FolderName, FileName);<br> load(File); <br>end<br><br>figure<br>plot(IPD_real_ideal.time,[IPD_real_ideal.signals.values(:,1,:)],'r')<br>hold on; grid on;<br>plot(IPD_real_ideal.time,[IPD_real_ideal.signals.values(:,2,:)],'b')<br>plot(IPD_real_ideal.time,[IPD_real_ideal.signals.values(:,3,:)],'g')<br>xlim([16 48]);<br>xlabel('Tiempo (s)');<br>ylabel('Voltaje (V)');<br>title('Referencia, simulación y salida real');<br>legend('Referencia','Respuesta Real','Siumulación');<br>%% <br>% Como podemos observar, en este caso, las especificaciones se cumplen en <br>% el caso ideal (simulación con el modelo de la planta), pero a la hora de controlar <br>% la planta real con esta simulación, podemos observar que, aunque el controlador <br>% sea capaz de controlar la planta, las respuestas son bastante distintas. Esto <br>% es porque el modelo de la planta no representa fielmente la planta real, ya <br>% que hay dinámicas no modeladas.<br>##### SOURCE END #####<br>--></body></html>