Loading AI tools
Из Википедии, свободной энциклопедии
Разре́женная/разрежённая матрица — матрица с преимущественно нулевыми элементами. В противном случае, если бо́льшая часть элементов матрицы ненулевая, матрица считается плотной или заполненной.
Эту страницу предлагается переименовать в «Разрежённая матрица». |
Эту страницу предлагается объединить со страницей Разреженный массив. |
Среди специалистов нет единства в определении того, какое именно количество ненулевых элементов делает матрицу разрежённой. Разные авторы предлагают различные варианты. Для матрицы порядка n число ненулевых элементов[1]:
Огромные разрежённые матрицы часто возникают при решении таких задач, как дифференциальное уравнение в частных производных.
При хранении и преобразовании разрежённых матриц в компьютере бывает полезно, а часто - и необходимо, использовать специальные алгоритмы и структуры данных, которые учитывают разрежённую структуру матрицы. Операции и алгоритмы, применяемые для работы с обычными, плотными матрицами, применительно к большим разрежённым матрицам работают относительно медленно и требуют значительных объёмов памяти. Однако разрежённые матрицы могут быть легко сжаты путём записи только своих ненулевых элементов, что снижает требования к компьютерной памяти.
Существует несколько способов хранения (представления) разрежённых матриц, различающихся:
Словарь по ключам (DOK — Dictionary of Keys) строится как словарь, где ключ — это пара (строка, столбец), а значение — это соответствующий строке и столбцу элемент матрицы.
Список списков (LIL — List of Lists) строится как список строк, где строка — это список узлов вида (столбец, значение).
Список координат (COO — Coordinate list) хранится список из элементов вида (строка, столбец, значение).
Сжатое хранение строкой (CSR — Compressed Sparse Row, CRS — Compressed Row Storage, Йельский формат)
Мы представляем исходную матрицу , cодержащую ненулевых значений в виде трёх массивов:
Примеры:
Пусть , тогда
массив_значений = {1, 2, 4, 2, 6}
массив_индексов_столбцов = {0, 1, 1, 1, 2}
массив_индексации_строк = {0, 2, 3, 5} -- в начале хранится 0, как запирающий элемент
Пусть , тогда
массив_значений = {1, 2, 3, 4, 1, 11}
массив_индексов_столбцов = {0, 1, 3, 2, 1, 3}
массив_индексации_строк = {0, 3, 4, 6} -- в начале хранится 0, как запирающий элемент
Для того, чтобы восстановить исходную матрицу, нужно взять некоторое значение в первом массиве и соответствующий индекс , тогда номер столбца , а номер строки находится, как наименьшее , для которого , это удобно, например, при матричном умножении на плотный вектор
void smdv(const crsm *A, double *b, const double *v) // b += Av
{
// crsm это структура {int n, int m, int nnz, double aval[], double aicol[], double airow[]};
for(int row = 0; row < n; ++row)
for(int i = A->airow[row]; i < A->airow[row+1]; ++i)
b[row] += A->aval[i] * v[A->aicol[i]];
}
Сжатое хранение столбцом (CSС — Compressed Sparse Column, CСS — Compressed Column Storage)
То же самое, что и CRS, только строки и столбцы меняются ролями — значения храним по столбцам, по второму массиву можем определить строку, после подсчётов с третьим массивом — узнаём столбцы.
Для вычислений с разрежёнными матрицами создан ряд библиотек для различных языков программирования, среди них:
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.