| 12345678910111213141516171819202122232425262728293031323334 |
- // Filename: linearRandomForce.I
- // Created by: charles (19Jun00)
- //
- ////////////////////////////////////////////////////////////////////
- //
- // PANDA 3D SOFTWARE
- // Copyright (c) 2001, Disney Enterprises, Inc. All rights reserved
- //
- // All use of this software is subject to the terms of the Panda 3d
- // Software license. You should have received a copy of this license
- // along with this source code; you will also find a current copy of
- // the license at http://www.panda3d.org/license.txt .
- //
- // To contact the maintainers of this program write to
- // [email protected] .
- //
- ////////////////////////////////////////////////////////////////////
- ////////////////////////////////////////////////////////////////////
- // Function : random_unit_vector
- // Access : Protected
- // Description : generates a random unit vector
- ////////////////////////////////////////////////////////////////////
- INLINE LVector3f LinearRandomForce::
- random_unit_vector(void) {
- float z, r, theta;
- z = 1.0f - (2.0f * bounded_rand());
- r = sqrtf(1.0f - (z * z));
- theta = 2.0f * 3.1415926f * bounded_rand();
- return LVector3f(r * cosf(theta), r * sinf(theta), z);
- }
|