Continuous variables
Continuous variables
Hello,
I found in the tutorial an explaination about "Continuous variables". Is it possible to use these in GeNIe? As I found no way to set a chance - node to a "Continuous" one. I only can set true or false.
Maybe if that is possible I could also set something like 40% true, 60% false as Evidence. But I think I need to build that using an helping additional chance node. I am right?
Thank you,
Christian
			
			
									
						
										
						I found in the tutorial an explaination about "Continuous variables". Is it possible to use these in GeNIe? As I found no way to set a chance - node to a "Continuous" one. I only can set true or false.
Maybe if that is possible I could also set something like 40% true, 60% false as Evidence. But I think I need to build that using an helping additional chance node. I am right?
Thank you,
Christian
- 
				shooltz[BayesFusion]
- Site Admin
- Posts: 1477
- Joined: Mon Nov 26, 2007 5:51 pm
Re: Continuous variables
We have the implementation for continous (equation-based) variables. It's still in the early stages and there's no direct way of creating them in GeNIe (there's a magic key combination, though  )
 )
			
			
									
						
										
						 )
 )As I need the continuous variables, is it the same to just define one node (the one that I consider to be the continuos Variable) and set the percent value directly? 
For example: I want a continuous variable with 60%. Do I have to set value (state0) to 60% and "antivalue"(state1) to 40%?
If I want to change the continuous variable to 20%, do I have to set the Value (state0) to 20% and the "antivalue" (state1) to 80%?
Would that be the same as a continuous variable if this node is not dependet on other nodes? Or is this something that should not be done?
I just don't want to descretize the value that needed to be set into so many categories. So is this a workaround?
If not, could you please give me the "magic key" for the continuous variables? 
 
Thank you,
Christian
			
			
									
						
										
						For example: I want a continuous variable with 60%. Do I have to set value (state0) to 60% and "antivalue"(state1) to 40%?
If I want to change the continuous variable to 20%, do I have to set the Value (state0) to 20% and the "antivalue" (state1) to 80%?
Would that be the same as a continuous variable if this node is not dependet on other nodes? Or is this something that should not be done?
I just don't want to descretize the value that needed to be set into so many categories. So is this a workaround?
If not, could you please give me the "magic key" for the continuous variables?
 
 Thank you,
Christian
This is called soft-evidence, but it is not supported in GeNIe (or SMILE). It is possible to implement by using an additional chance node, as you described.Christian wrote:Maybe if that is possible I could also set something like 40% true, 60% false as Evidence. But I think I need to build that using an helping additional chance node. I am right?
This is very different from having a continuous variable in the network. Soft-evidence means that you define a prior probability distribution on the states of a (non-root) node instead of using probabilities from the cpt. The node still has only two states, state0 or state1, and child nodes can only be conditioned on those states. In case of continuous variables the value of a node could be 60 (or 40), and a child could be conditioned on that. In your proposed approach, this is impossible.Christian wrote:For example: I want a continuous variable with 60%. Do I have to set value (state0) to 60% and "antivalue"(state1) to 40%?
Okay, I never knew that this is called soft evidence. Is that the same as "virtual evidence" in netica?
Can I do the following as workaround?
Node1:
True 60%
False 40%
Node 2 has True activated.
Then I build 6 datasets out of that one with Node1 true, Node2 true AND 4 with Node1 False, Node2 true.
Then I will have the relationship. Okay, I will need to add 10 datasets for everyone.
Or do you know an algorithm that I can use to calculate the needed values on my own, using soft evidence?
Because I have about 2 million datasets to be learned and to get the correct relationship I need to create about 1 million datasets for everyone of these 2 Million datasets. Smile is a bit slow with this amount of datasets
Christian
P.S.: Sorry for the late answer. I forgot to check "Notify me when a reply is posted"
			
			
									
						
										
						Can I do the following as workaround?
Node1:
True 60%
False 40%
Node 2 has True activated.
Then I build 6 datasets out of that one with Node1 true, Node2 true AND 4 with Node1 False, Node2 true.
Then I will have the relationship. Okay, I will need to add 10 datasets for everyone.
Or do you know an algorithm that I can use to calculate the needed values on my own, using soft evidence?
Because I have about 2 million datasets to be learned and to get the correct relationship I need to create about 1 million datasets for everyone of these 2 Million datasets. Smile is a bit slow with this amount of datasets

