Mercurial > repos > public > sbplib
annotate +blockmatrix/toMatrix.m @ 447:ae15b72c16c1 feature/grids
Change the version function to say that we are on the feature/grids branch
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Wed, 12 Apr 2017 13:24:16 +0200 |
parents | 46aa0b6a10cd |
children | c14875cf7ae6 |
rev | line source |
---|---|
206
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
1 function A = toMatrix(bm) |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
2 if ~blockmatrix.isBlockmatrix(bm) |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
3 error('blockmatrix:toMatrix:NotABlockmatrix', 'Input is not a blockmatrix'); |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
4 end |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
5 |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
6 div = blockmatrix.getDivision(bm); |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
7 n = div{1}; |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
8 m = div{2}; |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
9 |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
10 N = sum(n); |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
11 M = sum(m); |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
12 |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
13 A = sparse(N,M); |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
14 |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
15 n_ind = [0 cumsum(n)]; |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
16 m_ind = [0 cumsum(m)]; |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
17 |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
18 for i = 1:size(bm,1) |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
19 for j = 1:size(bm,2) |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
20 if isempty(bm{i,j}) |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
21 continue |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
22 end |
342 | 23 % TODO: If this ever fails for large matrices. Try cell2mat instead. |
206
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
24 A(n_ind(i)+1:n_ind(i+1),m_ind(j)+1:m_ind(j+1)) = bm{i,j}; |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
25 end |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
26 end |
50a323da7c7f
blockmatrix: Added function to convert blockmatrix to a regular matrix.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
27 end |