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