File: rinside_arma1.cpp

package info (click to toggle)
r-cran-rinside 0.2.19-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 668 kB
  • sloc: cpp: 3,310; ansic: 117; xml: 57; ruby: 34; makefile: 2
file content (28 lines) | stat: -rw-r--r-- 975 bytes parent folder | download | duplicates (5)
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
// -*- c-indent-level: 4; c-basic-offset: 4; indent-tabs-mode: nil; -*-
//
// Simple example using Armadillo on matrix data generated in R
//
// Copyright (C) 2012 - 2013  Dirk Eddelbuettel and Romain Francois

#include <RcppArmadillo.h>      	// for Armadillo as well as Rcpp 
#include <RInside.h>                    // for the embedded R via RInside

int main(int argc, char *argv[]) {

    RInside R(argc, argv);		// create an embedded R instance

    std::string cmd = "set.seed(42); matrix(rnorm(9),3,3)"; 	// create a random Matrix in r 

    arma::mat m = Rcpp::as<arma::mat>(R.parseEval(cmd)); // parse, eval + return result
    arma::mat n = m.t() * m;
    double nacc = arma::accu(n);
    double nrnk = arma::rank(n);

    m.print("Initial Matrix m"); 			// initial random matrix
    n.print("Product n = m' * m");		 	// product of m' * m
    std::cout << "accu(n) " << nacc << " " 
	      << "rank(n) " << nrnk << std::endl; 	// accu() and rank()

    exit(0);
}