Главная страница  |  Описание сайта  |  Контакты
Патент на изобретение №2451988

(19)

RU

(11)

2451988

(13)

C1

(51) МПК G06F7/60 (2006.01)

(12) ОПИСАНИЕ ИЗОБРЕТЕНИЯ К ПАТЕНТУ Статус: по данным на 27.08.2012 - действует Пошлина:

(21), (22) Заявка: 2011117695/08, 05.05.2011

(24) Дата начала отсчета срока действия патента:

05.05.2011

Приоритет(ы):

(22) Дата подачи заявки: 05.05.2011

(45) Опубликовано: 27.05.2012

(56) Список документов, цитированных в отчете о

поиске: RU 2047216 C1, 27.10.1995. US 5541865 A1, 30.07.1996. US 6754685 B2, 22.06.2004. US 5717616 A1, 10.02.1998.

Адрес для переписки:

410012, г.Саратов, ул. Московская, 155, СГУ, ЦПУ, Н.В. Романовой, рег. 325

(72) Автор(ы):

Сотов Леонид Сергеевич (RU)

(73) Патентообладатель(и):

Государственное образовательное учреждение высшего профессионального образования "Саратовский государственный университет им. Н.Г. Чернышевского" (RU)

(54) БЫСТРОДЕЙСТВУЮЩЕЕ УСТРОЙСТВО ДЛЯ РАСЧЕТА ПОРЯДКОВЫХ НОМЕРОВ БИТОВ С ВЫСОКИМ ЛОГИЧЕСКИМ УРОВНЕМ В СТРОКЕ ДАННЫХ

(57) Реферат:

Изобретение относится к области обработки информации. Техническим результатом является повышение быстродействия расчета порядковых номеров битов и общего числа бит с высоким логическим уровнем в строке данных длиной n, при этом число используемых сумматоров должно быть более O(nlog 2 n), при этом обеспечивается задержка расчета порядковых номеров битов и общего числа бит с высоким логическим уровнем не более t 3 log 2 n, где t 3 - задержка сумматора с сохранением переноса, при этом число используемых в устройстве сумматоров составляет nlog 2 n. Быстродействующее устройство для расчета порядковых номеров битов с высоким логическим уровнем в строке данных, согласно решению, характеризуется тем, что оно содержит n бинарных входов битов входной строки данных, n выходов порядковых номеров битов с высоким логическим уровнем, выход POPCNT количества битов с высоким логическим уровнем, n элементов логического умножения , каждый из которых имеет выход Y, соединеный с выходом Q j , первый вход X1 и второй бинарный вход Х2, иерархические вычислительные уровни , каждый из которых имеет 2 m входов D i и 2 m выходов , причем каждый вычислительный уровень состоит из первого и второго вычислительных уровней L m-1 и 2 m-1 сумматоров , имеющих первый А и второй В входы и выход С. 5 ил.

Устройство относится к области обработки информации и может быть использовано в вычислительной технике, системах коммуникации и защиты информации от несанкционированного доступа.

Известен многовходовый одноразрядный сумматор (см. патент на изобретение RU 2047216, МПК G06F 7/50). Многовходовый одноразрядный сумматор содержит К элементов сложения по модулю два (K[log 2 n] n разрядность входного двоичного слова), выход r-го из которых соединен с r-м выходом сумматора, отличающийся тем, что содержит p мажоритарных элементов (p[n/2]), s-й из которых имеет порог, равный 2s, i-й вход сумматора соединен с i-м входом первого элемента сложения по модулю два и i-м входом s-го мажоритарного элемента, t-й вход j-го элемента сложения по модулю два соединен с выходом мажоритарного элемента с порогом t·2 j-1 , (k+1)-й выход сумматора соединен с выходом мажоритарного элемента с порогом 2 k .

Данный многовходовый одноразрядный сумматор можно использовать для расчета порядковых номеров битов с высоким логическим уровнем в строке данных длиной n. Но для параллельной обработки необходимо использовать n многовходовых одноразрядных сумматоров. При этом общее число сумматоров, используемых в устройстве, составляет O(n 2 ). Недостатком такого решения является существенное усложнение схемы с параллельной обработкой. При использовании последовательной обработки, при которой с использованием одного многовходового одноразрядного сумматора последовательно рассчитывается каждый порядковый номер, существенно возрастает время расчета порядковых номеров битов с высоким логическим уровнем.

