CARLsim
5.0.0
CARLsim: a GPU-accelerated SNN simulator
interactive_spikegen.cpp
Go to the documentation of this file.
1
/* * Copyright (c) 2016 Regents of the University of California. All rights reserved.
2
*
3
* Redistribution and use in source and binary forms, with or without
4
* modification, are permitted provided that the following conditions
5
* are met:
6
*
7
* 1. Redistributions of source code must retain the above copyright
8
* notice, this list of conditions and the following disclaimer.
9
*
10
* 2. Redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution.
13
*
14
* 3. The names of its contributors may not be used to endorse or promote
15
* products derived from this software without specific prior written
16
* permission.
17
*
18
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
22
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
23
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
24
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
25
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
26
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
27
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
*
30
* *********************************************************************************************** *
31
* CARLsim
32
* created by: (MDR) Micah Richert, (JN) Jayram M. Nageswaran
33
* maintained by:
34
* (MA) Mike Avery <averym@uci.edu>
35
* (MB) Michael Beyeler <mbeyeler@uci.edu>,
36
* (KDC) Kristofor Carlson <kdcarlso@uci.edu>
37
* (TSC) Ting-Shuo Chou <tingshuc@uci.edu>
38
* (HK) Hirak J Kashyap <kashyaph@uci.edu>
39
*
40
* CARLsim v1.0: JM, MDR
41
* CARLsim v2.0/v2.1/v2.2: JM, MDR, MA, MB, KDC
42
* CARLsim3: MB, KDC, TSC
43
* CARLsim4: TSC, HK
44
* CARLsim5: HK, JX, KC
45
*
46
* CARLsim available from http://socsci.uci.edu/~jkrichma/CARLsim/
47
* Ver 12/31/2016
48
*/
49
#include <
interactive_spikegen.h
>
50
51
InteractiveSpikeGenerator::InteractiveSpikeGenerator
(
unsigned
int
numNeurons_,
unsigned
int
isi_) {
52
numNeurons = numNeurons_;
53
isi = isi_;
54
quota =
new
int
[numNeurons_];
55
for
(
unsigned
int
i = 0; i < numNeurons_; i++) quota[i] = 0;
56
}
57
58
InteractiveSpikeGenerator::~InteractiveSpikeGenerator
() {
59
delete
[] quota;
60
}
61
62
int
InteractiveSpikeGenerator::nextSpikeTime
(
CARLsim
* s,
int
grpId,
int
nid,
int
currentTime,
int
lastScheduledSpikeTime,
int
endOfTimeSlice) {
63
if
((
unsigned
int
) nid < numNeurons && quota[nid] > 0) {
64
quota[nid]--;
65
if
(lastScheduledSpikeTime + isi < (
unsigned
int
)currentTime) {
66
return
currentTime + isi;
67
}
else
{
68
return
lastScheduledSpikeTime + isi;
69
}
70
}
71
72
return
0xFFFFFFFF;
73
}
74
75
void
InteractiveSpikeGenerator::setQuota
(
int
nid_,
int
quota_) {
76
if
((
unsigned
int
)nid_ < numNeurons)
77
quota[nid_] = quota_;
78
}
79
80
void
InteractiveSpikeGenerator::setQuotaAll
(
int
quota_) {
81
for
(
unsigned
int
i = 0; i < numNeurons; i++)
82
quota[i] = quota_;
83
}
InteractiveSpikeGenerator::setQuotaAll
void setQuotaAll(int quota_)
Definition:
interactive_spikegen.cpp:80
InteractiveSpikeGenerator::nextSpikeTime
int nextSpikeTime(CARLsim *s, int grpId, int nid, int currentTime, int lastScheduledSpikeTime, int endOfTimeSlice)
controls spike generation using a callback mechanism
Definition:
interactive_spikegen.cpp:62
interactive_spikegen.h
InteractiveSpikeGenerator::InteractiveSpikeGenerator
InteractiveSpikeGenerator(unsigned int numNeurons_, unsigned int isi_)
Definition:
interactive_spikegen.cpp:51
InteractiveSpikeGenerator::setQuota
void setQuota(int nid_, int quota_)
Definition:
interactive_spikegen.cpp:75
InteractiveSpikeGenerator::~InteractiveSpikeGenerator
~InteractiveSpikeGenerator()
Definition:
interactive_spikegen.cpp:58
CARLsim
CARLsim User Interface This class provides a user interface to the public sections of CARLsimCore sou...
Definition:
carlsim.h:138
tools
spike_generators
interactive_spikegen.cpp
Generated on Sun Jul 19 2020 14:56:44 for CARLsim by
1.8.18