sources:


website:
more info here


screenshot:
studies/grafik2/Computergrafik-Code8/Aufgabe22/vector.cpp
download file

  1 //
  2 // Computergraphik II
  3 // Prof. Dr. Juergen Doellner
  4 // Wintersemester 2001/02
  5 //
  6 // Rahmenprogramm zu Aufgabenzettel 8
  7 //
  8
  9 #include "vector.h"
 10 #include <math.h>
 11 #include <string.h>
 12
 13 bool Vector::operator<(const Vector& u) const {
 14     return((v_[0]<u.v_[0]) ||
 15            (v_[0]==u.v_[0] && v_[1]<u.v_[1]) ||
 16            (v_[0]==u.v_[0] && v_[1]==u.v_[1] && v_[2]<u.v_[2])
 17     )
;
 18 }
 19
 20 Vector& Vector::operator*=(const Vector& u) { // cross product
 21     double x = v_[0];
 22     double y = v_[1];
 23     double z = v_[2];
 24     v_[0] = y*u.v_[2] - z*u.v_[1];
 25     v_[1] = z*u.v_[0] - x*u.v_[2];
 26     v_[2] = x*u.v_[1] - y*u.v_[0];
 27     return *this;
 28 }
 29
 30 Vector Vector::normalized() const {
 31     double L = sqrt(v_[0]*v_[0] + v_[1]*v_[1] + v_[2]*v_[2]);
 32     if(fabs(L) == 0.0) {
 33         return Vector(0,0,0);
 34     } else {
 35         return Vector(v_[0]/L, v_[1]/L, v_[2]/L);
 36     }
 37 }
 38
 39 bool Vector::normalize() {
 40     double L = sqrt(v_[0]*v_[0] + v_[1]*v_[1] + v_[2]*v_[2]);
 41     if(fabs(L) == 0.0) {
 42         return false;
 43     } else {
 44         v_[0] /= L;
 45         v_[1] /= L;
 46         v_[2] /= L;
 47         return true;
 48     }
 49 }
 50
 51 //
 52 // IO
 53 //
 54
 55 ostream& operator<<(ostream& s, const Vector& u) {
 56     s << "(" << u[0] << "," << u[1] << "," << u[2] << ")";
 57     return s;
 58 }
 59
 60 istream& operator>>(istream& s, Vector& u) {
 61     char ch;
 62
 63     s >> ch;
 64     if(ch!='(') { s.clear(ios::badbit); return s; }
 65
 66     s >> u[0];
 67     if(!s.good()) { return s; }
 68
 69     s >> ch;
 70     if(ch!=',') { s.clear(ios::badbit); return s; }
 71
 72     s >> u[1];
 73     if(!s.good()) { return s; }
 74
 75     s >> ch;
 76     if(ch!=',') { s.clear(ios::badbit); return s; }
 77
 78     s >> u[2];
 79     if(!s.good()) { return s; }
 80
 81     s >> ch;
 82     if(ch!=')') { s.clear(ios::badbit); return s; }
 83
 84     return s;
 85 }
 86