File: synapse_creation.py

package info (click to toggle)
brian 2.9.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,872 kB
  • sloc: python: 51,820; cpp: 2,033; makefile: 108; sh: 72
file content (67 lines) | stat: -rw-r--r-- 2,294 bytes parent folder | download | duplicates (4)
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
'''
How long does synapse creation take?
'''
import time
import pickle

import numpy as np
import joblib

from brian2 import *

repetitions = 3

memory = joblib.Memory(cachedir='.', verbose=0)

@memory.cache
def test_connectivity2(N, i, j, n, p, codeobj_class):
    G = NeuronGroup(N, '')
    # Do it once without measuring the time to ignore the compilation time for
    # C code
    S = Synapses(G, G, '', codeobj_class=codeobj_class)
    S.connect(i, j, p, n)
    connections = len(S)
    del S
    times = []
    for _ in range(repetitions):
        S = Synapses(G, G, '', codeobj_class=codeobj_class)
        start = time.time()
        S.connect(i, j, p, n)
        times.append(time.time() - start)
        del S

    return float(np.median(times)), connections

conditions = [('Full', 'True'),
              ('Full (no-self)', 'i != j'),
              ('One-to-one', 'i == j'),
              ('Simple neighbourhood', 'abs(i-j) < 5'),
              ('Gauss neighbourhood', 'exp(-(i - j)**2/5) > 0.005'),
              ('Random (50%)', (True, None, 1, 0.5)),
              ('Random (10%)', (True, None, 1, 0.1)),
              ('Random (1%)', (True, None, 1, 0.01)),
              ('Random no-self (50%)', ('(i != j)', None, 1, 0.5)),
              ('Random no-self (10%)', ('(i != j)', None, 1, 0.1)),
              ('Random no-self (1%)', ('(i != j)', None, 1, 0.01))]
targets = [NumpyCodeObject]
results = {}
max_connections = 2500000
for target in targets:
    lang_name = target.class_name
    for pattern, condition in conditions:
        N = 1
        connections = took = 0
        while connections < max_connections and took < 20:
            print(lang_name, pattern)
            if isinstance(condition, str):
                took, connections = test_connectivity2(N, condition, None, 1, 1.,
                                                      codeobj_class=target)
            else:
                took, connections = test_connectivity2(N, *condition,
                                                      codeobj_class=target)
            print(N, '%.4fs (for %d connections)' % (took, connections))
            results[(lang_name, connections, pattern)] = took
            N *= 2

with open('synapse_creation_times_brian2.pickle', 'w') as f:
    pickle.dump(results, f)