Mercurial > octave
annotate scripts/elfun/sinpi.m @ 33658:b1d6e40ac737 stable tip
NEWS.9.md: Fix typo and minor formatting changes.
* etc/NEWS.9.md: Fix typo. Adjust whitespace. Use markdown syntax for code
snippets.
author | Markus Mützel <markus.muetzel@gmx.de> |
---|---|
date | Wed, 05 Jun 2024 11:27:35 +0200 |
parents | 2e484f9f1f18 |
children |
rev | line source |
---|---|
29161
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
1 ######################################################################## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
2 ## |
32632
2e484f9f1f18
maint: update Octave Project Developers copyright for the new year
John W. Eaton <jwe@octave.org>
parents:
31706
diff
changeset
|
3 ## Copyright (C) 2020-2024 The Octave Project Developers |
29161
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
4 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
5 ## See the file COPYRIGHT.md in the top-level directory of this |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
6 ## distribution or <https://octave.org/copyright/>. |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
7 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
8 ## This file is part of Octave. |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
9 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
10 ## Octave is free software: you can redistribute it and/or modify it |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
11 ## under the terms of the GNU General Public License as published by |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
12 ## the Free Software Foundation, either version 3 of the License, or |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
13 ## (at your option) any later version. |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
14 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
15 ## Octave is distributed in the hope that it will be useful, but |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
16 ## WITHOUT ANY WARRANTY; without even the implied warranty of |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
17 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
18 ## GNU General Public License for more details. |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
19 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
20 ## You should have received a copy of the GNU General Public License |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
21 ## along with Octave; see the file COPYING. If not, see |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
22 ## <https://www.gnu.org/licenses/>. |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
23 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
24 ######################################################################## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
25 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
26 ## -*- texinfo -*- |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
27 ## @deftypefn {} {@var{y} =} sinpi (@var{x}) |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
28 ## Compute sine (@var{x} * pi) for each element of @var{x} accurately. |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
29 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
30 ## The ordinary @code{sin} function uses IEEE floating point numbers and may |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
31 ## produce results that are very close (within a few eps) of the correct |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
32 ## value, but which are not exact. The @code{sinpi} function is more accurate |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
33 ## and returns 0 exactly for integer values of @var{x} and +1/-1 for |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
34 ## half-integer values (e.g., @dots{}, -3/2, -1/2, 1/2, 3/2, @dots{}). |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
35 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
36 ## Example @* |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
37 ## comparison of @code{sin} and @code{sinpi} for integer values of @var{x} |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
38 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
39 ## @example |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
40 ## @group |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
41 ## sin ([0, 1, 2, 3] * pi) |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
42 ## @result{} |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
43 ## 0 1.2246e-16 -2.4493e-16 3.6739e-16 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
44 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
45 ## sinpi ([0, 1, 2, 3]) |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
46 ## @result{} |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
47 ## 0 0 0 0 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
48 ## @end group |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
49 ## @end example |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
50 ## |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
51 ## @seealso{cospi, sin} |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
52 ## @end deftypefn |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
53 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
54 function y = sinpi (x) |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
55 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
56 if (nargin < 1) |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
57 print_usage (); |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
58 endif |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
59 |
29167
9193e7c990ea
sind.m, sinpi.m, cospi.m: Wrap to interval closer to zero for higher accuracy.
Markus Mützel <markus.muetzel@gmx.de>
parents:
29161
diff
changeset
|
60 ## Wrap integer multiples so that new domain is [-1, 1) |
9193e7c990ea
sind.m, sinpi.m, cospi.m: Wrap to interval closer to zero for higher accuracy.
Markus Mützel <markus.muetzel@gmx.de>
parents:
29161
diff
changeset
|
61 x = mod (x-1, 2) - 1; |
29161
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
62 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
63 ## Integer multiples of pi must be exactly zero |
29167
9193e7c990ea
sind.m, sinpi.m, cospi.m: Wrap to interval closer to zero for higher accuracy.
Markus Mützel <markus.muetzel@gmx.de>
parents:
29161
diff
changeset
|
64 x(x == -1) = 0; |
29161
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
65 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
66 y = sin (x * pi); |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
67 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
68 endfunction |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
69 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
70 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
71 %!assert (sinpi ([-1, -2, 0, 1, 2]) == 0) |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
72 %!assert (sinpi ([-3/2, -1/2, 1/2, 3/2]), [1, -1, 1, -1]) |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
73 %!assert (sinpi (100 + [0.1:0.1:0.9]), sin ([0.1:0.1:0.9]*pi), 2*eps (100)) |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
74 |
b58e3a04fab3
sinpi.m, cospi.m: New trigonometric functions (bug #59615)
Rik <rik@octave.org>
parents:
diff
changeset
|
75 %!error <Invalid call> sinpi () |