1 PLANTWIDE CONTROL Sigurd Skogestad Department of Chemical Engineering Norwegian University of Science and Tecnology (NTNU) Trondheim, Norway
2 Outline Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (primary CV’s) (self-optimizing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control (secondary CV’s) ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
3 Idealized view of control (“Ph.D. control”)
4 Practice: Tennessee Eastman challenge problem (Downs, 1991) (“PID control”)
5 Idealized view II: Optimizing control
6 Practice II: Hierarchical decomposition with separate layers What should we control?
7 Outline About Trondheim and myself Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (self-optimizing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
8 Stepwise procedure plantwide control I. TOP-DOWN Step 1. DEGREES OF FREEDOM Step 2. OPERATIONAL OBJECTIVES Step 3. WHAT TO CONTROL? (primary CV’s c=y 1 ) Step 4. PRODUCTION RATE II. BOTTOM-UP (structure control system): Step 5. REGULATORY CONTROL LAYER (PID) “Stabilization” What more to control? (secondary CV’s y 2 ) Step 6. SUPERVISORY CONTROL LAYER (MPC) Decentralization Step 7. OPTIMIZATION LAYER (RTO) Can we do without it?
9 Outline About Trondheim and myself Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (self-optimzing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
10 Step 1. Degrees of freedom (DOFs) m – dynamic (control) degrees of freedom = valves u 0 – steady-state degrees of freedom N m : no. of dynamic (control) DOFs (valves) N u0 = N m - N 0 : no. of steady-state DOFs –N 0 = N 0y + N 0m : no. of variables with no steady-state effect N 0m : no. purely dynamic control DOFs N 0y : no. controlled variables (liquid levels) with no steady-state effect Cost J depends normally only on steady-state DOFs
11 N m =, N 0y =, N u0 = Distillation column with given feed
12 Heat-integrated distillation process
13 Heat exchanger with bypasses
14 Typical number of steady-state degrees of freedom (u 0 ) for some process units each external feedstream: 1 (feedrate) splitter: n-1 (split fractions) where n is the number of exit streams mixer: 0 compressor, turbine, pump: 1 (work) adiabatic flash tank: 1 (0 with fixed pressure) liquid phase reactor: 1 (volume) gas phase reactor: 1 (0 with fixed pressure) heat exchanger: 1 (duty or net area) distillation column excluding heat exchangers: 1 (0 with fixed pressure) + number of sidestreams
15 HDA process MixerFEHE FurnacePFR Quench Separator Compressor Cooler Stabilizer Benzene Column Toluene Column H 2 + CH 4 Toluene Benzene CH 4 Diphenyl Purge (H 2 + CH 4 )
16 Check that there are enough manipulated variables (DOFs) - both dynamically and at steady-state (step 2) Otherwise: Need to add equipment –extra heat exchanger –bypass –surge tank
17 Outline About Trondheim and myself Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (self-optimzing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
18 Optimal operation (economics) What are we going to use our degrees of freedom for? Define scalar cost function J(u 0,x,d) –u 0 : degrees of freedom –d: disturbances –x: states (internal variables) Typical cost function: Optimal operation for given d: min u0 J(u 0,x,d) subject to: Model equations: f(u 0,x,d) = 0 Operational constraints: g(u 0,x,d) < 0 J = cost feed + cost energy – value products
19 Optimal operation distillation column Steady-state DOFs (given p and F): 2, for example L/D and V Cost to be minimized (economics) J = - P where P= p D D + p B B – p F F – p V V Constraints Purity D: For example x D, impurity · max Purity B: For example, x B, impurity · max Flow constraints: min · D, B, L etc. · max Column capacity (flooding): V · V max, etc. Pressure: 1) p given, 2) p free: p min · p · p max Feed: 1) F given 2) F free: F · F max Optimal operation: Minimize J with respect to steady-state DOFs value products cost energy (heating+ cooling) cost feed
20 Outline About Trondheim and myself Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (self-optimizing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
21 Step 3. What should we control (c)? Outline Implementation of optimal operation Self-optimizing control Uncertainty (d and n) Example: Marathon runner Methods for finding the “magic” self-optimizing variables: A. Large gain: Minimum singular value rule B. “Brute force” loss evaluation C. Optimal combination of measurements Example: Recycle process Summary
22 Implementation of optimal operation Optimal operation for given d * : min u0 J(u 0,x,d) subject to: Model equations: f(u 0,x,d) = 0 Operational constraints: g(u 0,x,d) < 0 → u 0opt (d * ) Problem: Cannot keep u 0opt constant because disturbances d change Distillation: Steady-state degrees of freedom u 0 could be L/D and V. Cannot keep these constant
23 Problem: Too complicated (requires detailed model and description of uncertainty) Implementation of optimal operation (Cannot keep u 0opt constant) ”Obvious” solution: Optimizing control Estimate d from measurements and recompute u 0opt (d)
24 Implementation of optimal operation (Cannot keep u 0opt constant) Simpler solution: Look for another variable c which is better to keep constant and control c at constant setpoint c s = c opt (d*) Note: u 0 will indirectly change when d changes
25 What c’s should we control? Optimal solution is usually at constraints, that is, most of the degrees of freedom are used to satisfy “active constraints”, g(u 0,d) = 0 CONTROL ACTIVE CONSTRAINTS! –c s = value of active constraint –Implementation of active constraints is usually simple. WHAT MORE SHOULD WE CONTROL? –Find variables c for remaining unconstrained degrees of freedom u.
26 Solution to optimal operation distillation Cost to be minimized J = - P where P= p D D + p B B – p F F – p V V Optimal operation: Minimize J with respect to DOFs General: Optimal solution with N DOFs: –N – N u DOFs used to satisfy “active” constraints ( · is =) –N u remaining unconstrained variables Usually: N u zero or small Distillation at steady state with given p and F: N=2 DOFs. Three cases: 1.N u =0: Two active constraints (for example, x D, impurity = max. x B, impurity = max, “TWO-POINT” CONTROL) 2.N u =1: One constraint active 3.N u =2: No constraints active very unlikely unless there are no purity specifications (e.g. byproducts or recycle)
27 Remaining unconstrained variables: What should we control? (primary controlled variables y 1 =c) Intuition: “Dominant variables” (Shinnar) Systematic: Minimize cost J(u 0,d * ) w.r.t. DOFs u 0. 1.Control active constraints (constant setpoint is optimal) 2.Remaining unconstrained DOFs: Control “self-optimizing” variables c for which constant setpoints c s = c opt (d * ) give small (economic) loss Loss = J - J opt (d) when disturbances d ≠ d * occur c = ? (economics) y 2 = ? (stabilization)
28 Self-optimizing Control Self-optimizing control is when acceptable operation can be achieved using constant set points (c s ) for the controlled variables c (without the need to re-optimizing when disturbances occur). c=c s
29 The difficult unconstrained variables Cost J Selected controlled variable (remaining unconstrained) c opt J opt c
30 Implementation of unconstrained variables is not trivial: How do we deal with uncertainty? 1. Disturbances d (c opt (d) changes) 2. Implementation error n (actual c ≠ c opt ) c s = c opt (d * ) – nominal optimization n c = c s + n d Cost J J opt (d)
31 Problem no. 1: Disturbance d Cost J Controlled variable c opt (d * ) J opt d*d*d*d* d ≠ d * Loss with constant value for c ) Want c opt independent of d
32 Example: Tennessee Eastman plant J c = Purge rate Nominal optimum setpoint is infeasible with disturbance 2 Oopss.. bends backwards Conclusion: Do not use purge rate as controlled variable
33 Problem no. 2: Implementation error n Cost J c s =c opt (d * ) J opt d*d*d*d* Loss due to implementation error for c c = c s + n ) Want n small and ”flat” optimum
34 Effect of implementation error on cost (“problem 2”) BADGood
35 Example sharp optimum. High-purity distillation : c = Temperature top of column Temperature T top Water (L) - acetic acid (H) Max 100 ppm acetic acid 100 C: 100% water C: 100 ppm C: Infeasible
36 Summary unconstrained variables: Which variable c to control? Self-optimizing control: Constant setpoints c s give ”near-optimal operation” (= acceptable loss L for expected disturbances d and implementation errors n) Acceptable loss ) self-optimizing control
37 Examples self-optimizing control Marathon runner Central bank Cake baking Business systems (KPIs) Investment portifolio Biology Chemical process plants: Optimal blending of gasoline Define optimal operation (J) and look for ”magic” variable (c) which when kept constant gives acceptable loss (self- optimizing control)
38 Self-optimizing Control – Marathon Optimal operation of Marathon runner, J=T –Any self-optimizing variable c (to control at constant setpoint)?
39 Self-optimizing Control – Marathon Optimal operation of Marathon runner, J=T –Any self-optimizing variable c (to control at constant setpoint)? c 1 = distance to leader of race c 2 = speed c 3 = heart rate c 4 = level of lactate in muscles
40 Self-optimizing Control – Marathon Optimal operation of Marathon runner, J=T –Any self-optimizing variable c (to control at constant setpoint)? c 1 = distance to leader of race (Problem: Feasibility for d) c 2 = speed (Problem: Feasibility for d) c 3 = heart rate (Problem: Impl. Error n) c 4 = level of lactate in muscles (Problem: Impl.error n)
41 Self-optimizing Control – Sprinter Optimal operation of Sprinter (100 m), J=T –Active constraint control: Maximum speed (”no thinking required”)
42 Further examples Central bank. J = welfare. u = interest rate. c=inflation rate (2.5%) Cake baking. J = nice taste, u = heat input. c = Temperature (200C) Business, J = profit. c = ”Key performance indicator (KPI), e.g. –Response time to order –Energy consumption pr. kg or unit –Number of employees –Research spending Optimal values obtained by ”benchmarking” Investment (portofolio management). J = profit. c = Fraction of investment in shares (50%) Biological systems: –”Self-optimizing” controlled variables c have been found by natural selection –Need to do ”reverse engineering” : Find the controlled variables used in nature From this possibly identify what overall objective J the biological system has been attempting to optimize
43 Mathematical: Local analysis u cost J u opt
44 Unconstrained degrees of freedom: Looking for “magic” variables to keep at constant setpoints. What properties do they have? Skogestad and Postlethwaite (1996): c-c opt should be small: The optimal value of c should be insensitive to disturbances c should be easy to measure and control accurately G -1 should be small, i.e (G) should be large: The value of c should be sensitive to changes in the steady- state degrees of freedom (Equivalently, J as a function of c should be flat) For cases with more than one unconstrained degrees of freedom, the selected controlled variables should be independent. Summarized by maximum gain (min. singular value) rule Avoid problem 1 (d) Avoid problem 2 (n)
45 Unconstrained degrees of freedom: Looking for “magic” variables to keep at constant setpoints. How can we find them systematically? A. Maximum gain (minimum singular value) rule: B. “Brute force”: Consider available measurements y, and evaluate loss when they are kept constant: C. More general: Find optimal linear combination (matrix H):
46 Optimizer Controller that adjusts u to keep c m = c s Plant cscs c m =c+n u c n d u c J c s =c opt u opt n Unconstrained degrees of freedom: A. Maximum gain rule Want the slope (= gain G from u to y) as large as possible
47 Unconstrained degrees of freedom: A. Maximum gain (minimum singular value) rule “Maximum gain rule” (Skogestad and Postlethwaite, 1996): Look for variables c that maximize the minimum singular value ( G) of the appropriately scaled steady-state gain matrix G from u to c u: unconstrained degrees of freedom Loss Scaling is important: –Scale c such that their expected variation is similar (divide by “span”= optimal variation + noise) –Scale inputs u such that they have similar effect on cost J (J uu unitary) (G) is called the Morari Resiliency index (MRI) by Luyben Detailed proof: I.J. Halvorsen, S. Skogestad, J.C. Morud and V. Alstad, ``Optimal selection of controlled variables'', Ind. Eng. Chem. Res., 42 (14), (2003).
48 Maximum gain rule in words Select controlled variables c for which their controllable range is large compared to their sum of optimal variation and control error controllable range = range c may reach by varying the inputs (=gain) optimal variation: due to disturbance control error = implementation error n span
49 What should we control? Rule: Maximize the scaled gain Scalar case. Minimum singular value = gain |G| Maximize scaled gain: |G s | = |G| / span –|G|: gain from independent variable (u) to candidate controlled variable (c) –span (of c) = optimal variation in c + control error for c
50 Generally (more than unconstrained variable): Scaling for “maximum gain ( rule” “Control active constraints” and look at the remaining unconstrained problem Candidate outputs: Divide by span = optimal range + implementation error Candidate inputs: –A unit deviation in each input should have the same effect on the cost function (i.e. J uu should be constant times identity) –Alternatively (often simpler), consider (J uu 1/2 G)
51 B. “Brute-force” procedure for selecting (primary) controlled variables (Skogestad, 2000) Step 1 Determine DOFs for optimization Step 2 Definition of optimal operation J (cost and constraints) Step 3 Identification of important disturbances Step 4 Optimization (nominally and with disturbances) Step 5 Identification of candidate controlled variables (use active constraint control) Step 6 Evaluation of loss with constant setpoints for alternative controlled variables Step 7 Evaluation and selection (including controllability analysis) Case studies: Tenneessee-Eastman, Propane-propylene splitter, recycle process, heat-integrated distillation
52 B. Brute-force procedure Define optimal operation: Minimize cost function J Each candidate variable c: With constant setpoints c s compute loss L for expected disturbances d and implementation errors n Select variable c with smallest loss Acceptable loss ) self-optimizing control
53 Unconstrained degrees of freedom: C. Optimal measurement combination (Alstad, 2002) Basis: Want optimal value of c independent of disturbances ) – c opt = 0 ¢ d Find optimal solution as a function of d: u opt (d), y opt (d) Linearize this relationship: y opt = F d F – sensitivity matrix Want: To achieve this for all values of d: Always possible if Optimal when we disregard implementation error (n)
54 Alstad-method continued To handle implementation error: Use “sensitive” measurements, with information about all independent variables (u and d)
55 Toy Example
56 Toy Example
57 Toy Example
58 EXAMPLE: Recycle plant (Luyben, Yu, etc.) Given feedrate F 0 and column pressure: Dynamic DOFs: N m = 5 Column levels: N 0y = 2 Steady-state DOFs:N 0 = = 3
59 Recycle plant: Optimal operation mTmT 1 remaining unconstrained degree of freedom
60 Control of recycle plant: Conventional structure (“Two-point”: x D ) LC XC LC XC LC xBxB xDxD Control active constraints (M r =max and x B =0.015) + x D
61 Luyben rule Luyben rule (to avoid snowballing): “Fix a stream in the recycle loop” (F or D)
62 Luyben rule: D constant Luyben rule (to avoid snowballing): “Fix a stream in the recycle loop” (F or D) LC XC
63 A. Maximum gain rule: Steady-state gain Luyben rule: Not promising economically Conventional: Looks good
64 B. “Brute force” loss evaluation: Disturbance in F 0 Loss with nominally optimal setpoints for M r, x B and c Luyben rule: Conventional
65 B. “Brute force” loss evaluation: Implementation error Loss with nominally optimal setpoints for M r, x B and c Luyben rule:
66 C. Optimal measurement combination 1 unconstrained variable (#c = 1) 1 (important) disturbance: F 0 (#d = 1) “Optimal” combination requires 2 “measurements” (#y = #u + #d = 2) –For example, c = h 1 L + h 2 F BUT: Not much to be gained compared to control of single variable (e.g. L/F or x D )
67 Conclusion: Control of recycle plant Active constraint M r = M rmax Active constraint x B = x Bmin L/F constant: Easier than “two-point” control Assumption: Minimize energy (V) Self-optimizing
68 Recycle systems: Do not recommend Luyben’s rule of fixing a flow in each recycle loop (even to avoid “snowballing”)
69 Summary: Procedure selection controlled variables 1.Define economics and operational constraints 2.Identify degrees of freedom and important disturbances 3.Optimize for various disturbances 4.Identify (and control) active constraints (off-line calculations) May vary depending on operating region. For each operating region do step 5: 5.Identify “self-optimizing” controlled variables for remaining degrees of freedom 1.(A) Identify promising (single) measurements from “maximize gain rule” (gain = minimum singular value) (C) Possibly consider measurement combinations if no promising 2.(B) “Brute force” evaluation of loss for promising alternatives Necessary because “maximum gain rule” is local. In particular: Look out for feasibility problems. 3.Controllability evaluation for promising alternatives
70 Selection of controlled variables More examples and exercises HDA process Cooling cycle Distillation (C3-splitter) Blending
71 Summary ”self-optimizing” control Operation of most real system: Constant setpoint policy (c = c s ) –Central bank –Business systems: KPI’s –Biological systems –Chemical processes Goal: Find controlled variables c such that constant setpoint policy gives acceptable operation in spite of uncertainty ) Self-optimizing control Method A: Maximize (G) Method B: Evaluate loss L = J - J opt Method C: Optimal linear measurement combination: c = H y where HF=0
72 Outline Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (self-optimzing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
73 Step 4. Where set production rate? Very important! Determines structure of remaining inventory (level) control system Set production rate at (dynamic) bottleneck Link between Top-down and Bottom-up parts
74 Production rate set at inlet : Inventory control in direction of flow
75 Production rate set at outlet: Inventory control opposite flow
76 Production rate set inside process
77 Where set the production rate? Very important decision that determines the structure of the rest of the control system! May also have important economic implications
78 Optimal: Set production rate at bottleneck! "A bottleneck is an extensive variable that prevents an increase in the overall feed rate to the plant" If feed is cheap: Optimal to set production rate at bottleneck If the flow for some time is not at its maximum through the bottleneck, then this loss can never be recovered.
79 Reactor-recycle process: Given feedrate with production rate set at inlet
80 Reactor-recycle process: Given feedrate with production rate set at inlet Bottleneck: max. vapor rate in column
81 Reactor-recycle process with production rate set at inlet Want to maximize feedrate: reach bottleneck in column Bottleneck: max. vapor rate in column FC V max V V max -V s =Back-off = Loss Alt.1: Loss VsVs
82 Alt.2 “long loop” MAX Reactor-recycle process with increased feedrate: Optimal: Set production rate at bottleneck
83 Reactor-recycle process with increased feedrate: Optimal: Set production rate at bottleneck MAX Alt.3: reconfigure
84 Reactor-recycle process: Given feedrate with production rate set at bottleneck F 0s Alt.3: reconfigure (permanently)
85 Can reduce loss BUT: Is generally placed on top of the regulatory control system (including level loops), so it still important where the production rate is set! Alt.4: Multivariable control (MPC)
86 Conclusion production rate manipulator Think carefully about where to place it! Difficult to undo later
87 Outline Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (self-optimizing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
88 II. Bottom-up Determine secondary controlled variables and structure (configuration) of control system (pairing) A good control configuration is insensitive to parameter changes Step 5. REGULATORY CONTROL LAYER 5.1Stabilization (including level control) 5.2Local disturbance rejection (inner cascades) What more to control? (secondary variables) Step 6. SUPERVISORY CONTROL LAYER Decentralized or multivariable control (MPC)? Pairing? Step 7. OPTIMIZATION LAYER (RTO)
89 Example: Distillation Primary controlled variable: y 1 = c = x D, x B (compositions top, bottom) BUT: Delay in measurement of x + unreliable Regulatory control: For “stabilization” need control of: –Liquid level condenser (M D ) –Liquid level reboiler (M B ) –Pressure (p) –Holdup of light component in column (temperature profile) Unstable (Integrating) + No steady-state effect Disturbs (“destabilizes”) other loops Almost unstable (integrating)
90 Step 5. Regulatory control layer Purpose: “Stabilize” the plant using local SISO PID controllers Enable manual operation (by operators) Main structural issues: What more should we control? (secondary cv’s, y 2 ) Pairing with manipulated variables (mv’s u 2 ) y 1 = c y 2 = ?
91 XCXC TC FC ysys y LsLs TsTs L T z XCXC Cascade control distillation
92 Degrees of freedom unchanged No degrees of freedom lost by control of secondary (local) variables as setpoints become y 2s replace inputs u 2 as new degrees of freedom GK y 2s u2u2 y2y2 y1y1 Original DOF New DOF Cascade control:
93 Hierarchical control: Time scale separation With a “reasonable” time scale separation between the layers (typically by a factor 5 or more in terms of closed-loop response time) we have the following advantages: 1.The stability and performance of the lower (faster) layer (involving y 2 ) is not much influenced by the presence of the upper (slow) layers (involving y 1 ) Reason: The frequency of the “disturbance” from the upper layer is well inside the bandwidth of the lower layers 2.With the lower (faster) layer in place, the stability and performance of the upper (slower) layers do not depend much on the specific controller settings used in the lower layers Reason: The lower layers only effect frequencies outside the bandwidth of the upper layers
94 Objectives regulatory control layer 1.Allow for manual operation 2.Simple decentralized (local) PID controllers that can be tuned on-line 3.Take care of “fast” control 4.Track setpoint changes from the layer above 5.Local disturbance rejection 6.Stabilization (mathematical sense) 7.Avoid “drift” (due to disturbances) so system stays in “linear region” –“stabilization” (practical sense) 8.Allow for “slow” control in layer above (supervisory control) 9.Make control problem easy as seen from layer above Implications for selection of y 2 : 1.Control of y 2 “stabilizes the plant” 2.y 2 is easy to control (favorable dynamics)
95 1. “Control of y 2 stabilizes the plant” A. “Mathematical stabilization” (e.g. reactor): Unstable mode is “quickly” detected (state observability) in the measurement (y 2 ) and is easily affected (state controllability) by the input (u 2 ). Tool for selecting input/output: Pole vectors –y 2 : Want large element in output pole vector: Instability easily detected relative to noise –u 2 : Want large element in input pole vector: Small input usage required for stabilization B. “Practical extended stabilization” (avoid “drift” due to disturbance sensitivity): Intuitive: y 2 located close to important disturbance Or rather: Controllable range for y 2 is large compared to sum of optimal variation and control error More exact tool: Partial control analysis
96 Recall rule for selecting primary controlled variables c: Controlled variables c for which their controllable range is large compared to their sum of optimal variation and control error Control variables y 2 for which their controllable range is large compared to their sum of optimal variation and control error controllable range = range y 2 may reach by varying the inputs optimal variation: due to disturbances control error = implementation error n Restated for secondary controlled variables y 2 : Want small Want large
97 What should we control (y 2 )? Rule: Maximize the scaled gain Scalar case. Minimum singular value = gain |G| Maximize scaled gain: |G s | = |G| / span –|G|: gain from independent variable (u) to candidate controlled variable (y) –span (of y) = optimal variation in c + control error for y Note optimal variation: This is generally NOT the same as the optimal variation used for selecting primary controlled variables (c) because we at the “fast” regulatory time scale have that the “slower” (unused) inputs (u 1 ) are constant. –For each disturbance find optimal input change (u 2 ) that keeps primary variables c=y 1 closest to setpoint (with u 1 constant), and from this obtain optimal variation (c opt )
98 2. “y 2 is easy to control” Main rule: y 2 is easy to measure and located close to manipulated variable u 2 Statics: Want large gain (from u 2 to y 2 ) Dynamics: Want small effective delay (from u 2 to y 2 )
99 Aside: Effective delay and tunings PI-tunings from “SIMC rule” Use half rule to obtain first-order model –Effective delay θ = “True” delay + inverse response time constant + half of second time constant + all smaller time constants –Time constant τ 1 = original time constant + half of second time constant –NOTE: The first (largest) time constant is NOT important for controllability!
10 0 Summary: Rules for selecting y 2 1.y 2 should be easy to measure 2.Control of y 2 stabilizes the plant 3.y 2 should have good controllability, that is, favorable dynamics for control 4.y 2 should be located “close” to a manipulated input (u 2 ) (follows from rule 3) 5.The (scaled) gain from u 2 to y 2 should be large Additional rule for selecting u 2 : Avoid using inputs u 2 that may saturate (should generally avoid saturation in lower layers)
10 1 Exercise level control (10.1 in Seborg) Consider control of liquid condenser level (M1) in a distillation column. –Should we use L or D to control M1? –What is your answer if L/D=5? –What is your answer if it is important to avoid disturbing downstream process?
10 2 XCXC TC FC ysys y LsLs TsTs L T z XCXC LV-configuration preferred in practice for most columns (even when L and V are large)
10 3 Exercise distillation (10.3 in Seborg) Consider a column design to separate methanol and water. The desired distillate composition (xD) is methanol with only 5 ppm of water. Because a composition analyzer is not available, it is proposed to control XD indirectly by measuring and controlling a temperature at one of the following locations (a)the reflux stream (b)the top tray (stage) of the column (c)an intermediate tray in the top section (where?) Discuss the relative advantages and disadvantages of each choice based on both steady-state and dynamic considerations
10 4 More exact: Selecting stage for temperature control (y 2 ) in distillation Consider controlling temperature (y=T) with reflux (u=L) –Avoid V because it may saturate (i.e. reach maximum) G= “Controllable range”: Given by gain T/ L (“sensitivity”). This will be largest where temperature changes are the largest, that is, toward the feed stage for a binary separation T opt = “Optimal variation” for disturbances (in F, z F, etc.): –This is generally NOT the same as the optimal variation used for selecting primary controlled variables (c) because we have to assume that the “slower” variables (e.g. u 1 =V) are constant. –Here: We want to control product compositions. The optimal variation in T will be small towards the end of the column and largest toward the feed stage T err = “Control error” (=implementation error = static measurement error) – This will typically be 0.5 C and the same on stages Rule: Select location corresponding to max. value of –G / (T opt + T err ) Binary separation: This will have a max. in the middle of the top section and middle of bottom section Multicomponent separation: Will have a max. towards column ends
10 5 Distillation example columnn A. u=L. Which temperature (c) to control? 1.Nominal simulation (gives x0) 2.One simulation: Gain with constant inputs (u) –Make small change in input (L) with the other inputs (V) constant Find gain = x i / L 3.From process gains: Obtain “optimal” change for candidate measurements to disturbances, (with input L adjusted to keep both xD and xB close to setpoint, i.e. min ||x D -0.99; xb-0.01||, with V=constant). w=[xB,xD]. Then (- Gy pinv(Gw) Gwd + Gyd) d (Note: Gy=gain, d=F: Gyd=gainf etc.) Find x i,opt (yopt) for the following disturbances 1.F (from 1 to 1.2; has effect!)yoptf 2.z F from 0.5 to 0.6yoptz 3.q F from 1 to 1.2yoptq 4.x B from 0.01 to 0.02yoptxb=0 (no effect) 4.Control (implementation) error. Assume=0.05 on all stages 5.Find scaled-gain = gain/span where span = abs(yoptf)+abs(yoptz)+abs(yoptq)+0.05 “Maximize gain rule”: Prefer stage where scaled-gain is large >> res=[x0' gain' gainf' gainz' gainq'] res =
10 6 >> Gw Gw = Gwf = >> yoptf = (-gain'*pinv(Gw)*Gwf + gainf')*0.2 >> yoptq = (-gain'*pinv(Gw)*Gwq + gainq')*0.2 >> yoptz = (-gain'*pinv(Gw)*Gwz + gainz')*0.1 have checked with nonlinear simulation. OK! >> [yoptf yoptq yoptz span] ans = u=L
10 7 >> span = abs(yoptf)+abs(yoptz)+abs(yoptq)+0.05; >> plot(gain’./span) u=L: max. on stage 15 (below feed stage) In practice (because of dynamics): Will use tray in top (peak at 25)
10 8 variation=yoptz+yoptq+yoptxb+0.05 plot(gain./variation) TOP stage 31 NOT QUITE CORRECT: Using scalings from selection of primary variables
10 9 Another tool for stabilization: Pole vectors Maximum gain rule is good for integrating (drifting) modes For “fast” unstable modes (e.g. reactor): Pole vectors useful for determining which input (valve) and output (measurement) to use for stabilizing unstable modes Assumes input usage (avoiding saturation) may be a problem
11 0
11 1
11 2 Example: Tennessee Eastman challenge problem
11 3
11 4
11 5
11 6
11 7
11 8
11 9
12 0 Partial control analysis Primary controlled variable y 1 = c (supervisory control layer) Local control of y 2 using u 2 (regulatory control layer) Setpoint y 2s : new DOF for supervisory control
12 1 Cascade control: y 2 not important in itself, and setpoint (r 2 ) is available for control of y 1 Decentralized control (using sequential design): y 2 important in itself Partial control
12 2 Limitations of partial control? Cascade control: Closing of secondary loops does not by itself impose new problems –Theorem The partially controlled system [P 1 P r1 ] from [u 1 r 2 ] to y 1 has no new RHP-zeros that are not present in the open-loop system [G 11 G 12 ] from [u 1 u 2 ] to y 1 provided r 2 is available for control of y 1 K 2 has no RHP-zeros Decentralized control (sequential design): Can introduce limitations. –Avoid pairing on negative RGA for u 2 /y 2 – otherwise P u likely has a RHP- zero
12 3
12 4
12 5
12 6
12 7
12 8
12 9 Control configuration elements Control configuration. The restrictions imposed on the overall controller by decomposing it into a set of local controllers (subcontrollers, units, elements, blocks) with predetermined links and with a possibly predetermined design sequence where subcontrollers are designed locally. Control configuration elements: Cascade controllers Decentralized controllers Feedforward elements Decoupling elements
13 0 Cascade control arises when the output from one controller is the input to another. This is broader than the conventional definition of cascade control which is that the output from one controller is the reference command (setpoint) to another. In addition, in cascade control, it is usually assumed that the inner loop K2 is much faster than the outer loop K1. Feedforward elements link measured disturbances to manipulated inputs. Decoupling elements link one set of manipulated inputs (“measurements”) with another set of manipulated inputs. They are used to improve the performance of decentralized control systems, and are often viewed as feedforward elements (although this is not correct when we view the control system as a whole) where the “measured disturbance” is the manipulated input computed by another decentralized controller.
13 1 Why simplified configurations? Fundamental: Save on modelling effort Other: –easy to understand –easy to tune and retune –insensitive to model uncertainty –possible to design for failure tolerance –fewer links –reduced computation load
13 2 Cascade control (conventional; with extra measurement) The reference r 2 is an output from another controller General case (“parallel cascade”) Special common case (“series cascade”)
13 3 Series cascade 1.Disturbances arising within the secondary loop (before y 2 ) are corrected by the secondary controller before they can influence the primary variable y 1 2.Phase lag existing in the secondary part of the process (G 2 ) is reduced by the secondary loop. This improves the speed of response of the primary loop. 3.Gain variations in G 2 are overcome within its own loop. Thus, use cascade control (with an extra secondary measurement y 2 ) when: The disturbance d 2 is significant and G 1 has an effective delay The plant G 2 is uncertain (varies) or n onlinear Design: First design K 2 (“fast loop”) to deal with d 2 Then design K 1 to deal with d 1
13 4 Tuning cascade Use SIMC tuning rules K 2 is designed based on G 2 (which has effective delay 2 ) –then y 2 = T 2 r 2 + S 2 d 2 where S 2 ¼ 0 and T 2 ¼ 1 ¢ e -( 2 + c2 )s T 2 : gain = 1 and effective delay = 2 + c2 SIMC-rule: c2 ¸ 2 Time scale separation: c2 · c1 /5 (approximately) K 1 is designed based on G 1 T 2 same as G 1 but with an additional delay 2 + c2 y 2 = T 2 r 2 + S 2 d 2
13 5 Exercise: Tuning cascade 1.(without cascade, i.e. no feedback from y 2 ). Design a controller based on G 1 G 2.(with cascade) Design K 2 and then K 1
13 6 Exercise: Tuning cascade
13 7 Extra inputs Exercise: Explain how “valve position control” fits into this framework. As en example consider a heat exchanger with bypass
13 8 Exercise Exercise: (a)In what order would you tune the controllers? (b)Give a practical example of a process that fits into this block diagram
13 9 Outline Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (primary CV’s) (self-optimizing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control (secondary CV’s) ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
14 0 Step 6. Supervisory control layer Purpose: Keep primary controlled outputs c=y 1 at optimal setpoints c s Degrees of freedom: Setpoints y 2s in reg.control layer Main structural issue: Decentralized or multivariable?
14 1 Decentralized control (single-loop controllers) Use for: Noninteracting process and no change in active constraints +Tuning may be done on-line +No or minimal model requirements +Easy to fix and change -Need to determine pairing -Performance loss compared to multivariable control - Complicated logic required for reconfiguration when active constraints move
14 2 Multivariable control (with explicit constraint handling = MPC) Use for: Interacting process and changes in active constraints +Easy handling of feedforward control +Easy handling of changing constraints no need for logic smooth transition -Requires multivariable dynamic model -Tuning may be difficult -Less transparent -“Everything goes down at the same time”
14 3 Outline Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (self-optimizing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control ? Step 6: Supervisory control Step 7: Real-time optimization Case studies
14 4 Step 7. Optimization layer (RTO) Purpose: Identify active constraints and compute optimal setpoints (to be implemented by supervisory control layer) Main structural issue: Do we need RTO? (or is process self- optimizing) RTO not needed when –Can “easily” identify change in active constraints (operating region) –For each operating region there exists self-optimizing var
14 5 Outline Control structure design (plantwide control) A procedure for control structure design I Top Down Step 1: Degrees of freedom Step 2: Operational objectives (optimal operation) Step 3: What to control ? (self-optimizing control) Step 4: Where set production rate? II Bottom Up Step 5: Regulatory control: What more to control ? Step 6: Supervisory control Step 7: Real-time optimization Conclusion / References
14 6 Summary: Main steps 1.What should we control (y 1 =c=z)? Must define optimal operation! 2.Where should we set the production rate? At bottleneck 3.What more should we control (y 2 )? Variables that “stabilize” the plant 4.Control of primary variables Decentralized? Multivariable (MPC)?
14 7 Conclusion Procedure plantwide control: I. Top-down analysis to identify degrees of freedom and primary controlled variables (look for self-optimizing variables) II. Bottom-up analysis to determine secondary controlled variables and structure of control system (pairing).
14 8 References Halvorsen, I.J, Skogestad, S., Morud, J.C., Alstad, V. (2003), “Optimal selection of controlled variables”, Ind.Eng.Chem.Res., 42, Larsson, T. and S. Skogestad (2000), “Plantwide control: A review and a new design procedure”, Modeling, Identification and Control, 21, Larsson, T., K. Hestetun, E. Hovland and S. Skogestad (2001), “Self-optimizing control of a large-scale plant: The Tennessee Eastman process’’, Ind.Eng.Chem.Res., 40, Larsson, T., M.S. Govatsmark, S. Skogestad and C.C. Yu (2003), “Control of reactor, separator and recycle process’’, Ind.Eng.Chem.Res., 42, Skogestad, S. and Postlethwaite, I. (1996), Multivariable feedback control, Wiley Skogestad, S. (2000). “Plantwide control: The search for the self-optimizing control structure”. J. Proc. Control 10, Skogestad, S. (2003), ”Simple analytic rules for model reduction and PID controller tuning”, J. Proc. Control, 13, Skogestad, S. (2004), “Control structure design for complete chemical plants”, Computers and Chemical Engineering, 28, (Special issue from ESCAPE’12 Symposium, Haag, May 2002). … + more….. See home page of S. Skogestad: