numpy.polynomial.polyutils.mapdomain#
- polynomial.polyutils.mapdomain(x, старый, новый)[источник]#
Применить линейное отображение к входным точкам.
Линейное отображение
offset + scale*xкоторый отображает домен старый в область определения новый применяется к точкам x.- Параметры:
- xarray_like
Точки для отображения. Если x является подтипом ndarray, подтип будет сохранён.
- старый, новыйarray_like
Две области, определяющие отображение. Каждая должна (успешно) преобразовываться в одномерные массивы, содержащие ровно два значения.
- Возвращает:
- x_outndarray
Массив точек той же формы, что и x, после применения линейного отображения между двумя областями.
Примечания
По сути, это реализует:
\[x\_out = new[0] + m(x - old[0])\]где
\[m = \frac{new[1]-new[0]}{old[1]-old[0]}\]Примеры
>>> import numpy as np >>> from numpy.polynomial import polyutils as pu >>> old_domain = (-1,1) >>> new_domain = (0,2*np.pi) >>> x = np.linspace(-1,1,6); x array([-1. , -0.6, -0.2, 0.2, 0.6, 1. ]) >>> x_out = pu.mapdomain(x, old_domain, new_domain); x_out array([ 0. , 1.25663706, 2.51327412, 3.76991118, 5.02654825, # may vary 6.28318531]) >>> x - pu.mapdomain(x_out, new_domain, old_domain) array([0., 0., 0., 0., 0., 0.])
Также работает для комплексных чисел (и, следовательно, может использоваться для отображения любой линии в комплексной плоскости на любую другую линию в ней).
>>> i = complex(0,1) >>> old = (-1 - i, 1 + i) >>> new = (-1 + i, 1 - i) >>> z = np.linspace(old[0], old[1], 6); z array([-1. -1.j , -0.6-0.6j, -0.2-0.2j, 0.2+0.2j, 0.6+0.6j, 1. +1.j ]) >>> new_z = pu.mapdomain(z, old, new); new_z array([-1.0+1.j , -0.6+0.6j, -0.2+0.2j, 0.2-0.2j, 0.6-0.6j, 1.0-1.j ]) # may vary