ArhWriter.h 2.24 KB
Newer Older
1
2
3
4
// ============================================================================
// ==                                                                        ==
// == Amdis - Adaptive multidimensional simulations                          ==
// ==                                                                        ==
5
// ==  http://www.amdis-fem.org                                              ==
6
7
// ==                                                                        ==
// ============================================================================
8
9
10
11
12
13
14
15
16
17
18
19
//
// Software License for AMDiS
//
// Copyright (c) 2010 Dresden University of Technology 
// All rights reserved.
// Authors: Simon Vey, Thomas Witkowski et al.
//
// This file is part of AMDiS
//
// See also license.opensource.txt in the distribution.


20
21
22
23
24
25
26
27
28
29

/** \file ArhWriter.h */

#ifndef AMDIS_ARH_WRITER_H
#define AMDIS_ARH_WRITER_H

#include <iostream>
#include <fstream>

#include "AMDiS_fwd.h"
30
#include "DOFVector.h"
31
32
33
34
35
36

namespace AMDiS {

  class ArhWriter
  {
  public:
37
38
39
40
    static void write(std::string filename, Mesh *mesh, 
		      DOFVector<double>* vec0 = NULL, 
		      DOFVector<double>* vec1 = NULL,
		      DOFVector<double>* vec2 = NULL);
41
42

    static void write(std::string filename, Mesh *mesh, 
43
44
		      std::vector<DOFVector<double>*> vecs,
		      bool writeParallel = true);
45
46
47
48
49
50
51
52
53
54
55
56
    
    static void writeFile(DOFVector<double>* vec0,
			  std::string filename)
    {
	write(filename, vec0->getFeSpace()->getMesh(), vec0);
    }
    
    static void writeFile(DOFVector<double>& vec0,
			  std::string filename)
    {
	write(filename, vec0.getFeSpace()->getMesh(), &vec0);
    }
57

Praetorius, Simon's avatar
Praetorius, Simon committed
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
    static void writeFile(SystemVector *vec,
			  std::string filename)
    {
      std::vector<DOFVector<double>*> vecs;
      for (int i = 0; i < vec->getSize(); i++)
	vecs.push_back(vec->getDOFVector(i));
      write(filename, vecs[0]->getFeSpace()->getMesh(), vecs);
    }

    static void writeFile(std::vector<DOFVector<double>*> vecs,
			  std::string filename)
    {
      write(filename, vecs[0]->getFeSpace()->getMesh(), vecs);
    }
    
73
74
75
  protected:
    static void writeMacroElement(std::ofstream &file, 
				  MeshStructure &code, 
76
				  std::vector<std::vector<double> >& values,
77
				  int32_t elIndex);
78
79
80
81
  };
}

#endif