52 lines
1.6 KiB
Plaintext
52 lines
1.6 KiB
Plaintext
|
Name:
|
||
|
=====
|
||
|
prime
|
||
|
|
||
|
|
||
|
Description:
|
||
|
============
|
||
|
Example that displays the timer count on the LEDs.
|
||
|
|
||
|
|
||
|
Purpose:
|
||
|
========
|
||
|
This example consists of a non-optimized, brute-force routine for computing
|
||
|
the number of prime numbers between 1 and a given value, N. The routine
|
||
|
uses modulo operations to determine whether a value is prime or not. While
|
||
|
obviously not optimal, it is very useful for exercising the core.
|
||
|
|
||
|
For this example, N is 100000, for which the answer is 9592.
|
||
|
|
||
|
For Apollo3 at 48MHz, the time to compute the answer for Keil and IAR:
|
||
|
IAR v8.11.1: 1:43.
|
||
|
Keil ARMCC 4060528: 1:55.
|
||
|
|
||
|
Printing takes place over the ITM at 1M Baud.
|
||
|
|
||
|
Additional Information:
|
||
|
=======================
|
||
|
The goal of this example is to measure current consumption while the core
|
||
|
is working to compute the answer. Power and energy can then be derived
|
||
|
knowing the current and run time.
|
||
|
|
||
|
The example prints an initial banner to the UART port. After each prime
|
||
|
loop, it enables the UART long enough to print the answer, disables the
|
||
|
UART and starts the computation again.
|
||
|
|
||
|
Text is output to the UART at 115,200 BAUD, 8 bit, no parity.
|
||
|
Please note that text end-of-line is a newline (LF) character only.
|
||
|
Therefore, the UART terminal must be set to simulate a CR/LF.
|
||
|
|
||
|
Note: For minimum power, disable the printing by setting PRINT_UART to 0.
|
||
|
|
||
|
The prime_number() routine is open source and is used here under the
|
||
|
GNU LESSER GENERAL PUBLIC LICENSE Version 3, 29 June 2007. Details,
|
||
|
documentation, and the full license for this routine can be found in
|
||
|
the third_party/prime_mpi/ directory of the SDK.
|
||
|
|
||
|
|
||
|
|
||
|
******************************************************************************
|
||
|
|
||
|
|