The document discusses distributed computing and the MapReduce programming model. It provides examples of how Folding@home and PS3s contribute significantly to distributed computing projects. It then explains challenges with inter-machine parallelism like communication overhead and load balancing. The document outlines Google's MapReduce model which handles these issues and makes programming distributed systems easier through its map and reduce functions.