Monitoring of global predicates is a fundamental problem in asynchronous distributed systems. This problem arises in various contexts such as design, testing and debugging, and fault-tolerance of distributed programs. In this paper, we establish that the problem of determining whether there exists a consistent cut of a computation that satisfies a predicate in k-CNF, k > 1, in which no two clauses contain variables from the same process is NP-complete in general. A polynomial-time algorithm to find the consistent cut, if it exists, that satisfies the predicate for special cases is provided. We also give algorithms albeit exponential that can be used to achieve an exponential reduction in time over existing techniques for solving the general version.
Furthermore, we present an algorithm to determine whether there exists a consistent cut of a computation for which the sum x1 + x2 + ... + xn exactly equals some constant k, where each xi is an integer variable on process pi such that it is incremented or decremented by at most one at each step. As a corollary, any symmetric global predicate on boolean variables such as absence of simple majority and exclusive-or of local predicates can now be detected. Additionally, the problem is proved to be NP-complete if each xi can be changed by an arbitrary amount at each step.
Our results solve the previously open problems in predicate detection and bridge the wide gap between the known tractability and intractability results.