1
0
mirror of https://github.com/aportelli/LatAnalyze.git synced 2024-11-15 02:05:36 +00:00
LatAnalyze/examples/exMat.cpp

38 lines
1.1 KiB
C++
Raw Normal View History

#include <LatAnalyze/Io/Io.hpp>
#include <LatAnalyze/Core/Mat.hpp>
#include <LatAnalyze/Core/Math.hpp>
using namespace std;
using namespace Latan;
int main(void)
{
2016-02-29 19:49:06 +00:00
DMat A(2, 3), B(3, 2), C = DMat::Random(6, 6);
const string fileName = "exMat.dat";
2014-03-12 19:54:27 +00:00
A << 1, 2, 3,
4, 5, 6;
B << 1.0, 2.5,
4.5, 8.9,
1.2, 3.5;
// read
2016-02-29 19:49:06 +00:00
cout << "A=\n" << A << '\n' << endl;
cout << "B=\n" << B << '\n' << endl;
cout << "A*B=\n" << A*B << '\n' << endl;
cout << "cos(A)=\n" << A.unaryExpr(StdMath::cos) << '\n' << endl;
cout << "C=\n" << C << '\n' << endl;
cout << "inv(C)=\n" << C.inverse() << '\n' << endl;
cout << "pinv(C)=\n" << C.pInverse() << '\n' << endl;
// write
2015-10-01 00:13:34 +01:00
cout << "-- saving and loading A*B using '" + fileName + "'..." << endl;
2015-10-07 19:03:19 +01:00
Io::save(A*B, fileName, File::Mode::write);
2015-10-01 00:13:34 +01:00
2016-02-29 19:49:06 +00:00
DMat D = Io::load<DMat>(fileName);
cout << D << endl;
2015-10-01 00:13:34 +01:00
return EXIT_SUCCESS;
}