Главная страница


ru.algorithms

 
 - RU.ALGORITHMS ----------------------------------------------------------------
 From : Alexandr A. Redchuck                 2:5020/400     08 Aug 2002  23:15:58
 To : "Evgenij M. Baldin"
 Subject : Re: Сортировка    комплексных    чисел?
 -------------------------------------------------------------------------------- 
 
 8-Aug-02 14:26 Evgenij M. Baldin wrote to Andrey Belyaev:
 
 EB> У меня есть наборы пар чисел (4 набора по 20-50 тыс после
 EB> предварительного отбора), получаемых совершенно случайным образом.
 
   Я так надеюсь, опроный массив ("матрица коррекции") меняется гораздо
 реже массива сырых данных...
 
   Тогда я попробовал бы так: "опорный" набор режем на квадраты,
 штук так на 200. Получаем толпу структур вида
 
 * x0, x1, y0, y1; - координаты границ
 * массив опорных точек, находящихся в пределах x0-dx, x1+dx, y0-dy,
    y1+dy, где dx, dy - полуширина перекрытий.
    т.е. часть опорных точек попадет в 2 или 4 массива (обязательно
    нужно!).
 
 В зависимости от размера перекрытий в каждый массив попадет по
 200-500 пар.
 
 Взяв очередную "сырую" пару сначала проверяем в какой квадрат она
 попала, потом проверяем расстояния до точек в соответствующему этому
 квадрату массиве (а вот тут и перекрытия понадобились, иначе оказалось
 бы, что для точки на краю квадрата "истинно" ближайшая может оказаться в
 другом квадрате).
 
  Итого для каждой входной точки имеем максимум 200*4=800 сравнений чисел
 на больше/меньше (попадание в квадрат) и вычисление расстояний (в смысле,
 квадратов расстояний, как тут уже тебе напомнили :-) максимум для
 200-500 пар, т.е. ускорение на 2 порядка.
 Правда, ценой увеличения, может даже раза в 2-3, объема памяти,
 занимаемого опорными данными (из-за перекрытий), но даже
 1M*sizeof(double) по нынешним временам немного :-)
 
 wbr,
 p.s. возможно, имеет смысл сделать 3-уровневую пирамиду -
 зоны, содержащие только свои границы и ссылки на квадраты,
 квадраты, как описано выше.
 Скажем, 20 зон по 20 квадратов по 100-200 пар. Итого макс.
 (20+20)*4 = 160 сравнений и макс. 100-200 вычислений расстояний.
 Hо тут надо внимательно, из-за уменьшения числа пар,
 относящихся к каждому квадрату, может понадобится увеличить
 перекрытия.
 
 --
 /* Alexandr Redchuck, Kyiv, Ukraine */
 /* real на real тчк kiev тчк ua     */
 
 --- ifmail v.2.15dev5
  * Origin: ReAl at home (2:5020/400)
 
 

Вернуться к списку тем, сортированных по: возрастание даты  уменьшение даты  тема  автор 

 Тема:    Автор:    Дата:  
 Сортировка комплексных чисел?   Evgenij M. Baldin   08 Aug 2002 13:26:07 
 Re: Сортировка комплексных чисел?   Vladimir A. Pertzel   08 Aug 2002 15:40:51 
 Re: Сортировка комплексных чисел?   Evgenij M. Baldin   08 Aug 2002 16:35:54 
 Re: Сортировка комплексных чисел?   Andrey Belyaev   08 Aug 2002 17:33:17 
 Re: Сортировка комплексных чисел?   Evgenij M. Baldin   08 Aug 2002 18:26:39 
 Re: Сортировка комплексных чисел?   Oleg I. Khovayko   08 Aug 2002 21:02:29 
 Re: Сортировка комплексных чисел?   Alexandr A. Redchuck   08 Aug 2002 23:15:58 
 Re: Сортировка комплексных чисел?   Sergey Andrianov   10 Aug 2002 00:14:20 
 Re: Сортировка комплексных чисел?   Pertzel Family   09 Aug 2002 01:06:51 
 Re: Сортировка комплексных чисел?   Nick Kovaliov   09 Aug 2002 11:50:17 
 Re: Сортировка комплексных чисел?   Evgenij M. Baldin   09 Aug 2002 13:08:53 
 Re: Сортировка комплексных чисел?   Vladimir A. Pertzel   11 Aug 2002 11:14:40 
 Re: Соpтиpовка комплексных чисел?   Anatoly Svishev   09 Aug 2002 01:03:14 
 Re: Соpтиpовка комплексных чисел?   Evgenij M. Baldin   09 Aug 2002 08:22:17 
 Re: Соpтиpовка комплексных чисел?   Evgenij M. Baldin   09 Aug 2002 08:55:04 
 Re: Сортировка комплексных чисел?   Sergey Andrianov   10 Aug 2002 00:00:40 
Архивное /ru.algorithms/6270565b108a.html, оценка 2 из 5, голосов 10
Яндекс.Метрика
Valid HTML 4.01 Transitional