-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvctr.cpp
91 lines (71 loc) · 1.75 KB
/
vctr.cpp
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
#include "vctr.h"
//#include "cmplx.h"
#include <iostream>
using namespace std;
/*int Vector::getlen() const
{
return dim;
}
/*void vector::init(const double *const pd)
{
for (int i=0;i<dim;++i)
v[i]=pd[i];
}*/
Vector::Vector(int n)
{
dim=n;
elem=new Complex[dim];
for (int i=0;i<n;i++)
elem[i]=0.0;
}
//vector::vector(int n, double d ...) { if (n<=0) cout <<"vector: illegal dimension"; v=new double[len=n]; if (v==0) cout << "vector: out of memory"; v[0]=d; } vector::vector(int n, const double *pd) { if (n<=0) cout << "vector: illegal dimension"; v=new double[len=n]; if (v==0) cout << "vector: out of memory"; init(pd); } vector::vector(const vector& w) { v=new double[w.len]; if (v==0) cout << "vector: out of memory"; for (int i=0;i<len;++i) v[i]=w.v[i]; }
Complex Vector::GetElem(int i)
{
return elem[i];
}
void Vector::SetElem(int i, Complex C)
{
elem[i].SetRe(C.GetRe());
elem[i].SetIm(C.GetIm());
}
Vector Vector::operator &(Vector V2)
{
Vector v_erg(this->dim);
for(int i=0; i<dim;i++)
{
if(i<=dim-3)
v_erg.elem[i]=this->elem[i+1]*V2.elem[i+2]-this->elem[i+2]*V2.elem[i+1];
else
{
if(i==dim-2)
v_erg.elem[i]=this->elem[dim-1]*V2.elem[0]-this->elem[0]*V2.elem[dim-1];
if(i==dim-1)
v_erg.elem[i]=this->elem[0]*V2.elem[1]-this->elem[1]*V2.elem[0];
}
}
return v_erg;
}
Complex Vector::operator *(Vector V2)
{
Complex skalar;
for(int i=0; i<dim; i++)
skalar+=this->elem[i]*V2.elem[i];
return skalar;
}
Vector Vector::operator =(Vector V2)
{
for(int i=0; i<dim;i++)
{
this->elem[i]=V2.elem[i];
}
return (*this);
}
/*void vector::clear()
{
for (int i=0;i<dim;++i)
v[i]=0.0;
}*/
/*void vector::print(void) const
{
cout << "( "; for (int i=0;i<dim;++i) cout << v[i] << ' '; cout << ')';
} */