Scientific journal
International Journal of Applied and fundamental research
ISSN 1996-3955
ИФ РИНЦ = 0,593

THE ALGORITHM OF RECALCULATION OF ORTHOGONAL BASES WHEN CARRYING OUT CONTROLLED DEGRADATION NON-POSITIONAL COMPUTER SYSTEM

Belov S.P. 1 Sarkisov A.B. 2 Khakhalev T.A. 2 Kalmykov I.A. 2 Ryadnov S.A. 3
1 Belgorod State national research University
2 Federal state Autonomous educational institution of higher professional education «North-Caucasus Federal University»
3 Filial Moscow state University of instrument engineering and informatics in the city of Stavropol
3615 KB
Modern parallel computing system operating in modular codes, enable maximum productivity by handling malorazlichimyh residues. The desire to provide the ultimate speed characteristics leads to complication of the device, which adversely affects the reliability of its functioning. It is known that modular codes allow to detect and correct errors arising in the computation process due to equipment failure. In addition, these codes have the potential for redistribution of computational load in case of failure of channels. The application of controlled degradation of the non-positional structure of a computing system allows you to keep her healthy state by reducing within the acceptable range of the main indicators of quality of functioning. The main limiting factor in the widespread application of the method of reconfiguration is the lack of an efficient algorithm for the recalculation of orthogonal bases. The development of the algorithm of recalculation of orthogonal bases when carrying out controlled degradation non-positional computing systems is an urgent task.
modular codes
reconfiguration of orthogonal bases
error correction
polynomial system classes deductions
algorithms recalculation of orthogonal bases

Современные параллельные вычислительные системы, функционирующие в модулярных кодах, позволяют достичь максимальной производительности за счет обработки малоразрядных остатков. Стремление обеспечить предельные скоростные характеристики приводит к усложнению устройства, что негативно влияет на надежность его функционирования. Повысить отказоустойчивость параллельных вычислительных систем можно за счет применения избыточных модулярных кодов, в том числе кодов полиномиальной системы классов вычетов (ПСКВ).

Цель исследования

Коды полиномиальной системы классов вычетов за счет введения избыточных оснований позволяют обнаруживать и корректировать ошибки, возникающие в процессе вычислений из-за отказов оборудования. Однако для устранения последствий потока отказов такая избыточность становится достаточно большой. Решить эту проблему можно за счет проведения реконфигурации, то есть перераспределения вычислительной нагрузки между работоспособными каналами. Однако, отсутствие эффективного алгоритма пересчета значений ортогональных базисов (ОБ) не позволяют широко использовать реконфигурацию непозиционных вычислительных систем. Поэтому разработка алгоритма пересчета ОБ при проведении управляемой деградации непозиционной вычислительной системы является актуальной задачей.

Материалы и методы исследования

Код полиномиальной системы классов вычетов относится к непозиционным кодам. Кодовая комбинация ПСКВ представляется в виде набора остатков полиномам A(z) по основаниям, в качестве которых выбраны неприводимые полиномы pi(z). Тогда

belov01.wmf, (1)

где belov02.wmf; i = 1, 2, …, n.

Произведение оснований кода ПСКВ позволяет определить рабочий диапазон

belov03.wmf. (2)

Проведенный анализ работ [1, 3, 6] показал, что коды ПСКВ наиболее эффективно реализуют такие модульные операции как сложение, вычитание и умножение по модулю. В этом случае для кода ПСКВ справедливо

belov04.wmf, (3)

где belov05.wmf;

belov06.wmf;

belov07.wmf – модульная операция.

Для обеспечения отказоустойчивости в код ПСКВ вводят избыточные основания, удовлетворяющие условию

belov08.wmf. (4)

В результате происходит расширение рабочего диапазона до полного диапазона

belov09.wmf. (5)

Так как ошибка переводит правильный belov10.wmf в ошибочный полином belov11.wmf, лежащий вне рабочего диапазона, то, зная местоположение искаженного полинома А*(z), можно однозначно определить модуль pi(z), по которому произошла ошибка, а также ее глубину.

