Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Транспонирование матрицы  (Прочитано 7854 раз)
0 Пользователей и 1 Гость смотрят эту тему.
sys*.12
Новенький

ru
Offline Offline

« : 01-11-2011 12:39 » 

Доброго времени суток господа .. в общем необходимо составить программу вычисления и преобразования матрицы P=f(A,B,C), где P=f(A,B,C) – матричное выражение; A, B, C – исходные матрицы, размер и значения элементов которых выбираются произвольно.(A^T+B^2\2) - C
В общем получилось возвести в квадрат матрицу B и поделить на 2, но вот возник вопрос как транспортировать матрицу A?Помогите пожалуйста кто знает ибо в ассемблере я нуб
Вот текст:
Код: (Pascal)
program kursach;
const
maxn=10;
var
matrA,matrB,matrC:array[1..maxn,1..maxn] of shortint;
matrP,tempmatrP:array[1..maxn,1..maxn] of shortint;
i,j,k,n,m,p,f:integer;
s:shortint;
baseA,baseB,baseC,baseP:integer;
begin
write('Vvedite kolichestvo strok matrici A:');
readln(m);
write('Vvedite kolichestvo stolbcov matrici A:');
readln(p);
writeln('Vvedite elementi matrici A:');
for i:=1 to m do
for j:=1 to p do
begin
write('matrA[',i,',',j,']=');
readln(matrA[i,j]);
end;

begin
write('Vvedite kolichestvo strok matrici B:');
readln(m);
write('Vvedite kolichestvo stolbcov matrici B:');
readln(p);
writeln('Vvedite elementi matrici B:');
for i:=1 to m do
for j:=1 to p do
begin
write('matrB[',i,',',j,']=');
readln(matrB[i,j]);
end;
end;

asm
mov i,0
mov baseP,0
@@cicli:

mov j,0
@@ciclj:

mov s,0
mov k,0
mov baseB,0
@@ciclk:

mov dl,2
mov bx,baseP
mov si,j
mov al,byte ptr matrB[bx+si]
mov ah,0
imul byte ptr matrB[bx+si]
div dl

add s,al
add al,byte ptr matrB[bx+si]

mov bx,baseP
mov si,j
mov al,s
mov byte ptr matrP[bx+si],al

inc j
mov ax,p
cmp j,ax
jl @@ciclj

inc i
add baseP,maxn
mov ax, m
cmp i,ax
jl @@cicli

mov i,0
mov j,0
mov bx,i
mov si,j
mov al, byte ptr matrA[bx+si]
end;

writeln('ASM result Matrica P:');
for i:=1 to m do
begin
for j:=1 to p do
write(matrP[i,j],' ');
writeln;
end;
writeln('ASM result Matrica A:');
for i:=1 to m do
begin
for j:=1 to n do
write(matrA[i,j],' ');
writeln;
end;

end.
Записан
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #1 : 01-11-2011 13:54 » 

Цитата: sys*.12
ибо в ассемблере я нуб
Читай правила форума и учи ассемблер - для этого тебе и дана эта задача.

А к транспонированию матрицы ассемблер отношения не имеет. Напиши на Pascal транспонирование - станет очевидно, как это сделать в ассемблере.
Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
DneprSMV
Помогающий

kz
Offline Offline
Пол: Мужской

« Ответ #2 : 01-11-2011 13:57 » 

sys*.12,
"как транспоРТировать матрицу A?"  именно так ?
Матрицы у тебя объявлены как SHORTINT (2 байта),
а ассемблер использует команды с байтами (?) byte ptr matrB[bx+si]
Может таки
Код:
 ....   word ptr matrB[bx+si] 

и соответственно смещение индекса для обхода массивов должно быть 2 а не 1
Может конечно чевой не понял ..... Улыбаюсь
----------
Предчувствия меня не обманули. Паскаль не понял, с евойным SHORTINT (байтовый)
Так что все правильно.
« Последнее редактирование: 01-11-2011 20:45 от DneprSMV » Записан

"Не слушайте никаких советов, в том числе и этот" (Сократ ?)
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines