Matrix using tikz package
It is indeed a bit tedious. (EDIT: Fixed the first R
to become math mode, mille grazie to @Sebastiano!)
\documentclass[tikz,border=3.14mm]{standalone}
\usetikzlibrary{positioning,backgrounds,patterns}
\begin{document}
\begin{tikzpicture}
\begin{scope}[local bounding box=mat1]
\path node (R0) {$R$} foreach \X [remember=\X as \lastX (initially 0)] in
{1,...,4}
{\ifnum\X=3
node[below right=1.5em of R\lastX] (R\X) {$\phantom{R}$}
\else
node[below right=1.5em of R\lastX] (R\X) {$R$}
\fi
};
\begin{scope}[on background layer]
\draw[fill=green!70!black]
foreach \X in {0,1,2,4} {
([xshift=-1em]R\X.north west) -- ([yshift=-1em]R\X.south east)
coordinate(b\X)
|- cycle};
\draw[densely dotted] ([xshift=-1em]R3.north west) -- ([yshift=-1em]R3.south east)
coordinate(b3) |- cycle;
\end{scope}
\node[pattern=crosshatch,pattern color=purple,anchor=north west,
minimum height=6em] (F) at ([yshift=-1em]R4.south east) {$F$};
\draw[densely dotted] ([yshift=-1em]R3.south east-|R4.south east)
rectangle (F.east|-R3.north);
\foreach \X [evaluate=\X as \Y using {int(40+10*\X)}] in {0,1,2,4}
{\draw[fill=purple!\Y] ([yshift=-1em]R\X.south east-|R4.south east)
rectangle (F.east|-R\X.north);}
\end{scope}
\path (mat1.south west) -- (mat1.north east)
node[pos=0.3,font=\Large] {$0$} node[pos=0.7,font=\Large] {$0$};
\draw[thick] ([xshift=0.7em]mat1.north west) -| (mat1.south west) -- ++ (0.7em,0)
([xshift=-0.7em]mat1.north east) -| (mat1.south east) -- ++ (-0.7em,0);
%
\begin{scope}[local bounding box=mat2]
\foreach \X [remember=\X as \lastX (initially 0)] in {1,2,3}
{\path ([xshift=1em]mat1.east|-R\lastX.north) --
([xshift=2.5em]mat1.east|-b\lastX) node[midway] (a\X) {$a_{\X}$};}
\path ([xshift=1em]mat1.east|-R4.north) --
([xshift=2.5em]mat1.east|-b4) node[midway] (aM) {$a_{M}$};
\node[below=0.5em of aM] (b) {$b$};
\end{scope}
\draw[thick] ([xshift=0.5em]mat2.north west) -| (mat2.south west) -- ++
(0.5em,0)
([xshift=-0.5em]mat2.north east) -| (mat2.south east) -- ++ (-0.5em,0);
\foreach \X in {0,...,4}
{\draw (mat2.west|-b\X) -- (mat2.east|-b\X);}
%
\node[anchor=west] (eq) at (mat2.east|-mat1.center) {$=$};
%
\begin{scope}[local bounding box=mat3]
\node[pattern=dots,anchor=north west,pattern color=yellow!60!orange,
minimum height=6em] (f) at ([xshift=0.1em]eq.east|-F.north) {$f$};
\foreach \X [remember=\X as \lastX (initially 0),
evaluate=\X as \Y using {int(30*\X+10)}] in {1,2,3}
{\fill[yellow!\Y] ([xshift=0.1em]eq.east|-R\lastX.north) rectangle
(f.east|-b\lastX); }
\fill[yellow] ([xshift=0.1em]eq.east|-R4.north) rectangle
(f.east|-b4);
\draw[densely dotted] (f.center|-b2) -- (f.center|-b3);
\end{scope}
\foreach \X in {0,...,4}
{\draw (mat3.west|-b\X) -- (mat3.east|-b\X);}
\draw[thick] ([xshift=0.3em]mat3.north west) -| (mat3.south west) -- ++
(0.3em,0)
([xshift=-0.3em]mat3.north east) -| (mat3.south east) -- ++ (-0.3em,0);
\end{tikzpicture}
\end{document}
With TikZ matrix
:
\documentclass{article}
\usepackage{amsmath}
\usepackage{tikz}
\usetikzlibrary{matrix, positioning, patterns, backgrounds}
\tikzset{
every matrix/.append style={
matrix of math nodes,
nodes in empty cells,
inner sep=0pt,
outer sep=0pt,
column sep=-\pgflinewidth,
row sep=-\pgflinewidth,
},
mylargenode/.style={
text centered,
text width=30pt,
text height=20pt,
text depth=10pt,
},
mylongnode/.style={
text centered,
text width=20pt,
text height=40pt,
text depth=30pt,
},
mysmallnode/.style={
text centered,
text width=20pt,
text height=20pt,
text depth=10pt,
},
mylonglargenode/.style={
text centered,
text width=30pt,
text height=40pt,
text depth=30pt,
},
}
\begin{document}
With delimiters like in your image:
\[
\begin{tikzpicture}
\matrix[
nodes={mylargenode},
column 6/.style={nodes={mysmallnode}},
row 6/.style={nodes={mylonglargenode}}
] (A) {%
&&&&&|[draw=blue, fill=blue!10!white]| \\
&&&&&|[draw=blue, fill=blue!30!white]|\\
&&&&&|[draw=blue, fill=blue!50!white]|\\
&&&&&|[draw=blue,dotted]| \\
&&&&&|[draw=blue, fill=blue!70!white]|\\
&&&&& |[mylongnode,pattern=crosshatch,pattern color=blue!40!white, draw=blue]|\Dot{F}\\
};
\begin{scope}[on background layer]
\foreach \ind in {1,2,3,5}
{
\draw[green!70!black,fill=green!40!lightgray] (A-\ind-\ind.north west) -- (A-\ind-\ind.north east) -- (A-\ind-\ind.south east) -- cycle;
\node[anchor=north east] at (A-\ind-\ind.north east) {R};
}
\end{scope}
\draw[dotted, green!70!black] (A-4-4.north west) -- (A-4-4.north east) -- (A-4-4.south east) -- cycle;
\node[font=\Huge,shift={(-1,-2)}] at (A) {$0$};
\node[font=\Huge,shift={(1,3)}] at (A) {$0$};
\matrix[
right =of A.north east,
anchor=north west,
nodes={mysmallnode}
] (B) {%
\underline{a}_1 \\
\underline{a}_2 \\
\underline{a}_3 \\
\\
\underline{a}_M\\
\underline{b}\\
};
\foreach \ind in {1,2,...,5}{
\draw (B-\ind-1.south west) -- (B-\ind-1.south east);
}
\draw[dotted] (B-4-1.north) -- (B-4-1.south);
\matrix[
right =4em of B.north east,
anchor=north west,
nodes={draw,mysmallnode}
] (C) {%
|[fill=yellow!10!white]|\\
|[fill=yellow!30!white]|\\
|[fill=yellow!50!white]|\\
\\
|[fill=yellow!70!white]|\\
|[mylongnode, pattern=horizontal lines, pattern color=yellow!90!white]|\underline{\Dot{f}}\\
};
\path (B-4-1) -- node[midway] {$=$} (C-4-1);
\draw[dotted] (C-4-1.north) -- (C-4-1.south);
% delimiters:
\foreach \mymatr in {A,B,C}
{
\draw[very thick] ([xshift=4pt]\mymatr.north west) -- (\mymatr.north west) -- (\mymatr.south west) -- ([xshift=4pt]\mymatr.south west);
\draw[very thick] ([xshift=-4pt]\mymatr.north east) -- (\mymatr.north east) -- (\mymatr.south east) -- ([xshift=-4pt]\mymatr.south east);
}
\end{tikzpicture}
\]
Or with ordinary delimiter:
\[
\begin{tikzpicture}[
every matrix/.append style={
left delimiter={[},
right delimiter={]},
}
]
\matrix[
nodes={mylargenode},
column 6/.style={nodes={mysmallnode}},
row 6/.style={nodes={mylonglargenode}}
] (A) {%
&&&&&|[draw=blue, fill=blue!10!white]| \\
&&&&&|[draw=blue, fill=blue!30!white]|\\
&&&&&|[draw=blue, fill=blue!50!white]|\\
&&&&&|[draw=blue,dotted]| \\
&&&&&|[draw=blue, fill=blue!70!white]|\\
&&&&& |[mylongnode,pattern=crosshatch,pattern color=blue!40!white, draw=blue]|\Dot{F}\\
};
\begin{scope}[on background layer]
\foreach \ind in {1,2,3,5}
{
\draw[green!70!black,fill=green!40!lightgray] (A-\ind-\ind.north west) -- (A-\ind-\ind.north east) -- (A-\ind-\ind.south east) -- cycle;
\node[anchor=north east] at (A-\ind-\ind.north east) {R};
}
\end{scope}
\draw[dotted, green!70!black] (A-4-4.north west) -- (A-4-4.north east) -- (A-4-4.south east) -- cycle;
\node[font=\Huge,shift={(-1,-2)}] at (A) {$0$};
\node[font=\Huge,shift={(1,3)}] at (A) {$0$};
\matrix[
right =of A.north east,
anchor=north west,
nodes={mysmallnode}
] (B) {%
\underline{a}_1 \\
\underline{a}_2 \\
\underline{a}_3 \\
\\
\underline{a}_M\\
\underline{b}\\
};
\foreach \ind in {1,2,...,5}{
\draw (B-\ind-1.south west) -- (B-\ind-1.south east);
}
\draw[dotted] (B-4-1.north) -- (B-4-1.south);
\matrix[
right =4em of B.north east,
anchor=north west,
nodes={draw,mysmallnode}
] (C) {%
|[fill=yellow!10!white]|\\
|[fill=yellow!30!white]|\\
|[fill=yellow!50!white]|\\
\\
|[fill=yellow!70!white]|\\
|[mylongnode, pattern=horizontal lines, pattern color=yellow!90!white]|\underline{\Dot{f}}\\
};
\path (B-4-1) -- node[midway] {$=$} (C-4-1);
\draw[dotted] (C-4-1.north) -- (C-4-1.south);
\end{tikzpicture}
\]
\end{document}