sim-ballena 0.1.0__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of sim-ballena might be problematic. Click here for more details.

@@ -0,0 +1,186 @@
1
+ # This file is autogenerated by maturin v1.11.5
2
+ # To update, run
3
+ #
4
+ # maturin generate-ci github
5
+ #
6
+ name: CI
7
+
8
+ on:
9
+ push:
10
+ branches:
11
+ - main
12
+ - master
13
+ tags:
14
+ - '*'
15
+ pull_request:
16
+ workflow_dispatch:
17
+
18
+ permissions:
19
+ contents: read
20
+
21
+ jobs:
22
+ linux:
23
+ runs-on: ${{ matrix.platform.runner }}
24
+ strategy:
25
+ matrix:
26
+ platform:
27
+ - runner: ubuntu-22.04
28
+ target: x86_64
29
+ - runner: ubuntu-22.04
30
+ target: x86
31
+ - runner: ubuntu-22.04
32
+ target: aarch64
33
+ - runner: ubuntu-22.04
34
+ target: armv7
35
+ - runner: ubuntu-22.04
36
+ target: s390x
37
+ - runner: ubuntu-22.04
38
+ target: ppc64le
39
+ steps:
40
+ - uses: actions/checkout@v6
41
+ - uses: actions/setup-python@v6
42
+ with:
43
+ python-version: 3.x
44
+ - name: Build wheels
45
+ uses: PyO3/maturin-action@v1
46
+ with:
47
+ target: ${{ matrix.platform.target }}
48
+ args: --release --out dist --find-interpreter
49
+ sccache: ${{ !startsWith(github.ref, 'refs/tags/') }}
50
+ manylinux: auto
51
+ - name: Upload wheels
52
+ uses: actions/upload-artifact@v5
53
+ with:
54
+ name: wheels-linux-${{ matrix.platform.target }}
55
+ path: dist
56
+
57
+ musllinux:
58
+ runs-on: ${{ matrix.platform.runner }}
59
+ strategy:
60
+ matrix:
61
+ platform:
62
+ - runner: ubuntu-22.04
63
+ target: x86_64
64
+ - runner: ubuntu-22.04
65
+ target: x86
66
+ - runner: ubuntu-22.04
67
+ target: aarch64
68
+ - runner: ubuntu-22.04
69
+ target: armv7
70
+ steps:
71
+ - uses: actions/checkout@v6
72
+ - uses: actions/setup-python@v6
73
+ with:
74
+ python-version: 3.x
75
+ - name: Build wheels
76
+ uses: PyO3/maturin-action@v1
77
+ with:
78
+ target: ${{ matrix.platform.target }}
79
+ args: --release --out dist --find-interpreter
80
+ sccache: ${{ !startsWith(github.ref, 'refs/tags/') }}
81
+ manylinux: musllinux_1_2
82
+ - name: Upload wheels
83
+ uses: actions/upload-artifact@v5
84
+ with:
85
+ name: wheels-musllinux-${{ matrix.platform.target }}
86
+ path: dist
87
+
88
+ windows:
89
+ runs-on: ${{ matrix.platform.runner }}
90
+ strategy:
91
+ matrix:
92
+ platform:
93
+ - runner: windows-latest
94
+ target: x64
95
+ python_arch: x64
96
+ - runner: windows-latest
97
+ target: x86
98
+ python_arch: x86
99
+ - runner: windows-11-arm
100
+ target: aarch64
101
+ python_arch: arm64
102
+ steps:
103
+ - uses: actions/checkout@v6
104
+ - uses: actions/setup-python@v6
105
+ with:
106
+ python-version: 3.13
107
+ architecture: ${{ matrix.platform.python_arch }}
108
+ - name: Build wheels
109
+ uses: PyO3/maturin-action@v1
110
+ with:
111
+ target: ${{ matrix.platform.target }}
112
+ args: --release --out dist --find-interpreter
113
+ sccache: ${{ !startsWith(github.ref, 'refs/tags/') }}
114
+ - name: Upload wheels
115
+ uses: actions/upload-artifact@v5
116
+ with:
117
+ name: wheels-windows-${{ matrix.platform.target }}
118
+ path: dist
119
+
120
+ macos:
121
+ runs-on: ${{ matrix.platform.runner }}
122
+ strategy:
123
+ matrix:
124
+ platform:
125
+ - runner: macos-15-intel
126
+ target: x86_64
127
+ - runner: macos-latest
128
+ target: aarch64
129
+ steps:
130
+ - uses: actions/checkout@v6
131
+ - uses: actions/setup-python@v6
132
+ with:
133
+ python-version: 3.x
134
+ - name: Build wheels
135
+ uses: PyO3/maturin-action@v1
136
+ with:
137
+ target: ${{ matrix.platform.target }}
138
+ args: --release --out dist --find-interpreter
139
+ sccache: ${{ !startsWith(github.ref, 'refs/tags/') }}
140
+ - name: Upload wheels
141
+ uses: actions/upload-artifact@v5
142
+ with:
143
+ name: wheels-macos-${{ matrix.platform.target }}
144
+ path: dist
145
+
146
+ sdist:
147
+ runs-on: ubuntu-latest
148
+ steps:
149
+ - uses: actions/checkout@v6
150
+ - name: Build sdist
151
+ uses: PyO3/maturin-action@v1
152
+ with:
153
+ command: sdist
154
+ args: --out dist
155
+ - name: Upload sdist
156
+ uses: actions/upload-artifact@v5
157
+ with:
158
+ name: wheels-sdist
159
+ path: dist
160
+
161
+ release:
162
+ name: Release
163
+ runs-on: ubuntu-latest
164
+ if: ${{ startsWith(github.ref, 'refs/tags/') || github.event_name == 'workflow_dispatch' }}
165
+ needs: [linux, musllinux, windows, macos, sdist]
166
+ permissions:
167
+ # Use to sign the release artifacts
168
+ id-token: write
169
+ # Used to upload release artifacts
170
+ contents: write
171
+ # Used to generate artifact attestation
172
+ attestations: write
173
+ steps:
174
+ - uses: actions/download-artifact@v6
175
+ - name: Generate artifact attestation
176
+ uses: actions/attest-build-provenance@v3
177
+ with:
178
+ subject-path: 'wheels-*/*'
179
+ - name: Install uv
180
+ if: ${{ startsWith(github.ref, 'refs/tags/') }}
181
+ uses: astral-sh/setup-uv@v7
182
+ - name: Publish to PyPI
183
+ if: ${{ startsWith(github.ref, 'refs/tags/') }}
184
+ run: uv publish 'wheels-*/*'
185
+ env:
186
+ UV_PUBLISH_TOKEN: ${{ secrets.PYPI_API_TOKEN }}
@@ -0,0 +1,72 @@
1
+ /target
2
+
3
+ # Byte-compiled / optimized / DLL files
4
+ __pycache__/
5
+ .pytest_cache/
6
+ *.py[cod]
7
+
8
+ # C extensions
9
+ *.so
10
+
11
+ # Distribution / packaging
12
+ .Python
13
+ .venv/
14
+ env/
15
+ bin/
16
+ build/
17
+ develop-eggs/
18
+ dist/
19
+ eggs/
20
+ lib/
21
+ lib64/
22
+ parts/
23
+ sdist/
24
+ var/
25
+ include/
26
+ man/
27
+ venv/
28
+ *.egg-info/
29
+ .installed.cfg
30
+ *.egg
31
+
32
+ # Installer logs
33
+ pip-log.txt
34
+ pip-delete-this-directory.txt
35
+ pip-selfcheck.json
36
+
37
+ # Unit test / coverage reports
38
+ htmlcov/
39
+ .tox/
40
+ .coverage
41
+ .cache
42
+ nosetests.xml
43
+ coverage.xml
44
+
45
+ # Translations
46
+ *.mo
47
+
48
+ # Mr Developer
49
+ .mr.developer.cfg
50
+ .project
51
+ .pydevproject
52
+
53
+ # Rope
54
+ .ropeproject
55
+
56
+ # Django stuff:
57
+ *.log
58
+ *.pot
59
+
60
+ .DS_Store
61
+
62
+ # Sphinx documentation
63
+ docs/_build/
64
+
65
+ # PyCharm
66
+ .idea/
67
+
68
+ # VSCode
69
+ .vscode/
70
+
71
+ # Pyenv
72
+ .python-version
@@ -0,0 +1,172 @@
1
+ # This file is automatically @generated by Cargo.
2
+ # It is not intended for manual editing.
3
+ version = 4
4
+
5
+ [[package]]
6
+ name = "SimBallenaSNN"
7
+ version = "0.1.0"
8
+ dependencies = [
9
+ "pyo3",
10
+ ]
11
+
12
+ [[package]]
13
+ name = "autocfg"
14
+ version = "1.5.0"
15
+ source = "registry+https://github.com/rust-lang/crates.io-index"
16
+ checksum = "c08606f8c3cbf4ce6ec8e28fb0014a2c086708fe954eaa885384a6165172e7e8"
17
+
18
+ [[package]]
19
+ name = "heck"
20
+ version = "0.5.0"
21
+ source = "registry+https://github.com/rust-lang/crates.io-index"
22
+ checksum = "2304e00983f87ffb38b55b444b5e3b60a884b5d30c0fca7d82fe33449bbe55ea"
23
+
24
+ [[package]]
25
+ name = "indoc"
26
+ version = "2.0.7"
27
+ source = "registry+https://github.com/rust-lang/crates.io-index"
28
+ checksum = "79cf5c93f93228cf8efb3ba362535fb11199ac548a09ce117c9b1adc3030d706"
29
+ dependencies = [
30
+ "rustversion",
31
+ ]
32
+
33
+ [[package]]
34
+ name = "libc"
35
+ version = "0.2.180"
36
+ source = "registry+https://github.com/rust-lang/crates.io-index"
37
+ checksum = "bcc35a38544a891a5f7c865aca548a982ccb3b8650a5b06d0fd33a10283c56fc"
38
+
39
+ [[package]]
40
+ name = "memoffset"
41
+ version = "0.9.1"
42
+ source = "registry+https://github.com/rust-lang/crates.io-index"
43
+ checksum = "488016bfae457b036d996092f6cb448677611ce4449e970ceaf42695203f218a"
44
+ dependencies = [
45
+ "autocfg",
46
+ ]
47
+
48
+ [[package]]
49
+ name = "once_cell"
50
+ version = "1.21.3"
51
+ source = "registry+https://github.com/rust-lang/crates.io-index"
52
+ checksum = "42f5e15c9953c5e4ccceeb2e7382a716482c34515315f7b03532b8b4e8393d2d"
53
+
54
+ [[package]]
55
+ name = "portable-atomic"
56
+ version = "1.13.0"
57
+ source = "registry+https://github.com/rust-lang/crates.io-index"
58
+ checksum = "f89776e4d69bb58bc6993e99ffa1d11f228b839984854c7daeb5d37f87cbe950"
59
+
60
+ [[package]]
61
+ name = "proc-macro2"
62
+ version = "1.0.105"
63
+ source = "registry+https://github.com/rust-lang/crates.io-index"
64
+ checksum = "535d180e0ecab6268a3e718bb9fd44db66bbbc256257165fc699dadf70d16fe7"
65
+ dependencies = [
66
+ "unicode-ident",
67
+ ]
68
+
69
+ [[package]]
70
+ name = "pyo3"
71
+ version = "0.27.2"
72
+ source = "registry+https://github.com/rust-lang/crates.io-index"
73
+ checksum = "ab53c047fcd1a1d2a8820fe84f05d6be69e9526be40cb03b73f86b6b03e6d87d"
74
+ dependencies = [
75
+ "indoc",
76
+ "libc",
77
+ "memoffset",
78
+ "once_cell",
79
+ "portable-atomic",
80
+ "pyo3-build-config",
81
+ "pyo3-ffi",
82
+ "pyo3-macros",
83
+ "unindent",
84
+ ]
85
+
86
+ [[package]]
87
+ name = "pyo3-build-config"
88
+ version = "0.27.2"
89
+ source = "registry+https://github.com/rust-lang/crates.io-index"
90
+ checksum = "b455933107de8642b4487ed26d912c2d899dec6114884214a0b3bb3be9261ea6"
91
+ dependencies = [
92
+ "target-lexicon",
93
+ ]
94
+
95
+ [[package]]
96
+ name = "pyo3-ffi"
97
+ version = "0.27.2"
98
+ source = "registry+https://github.com/rust-lang/crates.io-index"
99
+ checksum = "1c85c9cbfaddf651b1221594209aed57e9e5cff63c4d11d1feead529b872a089"
100
+ dependencies = [
101
+ "libc",
102
+ "pyo3-build-config",
103
+ ]
104
+
105
+ [[package]]
106
+ name = "pyo3-macros"
107
+ version = "0.27.2"
108
+ source = "registry+https://github.com/rust-lang/crates.io-index"
109
+ checksum = "0a5b10c9bf9888125d917fb4d2ca2d25c8df94c7ab5a52e13313a07e050a3b02"
110
+ dependencies = [
111
+ "proc-macro2",
112
+ "pyo3-macros-backend",
113
+ "quote",
114
+ "syn",
115
+ ]
116
+
117
+ [[package]]
118
+ name = "pyo3-macros-backend"
119
+ version = "0.27.2"
120
+ source = "registry+https://github.com/rust-lang/crates.io-index"
121
+ checksum = "03b51720d314836e53327f5871d4c0cfb4fb37cc2c4a11cc71907a86342c40f9"
122
+ dependencies = [
123
+ "heck",
124
+ "proc-macro2",
125
+ "pyo3-build-config",
126
+ "quote",
127
+ "syn",
128
+ ]
129
+
130
+ [[package]]
131
+ name = "quote"
132
+ version = "1.0.43"
133
+ source = "registry+https://github.com/rust-lang/crates.io-index"
134
+ checksum = "dc74d9a594b72ae6656596548f56f667211f8a97b3d4c3d467150794690dc40a"
135
+ dependencies = [
136
+ "proc-macro2",
137
+ ]
138
+
139
+ [[package]]
140
+ name = "rustversion"
141
+ version = "1.0.22"
142
+ source = "registry+https://github.com/rust-lang/crates.io-index"
143
+ checksum = "b39cdef0fa800fc44525c84ccb54a029961a8215f9619753635a9c0d2538d46d"
144
+
145
+ [[package]]
146
+ name = "syn"
147
+ version = "2.0.114"
148
+ source = "registry+https://github.com/rust-lang/crates.io-index"
149
+ checksum = "d4d107df263a3013ef9b1879b0df87d706ff80f65a86ea879bd9c31f9b307c2a"
150
+ dependencies = [
151
+ "proc-macro2",
152
+ "quote",
153
+ "unicode-ident",
154
+ ]
155
+
156
+ [[package]]
157
+ name = "target-lexicon"
158
+ version = "0.13.4"
159
+ source = "registry+https://github.com/rust-lang/crates.io-index"
160
+ checksum = "b1dd07eb858a2067e2f3c7155d54e929265c264e6f37efe3ee7a8d1b5a1dd0ba"
161
+
162
+ [[package]]
163
+ name = "unicode-ident"
164
+ version = "1.0.22"
165
+ source = "registry+https://github.com/rust-lang/crates.io-index"
166
+ checksum = "9312f7c4f6ff9069b165498234ce8be658059c6728633667c526e27dc2cf1df5"
167
+
168
+ [[package]]
169
+ name = "unindent"
170
+ version = "0.2.4"
171
+ source = "registry+https://github.com/rust-lang/crates.io-index"
172
+ checksum = "7264e107f553ccae879d21fbea1d6724ac785e8c3bfc762137959b5802826ef3"
@@ -0,0 +1,12 @@
1
+ [package]
2
+ name = "SimBallenaSNN"
3
+ version = "0.1.0"
4
+ edition = "2024"
5
+
6
+ # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
7
+ [lib]
8
+ name = "sim_ballena"
9
+ crate-type = ["cdylib"]
10
+
11
+ [dependencies]
12
+ pyo3 = "0.27.0"
@@ -0,0 +1,9 @@
1
+ Metadata-Version: 2.4
2
+ Name: sim_ballena
3
+ Version: 0.1.0
4
+ Classifier: Programming Language :: Rust
5
+ Classifier: Programming Language :: Python :: Implementation :: CPython
6
+ Classifier: Programming Language :: Python :: Implementation :: PyPy
7
+ Summary: Ultra fast SNN simulator for machine learning
8
+ Author: Andrés Romo
9
+ Requires-Python: >=3.8
@@ -0,0 +1,113 @@
1
+ import Ballena as ballena
2
+
3
+
4
+ # ======================
5
+ # CREAR OBJETOS
6
+ # ======================
7
+
8
+ instance = [(0.4, 0),
9
+ (0.5, 1),
10
+ (2.1, 0),
11
+ (3.0, 0),
12
+ (3.4, 1)] # [ (TIME, INPUT_ID) ... ]
13
+
14
+ instance = ballena.create_input( instance ) # WRAPPER
15
+
16
+ synapses_in = [(0,1),(0,2),(1,1)] # [ (neu_pre, neu_post) ... ]
17
+ synapses_net = [(0,1),(0,2),(2,1)] # [ (neu_pre, neu_post) ... ]
18
+ weights_in = [0,1,2] # [ w1,w2,w3 ... ]
19
+ weights_net = [3,4,5]
20
+
21
+ neurons = [ballena.lif(tau=2, v_thres=-55, v_rest=-70, refract=5),
22
+ ballena.lif(tau=3, ),
23
+ ballena.lif(tau=4, )]
24
+
25
+ outputs = [2]
26
+
27
+ # ======================
28
+ # CREAR RED Y SIMULAR
29
+ # ======================
30
+
31
+ net = (ballena.network(neurons)
32
+ .set_synpases_in(synapses_in)
33
+ .set_synpases_net(synapses_net)
34
+ .set_weights_in(weights_in)
35
+ .set_weights_net(weights_net)
36
+ .set_outputs(outputs))
37
+
38
+ spikes = net.simulate( instance, t=300 ).get_spikes()
39
+
40
+
41
+
42
+
43
+ # ===========================================
44
+ # CASO DE USO EVALUAR ACCURACY CON SPIKES
45
+ # ===========================================
46
+
47
+ net = (
48
+ ballena.network(neurons)
49
+ .set_synpases_in(synapses_in)
50
+ .set_synpases_net(synapses_net)
51
+ .set_outputs([10,11,12]) # Topologia de la red fija
52
+ )
53
+
54
+ def evaluar_weights(weights): # Esta pudiera ser una funcion objetivo
55
+ net.set_weights( weights )
56
+
57
+ resultados = [ net.simulate(instance, t=10).get_spikes() for instance in dataset ]
58
+ return accuracy(resultados, dataset)
59
+
60
+ # =============================
61
+ # CASO DE USO PLOTEAR RESPUESTA
62
+ # =============================
63
+ net = (
64
+ ballena.network(neurons)
65
+ .set_synpases_in(synapses_in)
66
+ .set_synpases_net(synapses_net)
67
+ .net.set_weights( weights )
68
+ .set_outputs([1])
69
+ )
70
+
71
+ voltage = net.simulate(instance, t=10).get_voltage()
72
+ plt.plot(voltage[0])
73
+
74
+
75
+ # ==========================
76
+ # CASO DE USO NEUROEVOLUCION
77
+ # ==========================
78
+
79
+ net = ballena.network(neurons).set_synapses_in(synapses_in).set_outputs([2,3])
80
+
81
+ def evaluar_topologia(synapses, weights):
82
+ net.set_synapses_net(synapses).set_weights(weights)
83
+
84
+ resultados = [ net.simulate(instance, t=10).spikes() for instance in dataset ]
85
+ return accuracy(resultados, dataset)
86
+
87
+
88
+
89
+ # ==================================
90
+ # CASO DE USO NEUROEVOLUCION
91
+ # CON AJUSTE AUTOMATICO DE PESOS
92
+ # ==================================
93
+
94
+ net = (
95
+ ballena.network(neurons)
96
+ .set_synapses_in(synapses_in)
97
+ .set_outputs([2,3])
98
+ .stdp( True ) # Ajuste automatico
99
+ )
100
+
101
+ def evaluar_topologia(synapses):
102
+ net.set_synapses_net(synapses) # se contruye topologia
103
+
104
+ for e in range(epochs): # Se ajustan los pesos
105
+ for instancia in dataset.train():
106
+ res = net.simulate( instancia, t=10 ).get_spikes() # pass forward
107
+ err = calcular_error(res,instancia) # loss function
108
+ net.dopamina( err ) # ajuste pesos
109
+
110
+ res = [ net.simulate(instancia, t=10) for instancia in dataset.validation() ]
111
+ return acc(res, dataset.validation())
112
+
113
+
@@ -0,0 +1,15 @@
1
+ [build-system]
2
+ requires = ["maturin>=1.11,<2.0"]
3
+ build-backend = "maturin"
4
+
5
+ [project]
6
+ name = "sim_ballena"
7
+ requires-python = ">=3.8"
8
+ classifiers = [
9
+ "Programming Language :: Rust",
10
+ "Programming Language :: Python :: Implementation :: CPython",
11
+ "Programming Language :: Python :: Implementation :: PyPy",
12
+ ]
13
+ dynamic = ["version"]
14
+ authors = [{ name = "Andrés Romo" }]
15
+ description = "Ultra fast SNN simulator for machine learning"
@@ -0,0 +1,36 @@
1
+ use pyo3::prelude::*;
2
+ use crate::utils::vec_of_tuples;
3
+
4
+ #[pyclass]
5
+ pub struct Instance{
6
+ spikes: Vec<(f64,usize)>
7
+ }
8
+
9
+ #[pymethods]
10
+ impl Instance{
11
+ #[new]
12
+ fn new(obj: &Bound<'_,PyAny>)->PyResult<Self>{
13
+ let mut spikes = match vec_of_tuples::<f64>(obj){
14
+ Ok(v) => v,
15
+ Err(e) => return Err(e)
16
+ };
17
+
18
+
19
+ spikes.sort_by(|a,b|a.0.partial_cmp(&b.0).unwrap());
20
+
21
+ Ok(Self{spikes})
22
+ }
23
+
24
+ fn __str__(&self)->String{
25
+ format!("Input(count={})",self.spikes.len())
26
+ }
27
+
28
+ fn __repr__(&self)->String{
29
+ self.__str__()
30
+ }
31
+
32
+ pub fn get(&self)->&Vec<(f64,usize)>{
33
+ &self.spikes
34
+ }
35
+ }
36
+
@@ -0,0 +1,24 @@
1
+
2
+ mod networks;
3
+ mod neurons;
4
+ mod simulation;
5
+ mod instances;
6
+ mod utils;
7
+ mod responses;
8
+
9
+ use pyo3::prelude::*;
10
+
11
+
12
+ #[pymodule]
13
+ fn sim_ballena(m: &Bound<'_, PyModule>) -> PyResult<()> {
14
+ m.add_class::<neurons::Lif>()?;
15
+ m.add_class::<networks::Network>()?;
16
+ m.add_class::<instances::Instance>()?;
17
+ // m.add_function( wrap_pyfunction!(networks::network,m)? )?;
18
+
19
+ Ok(())
20
+ }
21
+
22
+
23
+
24
+