Performance Prophet: A Performance Modeling and Prediction Tool for Parallel and Distributed Programs