Применение корректирующих кодов ПСКВ наиболее эффективно при исправлении однократных ошибок. Однако при возникновении потока отказов такой подход не может обеспечить высокую отказоустойчивость. Решением данной проблемы является использование разработанный метод реконфигурации, который позволяет сохранять работоспособное состояние при возникновении отказов за счет снижения в допустимых пределах основных показателей качества функционирования. Данный метод перераспределения вычислительной нагрузки содержит следующие этапы [4, 5]: – обнаружение ошибочного вычислительного канала ПСКВ; – отключение отказавшего канала; – перераспределение вычислительной нагрузки между оставшимися модулями ПСКВ; – для организации обратного преобразования из кода ПСКВ в позиционный код пересчитать ортогональные базисы для деградируемой системы.

Если первые три этапа управляемой деградации структуры ВС можно достаточно легко реализовать в ПСКВ, то последний этап – во многом будет определять эффективность противодействия потоку отказов. В настоящее время известно несколько алгоритмов, позволяющих осуществлять перерасчет значений ортогональных базисов при изменении количества информационных и контрольных оснований ПСКВ [5].

В работе [3] представлено устройство для вычисления сумм парных произведений, функционирующее в ПСКВ. В основу работы данного устройства положено свойство сравнимости ортогональных базисов избыточной и безизбыточной систем ПСКВ.

belov12.wmf, (6)

где Bi(z) – ортогональный базис избыточной системы ПСКВ; belov13.wmf – ортогональный базис безизбыточной ПСКВ.

Такой подход позволяет перейти к вычислению в системе ПСКВ с меньшим числом модулей. Это свойство было положено в алгоритм пересчета ортогональных базисов модулярного кода при расширении системы оснований, который приведен в работе [1]. При расширении системы оснований необходимо осуществить пересчет ортогональных базисов belov14.wmf, при заданных начальных значениях belov15.wmf системы оснований belov16.wmf. Используя свойство сравнимости ортогональных базисов, имеем

belov17.wmf (7)

где mi(z) и belov18.wmf – вес ортогонального базиса в безизбыточной и расширенной ПСКВ.

Так как значения belov19.wmf расширенной системы оснований и belov20.wmf являются взаимно простыми с основанием pi(z), то выражение (7) можно переписать в виде

belov21.wmf (8)

С учетом того, что belov22.wmf, получаем

belov23.wmf (9)

Тогда, пересчитанная величина ортогонального базиса равна

belov24.wmf (10)

Так как в (10) используются константы, то для реализации пересчета была предложена двухслойная нейронная сеть, которая показана на рис. 1.

belovR1.tif

Рис. 1. Нейронная сеть для пересчета ортогональных базисов ПСКВ

В работе [1] задача пересчета сводится к преобразованию ортогональных базисов Bi(z), где i = 1, …, k, из пространства

belov25.wmf,

в ортогональные базисы belov26.wmf где i = 1, …, k –1, определяемые диапазоном

belov27.wmf.

Уменьшение диапазона Pk(z), определяемое оставшимися рабочими основаниями pj(z) приводит к изменению значений «деградируемых» ортогональных базисов известно, что

belov28.wmf. (11)

Проведенные исследования показали, что формирование новых ортогональных базисов можно осуществить с помощью многотактовых кодовых фильтров (МКФ). Такие фильтры содержат элементы трех видов: сумматоры по модулю два на два входа и один выход, устройство задержки символов на один временной такт, устройства умножения символов на величину 0, либо 1. Пусть полиномиальная форма делителя имеет вид:

belov29.wmf, (12)

где коэффициенты qi для i = 1, …, n лежат в поле GF(p).

Тогда все операции сложения должны быть выполнены в поле GF(p), и каждая ячейка регистра сдвига должна содержать элемент из GF(p). Далее, результат на выходе сумматора, формирующего член обратной связи, нужно умножить на belov30.wmf. Наконец для каждого нулевого qi, i > n, член обратной связи должен быть умножен на – qi. Сумма полученного произведения с результатом выхода предыдущей ячейки является входным значением i-й ячейки регистра, где i меняется от 0 до n – 1. Схема МКФ показана на рис. 2.

belovR2.tif

Рис. 2. Обобщенная схема МКФ

Однако данный метод вычисления обладает недостатком – для пересчета ОБ необходимо постоянно изменять структуру вычислительного устройства, постоянно подавая на его вход ортогональные вектора Bi(z), i = 1, …, k исходной ПСКВ. Отсюда следует актуальность разработки нового алгоритма пересчета ОБ, позволяющего осуществлять управляемую деградацию ВС ПСКВ.

