Elementary matrices in Matlab
Show older comments
I am very new to MATLAB, and I am trying to create a numerical scheme to solve a differential equation. However I am having trouble implementing matrices. I was wondering if anyone can help with constructing a following NxN matrix?

I am sure there is a better way to implement, but the following works
N=10
tod=zeros(N)
for k=1:(N-1)
tod(k, k+1)=-2
end
for k=1:(N-2)
tod(k, k+2)=1
end
tod_2=zeros(N)
for k=1:(N-1)
tod_2(k, k+1)=2
end
for k=1:(N-2)
tod_2(k, k+2)=-1
end
tran=transpose(tod_2)
Final=tran+tod
Answers (3)
(EDIT to fix misread)
Here's one way:
n = 8;
z = zeros(1,n-3);
R = toeplitz([0 2 -1 z],[0 -2 1 z])
5 Comments
Steven Lord
on 2 Feb 2022
The diag and spdiags functions may also be of interest for creating these types of matrices.
Voss
on 2 Feb 2022
This answer does not produce the requested matrix.
@DGM: as Benjamin points out the requested matrix is not symmetrical, but this is very easy to achieve with a small modification to your answer:
n = 8;
v = zeros(1,n-3);
R = toeplitz([0,2,-1,v],[0,-2,1,v])
DGM
on 3 Feb 2022
Oof . I totally overlooked that.
Stephen23
on 3 Feb 2022
@DGM: add it to your answer, no one will look in these comments.
So many ways to do this. DGM showed a great way using toeplitz. But there are others. For example, you could use diag.
n = 5;
R = diag(ones(n-2,1),2) - 2*diag(ones(n-1,1),1); R = R + R'
Or use spdiags, creating the matrix directly. Since your matrix is banded, if n is at all large, then you truly want to learn to use sparse matrices.
n = 10;
R = spdiags(ones(n,1)*[1 -2 -2 1],[-2 -1 1 2],n,n);
R is now a sparse matrix, so it will offer great advantages in computing when n grows large.
spy(R)
full(R)
I could probably have used tools like meshgrid, tril and triu.
1 Comment
Voss
on 2 Feb 2022
This answer does not produce the requested matrix.
Here's one way you can do it (and it produces the correct matrix too):
N = 10;
R = zeros(N);
R(2:N+1:end-N) = 2;
R(3:N+1:end-2*N) = -1;
R(N+1:N+1:end-1) = -2;
R(2*N+1:N+1:end-2) = 1;
R
Categories
Find more on Creating and Concatenating Matrices in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!