-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDDMCube.pyx
95 lines (85 loc) · 3 KB
/
DDMCube.pyx
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# DDMCube.pyx
# Created by nicain on 11/1/09.
# Copyright (c) 2009 __MyCompanyName__. All rights reserved.
# Wrapper for the RNG:
cdef extern from "MersenneTwister.h":
ctypedef struct c_MTRand "MTRand":
double randNorm( double mean, double stddev)
void seed( unsigned long bigSeed[])
# External math functions that are needed:
cdef extern from "math.h":
float sqrt(float sqrtMe)
float abs(float absMe)
################################################################################
######################## Main function, the workhorse: ########################
################################################################################
def DDMOU(settings, int FD,int perLoc, tempResultDir, quickName, totalUUID):
# Import necessary python packages:
import itertools, pickle, random, uuid, os
from scipy import zeros
# C initializations
cdef float xCurr, tCurr, yCurrP, yCurrN, xMean, xStd, xTau,
cdef float dt, theta, crossTimes, results, chop, beta, K, yTau, A, B, yBegin, tMax
cdef double mean = 0, std = 1
cdef unsigned long mySeed[624]
cdef c_MTRand myTwister
cdef int i, overTime
# Convert settings dictionary to iterator:
params = settings.keys()
params.sort()
settingsList = []
totalLength = 1
for parameter in params:
settingsList.append(settings[parameter])
totalLength *= len(settings[parameter])
settingsIterator = itertools.product(*settingsList)
resultsArray = zeros(totalLength, dtype=float)
crossTimesArray = zeros(totalLength, dtype=float)
# Initialization of random number generator:
myUUID = uuid.uuid4()
random.seed(myUUID.int)
for i in range(624): mySeed[i] = random.randint(0,2**30)
myTwister.seed(mySeed)
# Parameter space loop:
counter = 0
for currentSettings in settingsIterator:
A, B, K, beta, chop, dt, tMax, theta, xMean, xStd, xTau, yBegin, yTau = currentSettings # Must be alphabetized, with capitol letters coming first!
if FD:
theta = 1000000000
crossTimes = 0
results = 0
for i in range(perLoc):
overTime = 0
tCurr = 0
xCurr = myTwister.randNorm(xMean,xStd)
yCurrP = yBegin
yCurrN = yBegin
while yCurrP - yBegin < theta and yCurrN - yBegin < theta:
xCurr = xCurr+dt*(xMean - xCurr)/xTau + xStd*sqrt(2*dt/xTau)*myTwister.randNorm(mean,std)
if abs(xCurr + beta*yCurrP/K + B) < chop:
yCurrP = yCurrP
else:
yCurrP = yCurrP + dt/yTau*(K*xCurr + beta*yCurrP + A)
if abs(xCurr + beta*yCurrN/K + B) < chop:
yCurrN = yCurrN
else:
yCurrN = yCurrN + dt/yTau*(-K*xCurr + beta*yCurrN + A)
tCurr=tCurr+dt
if tCurr > tMax:
overTime = 1
break
crossTimes += tCurr
if FD:
if yCurrP > yCurrN:
results += 1
else:
if not(overTime) and yCurrP - yBegin >= theta:
results += 1
resultsArray[counter] = results
crossTimesArray[counter] = crossTimes
counter += 1
# Create output files:
fOut = open(os.getcwd() + tempResultDir + '/' + quickName + '_' + str(totalUUID) + '_' + str(myUUID) + '_temp.dat','w')
pickle.dump((crossTimesArray, resultsArray),fOut)
fOut.close()
return