The cell-probe model is a minor modification of the random-access machine model, itself a minor modification of the counter machine model, in which computational cost is only assigned to accessing units of memory called cells. In this model, computation is framed as a problem of querying a set of memory cells. The problem has two phases: the preprocessing phase and the query phase. The input to the first phase, the preprocessing phase, is a set of data from which to build some structure from memory cells. The input to the second phase, the query phase, is a query datum. The problem is to determine if the query datum was included in the original input data set. Operations are free except to access memory cells. This model is useful in the analysis of data structures. In particular, the model clearly shows a minimum number of memory accesses to solve a problem in which there is stored data on which we would like to run some query. An example of such a problem is the dynamic partial sum problem.
History
In Andrew Yao's 1981 paper "Should Tables Be Sorted?", Yao described the cell-probe model and used it to give a minimum number of memory cell "probes" or accesses necessary to determine whether a given query datum exists within a table stored in memory.
Formal definition
Given a set of data construct a structure consisting of memory cells, each able to store bits. Then when given a query element determine whether with correctness by accessing memory cells. Such an algorithm is called an -error -probe algorithm using cells with word size.
Notable results
Dynamic Partial Sums
The dynamic partial sum problem defines two operations which conceptually operation sets the value in an array at index to be, and which returns the sum of the values in at indices through. Such an implementation would take time for and time for. Instead, if the values are stored as leaves in a tree whose inner nodes store the values of the subtree rooted at that node. In this structure requires time to update each node in the leaf to root path, and similarly requires time to traverse the tree from leaf to root summing the values of all subtrees left of the query index. Mihai Pătraşcu used the cell-probe model and an information transfer argument to show that the partial sums problem requires time per operation.
The exact nearest neighbor search problem is to determine the closest in a set of input points to a given query point. An approximate version of this problem is often considered since many applications of this problem are in very high dimension spaces and solving the problem in high dimensions requires exponential time or space with respect to the dimension. Chakrabarti and Regev proved that the approximate nearest neighborsearch problem on the Hamming cube using polynomial storage and word size requires a worst-case query time of. This proof used the cell-probe model and information theoretic techniques for communication complexity.