一些数值计算的库
来源:互联网 发布:php代码注入原理 编辑:程序博客网 时间:2024/05/20 22:30
以下资料来源于OO Number
The Object-Oriented Numerics PageQuick Index
- Mailing lists
- Freely available libraries
- Freely available tools
- Commercial libraries and software
- Related Projects
- Reference material
- Conferences
- Related Web Indices
- Bibliography
Mailing lists
The Object-Oriented Numerics List is a forum for discussing scientific computing in object-oriented environments. An archive is available.
<!--Library developers have a separate reflector for discussing possiblestandard interfacesfor scientific computing components in C++.The archive is available, sorted bythread,date,subject orauthor.
There's also a list for C++ on high performance parallel computers, calledmpp-cxx.
-->To subscribe or unsubscribe, please visit this page.
Freely available libraries
- Linear Algebra
- PyMat, a matrix package for the Python programming language.
- JAMA, an elementary linear algebra package for Java.
- MTL, the Matrix Template Library. Dense and sparse matrices and vectors; banded, symmetric, triangular matrices; basic algorithms. C++.
- uBLAS, BLAS in C++ with expression templates.
- tvmet, a C++ library for "tiny" vectors and matrices with expression templates.
- GMM++, generic C++ template library for sparse, dense and skyline matrices, with solvers from ITL.
- dnAnalytics, C# numerics library, linear algebra, BLAS interface.
- MET, a C++ matrix library with expression templates, which eliminates the overhead of overloaded operators.
- SL++, the Scientific Library project. Will provide matrices, random numbers, complex, quaternions, plotting, and FFTs. C++.
- Seldon, C++ library for linear algebra with BLAS interface. Many matrix types (sparse, symmetric, hermitian, etc.) are supported.
- ALP, linear and polynomial algebra. Vectors, matrices, polynomials.
- SVMT: E. Robert Tisdale's proposal for a standard C++ Scalar, Vector, Matrix and Tensor Class Library (with implementation). Note: this is a proposal, not an official standard.
- GNUSSL [ftp only], the GNU Scientific Software Library. Linear algebra and arrays. C++.
- CPPLapack, C++ wrapper for BLAS and LAPACK.
- Lapack++, C++ wrapper for BLAS and LAPACK. <!--
- LAPACK++ (Linear Algebra PACKage in C++), solves systems of linear equations and eigenvalue problems on high performance computer architectures. -->
- IML++ A C++ template library for numerical iterative methods.
- MV++ Numerical Matrix/Vector Classes in C++
- SparseLib++ A library for sparse matrix computations, including the Sparse BLAS (Basic Linear Algebra Subprograms). C++.
- ISIS++, an object-oriented framework for solving sparse linear systems of equations. C++.
- ARPACK++, a C++ template library for solving large-scale standard and generalized eigenvalue problems.
- The Template Numerical Toolkit (TNT) for linear algebra is a successor to the Lapack++, Sparselib++, IML++, and MV++ packages. Its goal is to integrate these ideas into a generic algorithmic library, supporting generic user-defined data types, and increasing its functionality. C++.
- LinAlg, basic linear algebra and optimization classes. C++. <!--
- MatClass, general-purpose real, dense matrix; includes decompositions. C++. -->
- CAM C++ Class Library (Matrix, vector, and graphics classes)
- Newmat, a C++ matrix library (docs, download)
- CLHEP includes matrix classes, random number generators for the High Energy Physics (HEP) community. C++.
- BPKIT, Block Preconditioning Toolkit for iterative solution of linear systems. Callable from C++, C, or FORTRAN.
- FreePOOMA framework for scientific computing on sequential and parallel computers. C++.
- The Blitz++ class library: Array and Vector classes which rival Fortran's performance. C++.
- The AIPS++ Array and Image Classes (Astronomical Information Processing System). C++.
- Daixtrose, a general-purpose expression template engine.
- PETE, an expression templates library -- add expression templates to your own array class.
- SCTL (BlueSail), C++, arrays, matrics, vectors, sparse, rotations.
- NumPy, Numerical extensions to Python.
- VIGRA, generic computer vision/image processing library.
- CPPIMA A C++ image processing library
- LIMP, Large Image Manipulation Program
- Image Restoration and Inpainting, C++ library for image restoration.
- valarray<Troy> [ftp only], approximation of the valarray<T> class described in Ch. 26 of the ANSI/ISO C++ Standard. Uses expression templates for efficient evaluation.
- Image Understanding Environment (IUE), a DARPA project. C++.
- WAILI, a wavelet transform library in C++.
- PDP++, a neural-network simulation system written in C++
- EO -- Evolutionary Computation Framework
- CONICAL, C++ classes for building Neural Networks
- GALib, a C++ library for genetic algorithms
- Xelopes data mining library (Java, C++, C#)
- MLC++, Machine learning algorithms and data mining.
- QC++, quantum chemistry software in C++, supporting MNDO, AM1 and PM3 models.
- FTensor, C++ class library for tensors.
- GluCat, Clifford algebra template library.
- Computational Thermodynamics Library
- Tech-X has made available C++ libraries related to particle accelerator design.
- NTL, arbitrary length integers, vectors/matrices/polynomials over integers and over finite fields.
- EXTNUM, version of double which has the same number of mantissa bits as IEEE 754, but extends the exponent to have range from 10^-646456993 to 10^646456992.
- CLN, an extensive number library. Arbitrary precision integer, float, rational, polynomials, complex, modular integers, transcendental functions, assembly language kernels for some CPUs.
- MUNTL, Multiprecision unsigned number template library (C++).
- MPFUN++, a multiple precision floating point computation package in C++.
- LiDIA, A library for computational number theory. Provides a collection of highly optimized implementations of various multiprecision data types and time-intensive algorithms.
- Apfloat, a C++ High Performance Arbitrary Precision Arithmetic Package
- hfloat, An arbitrary precision package, optimized for very large (> 1000) (decimal) digit numbers.
- fPoint, a C++ class which helps convert floating-point arithmetic to fixed-point arithmetic by recommending range and precision requirements.
- doubledouble, a quad-precision (approximately 30 decimal place) floating point arithmetic class.
- Rheoolef, finite element environment in C++.
- EXPDE, a C++ library for solving partial differential equations on semi-unstructured grids. Parallel.
- PZ, a C++ library for finite elements. 1-3 dimensions with hp-adaptivity, continuous or discontinuous, variety of matrix formats.
- MBDyn, multibody dynamics analysis in C++. Built-in parallelization via MPI/Metis.
- P2MESH, 2D finite volume/finite elements, C++ library designed for fast prototyping of high-performance PDE solvers.
- Femlisp, a Common Lisp framework for Finite Element Methods.
- GETFEM++, a C++ finite element library, generic, arbitrary dimensions.
- MOUSE, a C++ library for finite volume computations on unstructured grids.
- DEAL, a C++ library for adaptive finite elements and error estimation. Supports SMPs.
- ODE++, a class library for ordinary differential equations. Explicit and linear-implicit ODE systems, IVP and BVP parameters, various solvers (Runge-Kutta, multistep, BDF). [English] [Deutsch] <!--
- Godess, a C++ library for solving ODEs and DAEs. -->
- Gaol, C++ library for interval arithmetic. Includes methods for interval constraint solvers.
- FADBAD-TADIFF, a C++ package for automatic differentiation using any arithmetic (double or interval) by operator overloading.
- PROFIL/BIAS [English] [Deutsch], a C++ interval arithmetic class library.
- The Visualization Toolkit (vtk), an extensive, free C++ library for scientific visualization.
- VisAD, a Java library for interactive and collaborative visualization and analysis of numerical data
- Java 2D Graph package. Includes contour plots, animation.
- Ptplot, a 2D data plotter in Java
- Boost Graph Library, a general purpose, generic C++ library for graph data structures and graph algorithms.
- GTL, the Graph Template Library (C++).
- LEDA, a C++ library for graph theory and combinatorial computing.
- CPPF77 (cppf77.zip), a utility for interfacing C++ and Fortran 77 programs.
- Paul Dubois's code for interfacing Python and C++
- SWIG, generates Perl, Python, Tcl, Java, Eiffel and Guile wrappers for C++ libraries.
- SILOON (Scripting Interface Languages for Object-Oriented Numerics), toolkits and run-time support for building scripting interfaces to existing numerical codes in C, C++, and Fortran. Generates script bindings for Perl, Tcl, and Python.
- Matwrap, a tool which generates C++ wrapper code for matrix-oriented scripting languages such as Matlab 5, Octave, and tela.
- FFTPACK++, a C++ wrapper for FFTPACK complex routines using LAPACK++ Matrix and Vector classes.
- The FXT library of transforms. FFTs, Hartley, Number theoretic, Walsh, others coded in C++.
- COOOL, an object-oriented optimization library
- OptSolve++, a C++ optimization library from Tech-X. (commercial)
- StarFLIP, optimization library for combinatorial problems with fuzzy constraints (C++)
- LM (Levenberg-Marquardt) implementation in Java for nonlinear least squares problems.
- GOOSE, GNU Object-Oriented Statistics Environment (C++).
- Borneo, a dialect of the Java language designed to have true support for the IEEE 754 floating point standard.
- SDTS++, a library for manipulating SDTS datasets (geographical information systems)
- Newran, C++ library for generating streams of random numbers.
- Multivariate polynomial interpolation library in C++
- MPI-2 C++ bindings (message passing library for parallel computers)
- CNCL, Communication networks simulation/analysis library (C++).
- OOMF, Object Oriented MicroMagnetic computing Framework at ITL/NIST
- CPPF77, a utility for interfacing C++ and Fortran 77 programs.
- The Standard Template Library (STL) <!--
- QMV (Quaternion Matrix Vector Library), a group of Unix C++ routines used to express geometric relationships. -->
- TAU (Tuning and Analysis Utilities), explicit instrumentation of C++ libraries for profiling and tracing. For both serial and parallel codes. <!--
- PAWS (Parallel Application Work Space), a framework for coupling parallel applications using high-speed parallel communication channels. Uses Nexus. -->
Compilers
- Compilers
- KAI C++, an optimizing compiler from Kuck & Associates (now a division of Intel). Unfortunately, this product has been discontinued.
- The free GCC (Gnu Compiler Collection) has a good C++ compiler which can be used under unix or windows (with CygWin).
- Intel's C++ compiler.
- The Portland Group C++ compiler
- The MPC++, a massively parallel, message passing, meta-level processing C++.
- Titanium (free), a dialect of Java for large-scale scientific computing.
Commercial software- Diffpack, a development framework for multi-physics simulations (C++).
- VectorSpace provides vs.lib (integrable/differentiable objects in C++) and fe.lib (an object-oriented finite element library).
- NMath provides vector, matrix, complex numbers and math functions for the .NET platform (e.g. C#)
- macstl, std::valarray implementation using SIMD opcodes (Altivec on PowerPC, SSE/SSE2 on Intel)
- ExacMath library (quad and double-quad precision floating point math), from Floating Point Software.
- Math.h++ and LAPACK.h++ from Rogue Wave Software, Inc (LAPACK.h++ is not the same package as Roldan Pozo's LAPACK++ listed above)
- MtxVec, linear algebra/numerical library for Delphi and C++ Builder.
- Extreme Optimization Library, numerical library for .NET <!--
- M++ Mathematical class library from Dyad Software, Inc. -->
- MAT<LIB> (Matlab compatible C++ Matrix Class Library)
- C-XSC: A C++ Class Library for Extended Scientific Computing (A C++ interval methods class library)
- Siscat, C++ software for scattered data approximation <!--
- ObjectSuite, from Visual Numerics, includes Math, Signal Processing, and Chart modules for C++. -->
- JNL, A numerical language/library proposal for Java from Visual Numerics.
- LIA,GIA,ICE libraries for interval methods in C++ from Delisoft Ltd. Includes interval arithmetic, global optimization, and solving nonlinear equations.
- AMRES, a C++ library for financial analysis.
Related projects
- <!-- <a href="http://info.desy.de/user/projects/C++/HEP.html"> --><!-- Object-oriented Programming in High Energy Physics -->
- The Java Grande Forum, high performance Java computing.
- Java Numerics Working Group at NIST.
- The National (American) HPCC Software Exchange (NHSE)
- The High Performance C++ (HPC++) Project <!--
- SciTL (Scientific Template Library), a US Dept. of Energy initiative -->
- LHC++, class libraries for the high-energy physics community.
Reference Material
- Bernd Mohr's course on C++ in postscript or pdf. These slides are geared toward scientific users.
- Todd V's notes on Techniques for Scientific C++. Also available in Postscript.
- C++ Programming for Scientists, course slides by Roldan Pozo and Karen Remington <!--
- Online book: A Survey of Object-Oriented Tools for Parallel and Scientific Computing (Marchand Olivier). Warning: from 1995, now out of date. --><!--
- The April 1995 ANSI/ISO C++ Standards Committee Working Paper, particularly:
- The class complex<T>, template complex number class
- Class valarray<T>, one-dimensional numerical array supporting subscripting and slicing
- The traits class numeric_limits<T>, provides access to machine epsilon, min/max values, etc. for numerical template functions
- Generalized numeric operations, STL-style operations for numeric arrays: accumulate(), inner_product(), partial_sum(), adjacent_difference()
--> - Fortran 2000 will introduce many object-oriented features (click on "Content of Fortran 2000" to see working papers)
- Paper: C++ Gets Faster for Scientific Computing, by Arch Robison, from Computers In Physics
- Paper: Expression Templates, a C++ template technique for evaluating matrix and vector expressions efficiently.
- Paper: Template Metaprograms, a method for compile-time algorithm specialization in C++.
- Paper: Comparison of C++ and Fortran 90 for Object-Oriented Scientific Programming <!--
- Slides: C++ vs. F90: Language Features and Syntax -->
- High Performance Object-Oriented Programming in Fortran 90
Conferences
- POOSC 2003, Parallel Object-Oriented Scientific Computing, July 22, Darmstadt, Germany
- Joint ACM Java Grande - ISCOPE 2001 Conference, Stanford University, California, June 2-4, 2001
- Java Grande 2000, San Francisco, California, June 3-5, 2000
- ISCOPE'99: International Symposium on Computing in Object-oriented Parallel Environments, December 7-10 1999, San Francisco, California
- POOSC'99 Workshop on Parallel/High-performance Object-Oriented Scientific Computing at the European Conference on Object-Oriented Programming (ECOOP'99), Lisbon, Portugal, June 14-18.
- ACM 1999 Java Grande Conference, Palo Alto, California, June 12-14.
- ISCOPE'98: International Symposium on Computing in Object-oriented Parallel Environments, December 8-11 1998, Santa Fe, New Mexico
- SIAM Workshop on Object-Oriented Methods for Inter-operable Scientific and Engineering Computing, October 21-23, 1998, Yorktown Heights, New York
- SciTools'98: Workshop on Modern Software Tools for Scientific Computing, Sept. 14 - 16, Oslo, Norway
- POOSC'98: Workshop on Parallel Object-Oriented Scientific Computing, Brussels, Belgium, July 20-24 1998.
- ACM 1998 Workshop on Java for High-Performance Network Computing, Palo Alto, California, February 28 and March 1, 1998.
- International Scientific Computing in Object-Oriented Parallel Environments (ISCOPE'97), Marina del Rey, California, December 8-11, 1997.
- Physics Computing'97, Santa Cruz, California, August 25-28, 1996. Included a session on object-oriented methods.
- ACM 1997 Workshop on Java for Science and Engineering Computation June 21-27, 1997. <!--
- Computing in High Energy Physics (CHEP'97), Berlin, April 7-11, 1997. Several of the papers described experiences with object-oriented approaches. -->
- SciTools'96: Workshop on Modern Software Tools for Scientific Computing, Sept. 16 - 18, Oslo, Norway
- Object Oriented Numerics Conference (OONSCI'96) (broken URL) Mississippi State University, March 27-29, 1996
- International Workshop on Parallel C++, Kanazawa, Japan March 10-12, 1996
- POOMA'96: Parallel Object-Oriented Methods and Applications Conference, Feb. 28 - Mar. 1, Santa Fe, New Mexico
Related Web Indices
- <!--
- sci@{Codepage} -->
- 6dof.com, Simulation and Finite Elements web Portal
- Java for Scientific Computing
- Netlib Repository, the source for free scientific/numerical codes. Predominantly C and Fortran.
- Free C/C++ Sources for Numerical Computation
- GAMS Problem Decision Tree, a hierarchical guide to numerical libraries.
- WWW C++ information from Forschungszentrum Juelich
- The Linux Software Encyclopaedia: C++
- Linux Software for Scientists
- Parallel C++ Projects Archive
- Numerical Analysis Objects (NAO) at IBM
- Parallel Programming with C++ web index from Forschungszentrum Juelich
- The Internet Parallel Computing Archive's page about Parallel C++
- A Summary of Research in Object-Oriented Programming
- Cetus Links - Thousands of Links on Objects and Components
- Mathworks has a decent index of scientific C++ and Java.
- An index of C++ Libraries for various applications, from DESY
- Available C++ libraries FAQ
- Yoyodyne: Object-Oriented Programming in Engineering
- SAL: Scientific Applications on Linux
- Long list of mathematical software packages (not just OO) from the Mathematics Archives
- The Object-Oriented Page, long list of object-oriented resources.
- 一些数值计算的库
- 一些数值计算的知识
- Python 数值计算的一些常见问题 --- 长期维护
- 关于Java中数值计算的一些误区
- python的Scipy数值计算库
- 数值计算的性质
- 变量的数值计算
- 常用数值计算库
- 常用数值计算库
- 常用数值计算库
- 常用数值计算库
- 常用数值计算库
- SciPy-数值计算库
- SciPy-数值计算库
- 常用数值计算库
- SciPy-数值计算库
- SciPy-数值计算库
- SciPy-数值计算库
- TCP/IP指南(卷1):OSI参考模型
- 软件开发的四大基础
- Hibernate基础教程(3-2)
- USB研究(一)
- 再次随便侃侃:看白乔老师的笔记有感
- 一些数值计算的库
- 我的第一个CSDN空间。。
- [书摘]迭代器适配器
- [书摘]c/c++中的一些算法
- [转]整洁代码的4个提示
- 函数修改CListCtrl的排序属性
- 采用弹出气泡方式进行客户端输入验证
- ACM小组内部预定函数
- 《白话C++》第1章 启蒙 1.3 什么是硬件、软件