1.. zephyr:code-sample:: smp_pi 2 :name: SMP Pi 3 4 Calculate the first 240 digits of Pi on multiple execution units. 5 6Overview 7******** 8This sample application calculates Pi independently in many threads, and 9demonstrates the benefit of multiple execution units (CPU cores) 10when compute-intensive tasks can be run in parallel, with 11no cross-dependencies or shared resources. 12 13By changing the value of CONFIG_MP_MAX_NUM_CPUS on SMP systems, you 14can see that using more cores takes almost linearly less time 15to complete the computational task. 16 17You can also edit the sample source code to change the 18number of digits calculated (``DIGITS_NUM``), and the 19number of threads to use (``THREADS_NUM``). 20 21Building and Running 22******************** 23 24This project outputs Pi values calculated by each thread and in the end total time 25required for all the calculation to be done. It can be built and executed 26on Synopsys ARC HSDK board as follows: 27 28.. zephyr-app-commands:: 29 :zephyr-app: samples/arch/smp/pi 30 :host-os: unix 31 :board: qemu_x86_64 32 :goals: run 33 :compact: 34 35Sample Output 36============= 37 38.. code-block:: console 39 40 Calculate first 240 digits of Pi independently by 16 threads. 41 Pi value calculated by thread #0: 3141592653589793238462643383279502884197... 42 Pi value calculated by thread #1: 3141592653589793238462643383279502884197... 43 ... 44 Pi value calculated by thread #14: 314159265358979323846264338327950288419... 45 Pi value calculated by thread #15: 314159265358979323846264338327950288419... 46 All 16 threads executed by 4 cores in 28 msec 47