File: ScalarParticleDistributionMaster.cpp

package info (click to toggle)
esys-particle 2.3.5%2Bdfsg2-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 13,132 kB
  • sloc: cpp: 81,480; python: 5,872; makefile: 1,259; sh: 313; perl: 225
file content (119 lines) | stat: -rw-r--r-- 4,466 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/////////////////////////////////////////////////////////////
//                                                         //
// Copyright (c) 2003-2017 by The University of Queensland //
// Centre for Geoscience Computing                         //
// http://earth.uq.edu.au/centre-geoscience-computing      //
//                                                         //
// Primary Business: Brisbane, Queensland, Australia       //
// Licensed under the Open Software License version 3.0    //
// http://www.apache.org/licenses/LICENSE-2.0              //
//                                                         //
/////////////////////////////////////////////////////////////

#include "tml/comm/comm.h"
#include "ScalarParticleDistributionMaster.h"

/*!
  Constructor without tagging info. Set up the Master and broadcast parameters to the slaves.

  \param comm the communicator
  \param fieldname the name of the field to be saved
  \param filename the name of the file to be saved into or the base for the generation of the filenames if the saving format requires multiple files
  \param savetype the way to save data, currently supported are WINDOW and GLOBAL
  \param t0 the first timestep to be saved
  \param tend the last timestep to be saved
  \param dt_coll the intervall between timesteps for collecting data
  \param dt_save the intervall between timesteps for saving the distribution
  \param x0 minimum value of the field
  \param xmax maximum value of the field
  \param nx number of bins in the histogram
*/
ScalarParticleDistributionMaster::ScalarParticleDistributionMaster(TML_Comm* comm,const string& fieldname,const string& filename,const string& savetype,int t0,int tend,int dt_coll,int dt_save,double x0,double xmax, int nx)
  :ScalarParticleFieldMaster(comm,fieldname,filename,savetype,t0,tend,dt_coll)
{
  m_dt_write=dt_save;
  m_dist=new RealDist(x0,xmax,nx);
  m_is_global=(savetype==string("GLOBAL"));
}

/*!
  Constructor with tagging info. Set up the Master and broadcast parameters to the slaves.

  \param comm the communicator
  \param fieldname the name of the field to be saved
  \param filename the name of the file to be saved into or the base for the generation of the filenames if the saving format requires multiple files
  \param savetype the way to save data, currently supported are WINDOW and GLOBAL
  \param t0 the first timestep to be saved
  \param tend the last timestep to be saved
  \param dt_coll the intervall between timesteps for collecting data
  \param dt_save the intervall between timesteps for saving the distribution
  \param x0 minimum value of the field
  \param xmax maximum value of the field
  \param nx number of bins in the histogram
  \param tag the tag of the particles to be saved
  \param mask the mask to be applied to the tag
*/
ScalarParticleDistributionMaster::ScalarParticleDistributionMaster(TML_Comm* comm,const string& fieldname,const string& filename,const string& savetype,int t0,int tend,int dt_coll,int dt_save,double x0,double xmax, int nx,int tag, int mask)
  :ScalarParticleFieldMaster(comm,fieldname,filename,savetype,t0,tend,dt_coll,tag,mask)
{
  m_dt_write=dt_save;
  m_dist=new RealDist(x0,xmax,nx);
  m_is_global=(savetype==string("GLOBAL"));
}

/*!
  Destructor, deletes the distribution
*/
ScalarParticleDistributionMaster::~ScalarParticleDistributionMaster()
{
  if(m_dist) delete m_dist;
}

/*!
  check if collecting or writing is necessary at current timestep

  \param t the timestep
*/
bool ScalarParticleDistributionMaster::needSave(int t)
{
  bool need_collect;

  need_collect=(((t-m_t0) % m_dt)==0) && (t>=m_t0) && (t<=m_tend);
  m_is_writing_time=(((t-m_t0) % m_dt_write)==0) && (t>=m_t0) && (t<=m_tend);

  return need_collect;
}

/*!
  collect data and add into the distribution
*/
void ScalarParticleDistributionMaster::collect()
{
  // send field id to slave
  m_comm->broadcast(m_id);
 
  // get data from slave
  collectFull();

  // add into distribution
  for(map<int,double>::iterator iter=m_save_map.begin();
      iter!=m_save_map.end();
      iter++){
    m_dist->AddSample(iter->second);
  }
  // clean up
  m_save_map.erase(m_save_map.begin(),m_save_map.end());
  m_pos_map.erase(m_pos_map.begin(),m_pos_map.end());
  m_rad_map.erase(m_rad_map.begin(),m_rad_map.end());
}

/*!
  write data
*/
void ScalarParticleDistributionMaster::write()
{
  if(m_is_writing_time){
    m_dist->Write(m_file_name);
    if(!m_is_global) m_dist->Clear();
  }
}