object_based_ufuncs #1
66
py/brown/brown.py
Normal file
66
py/brown/brown.py
Normal file
|
@ -0,0 +1,66 @@
|
|||
from brown.interaction import UFuncWrapper
|
||||
import numpy as np
|
||||
|
||||
class BrownIterator(object):
|
||||
def __init__(self
|
||||
, m
|
||||
, c
|
||||
, x
|
||||
, y
|
||||
, px
|
||||
, py
|
||||
, borders_x
|
||||
, borders_y
|
||||
, speed_of_light=1e3 # The value that will replace NaN momenta
|
||||
, border_dampening=1
|
||||
, dt=0.1):
|
||||
self._max_m = m
|
||||
self._i = 0
|
||||
self.c = c
|
||||
self.x = x
|
||||
self.y = y
|
||||
self.px = px
|
||||
self.py = py
|
||||
self.borders_x = borders_x
|
||||
self.borders_y = borders_y
|
||||
self.dt = dt
|
||||
self.speed_of_light = speed_of_light
|
||||
self.border_dampening = border_dampening
|
||||
self._interaction = UFuncWrapper(1, c)
|
||||
def __iter__(self):
|
||||
self._i = 0
|
||||
return self
|
||||
def __next__(self):
|
||||
self._i += 1
|
||||
if(self._i > self._max_m and self._max_m > 0):
|
||||
raise StopIteration()
|
||||
if(self._i == 1):
|
||||
return self.x, self.y
|
||||
|
||||
self.px, self.py = self._interaction(self.x, self.y, self.px, self.py)
|
||||
self.px[np.isnan(self.px)] = self.speed_of_light
|
||||
self.py[np.isnan(self.py)] = self.speed_of_light
|
||||
self._reflect_at_borders()
|
||||
|
||||
self.x += self.dt * self.px
|
||||
self.y += self.dt * self.py
|
||||
|
||||
return self.x, self.y
|
||||
|
||||
|
||||
def _reflect_at_borders(self):
|
||||
if(len(self.borders_x) > 0):
|
||||
self.px[self.x <= self.borders_x[0]] *= -self.border_dampening
|
||||
self.x[self.x <= self.borders_x[0]] = self.borders_x[0]
|
||||
if(len(self.borders_x) > 1):
|
||||
self.px[self.x >= self.borders_x[1]] *= -self.border_dampening
|
||||
self.x[self.x >= self.borders_x[1]] = self.borders_x[1]
|
||||
if(len(self.borders_y) > 0):
|
||||
self.py[self.y <= self.borders_y[0]] *= -self.border_dampening
|
||||
self.y[self.y <= self.borders_y[0]] = self.borders_y[0]
|
||||
if(len(self.borders_y) > 1):
|
||||
self.py[self.y >= self.borders_y[1]] *= -self.border_dampening
|
||||
self.y[self.y >= self.borders_y[1]] = self.borders_y[1]
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user