This document discusses thread and process-level parallelism. It begins by introducing how improvements to computer performance initially came from manufacturing techniques and exploitation of instruction-level parallelism (ILP), but that ILP is now fully exploited. It states that the way to achieve higher performance now is through exploiting parallelism across multiple processes or threads. It provides examples of how individual transactions in a banking application could be executed in parallel.