-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathHSolveUtils.h
129 lines (109 loc) · 3.26 KB
/
HSolveUtils.h
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
/**********************************************************************
** This program is part of 'MOOSE', the
** Messaging Object Oriented Simulation Environment.
** copyright (C) 2003-2007 Upinder S. Bhalla, Niraj Dudani and NCBS
** It is made available under the terms of the
** GNU Lesser General Public License version 2.1
** See the file COPYING.LIB for the full notice.
**********************************************************************/
#ifndef _HSOLVE_UTILS_H
#define _HSOLVE_UTILS_H
class HSolveUtils
{
public:
static void initialize( Id object );
template< class T, class A >
static void set( Id id, string field, A value )
{
const Finfo* finfo = id()->cinfo()->findFinfo( "set_" + field );
assert( finfo );
const DestFinfo* dest = dynamic_cast< const DestFinfo* >( finfo );
assert( dest );
const OpFunc* op = dest->getOpFunc();
assert( op );
Qinfo* qDummy = NULL;
const double* vp = reinterpret_cast< const double* >( &value );
op->op( id.eref(), qDummy, vp );
}
template< class T, class A >
static A get( Id id, string field )
{
const Finfo* finfo = id()->cinfo()->findFinfo( "get_" + field );
assert( finfo );
const DestFinfo* dest = dynamic_cast< const DestFinfo* >( finfo );
assert( dest );
const OpFunc* op = dest->getOpFunc();
assert( op );
const GetOpFunc< T, A >* gop =
dynamic_cast< const GetOpFunc< T, A >* >( op );
const GetEpFunc< T, A >* gep =
dynamic_cast< const GetEpFunc< T, A >* >( op );
assert( gop || gep );
if ( gop )
return gop->reduceOp( id.eref() );
else // gep
return gep->reduceOp( id.eref() );
}
static int adjacent( Id compartment, vector< Id >& ret );
static int adjacent( Id compartment, Id exclude, vector< Id >& ret );
static int children( Id compartment, vector< Id >& ret );
static int channels( Id compartment, vector< Id >& ret );
static int hhchannels( Id compartment, vector< Id >& ret );
static int gates( Id channel, vector< Id >& ret, bool getOriginals = true );
static int spikegens( Id compartment, vector< Id >& ret );
static int synchans( Id compartment, vector< Id >& ret );
static int leakageChannels( Id compartment, vector< Id >& ret );
static int caTarget( Id channel, vector< Id >& ret );
static int caDepend( Id channel, vector< Id >& ret );
class Grid
{
public:
Grid( double min, double max, unsigned int divs )
:
min_( min ),
max_( max ),
divs_( divs )
{
dx_ = ( max_ - min_ ) / divs_;
}
unsigned int size();
double entry( unsigned int i );
bool operator ==( const Grid& other ) {
return
min_ == other.min_ &&
max_ == other.max_ &&
divs_ == other.divs_;
}
double min_;
double max_;
unsigned int divs_;
double dx_;
};
// Functions for accessing gates' lookup tables.
//~ static int domain(
//~ Id gate,
//~ double& min,
//~ double& max );
static void rates(
Id gate,
Grid grid,
vector< double >& A,
vector< double >& B );
//~ static int modes(
//~ Id gate,
//~ int& AMode,
//~ int& BMode );
static int targets(
Id object,
string msg,
vector< Id >& target,
string filter = "",
bool include = true );
static int targets(
Id object,
string msg,
vector< Id >& target,
const vector< string >& filter,
bool include = true );
};
#endif // _HSOLVE_UTILS_H