Известен метод и устройство для подсчета количества бит с высоким логическим уровнем (см. патент на изобретение US 5541865, МПК G06F 7/60, G06F 007/50). Устройство, предназначенное для вычисления числа бит с высоким логическим уровнем элемента данных, включает: первый набор сумматоров с сохранением переноса, состоящий из первого, второго, третьего и четвертого сумматоров, входы которых соединены с входами устройства так, чтобы получить первую, вторую, третью и четвертую битовые части первого элемента данных соответственно, первый и второй сумматоры с сохранением переноса формируют на своих выходах первый многобитовый блок данных, а третий и четвертый сумматоры с сохранением переноса формируют на своих выходах второй многобитовый блок данных; второй набор сумматоров, состоящий из пятого и шестого сумматоров с сохранением переноса, входы которых соединены так, чтобы получить первый и второй многобитовые блоки данных соответственно, пятый и шестой сумматоры с сохранением переноса формируют на своих выходах третий многобитовый блок данных; седьмой сумматор с сохранением переноса, входы которого соединены так, чтобы получить третий многобитовый блок выходных данных, который формирует на своих выходах четвертый многобитовый блок данных; полный сумматор, входы которого соединены так, чтобы получить четвертый многобитовый блок данных, который формирует на своих выходах количество бит с высоким логическим уровнем. Каждый сумматор с сохранением переноса представляет собой 4-2 сумматор с сохранением переноса. Полный сумматор представляет собой четырехбитовый полный сумматор.

Данное устройство можно использовать для расчета порядковых номеров битов с высоким логическим уровнем в строке данных длиной n. Но для параллельной обработки необходимо использовать n устройств подсчета количества бит с высоким логическим уровнем, при этом общее число используемых сумматоров составляет O(n 2 ). Недостатком такого решения является существенное усложнение схемы с параллельной обработкой. При использовании последовательной обработки существенно возрастает время расчета порядковых номеров битов с высоким логическим уровнем.

Известно устройство для расчета количества бит с высоким логическим уровнем (см. патент на изобретение US 6754685, МПК G06F 5/01, G06F 7/60, G06F 007/00). Устройство выполняет функцию расчета количества бит с высоким логическим уровнем входной строки данных и функцию сдвига данных. Метод, положенный в основу работы устройства, обеспечивает баланс между нагрузкой счетчиков числа бит с высоким логическим уровнем и схем сдвига данных. Это приводит к увеличению скорости выполнения операции. Устройство имеет входы для битов первого вектора, второго вектора, средства для вычисления числа бит с высоким логическим уровнем первого вектора, средства для осуществления операции сдвига множества бит второго вектора на основе результатов расчета числа бит с высоким логическим уровнем первого вектора, средств для формирования третьего вектора, получающегося на основе операции сдвига. Устройство состоит из множества динамических уровней, за которыми следуют статические уровни. На динамических уровнях используются динамические узлы, которые вычисляют величины, зависящие от отдельных бит указателя и разреженного вектора. Устройство расширяется путем повторения базовой схемы, поэтому оно может быть изменено в соответствии с размером указателя и разреженного вектора.

Данное устройство можно использовать для расчета порядковых номеров битов с высоким логическим уровнем в строке данных длиной n. Но для параллельной обработки необходимо использовать n устройств подсчета количества бит с высоким логическим уровнем, при этом аппаратурная сложность устройства составляет O(n 2 ). Недостатком такого решения является существенное усложнение схемы с параллельной обработкой. При использовании последовательной обработки существенно возрастает время расчета порядковых номеров битов с высоким логическим уровнем.

