brianUtils.py 908 B

12345678910111213141516171819202122232425262728293031
  1. import numpy as np
  2. from brian2.units.fundamentalunits import Quantity
  3. import nixio
  4. def getSimT(simDur: Quantity, simStepSize: Quantity) -> Quantity:
  5. return np.arange(simDur / simStepSize) * simStepSize
  6. def addBrianQuantity2Section(sec: nixio.pycore.Section,
  7. name: str, qu: Quantity) -> nixio.pycore.Property:
  8. propStr = qu.in_best_unit()
  9. if qu.shape == ():
  10. propFloatStr, propUnit = propStr.split(" ")
  11. propFloat = float(propFloatStr)
  12. pr = sec.create_property(name, [nixio.Value(propFloat)])
  13. elif len(qu.shape) == 1:
  14. propFloatStr, propUnit = propStr.split("] ")
  15. values = list(map(float, propFloatStr[2:].split()))
  16. pr = sec.create_property(name, [nixio.Value(val) for val in values])
  17. else:
  18. raise(ValueError("Only scalar or 1D Brian Quantities as supported"))
  19. pr.unit = propUnit
  20. return pr