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
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
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 ()