Известно устройство и метод для расчета количества бит с высоким логическим уровнем (см. патент на изобретение US 5717616 США, МПК G06F 7/60, G06F 017/00). Устройство предназначено для вычисления числа бит с высоким логическим уровнем в строках большой длины. При этом вся строка разделяется более мелкие части и для каждой из частей рассчитывается число бит с высоким логическим уровнем. Для ускорения выполнения операции используются сумматоры с сохранением переноса. Устройство состоит из регистра данных, содержащего строку битов, в которой рассчитывается число битов с высоким логическим уровнем, множества полных сумматоров, каждый из которых имеет выход и суммирует биты с высоким логическим уровнем из уникального набора битов из регистра данных, множества сумматоров с сохранением переноса, каждый из которых имеет выход, и суммирует биты с высоким логическим уровнем из уникального набора битов из аккумулирующего регистра. Каждый из сумматоров с сохранением переноса формирует уникальный набор выходных данных в регистре назначения, где регистр назначения хранит количество бит с высоким логическим уровнем из подмножества бит регистра данных и группу бит из аккумулирующего регистра в формате суммы с сохранением переноса. Множество полных сумматоров образуют иерархическую структуру так, что первый уровень сумматоров рассчитывает число бит с высоким логическим уровнем, хранящихся в регистре данных. Входы полных сумматоров второго уровня соединены с выходами сумматоров первого уровня так, что каждый из сумматоров второго уровня складывает результаты на выходах двух сумматоров первого уровня, причем каждый из выходов сумматора первого уровня соединен с одним входом сумматора второго уровня. Число полных сумматоров первого уровня составляет половину от числа бит в регистре данных, число полных сумматоров на втором уровне составляет четверть от числа бит в регистре данных. Сумматоры с сохранением переноса суммируют одинаковое количество бит. Роль регистра назначения и аккумулирующего регистра выполняет один и тот же регистр.

Данное устройство можно использовать для расчета порядковых номеров битов с высоким логическим уровнем в строке данных длиной n. Но для параллельной обработки необходимо использовать n устройств подсчета количества бит с высоким логическим уровнем, при этом общее число используемых сумматоров составляет O(n 2 ). Недостатком такого решения является существенное усложнение схемы с параллельной обработкой. При использовании последовательной обработки существенно возрастает время расчета порядковых номеров битов с высоким логическим уровнем.

Задачей настоящего решения является разработка быстродействующего устройства расчета порядковых номеров битов и общего числа бит с высоким логическим уровнем в строке данных длиной n, при этом число используемых сумматоров должно быть более O(nlog 2 n).

Техническим результатом является обеспечение задержки расчета порядковых номеров битов и общего числа бит с высоким логическим уровнем не более t 3 log 2 n, где t 3 - задержка сумматора с сохранением переноса, при этом число используемых в устройстве сумматоров составляет nlog 2 n.

Поставленная задача достигается тем, что быстродействующее устройство расчета порядковых номеров битов с высоким логическим уровнем в строке данных длиной

n=2 k бит, где k - положительное целое число, согласно изобретению содержит n бинарных входов битов входной строки данных, n выходов порядковых номеров битов с высоким логическим уровнем, выход POPCNT количества битов с высоким логическим уровнем, n элементов логического умножения , каждый из которых имеет выход Y, соединеный с выходом Q j , первый вход X1 и второй бинарный вход Х2, иерархические вычислительные уровни , каждый из которых имеет 2 m входов D i и 2 m выходов , причем каждый вычислительный уровень состоит из первого и второго вычислительных уровней L m-1 и 2 m-1 сумматоров , имеющих первый А и второй В входы и выход С, каждый вход уровня L m соединен с входом D i первого вычислительного уровня L m-1 , каждый вход D q , где q=i+2 m-1 , уровня L m соединен с входом D i второго уровня L m-1 , каждый выход S i первого уровня L m-1 соединен с выходом S i уровня L m , выход S p , где p=2 m-1 , первого уровня L m-1 дополнительно соединен со вторыми входами В сумматоров , каждый выход S i второго уровня L m-1 соединен с первым входом А сумматора SM i,m , каждый выход С сумматора SM i,m соединен с выходом S q , где q=i+2 m-1 , уровня L m , a каждый вычислительный уровень L 1 состоит из сумматора SM 11 , имеющего первый А и второй В входы и выход С, причем первый вход А сумматора соединен с входом D 1 и выходом S 1 , второй вход В сумматора соединен с входом D 2 , выход С сумматора соединен с выходом S 2 , каждый вход вычислительного уровня L k соединен с входом устройства DS j , каждый выход уровня L k соединен с первым входом X1 элемента И j , выход S n уровня L k дополнительно соединен с выходом POPCNT устройства, каждый вход D j уровня L k дополнительно соединен со вторым бинарным входом Х2 элемента И j .

Изобретение поясняется чертежами, где на фиг.1 приведена схема устройства расчета порядковых номеров битов с высоким логическим уровнем в строке данных длиной n=8, на фиг.2 приведена схема вычислительного уровня L 1 , на фиг.3 приведена схема вычислительного уровня L 2 , на фиг.4 приведена структурно-функциональная схема вычислительного уровня L 3 устройства, на фиг.5 приведена диаграмма орграфа матрицы сумматоров устройства для случая n=16, где

SM 11 -SM 43 сумматоры;

А, В - первый и второй входы сумматора;

С - выход сумматора;

L 1 , L 2 , L 3 , - вычислительные уровни;

D 1 , D 2 - входы вычислительного уровня L 1 ;

D 1 -D 4 - входы вычислительного уровня L 2 ;

D 1 -D 8 - входы вычислительного уровня L 3 ;

D 1 -D 16 - входы вычислительного уровня L 4 ;

S 1 ,S 2 - выходы результатов суммирования вычислительного уровня L 1 ;

S 1 -S 4 - выходы результатов суммирования вычислительного уровня L 2 ;

S 1 -S 8 - выходы результатов суммирования вычислительного уровня L 3 ,

S 1 -S 16 - выходы результатов суммирования вычислительного уровня L 4 ;

DS 1 -DS 8 - бинарные входы битов входной строки данных устройства;

Q 1 -Q 8 - выходы значений порядковых номеров битов с высоким логическим уровнем;

POPCNT - выход количества битов с высоким логическим уровнем;

И 1 -И 8 - логические элементы И;

X1 - первый вход логического элемента И;

Х2 - второй бинарный вход логического элемента И;

Y - выход логического элемента И.

В общем случае предлагаемое устройство имеет n бинарных входов DS 1 -DS n для получения битов входной строки данных, n выходов Q 1 -Q n результатов расчета порядковых номеров битов с высоким логическим уровнем, выход POPCNT результатов расчета количества бит с высоким логическим уровнем. Устройство содержит сумматоры SM i,j , имеющие первый А и второй В входы для подачи суммируемых величин и выход С результатов суммирования чисел, подаваемых на входы А и В. Сумматоры SM i,j образуют матрицу с k=log 2 n стадиями суммирования и n линиями (фиг.5), причем индекс i, указывающий номер сумматора, на стадии суммирования, меняется от 1 до 2 k-1 , а индекс j, указывающий номер стадии суммирования, меняется от 1 до k. На каждой стадии суммирования расположено n/2 сумматоров. Устройство также содержит n элементов логического умножения И 1 , И 2 , И n , каждый из которых имеет выход Y, первый вход X1 и второй бинарный вход Х2, при этом число на выходе Y равно числу на входе XI, если на вход Х2 подается сигнал с высоким логическим уровенем, если на вход Х2 подается сигнал с низким логическим уровнем, то на выходе Y образуется код числа, равного нулю.

Ниже приведены два способа описания соединений сумматоров.

Для описания первого способа рассматривается матрица с числом линий n и числом стадий суммирования (столбцов) k=log 2 n.

Устройство содержит nk/2 сумматоров, которые располагаются в матрице приведенным ниже способом, при этом на каждой стадии суммирования находится n/2 сумматоров. Расположение сумматоров иллюстрируется диаграммой орграфа для случая n=16, k=4, представленной на фиг.5. Во всех вершинах, кроме висячих, определяющих входы и выходы матрицы, расположены сумматоры. Входы D 1 -D 16 матрицы соединены с соответстующими входами DS 1 -DS 16 устройства. Матрица имеет выходы S 1 -S 16 . Каждый выход матрицы соединен с входом X1 элемента логического умножения И i . На фиг.5 представлены 4 стадии суммирования j=1, j=2, j=3, j=4. Каждая вершина орграфа, в которой расположен сумматор, имеет две входящие дуги и одну или несколько исходящих дуг. Две входящие дуги определяют соединения первого А и второго В входов сумматора. Исходящие дуги определяют соединения выхода сумматора.

Сумматоры первой стадии расположены на четных линиях с номерами 2i, . Сумматоры второй стадии расположены на линиях с номерами 4i и . Сумматоры третьей стадии расположены на линиях с номерами 8i, 8i-1, 8i-2, . В общем случае сумматоры стадии расположены на линиях с номерами Каждый вход соединен с входом A первого, ближайшего к входу DS i , сумматора, расположенного на линии i, если такого сумматора нет, вход DS i соединен с выходом S i . Выход С каждого сумматора, расположенного на линии и стадии соединен с входом А сумматора следующей за j стадии, расположенного на линии i, причем если на линии i нет ни одного сумматора на стадиях с номером, большим j, то выход С соединен с выходом S i .

