TODO ==== * Break main() into smaller chunks; operations that are timed should become independent functions. * Const everything * OpenMP