User Tools

Site Tools


how_to_develop_a_bn

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
how_to_develop_a_bn [2018/12/18 16:51] – [2. Bayesian Network software] stritihahow_to_develop_a_bn [2023/04/21 15:30] (current) – external edit 127.0.0.1
Line 11: Line 11:
  
 Evidence can be data (e.g. when we know the type of land cover in a pixel) or scenarios (e.g. when we explore what happens in the system when we increase the harvesting rate). When we know the state of a node with 100% certainty, this is called **hard evidence** (the land cover is a forest), while **soft evidence** contains some uncertainty and is in the form of a probability distribution (the land cover is a forest with 70% probability and a grassland with 30% probability).  Evidence can be data (e.g. when we know the type of land cover in a pixel) or scenarios (e.g. when we explore what happens in the system when we increase the harvesting rate). When we know the state of a node with 100% certainty, this is called **hard evidence** (the land cover is a forest), while **soft evidence** contains some uncertainty and is in the form of a probability distribution (the land cover is a forest with 70% probability and a grassland with 30% probability). 
 +{{:example_inference.png?800|Example of a Bayesian Network }}
  
 +//Example of a Bayesian Network that describes the ecosystem service of recreation. The CPT of node "Landscape attractiveness" is shown, as well as how the probability distribution of this node is updated when we add evidence to its parent nodes. For more details on this network, Example x. //
 ==== 1. Model purpose and context ==== ==== 1. Model purpose and context ====
 Before the construction of the BN begins, it is important to clarify the problem and objectives, as well as the modelling context:  Before the construction of the BN begins, it is important to clarify the problem and objectives, as well as the modelling context: 