Каждый вход матрицы дополнительно соединен с входом В сумматора МS i,1 , расположенного на линии 2i первой стадии. Выход С каждого сумматора MS i,1 , расположенного на линии первой стадии дополнительно соединен с входами В двух сумматоров, расположенных на второй стадии, на линиях с номерами 4i и . Выход С каждого сумматора, расположенного на линии второй стадии дополнительно соединен с входами В четырех сумматоров, расположенных на четырех линиях с номерами 8i, 8i-1, 8i-2, третьей стадии. В общем случае, выход С каждого сумматора стадии расположенного на линии с номером дополнительно соединен с входами В 2 j сумматоров, расположенных на линиях с номерами стадии j+1.

Описанная выше матрица с числом линий n и числом стадий суммирования k=log 2 n, имеющая входы D 1 -D n и выходы S 1 -S n представляет собой вычислительный уровень L k c входами D 1 -D n и выходами S 1 -S n . Альтернативный способ построения уровня L k и соединения входов D 1 -D n и входов S 1 -S n приведен далее.

Согласно второму способу для описания соединений сумматоры SM i,j удобно сгруппировать в вычислительные уровни . Некоторые вычислительные уровни L 1 , L 2 , L 3 выделены на диаграмме орграфа, представленной на фиг.5. Каждый уровень L m имеет r=2 m входов результатов вычислений D 1 , D 2 , ,D r и r выходов результатов вычислений S 1 , S 2 , ,S r . При этом, как показано на фиг.2, вычислительный уровень L 1 состоит из сумматора SM 11 , первый вход А которого соединен с входом D 1 и с выходом S 1 , второй вход В соединен с входом D 2 , а выход С соединен с выходом S 2 .

На фиг.3 представлен вычислительный уровень L 2 . Он состоит из первого и второго уровней L 1 и двух сумматоров SM 12 и SM 22 . Входы D 1 -D 4 уровня L 2 образованы входами D 1 ,D 2 уровней L 1 . При этом вход D 1 уровня L 2 соединен с входом D 1 первого уровня L 1 , вход D 2 уровня L 2 соединен с входом D 2 первого уровня L 1 , вход D 3 , уровня L 2 соединен с входом D 1 второго уровня L 1 , вход D 4 уровня L 2 соединен с входом D 2 второго уровня L 1 . Выход S 1 уровня L 2 соединен с выходом S 1 первого уровня L 1 , выход S 2 уровня L 2 соединен с выходом S 2 первого уровня L 1 , выход S 3 уровня L 2 соединен с выходом С первого сумматора SM 12 , а выход S 4 уровня L 2 соединен с выходом С второго сумматора SM 22 . При этом выход S 2 первого уровня L 1 дополнительно соединен с входом В первого сумматора SM 12 и с входом В второго сумматора SM 22 , выход S 1 второго уровня L 1 соединен с входом А первого сумматора SM 12 , выход S 2 второго уровня L 1 соединен с входом А второго сумматора SM 22 .

На фиг.1 представлено устройство для расчета порядковых номеров битов с высоким логическим уровнем для случая n=8. Устройство содержит четыре вычислительных уровня L 1 , два вычислительных уровня L 2 , один вычислительный уровень L 3 . Причем уровни L 1 находятся внутри уровней L 2 и не изображены на фиг.1. Устройство также содержит элементы логического умножения И 1 -И 8 . Выходы уровня L 3 соединены через элементы логического умножения с выходами устройства. Уровень L 3 включает первый и второй уровни L 2 и четыре сумматора SM 13 , SM 23 , SM 33 , SM 43 . Входы D 1 -D 4 уровня L 3 образованы входами D 1 -D 4 первого уровня L 2 . Входы D 5 -D 8 уровня L 3 образованы входами D 1 -D 4 , второго уровня L 2 . Выходы S 1 -S 4 первого уровня L 2 образуют выходы S 1 -S 4 уровня L 3 и соединены с первыми входами X1 элементов логического умножения И 1 -И 4 . Выходы С сумматоров SM 13 , SM 23 , SM 33 , SM 43 уровня L 3 образуют выходы S 5 -S 8 и соединены с первыми входами элементов логического умножения И 5 -И 8 . Вторые бинарные входы Х2 элементов логического умножения И 1 -И 8 соединены с входами устройства D 1 -D 8 . Выход S 4 первого уровня L 2 , входящего в состав уровня L 3 , дополнительно соединен с входами В сумматоров SM 13 , SM 23 , SM 33 , SM 43 . Выход POPCNT устройства соединен с выходом С сумматора SM 43 .

