/*--------------------------------------------------------------------------
   Author: Thomas Nowotny
  
   Institute: Institute for Nonlinear Dynamics
              University of California San Diego
              La Jolla, CA 92093-0402
  
   email to:  tnowotny@ucsd.edu
  
   initial version: 2005-08-17
  
--------------------------------------------------------------------------*/

#ifndef CN_SYNAPSE_CC
#define CN_SYNAPSE_CC

#include "CN_synapse.h"

synapse::synapse(neuron *insource, neuron *intarget, int iniVarNo,
		 int inpNo, int intype)
{
  assert(intarget != NULL);
  source= insource;
  target= intarget;
  target->den.push_back(this);
  iVarNo= iniVarNo;
  pNo= inpNo;
  if (pNo > 0) p= new double[pNo];
  type= intype;

  // we don't know our index number yet
  idx= 0;
  enabled= 0;
}

synapse::~synapse()
{
  if (pNo > 0) delete[] p;
}

void synapse::set_p(double *inp)
{
  for (int i= 0; i < pNo; i++) p[i]= inp[i];
}

void synapse::init(double *x, double *iniVars)
{
  assert(enabled);
  for (int i= 0; i < iVarNo; i++) {
    x[idx+i]= iniVars[i];
  }
}


void synapse::setIdx(int inidx)
{
  assert(!enabled);
  idx= inidx;
  enabled= 1;
}

int synapse::getIdx()
{
  return idx;
}

#endif