Skip to content
forked from tschijnmo/drudge

CAS based on sympy focusing on tensor and noncommutative algebras

License

Notifications You must be signed in to change notification settings

chenpeizhi/drudge

 
 

Repository files navigation

https://circleci.com/gh/tschijnmo/drudge.svg?style=shield https://travis-ci.org/tschijnmo/drudge.svg?branch=master https://coveralls.io/repos/github/tschijnmo/drudge/badge.svg?branch=master

Drudge

Drudge is a symbolic algebra system built on top of the SymPy library with its primary focus on tensorial and non-commutative algebras. It is motivated by complex symbolic problems in quantum chemistry and many-body theory, but it could be useful for any tedious and error-prone symbolic manipulation and simplification in any problem with indexed quantities, symbolic summations, and non-commutative algebra.

Built on the generic algorithm for the canonicalization of combinatorial objects, like strings and graphs, in libcanon, drudge is able to find a canonical form for mathematical expressions with tensors with symmetries and symbolic summations. For instance, for a 4th-order tensor u with symmetry

u_{abcd} = -u_{bacd} = -u_{abdc} = u_{badc}

expression like

\sum_{cd} u_{acbd} \rho_{dc} - \sum_{cd} u_{cabd} \rho_{dc}
+ \sum_{cd} u_{cdbc} \rho_{cd}

can be automatically simplified into a single term like,

3 \sum_{cd} u_{acbd} \rho_{dc}

despite the initial different placement of the indices to the symmetric u tensor and different naming of the dummy indices for summations.

In addition to the full consideration of the combinatorial properties of symmetric tensors and summations during the simplification, drudge also offers a general system for handling non-commutative algebraic systems. Currently, drudge directly supports the CCR and CAR algebra for treating fermions and bosons in many-body theory, general Clifford algebras, and su(2) algebra in its Cartan-Killing basis. Other non-commutative algebraic systems should be able to be added with ease.

Based on the symbolic results from drudge, a companion package gristmill is able to automatically optimize and generate numerical code. For computations with heavy dependence on tensor contraction and sums of tensor contractions, substantial optimization could be given.

Drudge is developed by Jinmo Zhao and Prof Gustavo E Scuseria at Rice University, and was supported as part of the Center for the Computational Design of Functional Layered Materials, an Energy Frontier Research Center funded by the U.S. Department of Energy, Office of Science, Basic Energy Sciences under Award DE-SC0012575.

About

CAS based on sympy focusing on tensor and noncommutative algebras

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 90.4%
  • C++ 9.0%
  • Other 0.6%