В общем случае устройство для расчета порядковых номеров битов с высоким логическим уровнем в бинарной строке данных длиной n=2 k , где k - положительное целое число, имеет n бинарных входов DS 1 ,DS 2 , ,DS n битов входной строки данных, n выходов Q 1 ,Q 2 , ,Q n порядковых номеров битов с высоким логическим уровнем, выход POPCNT количества битов с высоким логическим уровнем. Устройство содержит 2 k-1 вычислительных уровней L 1 , 2 k-2 вычислительных уровней L 2 , 2 k-3 вычислительных уровней L 3 , один вычислительный уровень L k . В общем случае устройство содержит 2 k-m вычислительных уровней . Каждый вычислительный уровень состоит из первого и второго вычислительных уровней L m-1 и 2 m-1 сумматоров , имеющих первый А и второй В входы для подачи суммируемых чисел и выход С результатов суммирования чисел на входах А и В. Каждый вход D i уровня L m образован входом D i первого вычислительного уровня L m-1 , каждый вход D q , где q=i+2 m-1 , уровня L m образован входом D i второго уровня L m-1 . Каждый выход S i первого уровня L m-1 образует выход S i уровня L m , выход S p , где p=2 m-1 , первого уровня L m-1 дополнительно соединен со вторыми входами В сумматоров SM i,m . Каждый выход S i второго уровня L m-1 соединен с первым входом А сумматора SM i,m , каждый выход С сумматора SM i,m образует выход S q , где q=i+2 m-1 , уровня L m . Вычислительный уровень L 1 имеет бинарные входы D 1 ,D 2 , выходы S 1 ,S 2 и состоит из сумматора SM 11 , имеющего первый А и второй В входы для подачи суммируемых чисел и выход С результатов суммировния чисел на входах А и В, причем первый вход А сумматора соединен с входом D 1 и выходом S 1 , второй вход В сумматора соединен с входом D 2 , выход С сумматора соединен с выходом S 2 . Уровень L k имеет n бинарных входов D 1 ,D 2 , ,D n , образующих входы устройства DS 1 ,DS 2 , ,DS n , n выходов S 1 ,S 2 ,S n результатов суммирования. Устройство также содержит n элементов логического умножения И 1 ,И 2 , ,И n . Каждый элемент логического умножения имеет выход Y, первый вход X1 и второй бинарный вход Х2, при этом число на выходе Y равно числу на входе X1, если на вход Х2 подается высокий логический уровень, если на входе Х2 низкий логический уровень, то число на выходе Y равно нулю. Каждый выход результатов суммирования S i уровня L k соединен с первым входом X1 элемента логического умножения И i , где i=1, ,n. Выход результатов суммирования S n уровня L k дополнительно соединен с выходом POPCNT устройства. Каждый вход D i уровня L k соединен со вторым бинарным входом Х2 элемента логического умножения . Каждый выход Y элемента логического умножения И i образует выход Q i порядкового номера бита с высоким логическим уровнем.

Устройство работает следующим образом. На бинарные входы DS 1 , DS 2 , , DS n устройства для расчета порядковых номеров битов с высоким логическим уровнем поступают биты входной строки данных. Через время задержки t 3 на выходах Q 1 ,Q 2 , ,Q n устройства появляются значения порядковых номеров битов с высоким логическим уровнем во входной строке данных. Скорость выполнения операции зависит от типа используемых сумматоров. Если задержка сумматора не зависит от числа суммируемых разрядов и равна t 3 , задержка выполнения предлагаемым устройством расчета порядковых номеров битов с высоким логическим уровнем составляет t 3 log 2 (n)+t ЗИ , где t ЗИ - задержка на логическом элементе И, которой обычно можно пренебречь. Задержка формирования результата на выходе POPCNT равна t 3 log 2 (n).

