Next: , Previous: , Up: Top   [Contents]


4 Protocol

4.1 Interface

The following is a list of exported predicates available to the library users’.

Each predicate corresponds to one of the following categories

Each argument of a predicate correponds to a data type. See the SWI Prolog data types manual12 and the Learn Prolog Now manual13. Have a look at the Cplint help manual14 to learn in details about the functionality of each predicate.

Helper: build_xy_list(+X:list,+Y:list,-Out:list) is det

Given to lists X and Y build an output list Out in the form [X1-Y1,X2-Y2,...,XN-YN].

Helper: r_row(+X:atom,+Y:atom,-Out:atom) is det

Given two atoms X and Y, build the term r(X,Y) in Out.

Helper: get_set_from_xy_list(+L:list,-R:list) is det

Given an input list L in the form [X1-Y1,X2-Y2,...,XN-YN], transform it in an output list R in the form [r(X1,Y1),r(X2,Y2),...,r(XN,YN)]. This means that R will contain an X-Y relationship which can be then passed to an R data frame.

Pita: prob_bar_r(:Query:atom) is nondet

The predicate computes and plots the probability of Query as a bar chart with a bar for the probability of Query true and a bar for the probability of Query false. If Query is not ground, it returns in backtracking all ground instantiations of Query together with their probabilities.

Pita: prob_bar_r(:Query:atom,:Evidence:atom) is nondet

The predicate computes and plots the probability of Query given Evidence as a bar chart with a bar for the probability of Query true and a bar for the probability of Query false given Evidence. If Query / Evidence are not ground, it returns in backtracking all ground instantiations of Query / Evidence together with their probabilities.

Mcintyre: mc_prob_bar_r(:Query:atom,-Probability:dict) is det

See prob_bar_r/2.

Mcintyre: mc_sample_bar_r(:Query:atom,+Samples:int) is det

The predicate samples Query a number of Samples times and plots a bar chart with a bar for the number of successes and a bar for the number of failures. If Query is not ground, it considers it as an existential query.

Mcintyre: mc_sample_arg_bar_r(:Query:atom,+Samples:int,?Arg:var) is det

The predicate samples Query Samples times. Arg should be a variable in Query. The predicate plots a bar chart with a bar for each possible value of L, the list of values of Arg for which Query succeeds in a world sampled at random. The size of the bar is the number of samples returning that list of values.

Mcintyre: mc_sample_arg_first_bar_r(:Query:atom,+Samples:int,?Arg:var) is det

The predicate samples Query Samples times. Arg should be a variable in Query. The predicate plots a bar chart with a bar for each value of Arg returned as a first answer by Query in a world sampled at random. The size of the bar is the number of samples that returned that value. The value is failure if the query fails.

Mcintyre: mc_rejection_sample_arg_bar_r(:Query:atom,:Evidence:atom,+Samples:int,?Arg:var) is det

The predicate calls mc_rejection_sample_arg/5 and builds an R graph of the results. It plots a bar chart with a bar for each possible value of L, the list of values of Arg for which Query succeeds given that Evidence is true The size of the bar is the number of samples returning that list of values.

Mcintyre: mc_mh_sample_arg_bar_r(:Query:atom,:Evidence:atom,+Samples:int,+Lag:int,?Arg:var) is det

The predicate calls mc_mh_sample_arg/6 and builds an R graph of the results. The predicate plots a bar chart with a bar for each possible value of L, the list of values of Arg for which Query succeeds in a world sampled at random. The size of the bar is the number of samples returning that list of values.

Mcintyre: mc_mh_sample_arg_bar_r(:Query:atom,:Evidence:atom,+Samples:int,+Mix:int,+Lag:int,?Arg:var) is det

The predicate calls mc_mh_sample_arg/7 and builds an R graph of the results. The predicate plots a bar chart with a bar for each possible value of L, the list of values of Arg for which Query succeeds in a world sampled at random. The size of the bar is the number of samples returning that list of values.

Mcintyre: histogram_r(+List:list,+NBins:int) is det

Draws a histogram of the samples in List dividing the domain in NBins bins. List must be a list of couples of the form [V]-W or V-W where V is a sampled value and W is its weight.

Mcintyre: density_r(+List:list) is det

Display a smooth density estimate of a sets of samples. The samples are in List as couples V-W where V is a value and W its weigth.

Mcintyre: densities_r(+PriorList:list,+PostList:list) is det

Display a smooth density estimate of two sets of samples, usually prior and post observations. The samples from the prior are in PriorList while the samples from the posterior are in PostList as couples V-W where V is a value and W its weigth.

Auc: compute_areas_diagrams_r(+LG:list,-AUCROC:float,-AUCPR:float) is det

The predicate takes as input a list LG of pairs probability-literal in asceding order on probability where the literal can be an Atom (incading a positive example) or \+ Atom, indicating a negative example while the probability is the probability of Atom of being true. PR and ROC diagrams are plotted. The predicate returns:

See http://cplint.lamping.unife.it/example/exauc.pl for an example.

4.2 Internals

Important predicates in this library follow a common structure to avoid confusion and promote standardization.

Interface predicates are involved in the interaction between input data from a program and the plot of that same data. These predicates are usable from the programs.

As the name suggests, plotting predicates are only involved in plotting the data.

Finally there are other functions which handle the lists and other types of data.

4.2.1 Interface predicates

All interface predicates have a similar structure. Their names end with _r (except the Helpers) in order to distinguish them from the original Cplint predicates.

First and last operations are always load_r_libraries and finalize_r_graph respectively.

Plotting is done right before the last operation with one of the geom_ predicates.

A skeleton of the structure follows.

<cplint_graphing_predicate>_r(<input>):-
    load_r_libraries,
    <operations on the input>,
    geom_<something>(<new input, possibly lists>),
    finalize_r_graph.

4.2.2 Plotting predicates

Predicates directly involved in plotting all start with geom_ as prefix.

These predicates work with lists which are then transformed into R data frames, and, as a final instruction, a corresponding plot is generated.

You can visualize the structure with the following pseudocode:

geom_<something>(<Lists and/or other input>) :-
    <handle lists>,
    <create one or more R data frame with the lists data>,
    <rename data frame colnames to avoid using default ones>,
    <- ggplot <something>

4.2.3 List handling

List handling is useful to pass information between Prolog and R. This is done thanks to build_xy_list/3, r_row/3 and get_set_from_xy_list/2 predicates, described in the interface section.

In case there are multiple distributions we simply have to call get_set_from_xy_list/2 the appropriate number of times, like: get_set_from_xy_list(<something>,R#).

4.2.4 Main data frame creation

As descibed before, a data frame is useful to pass structured information between Prolog and R.

In Cplint R in particular, we use r_data_frame_from_rows/2 provided by the Rserve Client library, in the following manner:

r_data_frame_from_rows(df[#], R[#])

For each distribution the optional number is incremented by one.

In case it is the last (or only) data frame then its name will simply be df.

4.2.5 Helpers

What follows are extracts of some trivial predicates indicated as internal helpers.

bin_width(Min,Max,NBins,Width) :-
  D is Max-Min,
  Width is D/NBins.

load_r_libraries :-
    <- library("ggplot2").

finalize_r_graph :-
    r_download.

Footnotes

(12)

See item [SWI Prolog data types] in SWI Prolog data types.

(13)

See item [LPN] in LPN.

(14)

See item [Cplint] in Cplint.


Next: , Previous: , Up: Top   [Contents]