modified: myjupyterlab.sh
[GalaxyCodeBases.git] / c_cpp / etc / calc / help / pmod
blob38fe8e1f638d572725c727eac57b336a63770a01
1 NAME
2     pmod - integral power of an integer modulo a specified integer
4 SYNOPSIS
5     pmod(x, n, md)
7 TYPES
8     x           integer
9     n           nonnegative integer
10     md          integer
12     return      integer
14 DESCRIPTION
15     pmod(x, n, md) returns the integer value of the canonical residue
16     of x^n modulo md, where the set of canonical residues is determined
17     by md and bits 0, 2, and 4 of config("mod") (other bits are ignored).
19     If md is zero, the value is simply x^n.
21     For nonzero md, the canonical residues v modulo md are as follows:
23                 config("mod")     md > 0              md < 0
25                     0           0 < v < md         md < v < 0
26                     1         -md < v < 0           0 < v < -md
27                     4           0 < v < md          0 < v < -md
28                     5         -md < v < 0          md < v < 0
29                    16       -md/2 < v <= md/2   md/2 <= v < -md/2
30                    17      -md/2 <= v < md/2     md/2 < v <= -md/2
31                    20       -md/2 < v <= md/2    md/2 < v <= -md/2
32                    21      -md/2 <= v < md/2    md/2 <= v < -md/2
34 EXAMPLE
35     ; c = config("mod",0)
36     ; print pmod(2,3,10), pmod(2,5,10), pmod(2,3,-10), pod(2,5,-10)
37     8 2 -2 -8
39     ; c = config("mod",16)
40     ; print pmod(2,3,10), pmod(2,5,10), pmod(2,3,-10), pmod(2,5,-10)
41     -2 2 -2 2
43 LIMITS
44     none
46 LINK LIBRARY
47     NUMBER *qpowermod(NUMBER *x, NUMBER *n, NUMBER *md)
49 SEE ALSO
50     mod, minv
52 ## Copyright (C) 1999  Landon Curt Noll
54 ## Calc is open software; you can redistribute it and/or modify it under
55 ## the terms of the version 2.1 of the GNU Lesser General Public License
56 ## as published by the Free Software Foundation.
58 ## Calc is distributed in the hope that it will be useful, but WITHOUT
59 ## ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
60 ## or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General
61 ## Public License for more details.
63 ## A copy of version 2.1 of the GNU Lesser General Public License is
64 ## distributed with calc under the filename COPYING-LGPL.  You should have
65 ## received a copy with calc; if not, write to Free Software Foundation, Inc.
66 ## 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
68 ## @(#) $Revision: 30.1 $
69 ## @(#) $Id: pmod,v 30.1 2007/03/16 11:10:42 chongo Exp $
70 ## @(#) $Source: /usr/local/src/cmd/calc/help/RCS/pmod,v $
72 ## Under source code control:   1995/11/09 03:27:51
73 ## File existed as early as:    1995
75 ## chongo <was here> /\oo/\     http://www.isthe.com/chongo/
76 ## Share and enjoy!  :-)        http://www.isthe.com/chongo/tech/comp/calc/