Armadillo with Visual Studio Community 2022 guide
This guide works with Windows 10 (or Server), Visual Studio Community 2022 and Intel® oneAPI Math Kernel Library version 2021.4.0.
1. Visual Studio (VS) Community 2022
Install Visual Studio Community 2022 from https://visualstudio.microsoft.com/.
data:image/s3,"s3://crabby-images/20187/2018710ba1a0ba291681cc9d836e7d65909172b8" alt=""
You only need to choose Desktop development with C++ option.
data:image/s3,"s3://crabby-images/02e1f/02e1f8c2dc980384093835989a4aca629940ed23" alt=""
Now your VS is ready to run.
2. Armadillo CPP library
This library is for matrix operations in CPP.
Download the most recent Armadillo CPP library (armadillo-xx.x.x.tar.xz) from http://arma.sourceforge.net/download.html.
You will need unzip program to open the file (7-zip: https://www.7-zip.org/). Unzip the file to a convenient location.
3. Intel® oneAPI Math Kernel Library (MKL)
Down load the Intel MKL library from https://www.intel.com/content/www/us/en/developer/tools/oneapi/onemkl.html#gs.irg94x.
data:image/s3,"s3://crabby-images/e79c3/e79c31ffb1695de09c273953078e0ac2878b38c3" alt=""
Once you downloaded, install only Intel oneAPI Math Kernel Library.
data:image/s3,"s3://crabby-images/0b29f/0b29f7f01643286c8ddb5b57907b8ee2a4874fcc" alt=""
4. Create a new project with Armadillo
Create a new project in VS with “Console App” option. Choose a location and name of the project. I gave project name “ArmadilloEx”.
data:image/s3,"s3://crabby-images/204fc/204fcdda794865f5a18ae400a1e0085100ad308c" alt=""
data:image/s3,"s3://crabby-images/37476/374769085f7e8709faa87fc89865b5a5e4e1a500" alt=""
Then your project folder will look like this.
data:image/s3,"s3://crabby-images/33512/33512f758226c92908935d871ed8545b03fd1b80" alt=""
Copy/paste Armadillo files to your project (“armadillo-10.7.4″ folder).
data:image/s3,"s3://crabby-images/3c34a/3c34ad4a36698fabe26fb1064786a3d9db8dfdf2" alt=""
Copy/paste Intel MKL files to your project (“mkl” folder).
data:image/s3,"s3://crabby-images/481a9/481a95427d2bcc13bc88e0cd0eb8f95148ad933c" alt=""
Now, your project folder should look like this.
data:image/s3,"s3://crabby-images/a0d54/a0d543be76d604e01090c152b2d645feac5e73cb" alt=""
5. Setup VS to use Armadillo
Choose project name (“ArmadilloEx”) in the Solution Explorer window and right click –> Properties –> C/C++ –> General –> Additional Include Directories, and set as below for both Armadillo and MKL.
data:image/s3,"s3://crabby-images/dc20d/dc20d890e3204948e5b86eca621689bbb0a4e505" alt=""
Choose project name (“ArmadilloEx”) in the Solution Explorer window and right click –> Properties –> Linker –> General –> Additional Library Directories, and set as below.
data:image/s3,"s3://crabby-images/1ab1a/1ab1a7a1ddba21d5316da1d6454e1fc8b4fa4956" alt=""
Choose project name (“ArmadilloEx”) in the Solution Explorer window and right click –> Properties –> Linker –> Input –> Additional Dependencies, and set (type) as below.
data:image/s3,"s3://crabby-images/7cc12/7cc12008216f18764c0c21660fd3e8e639a93f1b" alt=""
You are all set!
6. Run this example at ArmadilloEx.cpp.
#include <iostream> #include <armadillo> int main() { std::cout << "Hello World!\n"; // Initialize the random generator arma::arma_rng::set_seed_random(); // Create a 4x4 random matrix and print it on the screen arma::Mat<double> A = arma::randu(4, 4); std::cout << "A:\n" << A << "\n"; // Multiply A with his transpose: std::cout << "A * A.t() =\n"; std::cout << A * A.t() << "\n"; // Access/Modify rows and columns from the array: A.row(0) = A.row(1) + A.row(3); A.col(3).zeros(); std::cout << "add rows 1 and 3, store result in row 0, also fill 4th column with zeros:\n"; std::cout << "A:\n" << A << "\n"; // Create a new diagonal matrix using the main diagonal of A: arma::Mat<double>B = arma::diagmat(A); std::cout << "B:\n" << B << "\n"; // Save matrices A and B: A.save("A_mat.txt", arma::arma_ascii); B.save("B_mat.txt", arma::arma_ascii); }