You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
36 lines
1.7 KiB
TeX
36 lines
1.7 KiB
TeX
3 years ago
|
\section{An overview of the code}
|
||
|
The algorithm implement is multi-threaded and written in C\texttt{++}
|
||
|
|
||
|
\subsection{Data structures}
|
||
|
In this case we are working with two simple \texttt{struct} for the classes \emph{Film} and \emph{Actor}
|
||
|
|
||
|
\lstinputlisting[language=c++]{code/struct.cpp}
|
||
|
\s
|
||
|
\nd Then we need two dictionaries build like this
|
||
|
|
||
|
\lstinputlisting[language=c++]{code/map.cpp}
|
||
|
\s
|
||
|
\nd We are considering the files \texttt{Attori.txt} and \texttt{FilmFiltrati.txt}, we don't need the relations one for now. Once that we have read this two files, we loop on each one brutally filling the two dictionaries created before. If a line is empty, we skip it. We are using a try and catch approach. Even if the good practice is to use it only for a specific error, since we are outputting everything on the terminal it makes sense to \emph{catch} any error.
|
||
|
|
||
|
\lstinputlisting[language=c++]{code/data.cpp}
|
||
|
\s
|
||
|
|
||
|
Now we can use the file \texttt{Relazioni.txt}. As before, we loop on all the elements of this file, creating the variables
|
||
|
|
||
|
\begin{itemize}
|
||
|
\item \texttt{id\textunderscore film}: index key of each movie
|
||
|
\item \texttt{id\textunderscore attore}: index key of each actor
|
||
|
\end{itemize}
|
||
|
|
||
|
\nd If they both exists, we update the list of indices of movies that the actor/actresses played in. In the same way, we updated the list of indices of actors/actresses that played in the movies with that id.
|
||
|
|
||
|
\lstinputlisting[language=c++]{code/graph.cpp}
|
||
|
\s
|
||
|
Now that we have defined how to build this graph, we have to implement the algorithm what will return the top-k central elements. \s
|
||
|
|
||
|
\nd The code can be found here: \url{https://github.com/lukefleed/imdb-graph}
|
||
|
\s
|
||
|
\begin{center}
|
||
|
\qrcode[height=1in]{https://github.com/lukefleed/imdb-graph}
|
||
|
\end{center}
|