Christian
P.S.: Sorry for the late answer. I forgot to check "Notify me when a reply is posted"
I am trying to simulate a soft evidence.
For example if I have a node with 60% state0 and 40% state1 I build 10 examples, 6 with state0 to 100% and 4 with state1 to 100%
After training this net I should have the 60%/40% for that node.
Now let asume I have two nodes that are connected (Node 1 is parent of node 2):
Node1:
state0 (N1S0)
state1 (N1S1)
Node2:
state0 (N2S0)
state1 (N2S1)
Now I want to build
N1S0 = 60%, N1S1 = 40 If N2S0 = 90% / N2S1 = 10%
Now I create 100 examples:
54: N1S0 = true, N1S1 = false, N2S0 = true, N2S1 = false
6: N1S0 = true, N1S1 = false, N2S0 = false, N2S1 = true
36: N1S0 = false, N1S1 = true, N2S0 = true, N2S1 = false
4: N1S0 = false, N1S1 = true, N2So = false, N2S1 = true
Is that now simulated soft evidence?
So this way is a work around to learn soft evidence with smile?
Now it is important that I build 100 examples for every dataset. Otherwise the relationship between the datasets would be gone.
My problem is now to build the correct datasets if I want to simulate soft evidence training with much more nodes and states than the two above.
So my question is/was if you know an easier way to archieve that. Or if you know a good algorithm.
Thank you,
Christian
			
			
									
						
										
						For example if I have a node with 60% state0 and 40% state1 I build 10 examples, 6 with state0 to 100% and 4 with state1 to 100%
After training this net I should have the 60%/40% for that node.
Now let asume I have two nodes that are connected (Node 1 is parent of node 2):
Node1:
state0 (N1S0)
state1 (N1S1)
Node2:
state0 (N2S0)
state1 (N2S1)
Now I want to build
N1S0 = 60%, N1S1 = 40 If N2S0 = 90% / N2S1 = 10%
Now I create 100 examples:
54: N1S0 = true, N1S1 = false, N2S0 = true, N2S1 = false
6: N1S0 = true, N1S1 = false, N2S0 = false, N2S1 = true
36: N1S0 = false, N1S1 = true, N2S0 = true, N2S1 = false
4: N1S0 = false, N1S1 = true, N2So = false, N2S1 = true
Is that now simulated soft evidence?
So this way is a work around to learn soft evidence with smile?
Now it is important that I build 100 examples for every dataset. Otherwise the relationship between the datasets would be gone.
My problem is now to build the correct datasets if I want to simulate soft evidence training with much more nodes and states than the two above.
So my question is/was if you know an easier way to archieve that. Or if you know a good algorithm.
Thank you,
Christian
I think soft evidence is related to inference and not learning. I constructed an example with two nodes where initially none of the nodes have evidence (see net1.jpg). Suppose soft evidence becomes available about node 2, namely P(node2=state0)=0.2 and P(node2=state1)=0.8. This can be implemented by attaching an extra node3 to node2 (see net2.jpg). To get the right soft evidence probabilities in node2, we use Bayes' rule to calculate the probabilities in the cpt for node3. I also attached the xdsl network if you want to have a look at the cpts. I'm not sure if my approach is fool proof, but in this simple case it seems to work fine.
			
							- Attachments
- 
			
		
		
				- net.xdsl
- (2.38 KiB) Downloaded 1822 times
 
- 
			
		
				- net2.jpg (10.94 KiB) Viewed 47797 times
 
- 
			
		
				- net1.jpg (7.26 KiB) Viewed 47797 times
 
ahh, okay - I understand. Thank you very much for your detailed examples. Thats a good approach. Then that's the way to go for me.
But if I need soft evidence in a parent node I can just change the weights?
For example in your net1.jpg - Node1, if I want 60% state0 and 40% state1 I can just set it, right?
So it is only called soft evidence if a child node is meant?
			
			
									
						
										
						But if I need soft evidence in a parent node I can just change the weights?
For example in your net1.jpg - Node1, if I want 60% state0 and 40% state1 I can just set it, right?
So it is only called soft evidence if a child node is meant?
- 
				joergweber79
- Posts: 21
- Joined: Thu Jan 15, 2009 4:22 pm
Hi Mark, can you please provide a formula, which shows how the cpt of node3 can be calculated? Using the bayes rule we get:mark wrote:I think soft evidence is related to inference and not learning. I constructed an example with two nodes where initially none of the nodes have evidence (see net1.jpg). Suppose soft evidence becomes available about node 2, namely P(node2=state0)=0.2 and P(node2=state1)=0.8. This can be implemented by attaching an extra node3 to node2 (see net2.jpg). To get the right soft evidence probabilities in node2, we use Bayes' rule to calculate the probabilities in the cpt for node3. I also attached the xdsl network if you want to have a look at the cpts. I'm not sure if my approach is fool proof, but in this simple case it seems to work fine.
P(Node3=State0|Node2=State0)=P(Node2=0|Node3=0)*P(Node3=0)/P(Node2=0)
which is as value: 0.2*0.39/0.65=0.118 <- the value of the probability table in node3
The value of P(Node3=0) is the marginal probability and has the value 0.39.
Normally the marginal probability is computed as:
P(Node3=0)=P(Node3=0|Node2=0)*P(Node2=0) + P(Node3=0|Node2=1)*P(Node2=1)
But we don't have probabilities of Node3 at this point. How can I create a formula which gives me back the 0.118 for the cpt of node3 in dependency of P(Node2=0), P(Node2=1) and desired "softevidence"-value(80, 20) ???
Can you please help me?
Probably the easiest way to calculate the probabilities is not to use Bayes' rule, but to do the following. Because of the soft evidence, P(node2=state0|node3=state0)=0.2=P(node2=state0,node3=state0)/P(node3=state0). Both terms can be calculated by marginalizing the joint distribution. Let P(node3=state0|node2=state0)=x and P(node3=state0|node2=state1)=1-x. After writing everything out (which is tedious) you can solve for x and find the probabilities in the CPT. Let me know if you need more details.
			
			
									
						
										
						- 
				joergweber79
- Posts: 21
- Joined: Thu Jan 15, 2009 4:22 pm
Thanks for advice
Hello Mark,
thank you for your advice. Using the formulas
P(node3=state0|node2=state0)=x and P(node3=state0|node2=state1)=1-x
...i have derived a formula for the marginal probability of node3=state0:
	
P(Node3=state0)=P(Node2=state1)*P(Node2=state0)/(P(Node2=state1|Node3=state0)*P(Node2=state0)+P(Node2=state0|node3=state0)*P(node2=state1))
=0.3855
...using the bayes rule we get
P(Node3=state0|Node2=state0)=P(Node2=state0|Node3=state0)*P(Node3=state0)/P(Node2=state0)
=0.1186
Is that formula mathematically correct? In comparison to the example you provided, i have a small difference in the results. Using the formula above genie exactly displays the values (0.2/0.8 ) in case of soft evidence.
	
But I have one more question:
Are there any inconsistencies, if i would use this "workaround" for an intermediate node? (Not an leaf node)
Thanks in advance!
	
Cheers,
Joerg
			
			
									
						
										
						thank you for your advice. Using the formulas
P(node3=state0|node2=state0)=x and P(node3=state0|node2=state1)=1-x
...i have derived a formula for the marginal probability of node3=state0:
P(Node3=state0)=P(Node2=state1)*P(Node2=state0)/(P(Node2=state1|Node3=state0)*P(Node2=state0)+P(Node2=state0|node3=state0)*P(node2=state1))
=0.3855
...using the bayes rule we get
P(Node3=state0|Node2=state0)=P(Node2=state0|Node3=state0)*P(Node3=state0)/P(Node2=state0)
=0.1186
Is that formula mathematically correct? In comparison to the example you provided, i have a small difference in the results. Using the formula above genie exactly displays the values (0.2/0.8 ) in case of soft evidence.
But I have one more question:
Are there any inconsistencies, if i would use this "workaround" for an intermediate node? (Not an leaf node)
Thanks in advance!
Cheers,
Joerg
To calculate the marginal probability of Node3, normally you would marginalize the joint distribution, i.e., P(Node3) = \sum_{Node1, Node2} P(Node1, Node2, Node3). My previous post described how to obtain the joint distribution. I don't know how you derived your formula, but it seems to calculate the marginal probability. I think this approach should also work for intermediate nodes, although the formulas will become more complicated.
			
			
									
						
										
						Soft Evidence and Fuzzy Bayesian Network
Hello, 
I am student on second year Master's of search "New Technology and Dedicated Computer System" and I work on Fuzzy Bayesian Network (FBN) ...
I think that this axis is very similar to the notion " soft evidence "..
What you think of that?
And if you can explain to me the functioning of " Soft Evidence "?
Thank you in advance
			
			
									
						
										
						I am student on second year Master's of search "New Technology and Dedicated Computer System" and I work on Fuzzy Bayesian Network (FBN) ...
I think that this axis is very similar to the notion " soft evidence "..
What you think of that?
And if you can explain to me the functioning of " Soft Evidence "?
Thank you in advance