/* Maxima tips
http://www.cymric.jp/maxima/tips.html */
rowmult(X, n, c) := block([M],
M:matrix(),
for i:1 thru length(X) do
if i=n then M:addrow(M, c*row(X, i))
else M:addrow(M, row(X, i)),
M
);
rowadd(X, n, m, c) := block([M],
M:matrix(),
for i:1 thru length(X) do
if i=n then M:addrow(M, c * row(X, m) + row(X, i))
else M:addrow(M, row(X, i)),
M
);
rowch(X, m, n) := block([M],
M:matrix(),
for i:1 thru length(X) do
if i=m then M:addrow(M, row(X, n))
else if i=n then M:addrow(M, row(X, m))
else M:addrow(M, row(X, i)),
M
);
colmult(X, n, c) := block([M],
M:matrix(),
for i:1 thru length(transpose(X)) do
if i=n then M:addcol(M, c*col(X, i))
else M:addcol(M, col(X, i)),
M
);
coladd(X, n, m, c) := block([M],
M:matrix(),
for i:1 thru length(transpose(X)) do
if i=n then M:addcol(M, c * col(X, m) + col(X, i))
else M:addcol(M, col(X, i)),
M
);
colch(X, m, n) := block([M],
M:matrix(),
for i:1 thru length(transpose(X)) do
if i=m then M:addcol(M, col(X, n))
else if i=n then M:addcol(M, col(X, m))
else M:addcol(M, col(X, i)),
M
);