AmpTools
AmpParameter.h
Go to the documentation of this file.
1 #if !defined(AMPPARMETER)
2 #define AMPPARMETER
3 
4 //******************************************************************************
5 // This file is part of AmpTools, a package for performing Amplitude Analysis
6 //
7 // Copyright Trustees of Indiana University 2010, all rights reserved
8 //
9 // This software written by Matthew Shepherd, Ryan Mitchell, and
10 // Hrayr Matevosyan at Indiana University, Bloomington
11 //
12 // Redistribution and use in source and binary forms, with or without
13 // modification, are permitted provided that the following conditions
14 // are met:
15 // 1. Redistributions of source code must retain the above copyright
16 // notice and author attribution, this list of conditions and the
17 // following disclaimer.
18 // 2. Redistributions in binary form must reproduce the above copyright
19 // notice and author attribution, this list of conditions and the
20 // following disclaimer in the documentation and/or other materials
21 // provided with the distribution.
22 // 3. Neither the name of the University nor the names of its contributors
23 // may be used to endorse or promote products derived from this software
24 // without specific prior written permission.
25 //
26 // Creation of derivative forms of this software for commercial
27 // utilization may be subject to restriction; written permission may be
28 // obtained from the Trustees of Indiana University.
29 //
30 // INDIANA UNIVERSITY AND THE AUTHORS MAKE NO REPRESENTATIONS OR WARRANTIES,
31 // EXPRESS OR IMPLIED. By way of example, but not limitation, INDIANA
32 // UNIVERSITY MAKES NO REPRESENTATIONS OR WARRANTIES OF MERCANTABILITY OR
33 // FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF THIS SOFTWARE OR
34 // DOCUMENTATION WILL NOT INFRINGE ANY PATENTS, COPYRIGHTS, TRADEMARKS,
35 // OR OTHER RIGHTS. Neither Indiana University nor the authors shall be
36 // held liable for any liability with respect to any claim by the user or
37 // any other party arising from use of the program.
38 //******************************************************************************
39 
40 #include<string>
41 #include<iostream>
42 
43 using namespace std;
44 
54 class AmpParameter {
55 
56 public:
57 
73  AmpParameter( const string& arg );
74 
79 
84  AmpParameter( const AmpParameter& ampPar );
85 
89  AmpParameter& operator=( const AmpParameter& ampPar );
90 
94  string name() const { return m_name; }
95 
100  bool operator==( const AmpParameter& otherPar ) const;
101 
105  inline operator double() const { return *m_valPtr; }
106 
111  bool hasExternalPtr() const { return m_hasExternalPtr; }
112 
116  const double* valPtr() const { return m_valPtr; }
117 
128  void setExternalValue( const double* ptr );
129 
138  void setValue( double val );
139 
145  void setName( const string& name ) { m_name = name; }
146 
147 private:
148 
149  const double* m_valPtr;
150  double m_defaultValue;
151  string m_name;
152 
153  bool m_hasExternalPtr;
154 };
155 
156 #endif
157 
string name() const
Definition: AmpParameter.h:94
void setName(const string &name)
Definition: AmpParameter.h:145
bool hasExternalPtr() const
Definition: AmpParameter.h:111
const double * valPtr() const
Definition: AmpParameter.h:116