В разработанном алгоритме пересчета ОБ применяется свойство ортогональности, а также алгоритм вычисления ОБ. Согласно последнему для вычисления ОБ необходимо знать

belov31.wmf. (13)

Для выполнения условия ортогональности используют вес ОБ mi(z), такого, что

belov32.wmf. (14)

Исходя из последнего условия, выражение (14) можно представить как

belov33.wmf, (15)

где ml(z) – вес l-го основания ПСКВ, определяемый соотношением

belov34.wmf. (16)

Очевидно, что для выполнения условия (14) необходимо соблюдение равенства

belov35.wmf. (17)

Следовательно, для пересчета ортогональных базисов при построении деградируемого СП ПСКВ необходимо использовать значения belov36.wmf, то есть обратных величин оснований pl(z) по модулю pi(z).

Результаты исследования и их обсуждение

Пусть задан код с модулями belov37.wmf, belov38.wmf, belov39.wmf, belov40.wmf, belov41.wmf. и все основания СП ПСКВ находятся в исправном состоянии. Рассмотрим реализацию алгоритма вычисления веса ортогонального базиса B5(z). Для вычисления данного ортогонального базиса была получена константы

belov42.wmf.

Тогда остаток belov43.wmf, а индексное представление будет равно belov44.wmf. Для выполнения условие (14) определим значение индекса веса ортогонального базиса m5(z) такое, чтобы

belov45.wmf.

В этом случае индекс веса ортогонального базиса будет определяться из условия

belov46.wmf.

Таким образом, ind m5(z) = 1. Это означает, что величина веса ортогонального базиса B5(z) равна m5(z) = z. Тогда ортогональный базис составит

belov47.wmf.

Для вычисления B5(z) были использованы константы и их индексное представление:

belov48.wmf;

belov49.wmf.

belov50.wmf;

belov51.wmf.

belov52.wmf;

belov53.wmf.

belov54.wmf;

belov55.wmf.

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

belov56.wmf.

Таким образом, вес ортогонального базиса B5(z) равен belov57.wmf.

Аналогичным образом можно произвести вычисление веса ортогонального базиса при постепенной управляемой деградации структуры СП ПСКВ при потоке отказов. Очевидно, чтобы использование разработанного алгоритма индексного представления веса ОБ позволяет повысить скорость выполнения данной немоудльной операции.

Определим схемные затраты, которые будут затрачены на реализацию алгоритма пересчета ОБ, приведенные в работе [2]. В состав этого блока пересчета входят два блока памяти, (n –2) умножителя по модулю pi(z), а также один позиционный умножитель. Тогда схемные затраты на блок расчета ортогонального базиса определяются

belov58.wmf, (18)

где Vmod – схемные затраты на умножители по модулю pi(z); VLUT – схемные затраты на блок памяти LUT; Vумн – схемные затраты на позиционный сумматор.

Значит для рассмотренного кода ПСКВ данных схемные затраты на блок вычисления ОБ, использующего мультипликативный алгоритм потребуется V1 = 810 элементов.

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

belov59.wmf, (19)

где VSUmod – схемные затраты на сумматор по модулю belov60.wmf; Vрег – схемные затраты на регистр;Vпроеб – схемные затраты на преобразователь «индекс-элемент».

Проведенные исследования показали, что схемные затраты на реализацию разработанного алгоритма V2 = 681 элемент. Очевидно, что выигрыш в схемных затратах разработанного алгоритма вычисления веса ОБ составит К = V1/V2 = 1,19.

Заключение

В работе проведен анализ основных методов пересчета ортогональных базисов при постепенной деградации СП ПСКВ из-за потока отказов. Показано, что известные ранее алгоритмы имеют значительные схемные затраты. С целью решения данной проблемы был разработан алгоритм пересчета весов ОБ, на основе использования индексного представления. Проведенные исследования показали, что при использовании разработанного алгоритма пересчета веса ОБ, схемные затраты будут сокращены в 1,19 раза по сравнению с алгоритмом, использующем линейку умножителей по модулю.

Исследование выполнено при финансовой поддержке РФФИ в рамках научного проекта № 16-37-50032.