Created
October 4, 2014 21:25
-
-
Save neildanson/11cd7874fba0fb437ba3 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import Foundation | |
class Vector { | |
let x,y,z: Double; | |
init(x:Double, y:Double, z:Double) { | |
self.x = x; | |
self.y = y; | |
self.z = z; | |
} | |
func Length() -> Double { | |
return sqrt(self.Dot()) | |
} | |
func Dot() -> Double { | |
return (self.x * self.x) + (self.y * self.y) + (self.z * self.z) | |
} | |
func Cross(v:Vector) -> Vector { | |
return Vector(x: self.y*v.z - self.z*v.y, | |
y: self.z*v.x - self.x*v.z, | |
z: self.x*v.y - self.y*v.x) | |
} | |
func Add(v:Vector) -> Vector { | |
return Vector(x:self.x + v.x, y:self.y + v.y, z:self.z + v.z) | |
} | |
func Subtract(v:Vector) -> Vector { | |
return Vector(x:self.x - v.x, y:self.y - v.y, z:self.z - v.z) | |
} | |
func Scale(s:Double) -> Vector { | |
return Vector(x:self.x * s, y:self.y * s, z:self.z * s) | |
} | |
func Normalize() -> Vector { | |
let mag = self.Length() | |
if mag == 0 { | |
return self.Scale(Double.infinity) | |
} | |
else { | |
return self.Scale(1.0 / mag) | |
} | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment