2010-08-26 13:44:10 +01:00
|
|
|
%%% -*- Mode: Prolog; -*-
|
|
|
|
|
2010-10-05 17:26:40 +01:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
% ProbLog program describing a viral marketing problem
|
|
|
|
% example for using decision theory ProbLog
|
|
|
|
% $Id: viralmarketing.pl 4875 2010-10-05 15:28:35Z theo $
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
2010-08-26 13:44:10 +01:00
|
|
|
% The viral marketing example consists of a social network of friend relations. You have to decide which persons to market. Sending marketing has a cost of 2, but might cause people to buy your product, giving you a profit of 5. When someone buys the product, it becomes more likely that his friends also buy the product.
|
|
|
|
|
2010-12-02 14:04:42 +00:00
|
|
|
:- use_module(library(dtproblog)).
|
2010-08-26 13:44:10 +01:00
|
|
|
|
|
|
|
% Decisions
|
|
|
|
? :: marketed(P) :- person(P).
|
|
|
|
|
|
|
|
% Utility attributes
|
|
|
|
buys(P) => 5 :- person(P).
|
|
|
|
marketed(P) => -2 :- person(P).
|
|
|
|
|
|
|
|
% Probabilistic facts
|
|
|
|
0.2 :: buy_from_marketing(_).
|
|
|
|
0.3 :: buy_from_trust(_,_).
|
|
|
|
|
|
|
|
% Background knowledge
|
|
|
|
person(bernd).
|
|
|
|
person(ingo).
|
|
|
|
person(theo).
|
|
|
|
person(angelika).
|
|
|
|
person(guy).
|
|
|
|
person(martijn).
|
|
|
|
person(laura).
|
|
|
|
person(kurt).
|
|
|
|
|
|
|
|
trusts(X,Y) :- trusts_directed(X,Y).
|
|
|
|
trusts(X,Y) :- trusts_directed(Y,X).
|
|
|
|
|
|
|
|
trusts_directed(bernd,ingo).
|
|
|
|
trusts_directed(ingo,theo).
|
|
|
|
trusts_directed(theo,angelika).
|
|
|
|
trusts_directed(bernd,martijn).
|
|
|
|
trusts_directed(ingo,martijn).
|
|
|
|
trusts_directed(martijn,guy).
|
|
|
|
trusts_directed(guy,theo).
|
|
|
|
trusts_directed(guy,angelika).
|
|
|
|
trusts_directed(laura,ingo).
|
|
|
|
trusts_directed(laura,theo).
|
|
|
|
trusts_directed(laura,guy).
|
|
|
|
trusts_directed(laura,martijn).
|
|
|
|
trusts_directed(kurt,bernd).
|
|
|
|
|
|
|
|
buys(X) :- buys(X,[X]).
|
|
|
|
|
|
|
|
buys(X, _) :-
|
|
|
|
marketed(X),
|
|
|
|
buy_from_marketing(X).
|
|
|
|
buys(X, Visited) :-
|
|
|
|
trusts(X,Y),
|
|
|
|
buy_from_trust(X,Y),
|
|
|
|
absent(Y,Visited),
|
|
|
|
buys(Y, [Y|Visited]).
|
|
|
|
|
|
|
|
absent(_,[]).
|
|
|
|
absent(X,[Y|Z]):-X \= Y, absent(X,Z).
|
|
|
|
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
% EXAMPLE USE::
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%
|
|
|
|
% Find the globally optimal strategy.
|
|
|
|
%
|
|
|
|
% ?- dtproblog_solve(Strategy,ExpectedValue).
|
|
|
|
% ExpectedValue = 3.21097,
|
|
|
|
% Strategy = [marketed(martijn),marketed(guy),marketed(theo),marketed(ingo)]
|
|
|
|
%
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%
|
|
|
|
% Compute the expected value for a given strategy.
|
|
|
|
%
|
|
|
|
% ?- dtproblog_ev([marketed(martijn),marketed(laura)],ExpectedValue).
|
|
|
|
% ExpectedValue = 2.35771065
|
|
|
|
%
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%
|
|
|
|
% Find a locally optimal strategy.
|
|
|
|
%
|
|
|
|
% ?- set_problog_flag(optimization, local), dtproblog_solve(Strategy,ExpectedValue).
|
|
|
|
% ExpectedValue = 3.19528,
|
|
|
|
% Strategy = [marketed(martijn),marketed(laura),marketed(guy),marketed(ingo)]
|
|
|
|
%
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%
|
|
|
|
% Find all ground utility facts in the theory.
|
|
|
|
%
|
|
|
|
% ?- dtproblog_utility_facts(Facts).
|
|
|
|
% Facts = [buys(bernd)=>5, buys(ingo)=>5, buys(theo)=>5, buys(angelika)=>5, buys(guy)=>5, buys(martijn)=>5, buys(laura)=>5, buys(kurt)=>5, marketed(bernd)=> -2, marketed(ingo)=> -2, marketed(theo)=> -2, marketed(angelika)=> -2, marketed(guy)=> -2, marketed(martijn)=> -2, marketed(laura)=> -2, marketed(kurt)=> -2]
|
|
|
|
%
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%
|
|
|
|
% Find all ground decisions relevant to the utility attributes.
|
|
|
|
%
|
|
|
|
% ?- dtproblog_decisions(Decisions).
|
|
|
|
% Decisions = [marketed(angelika), marketed(theo), marketed(kurt), marketed(ingo), marketed(laura), marketed(martijn), marketed(guy), marketed(bernd)]
|
|
|
|
%
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%
|
|
|
|
% Set the inference method to K-best to limit the complexity. This means that only the K most likely proofs for each utility attribute are considered as an underestimate of the probabilities and utilities. In the viral marketing example, this means that the probability that someone buys the product only depends on a limited number of other people in the social network, regardless of the size of the social network.
|
|
|
|
% Finding the globally optimal strategy under these simplifying assumptions yields a good but suboptimal strategy.
|
|
|
|
%
|
|
|
|
% ?- set_problog_flag(inference,20-best), dtproblog_solve(Strategy,ExpectedValue).
|
|
|
|
% ExpectedValue = 2.62531,
|
|
|
|
% Strategy = [marketed(martijn),marketed(guy),marketed(ingo),marketed(laura)]
|
|
|
|
%
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%
|
|
|
|
% The expected value returned in the previous example is an underestimate of the real expected value of the strategy found, which can be computed as
|
|
|
|
%
|
|
|
|
% ?- set_problog_flag(inference,exact), dtproblog_ev([marketed(martijn), marketed(guy), marketed(ingo), marketed(laura)], ExpectedValue).
|
|
|
|
% ExpectedValue = 3.1952798
|
|
|
|
%
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|