Classes | Public Member Functions | Protected Attributes

PLAdditiveKernelSpikeResponse Class Reference

Piecewise linear additive spike response. More...

#include <PLAdditiveKernelSpikeResponse.h>

Inheritance diagram for PLAdditiveKernelSpikeResponse:
SpikeResponse DirectEventSender EvSimObject EvSimObjectFactory

List of all members.

Classes

class  CompareResponseKernel
class  ResponseKernel

Public Member Functions

 PLAdditiveKernelSpikeResponse ()
 Default Constructor: initializes the object without a response kernel.
 PLAdditiveKernelSpikeResponse (const SharedArray< double > &resp_shape_amplitudes, const SharedArray< double > &resp_shape_timepoints)
 Constructs a spike response with given response kernel.
virtual ~PLAdditiveKernelSpikeResponse ()
 Destructor: deletes all active spike responses.
void setResponseKernel (const SharedArray< double > &resp_shape_amplitudes, const SharedArray< double > &resp_shape_timepoints)
 Sets the response kernel.
virtual unsigned numInputPorts () const
virtual unsigned numOutputPorts () const
virtual PortType getInputPortType (port_id_t p) const
virtual PortType getOutputPortType (port_id_t p) const
virtual void reset (SimContext &sim_ctxt)
virtual double getSlope ()
virtual void postAddedInNetwork (EvSimNetwork &net, EvSimObject::ID self)
virtual void eventHit (SimContext &sim_info, Time time, port_id_t port)
virtual void updateState (SimContext &sim_info, Time time, update_id_t upd_id)

Protected Attributes

std::priority_queue
< ResponseKernel
*, std::vector< ResponseKernel * >
, CompareResponseKernel
response_queue
const vector< double > * resp_shape_amplitudes
const vector< double > * resp_shape_timepoints
Time cur_time
double slope

Detailed Description

Piecewise linear additive spike response.

The shape of the spike response is defined by an array of amplitudes $(a_1,...,a_N)$ and an array of time spans $(d_1,...,d_N)$. The PSP amplitude at time $t_1 = 0$ after a spike was triggered is $a_1$, that at time $t_n = d_1 + d_2 + ... + d_{n-1}$ is $a_n$. The PSP amplitudes are linearly interpolated between $t_{n}$ and $t_{n+1}$. The PSP amplitudes between $t_{N}$ and $t_{N+1}$ are constant $a_{N}$. If a spike occurs while the response is active the overlapping spike responses are added up.

See also:
PLResetKernelSpikeResponse

Constructor & Destructor Documentation

PLAdditiveKernelSpikeResponse::PLAdditiveKernelSpikeResponse (  )  [inline]

Default Constructor: initializes the object without a response kernel.

Use the setResponseKernel() to set up the response kernel

See also:
setResponseKernel()
PLAdditiveKernelSpikeResponse::PLAdditiveKernelSpikeResponse ( const SharedArray< double > &  resp_shape_amplitudes,
const SharedArray< double > &  resp_shape_timepoints 
) [inline]

Constructs a spike response with given response kernel.

Parameters:
resp_shape_amplitudes A shared array holding the amplitude values
resp_shape_timepoints A shared array holding the time span of the given amplitude value

Member Function Documentation

void PLAdditiveKernelSpikeResponse::setResponseKernel ( const SharedArray< double > &  resp_shape_amplitudes,
const SharedArray< double > &  resp_shape_timepoints 
) [inline]

Sets the response kernel.

Parameters:
resp_shape_amplitudes A shared array holding the amplitude values
resp_shape_timepoints A shared array holding the time span of the given amplitude value

The documentation for this class was generated from the following files: