博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
高性能Java科学与技术运算库Colt
阅读量:5896 次
发布时间:2019-06-19

本文共 1719 字,大约阅读时间需要 5 分钟。

  在学习《Machine Learning in Action》和《NLTK Natural Language Processing with Python》的过程中,我真切地感受到Numpy库的便捷与强大,线性代数的数据结构与运算封装得浅显易懂。不过Numpy或者Python有两个很致 命的缺点:①弱类型导致我无法看到深层对象中的注释。②运行效率无法满足生产需要。我在想Java平台上是否有比较成熟的数学库,类似于Numpy这样简 洁强大,同时又文档完整。没想到还真的有,在StackOverflow上有人问“Java equivalent for the Numpy multi-dimensional object”,得票最高的答案就是Colt。

  Colt简介

  Colt是一个高性能的数学库,由以下几个子库构成:

  Colt库:基本的动态数组、稀疏矩阵、线性代数。

  Jet库:数理统计、直方图。

  CoreJava库:类printf的打印函数,

  文档

  详细的文档在http://acs.lbl.gov/software/colt/api/overview-summary.html

  实例

  挑我急着用的矩阵来说:

  package com.hankcs;

  import cern.colt.matrix.DoubleMatrix2D;

  import cern.colt.matrix.impl.DenseDoubleMatrix2D;

  import cern.colt.matrix.linalg.Algebra;

  public class Main

  {

  public static void main(String[] args)

  {

  DoubleMatrix2D matrix;

  matrix = new DenseDoubleMatrix2D(3,4);

  //matrix = new SparseDoubleMatrix2D(3,4); // 稀疏矩阵

  //matrix = new RCDoubleMatrix2D(3,4); //

  System.out.println("初始矩阵");

  System.out.println(matrix);

  System.out.println("填充");

  matrix.assign(new double[][]{

{1, 2, 3, 4},{5, 6, 7, 8},{9, 10, 11, 12}});

  System.out.println(matrix);

  System.out.println("转置");

  DoubleMatrix2D transpose = Algebra.DEFAULT.transpose(matrix);

  System.out.println(transpose);

  System.out.println("矩阵乘法");

  System.out.println(Algebra.DEFAULT.mult(matrix, transpose));

  }

  }

  复制代码

  输出:

  初始矩阵

  3 x 4 matrix

  0 0 0 0

  0 0 0 0

  0 0 0 0

  填充

  3 x 4 matrix

  1 2 3 4

  5 6 7 8

  9 10 11 12

  转置

  4 x 3 matrix

  1 5 9

  2 6 10

  3 7 11

  4 8 12

  矩阵乘法

  3 x 3 matrix

  30 70 110

  70 174 278

  110 278 446

  复制代码

  由于Java不能重载运算符,所有的运算符都是通过更多运算请参考 http://acs.lbl.gov/software/colt ... linalg/Algebra.html

转载于:https://www.cnblogs.com/anjijiji/p/6370521.html

你可能感兴趣的文章
Unity 性能优化(力荐)
查看>>
Python菜鸟之路:Jquery Ajax的使用
查看>>
C# 时间戳转换为时间方法
查看>>
大话GIS(转载)
查看>>
Android软件加安全码
查看>>
091、万能的数据收集器 Fluentd (2019-05-15 周三)
查看>>
20条Linux命令面试问答(转载)
查看>>
LeetCode算法题-Maximum Depth of Binary Tree
查看>>
POJ - 3436 ACM Computer Factory(最大流)
查看>>
浅析socket与http (转载)
查看>>
[线程]线程池
查看>>
浏览器内多个标签页之间的通信之storage
查看>>
sha1withRSA算法
查看>>
git分支的创建与合并
查看>>
ibatis.net学习笔记(五) 带条件查询语法
查看>>
C语言第十次博客作业--结构体
查看>>
让简历一发即中三大绝招
查看>>
Vim和操作系统剪贴板交互
查看>>
使用ExposedObject对Asp.net MVC中匿名类型的JsonResult做单元测试
查看>>
ajax省市县联动
查看>>