ACM Home Page
Please provide us with feedback. Feedback
Optimal vertex elimination in single-expression-use graphs
Full text PdfPdf (345 KB)
Source
ACM Transactions on Mathematical Software (TOMS) archive
Volume 35 ,  Issue 1  (July 2008) table of contents
Article No. 2  
Year of Publication: 2008
ISSN:0098-3500
Authors
Uwe Naumann  RWTH Aachen University, Aachen, Germany
Yuxiao Hu  RWTH Aachen University, Aachen, Germany
Publisher
ACM  New York, NY, USA
Bibliometrics
Downloads (6 Weeks): 5,   Downloads (12 Months): 56,   Citation Count: 0
Additional Information:

abstract   references   index terms   collaborative colleagues  

Tools and Actions: Request Permissions Request Permissions    Review this Article  
DOI Bookmark: Use this link to bookmark this Article: http://doi.acm.org/10.1145/1377603.1377605
What is a DOI?

ABSTRACT

The source transformation tool for automatic differentiation of Fortran programs ADIFOR uses a preaccumulation technique to speed up tangent-linear codes significantly compared to the standard forward mode. Reverse mode automatic differentiation is applied to all scalar assignments to generate efficient code for the computation of local gradients. It has been well known for some time that reverse mode is not necessarily the optimal choice for the computation of these statement-level gradients as it does not minimize the number of operations required. This article presents an efficient algorithm for the solution of this combinatorial optimization problem. The corresponding software is freely available for downloading on our website. Developers of software for automatic differentiation are invited to integrate the algorithm into their tools.

Gradients of scalar multivariate functions can be computed by elimination methods on the linearized computational graph. The combinatorial optimization problem that aims to minimize the number of arithmetic operations performed by the elimination algorithm is known to be NP-complete. In this article we present a polynomial algorithm for solving a relevant subclass of this problem's instances. The proposed method relies on the ability to compute vertex covers in bipartite graphs in polynomial time. A simplified version of this graph algorithm is used in a research prototype of the differentiation-enabled NAGWare Fortran compiler for the preaccumulation of local gradients of scalar assignments in the context of automatic generation of efficient tangent-linear code for numerical programs.


REFERENCES

Note: OCR errors may be found in this Reference List extracted from the full text article. ACM has opted to expose the complete List rather than only correct and linked references.

 
1
Baur, W. and Strassen, V. 1983. The complexity of partial derivatives. Theoret. Comput. Sci. 22, 317--330.
 
2
Berz, M., Bischof, C., Corliss, G., and Griewank, A., Eds. 1996. Computational Differentiation: Techniques, Applications, and Tools. Proceedings Series. SIAM.
 
3
 
4
Bischof, C. and Haghighat, M. 1996. Hierarchical approaches to automatic differentiation. In Computational Differentiation: Techniques, Applications, and Tools. Proceedings Series. SIAM. 82--94.
 
5
 
6
 
7
Corliss, G. and Griewank, A., Eds. 1991. Automatic Differentiation: Theory, Implementation, and Application. Proceedings Series. SIAM.
8
 
9
Ford, L. and Fulkerson, D. 1962. Flows in Networks. Princeton University Press.
10
11
 
12
13
 
14
Griewank, A. and Reese, S. 1991. On the calculation of Jacobian matrices by the Markovitz rule. In Automatic Differentiation: Theory, Implementation, and Applications. Proceedings Series. SIAM. 126--135.
 
15
Griewank, A. and Vogel, O. 2003. Analysis and exploitation of Jacobian scarcity. In Proceedings of the International Conference on High Performance Scientific Computing (HPSC). Springer.
 
16
Harary, F. 1969. Graph Theory. Addison-Wesley.
 
17
Hopcroft, J. and Karp, R. 1973. An n5/2 algorithm for physics graphs. SIAM J. Comput. 2, 225--231.
18
 
19
König, D. 1931. Graphs and matrices (Hungarian). Mat. Fiz. Lapok 38, 116--119.
 
20
Naumann, U. 1999. Efficient calculation of Jacobian matrices by optimized application of the chain rule to computational graphs. Ph.D. thesis, Technical University Dresden, Dresden, Germany.
 
21
 
22
23
 
24
Naumann, U. and Riehme, J. 2006. Computing adjoints with the NAGWare Fortran 95 compiler. In Automatic Differentiation: Applications, Theory, and Tools. Lecture Notes on Computational Science and Engineering, vol. 50, Springer, Berlin, Germany.
 
25