Source code for jaxley.channels.non_capacitive.rate
# This file is part of Jaxley, a differentiable neuroscience simulator. Jaxley is
# licensed under the Apache License Version 2.0, see <https://www.apache.org/licenses/>
from typing import Optional
import jax.numpy as jnp
from jaxley.channels import Channel
from jaxley.solver_gate import exponential_euler
[docs]
class Rate(Channel):
"""Rate-based, unit-less, neuron model."""
def __init__(self, name: Optional[str] = None):
self.current_is_in_mA_per_cm2 = True
super().__init__(name)
self.channel_params = {f"{self.name}_tau": 1.0}
self.channel_states = {}
self.current_name = f"{self.name}_rate"
[docs]
def update_states(self, states, dt, v, params):
"""Voltages get pulled towards zero."""
tau = params[f"{self.name}_tau"]
return {"v": exponential_euler(v, dt, 0.0, tau)}
[docs]
def compute_current(self, states, v, params):
return jnp.zeros((1,))
[docs]
def init_state(self, states, v, params, delta_t):
return {}