%% -*- prolog -*- %%============================================================================= %% Copyright (C) 2011 by Denys Duchier %% %% This program is free software: you can redistribute it and/or modify it %% under the terms of the GNU Lesser General Public License as published by the %% Free Software Foundation, either version 3 of the License, or (at your %% option) any later version. %% %% This program is distributed in the hope that it will be useful, but WITHOUT %% ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or %% FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for %% more details. %% %% You should have received a copy of the GNU Lesser General Public License %% along with this program. If not, see . %%============================================================================= :- use_module(library(gecode/clpfd)). :- use_module(library(maplist)). % 5 people want to have a photograph together, but they have preferences. photo(Ex, People, Amount) :- db(Ex, People, Preferences), length(People, Len), Len0 is Len-1, People ins 0..Len0, all_distinct(People), % Bools are the satisfied constraints maplist(preferences, Preferences, Bools), length(Preferences, PLen), Amount in 0..PLen, sum( Bools, #= , Amount ), % add all satisfied constraints maximize(Amount), labeling([], People). %reification, use with care preferences(X-Y, B) :- abs(X - Y) #= 1 #<==> B. db(s,[Alice,Bob,Carl,Deb,Evan], [Alice-Carl, Carl-Deb, Deb-Alice, Evan-Alice, Bob-Evan, Carl-Evan, Deb-Evan, Evan-Bob]). db(l,[Betty,Chris,Donald,Fred,Gary,Mary,Paul,Peter,Susan], [Betty-Donald, Betty-Gary, Betty-Peter, Chris-Gary, Chris-Susan, Donald-Fred, Donald-Gary, Fred-Betty, Fred-Gary, Gary-Mary, Gary-Betty, Mary-Betty, Mary-Susan, Paul-Donald, Paul-Peter, Peter-Susan, Peter-Paul]).