Dollar logo

Combined cycle power plant

By Roberto Lopez, Artelnics.

A combined cycle power plant is composed of gas turbines, steam turbines and heat recovery steam generators. In this type of power plants, the electricity is generated by gas and steam turbines, which are combined in one cycle, and is transferred from one turbine to another. While the vacuum is collected from and has effect on the steam turbine, the ambient variables effect the gas turbine performance.

Combined cycle power plant
Combined cycle power plant.

The electrical energy production will be influenced by the environment variables, such as temperature or humidity. The goal of this research is to know where will be more productive this kind of power plant in order to optimize profit.


  1. Data set
  2. Neural network
  3. Loss index
  4. Training strategy
  5. Testing analysis
  6. Model deployment

1. Data set

The data set contains 9568 data points collected from a combined cycle power plant over 6 years (2006-2011), when the power plant was set to work with full load. Features consist of hourly average ambient variables temperature, ambient pressure, relative humidity and exhaust vacuum to predict the net hourly electrical energy output of the plant. The measurement were taken from various sensors located around the plant that record the ambient variables every second. In the next table a preview of the data file is shown:

Combined cycle dataset picture
Combined cycle dataset.

The next figure shows the data set page in Neural Designer.

Data set page screenshot
Data set page.

It contains four sections:

  1. Data file.
  2. Variables.
  3. Instances.
  4. Missing values.

Neural Designer shows a preview of the data file and says that the number of columns is 5 and the number of rows is 9568.

The task "Report data set" shows some useful information about the data set. The next figure depicts one of the tables shown, which contains the names, units, descriptions and uses of all the variables. In this case, there are 5 variables.

Variables table
Variables table.

The instances are divided into a training, a selection and a testing subsets. They represent 60% , 20% and 20% of the original instances, respectively, and have been splitted at random.

2. Neural network

The second step is to choose a network architecture to represent the approximation function. For approximation problems, it is composed by:

  • Inputs.
  • Scaling layer.
  • Neural network.
  • Probabilistic layer.
  • Outputs.

The next figure shows the neural network page in Neural Designer.

>Neural network page screenshot
Neural network page.

The scaling layer section contains information about the method for scaling the input variables and the statistic values to be used by that method. In this example, we will use the minimum and maximum method for scaling the inputs. The mean and standard deviation would also be appropriate here.

The next image represents the neural network for this example.

Neural network graph
Neural network.

The inputs of the neural network are the variables AT, V, AP, RH and it has one output, PE. The number of hidden perceptrons that have been chosen is 4. Therefore, the neural network can be denoted as 4:4:1.

3. Loss index

The next step is to configure the loss index, which defines what the neural network will learn. It is composed by the objective term and the regularization term. Both of them will be set by default.

The next figure shows the loss index page here.

Loss index page screenshot
Loss index page.

The objective term is to be the normalized squared error. It divides the squared error between the outputs from the neural network and the targets in the data set by a normalization coefficient. If the normalized squared error has a value of unity then the neural network is predicting the data 'in the mean', while a value of zero means perfect prediction of the data. This objective term does not have any parameters to set.

The neural parameters norm is used as regularization term. It is applied to control the complexity of the neural network by reducing the value of the parameters. The weight of this regularization term in the loss index is 0.001.

The learning problem can be stated as to find a neural network which minimizes the loss index, i.e., a neural network that fits the data set (objective) and that does not oscillate (regularization).

4. Training strategy

The task "perform training", trains the neural network in order to create the model. The training strategy can be configured in the training strategy page. In this case, all the parameters are set to their default values.

Training strategy page screenshot
Training strategy page.

As we can see, the training strategy chosen is the quasi-Newton method.

5. Testing analysis

When the neural network is designed and trained, there are diverse ways to test the result offered by the model. One of them is to perform a linear regression between the predicted output and a independent subset of validation data. This can be done using the task "Perform linear regression analysis", which shows the next output:

Linear regression plot
Linear regression analysis.

The next table lists the linear regression parameters for the scaled output PE. The intercept, slope and correlation are very similar to 0, 1 and 1, respectively, so the neural network is predicting well the testing data.

Linear regression analysis table picture
Linear regression analysis results

For a perfect fit the slope would be 1, and the y-intercept would be 0. The correlations measure whether there is complete relationship between the outputs of the neural network and the targets in the testing subset or not.

6. Model deployment

The neural network is now ready to predict outputs for inputs that it has never seen.

The "Calculate outputs" task will open the next dialog where the user types the input values.

Inputs dialog
Inputs dialog.

The results from that task are written in the viewer.

>Inputs-outputs table
Inputs-outputs table.

The task "Write expression" shows the mathematical expression represented by the predictive model: