Курс 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"
- Объединение словарей в Python
- Преобразование данных в Python
- Декораторы в Python
- Бесконечные списки в Python
- Функция divmod() в Python
- Преобразование чисел в Python
- Создание лямбда-функций
- Python Менеджер контекста
- Изменение списка срезами
- Копирование объектов в Python
- Библиотека Emoji: использование смайлов в Python
- Создание словарей с defaultdict
- Потоковый ввод в Python
- Декораторы в Python
- Сравнение объектов в Python
- Частичное совпадение ввода
- Генераторы в Python
- Форматирование данных с помощью pprint
- Просмотр файла в Jupyter Noteboo
- Распаковка с оператором *
- Удаление пробелов методом translate()
- Python reversed() vs срез[::-1]
- Поиск подстроки в строке
- Метод remove() для удаления элемента из списка
- Вложенные генераторы в Python
- Профилирование данных с Pandas.
- Классы данных в Python
- Декодирование строк в Python
- Метод enumerate() в Python
- Дизассемблирование Python кода
- Различия символов в Python
- Создание списка через итерацию
- Множества и frozenset
- Метод add для класса Vector
- Изменение списка срезом
- Вычисление времени выполнения
- Bootle — простой веб-фреймворк
- Документирование функций в Python
- Преобразование числа в список цифр
- Добавление элемента в список.
- Удаление символов новой строки в Python.
- Обработка исключения UnboundLocalError
- JMESPath в Python
- Нахождение разницы между списками в Python
- Numpy: объединение массивов
- Блок else в циклах Python
- Создание итерируемых объектов
- Работа с файлами в Python
- Функция zip() в Python















