data:image/s3,"s3://crabby-images/f0731/f07315330c72d721a433df91b1dcf64ddc348248" alt=":)"
data:image/s3,"s3://crabby-images/3dab6/3dab61cbbe672526711b8a9e270956916b33127f" alt=":lol:"
There are two main approaches to writing a computer bridge program to reproduce human card-play:
The first is the "monte-carlo" or random simulation approach. This is a "one size fits all" type of approach requiring only a limited number of algorithms.
It involves a dealer program which provides random hands for the concealed players constrained by the known cards in the open hands( the player and dummy)The number of random hands dealt is limited by the need to keep delays within acceptable limits. This is merely a quick way of approximating to the true probabilities of the distribution of the unknown cards.
Next everyone of these sample distributions is examined on a double-dummy basis and the acceptable card or cards recorded.Then the card which is recorded on the greatest number of samples is played. If there is more than one card the choice between them is either made at random or according to some rule set in advance. We have seen that either method can lead to seriously weird results.
The major advantage of the random simulation approach is that it is relatively quick to program - one estimate is 2 years to produce to develop a computer champion standard program. The great disadvantage is that it plays poorly on many types of deals and the timing of individual plays is decidedly eccentric.
data:image/s3,"s3://crabby-images/7d939/7d939770e447b147fd6d342b81fef775dd3a5660" alt=":("
The second approach may be labelled "pragmatic reasoning". This requires a much longer period of development with separate groups of algorithms for every type of play, and the computer declarer at least is also required to formulate an initial plan.
There are several programs on the market which could be classed as following this approach but I have not found any where programming has gone beyond a few basic plays.
However Fred Gitelman described such a program in 1992 and estimated developing it would take a further 5 years on top of the work he had already put into Base III. I fear his estimate may prove conservative.
Bridge Baron seem to have used a simpler program of this type, which they called Tignum2, when they won the championship in 1997. Unfortunately they lost to GIB in 1998 and seem to have reverted to a monte-carlo clone thereafter.
Various academic papers (lists available) have discussed the limitations of random simulations and have formulated approaches to reproducing declarer play but no complete system or program has emerged so far.
To date, the random simulation programs have the edge in competitive play; I would say largely because no one has been prepared to devote the time necessary to develop a pragmatic program capable of beating them.
I would dearly like to see a fully developed pragmatic program before I die because it would offer so much more than a random simulation. It would be a program worth queuing in the rain for
data:image/s3,"s3://crabby-images/e4c04/e4c04af6171f715eac55af5d6d276f5e52e2cf73" alt=":rolleyes:"
I do see one slander ray of hope. Each year the programmers return from the championship and settle down to improving their programs competitiveness. Similar to Barmer and Inquiry improving GIB in response to our complaints.
Now random simulations can be improved by:
removing bugs
removing errors in the dealer or double-dummy programs
increasing the number of samples, this cannot go beyond making the probabilities more nearly accurate
Thus at some time they have to realize that any further improvement must come from superimposing pragmatic reasoning on the monte-carlo results. Once this is done the door is opened to a seamless transition from a very imperfect random simulation to a potentially perfect pragmatic program. The program need never be off the market and the only visible evidence of change is that more and more deals begin to be played correctly.
data:image/s3,"s3://crabby-images/f0731/f07315330c72d721a433df91b1dcf64ddc348248" alt=":)"