CalculationHistory - Maple Help
For the best experience, we recommend viewing online help using Google Chrome or Microsoft Edge.

Online Help

All Products    Maple    MapleSim


DifferentialGeometry[Tools]

  

CalculationHistory

 

Calling Sequence

Parameters

Description

Examples

Calling Sequence

CalculationHistory:-Update(S, exp)

CalculationHistory:-Get(S)

CalculationHistory:-Clear()

Parameters

S

-

an unassigned name or string

exp

-

any Maple expression

Description

• 

The CalculationHistory module is a collection of three simple commands for storing and retrieving the results of intermediate calculations.  The command Update(S, exp) stores the Maple expression exp in a table (called the HistoryTable) with table index S.  Only the 10 most current values of exp are retained in the HistoryTable.  The command Get(S) retrieves these values.  The command Clear() clears all stored values in the HistoryTable.

• 

At present, the commands Query/Indecomposable, Decompose and Nilradical use the CalculationHistory module and store intermediate results which can be recalled.

• 

The number of calculations stored in the HistoryTable can be specified by the DifferentialGeometry:-Preferences command.

• 

This command is part of the DifferentialGeometry:-Tools package, and so can be used in the form CalculationHistory:-Update(...) only after executing the commands with(DifferentialGeometry) and with(Tools) in that order.  It can always be used in the long form DifferentialGeometry:-Tools:-CalculationHistory:-Update.  The commands Get and Clear work the same way.

Examples

withDifferentialGeometry:withTools:withLieAlgebras:

exportsCalculationHistory

Clear,Get,Update

(1)

 

Example 1.

We begin with a simple example to illustrate the use of the three exports of the CalculationHistory module.  The program Test computes the sum of squares of the first n integers.  The Update command stores the individual terms in the sum.

Test := proc(n)
local i, s, t;
s := 0;
for i to n do
t := i^2;
Tools:-CalculationHistory:-Update("Test", [i, t]);
s := s + t;
od;
s
end:

 

Run the program test.

Test25

5525

(2)

Retrieve the calculated values from the HistoryTable -- only 10 values are stored.

Tools:-CalculationHistory:-GetTest

25,625,24,576,23,529,22,484,21,441,20,400,19,361,18,324,17,289,16,256

(3)

Clear all calculated values.

Tools:-CalculationHistory:-ClearTest

(4)

 

 Example 2.

The following example is taken from the help file for the LieAlgebras command Decompose.  A critical step in the algorithm involves factoring a certain polynomial.  This polynomial is stored in the HistoryTable under the index "Decompose."

L_DGLieAlgebra,Alg3,4,1,3,2,2,1,4,1,1,2,3,1,1,2,4,2,1

Le1,e3=2e2,e1,e4=e1,e2,e3=e1,e2,e4=e2

(5)

DGsetupL

Lie algebra: Alg3

(6)

Decompose:

Warning, the Lie algebra "Alg3:2" is decomposable but an explicit decomposition could not be constructed.  See CalculationHistory and rerun Decompose with optional argument hint.

CalculationHistory:-GetDecompose

Alg3,1+_z5,12+_z52

(7)

 

To perform the decomposition of the algebra, a factorization of the polynomial -1/2 + _z1^2 is required.  We perform this factorization by hand and rerun the DecomposeLieAlgebra program using the hint option to pass the program the information it needs.

Decomposehint=x,x212,x1sqrt2,x+1sqrt2

,e1+2e2,e3+2e4,e12e2,e32e4

(8)

See Also

DifferentialGeometry

LieAlgebras

Decompose

Preferences