Insight is eWater’s multiple-objective optimisation decision support framework. This framework allows for more efficient evaluation of planning options than the traditional manual trial and error approach that is often used. In other words, the main aim of Insight is to optimise decision rules for all scenarios. The optimisation tool enables a more thorough examination of potential planning scenarios and the resulting trade-offs between desired outcomes.
Insight allows you to define which parameters (called decision variables) must be considered in the optimisation framework. Decisions variables can be thought of as management levers that can be pulled to affect the outcome. For example, you may be unsure of what the operating rules for a new desalination plant should be used to meet the objective of minimising cost, or what the optimal operating rules are for transferring water between storages to meet supply security objectives and minimising environmental impacts. By creating decision variables for these operating rules, the optimiser will try hundreds or thousands of different operating rules based on these decision variables and determine how the rules perform against a set of specified objectives.
Results of an optimisation run can be used as follows:
The goal of optimsation is to acheive a set of defined objectives based on decision variables that act as management levers. For example, the amount of water to release for environmental flows, the level of demand, or the amount of water to order from alternative supplies.
When deciding on decision variables, it is important to consider:
Theoretically, the larger the number of decision variables, the closer you are to acheiving the objectives. Practically, however, the greater the number, and broader the range of each variable, the longer the run time for completion of the optimisation run problem.
Mathematically known as objective functions, these can contain multiple parts, such as measure of cost, a measure of environmental impact and a measure of social costs. Examples of objective functions might include: minimising the operating cost of the system, minimising environmental impacts, or minimising time spent in water restrictions.
When choosing objectives, it is important to consider:
All tasks undertaken to carry out an optimisation run (from creating a settings file to the actual run) can be completed using either the Insight interface or a command line. Results for an optimisation run can be viewed in the interface only. These are described in further detail in subsequent sections.
Note: Results of the optimisation run can only be viewed using the Insight interface (due to the two and three-dimensional graphs showing the results). |
Ensure that the following pre-requisites are met prior to installing Insight:
Additionally, at a minimum, Insight requires the following to run an optimisation:
The decision variables and objectives must be defined in the Source project as global expressions. Insight can then run the Source model thousands of times, setting different values for the decision variable expressions and evaluating the corresponding objectives for every individual run.
This means that in order for a Source parameter to be included in an optimisation problem, that parameter needs to be defined using the Function manager in Source.
When you open Insight for the first time, you may be prompted to point Insight to the location of the Source command line tool (RiverSystem.CommandLine.exe).
Figure 1 shows the user interface for Insight, which allows you to load Source projects, configure a settings file and perform an optimisation run.
The File menu items allow you to work with settings and results as follows:
Prior to using Insight, ensure that you have created and saved a Source project containing one scenario only. |
Note: The difference between Objectives and tracked variables are that the former are optimised, whereas the latter are not. Tracked variables are a set of secondary objectives that may affect decision-making, but do not get optimised. |
The optimisation is now ready to be run.
Once you have nominated the location of Source, the Source project to optimise, and the objectives and decision variables, click Run to begin the optimisation.
On completion of the run, you will be prompted to save the results, which can then be viewed at a later stage if required.
Insight can be configured, set up (to create a settings file) and run using the command line as well. This link shows some examples of how to use the command line for Insight. Note that an explanation of these commands is provided further down:
Additional help for the command line is available using the following command. Once in the Insight directory, enter the following: hindsight.exe --help |
The settings file can be created in a text editor, such as Notepad, saved as a .txt file (such as Example_InsightSettings.txt) and must include the information shown in Table 1.
Information required | Example |
---|---|
Location of the Source project file | project C:\Insight\test\Example_project.rsproj |
List of the objectives, using the global expressions in the Source project | Output $reliabilityNeg |
List of decision variables, using the global expressions in the Source project, along with their constraint | real $pipecapacity 0 200 |
Note: To view a list of all available global expressions in a Source project, use the following command: –configurationOption "C:\Insight\test\Example_InsightSettings.txt" |
Once a settings file has been created, specify the following (as shown in Table 2) in the command line to configure the optimisation run.
Information required | Example |
---|---|
Specify to run the Insight executable file | Insight.Optimiser.Console.exe |
Location of Insight settings file | --configurationOption "C:\Insight\test\Example_InsightSettings.txt” |
The number of cores / endpoints to use | --source 2 |
The number of generations | --generations 6 |
The population size | --population 100 |
Output file name | --output “C:\Insight\test\Example_CommandLineResults_6x100.csv" |
Note: Whenever specifying a file outside the Insight folder, you must include the full path. |
Server endpoints allow you to run the optimisation across several machines simultaneously. It is recommended to discuss the use of endpoints with your IT department should you wish to choose this option.
If you wish to run the optimisation across multiple machines at once, you can do so using server endpoints, noting that:
Note: if you are using a Windows 7 machine as an endpoint, you may need to relocate Source out of Program Files to avoid folder access issues. For example, move Source to C:\Source 3.3.0. |
Endpoints can be set up manually or using the Powershell script. These are discussed separately next.
For each individual computer you wish to use in the optimisation, you will need to set it up as an endpoint(s). This is setup using the command line on each machine.
RiverSystem.CommandLine.exe -m server -a net.tcp://localhost:8593/insight
Once setup is complete, a message will appear indicating this.
Note: Windows may request permission to allow access to the endpoint. Click OK to grant permission. |
You must keep the command prompt open until the optimisation has been run and is complete. |
To use additional cores on an individual machine, you will need to set up multiple endpoints.
If you wish to open up another endpoint for the same machine, open up another command prompt, change to the Source directory, and enter a similar command, this time with a different endpoint identifier. For example:
RiverSystem.CommandLine.exe -m server -a net.tcp://localhost:8594/insight
You can also set up endpoints using the included PowerShell script.
Note: If Source is installed in your Program Files folder, you will need to run PowerShell as administrator every time you set up endpoints. In the Start menu, right click on the PowerShell icon and choose Run as Administrator. |
Do the following on every machine that you wish to set up as an endpoint/s:
Note: To find out more about execution policies, enter help about_execution_policy at the PowerShell command prompt. |
Finally, create an endpoints setting file using a text editor. Using the IP addresses or machine names (as located previously), specify the endpoints manually or via PowerShell. An example of such as file (Endpoints.txt) is shown below:
net.tcp://192.168.1.2:8593/insight net.tcp://192.168.1.2:8594/insight net.tcp://192.168.1.73:8595/insight net.tcp://192.168.1.73:8596/insight |
Once the settings file has been configured (along with endpoints if you are using them), set up the optimisation run itself.
Note: The location of the Source project must be in a location accessible to all endpoints (for example, a local server). |
Ensure that the parameters listed in Table 2 are entered. Then, press enter to begin the optimisation run.
As Insight computes the optimisation for each popluation, a completion notification is displayed in the command line.
To view the results of an optimisation run, choose File » Load results. This will load the Results dialog where you can view the results in various graphical formats.
Optimisation run results are compared to the Pareto Front. The Pareto Front is the set of solutions which have differing performance on each of the objectives. A solution is not on the Pareto Front if there is an alternative that is better on at-least one of the objectives but no worse on any objectives. In this case the solution is discarded as the alternative is clearly preferable. If the Pareto Front solutions are not changing, the optimiser may have satisfactorily completed its multi-objective search.
During the optimisation run (when using the interface), after more than a generation is complete, you will be able to view the hypervolume plot – an indication of how the Pareto Front (selection of optimal results) is converging. The hypervolume provides an indication of the convergence of the model results towards the Pareto Front. The hypervolume is calculated based on the distance between a maximum non-optimal solution and the modelled results. In effect, the larger the hypervolume, the closer the results are towards reaching the Pareto optimal solution. The hypervolume provides an indication of the convergence of the model results towards the Pareto Front. It is calculated based on the distance between a maximum non-optimal solution and the modelled results. In effect, the larger the hypervolume, the closer the results are towards reaching the Pareto optimal solution.
Insight provides two plots of hypervolume when using the user interface (shown in Figure 2). The blue hypervolume plot is calculated whilst Insight is running, without knowing what the maximum non-optimal solution is (shown on the left of Figure 2). The red hypervolume plot is calculated at the end of the optimisation run, using the maximum non-optimal solution as reference. The hypervolume is a useful indication of how much the optimal solutions are changing – if the hypervolume plot is flattening out, this is a sign that more generations are unlikely to produce more optimal results.
Click the 2D Graph tab at the top of the Results dialog to view two-dimensional scatterplots of the results (as shown in Figure 3). The drop-down menus for the x and y axes list all the objectives specified in the optimisation. To view the graph for a particular relationship, choose the relevant items from the drop-down menus and click Plot. The example shown in Figure 3 has three objectives defined: $reliabilityNeg, $unitcost and $Yieldneg. The points on the graph are forming the Pareto Front for this optimisation.
The Filter Properties dialog allows you to view the results in a specified range:
Click the 3D Graph tab to view a three-dimensional plot of the computed optimised solutions (shown in Figure 5). Just as with the two-dimensional graph, the individual solutions form a Pareto Front. The x, y and z-axes represent the objectives that were specified in the project. These can be changed using their individual corresponding drop down menus in the Configure panel on the left. Click Plot to re-arrange the plot. Click Reset to revert it back to its original state, and Save to save the results of the 3D graph to a file.
Additionally, you can filter the graph view to a specified range using the Filter Properties dialog (as shown in Figure 4) under the Plot Option drop-down menu.
The third tab in the Results dialog shows the optimised results in a spider graph (as shown in Figure 6). You can use the Filter feature (as described previously) to view a filtered spider graph of the results.
The final tab in the Results dialog shows all the results of the optimisation in a table. Figure 7 shows an example of the table, with all optimised solutions for each objective and decision variable specified in Insight. Note that the green arrow on the right allows you to save the decision variable to the Source project.