Sophie

Sophie

distrib > Mandriva > 2010.0 > i586 > media > contrib-release > by-pkgid > bd5c3d824c3db63ffd9226c15941e6ad > files > 703

mozart-1.4.0-1mdv2010.0.i586.rpm

%%%
%%% Authors:
%%%   Gert Smolka <smolka@ps.uni-sb.de>
%%%
%%% Copyright:
%%%   Gert Smolka, 1998
%%%
%%% Last change:
%%%   $Date: 1999-06-09 16:30:43 +0200 (Wed, 09 Jun 1999) $ by $Author: schulte $
%%%   $Revision: 11475 $
%%%
%%% This file is part of Mozart, an implementation
%%% of Oz 3
%%%    http://www.mozart-oz.org
%%%
%%% See the file "LICENSE" or
%%%    http://www.mozart-oz.org/LICENSE.html
%%% for information on usage and redistribution
%%% of this file, and for a DISCLAIMER OF ALL
%%% WARRANTIES.
%%%

declare
fun {Plug RackSpecs CardSpecs NbRacks Cards}
   RackType        = {List.number 0 {Length RackSpecs} 1}
   RackPower       = 0|{Map RackSpecs fun {$ T} T.power end}
   RackPrice       = 0|{Map RackSpecs fun {$ T} T.price end}
   RackNbSlots     = 0|{Map RackSpecs fun {$ T} T.slots end}
   RackMaxNbSlots  = {FoldR RackNbSlots Max 0}
   CardType        = {List.number 1 {Length CardSpecs} 1}
   CardPower       = {Map CardSpecs fun {$ T} T.power end}
   proc {Rack R}
      Type    = {FD.int RackType}
      Power   = {FD.int RackPower}
      NbCards = {FD.record type CardType 0#RackMaxNbSlots}
      Price   = {FD.int RackPrice}
      NbSlots = {FD.int RackNbSlots}
   in
      R = rack(type:  Type
	       cards: NbCards 
	       price: Price)
      {FD.sumC CardPower NbCards '=<:' Power}
      thread
	 if Type==0 then
	    Power=0  Price=0  NbSlots=0
	 else Spec={Nth RackSpecs Type} in
	    Power=Spec.power  Price=Spec.price  NbSlots=Spec.slots
	 end
      end
   end
   proc {RackList Racks}
      {ForAll Racks Rack}
      % impose order to remove symmetries
      {ForAllTail Racks 
       proc {$ Rs}
	  case Rs of A|B|_ then
	     A.type =<: B.type
	     thread
		if A.type == B.type then A.cards.1 >=: B.cards.1 end
	     end
	  else skip end
       end}
   end
   proc {Match Racks Cards}
      {ForAll CardType
       proc {$ T}
	  {FD.sum {Map Racks fun {$ R} R.cards.T end} '=:' Cards.T}
       end}
   end
   proc {Distribute Racks}
      CompList = {FoldR Racks
		  fun {$ R Cs}
		     {Append {Record.toList R.cards} Cs}
		  end
		  nil}
      TypeList = {Map Racks fun {$ R} R.type end}
   in
      {FD.distribute naive TypeList}
      {FD.distribute ff CompList}
   end
in
   proc {$ X}
      Racks = {MakeList NbRacks} = {RackList}
      Price = {FD.decl} = {FD.sum {Map Racks fun {$ R} R.price end} '=:'}
   in
      X = p(price:Price racks:Racks)
      {Match Racks Cards} 
      {Distribute Racks}
   end
end

RackSpecs = [r(power:150 slots:8  price:150)
	     r(power:200 slots:16 price:200)]
CardSpecs = [c(power:20)
	     c(power:40)
	     c(power:50)
	     c(power:75)]
NbRacks   = 5
Cards     = cards(10 4 2 1)

Order     = proc {$ Old New} Old.price >: New.price end

{ExploreBest {Plug RackSpecs CardSpecs NbRacks Cards} Order}


/*
{SearchBest {Plug RackSpecs CardSpecs NbRacks Cards} Order _}
*/