aboutsummaryrefslogtreecommitdiff
path: root/src/Startup.c
blob: 6384fc1d635349eefd6ad56318a1fcc103c1462c (plain)
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include "cctk.h"
#include "cctk_parameters.h"

#include "Ell_DBstructure.h"

/* At Startup, EllBase registers the elliptic equation classes for which 
   it provides solvers. Other routines, which may come up with new classes, 
   can registers the classes in their own thorns. */

void Ell_RegisterBaseEqTypes(cGH *GH) 
{
  DECLARE_CCTK_PARAMETERS

  void Ell_RegisterEq(void (*function),const char *);
  void Ell_LinConfMetricRegistry(void (*function),const char *);
  void Ell_LinMetricRegistry(void (*function),const char *);
  void Ell_LinFlatRegistry(void (*function),const char *);
  void Ell_BrBrConfMetricRegistry(void (*function),const char *);
  void Ell_PolyConfMetricRegistry(void (*function),const char *);
  
  int err;
  
  Ell_RegisterEq(Ell_LinConfMetricRegistry,"Ell_LinConfMetric");
  Ell_RegisterEq(Ell_BrBrConfMetricRegistry,"Ell_BrBrConfMetric");
  Ell_RegisterEq(Ell_PolyConfMetricRegistry,"Ell_PolyConfMetric");
  Ell_RegisterEq(Ell_LinMetricRegistry,"Ell_LinMetric");
  Ell_RegisterEq(Ell_LinFlatRegistry,"Ell_LinFlat");

  /* Register boundary SOR can handle */
  err = 

  err = Ell_CreateKey(CCTK_VARIABLE_STRING,"EllLinFlat::Bnd");
  err = Ell_CreateKey(CCTK_VARIABLE_STRING,"EllLinConfMetric::Bnd");
  err = Ell_CreateKey(CCTK_VARIABLE_STRING,"EllLinMetric::Bnd");
  
  /* Register the variables needed to use these boundaries */
  err = Ell_CreateKey(CCTK_VARIABLE_REAL, "EllLinConfMetric::Bnd::Robin::inf"); 
  err = Ell_CreateKey(CCTK_VARIABLE_INT,  "EllLinConfMetric::Bnd::Robin::falloff"); 
  err = Ell_CreateKey(CCTK_VARIABLE_REAL, "EllLinConfMetric::Bnd::Const::V0");

  /* Register the variables needed to use these boundaries */
  err = Ell_CreateKey(CCTK_VARIABLE_REAL, "EllLinMetric::Bnd::Robin::inf"); 
  err = Ell_CreateKey(CCTK_VARIABLE_INT,  "EllLinMetric::Bnd::Robin::falloff"); 
  err = Ell_CreateKey(CCTK_VARIABLE_REAL, "EllLinMetric::Bnd::Const::V0");

  /* Register the variables needed to use these boundaries */
  err = Ell_CreateKey(CCTK_VARIABLE_REAL, "EllLinFlat::Bnd::Robin::inf"); 
  err = Ell_CreateKey(CCTK_VARIABLE_INT,  "EllLinFlat::Bnd::Robin::falloff"); 
  err = Ell_CreateKey(CCTK_VARIABLE_REAL, "EllLinFlat::Bnd::Const::V0");
  
}