В качестве сумматоров могут использоваться сумматоры с сохранением переноса, сумматоры с последовательным переносом, сумматоры со сквозным переносом, сумматоры с ускоренным переносом и другие сумматоры, описанные, например, в книгах Жан М. Рабаи, Ананта Чандракасан, Боривож Николич. Цифровые интегральные схемы. Методология проектирования. М.: Вильямс, 2007. 912 с., или Хамахер К., Вранешич 3., Заки С. Организация ЭВМ. 5-е изд. СПб.: Питер; Киев: Изд. группа BHV, 2003. 848 с. При расчете порядковых номеров битов с высоким логическим уровнем в n разрядной строке данных используются сумматоры входных данных с числом разрядов от 1 до log 2 n.

В качестве сумматоров SM i,j могут также использоваться сумматоры по модулю 2. В этом случае устройство определяет четность или нечетность порядкового номера бита с высоким логическим уровнем в строке данных. В общем случае, если используются сумматоры по модулю d, порядковые номера битов с высоким логическим уровнем в строке данных также будут вычисляться по модулю d.

Число разрядов суммируемых сумматорами SM i,j величин различно. У сумматора SM i,j уровня на первый вход поступает число с количеством двоичных разрядов от 1 до j, а на второй вход поступает число с количеством двоичных разрядов j.

Для ускорения работы уровни L 2 , L 3 и т.д. можно рассматривать как единые устройства, не имеющие иерархической структуры, реализующие логические функции в соответствии с приведенным описанием. При этом осуществляется оптимизация быстродействия уровней L 2 , L 3 и т.д.

Устройство можно использовать при значениях длины входной строки данных n, отличной от степени числа 2. При этом используется только часть сумматоров, на которые поступают биты строки входных данных. Неиспользуемые сумматоры можно исключить из устройства.

Таким образом, устройство выполняет расчет порядковых номеров битов с высоким логическим уровнем входной бинарной строки данных. Одновременно с расчетом порядковых номеров битов устройство осуществляет расчет количества битов с высоким логическим уровнем во входной строке данных. Устройство характеризуется высокой скоростью выполнения операции. Задержка выдачи результата составляет не более задержки известных устройств расчета количества бит с высоким логическим уровнем. Аппаратурная сложность устройства, определяемая количеством используемых сумматоров, составляет nlog 2 (n), где n - число бит входной строки данных. Это значительно меньше количества сумматоров, необходимого для расчета порядковых номеров битов с высоким логическим уровнем с использованием n устройств расчета количества бит с высоким логическим уровнем.

Формула изобретения

Быстродействующее устройство для расчета порядковых номеров битов с высоким логическим уровнем в строке данных длиной n=2 k бит, где k - положительное целое число, характеризующееся тем, что оно содержит n бинарных входов

битов входной строки данных, n выходов порядковых номеров битов с высоким логическим уровнем, выход POPCNT количества битов с высоким логическим уровнем, n элементов логического умножения , каждый из которых имеет выход Y, соединений с выходом Q j , первый вход X1 и второй бинарный вход Х2, иерархические вычислительные уровни , каждый из которых имеет 2 m входов D i и 2 m выходов , причем каждый вычислительный уровень состоит из первого и второго вычислительных уровней L m-1 и 2 m-l сумматоров , имеющих первый А и второй В входы и выход С, каждый вход уровня L m соединен с входом D i первого вычислительного уровня L m-1 , каждый вход D q , где q=i+2 m-1 , уровня L m соединен с входом D i второго уровня L m-1 , каждый выход S i первого уровня L m-1 соединен с выходом S i уровня L m , выход S p , где p=2 m-l , первого уровня L m-1 дополнительно соединен со вторыми входами В сумматоров , каждый выход S i второго уровня L m-1 соединен с первым входом А сумматора SM i,m , каждый выход С сумматора SM i,m соединен с выходом S q , где q=i+2 m-l , уровня L m , а каждый вычислительный уровень L 1 состоит из сумматора SМ 11 , имеющего первый А и второй В входы и выход С, причем первый вход А сумматора соединен с входом D 1 и выходом S 1 , второй вход В сумматора соединен с входом D 2 , выход С сумматора соединен с выходом S 2 , каждый вход вычислительного уровня L k соединен с входом устройства DS j , каждый выход уровня L k соединен с первым входом X1 элемента И j , выход S n уровня L k дополнительно соединен с выходом POPCNT устройства, каждый вход D j уровня L k дополнительно соединен со вторым бинарным входом Х2 элемента И j .

РИСУНКИ