Курс Python → Метод matmul для умножения матриц
Класс Matrix в Python представляет собой специальный тип данных, который позволяет работать с матрицами и выполнять над ними различные операции. Одним из таких методов, реализованных в классе Matrix, является метод matmul(self, other), который определяет поведение оператора матричного умножения @. Для того чтобы использовать этот метод, необходимо импортировать класс Matrix из соответствующего модуля.
В методе matmul происходит проверка того, что число столбцов первой матрицы равно числу строк второй матрицы, так как это условие является необходимым для выполнения операции умножения матриц. Если данное условие не выполняется, то будет сгенерировано исключение. После проверки создается матрица, которая будет содержать результат умножения, и заполняется нулями.
class Matrix:
def __matmul__(self, other):
if len(self[0]) != len(other):
raise ValueError("Number of columns in first matrix must be equal to number of rows in second matrix")
result = [[0 for _ in range(len(other[0]))] for _ in range(len(self))]
for i in range(len(self)):
for j in range(len(other[0])):
for k in range(len(other)):
result[i][j] += self[i][k] * other[k][j]
return Matrix(result)
Далее происходит умножение матриц с использованием вложенных циклов. Каждый элемент результирующей матрицы вычисляется путем умножения соответствующих элементов из первой и второй матрицы, а затем их суммирования. Результат умножения возвращается в виде новой матрицы, содержащей произведение исходных матриц.
Использование оператора @ для умножения матриц позволяет удобно и интуитивно выполнять матричные операции в Python. При необходимости можно переопределить метод matmul для пользовательских классов, чтобы обеспечить поддержку оператора @ и работу с матрицами по определенным правилам или логике. Этот лайфхак особенно полезен при работе с линейной алгеброй и другими задачами, требующими манипулирования матрицами.
Другие уроки курса "Python"
- Оператор is в Python
- Обмен переменными в Jupyter
- Конвертация текстовых чисел с помощью Numerizer
- Настройка вывода в Numpy
- Модуль os: работа с файлами и папками
- Обмен значений переменных в Python
- Решатель судоку на Python с pygame
- Кортеж в Python: создание и использование
- Возвращение нескольких значений
- Потоковый ввод в Python
- Аргументы *args и **kwargs
- Управление контекстом выполнения
- Функции range() в Python
- Установка random seed в Python
- Обход словаря в Python
- Классы данных в Python
- Модуль os в Python: работа с файлами
- Обработка ошибок в Python
- Объединение словарей в Python
- Работа с итераторами в Python
- Округление банкира в Python
- Названия переменных
- Numpy: использование Ellipsis
- Отрицательные индексы списков в Python
- Работа с defaultdictами в Python
- Метод __float__ в Python
- Работа с эмодзи в Python
- Оператор += в Python
- Фильтрация последовательности
- Модуль pprint: улучшение вывода данных
- Работа с географическими данными в Python
- Итерация по коллекции в Python
- Извлечение чисел из текста
- Справка по импортированным модулям
- Python groupby() из itertools: работа с повторяющимися элементами
- Управление импортом в Python
- Копирование списков в Python
- Переопределение метода __or__()
- split() без разделителя
- Работа с датой и временем в Python
- Вывод переменной и строки в Python
- Создание списка дат
- Метод сравнения объектов в Python
- Форматирование строк в Python















