source: ThirdParty/mpqc_open/src/lib/math/isosurf/isotest.cc@ 860145

Action_Thermostats Add_AtomRandomPerturbation Add_RotateAroundBondAction Add_SelectAtomByNameAction Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.6.0 Candidate_v1.6.1 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_ChronosMutex Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion GeometryObjects Gui_displays_atomic_force_velocity IndependentFragmentGrids_IntegrationTest JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo StoppableMakroAction Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg ThirdParty_MPQC_rebuilt_buildsystem TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes stable
Last change on this file since 860145 was 860145, checked in by Frederik Heber <heber@…>, 8 years ago

Merge commit '0b990dfaa8c6007a996d030163a25f7f5fc8a7e7' as 'ThirdParty/mpqc_open'

  • Property mode set to 100644
File size: 3.1 KB
Line 
1//
2// isotest.cc
3//
4// Copyright (C) 1996 Limit Point Systems, Inc.
5//
6// Author: Curtis Janssen <cljanss@limitpt.com>
7// Maintainer: LPS
8//
9// This file is part of the SC Toolkit.
10//
11// The SC Toolkit is free software; you can redistribute it and/or modify
12// it under the terms of the GNU Library General Public License as published by
13// the Free Software Foundation; either version 2, or (at your option)
14// any later version.
15//
16// The SC Toolkit is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU Library General Public License for more details.
20//
21// You should have received a copy of the GNU Library General Public License
22// along with the SC Toolkit; see the file COPYING.LIB. If not, write to
23// the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
24//
25// The U.S. Government is granted a limited license as per AL 91-7.
26//
27
28extern "C" {
29#include <math.h>
30#ifdef SGI
31#include <sigfpe.h>
32#endif // SGI
33}
34
35#include <util/misc/ieee.h>
36#include <util/misc/formio.h>
37
38#include <util/keyval/keyval.h>
39#include <math/isosurf/volume.h>
40#include <math/isosurf/shape.h>
41#include <math/isosurf/surf.h>
42#include <math/isosurf/isosurf.h>
43
44using namespace std;
45using namespace sc;
46
47// Force linkages:
48#ifndef __PIC__
49static ForceLink<SphereShape> fl0;
50static ForceLink<TriangulatedImplicitSurface> fl1;
51#endif
52
53main(int argc,char** argv)
54{
55 ieee_trap_errors();
56
57 // The first argument is the input filename. If it doesn't
58 // exist or is a '.', then the default ioput file is used.
59 const char *defaultinput = SRCDIR "/isotest.in";
60 const char *input;
61 if (argc == 1 || !strcmp(argv[1], ".")) input = defaultinput;
62 else input = argv[1];
63
64 const char *keyword = (argc > 2)? argv[2] : "surf";
65
66 // open keyval input
67 Ref<KeyVal> rpkv(new ParsedKeyVal(input));
68
69 Ref<TriangulatedSurface> surf;
70 surf << rpkv->describedclassvalue(keyword);
71
72 cout << scprintf("surf->flat_area() = %f\n", surf->flat_area());
73 cout << scprintf("surf->flat_volume() = %f\n", surf->flat_volume());
74
75 cout << scprintf("surf->area() = %f\n", surf->area());
76 cout << scprintf("surf->volume() = %f\n", surf->volume());
77
78 for (int order=1; order<4; order++) {
79 cout << scprintf("order = %d", order) << endl;
80 int nir = 4;
81 for (int ir=0; ir<nir; ir++) {
82 double r = double(ir)/(nir-1);
83 double s = 1.0 - r;
84 cout << scprintf(" r = %6.4f, s = %6.4f", r, s) << endl;
85 TriInterpCoefKey key(order, r, s);
86 Ref<TriInterpCoef> coef = new TriInterpCoef(key);
87 for (int i=0; i<=order; i++) {
88 for (int j=0; j+i<=order; j++) {
89 int k = order - i - j;
90 cout << scprintf(" coef(%d,%d,%d) = %12.8f",
91 i,j,k,coef->coef(i,j,k))
92 << endl;
93 }
94 }
95 }
96 }
97
98 return 0;
99}
100
101/////////////////////////////////////////////////////////////////////////////
102
103// Local Variables:
104// mode: c++
105// c-file-style: "CLJ"
106// End:
Note: See TracBrowser for help on using the repository browser.