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
|
/*
* pycsa.h
*
* This file is part of libneurosim.
*
* Copyright (C) 2013 INCF
*
* libneurosim is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* libneurosim is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
#ifndef PYCSA_H
#define PYCSA_H
extern "C" {
#include <Python.h>
}
#ifdef WITH_THREAD
/* CPython compiled with threads */
#define PYGILSTATE_ENSURE(VAR) PyGILState_STATE VAR = PyGILState_Ensure()
#define PYGILSTATE_RELEASE(VAR) PyGILState_Release (VAR)
#else
#define PYGILSTATE_ENSURE(VAR)
#define PYGILSTATE_RELEASE(VAR)
#endif
#include <neurosim/connection_generator.h>
namespace PyCSA {
class PyCSAGenerator : public ConnectionGenerator {
PyObject* pCSAObject;
PyObject* pPartitionedCSAObject;
int arity_;
PyObject* pIterator;
private:
PyObject* makeIntervals (IntervalSet& iset);
public:
PyCSAGenerator (PyObject* obj);
~PyCSAGenerator ();
int arity ();
void setMask (std::vector<Mask>& masks, int local);
int size ();
void start ();
bool next (int& source, int& target, double* value);
};
}
#endif
|