File: main.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 (98 lines) | stat: -rw-r--r-- 2,605 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
/////////////////////////////////////////////////////////////
//                                                         //
// 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              //
//                                                         //
/////////////////////////////////////////////////////////////

// --- System includes ---
#include <string>
#include <iostream>

using std::cerr;
using std::endl;
using std::string;

// --- project includes ---
#include "DataExtractor.h"

int main(int argc,char** argv)
{
  string infilename;
  string outfilename;
  string dataname;
  int ret;
  int xdim=0, ydim=0, zdim=0;
  double gsize=0.0, srange=0.0;
  bool options_valid=true;
  bool debug_on=false;

  // process args
  int args_read=1;  
  while(args_read<argc){
    string option=string(argv[args_read]); 
    if(option=="-i"){
      if(argc>args_read){
        infilename=string(argv[args_read+1]);
        args_read+=2;
      } else {
        options_valid=false;
      }
    } else if(option=="-o"){
      if(argc>args_read){
        outfilename=string(argv[args_read+1]);
        args_read+=2;
      } else {
        options_valid=false;
      }
    } else if(option=="-strain"){
      if(argc>args_read){
        srange=atof(argv[args_read+1]);
        dataname="strain";
        args_read+=2;
      } else {
        options_valid=false;
      }
    } else if(option=="-grid"){
      if(argc>args_read+3){
        xdim=atoi(argv[args_read+1]);
        ydim=atoi(argv[args_read+2]);
        zdim=atoi(argv[args_read+3]);
        gsize=atof(argv[args_read+4]);    
        args_read+=5;
      } else {
        options_valid=false;
      }
    } else if(option=="-debug"){
      if(argc>=args_read){
        debug_on=true;
      } else {
        options_valid=false;
      }
      args_read++;
    } else {
      cerr << "Unknown option " << option << endl;
      options_valid = false;
      break;
    }
  } 

  if(options_valid){
    DataExtractor D(xdim,ydim,zdim,gsize,Vec3(0.0,0.0,0.0));
    D.read(infilename);
    D.StrainToTensorData(srange);
    D.MaxShearToScalarData();
    D.writeScalarDataVtk(outfilename,dataname);
    ret=0;
  } else {
    cerr << "Options invalid" << endl;
    ret=1;
  }

  return ret;
}