R与JAVA的混合编程

我这里将UJMP包中的Matrix类型转化为二维数组再转化为,一维数组,再转换为R中的矩阵,获取矩阵返回二维数组也有相应的描述

注意:在使用时一定要加载Rserve服务,如果不是R系统中的包,还需加载包名。

 int genoRCnt = (int) geno.getRowCount();
        int genoCCnt = (int) geno.getColumnCount();
        int phenoRCnt = (int) pheno.getRowCount();
        int phenoCCnt = (int) pheno.getColumnCount();
        double[] genoArray = new double[genoCCnt * genoRCnt];
        double[] phenoArray = new double[phenoRCnt * phenoCCnt];
        long begin = System.currentTimeMillis();
        {//Translate Matrix geno In Java To Matrix In R
            int k1 = 0;
            for (int i = 0; i < genoRCnt; i++) {
                for (int j = 0; j < genoCCnt; j++) {
                    genoArray[k1++] = geno.getAsDouble(i, j);
                }
            }
            c.assign("genoR", genoArray);
            c.voidEval("GenoInR<-matrix(genoR," + genoRCnt + "," + genoCCnt + ",TRUE" + ")");
//            REXP phenoY = c.eval("GenoInR");
//            MatrixFactory.importFromArray(phenoY.asDoubleMatrix()).showGUI();
        }
        {//Translate Matrix pheno In Java To Matrix In R
            int k2 = 0;
            for (int i = 0; i < phenoRCnt; i++) {
                for (int j = 0; j < phenoCCnt; j++) {
                    phenoArray[k2++] = pheno.getAsDouble(i, j);
                }
            }
            c.assign("phenoR", phenoArray);
            c.voidEval("PhenoInR<-matrix(phenoR," + phenoRCnt + "," + phenoCCnt + ",TRUE" + ")");
        }

 

posted @ 2015-03-26 21:29  暴走的豆浆  阅读(786)  评论(1编辑  收藏  举报