Xmipp  v3.23.11-Nereus
mpi_reconstruct_fourier_gpu.h
Go to the documentation of this file.
1 /***************************************************************************
2  *
3  * Authors: David Strelak (davidstrelak@gmail.com)
4  *
5  * Unidad de Bioinformatica of Centro Nacional de Biotecnologia , CSIC
6  *
7  * This program is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2 of the License, or
10  * (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
20  * 02111-1307 USA
21  *
22  * All comments concerning this program package may be sent to the
23  * e-mail address 'xmipp@cnb.csic.es'
24  ***************************************************************************/
25 #ifndef MPI_RECONSTRUCT_FOURIER_GPU_H_
26 #define MPI_RECONSTRUCT_FOURIER_GPU_H_
27 
28 #include <parallel/xmipp_mpi.h>
30 
31 #include <core/args.h>
32 #include <data/projection.h>
33 #include <cstring>
34 #include <cstdlib>
35 #include <core/xmipp_funcs.h>
36 #include <core/matrix2d.h>
37 #include <sys/time.h>
38 #include <iostream>
39 #include <sstream>
40 #include <fstream>
41 #include <iomanip>
42 
43 #define TAG_WORKFORWORKER 0
44 #define TAG_STOP 1
45 #define TAG_TRANSFER 2
46 #define TAG_FREEWORKER 3
47 #define TAG_SETVERBOSE 5
48 
49 //TODO (MARIANA) Please give more documentation and in a good structure e.g. @name
50 
51 
55 
57 {
58 public:
61 
62  /* constructor ------------------------------------------------------- */
63  ProgMPIRecFourierGPU(int argc, char *argv[]);
64 
65  /* constructor providing an MpiNode
66  * this is useful for using this programs from others
67  */
68  ProgMPIRecFourierGPU(const std::shared_ptr<MpiNode> &node);
69 
71  void read(int argc, char** argv);
72 
73 private:
75  int mpi_job_size;
76 
78  int threadsPerGPU;
79 
81  int gpusPerNode;
82 
84  void readParams();
85 
87  void defineParams();
88 
90  void preRun();
91 
93  void run();
94 
95 
96 };
98 //end of class MPI reconstruct fourier gpu
99 
100 #endif /* MPI_RECONSTRUCT_FOURIER_GPU_H_ */
int argc
Original command line arguments.
Definition: xmipp_program.h:86
std::shared_ptr< MpiNode > node
Definition: xmipp_mpi.h:164
const char ** argv
Definition: xmipp_program.h:87
void read(int argc, char **argv)