| 1 |
128 |
Agner |
/*************************** integrate.as ***********************************
|
| 2 |
|
|
* Author: Agner Fog
|
| 3 |
|
|
* date created: 2018-02-30
|
| 4 |
|
|
* Version: 1.00
|
| 5 |
|
|
* Project: ForwardCom example, assembly code
|
| 6 |
|
|
* Description: Numerical integration of sin(x) from 0 to pi/2
|
| 7 |
|
|
*
|
| 8 |
|
|
* Link with libraries libc.li and math.li
|
| 9 |
|
|
*
|
| 10 |
|
|
* Copyright 2018 GNU General Public License http://www.gnu.org/licenses
|
| 11 |
|
|
*****************************************************************************/
|
| 12 |
|
|
|
| 13 |
|
|
// define parameters. you may change these
|
| 14 |
|
|
% npoints = 8 // number of function points to calculate. must be a power of 2
|
| 15 |
|
|
% M_PI = 3.14159265358979323846 // pi
|
| 16 |
|
|
% startvalue = 0 // start of x interval
|
| 17 |
|
|
% endvalue = M_PI / 2 // end of x interval
|
| 18 |
|
|
|
| 19 |
|
|
|
| 20 |
|
|
|
| 21 |
|
|
const section read ip // read-only data section
|
| 22 |
|
|
// format string for printf
|
| 23 |
|
|
form: int8 "\nNumerical integration of sin(x) from %f to %f "
|
| 24 |
|
|
int8 "with %i function points."
|
| 25 |
|
|
int8 "\nThe result is %.15f\n",0
|
| 26 |
|
|
const end
|
| 27 |
|
|
|
| 28 |
|
|
bss section datap uninitialized // uninitialized read/write data section
|
| 29 |
|
|
int64 parlist[8] // parameter list for printf
|
| 30 |
|
|
bss end
|
| 31 |
|
|
|
| 32 |
|
|
code section execute align = 4 // code section
|
| 33 |
|
|
|
| 34 |
|
|
extern _sin: function // library function: sine in radians
|
| 35 |
|
|
extern _integrate: function // library function: numerical integration
|
| 36 |
|
|
extern _printf: function // library function: formatted output to stdout
|
| 37 |
|
|
|
| 38 |
|
|
_main function public // program begins here
|
| 39 |
|
|
|
| 40 |
|
|
double v0 = startvalue // x interval start
|
| 41 |
|
|
double v1 = endvalue // x interval end
|
| 42 |
|
|
int64 r0 = address([_sin]) // function pointer
|
| 43 |
|
|
int64 r1 = npoints // number of x points
|
| 44 |
|
|
call _integrate // integrate sin(x)
|
| 45 |
|
|
|
| 46 |
|
|
// print results
|
| 47 |
|
|
int64 r0 = address([form]) // format string for printf
|
| 48 |
|
|
int64 r1 = address([parlist]) // parameter list for printf
|
| 49 |
|
|
double v1 = startvalue // parameters
|
| 50 |
|
|
double v2 = endvalue
|
| 51 |
|
|
int32+ r2 = npoints
|
| 52 |
|
|
double [r1, scalar] = v1 // put parameters into variable argument list for printf
|
| 53 |
|
|
double [r1+8, scalar] = v2
|
| 54 |
|
|
int64 [r1+16 ] = r2
|
| 55 |
|
|
double [r1+24, scalar] = v0
|
| 56 |
|
|
call _printf // print results
|
| 57 |
|
|
|
| 58 |
|
|
int64 r0 = 0 // program return value
|
| 59 |
|
|
return // return from main
|
| 60 |
|
|
_main end
|
| 61 |
|
|
|
| 62 |
|
|
code end
|