mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
Declaring zmod and poly obsolete. They have problems.
This commit is contained in:
parent
b736a87703
commit
e0fbe1c26d
2 changed files with 0 additions and 0 deletions
52
Lib/lib-old/poly.py
Normal file
52
Lib/lib-old/poly.py
Normal file
|
@ -0,0 +1,52 @@
|
|||
# module 'poly' -- Polynomials
|
||||
|
||||
# A polynomial is represented by a list of coefficients, e.g.,
|
||||
# [1, 10, 5] represents 1*x**0 + 10*x**1 + 5*x**2 (or 1 + 10x + 5x**2).
|
||||
# There is no way to suppress internal zeros; trailing zeros are
|
||||
# taken out by normalize().
|
||||
|
||||
def normalize(p): # Strip unnecessary zero coefficients
|
||||
n = len(p)
|
||||
while p:
|
||||
if p[n-1]: return p[:n]
|
||||
n = n-1
|
||||
return []
|
||||
|
||||
def plus(a, b):
|
||||
if len(a) < len(b): a, b = b, a # make sure a is the longest
|
||||
res = a[:] # make a copy
|
||||
for i in range(len(b)):
|
||||
res[i] = res[i] + b[i]
|
||||
return normalize(res)
|
||||
|
||||
def minus(a, b):
|
||||
neg_b = map(lambda x: -x, b[:])
|
||||
return plus(a, neg_b)
|
||||
|
||||
def one(power, coeff): # Representation of coeff * x**power
|
||||
res = []
|
||||
for i in range(power): res.append(0)
|
||||
return res + [coeff]
|
||||
|
||||
def times(a, b):
|
||||
res = []
|
||||
for i in range(len(a)):
|
||||
for j in range(len(b)):
|
||||
res = plus(res, one(i+j, a[i]*b[j]))
|
||||
return res
|
||||
|
||||
def power(a, n): # Raise polynomial a to the positive integral power n
|
||||
if n == 0: return [1]
|
||||
if n == 1: return a
|
||||
if n/2*2 == n:
|
||||
b = power(a, n/2)
|
||||
return times(b, b)
|
||||
return times(power(a, n-1), a)
|
||||
|
||||
def der(a): # First derivative
|
||||
res = a[1:]
|
||||
for i in range(len(res)):
|
||||
res[i] = res[i] * (i+1)
|
||||
return res
|
||||
|
||||
# Computing a primitive function would require rational arithmetic...
|
Loading…
Add table
Add a link
Reference in a new issue