possibility to give fixed seed to random orientation

This commit is contained in:
Martin Diehl 2015-06-26 06:32:25 +00:00
parent 6aaf074651
commit 50bcfe6e0d
1 changed files with 10 additions and 4 deletions

View File

@ -4,7 +4,7 @@
# NOTE: everything here needs to be a np array # # NOTE: everything here needs to be a np array #
################################################### ###################################################
import math,random import math,random,os
import numpy as np import numpy as np
# ****************************************************************************************** # ******************************************************************************************
@ -369,7 +369,10 @@ class Quaternion:
@classmethod @classmethod
def fromRandom(cls): def fromRandom(cls,randomSeed=None):
if randomSeed == None:
randomSeed = int(os.urandom(4).encode('hex'), 16)
random.seed(randomSeed)
r1 = random.random() r1 = random.random()
r2 = random.random() r2 = random.random()
r3 = random.random() r3 = random.random()
@ -750,11 +753,14 @@ class Orientation:
angleAxis = None, angleAxis = None,
matrix = None, matrix = None,
Eulers = None, Eulers = None,
random = False, random = False, # put any integer to have a fixed seed or True for real random
symmetry = None, symmetry = None,
): ):
if random: # produce random orientation if random: # produce random orientation
self.quaternion = Quaternion.fromRandom() if isinstance(random, bool ):
self.quaternion = Quaternion.fromRandom()
else:
self.quaternion = Quaternion.fromRandom(randomSeed=random)
elif isinstance(Eulers, np.ndarray) and Eulers.shape == (3,): # based on given Euler angles elif isinstance(Eulers, np.ndarray) and Eulers.shape == (3,): # based on given Euler angles
self.quaternion = Quaternion.fromEulers(Eulers,'bunge') self.quaternion = Quaternion.fromEulers(Eulers,'bunge')
elif isinstance(matrix, np.ndarray) : # based on given rotation matrix elif isinstance(matrix, np.ndarray) : # based on given rotation matrix