123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 |
- \hypertarget{classutil_1_1FileIO}{}\section{util\+:\+:File\+IO Class Reference}
- \label{classutil_1_1FileIO}\index{util\+::\+File\+IO@{util\+::\+File\+IO}}
- {\ttfamily \#include $<$File\+I\+O.\+h$>$}
- \subsection*{Static Public Member Functions}
- \begin{DoxyCompactItemize}
- \item
- static void \hyperlink{classutil_1_1FileIO_ae31b9e693316483eda89df8463ea0d0a}{Read\+C\+SV} (Vector3d \&values, const std\+::string \&file\+\_\+name, char delimiter)
- \item
- static void \hyperlink{classutil_1_1FileIO_a49f014af1e0f03d290f00049e082d9c6}{Read\+C\+SV} (Vector2d \&values, const std\+::string \&file\+\_\+name, char delimiter)
- \item
- static void \hyperlink{classutil_1_1FileIO_a6e290e22083d49619b757bfca96a51fa}{List\+Files} (const std\+::string \&folder, std\+::vector$<$ std\+::string $>$ \&file\+\_\+names, bool sort=true)
- \item
- static void \hyperlink{classutil_1_1FileIO_a5f2730a95e0801faa32e49dae9b86544}{Write\+C\+S\+V\+Matlab} (Directed\+Graph \&graph, const std\+::string \&file\+\_\+name)
- \item
- static void \hyperlink{classutil_1_1FileIO_a2833554dcdf4a04f9fe67a324b5815ff}{Write\+C\+S\+V\+Matlab} (Multi\+Predecessor\+Map \&map, Vertex \&source, Vertex \&sink, const std\+::string \&file\+\_\+name)
- \item
- static void \hyperlink{classutil_1_1FileIO_a642616eb6f07c71bd8dcb1585a532d92}{Read\+C\+SV} (Value\+Map\+Vector \&values, const std\+::string \&file\+\_\+name, char delimiter)
- \item
- static void \hyperlink{classutil_1_1FileIO_a59b96733490d7b60e4f107da84efb245}{Read\+C\+SV} (Value\+Map\+Vector \&values, const std\+::string \&header, const std\+::string \&file\+\_\+name, char delimiter)
- \item
- static void \hyperlink{classutil_1_1FileIO_a57059c9b52e86c753db5da6281cf23c6}{Write\+Tracks} (std\+::vector$<$ core\+::\+Tracklet\+Ptr $>$ \&tracks, const std\+::string \&file\+\_\+name, char delimiter)
- \item
- static void \hyperlink{classutil_1_1FileIO_a82be787051876b0e3d3c4f887c3c27ce}{Read\+Tracks} (std\+::vector$<$ core\+::\+Tracklet\+Ptr $>$ \&tracks, const std\+::string \&file\+\_\+name, char delimiter)
- \item
- static std\+::vector$<$ std\+::string $>$ \hyperlink{classutil_1_1FileIO_a925a74ff26782b8f64106579c9d54b47}{Split} (const std\+::string \&input, char delimiter)
- \end{DoxyCompactItemize}
- \subsection{Detailed Description}
- Utility class for file in-\/ and output.
- \subsection{Member Function Documentation}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!List\+Files@{List\+Files}}
- \index{List\+Files@{List\+Files}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{List\+Files(const std\+::string \&folder, std\+::vector$<$ std\+::string $>$ \&file\+\_\+names, bool sort=true)}{ListFiles(const std::string \&folder, std::vector< std::string > \&file\_names, bool sort=true)}}]{\setlength{\rightskip}{0pt plus 5cm}void util\+::\+File\+I\+O\+::\+List\+Files (
- \begin{DoxyParamCaption}
- \item[{const std\+::string \&}]{folder, }
- \item[{std\+::vector$<$ std\+::string $>$ \&}]{file\+\_\+names, }
- \item[{bool}]{sort = {\ttfamily true}}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a6e290e22083d49619b757bfca96a51fa}{}\label{classutil_1_1FileIO_a6e290e22083d49619b757bfca96a51fa}
- Lists all file names in the given folder.
- \begin{DoxyParams}{Parameters}
- {\em folder} & The folder to look into \\
- \hline
- {\em file\+\_\+names} & The name of the files in the folder \\
- \hline
- {\em sort} & True, if the files should be sorted alphabetically \\
- \hline
- \end{DoxyParams}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Read\+C\+SV@{Read\+C\+SV}}
- \index{Read\+C\+SV@{Read\+C\+SV}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Read\+C\+S\+V(\+Vector3d \&values, const std\+::string \&file\+\_\+name, char delimiter)}{ReadCSV(Vector3d \&values, const std::string \&file\_name, char delimiter)}}]{\setlength{\rightskip}{0pt plus 5cm}void util\+::\+File\+I\+O\+::\+Read\+C\+SV (
- \begin{DoxyParamCaption}
- \item[{Vector3d \&}]{values, }
- \item[{const std\+::string \&}]{file\+\_\+name, }
- \item[{char}]{delimiter}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_ae31b9e693316483eda89df8463ea0d0a}{}\label{classutil_1_1FileIO_ae31b9e693316483eda89df8463ea0d0a}
- Reads a C\+SV file and stores the values in a 3D array. The first dimension is the first value of each row, used as a index to bundle multiple rows with the same first value into a single vector. The second dimension is the row in the row bundle. The third dimension is the value in that row.
- \begin{DoxyParams}{Parameters}
- {\em values} & The 3D array of values to store the read values in \\
- \hline
- {\em file\+\_\+name} & The name of the file to read \\
- \hline
- {\em delimiter} & The value delimiter of the file \\
- \hline
- \end{DoxyParams}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Read\+C\+SV@{Read\+C\+SV}}
- \index{Read\+C\+SV@{Read\+C\+SV}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Read\+C\+S\+V(\+Vector2d \&values, const std\+::string \&file\+\_\+name, char delimiter)}{ReadCSV(Vector2d \&values, const std::string \&file\_name, char delimiter)}}]{\setlength{\rightskip}{0pt plus 5cm}void util\+::\+File\+I\+O\+::\+Read\+C\+SV (
- \begin{DoxyParamCaption}
- \item[{Vector2d \&}]{values, }
- \item[{const std\+::string \&}]{file\+\_\+name, }
- \item[{char}]{delimiter}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a49f014af1e0f03d290f00049e082d9c6}{}\label{classutil_1_1FileIO_a49f014af1e0f03d290f00049e082d9c6}
- Reads a C\+SV file and stores the values in a 2D array. The first dimension is the row and the second the value in that row.
- \begin{DoxyParams}{Parameters}
- {\em values} & The 2D array of values to store the read values in \\
- \hline
- {\em file\+\_\+name} & The name of the file to read \\
- \hline
- {\em delimiter} & The value delimiter of the file \\
- \hline
- \end{DoxyParams}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Read\+C\+SV@{Read\+C\+SV}}
- \index{Read\+C\+SV@{Read\+C\+SV}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Read\+C\+S\+V(\+Value\+Map\+Vector \&values, const std\+::string \&file\+\_\+name, char delimiter)}{ReadCSV(ValueMapVector \&values, const std::string \&file\_name, char delimiter)}}]{\setlength{\rightskip}{0pt plus 5cm}void util\+::\+File\+I\+O\+::\+Read\+C\+SV (
- \begin{DoxyParamCaption}
- \item[{Value\+Map\+Vector \&}]{values, }
- \item[{const std\+::string \&}]{file\+\_\+name, }
- \item[{char}]{delimiter}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a642616eb6f07c71bd8dcb1585a532d92}{}\label{classutil_1_1FileIO_a642616eb6f07c71bd8dcb1585a532d92}
- Reads a C\+SV file. The first line of the C\+SV file is a header specifying the keys. The values are stored with their specified key into one map per line.
- \begin{DoxyParams}{Parameters}
- {\em values} & A vector of maps to store the key-\/value pairs into \\
- \hline
- {\em file\+\_\+name} & The name of the file to read \\
- \hline
- {\em delimiter} & The value delimiter of the file \\
- \hline
- \end{DoxyParams}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Read\+C\+SV@{Read\+C\+SV}}
- \index{Read\+C\+SV@{Read\+C\+SV}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Read\+C\+S\+V(\+Value\+Map\+Vector \&values, const std\+::string \&header, const std\+::string \&file\+\_\+name, char delimiter)}{ReadCSV(ValueMapVector \&values, const std::string \&header, const std::string \&file\_name, char delimiter)}}]{\setlength{\rightskip}{0pt plus 5cm}void util\+::\+File\+I\+O\+::\+Read\+C\+SV (
- \begin{DoxyParamCaption}
- \item[{Value\+Map\+Vector \&}]{values, }
- \item[{const std\+::string \&}]{header, }
- \item[{const std\+::string \&}]{file\+\_\+name, }
- \item[{char}]{delimiter}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a59b96733490d7b60e4f107da84efb245}{}\label{classutil_1_1FileIO_a59b96733490d7b60e4f107da84efb245}
- Reads a C\+SV file. The header specifies the keys. The values are stored with their specified key into one map per line.
- \begin{DoxyParams}{Parameters}
- {\em values} & A vector of maps to store the key-\/value pairs into \\
- \hline
- {\em header} & A string containing the keys separated by the delimiter \\
- \hline
- {\em file\+\_\+name} & The name of the file to read \\
- \hline
- {\em delimiter} & The value delimiter of the file \\
- \hline
- \end{DoxyParams}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Read\+Tracks@{Read\+Tracks}}
- \index{Read\+Tracks@{Read\+Tracks}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Read\+Tracks(std\+::vector$<$ core\+::\+Tracklet\+Ptr $>$ \&tracks, const std\+::string \&file\+\_\+name, char delimiter)}{ReadTracks(std::vector< core::TrackletPtr > \&tracks, const std::string \&file\_name, char delimiter)}}]{\setlength{\rightskip}{0pt plus 5cm}static void util\+::\+File\+I\+O\+::\+Read\+Tracks (
- \begin{DoxyParamCaption}
- \item[{std\+::vector$<$ core\+::\+Tracklet\+Ptr $>$ \&}]{tracks, }
- \item[{const std\+::string \&}]{file\+\_\+name, }
- \item[{char}]{delimiter}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a82be787051876b0e3d3c4f887c3c27ce}{}\label{classutil_1_1FileIO_a82be787051876b0e3d3c4f887c3c27ce}
- Reads the tracks from the specified file.
- \begin{DoxyParams}{Parameters}
- {\em tracks} & A vector for storing the read tracks \\
- \hline
- {\em file\+\_\+name} & The path of the file to read from \\
- \hline
- {\em delimiter} & The delimiter used to separate values \\
- \hline
- \end{DoxyParams}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Split@{Split}}
- \index{Split@{Split}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Split(const std\+::string \&input, char delimiter)}{Split(const std::string \&input, char delimiter)}}]{\setlength{\rightskip}{0pt plus 5cm}std\+::vector$<$ std\+::string $>$ util\+::\+File\+I\+O\+::\+Split (
- \begin{DoxyParamCaption}
- \item[{const std\+::string \&}]{input, }
- \item[{char}]{delimiter}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a925a74ff26782b8f64106579c9d54b47}{}\label{classutil_1_1FileIO_a925a74ff26782b8f64106579c9d54b47}
- Splits the input string at the delimiter and store each part into the return vector. If there is nothing between two delimiters the part will be an empty string.
- \begin{DoxyParams}{Parameters}
- {\em input} & The string to split \\
- \hline
- {\em delimiter} & The delimiter used to split, the delimiter will not be stored \\
- \hline
- \end{DoxyParams}
- \begin{DoxyReturn}{Returns}
- A vector of parts like (for string of length n\+: \mbox{[}0,d)...(d,d)...(d,n))
- \end{DoxyReturn}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Write\+C\+S\+V\+Matlab@{Write\+C\+S\+V\+Matlab}}
- \index{Write\+C\+S\+V\+Matlab@{Write\+C\+S\+V\+Matlab}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Write\+C\+S\+V\+Matlab(\+Directed\+Graph \&graph, const std\+::string \&file\+\_\+name)}{WriteCSVMatlab(DirectedGraph \&graph, const std::string \&file\_name)}}]{\setlength{\rightskip}{0pt plus 5cm}void util\+::\+File\+I\+O\+::\+Write\+C\+S\+V\+Matlab (
- \begin{DoxyParamCaption}
- \item[{Directed\+Graph \&}]{graph, }
- \item[{const std\+::string \&}]{file\+\_\+name}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a5f2730a95e0801faa32e49dae9b86544}{}\label{classutil_1_1FileIO_a5f2730a95e0801faa32e49dae9b86544}
- Writes the specified graph into a C\+SV file with an format readable by Matlab.
- \begin{DoxyParams}{Parameters}
- {\em graph} & The graph to write \\
- \hline
- {\em file\+\_\+name} & The name of the file to write \\
- \hline
- \end{DoxyParams}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Write\+C\+S\+V\+Matlab@{Write\+C\+S\+V\+Matlab}}
- \index{Write\+C\+S\+V\+Matlab@{Write\+C\+S\+V\+Matlab}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Write\+C\+S\+V\+Matlab(\+Multi\+Predecessor\+Map \&map, Vertex \&source, Vertex \&sink, const std\+::string \&file\+\_\+name)}{WriteCSVMatlab(MultiPredecessorMap \&map, Vertex \&source, Vertex \&sink, const std::string \&file\_name)}}]{\setlength{\rightskip}{0pt plus 5cm}void util\+::\+File\+I\+O\+::\+Write\+C\+S\+V\+Matlab (
- \begin{DoxyParamCaption}
- \item[{Multi\+Predecessor\+Map \&}]{map, }
- \item[{Vertex \&}]{source, }
- \item[{Vertex \&}]{sink, }
- \item[{const std\+::string \&}]{file\+\_\+name}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a2833554dcdf4a04f9fe67a324b5815ff}{}\label{classutil_1_1FileIO_a2833554dcdf4a04f9fe67a324b5815ff}
- Writes the specified multi predecessor map into a C\+SV format readable by Matlab to display all paths in the corresponding graph.
- \begin{DoxyParams}{Parameters}
- {\em map} & The multi predecessor map to extract the paths from \\
- \hline
- {\em source} & The sink, this is the vertex where all paths begin \\
- \hline
- {\em sink} & The sink, this is the vertex where all paths end \\
- \hline
- {\em file\+\_\+name} & The name of the file to write \\
- \hline
- \end{DoxyParams}
- \index{util\+::\+File\+IO@{util\+::\+File\+IO}!Write\+Tracks@{Write\+Tracks}}
- \index{Write\+Tracks@{Write\+Tracks}!util\+::\+File\+IO@{util\+::\+File\+IO}}
- \subsubsection[{\texorpdfstring{Write\+Tracks(std\+::vector$<$ core\+::\+Tracklet\+Ptr $>$ \&tracks, const std\+::string \&file\+\_\+name, char delimiter)}{WriteTracks(std::vector< core::TrackletPtr > \&tracks, const std::string \&file\_name, char delimiter)}}]{\setlength{\rightskip}{0pt plus 5cm}void util\+::\+File\+I\+O\+::\+Write\+Tracks (
- \begin{DoxyParamCaption}
- \item[{std\+::vector$<$ core\+::\+Tracklet\+Ptr $>$ \&}]{tracks, }
- \item[{const std\+::string \&}]{file\+\_\+name, }
- \item[{char}]{delimiter}
- \end{DoxyParamCaption}
- )\hspace{0.3cm}{\ttfamily [static]}}\hypertarget{classutil_1_1FileIO_a57059c9b52e86c753db5da6281cf23c6}{}\label{classutil_1_1FileIO_a57059c9b52e86c753db5da6281cf23c6}
- Writes the given tracks to the given file.
- \begin{DoxyParams}{Parameters}
- {\em tracks} & The tracks to store \\
- \hline
- {\em file\+\_\+name} & The path to the file to store the tracks in \\
- \hline
- {\em delimiter} & The delimiter used to separate values \\
- \hline
- \end{DoxyParams}
- The documentation for this class was generated from the following files\+:\begin{DoxyCompactItemize}
- \item
- util/File\+I\+O.\+h\item
- util/File\+I\+O.\+cpp\end{DoxyCompactItemize}
|