0 / 0 / 0
Регистрация: 07.09.2022
Сообщений: 91

Перемножить две квадратные матрицы двумя способами

20.10.2022, 15:46. Показов 3501. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
как выполнить задание
Задание 1
В первой задаче вам предлагается перемножить две квадратные матрицы двумя способами -- без использования пакета ***numpy*** и с ним.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# Для генерации матриц используем фукнцию random -- она используется для генерации случайных объектов 
# функция sample создает случайную выборку. В качестве аргумента ей передается кортеж (i,j),  
# здесь i -- число строк, j -- число столбцов.
a = np.random.sample((100, 100))
b = np.random.sample((100, 100))
 
# Выведите размерность (ранг) каждой матрицы с помощью функции ndim.
# Используйте функцию shape, что она вывела?
 
# ========
# Ваш код здесь
# ========
print(a)
print(b)
 
def mult(a, b):
    """  
    a: list of "size" lists, each contains "size" floats --- первая матрица-аргумент
    b: list of "size" lists, each contains "size" floats --- вторая матрица-аргумент
    return c: list of "size" lists, each contains "size" floats --- матрица, являющаяся результатом умножения матриц a и b
    
    Функция принимает на вход две матрицы: a и b размерностью size x size
    Возвращает матрицу их произведения a * b = c 
 
    Реализуйте умножение матриц без использования функций из пакета numpy
    """
    pass
 
def np_mult(a, b):
    """  
    a: np.array[size, size]             --- первая матрица-аргумент
    b: np.array[size, size] --- вторая матрица-аргумент
    return c: np.array[size, size]       --- матрица, являющаяся результатом умножения матриц a и b
    
    Функция принимает на вход две матрицы: a и b размерностью size x size
    Возвращает матрицу их произведения a * b = c 
 
    Реализуйте умножение матриц, используя функции из пакета numpy
    """
    pass
 
%%time
# засечем время работы функции без NumPy
M1 = mult(a, b)
 
%%time
# засечем время работы функции с NumPy
M2 = np_mult(a, b)
 
# проверим корректность
assert np.allclose(np.array(M1), M2)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.10.2022, 15:46
Ответы с готовыми решениями:

Две квадратные матрицы
Заданы две квадратные матрицы А и В размера NxN. Сформировать из них прямоугольную матрицу C размером Nx2N, взяв в качестве первых N...

Помогите решить две задачки двумя способами
A4-13. Дан массив из 10 элементов (натуральные числа). Вычис-лить сумму элементов, индексы которых есть числа Фибоначчи (1, 2, 3, 5, 8). ...

Перемножить две матрицы
Задача 1 Перемножить две матрицы (3х4 и 4х5)

5
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
20.10.2022, 21:04
Цитата Сообщение от allsu Посмотреть сообщение
перемножить две квадратные матрицы двумя способами -- без использования пакета ***numpy*** и с ним
- перемножение "с использованием пакета numpy" - это хорошо сказано!

Вот умножение матриц:

Python
1
2
3
4
5
6
7
8
def mult_matr(a,b):
    n=len(a)
    c=[[0 for _ in range(n)] for _ in range(n)]
    for i in range(n):
        for j in range(n):
             for k in range(n):
                  c[i][j]=c[i][j]+a[i][k]*b[k][j]
    return c
1
5522 / 2875 / 572
Регистрация: 07.11.2019
Сообщений: 4,771
20.10.2022, 21:23
Цитата Сообщение от Catstail Посмотреть сообщение
перемножение "с использованием пакета numpy" - это хорошо сказано!
наверное, имелось ввиду, что-то подобное:
Python
1
2
def np_mult(a, b):
    return a@b
и она, примерно, на 4 порядка быстрее..
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
20.10.2022, 21:38
Цитата Сообщение от u235 Посмотреть сообщение
и она, примерно, на 4 порядка быстрее..
- не сомневаюсь. Просто я всегда в таком случае задаю вопрос: что является целью упражнения: понять алгоритм умножения матриц или запомнить, как умножать матрицы в numpy?
0
5522 / 2875 / 572
Регистрация: 07.11.2019
Сообщений: 4,771
20.10.2022, 21:47
Catstail, думаю в этом конкретном задании цель и понять или вспомнить алгоритм, и запомнить как это делать в numpy. Заодно есть проверка на тождественность результатов, что само по себе неплохо.
Чтобы понять и запомнить алгоритм лучше всего перемножать две матрицы в тетрадке, как по мне..
1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
20.10.2022, 21:48
Цитата Сообщение от u235 Посмотреть сообщение
что само по себе неплохо.
- это да.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.10.2022, 21:48
Помогаю со студенческими работами здесь

Перемножить две матрицы
надо эти две матрицы перемножить, так и не дойдёт как это сделать. int r = Convert.ToInt16(Console.ReadLine()); int Matrix...

Перемножить две матрицы
Сформировать два одномерных массива целочисленных из 10 элементов каждый, а потом сформировать матрицу MxN элементами которого являются...

Перемножить две прямоугольные матрицы
Помогите, пожалуйста, составить программу для Перемножения двух прямоугольных матриц.

Как перемножить две матрицы
в чем ошибка ? #include <conio.h> #include <stdio.h> #include <stdlib.h> #include <iostream.h> #define i 2 #define j 3 ...

Перемножить две заданные матрицы
Доброго времени. Возможно уже были подобные задачи или сами когда-то делали. 5. Задать две матрицы следующим образом. С помощью двух...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru