Go to the documentation of this file.
39 for (
int i = 0;
i < nt.
end; ++
i) {
56 bool header_printed =
false;
62 for (
int iorig = 0; iorig < ml->
nodecount; ++iorig) {
67 if (!header_printed) {
68 header_printed =
true;
71 if (receives_events) {
72 fprintf(f,
"%d nri %d\n", cix,
pntindex);
78 for (
int j = 0; j < size; ++j) {
94 std::vector<std::vector<NetCon*>> nclist(
pntindex);
100 std::map<Point_process*, int>::iterator it =
pnt2index.find(pp);
102 nclist[it->second].push_back(nc);
107 fprintf(f,
"netcons %d\n", nc_cnt);
108 fprintf(f,
" pntindex srcgid active delay weights\n");
116 for (
int j = 0; j < ps->
nc_cnt_; ++j) {
120 it_nc2src->second = ps;
130 std::map<NetCon*, int> map_nc2gid;
131 for (
const auto& gid:
gid2in) {
137 it_nc2src->second = ips;
138 map_nc2gid[nc] = gid.first;
144 for (
int j = 0; j < (int) (nclist[
i].size()); ++j) {
155 if (srcgid < 0 && pnt) {
156 int type = pnt->
_type;
164 }
else if (srcgid < 0 && ps->thvar_index_ > 0) {
189 for (
int k = 0; k < wcnt; ++k) {
213 while (rnode >= nt.
ncell) {
220 int* cellnodes =
new int[nt.
end];
221 for (
int i = 0;
i < nt.
end; ++
i) {
228 cellnodes[
i] =
cnt++;
231 fprintf(f,
"%d nodes %d is the threshold node\n",
cnt, cellnodes[
inv_permute(inode, nt)] - 1);
233 fprintf(f,
"inode parent area a b\n");
234 for (
int iorig = 0; iorig < nt.
end; ++iorig)
235 if (cellnodes[iorig] >= 0) {
239 "%d %d %.*g %.*g %.*g\n",
249 fprintf(f,
"inode v\n");
250 for (
int i = 0;
i < nt.
end; ++
i)
251 if (cellnodes[
i] >= 0) {
257 pr_memb(tml->index, tml->ml, cellnodes, nt, f);
275 for (
int ip = 0; ip < nt.
n_presyn; ++ip) {
279 std::string filename = std::to_string(gid) +
"_" + suffix +
".corenrn";
280 FILE* f = fopen(filename.c_str(),
"w");
282 fprintf(f,
"gid = %d\n", gid);
auto & get_mech_data_layout()
static std::vector< int > * inv_permute_
std::vector< NetCon * > netcon_in_presyn_order_
InputPreSyn.nc_index_ to + InputPreSyn.nc_cnt_ give the NetCon*.
static int inv_permute(int i, NrnThread &nt)
auto & get_is_artificial()
auto & get_memb_func(size_t idx)
union coreneuron::NetCon::@0 u
void hoc_execerror(const char *s1, const char *s2)
static void pr_realcell(PreSyn &ps, NrnThread &nt, FILE *f)
THIS FILE IS AUTO GENERATED DONT MODIFY IT.
static std::map< Point_process *, int > pnt2index
auto & get_prop_dparam_size()
std::map< int, InputPreSyn * > gid2in
static int ml_permute(int i, Memb_list *ml)
int nrn_i_layout(int icnt, int cnt, int isz, int sz, int layout)
This function return the index in a flat array of a matrix coordinate (icnt, isz).
static void pr_memb(int type, Memb_list *ml, int *cellnodes, NrnThread &nt, FILE *f)
int prcellstate(int gid, const char *suffix)
static std::map< NetCon *, DiscreteEvent * > map_nc2src
auto & get_prop_param_size()
static void pr_netcon(NrnThread &nt, FILE *f)
#define nrn_assert(x)
assert()-like macro, independent of NDEBUG status
static int permute(int i, NrnThread &nt)
auto & get_pnt_receive_size()