int_table(_, [0.5, 0.4, 0.1],[h, m, l]). grade_table(I, D, /* h h h m h l m h m m m l l h l m l l */ p([a,b,c,d], [ 0.2, 0.7, 0.85, 0.1, 0.2, 0.5, 0.01, 0.05,0.1 , 0.6, 0.25, 0.12, 0.3, 0.6,0.35,0.04, 0.15, 0.4 , 0.15,0.04, 0.02, 0.4,0.15,0.12, 0.5, 0.6, 0.4, 0.05,0.01, 0.01, 0.2,0.05,0.03, 0.45, 0.2, 0.1 ], [I,D])). /* A: professor's ability; B: student's grade (for course registration). */ satisfaction_table(A, G, /* h a h b h c h d m a m b m c m d l a l b l c l d */ p([h,m,l], /*h*/ [0.98, 0.9,0.8 , 0.6, 0.9, 0.4, 0.2, 0.01, 0.5, 0.2, 0.01, 0.01, /*m*/ 0.01, 0.09,0.15, 0.3,0.05, 0.4, 0.3, 0.04,0.35, 0.3, 0.09, 0.01 , /*l*/ 0.01, 0.01,0.05, 0.1,0.05, 0.2, 0.5, 0.95,0.15, 0.5, 0.9, 0.98], [A,G])). % The idea is quite simple: % hs = h -> r = ( 0.9, 0.1, 0) % hs = m -> r = ( 0.2, 0.6, 0.2) % hs = l -> r = ( 0, 0.1, 0.9) % % add all and divide on the number of elements on the table! % rating_prob_table([0.9,0.05,0.01, 0.09,0.9,0.09, 0.01,0.05,0.9]). abi_table( _, [0.50, 0.40, 0.10]). pop_table(_, [0.9, 0.2, 0.01, 0.09, 0.6, 0.09, 0.01, 0.2, 0.9]). dif_table( _, [0.25, 0.50, 0.25]).