Обозначение индекса - Index notation

В математика и компьютерное программирование, индексное обозначение используется для указания элементов массива чисел. Формализм использования индексов зависит от предмета. В частности, существуют разные методы для ссылки на элементы списка, вектора или матрицы, в зависимости от того, пишет ли человек формальную математическую статью для публикации или когда он пишет компьютерная программа.

По математике

В математике часто бывает полезно ссылаться на элементы массива с помощью индексов. Индексы могут быть целые числа или же переменные. Массив имеет вид тензоры в общем, поскольку их можно рассматривать как многомерные массивы. Особые (и более известные) случаи: векторов (1d массивы) и матрицы (2d массивы).

Следующее является лишь введением в концепцию: индексная нотация используется более подробно в математике (особенно при представлении и манипулировании тензорные операции ). См. Основную статью для получения дополнительной информации.

Одномерные массивы (векторы)

Вектор, рассматриваемый как массив чисел, записывается как вектор строки или же вектор столбца (что бы ни использовалось, зависит от удобства или контекста):

Обозначение индекса позволяет указывать элементы массива простым написанием ая, где индекс я как известно, работает от 1 до п, из-за n-мерности.[1]Например, учитывая вектор:

тогда некоторые записи

.

Обозначения могут быть применены к векторы в математике и физике. Следующее векторное уравнение

также можно записать в терминах элементов вектора (иначе говоря, компонентов), то есть

где индексы принимают заданный диапазон значений. Это выражение представляет собой набор уравнений, по одному для каждого индекса. Если каждый вектор имеет п элементы, значение я = 1,2...п, то уравнения явно имеют вид

Следовательно, индексная нотация служит эффективным сокращением для

  1. представляя общую структуру уравнения,
  2. пока применимо к отдельным компонентам.

Двумерные массивы

Элементы матрицы А описываются двумя нижними индексами или индексами.

Для описания массивов чисел в двух или более измерениях, таких как элементы матрицы, используется более одного индекса (см. Также изображение справа);

Запись матрицы А записывается с использованием двух индексов, скажем я и j, с запятыми или без них для разделения индексов: аij или же ая, j, где первый индекс - это номер строки, а второй - номер столбца. Сопоставление также используется как обозначение для умножения; это может быть источником путаницы. Например, если

тогда некоторые записи

.

Для индексов больше 9 использование запятой может быть лучше (например, а3,12 вместо а312).

Матричные уравнения записываются аналогично векторным уравнениям, например

в терминах элементов матриц (также известных как компоненты)

для всех значений я и j. Это выражение снова представляет собой набор уравнений, по одному для каждого индекса. Если каждая из матриц имеет м ряды и п столбцы, то есть я = 1, 2, …, м и j = 1, 2, …, п, то есть мин уравнения.

Многомерные массивы

Обозначение позволяет сделать четкое обобщение на многомерные массивы элементов: тензоры. Например,

представляющий набор многих уравнений.

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

В вычислениях

В некоторых языках программирования индексная нотация - это способ адресации элементов массива. Этот метод используется, поскольку он наиболее близок к тому, как он реализован в язык ассемблера при этом адрес первого элемента используется в качестве основы, а кратное (индекс) размера элемента используется для адресации внутри массива.

Например, если массив целых чисел хранится в области памяти компьютера, начиная с ячейки памяти с адресом 3000 ( базовый адрес ), и каждое целое число занимает четыре ячейки (байта), то элементы этого массива находятся в ячейках памяти 0x3000, 0x3004, 0x3008,…, 0x3000 + 4 (п - 1) (обратите внимание на нумерация с нуля ). В общем, адрес яth элемент массива с базовый адрес б и размер элемента s является б + является.

Детали реализации

в Язык программирования C, мы можем записать это как * (основание + я) (форма указателя) или база [я] (форма индексации массива), что в точности эквивалентно, поскольку стандарт C определяет форму индексации массива как преобразование в форму указателя. По совпадению, поскольку добавление указателей является коммутативным, это позволяет использовать неясные выражения, такие как 3 [базовый] что эквивалентно база [3].[2]

Многомерные массивы

Все становится интереснее, когда мы рассматриваем массивы с более чем одним индексом, например, двумерную таблицу. У нас есть три возможности:

  • сделать двумерный массив одномерным, вычислив один индекс из двух
  • рассмотрим одномерный массив, где каждый элемент является другим одномерным массивом, то есть массивом массивов
  • использовать дополнительное хранилище для хранения массива адресов каждой строки исходного массива и хранить строки исходного массива как отдельные одномерные массивы

В C можно использовать все три метода. Когда используется первый метод, программист решает, как элементы массива располагаются в памяти компьютера, и предоставляет формулы для вычисления местоположения каждого элемента. Второй метод используется, когда количество элементов в каждой строке одинаково и известно на момент написания программы. Программист объявляет, что массив имеет, скажем, три столбца, написав, например, elementtype tablename [] [3];. Затем один обращается к конкретному элементу массива, записывая имя таблицы [первый индекс] [второй индекс]. Компилятор вычисляет общее количество ячеек памяти, занимаемых каждой строкой, использует первый индекс, чтобы найти адрес нужной строки, а затем использует второй индекс, чтобы найти адрес желаемого элемента в строке. Когда используется третий метод, программист объявляет таблицу как массив указателей, как в elementtype * tablename [];. Когда программист впоследствии указывает конкретный элемент имя таблицы [первый индекс] [второй индекс], компилятор генерирует инструкции для поиска адреса строки, указанной первым индексом, и использования этого адреса в качестве основы при вычислении адреса элемента, указанного вторым индексом.

Пример

Эта функция умножает две матрицы 3x3 с плавающей запятой вместе.

 пустота mult3x3f(плавать результат[][3], const плавать А[][3], const плавать B[][3]) {   int я, j, k;   за (я = 0; я < 3; ++я) {     за (j = 0; j < 3; ++j) {       результат[я][j] = 0;       за (k = 0; k < 3; ++k)         результат[я][j] += А[я][k] * B[k][j];     }   } }

На других языках

В других языках программирования, таких как Pascal, индексы могут начинаться с 1, поэтому индексирование в блоке памяти может быть изменено для соответствия схеме адресации start-at-1 с помощью простого линейного преобразования - в этой схеме расположение в памяти яth элемент с базовый адрес б и размер элемента s является б + (я − 1)s.

Рекомендации

  1. ^ Введение в тензорный анализ: для инженеров и ученых-прикладников, J.R. Tyldesley, Longman, 1975, ISBN  0-582-44355-5
  2. ^ Программирование на C ++, J. Hubbard, Schaum's Outlines, McGraw Hill (США), 1996, ISBN  0-07-114328-9
  • Программирование на C ++, Дж. Хаббард, Schaum's Outlines, McGraw Hill (США), 1996, ISBN  0-07-114328-9
  • Тензорное исчисление, D.C. Kay, Schaum's Outlines, McGraw Hill (США), 1988, ISBN  0-07-033484-6
  • Математические методы для физики и техники, К.Ф. Райли, М. Хобсон, С.Дж. Бенс, издательство Кембриджского университета, 2010 г., ISBN  978-0-521-86153-3

внешняя ссылка