#include <cstdlib>
#include <iostream>
using namespace std;
double scalar(double *a, double *b, int i)
{
double sum = 0;
for(i--;i >= 0; i--)
sum += a[i] * b[i];
return sum;
}
void vsum(double *a, double *b, int i)
{
for(i--;i >= 0; i--)
a[i] += b[i];
}
void vprod(double *a, double b, int i)
{
for(i--;i >= 0; i--)
a[i] *= b;
}
void vcopy(double *a, double *b, int i)
{
for(i--;i >= 0; i--)
a[i] = b[i];
}
double vmod(double *a, int i)
{
double sum = 0;
for(i--;i >= 0; i--)
sum += a[i] * a[i];
return sum;
}
int main(int argc, char *argv[])
{
double vect[10] = {0, 0.0, 0.0, 0, 0, 0, 0, 0, 0, 0};
double a[23][10] = {{1, 1, 1, 1, 1, 1, 1, 1, 1, 1},
{1, 0, 0, 0, 0, 0, 0, 0, 0, 0},
{0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 1, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 1, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 1, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 1, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 1, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 1, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0, 1, 0},
{0, 0, 0, 0, 0, 0, 0, 0, 0, 1},
{-1, 0, 0, 0, 0, 0, 0, 0, 0, 0},
{0, -1, 0, 0, 0, 0, 0, 0, 0, 0},
{0, 0, -1, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, -1, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, -1, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, -1, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, -1, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, -1, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0, -1, 0},
{0, 0, 0, 0, 0, 0, 0, 0, 0, -1},
{-1, -1, -1, -1, -1, -1, -1, -1, -1, -1},
{0.01627813, 0.02666463, 0.01283752, 0.05161583, 0.03666832, 0.03200336, 0.01160796, 0.0180156, 0.02580591, 0.02835363}};
double b[23] = {1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0.03161189};
bool NotOk = true;
while (NotOk)
{
NotOk = false;
for (int i = 0; i < 23; i++)
{
//cout << i;
double d = scalar(vect, a[i], 10) - b[i];
if (d < 0)
{
NotOk = true;
double temp[10];
vcopy(temp, a[i], 10);
d = (- d + 0.0000000) / vmod(temp, 10);
vprod(temp, d, 10);
vsum(vect, temp, 10);
}
}
}
for (int i = 0; i < 10; i ++)
cout << vect[i] << " ";
cout << endl << endl;
system("PAUSE");
return EXIT_SUCCESS;
}