Line 27: Line 29:
 However, many functionalities are also available in other software packages. For an overview, see review by [[https://doi.org/10.1016/j.envsoft.2016.07.007|Pérez-Miñana (2016)]]. However, many functionalities are also available in other software packages. For an overview, see review by [[https://doi.org/10.1016/j.envsoft.2016.07.007|Pérez-Miñana (2016)]].
  
-In order to map ES, we link BNs to spatial data using a specialized online application (gBay.ethz.ch) developed at ETH-PLUS within the framework of the ECOPOTENTIAL project. +
  
 ==== 3. Defining the nodes==== ==== 3. Defining the nodes====
Line 45: Line 47:
 === 3.2 Creating nodes in Netica=== === 3.2 Creating nodes in Netica===
  
-To create a node in Netica, click on the   icon and then place the new node somewhere on the canvas. Double click on the node to open a window with the node properties, where you can change the node name and define it as discrete or continuous. +To create a node in [[https://www.norsys.com/WebHelp/NETICA.htm|Netica]], click on the   icon and then place the new node somewhere on the canvas. Double click on the node to open a window with the node properties, where you can change the node name and define it as discrete or continuous. 
  
 ==== 4. Designing the network ==== ==== 4. Designing the network ====
Line 69: Line 71:
 === 5.1 Defining node states in Netica === === 5.1 Defining node states in Netica ===
 To modify the states of a node in [[https://www.norsys.com/WebHelp/NETICA.htm|Netica]], double click on the node to open the node properties window. Click on “Description” and select “States”. Then, simply enter the names of the states in the box below. For continuous nodes, the states are defined through discretization intervals. Select “Discretization” and enter the threshold values between the states.  To modify the states of a node in [[https://www.norsys.com/WebHelp/NETICA.htm|Netica]], double click on the node to open the node properties window. Click on “Description” and select “States”. Then, simply enter the names of the states in the box below. For continuous nodes, the states are defined through discretization intervals. Select “Discretization” and enter the threshold values between the states. 
- +{{:states_netica.png?600|Defining states for discrete and continuous nodes in Netica}} 
 + 
 +// Defining states for discrete and continuous nodes in Netica.//
 ==== 6. Filling the CPTs ==== ==== 6. Filling the CPTs ====
 The links between nodes in a BN are represented by conditional probability tables, where a probability distribution of a child node is defined for every combination of states of its parent nodes. Depending on the availability of data or models, various methods can be used to populate CPTs, from expert elicitation to “learning” from data. During this process, we may find it necessary to return to previous steps and redefine the nodes, their states, or the links between them. The links between nodes in a BN are represented by conditional probability tables, where a probability distribution of a child node is defined for every combination of states of its parent nodes. Depending on the availability of data or models, various methods can be used to populate CPTs, from expert elicitation to “learning” from data. During this process, we may find it necessary to return to previous steps and redefine the nodes, their states, or the links between them.
  
 In [[https://www.norsys.com/WebHelp/NETICA.htm|Netica]], the CPTs can be filled either manually (right click on the node -> Table) or through equations. To use an equation, open the node properties, select Equation, and enter the equation in the box. Then, click on   to calculate the CPT based on the equation.  In [[https://www.norsys.com/WebHelp/NETICA.htm|Netica]], the CPTs can be filled either manually (right click on the node -> Table) or through equations. To use an equation, open the node properties, select Equation, and enter the equation in the box. Then, click on   to calculate the CPT based on the equation. 
- + 
 +{{:equations.png?600|Examples of a deterministic (left) and probabilistic (right) equation in Netica.}} 
 + 
 +// Examples of a deterministic (left) and probabilistic (right) equation in Netica.//
 === 6.1 With experts or stakeholders === === 6.1 With experts or stakeholders ===
-When data is lacking, the CPTs can be filled manually by experts or by stakeholders. Usually, this means that the experts should specify the probability of each state of the child node given each combination of parent nodes. When a node has many parents with several states, many rows of CPTs need to be filled, which can lead to fatigue and boredom, and it is difficult to ensure consistent distributions (Das 2004). This is why it is important to limit the number of parents, and the number of node states. +When data is lacking, the CPTs can be filled manually by experts or by stakeholders. Usually, this means that the experts should specify the probability of each state of the child node given each combination of parent nodes. When a node has many parents with several states, many rows of CPTs need to be filled, which can lead to fatigue and boredom, and it is difficult to ensure consistent distributions ([[https://arxiv.org/abs/cs/0411034|Das 2004]]). This is why it is important to limit the number of parents, and the number of node states. 
  
-When node states are binary or ordered, this problem can be reduced by using various interpolation methods (Cain 2001, Das 2004). For example, if a child node C has three states (“low”, “medium”, “high”), and three parents Pa with the same three states, we can elicit three probability distributions of C: where all three parents are in state “high”, all in state “medium”, and all in state “low”. In addition, we need the relative weights of each parents (w1, w2, w3, which should sum up to one). Then, all the other rows of the CPT can be calculated by interpolation. +When node states are binary or ordered, this problem can be reduced by using various interpolation methods ([[http://nora.nerc.ac.uk/id/eprint/9461/1/N009461BO.pdf|Cain 2001]][[https://arxiv.org/abs/cs/0411034|Das 2004]]). For example, if a child node C has three states (“low”, “medium”, “high”), and three parents Pa with the same three states, we can elicit three probability distributions of C: where all three parents are in state “high”, all in state “medium”, and all in state “low”. In addition, we need the relative weights of each parents (w1, w2, w3, which should sum up to one). Then, all the other rows of the CPT can be calculated by interpolation. 
  
-Distributions of continuous variables can also be elicited from experts. One useful approach is the four-point estimation method (Speirs-Bridge et al. 2010), where we ask experts for the expected value of the node for a specific combination of parents, the expected upper and lower bounds of possible values, and their confidence in their estimate. Using this information, we can estimate a probability distribution (e.g. a normal or triangular distribution). An example of this approach is available in the avalanche protection case study.+//Example of interpolation in a CPT, where the weights of the parents are w1 = 0.17, w2 = 0.5, w3 = 0.33. Elicited probabilities are shown in bold, while all other probabilities in the table are calculated using interpolation, as shown below. // 
 +{{:interpolation_table.png|}} 
 + 
 +  
 +Distributions of continuous variables can also be elicited from experts. One useful approach is the four-point estimation method ([[https://doi.org/10.1111/j.1539-6924.2009.01337.x|Speirs-Bridge et al. 2010]]), where we ask experts for the expected value of the node for a specific combination of parents, the expected upper and lower bounds of possible values, and their confidence in their estimate. Using this information, we can estimate a probability distribution (e.g. a normal or triangular distribution). An example of this approach is available in the [[Avalanche protection in Davos, Switzerland|avalanche protection case study]].
    
 In some cases, experts find it easier to deal with categories rather than continuous variables, and it may be useful to translate continuous nodes to discrete classes using fuzzy logic. In some cases, experts find it easier to deal with categories rather than continuous variables, and it may be useful to translate continuous nodes to discrete classes using fuzzy logic.
Line 89: Line 100:
  
 === 6.2 Linking remote sensing proxies to the state of the ecosystem=== === 6.2 Linking remote sensing proxies to the state of the ecosystem===
-To map ecosystem services, proxies of ecosystem structure are often derived from remote sensing (e.g. land cover classifications or LiDAR-based measurements of vegetation cover). However, these remote sensing products often include some uncertainty due to measurement errors or misclassifications.  To make these uncertainties explicit, we can create separate nodes representing the observed value and the actual state of the variable. The observation is caused by the actual state, not vice-versa, and defining the structure of the network based on this causality helps to define conditional probabilities (see avalanche protection case study).+To map ecosystem services, proxies of ecosystem structure are often derived from remote sensing (e.g. land cover classifications or LiDAR-based measurements of vegetation cover). However, these remote sensing products often include some uncertainty due to measurement errors or misclassifications.  To make these uncertainties explicit, we can create separate nodes representing the observed value and the actual state of the variable. The observation is caused by the actual state, not vice-versa, and defining the structure of the network based on this causality helps to define conditional probabilities (see [[Avalanche protection in Davos, Switzerland|avalanche protection case study]]).
  
 === 6.3 From existing empirical models=== === 6.3 From existing empirical models===
 Often, some parts of the network have already been extensively researched and empirical or process-based models are available in literature. In this case, the model can be incorporated in the BN in the form of probabilistic equations. This usually means that the probability distribution of the child node is a normal distribution, where the mean is a function of its parents, and the standard deviation is derived from the reported uncertainty in the model. Other types of distributions can also be used. Often, some parts of the network have already been extensively researched and empirical or process-based models are available in literature. In this case, the model can be incorporated in the BN in the form of probabilistic equations. This usually means that the probability distribution of the child node is a normal distribution, where the mean is a function of its parents, and the standard deviation is derived from the reported uncertainty in the model. Other types of distributions can also be used.
  
-For an example of how an empirical model can be incorporated in a BN, see the avalanche protection case study. +For an example of how an empirical model can be incorporated in a BN, see the [[Avalanche protection in Davos, Switzerland|avalanche protection case study]]
  
 === 6.4 Learning from data or simulations === === 6.4 Learning from data or simulations ===
Line 101: Line 112:
 To “learn” from data in [[https://www.norsys.com/WebHelp/NETICA.htm|Netica]], create a text file where the column names match the names of the nodes in the network, and rows represent cases (i.e. observations, plots, measurements). Go to Cases -> Learn -> Incorp Case File (to derive CPTs by simply counting the cases) or Learn Using EM (to use the expectation maximisation algorithm, e.g. in case of missing data). To use learning only for the CPT of one node, select the node before performing the learning.  To “learn” from data in [[https://www.norsys.com/WebHelp/NETICA.htm|Netica]], create a text file where the column names match the names of the nodes in the network, and rows represent cases (i.e. observations, plots, measurements). Go to Cases -> Learn -> Incorp Case File (to derive CPTs by simply counting the cases) or Learn Using EM (to use the expectation maximisation algorithm, e.g. in case of missing data). To use learning only for the CPT of one node, select the node before performing the learning. 
  
-Learning from simulations was used to populate one of the nodes in the avalanche protection network, while in-situ data were used to quantify some nodes in the BN of ecosystem services in the Wadden Sea.+Learning from simulations was used to populate one of the nodes in the [[Avalanche protection in Davos, Switzerland|avalanche protection network]], while in-situ data were used to quantify some nodes in the BN of ecosystem services in the Wadden Sea.
  
 ==== 7. Testing, evaluating, and updating the BN ==== ==== 7. Testing, evaluating, and updating the BN ====
Line 109: Line 120:
 Sensitivity analysis is a useful tool that determines the influence of individual variables on the outputs, which can help us decide where more data is necessary. When new data becomes available, it can be used to update the conditional probability distributions in an iterative process. Sensitivity analysis is a useful tool that determines the influence of individual variables on the outputs, which can help us decide where more data is necessary. When new data becomes available, it can be used to update the conditional probability distributions in an iterative process.
  
-In Bayesian Network modelling, sensitivity analysis is often used to evaluate the influence of variables in the modelled system on the posterior probability distribution of a node of interest (Uusitalo 2007, Marcot 2012). Sensitivity to findings can be measured by the reduction in uncertainty (e.g. entropy or variance) in the target node due to a finding on another node. Entropy reduction is expressed by the measure of mutual information (Kjaerulff and Madsen 2013):+In Bayesian Network modelling, sensitivity analysis is often used to evaluate the influence of variables in the modelled system on the posterior probability distribution of a node of interest ([[https://doi.org/10.1016/j.ecolmodel.2006.11.033|Uusitalo 2007]][[https://doi.org/10.1016/j.ecolmodel.2012.01.013|Marcot 2012]]). Sensitivity to findings can be measured by the reduction in uncertainty (e.g. entropy or variance) in the target node due to a finding on another node. Entropy reduction is expressed by the measure of mutual information ([[https://www.springer.com/de/book/9781441925466|Kjaerulff and Madsen 2013]]):
  
 $ I(X,Y) = H(X) - H(X|Y) = H(Y) - H(X|Y)= ∑_Y P(Y)∑_X P(Y)(P(X,Y))/(P(X)P(Y))  $ $ I(X,Y) = H(X) - H(X|Y) = H(Y) - H(X|Y)= ∑_Y P(Y)∑_X P(Y)(P(X,Y))/(P(X)P(Y))  $
how_to_develop_a_bn.1545148291.txt.gz · Last modified: 2023/04/21 15:30 (external edit)