LCOV - code coverage report
Current view: top level - src/Model/Interface/GB - Read.H (source / functions) Coverage Total Hit
Test: coverage_merged.info Lines: 0.0 % 17 0
Test Date: 2025-04-03 04:02:21 Functions: 0.0 % 6 0

            Line data    Source code
       1              : #ifndef MODEL_INTERFACE_GB_READ_H
       2              : #define MODEL_INTERFACE_GB_READ_H
       3              : 
       4              : #include <iostream>
       5              : #include <fstream>
       6              : #include <vector>
       7              : 
       8              : #include "AMReX.H"
       9              : #include "GB.H"
      10              : 
      11              : #include "Numeric/Interpolator/Linear.H"
      12              : 
      13              : #define PI 3.14159265 
      14              : 
      15              : namespace Model
      16              : {
      17              : namespace Interface
      18              : {
      19              : namespace GB
      20              : {
      21              : /// Reads the data from a file and computes energies and its derivates
      22              : ///
      23              : class Read : public GB
      24              : {
      25              : public:
      26              :     static constexpr const char* name = "read";
      27              : 
      28              : 
      29              :     /// \brief Read in data
      30              :     ///
      31              :     /// Reads the data from a file and abort if it is not possible to open the file or if the range of thetas do not give a range between 0 and 2pi. It also computes the derivatives of the energy and stores them in vectors that will be used in W, DW, and DDW
      32              :     ///
      33              :     /// \f[ \int_0^1x^2dx = \frac{1}{3} \f]
      34              :     ///
      35              :     Read() {}
      36              :     Read(IO::ParmParse &pp) {pp_queryclass(*this);}
      37            0 :     Read(IO::ParmParse &pp, std::string name) {pp_queryclass(name,*this);}
      38              :     Read(std::string filename)
      39              :     {
      40              :         Define(filename);
      41              :     }
      42              : 
      43            0 :     void Define(std::string filename)
      44              :     {
      45            0 :         m_w   = Numeric::Interpolator::Linear<Set::Scalar>::Read(filename,0);
      46            0 :         m_dw  = Numeric::Interpolator::Linear<Set::Scalar>::Read(filename,1);
      47            0 :         m_ddw = Numeric::Interpolator::Linear<Set::Scalar>::Read(filename,2);
      48            0 :         return;
      49              :         std::ifstream input;
      50              :         input.open(filename);
      51              :         std::string line;
      52              :         std::vector<Set::Scalar> theta, thetasmall, w, dw, ddw;
      53              :         while(std::getline(input,line))
      54              :         {
      55              :             std::vector<std::string> dat = Util::String::Split(line);
      56              :             theta.push_back(std::stof(dat[0]));
      57              :             w.push_back(std::stof(dat[1]));
      58              :         }
      59              :         for (unsigned int i = 1; i < theta.size()-1; i++)
      60              :         {
      61              :             thetasmall.push_back(theta[i]);
      62              :             dw.push_back((w[i+1] - w[i-1]) / (theta[i+1] - theta[i-1]));
      63              :             ddw.push_back((w[i+1] - 2.0*w[i] + w[i-1]) / ((theta[i+1]-theta[i]) * (theta[i]-theta[i-1])));
      64              :         }
      65              :         m_w.define(w,theta);
      66              :         m_dw.define(dw,thetasmall);
      67              :         m_ddw.define(ddw,thetasmall);
      68              : 
      69              :         for (Set::Scalar t = -0.001; t < 2*Set::Constant::Pi+1.0; t+=0.001)
      70              :         {
      71              :             Set::Scalar w = m_w(t), dw = m_dw(t), ddw = m_ddw(t);
      72              :             if (std::isnan(w) || std::isnan(dw) || std::isnan(ddw) ||
      73              :                 std::isinf(w) || std::isinf(dw) || std::isinf(ddw)) 
      74              :                 Util::Abort(INFO,"Error in GB Read: t=",t," w=",w," dw=",dw," ddw=",ddw);
      75              :         }
      76              :     };
      77            0 :     Set::Scalar W(const Set::Scalar theta) const
      78              :     {
      79            0 :         return m_w(theta);
      80              :     };
      81            0 :     Set::Scalar DW(const Set::Scalar theta) const
      82              :     {
      83            0 :         return m_dw(theta);
      84              :     };
      85            0 :     Set::Scalar DDW(const Set::Scalar theta) const
      86              :     {
      87            0 :         return m_ddw(theta);
      88              :     };
      89              : 
      90              : private:
      91              :     Numeric::Interpolator::Linear<Set::Scalar> m_w, m_dw, m_ddw;
      92              :       
      93              : public:
      94            0 :     static void Parse(Read & value, IO::ParmParse & pp)
      95              :     {
      96            0 :         std::string filename;
      97            0 :         pp_query_file("filename",filename); // Filename containing GB data
      98            0 :         value.Define(filename);
      99            0 :     }
     100              :       
     101              : };
     102              : }
     103              : }
     104              : }
     105              : #endif
        

Generated by: LCOV version 2.0-1