From b34e6744286c66434ee1ecd35d9aa6ba78bf476a Mon Sep 17 00:00:00 2001 From: deseilligny Date: Mon, 27 May 2024 17:52:11 +0200 Subject: [PATCH] Doc images --- MMVII/Doc/Programmer/ImagesClasses.tex | 45 ++++++++++++++++++++++++-- 1 file changed, 42 insertions(+), 3 deletions(-) diff --git a/MMVII/Doc/Programmer/ImagesClasses.tex b/MMVII/Doc/Programmer/ImagesClasses.tex index 62f7607cb3..131c02def3 100755 --- a/MMVII/Doc/Programmer/ImagesClasses.tex +++ b/MMVII/Doc/Programmer/ImagesClasses.tex @@ -267,6 +267,7 @@ \subsubsection{Generalities} + \begin{figure} \centering \includegraphics[width=6cm]{Programmer/ImagesProg/PtrIm2D.jpg} @@ -370,7 +371,7 @@ \subsection{Elementary access} %---------------------------------------------------------------------------------------- \subsection{Raw pointer and data organization} -Note also that the class export also access to raw pointer and {\tt mRawDataXD} , {\tt mRawDataLin} +Note also that the class exports also access to raw pointer and {\tt mRawDataXD} , {\tt mRawDataLin} or a specific line with {\tt GetLine}, these access can be usefull for : @@ -383,12 +384,29 @@ \subsection{Raw pointer and data organization} \end{itemize} +Regarding the data organisation for image with dimension $\geq 2$, the convention +is to access {\tt mRawData2D[y][x]} or {\tt mRawData3D[z][y][x]} . This convention +comes from the fact that in image file formats the consecutive pixel are on the same +line (vs the same column). For {\tt mRawDataLin}, the organization is the generalization +of convention of figure~\ref{fig:Ptr2D}, for example : + +\begin{equation} + mRawData3D[z][y][x] = mRawDataLin[x + y * Sz_x + z * Sz_x * Sz_y] \label{EqIm3D} +\end{equation} %---------------------------------------------------------------------------------------- -\subsection{Memory management} +\subsection{Memory managementi and {\tt cDataImXD} vs {\tt cImXD} } +For safety consideration, it is not possible to creat directly or to copy +the objects of type {\tt cDataImXD} . The way it work is : + +\begin{itemize} + \item the object that can be created are {\tt cImXD} (i.e {\tt cIm1D, cIm2D, cIm3D }) + \item the {\tt cImXD} are shared pointer to {\tt cDataImXD}, the reference to the {\tt cDataImXD} can + be extracted via the method {\tt DIm()}. +\end{itemize} %--------------------------------------------- %--------------------------------------------- @@ -397,7 +415,28 @@ \subsection{Memory management} \section{Unlimited dimension image} \label{UlimDimIm} -Classe {\tt cDataGenDimTypedIm} +\PPP propose also a class for images of any dimension. The manipulation is +certainly slower than the specialized version {\tt cDataImXD}, but can be usefull +for image of dimension $4,5 \dots 10$ for creating a prototype or when performance +is not the main issue. + +Basically for these images : + +\begin{itemize} + \item the constructor take as argument the dimension of the image (i.e. the dimension + is not contained in the type, but is a value of the object) + + \item the access to "pixels" is done via dense vector of type int ({\tt cDenseVect}) , + internaly the data is stored on a linear vector and the conversion is done via + the generalization of formula like equation \ref{EqIm3D} ; + + \item access to linear interpolation can also be done via ({\tt cDenseVect)}), by the + way it can be intrinsiqually slow (form dimension D, i.e. there $2^D$ values to access). +\end{itemize} + + + +