This page contains a Flash digital edition of a book.
Power Plant Valuation


An even more challenging operational constraint is a hard


bound limitation to the number of starts, or alternatively, that start costs increase with the number of starts made before. This can be used to avoid an otherwise quite destructive number of starts, e.g. every working day. As a consequence of such a hard bound constraint, the owner of a plant will try to minimize the number of startups. In any case, the plant operator needs to keep track of two quite different statistics: 1. How many hours is the plant already offline, or how many hours is it already producing? This is a statistic (‘state’ in the dynamic programming language) which looks at the recent history of actions.


2. How many times did the plant start already this year? This is a statistic of a different nature, looking back until the beginning of the year.


Whatever the model implementation is, an optimisation


tries to search for the optimal dispatch taking into account the current and future spark spread levels, the current ‘short-history’ state, and the current ‘long- history state’.


max {


3. As 2, but assuming no perfect foresight. This means the plant operator has to judge the likely level of spark spreads in the future and take decisions which are inevitably suboptimal in certain situations. We use Least-Squares Monte Carlo to establish this strategy.


The paper of Tseng and Barz (2002) is the primary academic


reference for a description of a dynamic programming approach to handle short-history constraints of up/down times. The picture below shows the main logic. The model distinguishes between different states (y-axis) that the plant can reach at different hours (x-axis). In the shown example with 2 hours minimum on-time and 2 hours minimum off-time, if the plant is up (‘on’) for 2 hours or more it can stay ‘on’ or go ‘off’; if it is off for 1 hour (idem if on for 1 hour), the operator has no choice other than to stay off for one more hour. At each node, the model compares the continuation values (F) for the alternatives it has and chooses the maximum. For example, when at the end of hour t the plant is already off for 2 hours or more, the choice is:


F on 1hr + Margin – Start Costs t+1 – Shadow Costs “Plant switched on in hour t+1” F off 2hr


t+1


Solution Approaches to Handle Start Constraints In this paragraph we will demonstrate three different solution approaches, each using backward valuation dynamic programming. We show the pros and cons of each, but before doing so, a fourth alternative is worth mentioning. Mixed- integer linear programming (MILP) is a common alternative in which the objective (profit maximization) and constraints are written down in a set of linear equations. While this approach is relatively easy to implement, it is often a factor 5-20 slower than a dynamic programming approach due to the large number (at least 8,760 per year) of decision variables. Even more, MILP ignores any price uncertainty, which is part of our third approach below. These approaches are: 1. A dynamic programming approach for the ‘short-history’ constraint, and a ‘shadow cost’ for the ‘long-history’ constraint to limit the number of starts. This approach assumes perfect foresight about future price levels.


2. A dynamic programming approach for both types of constraints, meaning we have an additional dimension to keep track of the number of previously made starts. This approach assumes perfect foresight about future price levels.


“Plant switched on in hour t+1”


Solution approach 1 means we run through the dynamic


program a couple of times. In round 1 we only include the real costs for starting up (Start Costs, e.g. fuel-related) and set the shadow costs for starts to zero (Shadow Costs = 0). If the number of starts is below the maximum, we are done. If the number of starts in the previous round is above the maximum, we modify the shadow cost. We make as many modifications to the shadow cost until the model reaches the maximum plant value within the start limitation per year. In our implementation typically 10- 20 rounds are needed before reaching the optimum; the whole procedure generally takes less than 1 second per simulation


50 worldPower 2010


Page 1  |  Page 2  |  Page 3  |  Page 4  |  Page 5  |  Page 6  |  Page 7  |  Page 8  |  Page 9  |  Page 10  |  Page 11  |  Page 12  |  Page 13  |  Page 14  |  Page 15  |  Page 16  |  Page 17  |  Page 18  |  Page 19  |  Page 20  |  Page 21  |  Page 22  |  Page 23  |  Page 24  |  Page 25  |  Page 26  |  Page 27  |  Page 28  |  Page 29  |  Page 30  |  Page 31  |  Page 32  |  Page 33  |  Page 34  |  Page 35  |  Page 36  |  Page 37  |  Page 38  |  Page 39  |  Page 40  |  Page 41  |  Page 42  |  Page 43  |  Page 44  |  Page 45  |  Page 46  |  Page 47  |  Page 48  |  Page 49  |  Page 50  |  Page 51  |  Page 52  |  Page 53  |  Page 54  |  Page 55  |  Page 56  |  Page 57  |  Page 58  |  Page 59  |  Page 60  |  Page 61  |  Page 62  |  Page 63  |  Page 64  |  Page 65  |  Page 66  |  Page 67  |  Page 68  |  Page 69  |  Page 70  |  Page 71  |  Page 72  |  Page 73  |  Page 74  |  Page 75  |  Page 76  |  Page 77  |  Page 78  |  Page 79  |  Page 80  |  Page 81  |  Page 82  |  Page 83  |  Page 84  |  Page 85  |  Page 86  |  Page 87  |  Page 88  |  Page 89  |  Page 90  |  Page 91  |  Page 92  |  Page 93  |  Page 94  |  Page 95  |  Page 96  |  Page 97  |  Page 98  |  Page 99  |  Page 100  |  Page 101  |  Page 102  |  Page 103  |  Page 104  |  Page 105  |  Page 106  |  Page 107  |  Page 108  |  Page 109  |  Page 110  |  Page 111  |  Page 112  |  Page 113  |  Page 114  |  Page 115  |  Page 116  |  Page 117  |  Page 118  |  Page 119  |  Page 120  |  Page 121  |  Page 122  |  Page 123  |  Page 124  |  Page 125  |  Page 126  |  Page 127  |  Page 128  |  Page 129  |  Page 130  |  Page 131  |  Page 132  |  Page 133  |  Page 134  |  Page 135  |  Page 136  |  Page 137  |  Page 138  |  Page 139  |  Page 140  |  Page 141  |  Page 142  |  Page 143  |  Page 144  |  Page 145  |  Page 146  |  Page 147  |  Page 148
Produced with Yudu - www.yudu.com