Maxima
Maxima
Version 5.45.0
Maxima is a computer algebra system, implemented in Lisp.
Maxima is derived from the Macsyma system, developed at MIT in the years 1968 through
1982 as part of Project MAC. MIT turned over a copy of the Macsyma source code to the
Department of Energy in 1982; that version is now known as DOE Macsyma. A copy of DOE
Macsyma was maintained by Professor William F. Schelter of the University of Texas from
1982 until his death in 2001. In 1998, Schelter obtained permission from the Department
of Energy to release the DOE Macsyma source code under the GNU Public License, and
in 2000 he initiated the Maxima project at SourceForge to maintain and develop DOE
Macsyma, now called Maxima.
                                                                                                              i
Short Contents
1     Introduction to Maxima . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
2     Bug Detection and Reporting . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
3     Help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
4     Command Line . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
5     Data Types and Structures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
6     Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
7     Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
8     Evaluation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131
9     Simplification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143
10 Mathematical Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161
11 Maxima’s Database . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189
12 Plotting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209
13 File Input and Output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 241
14 Polynomials . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
15 Special Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 287
16 Elliptic Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313
17 Limits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319
18 Differentiation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 321
19 Integration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 335
20 Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 357
21 Differential Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 377
22 Numerical . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 381
23 Matrices and Linear Algebra . . . . . . . . . . . . . . . . . . . . . . . . . . . 399
24 Affine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 425
25 itensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 429
26 ctensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 463
27 atensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 491
28 Sums, Products, and Series . . . . . . . . . . . . . . . . . . . . . . . . . . . . 495
29 Number Theory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 515
30 Symmetries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 537
31 Groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 555
32 Runtime Environment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 557
33 Miscellaneous Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 565
ii
70 linearalgebra . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1017
71 lsquares . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1031
72 minpack . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1041
73 makeOrders . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1043
74 mnewton . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1045
75 numericalio . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1047
76 odepack . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1053
77 operatingsystem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1057
78 opsubst . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1059
79 orthopoly . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1061
80 pytranslate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1073
81 ratpow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1079
82 romberg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1081
83 simplex . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1085
84 simplification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1089
85 solve rec . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1099
86 stats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1105
87 stirling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1123
88 stringproc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1125
89 to poly solve . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1149
90 unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1169
91 wrstcse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1179
92 zeilberger . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1183
93 Error and warning messages . . . . . . . . . . . . . . . . . . . . . . . . . . 1187
94 Command-line options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1191
A Function and Variable Index . . . . . . . . . . . . . . . . . . . . . . . . . . 1193
                                                                                                                                        v
Table of Contents
1 Introduction to Maxima . . . . . . . . . . . . . . . . . . . . . . . . 1
3      Help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
    3.1      Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
    3.2      Functions and Variables for Help. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
4      Command Line . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
    4.1      Introduction to Command Line . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
    4.2      Functions and Variables for Command Line . . . . . . . . . . . . . . . . . . . . 15
    4.3      Functions and Variables for Display . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
6      Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
    6.1      Introduction to Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
    6.2      Nouns and Verbs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
    6.3      Identifiers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
    6.4      Inequality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
    6.5      Functions and Variables for Expressions. . . . . . . . . . . . . . . . . . . . . . . . 87
vi
7      Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
     7.1     Introduction to operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
     7.2     Arithmetic operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
     7.3     Relational operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
     7.4     Logical operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118
     7.5     Operators for Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 119
     7.6     Assignment operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121
     7.7     User defined operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
8      Evaluation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131
     8.1     Functions and Variables for Evaluation . . . . . . . . . . . . . . . . . . . . . . . 131
9      Simplification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143
     9.1     Introduction to Simplification. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143
     9.2     Functions and Variables for Simplification . . . . . . . . . . . . . . . . . . . . 145
12         Plotting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209
     12.1     Introduction to Plotting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209
     12.2     Plotting Formats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209
     12.3     Functions and Variables for Plotting . . . . . . . . . . . . . . . . . . . . . . . . . 210
     12.4     Plotting Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 227
     12.5     Gnuplot Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236
     12.6     Gnuplot pipes Format Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239
14    Polynomials . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
 14.1      Introduction to Polynomials . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
 14.2      Functions and Variables for Polynomials . . . . . . . . . . . . . . . . . . . . . 257
17    Limits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319
 17.1      Functions and Variables for Limits. . . . . . . . . . . . . . . . . . . . . . . . . . . 319
18    Differentiation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 321
 18.1      Functions and Variables for Differentiation . . . . . . . . . . . . . . . . . . . 321
19    Integration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 335
 19.1 Introduction to Integration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 335
 19.2 Functions and Variables for Integration . . . . . . . . . . . . . . . . . . . . . . 335
 19.3 Introduction to QUADPACK . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 345
    19.3.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 346
 19.4 Functions and Variables for QUADPACK . . . . . . . . . . . . . . . . . . . . 347
20    Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 357
 20.1      Functions and Variables for Equations . . . . . . . . . . . . . . . . . . . . . . . 357
22           Numerical . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 381
       22.1      Introduction to fast Fourier transform . . . . . . . . . . . . . . . . . . . . . . . 381
       22.2      Functions and Variables for fft . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 381
       22.3      Functions and Variables for FFTPACK5 . . . . . . . . . . . . . . . . . . . . . 385
       22.4      Functions for numerical solution of equations . . . . . . . . . . . . . . . . 387
       22.5      Introduction to numerical solution of differential equations . . . 389
       22.6      Functions for numerical solution of differential equations . . . . . 390
24           Affine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 425
       24.1      Introduction to Affine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 425
       24.2      Functions and Variables for Affine . . . . . . . . . . . . . . . . . . . . . . . . . . . 425
25           itensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 429
       25.1 Introduction to itensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 429
          25.1.1 New tensor notation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 430
          25.1.2 Indicial tensor manipulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 430
       25.2 Functions and Variables for itensor . . . . . . . . . . . . . . . . . . . . . . . . . . 433
          25.2.1 Managing indexed objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 433
          25.2.2 Tensor symmetries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 442
          25.2.3 Indicial tensor calculus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 444
          25.2.4 Tensors in curved spaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 448
          25.2.5 Moving frames . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 451
          25.2.6 Torsion and nonmetricity . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 454
          25.2.7 Exterior algebra . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 457
          25.2.8 Exporting TeX expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 460
          25.2.9 Interfacing with ctensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 461
          25.2.10 Reserved words . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 462
26           ctensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 463
       26.1 Introduction to ctensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 463
       26.2 Functions and Variables for ctensor . . . . . . . . . . . . . . . . . . . . . . . . . . 465
          26.2.1 Initialization and setup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 465
          26.2.2 The tensors of curved space. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 468
          26.2.3 Taylor series expansion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 470
          26.2.4 Frame fields . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 473
          26.2.5 Algebraic classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 473
          26.2.6 Torsion and nonmetricity . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 476
          26.2.7 Miscellaneous features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 477
                                                                                                                                     ix
27    atensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 491
 27.1      Introduction to atensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 491
 27.2      Functions and Variables for atensor . . . . . . . . . . . . . . . . . . . . . . . . . . 492
30    Symmetries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 537
 30.1 Introduction to Symmetries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 537
 30.2 Functions and Variables for Symmetries . . . . . . . . . . . . . . . . . . . . . 537
    30.2.1 Changing bases . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 537
    30.2.2 Changing representations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 541
    30.2.3 Groups and orbits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 542
    30.2.4 Partitions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 545
    30.2.5 Polynomials and their roots . . . . . . . . . . . . . . . . . . . . . . . . . . . . 546
    30.2.6 Resolvents. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 547
    30.2.7 Miscellaneous . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 553
31    Groups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 555
 31.1      Functions and Variables for Groups . . . . . . . . . . . . . . . . . . . . . . . . . . 555
35        Sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 585
    35.1 Introduction to Sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 585
       35.1.1 Usage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 585
       35.1.2 Set Member Iteration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 587
       35.1.3 Authors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 588
    35.2 Functions and Variables for Sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 588
38        Debugging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 657
    38.1      Source Level Debugging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 657
    38.2      Keyword Commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 658
    38.3      Functions and Variables for Debugging . . . . . . . . . . . . . . . . . . . . . . 659
39        alt-display . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 665
    39.1      Introduction to alt-display . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 665
    39.2      Functions and Variables for alt-display. . . . . . . . . . . . . . . . . . . . . . . 666
40        asympa . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 671
    40.1      Introduction to asympa . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 671
    40.2      Functions and variables for asympa . . . . . . . . . . . . . . . . . . . . . . . . . . 671
42        Bernstein . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 675
    42.1      Functions and Variables for Bernstein . . . . . . . . . . . . . . . . . . . . . . . 675
                                                                                                                    xi
43   bitwise . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 677
 43.1   Functions and Variables for bitwise . . . . . . . . . . . . . . . . . . . . . . . . . . 677
44   bode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 681
 44.1   Functions and Variables for bode . . . . . . . . . . . . . . . . . . . . . . . . . . . . 681
45   celine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 685
 45.1   Introduction to celine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 685
47   cobyla . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 689
 47.1   Introduction to cobyla . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 689
 47.2   Functions and Variables for cobyla. . . . . . . . . . . . . . . . . . . . . . . . . . . 689
 47.3   Examples for cobyla . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 691
48   combinatorics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 693
 48.1   Package combinatorics. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 693
 48.2   Functions and Variables for Combinatorics . . . . . . . . . . . . . . . . . . . 693
50   descriptive . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 705
 50.1   Introduction to descriptive . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 705
 50.2   Functions and Variables for data manipulation . . . . . . . . . . . . . . . 707
 50.3   Functions and Variables for descriptive statistics . . . . . . . . . . . . . 713
 50.4   Functions and Variables for statistical graphs . . . . . . . . . . . . . . . . 728
51   diag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 739
 51.1   Functions and Variables for diag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 739
52   distrib . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 745
 52.1   Introduction to distrib . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 745
 52.2   Functions and Variables for continuous distributions . . . . . . . . . 747
 52.3   Functions and Variables for discrete distributions . . . . . . . . . . . . 767
xii
53          draw . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 779
      53.1 Introduction to draw . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .            779
      53.2 Functions and Variables for draw . . . . . . . . . . . . . . . . . . . . . . . . . . . .                        780
         53.2.1 Scenes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   780
         53.2.2 Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .      781
         53.2.3 Plot options for draw programs . . . . . . . . . . . . . . . . . . . . . . . . .                           785
         53.2.4 Graphics objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .             854
      53.3 Functions and Variables for pictures . . . . . . . . . . . . . . . . . . . . . . . . .                          884
      53.4 Functions and Variables for worldmap . . . . . . . . . . . . . . . . . . . . . . .                              886
         53.4.1 Variables and Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .                    886
         53.4.2 Graphic objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .            891
54          drawdf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 897
      54.1 Introduction to drawdf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 897
      54.2 Functions and Variables for drawdf . . . . . . . . . . . . . . . . . . . . . . . . . . 897
         54.2.1 Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 897
55          dynamics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 901
      55.1 The dynamics package. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 901
      55.2 Graphical analysis of discrete dynamical systems . . . . . . . . . . . . . 901
      55.3 Visualization with VTK . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 906
         55.3.1 Scene options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 908
         55.3.2 Scene objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 909
         55.3.3 Scene object’s options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 910
56          engineering-format . . . . . . . . . . . . . . . . . . . . . . . . . . 915
      56.1      Functions and Variables for engineering-format . . . . . . . . . . . . . . 915
      56.2      Known Bugs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 915
57          ezunits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 917
      57.1      Introduction to ezunits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 917
      57.2      Introduction to physical constants . . . . . . . . . . . . . . . . . . . . . . . . . . . 918
      57.3      Functions and Variables for ezunits . . . . . . . . . . . . . . . . . . . . . . . . . . 920
58          f90 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 935
      58.1      Package f90 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 935
59          finance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 937
      59.1      Introduction to finance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 937
      59.2      Functions and Variables for finance . . . . . . . . . . . . . . . . . . . . . . . . . . 937
                                                                                                                     xiii
60    fractals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 943
 60.1     Introduction to fractals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 943
 60.2     Definitions for IFS fractals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 943
 60.3     Definitions for complex fractals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 944
 60.4     Definitions for Koch snowflakes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 945
 60.5     Definitions for Peano maps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 945
61    ggf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 947
 61.1     Functions and Variables for ggf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 947
62    graphs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 949
 62.1 Introduction to graphs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 949
 62.2 Functions and Variables for graphs . . . . . . . . . . . . . . . . . . . . . . . . . . 949
    62.2.1 Building graphs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 949
    62.2.2 Graph properties . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 955
    62.2.3 Modifying graphs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 970
    62.2.4 Reading and writing to files . . . . . . . . . . . . . . . . . . . . . . . . . . . . 972
    62.2.5 Visualization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 973
63    grobner . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 979
 63.1 Introduction to grobner . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 979
    63.1.1 Notes on the grobner package . . . . . . . . . . . . . . . . . . . . . . . . . . . 979
    63.1.2 Implementations of admissible monomial orders in grobner . . 979
 63.2 Functions and Variables for grobner . . . . . . . . . . . . . . . . . . . . . . . . . 980
    63.2.1 Global switches for grobner . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 980
    63.2.2 Simple operators in grobner . . . . . . . . . . . . . . . . . . . . . . . . . . . . 981
    63.2.3 Other functions in grobner. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 981
    63.2.4 Standard postprocessing of Groebner Bases . . . . . . . . . . . . . 983
64    hompack . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 987
 64.1     Introduction to hompack . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 987
 64.2     Functions and Variables for hompack . . . . . . . . . . . . . . . . . . . . . . . . 987
65    impdiff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 991
 65.1     Functions and Variables for impdiff . . . . . . . . . . . . . . . . . . . . . . . . . . 991
66    interpol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 993
 66.1     Introduction to interpol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 993
 66.2     Functions and Variables for interpol . . . . . . . . . . . . . . . . . . . . . . . . . 993
67    lapack . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1001
 67.1     Introduction to lapack. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1001
 67.2     Functions and Variables for lapack . . . . . . . . . . . . . . . . . . . . . . . . . 1001
xiv
68         lbfgs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1009
      68.1    Introduction to lbfgs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1009
      68.2    Functions and Variables for lbfgs . . . . . . . . . . . . . . . . . . . . . . . . . . . 1009
69         lindstedt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1015
      69.1    Functions and Variables for lindstedt . . . . . . . . . . . . . . . . . . . . . . . 1015
70         linearalgebra . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1017
      70.1    Introduction to linearalgebra . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1017
      70.2    Functions and Variables for linearalgebra . . . . . . . . . . . . . . . . . . . 1019
71         lsquares . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1031
      71.1    Introduction to lsquares . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1031
      71.2    Functions and Variables for lsquares . . . . . . . . . . . . . . . . . . . . . . . . 1031
72         minpack . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1041
      72.1    Introduction to minpack. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1041
      72.2    Functions and Variables for minpack . . . . . . . . . . . . . . . . . . . . . . . 1041
73         makeOrders . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1043
      73.1    Functions and Variables for makeOrders . . . . . . . . . . . . . . . . . . . . 1043
74         mnewton . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1045
      74.1    Introduction to mnewton . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1045
      74.2    Functions and Variables for mnewton . . . . . . . . . . . . . . . . . . . . . . . 1045
75         numericalio . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1047
      75.1 Introduction to numericalio . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1047
         75.1.1 Plain-text input and output . . . . . . . . . . . . . . . . . . . . . . . . . . . 1047
         75.1.2 Separator flag values for input . . . . . . . . . . . . . . . . . . . . . . . . . 1047
         75.1.3 Separator flag values for output . . . . . . . . . . . . . . . . . . . . . . . 1047
         75.1.4 Binary floating-point input and output . . . . . . . . . . . . . . . . 1048
      75.2 Functions and Variables for plain-text input and output . . . . 1048
      75.3 Functions and Variables for binary input and output . . . . . . . . 1050
76         odepack . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1053
      76.1 Introduction to ODEPACK . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1053
         76.1.1 Getting Started with ODEPACK . . . . . . . . . . . . . . . . . . . . . . 1053
      76.2 Functions and Variables for odepack . . . . . . . . . . . . . . . . . . . . . . . . 1054
77         operatingsystem . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1057
      77.1    Introduction to operatingsystem . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1057
      77.2    Directory operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1057
      77.3    File operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1057
      77.4    Environment operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1057
                                                                                                                            xv
78    opsubst . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1059
 78.1     Functions and Variables for opsubst . . . . . . . . . . . . . . . . . . . . . . . . 1059
79    orthopoly . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1061
 79.1 Introduction to orthogonal polynomials . . . . . . . . . . . . . . . . . . . . . 1061
    79.1.1 Getting Started with orthopoly . . . . . . . . . . . . . . . . . . . . . . . . 1061
    79.1.2 Limitations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1063
    79.1.3 Floating point Evaluation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1065
    79.1.4 Graphics and orthopoly . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1066
    79.1.5 Miscellaneous Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1067
    79.1.6 Algorithms . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1068
 79.2 Functions and Variables for orthogonal polynomials . . . . . . . . . 1068
80    pytranslate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1073
 80.1 Introduction to pytranslate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1073
    80.1.1 Tests for pytranslate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1074
 80.2 Functions in pytranslate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1074
 80.3 Extending pytranslate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1075
81    ratpow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1079
 81.1     Functions and Variables for ratpow . . . . . . . . . . . . . . . . . . . . . . . . . 1079
82    romberg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1081
 82.1     Functions and Variables for romberg. . . . . . . . . . . . . . . . . . . . . . . . 1081
83    simplex . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1085
 83.1 Introduction to simplex . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .            1085
    83.1.1 Tests for simplex . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .         1085
       83.1.1.1 klee minty . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .         1085
       83.1.1.2 NETLIB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .         1085
 83.2 Functions and Variables for simplex . . . . . . . . . . . . . . . . . . . . . . . .                        1086
84    simplification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1089
 84.1     Introduction to simplification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1089
 84.2     Package absimp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1089
 84.3     Package facexp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1089
 84.4     Package functs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1091
 84.5     Package ineq . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1094
 84.6     Package rducon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1096
 84.7     Package scifac . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1096
86         stats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1105
      86.1      Introduction to stats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .      1105
      86.2      Functions and Variables for inference result . . . . . . . . . . . . . . . .                             1105
      86.3      Functions and Variables for stats . . . . . . . . . . . . . . . . . . . . . . . . . . .                  1107
      86.4      Functions and Variables for special distributions . . . . . . . . . . . .                                1122
87         stirling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1123
      87.1      Functions and Variables for stirling . . . . . . . . . . . . . . . . . . . . . . . . . 1123
88         stringproc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1125
      88.1      Introduction to String Processing . . . . . . . . . . . . . . . . . . . . . . . . . . . 1125
      88.2      Input and Output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1126
      88.3      Characters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1132
      88.4      String Processing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1137
      88.5      Octets and Utilities for Cryptography . . . . . . . . . . . . . . . . . . . . . . 1143
90         unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1169
      90.1      Introduction to Units . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1169
      90.2      Functions and Variables for Units . . . . . . . . . . . . . . . . . . . . . . . . . . 1170
91         wrstcse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1179
      91.1      Introduction to wrstcse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1179
      91.2      Functions and Variables for wrstcse. . . . . . . . . . . . . . . . . . . . . . . . . 1179
92         zeilberger . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1183
      92.1 Introduction to zeilberger . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1183
         92.1.1 The indefinite summation problem . . . . . . . . . . . . . . . . . . . . . 1183
         92.1.2 The definite summation problem . . . . . . . . . . . . . . . . . . . . . . 1183
         92.1.3 Verbosity levels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1183
      92.2 Functions and Variables for zeilberger . . . . . . . . . . . . . . . . . . . . . . 1184
      92.3 General global variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1185
      92.4 Variables related to the modular test . . . . . . . . . . . . . . . . . . . . . . . 1186
1 Introduction to Maxima
Start Maxima with the command "maxima". Maxima will display version information
and a prompt. End each Maxima command with a semicolon. End the session with the
command "quit();". Here’s a sample session:
     [wfs@chromium]$ maxima
     Maxima 5.9.1 http://maxima.sourceforge.net
     Using Lisp CMU Common Lisp 19a
     Distributed under the GNU Public License. See the file COPYING.
     Dedicated to the memory of William Schelter.
     This is a development version of Maxima. The function bug_report()
     provides bug reporting information.
     (%i1) factor(10!);
                                 8 4 2
     (%o1)                      2 3 5 7
     (%i2) expand ((x + y)^6);
            6        5       2 4        3 3        4 2       5      6
     (%o2) y + 6 x y + 15 x y + 20 x y + 15 x y + 6 x y + x
     (%i3) factor (x^6 - 1);
                                   2            2
     (%o3)       (x - 1) (x + 1) (x - x + 1) (x + x + 1)
     (%i4) quit();
     [wfs@chromium]$
   Maxima can search the info pages. Use the describe command to show information
about the command or all the commands and variables containing a string. The question
mark ? (exact search) and double question mark ?? (inexact search) are abbreviations for
describe:
     (%i1) ?? integ
      0: Functions and Variables for Elliptic Integrals
      1: Functions and Variables for Integration
      2: Introduction to Elliptic Functions and Integrals
      3: Introduction to Integration
      4: askinteger (Functions and Variables for Simplification)
      5: integerp (Functions and Variables for Miscellaneous Options)
      6: integer_partitions (Functions and Variables for Sets)
      7: integrate (Functions and Variables for Integration)
      8: integrate_use_rootsof (Functions and Variables for Integration)
      9: integration_constant_counter (Functions and Variables for
         Integration)
      10: nonnegintegerp (Functions and Variables for linearalgebra)
     Enter space-separated numbers, ‘all' or ‘none': 5 4
Examples:
      (%o1)                                         true
   To use a result in later calculations, you can assign it to a variable or refer to it by its
automatically supplied label. In addition, % refers to the most recent calculated result:
      (%i1) u: expand ((x + y)^6);
             6        5       2 4    3 3      4 2     5     6
      (%o1) y + 6 x y + 15 x y + 20 x y + 15 x y + 6 x y + x
      (%i2) diff (u, x);
               5         4       2 3   3 2      4       5
Chapter 1: Introduction to Maxima                                                  3
     (%o2) 6 y + 30 x y       + 60 x   y    + 60 x    y   + 30 x   y + 6 x
     (%i3) factor (%o2);
                                              5
     (%o3)                           6 (y + x)
  Maxima knows about complex numbers and numerical constants:
     (%i1) cos(%pi);
     (%o1)                                 - 1
     (%i2) exp(%i*%pi);
     (%o2)                                 - 1
  Maxima can do differential and integral calculus:
     (%i1) u: expand ((x + y)^6);
            6        5       2 4        3 3                  4 2     5     6
     (%o1) y + 6 x y + 15 x y + 20 x y + 15                 x y + 6 x y + x
     (%i2) diff (%, x);
              5          4      2 3        3 2                  4       5
     (%o2) 6 y + 30 x y + 60 x y + 60 x y +                 30 x y + 6 x
     (%i3) integrate (1/(1 + x^3), x);
                                       2 x - 1
                     2            atan(-------)
                log(x - x + 1)         sqrt(3)             log(x + 1)
     (%o3)    - --------------- + ------------- +          ----------
                       6             sqrt(3)                   3
  Maxima can solve linear systems and cubic equations:
     (%i1) linsolve ([3*x + 4*y = 7, 2*x + a*y = 13], [x, y]);
                             7 a - 52        25
     (%o1)              [x = --------, y = -------]
                             3 a - 8       3 a - 8
     (%i2) solve (x^3 - 3*x^2 + 5*x = 15, x);
     (%o2)       [x = - sqrt(5) %i, x = sqrt(5) %i, x = 3]
   Maxima can solve nonlinear sets of equations. Note that if you don’t want a result
printed, you can finish your command with $ instead of ;.
     (%i1) eq_1: x^2 + 3*x*y + y^2 = 0$
     (%i2) eq_2: 3*x + y = 1$
     (%i3) solve ([eq_1, eq_2]);
                   3 sqrt(5) + 7      sqrt(5) + 3
     (%o3) [[y = - -------------, x = -----------],
                         2                 2
                                         3 sqrt(5) - 7        sqrt(5) - 3
                                    [y = -------------, x = - -----------]]
                                               2                   2
  Maxima can generate plots of one or more functions:
4                                                                                   Maxima 5.45.0 Manual
0.8
             0.6
sin(x)/x
0.4
0.2
-0.2
(%i2) plot2d ([atan(x), erf(x), tanh(x)], [x, -5, 5], [y, -1.5, 2])$
             2
                                                               atan(x)
                                                                 erf(x)
           1.5                                                 tanh(x)
0.5
-0.5
-1
           -1.5
                        -4           -2        0           2               4
                                               x
Chapter 1: Introduction to Maxima                                           5
sin(sqrt(y^2+x^2))/sqrt(y^2+x^2)
       1
     0.8
     0.6
     0.4
 z
     0.2
       0
     -0.2                                                              10
                                                               5
     -0.4
            -10                                            0
                  -5                                               y
                           0                          -5
                       x          5             -10
                                         10
                                                                                             7
    This specifies the testsuite consists of the files "rtest13s" and "rtest14", but "rtest14"
    contains two tests that are known to fail: 57 and 63.
bug_report ()                                                                 [Function]
    Prints out Maxima and Lisp version numbers, and gives a link to the Maxima project
    bug report web page. The version information is the same as reported by build_info.
    When a bug is reported, it is helpful to copy the Maxima and Lisp version information
    into the bug report.
    bug_report returns an empty string "".
build_info ()                                                               [Function]
    Returns a summary of the parameters of the Maxima build, as a Maxima structure
    (defined by defstruct). The fields of the structure are: version, timestamp, host,
    lisp_name, and lisp_version. When the pretty-printer is enabled (via display2d),
    the structure is displayed as a short table.
    See also bug_report.
    Examples:
          (%i1) build_info ();
          (%o1)
          Maxima version: "5.36.1"
          Maxima build date: "2015-06-02 11:26:48"
          Host type: "x86_64-unknown-linux-gnu"
          Lisp implementation type: "GNU Common Lisp (GCL)"
          Lisp implementation version: "GCL 2.6.12"
          (%i2) x : build_info ()$
          (%i3) x@version;
          (%o3)                               5.36.1
          (%i4) x@timestamp;
          (%o4)                         2015-06-02 11:26:48
          (%i5) x@host;
          (%o5)                      x86_64-unknown-linux-gnu
          (%i6) x@lisp_name;
          (%o6)                        GNU Common Lisp (GCL)
          (%i7) x@lisp_version;
          (%o7)                             GCL 2.6.12
          (%i8) x;
          (%o8)
          Maxima version: "5.36.1"
          Maxima build date: "2015-06-02 11:26:48"
          Host type: "x86_64-unknown-linux-gnu"
          Lisp implementation type: "GNU Common Lisp (GCL)"
          Lisp implementation version: "GCL 2.6.12"
Chapter 2: Bug Detection and Reporting                                     9
     The Maxima version string can (here 5.36.1) can look very different:
           (%i1) build_info();
           (%o1)
           Maxima version: "branch_5_37_base_331_g8322940_dirty"
           Maxima build date: "2016-01-01 15:37:35"
           Host type: "x86_64-unknown-linux-gnu"
           Lisp implementation type: "CLISP"
           Lisp implementation version: "2.49 (2010-07-07) (built 3605577779) (memory 3660647
     In that case, Maxima was not build from a released sourcecode, but directly from the
     GIT-checkout of the sourcecode. In the example, the checkout is 331 commits after
     the latest GIT tag (usually a Maxima (major) release (5.37 in our example)) and the
     abbreviated commit hash of the last commit was "8322940".
     Front-ends for maxima can add information about currently being used by setting
     the variables maxima_frontend and maxima_frontend_version accordingly.
                                                                                      11
3 Help
3.1 Documentation
The Maxima on-line user’s manual can be viewed in different forms. From the Maxima
interactive prompt, the user’s manual is viewed as plain text by the ? command (i.e., the
describe function). The user’s manual is viewed as info hypertext by the info viewer
program and as a web page by any ordinary web browser.
   example displays examples for many Maxima functions. For example,
      (%i1) example (integrate);
   yields
      (%i2) test(f):=block([u],u:integrate(f,x),ratsimp(f-diff(u,x)))
      (%o2) test(f) := block([u], u : integrate(f, x),
                                               ratsimp(f - diff(u, x)))
      (%i3) test(sin(x))
      (%o3)                           0
      (%i4) test(1/(x+1))
      (%o4)                           0
      (%i5) test(1/(x^2+1))
      (%o5)                           0
   and additional output.
            The same example, using the symbol gamma, rather than the string:
12                                                                Maxima 5.45.0 Manual
           (%i2) apropos(gamma);
           (%o2) [%gamma, Gamma, gamma_expand, gammalim, makegamma,
           prefer_gamma_incomplete, gamma, gamma-incomplete, gamma_incomplete,
           gamma_incomplete_generalized, gamma_incomplete_generalized_regularized,
           gamma_incomplete_lower, gamma_incomplete_regularized, log_gamma]
           The number of symbols in the current Maxima session. This will vary.
           (%i3) length(apropos(""));
           (%o3)                                2338
           batching /home/wfs/maxima/share/simplification/disol.dem
            At the _ prompt, type ';' followed by enter to get next demo
           (%i2)                      load("disol")
           _
           (%i3)              exp1 : a (e (g + f) + b (d + c))
           (%o3)                  a (e (g + f) + b (d + c))
           _
           (%i4)                    disolate(exp1, a, b, e)
           (%t4)                             d + c
(%t5) g + f
describe                                                                       [Function]
        describe (string)
        describe (string, exact)
        describe (string, inexact)
     describe(string) is equivalent to describe(string, exact).
     describe(string, exact) finds an item with title equal (case-insensitive) to string,
     if there is any such item.
Chapter 3: Help                                                                         13
     describe(string, inexact) finds all documented items which contain string in their
     titles. If there is more than one such item, Maxima asks the user to select an item or
     items to display.
     At the interactive prompt, ? foo (with a space between ? and foo) is equivalent to
     describe("foo", exact), and ?? foo is equivalent to describe("foo", inexact).
     describe("", inexact) yields a list of all topics documented in the on-line manual.
     describe quotes its argument. describe returns true if some documentation is
     found, otherwise false.
     See also Section 3.1 [Documentation], page 11.
     Example:
           (%i1) ?? integ
            0: Functions and Variables for Elliptic Integrals
            1: Functions and Variables for Integration
            2: Introduction to Elliptic Functions and Integrals
            3: Introduction to Integration
            4: askinteger (Functions and Variables for Simplification)
            5: integerp (Functions and Variables for Miscellaneous Options)
            6: integer_partitions (Functions and Variables for Sets)
            7: integrate (Functions and Variables for Integration)
            8: integrate_use_rootsof (Functions and Variables for
               Integration)
            9: integration_constant_counter (Functions and Variables for
               Integration)
            10: nonnegintegerp (Functions and Variables for linearalgebra)
           Enter space-separated numbers, ‘all' or ‘none': 7 8
example                                                                         [Function]
          example (topic)
          example ()
     example (topic) displays some examples of topic, which is a symbol or a string. To
     get examples for operators like if, do, or lambda the argument must be a string, e.g.
     example ("do"). example is not case sensitive. Most topics are function names.
     example () returns the list of all recognized topics.
     The name of the file containing the examples is given by the global option variable
     manual_demo, which defaults to "manual.demo".
     example quotes its argument. example returns done unless no examples are found or
     there is no argument, in which case example returns the list of all recognized topics.
     Examples:
           (%i1) example(append);
           (%i2) append([y+x,0,-3.2],[2.5e+20,x])
           (%o2)                 [y + x, 0, - 3.2, 2.5e+20, x]
           (%o2)                                done
           (%i3) example("lambda");
           (%i4) lambda([x,y,z],x^2+y^2+z^2)
                                                       2     2    2
           (%o4)               lambda([x, y, z], x + y + z )
           (%i5) %(1,2,a)
                                                2
           (%o5)                               a + 5
           (%i6) 1+2+a
           (%o6)                                a + 3
           (%o6)                                done
4 Command Line
_                                                                           [System variable]
     _ is the most recent input expression (e.g., %i1, %i2, %i3, . . . ).
     _ is assigned the input expression before the input is simplified or evaluated. However,
     the value of _ is simplified (but not evaluated) when it is displayed.
     _ is recognized by batch and load. In a file processed by batch, _ has the same
     meaning as at the interactive prompt. In a file processed by load, _ is bound to the
     input expression most recently evaluated at the interactive prompt or in a batch file;
     _ is not bound to the input expressions in the file being processed.
16                                                                Maxima 5.45.0 Manual
%                                                                       [System variable]
     % is the output expression (e.g., %o1, %o2, %o3, . . . ) most recently computed by
     Maxima, whether or not it was displayed.
     % is recognized by batch and load. In a file processed by batch, % has the same
     meaning as at the interactive prompt. In a file processed by load, % is bound to the
     output expression most recently computed at the interactive prompt or in a batch
     file; % is not bound to output expressions in the file being processed.
     See also _, %%, and %th.
%%                                                                  [System variable]
     In compound statements, namely block, lambda, or (s_1, ..., s_n), %% is the value
     of the previous statement.
     At the first statement in a compound statement, or outside of a compound statement,
     %% is undefined.
     %% is recognized by batch and load, and it has the same meaning as at the interactive
     prompt.
     See also %.
     Examples:
Chapter 4: Command Line                                                                  17
?                                                                         [Special symbol]
     As prefix to a function or variable name, ? signifies that the name is a Lisp name,
     not a Maxima name. For example, ?round signifies the Lisp function ROUND. See
     Section 37.1 [Lisp and Maxima], page 641, for more on this point.
     The notation ? word (a question mark followed a word, separated by whitespace) is
     equivalent to describe("word"). The question mark must occur at the beginning of
     an input line; otherwise it is not recognized as a request for documentation. See also
     describe.
??                                                                      [Special symbol]
     The notation ?? word (?? followed a word, separated by whitespace) is equivalent to
     describe("word", inexact). The question mark must occur at the beginning of an
     input line; otherwise it is not recognized as a request for documentation. See also
     describe.
$                                                                         [Input terminator]
     The dollar sign $ terminates an input expression, and the most recent output % and
     an output label, e.g. %o1, are assigned the result, but the result is not displayed.
     See also ;.
     Example:
           (%i1) 1 + 2 + 3 $
           (%i2) %;
           (%o2)                                  6
           (%i3) %o1;
           (%o3)                                  6
;                                                                       [Input terminator]
     The semicolon ; terminates an input expression, and the resulting output is displayed.
     See also $.
     Example:
           (%i1) 1 + 2 + 3;
           (%o1)                                 6
inchar                                                                   [Option variable]
     Default value: %i
     inchar is the prefix of the labels of expressions entered by the user. Maxima auto-
     matically constructs a label for each input expression by concatenating inchar and
     linenum.
     inchar may be assigned any string or symbol, not necessarily a single character.
     Because Maxima internally takes into account only the first char of the prefix, the
     prefixes inchar, outchar, and linechar should have a different first char. Otherwise
     some commands like kill(inlabels) do not work as expected.
     See also labels.
     Example:
           (%i1) inchar: "input";
           (%o1)                                input
Chapter 4: Command Line                                                                  19
             (input2) expand((a+b)^3);
                                  3       2     2     3
             (%o2)               b + 3 a b + 3 a b + a
     values       All bound atoms which are user variables, not Maxima options or
                  switches, created by : or :: or functional binding.
     functions
                  All user-defined functions, created by := or define.
     myoptions
                  All options ever reset by the user (whether or not they are later reset to
                  their default values).
     aliases      All atoms which have an user-defined alias, created by the alias,
                  ordergreat, orderless functions or by declaring the atom as a noun
                  with declare.
     dependencies
               All atoms which have functional dependencies, created by the depends,
               dependencies, or gradef functions.
     gradefs      All functions which have user-defined derivatives, created by the gradef
                  function.
     props        All atoms which have any property other than those mentioned above,
                  such as properties established by atvalue or matchdeclare, etc., as well
                  as properties established in the declare function.
     structures
                  All structs defined using defstruct.
     let_rule_packages
               All user-defined let rule packages plus the special package default_
               let_rule_package. (default_let_rule_package is the name of the
               rule package used when one is not explicitly set by the user.)
20                                                                     Maxima 5.45.0 Manual
kill                                                                                [Function]
           kill   (a_1, . . . , a_n)
           kill   (labels)
           kill   (inlabels, outlabels, linelabels)
           kill   (n)
           kill   ([m, n])
           kill   (values, functions, arrays, . . . )
           kill   (all)
           kill   (allbut (a_1, . . . , a_n))
       Removes all bindings (value, function, array, or rule) from the arguments a 1, . . . ,
       a n. An argument a k may be a symbol or a single array element. When a k is a
       single array element, kill unbinds that element without affecting any other elements
       of the array.
       Several special arguments are recognized. Different kinds of arguments may be com-
       bined, e.g., kill (inlabels, functions, allbut (foo, bar)).
       kill (labels) unbinds all input, output, and intermediate expression labels created
       so far. kill (inlabels) unbinds only input labels which begin with the current value
       of inchar. Likewise, kill (outlabels) unbinds only output labels which begin with
       the current value of outchar, and kill (linelabels) unbinds only intermediate
       expression labels which begin with the current value of linechar.
       kill (n), where n is an integer, unbinds the n most recent input and output labels.
       kill ([m, n]) unbinds input and output labels m through n.
       kill (infolist), where infolist is any item in infolists (such as values,
       functions, or arrays) unbinds all items in infolist. See also infolists.
       kill (all) unbinds all items on all infolists. kill (all) does not reset global vari-
       ables to their default values; see reset on this point.
       kill (allbut (a_1, ..., a_n)) unbinds all items on all infolists except for a 1, . . . ,
       a n. kill (allbut (infolist)) unbinds all items except for the ones on infolist,
       where infolist is values, functions, arrays, etc.
       The memory taken up by a bound property is not released until all symbols are
       unbound from it. In particular, to release the memory taken up by the value of
       a symbol, one unbinds the output label which shows the bound value, as well as
       unbinding the symbol itself.
       kill quotes its arguments. The quote-quote operator '' defeats quotation.
       kill (symbol) unbinds all properties of symbol. In contrast, the functions remvalue,
       remfunction, remarray, and remrule unbind a specific property. Note that facts
       declared by assume don’t require a symbol they apply to, therefore aren’t stored as
       properties of symbols and therefore aren’t affected by kill.
       kill always returns done, even if an argument has no binding.
     By default, Maxima displays the result of each user input expression, giving the result
     an output label. The output display is suppressed by terminating the input with $
     (dollar sign) instead of ; (semicolon). An output label is constructed and bound to
     the result, but not displayed, and the label may be referenced in the same way as
     displayed output labels. See also %, %%, and %th.
     Intermediate expression labels can be generated by some functions. The option vari-
     able programmode controls whether solve and some other functions generate interme-
     diate expression labels instead of returning a list of expressions. Some other functions,
     such as ldisplay, always generate intermediate expression labels.
     See also inchar, outchar, linechar, and infolists.
labels                                                                  [System variable]
     The variable labels is the list of input, output, and intermediate expression labels,
     including all previous labels if inchar, outchar, or linechar were redefined.
linechar                                                                    [Option variable]
     Default value: %t
     linechar is the prefix of the labels of intermediate expressions generated by Max-
     ima. Maxima constructs a label for each intermediate expression (if displayed) by
     concatenating linechar and linenum.
     linechar may be assigned any string or symbol, not necessarily a single character.
     Because Maxima internally takes into account only the first char of the prefix, the
     prefixes inchar, outchar, and linechar should have a different first char. Otherwise
     some commands like kill(inlabels) do not work as expected.
     Intermediate expressions might or might not be displayed. See programmode and
     labels.
linenum                                                                [System variable]
     The line number of the current pair of input and output expressions.
myoptions                                                               [System variable]
     Default value: []
     myoptions is the list of all options ever reset by the user, whether or not they get
     reset to their default value.
nolabels                                                                   [Option variable]
     Default value: false
     When nolabels is true, input and output result labels (%i and %o, respectively) are
     displayed, but the labels are not bound to results, and the labels are not appended to
     the labels list. Since labels are not bound to results, garbage collection can recover
     the memory taken up by the results.
     Otherwise input and output result labels are bound to results, and the labels are
     appended to the labels list.
     Intermediate expression labels (%t) are not affected by nolabels; whether nolabels
     is true or false, intermediate expression labels are bound and appended to the
     labels list.
     See also batch, load, and labels.
22                                                                   Maxima 5.45.0 Manual
playback                                                                    [Function]
        playback    ()
        playback    (n)
        playback    ([m, n])
        playback    ([m])
        playback    (input)
        playback    (slow)
        playback    (time)
        playback    (grind)
     Displays input, output, and intermediate expressions, without recomputing them.
     playback only displays the expressions bound to labels; any other output (such as
     text printed by print or describe, or error messages) is not displayed. See also
     labels.
     playback quotes its arguments. The quote-quote operator '' defeats quotation.
     playback always returns done.
Chapter 4: Command Line                                                                 23
     playback () (with no arguments) displays all input, output, and intermediate expres-
     sions generated so far. An output expression is displayed even if it was suppressed by
     the $ terminator when it was originally computed.
     playback (n) displays the most recent n expressions. Each input, output, and inter-
     mediate expression counts as one.
     playback ([m, n]) displays input, output, and intermediate expressions with num-
     bers from m through n, inclusive.
     playback ([m]) is equivalent to playback ([m, m]); this usually prints one pair of
     input and output expressions.
     playback (input) displays all input expressions generated so far.
     playback (slow) pauses between expressions and waits for the user to press enter.
     This behavior is similar to demo. playback (slow) is useful in conjunction with
     save or stringout when creating a secondary-storage file in order to pick out useful
     expressions.
     playback (time) displays the computation time for each expression.
     playback (grind) displays input expressions in the same format as the grind func-
     tion. Output expressions are not affected by the grind option. See grind.
     Arguments may be combined, e.g., playback ([5, 10], grind, time, slow).
quit ()                                                                     [Function]
     Terminates the Maxima session. Note that the function must be invoked as quit();
     or quit()$, not quit by itself.
     To stop a lengthy computation, type control-C. The default action is to return to the
     Maxima prompt. If *debugger-hook* is nil, control-C opens the Lisp debugger.
     See also Chapter 38 [Debugging], page 657.
     The display index separator S can be a string, including an empty string, or false,
     indicating the default separator, or any expression. If not a string and not false, the
     property value is coerced to a string via string.
     If no display index separator is assigned, the default separator is used. The default
     separator is a comma. There is no way to change the default separator.
     Each symbol has its own value of display_index_separator.
     See also put, get, and declare_index_properties.
     Examples:
     When a symbol A has index display properties, the value of the property display_
     index_separator is the string or other expression which is displayed between indices.
     The value is assigned by put(A, S, display_index_separator),
           (%i1) declare_index_properties (A, [postsuperscript, postsuperscript,
             presubscript, presubscript]);
           (%o1)                                done
           (%i2) put (A, ";", display_index_separator);
           (%o2)                                   ;
           (%i3) A[w, x, y, z];
                                                    w;x
           (%o3)                                   A
                                               y;z
     The assigned value is retrieved by get(A, display_index_separator).
           (%i1) declare_index_properties (A, [postsuperscript, postsuperscript,
             presubscript, presubscript]);
           (%o1)                                done
           (%i2) put (A, ";", display_index_separator);
           (%o2)                                   ;
           (%i3) get (A, display_index_separator);
           (%o3)                                   ;
     The display index separator S can be a string, including an empty string, or false,
     indicating the default separator, or any expression.
           (%i1) declare_index_properties (A, [postsuperscript, postsuperscript,
             presubscript, presubscript]);
           (%o1)                                done
           (%i2) A[w, x, y, z];
                                                    w, x
           (%o2)                                   A
                                              y, z
           (%i3) put (A, "-", display_index_separator);
           (%o3)                                   -
           (%i4) A[w, x, y, z];
                                                    w-x
           (%o4)                                   A
                                               y-z
           (%i5) put (A, " ", display_index_separator);
           (%o5)
Chapter 4: Command Line                                                                29
                                                    2
                                               x - x
0.8414709848078965
            (%o3)                                   done
display (expr_1, expr_2, . . . )                                               [Function]
     Displays equations whose left side is expr i unevaluated, and whose right side is the
     value of the expression centered on the line. This function is useful in blocks and
     for statements in order to have intermediate results displayed. The arguments to
     display are usually atoms, subscripted variables, or function calls.
     See also ldisplay, disp, and ldisp.
     Example:
           (%i1) b[1,2]:x-x^2$
           (%i2) x:123$
           (%i3) display(x, b[1,2], sin(1.0));
                                              x = 123
                                                           2
                                         b          = x - x
                                             1, 2
sin(1.0) = 0.8414709848078965
            (%o3)                                   done
display2d                                                                [Option variable]
     Default value: true
     When display2d is true, the console display is an attempt to present mathematical
     expressions as they might appear in books and articles, using only letters, num-
     bers, and some punctuation characters. This display is sometimes called the "pretty
     printer" display.
     When display2d is false, the console display is a 1-dimensional or linear form which
     is the same as the output produced by grind.
Chapter 4: Command Line                                                                  31
     When display2d is false, the value of stringdisp is ignored, and strings are always
     displayed with quote marks.
     See also leftjust to switch between a left justified and a centered display of equa-
     tions.
     Example:
            (%i1) x/(x^2+1);
                                               x
            (%o1)                           ------
                                             2
                                            x + 1
            (%i2) display2d:false$
            (%i3) x/(x^2+1);
            (%o3) x/(x^2+1)
display_format_internal                                                   [Option variable]
     Default value: false
     When display_format_internal is true, expressions are displayed without being
     transformed in ways that hide the internal mathematical representation. The display
     then corresponds to what inpart returns rather than part.
     Examples:
           User       part        inpart
           a-b;        a - b      a + (- 1) b
                        a               - 1
           a/b;         -            a b
                        b
                                       1/2
           sqrt(x);     sqrt(x)       x
                       4 X           4
           X*4/3;      ---           - X
                        3            3
dispterms (expr)                                                                  [Function]
     Displays expr in parts one below the other. That is, first the operator of expr is
     displayed, then each term in a sum, or factor in a product, or part of a more general
     expression is displayed separately. This is useful if expr is too large to be otherwise
     displayed. For example if P1, P2, . . . are very large expressions then the display
     program may run out of storage space in trying to display P1 + P2 + ... all at once.
     However, dispterms (P1 + P2 + ...) displays P1, then below it P2, etc. When not
     using dispterms, if an exponential expression is too wide to be displayed as A^B it
     appears as expt (A, B) (or as ncexpt (A, B) in the case of A^^B).
     Example:
           (%i1) dispterms(2*a*sin(x)+%e^x);
           +
32                                                                  Maxima 5.45.0 Manual
2 a sin(x)
             x
           %e
           (%o1)                                done
expt (a, b)                                                                [Special symbol]
ncexpt (a, b)                                                              [Special symbol]
     If an exponential expression is too wide to be displayed as a^b it appears as expt (a,
     b) (or as ncexpt (a, b) in the case of a^^b).
     expt and ncexpt are not recognized in input.
exptdispflag                                                       [Option variable]
     Default value: true
     When exptdispflag is true, Maxima displays expressions with negative exponents
     using quotients. See also %edispflag.
     Example:
           (%i1) exptdispflag:true;
           (%o1)                           true
           (%i2) 10^-x;
                                             1
           (%o2)                            ---
                                              x
                                            10
           (%i3) exptdispflag:false;
           (%o3)                           false
           (%i4) 10^-x;
                                             - x
           (%o4)                           10
grind (expr)                                                                      [Function]
     The function grind prints expr to the console in a form suitable for input to Maxima.
     grind always returns done.
     When expr is the name of a function or macro, grind prints the function or macro
     definition instead of just the name.
     See also string, which returns a string instead of printing its output. grind attempts
     to print the expression in a manner which makes it slightly easier to read than the
     output of string.
     grind evaluates its argument.
     Examples:
            (%i1) aa + 1729;
            (%o1)                             aa + 1729
            (%i2) grind (%);
            aa+1729$
            (%o2)                               done
Chapter 4: Command Line                                                  33
                                     3       2     2     3
           (%t4)                    b + 3 a b + 3 a b + a
                                     3       2     2     3
           (%t4)                f = b + 3 a b + 3 a b + a
     When leftjust is true, equations in 2D-display are drawn left justified rather than
     centered.
     See also display2d to switch between 1D- and 2D-display.
     Example:
           (%i1) expand((x+1)^3);
                                      3       2
           (%o1)                     x + 3 x + 3 x + 1
           (%i2) leftjust:true$
           (%i3) expand((x+1)^3);
                   3       2
           (%o3) x + 3 x + 3 x + 1
linel                                                                   [Option variable]
     Default value: 79
     linel is the assumed width (in characters) of the console display for the purpose
     of displaying expressions. linel may be assigned any value by the user, although
     very small or very large values may be impractical. Text printed by built-in Maxima
     functions, such as error messages and the output of describe, is not affected by
     linel.
     displayed if the leading digit is otherwise a letter. The numerals for base 36, the
     largest acceptable base, comprise 0 through 9, and A through Z.
     See also ibase.
     Examples:
           (%i1) obase : 2;
           (%o1)                                 10
           (%i10) 2^8 - 1;
           (%o10)                            11111111
           (%i11) obase : 8;
           (%o3)                                 10
           (%i4) 8^8 - 1;
           (%o4)                             77777777
           (%i5) obase : 16;
           (%o5)                                 10
           (%i6) 16^8 - 1;
           (%o6)                             0FFFFFFFF
           (%i7) obase : 36;
           (%o7)                                 10
           (%i8) 36^8 - 1;
           (%o8)                             0ZZZZZZZZ
pfeformat                                                                 [Option variable]
     Default value: false
     When pfeformat is true, a ratio of integers is displayed with the solidus (forward
     slash) character, and an integer denominator n is displayed as a leading multiplicative
     term 1/n.
     Examples:
           (%i1) pfeformat: false$
           (%i2) 2^16/7^3;
                                               65536
           (%o2)                               -----
                                                343
           (%i3) (a+b)/8;
                                               b + a
           (%o3)                               -----
                                                 8
           (%i4) pfeformat: true$
           (%i5) 2^16/7^3;
           (%o5)                             65536/343
           (%i6) (a+b)/8;
           (%o6)                           1/8 (b + a)
powerdisp                                                               [Option variable]
     Default value: false
     When powerdisp is true, a sum is displayed with its terms in order of increasing
     power. Thus a polynomial is displayed as a truncated power series, with the constant
     term first and the highest power last.
Chapter 4: Command Line                                                                        39
                                                         10 log(a) - log(b)
           (%i2) r;
           (%o2)                  10 log(a) - log(b)
           (%i3) disp ("(a+b)^3 is", expand ((a+b)^3), "log (a^10/b) is",
                 radcan (log (a^10/b)))$
                                      (a+b)^3 is
                                       3             2           2           3
                                   b       + 3 a b       + 3 a       b + a
log (a^10/b) is
10 log(a) - log(b)
5.1 Numbers
5.1.1 Introduction to Numbers
Complex numbers
A complex expression is specified in Maxima by adding the real part of the expression to
%i times the imaginary part. Thus the roots of the equation x^2 - 4*x + 13 = 0 are 2 +
3*%i and 2 - 3*%i. Note that simplification of products of complex expressions can be
effected by expanding the product. Simplification of quotients, roots, and other functions
of complex expressions can usually be accomplished by using the realpart, imagpart,
rectform, polarform, abs, carg functions.
           (%o2)                  2.314069263277927b1
           (%i3) bfloat(abs(-%gamma));
           (%o3)                 5.772156649015329b-1
           (%i4) bfloat(log(%phi));
           (%o4)                 4.812118250596035b-1
            (-1)^(1/3):        -1
            (-1)^(1/4):     (-1)^(1/4)
                         domain:complex
            m1pbranch:false          m1pbranch:true
            (-1)^(1/3)               1/2+%i*sqrt(3)/2
            (-1)^(1/4)              sqrt(2)/2+%i*sqrt(2)/2
5.2 Strings
5.2.1 Introduction to Strings
Strings (quoted character sequences) are enclosed in double quote marks " for input, and
displayed with or without the quote marks, depending on the global variable stringdisp.
   Strings may contain any characters, including embedded tab, newline, and carriage re-
turn characters. The sequence \" is recognized as a literal double quote, and \\ as a literal
backslash. When backslash appears at the end of a line, the backslash and the line termina-
tion (either newline or carriage return and newline) are ignored, so that the string continues
with the next line. No other special combinations of backslash with another character are
recognized; when backslash appears before any character other than ", \, or a line termi-
nation, the backslash is ignored. There is no way to represent a special character (such as
tab, newline, or carriage return) except by embedding the literal character in the string.
    There is no character type in Maxima; a single character is represented as a one-character
string.
   The stringproc add-on package contains many functions for working with strings.
   Examples:
      (%i1) s_1 : "This is a string.";
      (%o1)                   This is a string.
      (%i2) s_2 : "Embedded \"double quotes\" and backslash \\ characters.";
      (%o2) Embedded "double quotes" and backslash \ characters.
      (%i3) s_3 : "Embedded line termination
      (%o3) Embedded line termination
      in this string.
      (%i4) in this string.";
      (%o4) Ignore the line termination characters in this string.
      (%i5) s_4 : "Ignore the \
      (%o5)                         false
      (%i6) line termination \
      (%o6)                   This is a string.
      (%i7) characters in \
      (%o7)                         true
      (%i8) this string.";
      (%o8)                  "This is a string."
      (%i9) stringdisp : false;
           (%i2) z: 88$
           (%i3) concat (y, z/2);
           (%o3)                                744
           (%i4) concat ('y, z/2);
           (%o4)                                y44
     A symbol constructed by concat may be assigned a value and appear in expressions.
     The :: (double colon) assignment operator evaluates its left-hand side.
           (%i5)   a: concat ('y, z/2);
           (%o5)                                y44
           (%i6)   a:: 123;
           (%o6)                                123
           (%i7)   y44;
           (%o7)                                123
           (%i8)   b^a;
                                                y44
           (%o8)                               b
           (%i9) %, numer;
                                                123
           (%o9)                               b
     Note that although concat (1, 2) looks like a number, it is a string.
           (%i10) concat (1, 2) + 3;
           (%o10)                            12 + 3
5.3 Constants
5.3.1 Functions and Variables for Constants
%e                                                                                 [Constant]
       %e represents the base of the natural logarithm, also known as Euler’s number. The
       numeric value of %e is the double-precision floating-point value 2.718281828459045d0.
%i                                                                                [Constant]
       %i represents the imaginary unit, sqrt(−1).
false                                                                       [Constant]
       false represents the Boolean constant of the same name. Maxima implements false
       by the value NIL in Lisp.
%gamma                                                                            [Constant]
       The Euler-Mascheroni constant, 0.5772156649015329 ....
ind                                                                               [Constant]
       ind represents a bounded, indefinite result.
       See also limit.
       Example:
             (%i1) limit (sin(1/x), x, 0);
             (%o1)                                 ind
inf                                                                               [Constant]
       inf represents real positive infinity.
infinity                                                                          [Constant]
       infinity represents complex infinity.
minf                                                                              [Constant]
       minf represents real minus (i.e., negative) infinity.
%phi                                                                            [Constant]
       %phi represents the so-called golden mean, (1+sqrt(5))/2. The numeric value of %phi
       is the double-precision floating-point value 1.618033988749895d0.
       fibtophi expresses Fibonacci numbers fib(n) in terms of %phi.
       By default, Maxima does not know the algebraic properties of %phi. After evaluat-
       ing tellrat(%phi^2 - %phi - 1) and algebraic: true, ratsimp can simplify some
       expressions containing %phi.
       Examples:
       fibtophi expresses Fibonacci numbers fib(n) in terms of %phi.
              (%i1) fibtophi (fib (n));
                                               n               n
                                          %phi - (1 - %phi)
              (%o1)                       -------------------
                                               2 %phi - 1
Chapter 5: Data Types and Structures                                                     51
zerob                                                                           [Constant]
     zerob represents an infinitesimal below zero. zerob can be used in expressions. limit
     simplifies expressions which contain infinitesimals.
     See also zeroa and limit.
Chapter 5: Data Types and Structures                                                        53
5.4 Lists
5.4.1 Introduction to Lists
Lists are the basic building block for Maxima and Lisp. All data types other than arrays,
hashed arrays and numbers are represented as Lisp lists, These Lisp lists have the form
      ((MPLUS) $A 2)
to indicate an expression a+2. At Maxima level one would see the infix notation a+2.
Maxima also has lists which are printed as
      [1, 2, 7, x+y]
for a list with 4 elements. Internally this corresponds to a Lisp list of the form
      ((MLIST) 1 2 7 ((MPLUS) $X $Y))
The flag which denotes the type field of the Maxima expression is a list itself, since after it
has been through the simplifier the list would become
      ((MLIST SIMP) 1 2 7 ((MPLUS SIMP) $X $Y))
[                                                                                    [Operator]
]                                                                                    [Operator]
      [ and ] mark the beginning and end, respectively, of a list.
      [ and ] also enclose the subscripts of a list, array, hashed array, or memoizing
      function. Note that other than for arrays accessing the nth element of a list may need
      an amount of time that is roughly proportional to n, See Section 5.4.3 [Performance
      considerations for Lists], page 70.
      Note that if an element of a subscripted variable is written to before a list or an array
      of this name is declared a hashed array (see Section 5.5 [Arrays], page 72) is created,
      not a list.
      Examples:
            (%i1)   x: [a, b, c];
            (%o1)                              [a, b, c]
            (%i2)   x[3];
            (%o2)                                   c
            (%i3)   array (y, fixnum, 3);
            (%o3)                                   y
            (%i4)   y[2]: %pi;
            (%o4)                                  %pi
            (%i5)   y[2];
            (%o5)                                  %pi
            (%i6)   z['foo]: 'bar;
            (%o6)                                  bar
            (%i7)   z['foo];
            (%o7)                                  bar
54                                                                   Maxima 5.45.0 Manual
assoc                                                                              [Function]
         assoc (key, e, default)
         assoc (key, e)
     assoc searches for key as the first part of an argument of e and returns the second
     part of the first match, if any.
     key may be any expression. e must be a nonatomic expression, and every argument
     of e must have exactly two parts. assoc returns the second part of the first match-
     ing argument of e. Matches are determined by is(key = first(a)) where a is an
     argument of e.
     If there are two or more matches, only the first is returned. If there are no matches,
     default is returned, if specified. Otherwise, false is returned.
     See also sublist and member.
     Examples:
     key may be any expression. e must be a nonatomic expression, and every argument
     of e must have exactly two parts. assoc returns the second part of the first matching
     argument of e.
           (%i1) assoc (f(x), foo(g(x) = y, f(x) = z + 1, h(x) = 2*u));
           (%o1)                         z + 1
     If there are two or more matches, only the first is returned.
           (%i1) assoc (yy, [xx = 111, yy = 222, yy = 333, yy = 444]);
           (%o1)                          222
     If there are no matches, default is returned, if specified. Otherwise, false is returned.
           (%i1) assoc (abc, [[x, 111], [y, 222], [z, 333]], none);
           (%o1)                         none
           (%i2) assoc (abc, [[x, 111], [y, 222], [z, 333]]);
           (%o2)                         false
Chapter 5: Data Types and Structures                                                      55
cons                                                                              [Function]
           cons (expr, list)
           cons (expr_1, expr_2)
       cons (expr, list) returns a new list constructed of the element expr as its first
       element, followed by the elements of list. This is analogous to the Lisp language
       construction operation "cons".
       The Maxima function cons can also be used where the second argument is other than a
       list and this might be useful. In this case, cons (expr_1, expr_2) returns an expres-
       sion with same operator as expr 2 but with argument cons(expr_1, args(expr_2)).
       Examples:
              (%i1) cons(a,[b,c,d]);
              (%o1)                            [a, b, c, d]
              (%i2) cons(a,f(b,c,d));
              (%o2)                            f(a, b, c, d)
       In general, cons applied to a nonlist doesn’t make sense. For instance, cons(a,b^c)
       results in an illegal expression, since ’^’ cannot take three arguments.
       When inflag is true, cons operates on the internal structure of an expression, oth-
       erwise cons operates on the displayed form. Especially when inflag is true, cons
       applied to a nonlist sometimes gives a surprising result; for example
              (%i1) cons(a,-a), inflag : true;
                                                        2
              (%o1)                                  - a
              (%i2) cons(a,-a), inflag : false;
              (%o2)                                    0
delete                                                                          [Function]
         delete (expr_1, expr_2)
         delete (expr_1, expr_2, n)
     delete(expr_1, expr_2) removes from expr 2 any arguments of its top-level oper-
     ator which are the same (as determined by "=") as expr 1. Note that "=" tests for
     formal equality, not equivalence. Note also that arguments of subexpressions are not
     affected.
     expr 1 may be an atom or a non-atomic expression. expr 2 may be any non-atomic
     expression. delete returns a new expression; it does not modify expr 2.
     delete(expr_1, expr_2, n) removes from expr 2 the first n arguments of the top-
     level operator which are the same as expr 1. If there are fewer than n such arguments,
     then all such arguments are removed.
     Examples:
     Removing elements from a list.
           (%i1) delete (y, [w, x, y, z, z, y, x, w]);
           (%o1)                  [w, x, z, z, x, w]
     Removing terms from a sum.
           (%i1) delete (sin(x), x + sin(x) + y);
           (%o1)                         y + x
     Removing factors from a product.
           (%i1) delete (u - x, (u - w)*(u - x)*(u - y)*(u - z));
           (%o1)                (u - w) (u - y) (u - z)
     Removing arguments from an arbitrary expression.
           (%i1) delete (a, foo (a, b, c, d, a));
           (%o1)                     foo(b, c, d)
     Limit the number of removed arguments.
           (%i1) delete (a, foo (a, b, a, c, d, a), 2);
           (%o1)                    foo(b, c, d, a)
     Whether arguments are the same as expr 1 is determined by "=". Arguments which
     are equal but not "=" are not removed.
           (%i1) [is (equal (0, 0)), is (equal (0, 0.0)), is (equal (0, 0b0))];
           (%o1)                  [true, true, true]
           (%i2) [is (0 = 0), is (0 = 0.0), is (0 = 0b0)];
           (%o2)                 [true, false, false]
           (%i3) delete (0, [0, 0.0, 0b0]);
           (%o3)                     [0.0, 0.0b0]
           (%i4) is (equal ((x + y)*(x - y), x^2 - y^2));
           (%o4)                         true
           (%i5) is ((x + y)*(x - y) = x^2 - y^2);
           (%o5)                         false
           (%i6) delete ((x + y)*(x - y), [(x + y)*(x - y), x^2 - y^2]);
                                         2    2
           (%o6)                       [x - y ]
Chapter 5: Data Types and Structures                                                       57
endcons                                                                            [Function]
          endcons (expr, list)
          endcons (expr_1, expr_2)
     endcons (expr, list) returns a new list constructed of the elements of list followed
     by expr. The Maxima function endcons can also be used where the second argu-
     ment is other than a list and this might be useful. In this case, endcons (expr_1,
     expr_2) returns an expression with same operator as expr 2 but with argument
     endcons(expr_1, args(expr_2)). Examples:
          (%i1) endcons(a,[b,c,d]);
          (%o1)                           [b, c, d, a]
          (%i2) endcons(a,f(b,c,d));
          (%o2)                           f(b, c, d, a)
     In general, endcons applied to a nonlist doesn’t make sense. For instance,
     endcons(a,b^c) results in an illegal expression, since ’^’ cannot take three
     arguments.
     When inflag is true, endcons operates on the internal structure of an expression,
     otherwise endcons operates on the displayed form. Especially when inflag is true,
     endcons applied to a nonlist sometimes gives a surprising result; for example
          (%i1) endcons(a,-a), inflag : true;
                                                  2
          (%o1)                               - a
          (%i2) endcons(a,-a), inflag : false;
          (%o2)                                  0
     Note that first and its related functions, rest and last, work on the form of expr
     which is displayed not the form which is typed on input. If the variable inflag is set
     to true however, these functions will look at the internal form of expr. One reason
     why this may make a difference is that the simplifier re-orders expressions:
           (%i1) x+y;
           (%o1)                                     y+1
           (%i2) first(x+y),inflag : true;
           (%o2)                                     x
           (%i3) first(x+y),inflag : false;
           (%o3)                                     y
     The functions second . . . tenth yield the second through the tenth part of their
     input argument.
     See also firstn and part.
     lreduce(F, s) returns F(... F(F(s_1, s_2), s_3), ... s_n). When the optional
     argument s 0 is present, the result is equivalent to lreduce(F, cons(s_0, s)).
     The function F is first applied to the leftmost list elements, thus the name "lreduce".
     See also rreduce, xreduce, and tree_reduce.
     Examples:
     lreduce without the optional argument.
           (%i1) lreduce (f, [1, 2, 3]);
           (%o1)                            f(f(1, 2), 3)
           (%i2) lreduce (f, [1, 2, 3, 4]);
           (%o2)                        f(f(f(1, 2), 3), 4)
     lreduce with the optional argument.
           (%i1) lreduce (f, [1, 2, 3], 4);
           (%o1)                        f(f(f(4, 1), 2), 3)
     lreduce applied to built-in binary operators. / is the division operator.
           (%i1) lreduce ("^", args ({a, b, c, d}));
                                                  b c d
           (%o1)                               ((a ) )
           (%i2) lreduce ("/", args ({a, b, c, d}));
                                                   a
           (%o2)                                 -----
                                                 b c d
makelist                                                                         [Function]
        makelist       ()
        makelist       (expr, n)
        makelist       (expr, i, i_max)
        makelist       (expr, i, i_0, i_max)
        makelist       (expr, i, i_0, i_max, step)
        makelist       (expr, x, list)
     The first form, makelist (), creates an empty list. The second form, makelist
     (expr), creates a list with expr as its single element. makelist (expr, n) creates a
     list of n elements generated from expr.
     The most general form, makelist (expr, i, i_0, i_max, step), returns the list of
     elements obtained when ev (expr, i=j) is applied to the elements j of the sequence:
     i 0, i 0 + step, i 0 + 2*step, ..., with |j| less than or equal to |i max|.
     The increment step can be a number (positive or negative) or an expression. If it is
     omitted, the default value 1 will be used. If both i 0 and step are omitted, they will
     both have a default value of 1.
     makelist (expr, x, list) returns a list, the jth element of which is equal to ev
     (expr, x=list[j]) for j equal to 1 through length (list).
     Examples:
            (%i1) makelist (concat (x,i), i, 6);
            (%o1)                     [x1, x2, x3, x4, x5, x6]
            (%i2) makelist (x=y, y, [a, b, c]);
            (%o2)                        [x = a, x = b, x = c]
Chapter 5: Data Types and Structures                                                   63
       item can be any Maxima symbol or expression. If the argument list is not bound to
       a list, Maxima signals an error.
       To remove the first item from a list, see pop.
       Examples:
             (%i1) ll: [];
             (%o1)                                  []
             (%i2) push (x, ll);
             (%o2)                                  [x]
             (%i3) push (x^2+y, ll);
                                              2
             (%o3)                      [y + x , x]
             (%i4) a: push ("string", ll);
                                                  2
             (%o4)                  [string, y + x , x]
             (%i5) pop (ll);
             (%o5)                        string
             (%i6) pop (ll);
                                               2
             (%o6)                        y + x
             (%i7) pop (ll);
             (%o7)                           x
             (%i8) ll;
             (%o8)                          []
             (%i9) a;
                                                  2
             (%o9)                  [string, y + x , x]
rest                                                                                 [Function]
           rest (expr, n)
           rest (expr)
       Returns expr with its first n elements removed if n is positive and its last - n elements
       removed if n is negative. If n is 1 it may be omitted. The first argument expr may
       be a list, matrix, or other expression. When expr is an atom, rest signals an error;
       when expr is an empty list and partswitch is false, rest signals an error. When
       expr is an empty list and partswitch is true, rest returns end.
       Applying rest to expression such as f(a,b,c) returns f(b,c). In general, applying
       rest to a nonlist doesn’t make sense. For example, because ’^’ requires two argu-
       ments, rest(a^b) results in an error message. The functions args and op may be
       useful as well, since args(a^b) returns [a,b] and op(a^b) returns ^.
       See also firstn and lastn.
             (%i1)   rest(a+b+c);
             (%o1)   b+a
             (%i2)   rest(a+b+c,2);
             (%o2)   a
             (%i3)   rest(a+b+c,-2);
             (%o3)   c
Chapter 5: Data Types and Structures                                                        65
     in the result. If neither P(a, b) nor P(b, a) are true, then a and b are equivalent,
     and appear in the result in the same order as in the input. That is, sort is a stable
     sort.
     If P(a, b) and P(b, a) are both true for some elements of L, then P is not a valid
     sort predicate, and the result is undefined. If P(a, b) is something other than true
     or false, sort signals an error.
     The predicate may be specified as the name of a function or binary infix operator, or
     as a lambda expression. If specified as the name of an operator, the name must be
     enclosed in double quotes.
     The sorted list is returned as a new object; the argument L is not modified.
     sort(L) is equivalent to sort(L, orderlessp).
     The default sorting order is ascending, as determined by orderlessp. The predicate
     ordergreatp sorts a list in descending order.
     All Maxima atoms and expressions are comparable under orderlessp and
     ordergreatp.
     Operators < and > order numbers, constants, and constant expressions by magni-
     tude. Note that orderlessp and ordergreatp do not order numbers, constants, and
     constant expressions by magnitude.
     ordermagnitudep orders numbers, constants, and constant expressions the same as
     <, and all other elements the same as orderlessp.
     Examples:
     sort sorts a list according to a predicate of two arguments which defines a strict weak
     order on the elements of the list.
           (%i1) sort ([1, a, b, 2, 3, c], 'orderlessp);
           (%o1)                         [1, 2, 3, a, b, c]
           (%i2) sort ([1, a, b, 2, 3, c], 'ordergreatp);
           (%o2)                         [c, b, a, 3, 2, 1]
     The predicate may be specified as the name of a function or binary infix operator, or
     as a lambda expression. If specified as the name of an operator, the name must be
     enclosed in double quotes.
           (%i1) L : [[1, x], [3, y], [4, w], [2, z]];
           (%o1)                [[1, x], [3, y], [4, w], [2, z]]
           (%i2) foo (a, b) := a[1] > b[1];
           (%o2)                       foo(a, b) := a > b
                                                         1    1
           (%i3) sort (L, 'foo);
           (%o3)                [[4, w], [3, y], [2, z], [1, x]]
           (%i4) infix (">>");
           (%o4)                                   >>
           (%i5) a >> b := a[1] > b[1];
           (%o5)                         (a >> b) := a > b
                                                         1    1
           (%i6) sort (L, ">>");
           (%o6)                [[4, w], [3, y], [2, z], [1, x]]
Chapter 5: Data Types and Structures                                            67
     unchanged if there are an odd number of elements. Then repeat until the list is
     reduced to a single element, which is the return value.
     When the optional argument s 0 is present, the result is equivalent tree_reduce(F,
     cons(s_0, s)).
     For addition of floating point numbers, tree_reduce may return a sum that has a
     smaller rounding error than either rreduce or lreduce.
     The elements of s and the partial results may be arranged in a minimum-depth binary
     tree, thus the name "tree reduce".
     Examples:
     tree_reduce applied to a list with an even number of elements.
            (%i1) tree_reduce (f, [a, b, c, d]);
            (%o1)                       f(f(a, b), f(c, d))
     tree_reduce applied to a list with an odd number of elements.
            (%i1) tree_reduce (f, [a, b, c, d, e]);
            (%o1)                  f(f(f(a, b), f(c, d)), e)
unique (L)                                                                 [Function]
     Returns the unique elements of the list L.
     When all the elements of L are unique, unique returns a shallow copy of L, not L
     itself.
     If L is not a list, unique returns L.
     Example:
             (%i1) unique ([1, %pi, a + b, 2, 1, %e, %pi, a + b, [1]]);
             (%o1)                  [1, 2, %e, %pi, [1], b + a]
xreduce                                                                         [Function]
          xreduce (F, s)
          xreduce (F, s, s_0)
     Extends the function F to an n-ary function by composition, or, if F is already n-ary,
     applies F to s. When F is not n-ary, xreduce is the same as lreduce. The argument
     s is a list.
     Functions known to be n-ary include addition +, multiplication *, and, or, max, min,
     and append. Functions may also be declared n-ary by declare(F, nary). For these
     functions, xreduce is expected to be faster than either rreduce or lreduce.
     When the optional argument s 0 is present, the result is equivalent to xreduce(s,
     cons(s_0, s)).
     Floating point addition is not exactly associative; be that as it may, xreduce applies
     Maxima’s n-ary addition when s contains floating point numbers.
     Examples:
     xreduce applied to a function known to be n-ary. F is called once, with all arguments.
            (%i1) declare (F, nary);
            (%o1)                               done
            (%i2) F ([L]) := L;
            (%o2)                           F([L]) := L
70                                                                       Maxima 5.45.0 Manual
       (%o2)                              done
     Another even faster example would be:
       (%i1) l:[Test,1,2,3,4];
       (%o1)                      [Test, 1, 2, 3, 4]
       (%i2) for i in l do
          disp(pop(l));
                                          Test
                                                3
Chapter 5: Data Types and Structures                                                      71
      (%o2)                                done
   Beginning traversal with the last element of a list is possible after reversing the list
using reverse (). If the elements of a long list need to be processed in a different order
performance might be increased by converting the list into a declared array first.
   Note also that the ending condition of for loops is tested for every iteration which means
that the result of a length should be cached if it is used in the ending condition:
      (%i1) l:makelist(i,i,1,100000)$
      (%i2) lngth:length(l);
      (%o2)                               100000
      (%i3) x:1;
      (%o3)                                  1
      (%i4) for i:1 thru lngth do
           x:x+1$
      (%i5) x;
      (%o5)                               100001
72                                                                   Maxima 5.45.0 Manual
5.5 Arrays
Maxima supports 3 array-like constructs:
 • If one tries to write to an indexed variable without creating a list first an undeclared
   array (also named hashed array) is created that grows dynamically and allows numbers,
   symbols and strings as indices:
          (%i1) a["feww"]:1;
          (%o1)                                 1
          (%i2) a[qqwdqwd]:3;
          (%o2)                                 3
          (%i3) a[5]:99;
          (%o3)                                99
          (%i4) a[qqwdqwd];
          (%o4)                                 3
          (%i5) a[5];
          (%o5)                                99
          (%i6) a["feww"];
          (%o6)                                 1
   Since lisp handles hashed arrays and memoizing functions similar to arrays many of
   the functions that can be applied to arrays can be applied to them, as well.
 • Lists (see makelist allow for fast addition and removal of elements, can be created
   without knowing their final size.
 • Declared arrays that allow fast access to random elements at the cost that their size
   needs to be known at construction time. (See Section 5.4.3 [Performance considerations
   for Lists], page 70.)
           (%i1) cc [x, y] := y / x;
                                                    y
           (%o1)                          cc     := -
                                            x, y    x
           (%i2) cc [u, v];
                                                v
           (%o2)                                -
                                                u
           (%i3) cc [4, z];
                                                z
           (%o3)                                -
                                                4
           (%i4) arrayinfo (cc);
           (%o4)              [hashed, 2, [4, z], [u, v]]
           (%i5) listarray (cc);
                                         z v
           (%o5)                        [-, -]
                                         4 u
     Using arrayinfo in order to convert an undeclared array to a declared array:
           (%i1)   for i:0 thru 10 do a[i]:i^2$
           (%i2)   indices:map(first,rest(rest(arrayinfo(a))));
           (%o2)            [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
           (%i3)   array(A,fixnum,length(indices)-1)$
           (%i4)   fillarray(A,map(lambda([x],a[x]),indices))$
           (%i5)   listarray(A);
           (%o5)         [0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
     arrayinfo and listarray applied to a subscripted function.
           (%i1) dd [x] (y) := y ^ x;
                                                    x
           (%o1)                         dd (y) := y
                                           x
           (%i2) dd [a + b];
                                                  b + a
           (%o2)                     lambda([y], y      )
           (%i3) dd [v - u];
                                                  v - u
           (%o3)                     lambda([y], y      )
           (%i4) arrayinfo (dd);
           (%o4)             [hashed, 1, [b + a], [v - u]]
           (%i5) listarray (dd);
                                    b + a                 v - u
           (%o5)      [lambda([y], y      ), lambda([y], y      )]
     Examples:
         (%i1) array (aa, 5, 7);
         (%o1)                                   aa
         (%i2) bb [FOO] : (a + b)^2;
                                                    2
           (%o2)                             (b + a)
           (%i3) cc [x] := x/100;
                                                x
           (%o3)                        cc := ---
                                          x    100
           (%i4)   dd : make_array ('any, 7);
           (%o4)       {Lisp Array: #(NIL NIL NIL NIL NIL NIL NIL)}
           (%i5)   arrays;
           (%o5)                       [aa, bb, cc]
arraysetapply (A, [i_1, . . . , i_n], x)                                         [Function]
     Assigns x to A[i_1, ..., i_n], where A is an array and i 1, . . . , i n are integers.
     arraysetapply evaluates its arguments.
fillarray (A, B)                                                                [Function]
     Fills array A from B, which is a list or an array.
     If a specific type was declared for A when it was created, it can only be filled with
     elements of that same type; it is an error if an attempt is made to copy an element
     of a different type.
     If the dimensions of the arrays A and B are different, A is filled in row-major order.
     If there are not enough elements in B the last element is used to fill out the rest of
     A. If there are too many, the remaining ones are ignored.
     fillarray returns its first argument.
     Examples:
     Create an array of 9 elements and fill it from a list.
            (%i1) array (a1, fixnum, 8);
            (%o1)                                 a1
            (%i2) listarray (a1);
            (%o2)                  [0, 0, 0, 0, 0, 0, 0, 0, 0]
            (%i3) fillarray (a1, [1, 2, 3, 4, 5, 6, 7, 8, 9]);
            (%o3)                                 a1
            (%i4) listarray (a1);
            (%o4)                  [1, 2, 3, 4, 5, 6, 7, 8, 9]
     When there are too few elements to fill the array, the last element is repeated. When
     there are too many elements, the extra elements are ignored.
            (%i1) a2 : make_array (fixnum, 8);
            (%o1)              {Lisp Array: #(0 0 0 0 0 0 0 0)}
            (%i2) fillarray (a2, [1, 2, 3, 4, 5]);
            (%o2)              {Lisp Array: #(1 2 3 4 5 5 5 5)}
            (%i3) fillarray (a2, [4]);
            (%o3)              {Lisp Array: #(4 4 4 4 4 4 4 4)}
Chapter 5: Data Types and Structures                                                    77
     make_array (...) then y points to an object which takes up space, but after y:
     false, y no longer points to that object, so the object can be garbage collected.
Examples:
remarray                                                                             [Function]
        remarray (A_1, . . . , A_n)
        remarray (all)
     Removes arrays and array associated functions and frees the storage occupied. The
     arguments may be declared arrays, hashed arrays, array functions, and subscripted
     functions.
     remarray (all) removes all items in the global list arrays.
     It may be necessary to use this function if it is desired to clear the cache of a memoizing
     function.
     remarray returns the list of arrays removed.
     remarray quotes its arguments.
5.6 Structures
5.6.1 Introduction to Structures
Maxima provides a simple data aggregate called a structure. A structure is an expression
in which arguments are identified by name (the field name) and the expression as a whole
is identified by its operator (the structure name). A field value can be any expression.
   A structure is defined by the defstruct function; the global variable structures is
the list of user-defined structures. The function new creates instances of structures. The
@ operator refers to fields. kill(S) removes the structure definition S, and kill(x@ a)
unbinds the field a of the structure instance x.
   In the pretty-printing console display (with display2d equal to true), structure in-
stances are displayed with the value of each field represented as an equation, with the field
name on the left-hand side and the value on the right-hand side. (The equation is only a
display construct; only the value is actually stored.) In 1-dimensional display (via grind or
with display2d equal to false), structure instances are displayed without the field names.
   There is no way to use a field name as a function name, although a field value can be
a lambda expression. Nor can the values of fields be restricted to certain types; any field
can be assigned any kind of expression. There is no way to make some fields accessible or
inaccessible in different contexts; all fields are always visible.
defstruct                                                                         [Function]
        defstruct (S(a_1, . . . , a_n))
        defstruct (S(a_1 = v_1, . . . , a_n = v_n))
      Define a structure, which is a list of named fields a 1, . . . , a n associated with a
      symbol S. An instance of a structure is just an expression which has operator S and
      exactly n arguments. new(S) creates a new instance of structure S.
      An argument which is just a symbol a specifies the name of a field. An argument
      which is an equation a = v specifies the field name a and its default value v. The
      default value can be any expression.
      defstruct puts S on the list of user-defined structures, structures.
      kill(S) removes S from the list of user-defined structures, and removes the structure
      definition.
      Examples:
            (%i1)   defstruct (foo (a, b, c));
            (%o1)                      [foo(a, b, c)]
            (%i2)   structures;
            (%o2)                      [foo(a, b, c)]
            (%i3)   new (foo);
            (%o3)                       foo(a, b, c)
            (%i4)   defstruct (bar (v, w, x = 123, y = %pi));
Chapter 5: Data Types and Structures                                                         83
           (%i8) u@z;
           (%o8)                            u@z
     The field name is not evaluated.
           (%i1) defstruct (bar (g, h));
           (%o1)                        [bar(g, h)]
           (%i2) x : new (bar);
           (%o2)                         bar(g, h)
           (%i3) x@h : 42;
           (%o3)                            42
           (%i4) h : 123;
           (%o4)                            123
           (%i5) x@h;
           (%o5)                            42
           (%i6) x@h : 19;
           (%o6)                            19
           (%i7) x;
           (%o7)                      bar(g, h = 19)
           (%i8) h;
           (%o8)                            123
                                                                                      85
6 Expressions
forms of a function are identical when displayed. The global flag noundisp causes Maxima
to display nouns with a leading quote mark '.
     See also noun, nouns, nounify, and verbify.
     Examples:
       (%i1) foo (x) := x^2;
                                                 2
       (%o1)                          foo(x) := x
       (%i2)   foo (42);
       (%o2)                               1764
       (%i3)   'foo (42);
       (%o3)                             foo(42)
       (%i4)   'foo (42), nouns;
       (%o4)                               1764
       (%i5)   declare (bar, noun);
       (%o5)                               done
       (%i6)   bar (x) := x/17;
                                                x
       (%o6)                          bar(x) := --
                                                17
       (%i7) bar (52);
       (%o7)                         bar(52)
       (%i8) bar (52), nouns;
       (%o8)                         bar(52)
       (%i9) integrate (1/x, x, 1, 42);
       (%o9)                         log(42)
       (%i10) 'integrate (1/x, x, 1, 42);
                                     42
                                   /
                                   [    1
       (%o10)                      I    - dx
                                   ]    x
                                   /
                                     1
       (%i11) ev (%, nouns);
       (%o11)                        log(42)
6.3 Identifiers
Maxima identifiers may comprise alphabetic characters, plus the numerals 0 through 9, plus
any special character preceded by the backslash \ character.
  A numeral may be the first character of an identifier if it is preceded by a backslash.
Numerals which are the second or later characters need not be preceded by a backslash.
   Characters may be declared alphabetic by the declare function. If so declared, they
need not be preceded by a backslash in an identifier. The alphabetic characters are initially
A through Z, a through z, %, and _.
Chapter 6: Expressions                                                                    87
   Maxima is case-sensitive. The identifiers foo, FOO, and Foo are distinct. See Section 37.1
[Lisp and Maxima], page 641, for more on this point.
   A Maxima identifier is a Lisp symbol which begins with a dollar sign $. Any other Lisp
symbol is preceded by a question mark ? when it appears in Maxima. See Section 37.1 [Lisp
and Maxima], page 641, for more on this point.
   Examples:
      (%i1) %an_ordinary_identifier42;
      (%o1)               %an_ordinary_identifier42
      (%i2) embedded\ spaces\ in\ an\ identifier;
      (%o2)           embedded spaces in an identifier
      (%i3) symbolp (%);
      (%o3)                         true
      (%i4) [foo+bar, foo\+bar];
      (%o4)                 [foo + bar, foo+bar]
      (%i5) [1729, \1729];
      (%o5)                     [1729, 1729]
      (%i6) [symbolp (foo\+bar), symbolp (\1729)];
      (%o6)                     [true, true]
      (%i7) [is (foo\+bar = foo+bar), is (\1729 = 1729)];
      (%o7)                    [false, false]
      (%i8) baz\~quux;
      (%o8)                       baz~quux
      (%i9) declare ("~", alphabetic);
      (%o9)                         done
      (%i10) baz~quux;
      (%o10)                      baz~quux
      (%i11) [is (foo = FOO), is (FOO = Foo), is (Foo = foo)];
      (%o11)                [false, false, false]
      (%i12) :lisp (defvar *my-lisp-variable* '$foo)
      *MY-LISP-VARIABLE*
      (%i12) ?\*my\-lisp\-variable\*;
      (%o12)                         foo
6.4 Inequality
Maxima has the inequality operators <, <=, >=, >, #, and notequal. See if for a description
of conditional expressions.
     aliases is the list of atoms which have an user defined alias (set up by the alias,
     ordergreat, orderless functions or by declaring the atom a noun with declare.)
allbut                                                                    [Keyword]
     works with the part commands (i.e. part, inpart, substpart, substinpart, dpart,
     and lpart). For example,
            (%i1) expr : e + d + c + b + a;
            (%o1)                       e + d + c + b + a
            (%i2) part (expr, [2, 5]);
            (%o2)                             d + a
     while
            (%i1) expr : e + d + c + b + a;
            (%o1)                       e + d + c + b + a
            (%i2) part (expr, allbut (2, 5));
            (%o2)                           e + c + b
     allbut is also recognized by kill.
            (%i1) [aa : 11, bb : 22, cc : 33, dd : 44, ee : 55];
            (%o1)                     [11, 22, 33, 44, 55]
            (%i2) kill (allbut (cc, dd));
            (%o0)                             done
            (%i1) [aa, bb, cc, dd];
            (%o1)                       [aa, bb, 33, 44]
     kill(allbut(a_1, a_2, ...)) has the effect of kill(all) except that it does not
     kill the symbols a 1, a 2, . . .
box                                                                             [Function]
          box (expr)
          box (expr, a)
      Returns expr enclosed in a box. The return value is an expression with box as the
      operator and expr as the argument. A box is drawn on the display when display2d
      is true.
      box (expr, a) encloses expr in a box labelled by the symbol a. The label is truncated
      if it is longer than the width of the box.
      box evaluates its argument. However, a boxed expression does not evaluate to its
      content, so boxed expressions are effectively excluded from computations. rembox
      removes the box again.
      boxchar is the character used to draw the box in box and in the dpart and lpart
      functions.
      See also rembox, dpart and lpart.
      Examples:
            (%i1) box (a^2 + b^2);
                                             """""""""
                                             " 2    2"
            (%o1)                            "b + a "
                                             """""""""
            (%i2) a : 1234;
            (%o2)                         1234
            (%i3) b : c - d;
            (%o3)                         c - d
            (%i4) box (a^2 + b^2);
                                  """"""""""""""""""""
                                  "       2          "
            (%o4)                 "(c - d) + 1522756"
                                  """"""""""""""""""""
            (%i5) box (a^2 + b^2, term_1);
                                  term_1""""""""""""""
                                  "       2          "
            (%o5)                 "(c - d) + 1522756"
                                  """"""""""""""""""""
            (%i6) 1729 - box (1729);
                                             """"""
            (%o6)                     1729 - "1729"
                                             """"""
            (%i7) boxchar: "-";
            (%o7)                           -
90                                                                   Maxima 5.45.0 Manual
dispform                                                                        [Function]
        dispform (expr)
        dispform (expr, all)
     Returns the external representation of expr.
     dispform(expr) returns the external representation with respect to the main (top-
     level) operator. dispform(expr, all) returns the external representation with re-
     spect to all operators in expr.
     See also part, inpart, and inflag.
     Examples:
     The internal representation of - x is "negative one times x" while the external repre-
     sentation is "minus x".
           (%i1) - x;
           (%o1)                          - x
           (%i2) ?format (true, "~S~%", %);
           ((MTIMES SIMP) -1 $X)
           (%o2)                         false
           (%i3) dispform (- x);
           (%o3)                          - x
           (%i4) ?format (true, "~S~%", %);
           ((MMINUS SIMP) $X)
           (%o4)                         false
     The internal representation of sqrt(x) is "x to the power 1/2" while the external
     representation is "square root of x".
           (%i1) sqrt (x);
           (%o1)                              sqrt(x)
           (%i2) ?format (true, "~S~%",       %);
           ((MEXPT SIMP) $X ((RAT SIMP)       1 2))
           (%o2)                               false
           (%i3) dispform (sqrt (x));
           (%o3)                              sqrt(x)
           (%i4) ?format (true, "~S~%",       %);
           ((%SQRT SIMP) $X)
           (%o4)                               false
     Use of the optional argument all.
           (%i1)   expr : sin (sqrt (x));
           (%o1)                       sin(sqrt(x))
           (%i2)   freeof (sqrt, expr);
           (%o2)                           true
           (%i3)   freeof (sqrt, dispform (expr));
           (%o3)                           true
           (%i4)   freeof (sqrt, dispform (expr, all));
           (%o4)                           false
92                                                                 Maxima 5.45.0 Manual
           (%o5)                                 %e
           (%i6) freeof (exp, exp (x));
           (%o6)                               true
     A summation or definite integral is free of its dummy variable. An indefinite integral
     is not free of its variable of integration.
           (%i1) freeof (i, 'sum (f(i), i, 0, n));
           (%o1)                         true
           (%i2) freeof (x, 'integrate (x^2, x, 0, 1));
           (%o2)                         true
           (%i3) freeof (x, 'integrate (x^2, x));
           (%o3)                         false
(%t2) 2 a
(%t3) 2 b
                                          2           2
           (%t4)                         b + 2 a b + a
                                2
           (%o4)               c + %t3 c + %t2 c + %t4
           (%i4) isolate_wrt_times: false$
           (%i5) isolate (expand ((a+b+c)^2), c);
                                2
           (%o5)               c + 2 b c + 2 a c + %t4
listconstvars                                                             [Option variable]
     Default value: false
     When listconstvars is true the list returned by listofvars contains constant
     variables, such as %e, %pi, %i or any variables declared as constant that occur in
     expr. A variable is declared as constant type via declare, and constantp returns
     true for all variables declared as constant. The default is to omit constant variables
     from listofvars return value.
listdummyvars                                                            [Option variable]
     Default value: true
     When listdummyvars is false, "dummy variables" in the expression will not be
     included in the list returned by listofvars. (The meaning of "dummy variables" is
96                                                                    Maxima 5.45.0 Manual
       as given in freeof. "Dummy variables" are mathematical things like the index of a
       sum or product, the limit variable, and the definite integration variable.)
       Example:
             (%i1) listdummyvars: true$
             (%i2) listofvars ('sum(f(i), i, 0, n));
             (%o2)                              [i, n]
             (%i3) listdummyvars: false$
             (%i4) listofvars ('sum(f(i), i, 0, n));
             (%o4)                                [n]
listofvars (expr)                                                                  [Function]
       Returns a list of the variables in expr.
       listconstvars if true causes listofvars to include %e, %pi, %i, and any variables
       declared constant in the list it returns if they appear in expr. The default is to omit
       these.
       See also the option variable listdummyvars to exclude or include "dummy variables"
       in the list of variables.
              (%i1) listofvars (f (x[1]+y) / g^(2+a));
              (%o1)                           [g, a, x , y]
                                                         1
lfreeof (list, expr)                                                           [Function]
       For each member m of list, calls freeof (m, expr). It returns false if any call to
       freeof does and true otherwise.
       Example:
             (%i1) lfreeof ([ a, x], x^2+b);
             (%o1)                             false
             (%i2) lfreeof ([ b, x], x^2+b);
             (%o2)                             false
             (%i3) lfreeof ([ a, y], x^2+b);
             (%o3)                             true
lpart (label, expr, n_1, . . . , n_k)                                          [Function]
       is similar to dpart but uses a labelled box. A labelled box is similar to the one
       produced by dpart but it has a name in the top line.
mainvar                                                                            [Property]
       You may declare variables to be mainvar. The ordering scale for atoms is essentially:
       numbers < constants (e.g., %e, %pi) < scalars < other variables < mainvars. E.g., com-
       pare expand ((X+Y)^4) with (declare (x, mainvar), expand ((x+y)^4)). (Note:
       Care should be taken if you elect to use the above feature. E.g., if you subtract an
       expression in which x is a mainvar from one in which x isn’t a mainvar, resimplifica-
       tion e.g. with ev (expr, simp) may be necessary if cancellation is to occur. Also, if
       you save an expression in which x is a mainvar, you probably should also save x.)
noun                                                                           [Property]
       noun is one of the options of the declare command. It makes a function so declared
       a "noun", meaning that it won’t be evaluated automatically.
Chapter 6: Expressions                                                                    97
     Example:
         (%i1) factor (12345678);
                                         2
            (%o1)                     2 3 47 14593
            (%i2) declare (factor, noun);
            (%o2)                          done
            (%i3) factor (12345678);
            (%o3)                   factor(12345678)
            (%i4) ''%, nouns;
                                         2
            (%o4)                     2 3 47 14593
noundisp                                                                   [Option variable]
     Default value: false
     When noundisp is true, nouns display with a single quote. This switch is always
     true when displaying function definitions.
nounify (f)                                                                     [Function]
     Returns the noun form of the function name f. This is needed if one wishes to refer
     to the name of a verb function as if it were a noun. Note that some verb functions
     will return their noun forms if they can’t be evaluated for certain arguments. This is
     also the form returned if a function call is preceded by a quote.
     See also verbify.
nterms (expr)                                                                 [Function]
     Returns the number of terms that expr would have if it were fully expanded out and
     no cancellations or combination of terms occurred. Note that expressions like sin
     (expr), sqrt (expr), exp (expr), etc. count as just one term regardless of how
     many terms expr has (if it is a sum).
op (expr)                                                                          [Function]
     Returns the main operator of the expression expr. op (expr) is equivalent to part
     (expr, 0).
     op returns a string if the main operator is a built-in or user-defined prefix, binary or
     n-ary infix, postfix, matchfix, or nofix operator. Otherwise, if expr is a subscripted
     function expression, op returns the subscripted function; in this case the return value
     is not an atom. Otherwise, expr is a memoizing function or ordinary function ex-
     pression, and op returns a symbol.
     op observes the value of the global flag inflag.
     op evaluates it argument.
     See also args.
     Examples:
           (%i1) stringdisp: true$
           (%i2) op (a * b * c);
           (%o2)                                  "*"
           (%i3) op (a * b + c);
           (%o3)                                  "+"
98                                                               Maxima 5.45.0 Manual
operatorp                                                                     [Function]
        operatorp (expr, op)
        operatorp (expr, [op_1, . . . , op_n])
     operatorp (expr, op) returns true if op is equal to the operator of expr.
     When opsubst is false, subst does not attempt to substitute into the operator of
     an expression. E.g., (opsubst: false, subst (x^2, r, r+r[0])) will work.
           (%i1) r+r[0];
           (%o1)                             r + r
                                                  0
           (%i2) opsubst;
           (%o2)                         true
           (%i3) subst (x^2, r, r+r[0]);
                                       2     2
           (%o3)                      x + (x )
                                               0
           (%i4) opsubst: not opsubst;
           (%o4)                         false
Chapter 6: Expressions                                                                    99
      For other built-in operators and all other functions and operators, expressions are
      ordered by their arguments (beginning with the first argument), then by the name
      of the operator or function. In the case of subscripted expressions, the subscripted
      symbol is considered the operator and the subscript is considered an argument.
      The canonical ordering of expressions is modified by the functions ordergreat and
      orderless, and the mainvar, constant, and scalar declarations.
      See also sort.
      Examples:
      Ordering ordinary symbols and constants. Note that %pi is not ordered according to
      its numerical value.
           (%i1) stringdisp : true;
           (%o1)                         true
           (%i2) sort ([%pi, 3b0, 3.0, x, X, "foo", 3, a, 4, "bar", 4.0, 4b0]);
           (%o2) [3, 3.0, 4, 4.0, 3.0b0, 4.0b0, %pi, "bar", "foo", X, a, x]
      Effect of ordergreat and orderless functions.
           (%i1)   sort ([M, H, K, T, E, W, G, A, P, J, S]);
           (%o1)             [A, E, G, H, J, K, M, P, S, T, W]
           (%i2)   ordergreat (S, J);
           (%o2)                           done
           (%i3)   orderless (M, H);
           (%o3)                           done
           (%i4)   sort ([M, H, K, T, E, W, G, A, P, J, S]);
           (%o4)             [M, H, A, E, G, K, P, T, W, J, S]
      Effect of mainvar, constant, and scalar declarations.
           (%i1)   sort ([aa, foo, bar, bb, baz, quux, cc, dd, A1, B1, C1]);
           (%o1)     [A1, B1, C1, aa, bar, baz, bb, cc, dd, foo, quux]
           (%i2)   declare (aa, mainvar);
           (%o2)                           done
           (%i3)   declare ([baz, quux], constant);
           (%o3)                           done
           (%i4)   declare ([A1, B1], scalar);
           (%o4)                           done
           (%i5)   sort ([aa, foo, bar, bb, baz, quux, cc, dd, A1, B1, C1]);
           (%o5)     [baz, quux, A1, B1, C1, bar, bb, cc, dd, foo, aa]
      Ordering non-atomic expressions.
           (%i1) sort ([1, 2, n, f(1), f(2), f(2, 1), g(1), g(1, 2), g(n),
                  f(n, 1)]);
           (%o1) [1, 2, f(1), g(1), g(1, 2), f(2), f(2, 1), n, g(n),
                                                                    f(n, 1)]
           (%i2) sort ([foo(1), X[1], X[k], foo(k), 1, k]);
           (%o2)            [1, X , foo(1), k, X , foo(k)]
                                 1              k
Chapter 6: Expressions                                                                       101
(%t3) - log(sqrt(x + 1) + 1)
                                                 2
                                            sin(x )
           (%t4)                            -------
                                               3
                                             b + a
           (%t5)                             -----
                                               2
(%t6) log(sqrt(x + 1) + 1)
                                                 2
           (%t7)                            sin(x )
(%t8) b + a
                                    %t8   %t7
           (%o8)                    --- + --- - %t6
                                     2     3
           (%i8) pickapart (expr, 3);
           (%t9)                        sqrt(x + 1) + 1
Chapter 6: Expressions                                                                 103
                                                  2
           (%t10)                                x
                             b + a              sin(%t10)
           (%o10)            ----- - log(%t9) + ---------
                               2                    3
           (%i10) pickapart (expr, 4);
           (%t11)                           sqrt(x + 1)
                                 2
                            sin(x )   b + a
           (%o11)           ------- + ----- - log(%t11 + 1)
                               3        2
           (%i11) pickapart (expr, 5);
(%t12) x + 1
                               2
                         sin(x )   b + a
           (%o12)        ------- + ----- - log(sqrt(%t12) + 1)
                             3        2
           (%i12) pickapart (expr, 6);
                              2
                        sin(x )   b + a
           (%o12)       ------- + ----- - log(sqrt(x + 1) + 1)
                           3        2
psubst                                                                          [Function]
         psubst (list, expr)
         psubst (a, b, expr)
     psubst(a, b, expr) is similar to subst. See subst.
     In distinction from subst the function psubst makes parallel substitutions, if the
     first argument list is a list of equations.
     See also sublis for making parallel substitutions and let and letsimp for others
     ways to do substitutions.
     Example:
     The first example shows parallel substitution with psubst. The second example shows
     the result for the function subst, which does a serial substitution.
           (%i1) psubst ([a^2=b, b=a], sin(a^2) + sin(b));
           (%o1)                    sin(b) + sin(a)
104                                                               Maxima 5.45.0 Manual
rembox                                                                       [Function]
          rembox (expr, unlabelled)
          rembox (expr, label)
          rembox (expr)
      Removes boxes from expr.
Examples:
                                     Product(2)       Product(2)
                          2 Expt + %e            + %e
            (%i6) reveal (e, 5);
                                     2             2
                                    b - 2 a b + a
            (%o6)              --------------------------
                                   Sum(2)      2 b      2 a
                               2 %e       + %e     + %e
            (%i7) reveal (e, 6);
                                       2             2
                                     b - 2 a b + a
            (%o7)               -------------------------
                                    b + a     2 b       2 a
                                2 %e      + %e     + %e
sqrtdenest (expr)                                                                [Function]
      Denests sqrt of simple, numerical, binomial surds, where possible. E.g.
           (%i1) sqrt(sqrt(3)/2+1)/sqrt(11*sqrt(2)-12);
                                              sqrt(3)
                                        sqrt(------- + 1)
                                                  2
           (%o1)                     ---------------------
                                     sqrt(11 sqrt(2) - 12)
           (%i2) sqrtdenest(%);
                                            sqrt(3)     1
                                            ------- + -
                                               2        2
           (%o2)                           -------------
                                              1/4      3/4
                                           3 2      - 2
      Sometimes it helps to apply sqrtdenest more than once, on such as (19601-13860
      sqrt(2))^(7/4).
sublis (list, expr)                                                               [Function]
      Makes multiple parallel substitutions into an expression. list is a list of equations.
      The left hand side of the equations must be an atom.
      The variable sublis_apply_lambda controls simplification after sublis.
      See also psubst for making parallel substitutions.
      Example:
            (%i1) sublis ([a=b, b=a], sin(a) + cos(b));
            (%o1)                         sin(b) + cos(a)
sublis_apply_lambda                                                     [Option variable]
      Default value: true
      Controls whether lambda’s substituted are applied in simplification after sublis is
      used or whether you have to do an ev to get things to apply. true means do the
      application.
Chapter 6: Expressions                                                                   107
           (%i2) subst(100,g,g[x]+2),subnumsimp:true;
           (%o2)                          102
subst (a, b, c)                                                                   [Function]
     Substitutes a for b in c. b must be an atom or a complete subexpression of c.
     For example, x+y+z is a complete subexpression of 2*(x+y+z)/w while x+y is not.
     When b does not have these characteristics, one may sometimes use substpart or
     ratsubst (see below). Alternatively, if b is of the form e/f then one could use subst
     (a*f, e, c) while if b is of the form e^(1/f) then one could use subst (a^f, e,
     c). The subst command also discerns the x^y in x^-y so that subst (a, sqrt(x),
     1/sqrt(x)) yields 1/a. a and b may also be operators of an expression enclosed in
     double-quotes " or they may be function names. If one wishes to substitute for the
     independent variable in derivative forms then the at function (see below) should be
     used.
     subst is an alias for substitute.
     The commands subst (eq_1, expr) or subst ([eq_1, ..., eq_k], expr) are other
     permissible forms. The eq i are equations indicating substitutions to be made. For
     each equation, the right side will be substituted for the left in the expression expr.
     The equations are substituted in serial from left to right in expr. See the functions
     sublis and psubst for making parallel substitutions.
     exptsubst if true permits substitutions like y for %e^x in %e^(a*x) to take place.
     When opsubst is false, subst will not attempt to substitute into the operator of an
     expression. E.g. (opsubst: false, subst (x^2, r, r+r[0])) will work.
     See also at, ev and psubst, as well as let and letsimp.
     Examples:
           (%i1) subst (a, x+y, x + (x+y)^2 + y);
                                                          2
           (%o1)                              y + x + a
           (%i2) subst (-%i, %i, a + b*%i);
           (%o2)                                a - %i b
     The substitution is done in serial for a list of equations. Compare this with a parallel
     substitution:
           (%i1) subst([a=b, b=c], a+b);
           (%o1)                                    2 c
108                                                                   Maxima 5.45.0 Manual
unorder ()                                                                      [Function]
      Disables the aliasing created by the last use of the ordering commands ordergreat
      and orderless. ordergreat and orderless may not be used more than one time
      each without calling unorder. unorder does not substitute back in expressions the
      original symbols for the aliases introduced by ordergreat and orderless. Therefore,
      after execution of unorder the aliases appear in previous expressions.
      See also ordergreat and orderless.
      Examples:
      ordergreat(a) introduces an alias for the symbol a. Therefore, the difference of %o2
      and %o4 does not vanish. unorder does not substitute back the symbol a and the
      alias appears in the output %o7.
             (%i1) unorder();
             (%o1)                                  []
             (%i2) b*x + a^2;
                                                        2
             (%o2)                              b x + a
             (%i3) ordergreat (a);
             (%o3)                                 done
             (%i4) b*x + a^2;
              %th(1) - %th(3);
                                                 2
             (%o4)                              a + b x
             (%i5) unorder();
                                                  2     2
             (%o5)                               a - a
             (%i6) %th(2);
             (%o6)                                  [a]
7 Operators
         :           180       20
         ::          180       20
         :=          180       20
         ::=         180       20
         !           160
         !!          160
         ^           140       139
         .           130       129
         *           120
         /           120       120
         +           100       100
         -           100       134
         =           80        80
         #           80        80
         >           80        80
         >=          80        80
         <           80        80
         <=          80        80
         not                   70
         and         65
         or          60
         ,           10
         $           -1
         ;           -1
   remove and kill remove operator properties from an atom. remove ("a", op) removes
only the operator properties of a. kill ("a") removes all properties of a, including the
operator properties. Note that the name of the operator must be enclosed in quotation
marks.
        (%i1) infix ("##");
        (%o1)                                   ##
        (%i2) "##" (a, b) := a^b;
                                                  b
        (%o2)                          a ## b := a
        (%i3) 5 ## 3;
        (%o3)                                   125
        (%i4) remove ("##", op);
        (%o4)                               done
Chapter 7: Operators                                                                   113
     (%i5) 5 ## 3;
     Incorrect syntax: # is not a prefix operator
     5 ##
       ^
     (%i5) "##" (5, 3);
     (%o5)                          125
     (%i6) infix ("##");
     (%o6)                          ##
     (%i7) 5 ## 3;
     (%o7)                          125
     (%i8) kill ("##");
     (%o8)                         done
     (%i9) 5 ## 3;
     Incorrect syntax: # is not a prefix operator
     5 ##
       ^
     (%i9) "##" (5, 3);
     (%o9)                       ##(5, 3)
**                                                                           [Operator]
      Exponentiation operator. Maxima recognizes ** as the same operator as ^ in input,
      and it is displayed as ^ in 1-dimensional output, or by placing the exponent as a
      superscript in 2-dimensional output.
      The fortran function displays the exponentiation operator as **, whether it was
      input as ** or ^.
      Examples:
            (%i1) is (a**b = a^b);
            (%o1)                                true
            (%i2) x**y + x^z;
                                                 z   y
            (%o2)                               x + x
            (%i3) string (x**y + x^z);
            (%o3)                               x^z+x^y
            (%i4) fortran (x**y + x^z);
                  x**z+x**y
            (%o4)                                done
^^                                                                          [Operator]
      Noncommutative exponentiation operator. ^^ is the exponentiation operator corre-
      sponding to noncommutative multiplication ., just as the ordinary exponentiation
      operator ^ corresponds to commutative multiplication *.
      Noncommutative exponentiation is displayed by ^^ in 1-dimensional output, and by
      placing the exponent as a superscript within angle brackets < > in 2-dimensional
      output.
      Examples:
            (%i1) a . a . b . b . b + a * a * a           * b * b;
                                    3 2     <2>              <3>
            (%o1)                  a b + a                . b
            (%i2) string (a . a . b . b . b + a           * a * a * b * b);
            (%o2)                  a^3*b^2+a^^2           . b^^3
.                                                                                  [Operator]
      The dot operator, for matrix (non-commutative) multiplication. When "." is used
      in this way, spaces should be left on both sides of it, e.g. A . B This distinguishes it
      plainly from a decimal point in a floating point number.
Chapter 7: Operators                                                                   117
not                                                                           [Operator]
      The logical negation operator. not is a prefix operator; its operand is a Boolean
      expression, and its result is a Boolean value.
      not forces evaluation (like is) of its operand.
      The global flag prederror governs the behavior of not when its operand cannot be
      determined to be true or false. not prints an error message when prederror is
      true. Otherwise, operands which do not evaluate to true or false are accepted, and
      the result is a Boolean expression.
or                                                                                [Operator]
      The logical disjunction operator. or is an n-ary infix operator; its operands are
      Boolean expressions, and its result is a Boolean value.
      or forces evaluation (like is) of one or more operands, and may force evaluation of
      all operands.
      Operands are evaluated in the order in which they appear. or evaluates only as many
      of its operands as necessary to determine the result. If any operand is true, the result
      is true and no further operands are evaluated.
      The global flag prederror governs the behavior of or when an evaluated operand can-
      not be determined to be true or false. or prints an error message when prederror
      is true. Otherwise, operands which do not evaluate to true or false are accepted,
      and the result is a Boolean expression.
      or is not commutative: a or b might not be equal to b or a due to the treatment of
      indeterminate operands.
Chapter 7: Operators                                                                     119
=                                                                                 [Operator]
     The equation operator.
     An expression a = b, by itself, represents an unevaluated equation, which might or
     might not hold. Unevaluated equations may appear as arguments to solve and
     algsys or some other functions.
     The function is evaluates = to a Boolean value. is(a = b) evaluates a = b to true
     when a and b are identical. That is, a and b are atoms which are identical, or they
     are not atoms and their operators are identical and their arguments are identical.
     Otherwise, is(a = b) evaluates to false; it never evaluates to unknown. When is(a
     = b) is true, a and b are said to be syntactically equal, in contrast to equivalent
     expressions, for which is(equal(a, b)) is true. Expressions can be equivalent and
     not syntactically equal.
     The negation of = is represented by #. As with =, an expression a # b, by itself, is not
     evaluated. is(a # b) evaluates a # b to true or false.
     In addition to is, some other operators evaluate = and # to true or false, namely
     if, and, or, and not.
     Note that because of the rules for evaluation of predicate expressions (in particular
     because not expr causes evaluation of expr), not a = b is equivalent to is(a # b),
     instead of a # b.
     rhs and lhs return the right-hand and left-hand sides, respectively, of an equation
     or inequation.
     See also equal and notequal.
     Examples:
120                                                               Maxima 5.45.0 Manual
(%o2) true
::                                                                               [Operator]
      Assignment operator.
      :: is the same as : (which see) except that :: evaluates its left-hand side as well as
      its right-hand side.
      Examples:
            (%i1)   x : 'foo;
            (%o1)                                 foo
            (%i2)   x :: 123;
            (%o2)                                 123
            (%i3)   foo;
            (%o3)                                 123
            (%i4)   x : '[a, b, c];
            (%o4)                             [a, b, c]
            (%i5)   x :: [11, 22, 33];
            (%o5)                          [11, 22, 33]
            (%i6)   a;
            (%o6)                                 11
            (%i7)   b;
            (%o7)                                 22
            (%i8)   c;
            (%o8)                                 33
Chapter 7: Operators                                                                    123
::=                                                                              [Operator]
      Macro function definition operator. ::= defines a function (called a "macro" for
      historical reasons) which quotes its arguments, and the expression which it returns
      (called the "macro expansion") is evaluated in the context from which the macro was
      called. A macro function is otherwise the same as an ordinary function.
      macroexpand returns a macro expansion (without evaluating it). macroexpand (foo
      (x)) followed by ''% is equivalent to foo (x) when foo is a macro function.
      ::= puts the name of the new macro function onto the global list macros. kill,
      remove, and remfunction unbind macro function definitions and remove names from
      macros.
      fundef or dispfun return a macro function definition or assign it to a label, respec-
      tively.
      Macro functions commonly contain buildq and splice expressions to construct an
      expression, which is then evaluated.
      Examples
      A macro function quotes its arguments, so message (1) shows y - z, not the value of
      y - z. The macro expansion (the quoted expression '(print ("(2) x is equal to",
      x))) is evaluated in the context from which the macro was called, printing message
      (2).
              (%i1) x: %pi$
              (%i2) y: 1234$
              (%i3) z: 1729 * w$
              (%i4) printq1 (x) ::= block (print ("(1) x is equal to", x),
                    '(print ("(2) x is equal to", x)))$
              (%i5) printq1 (y - z);
              (1) x is equal to y - z
              (2) x is equal to %pi
              (%o5)                                       %pi
      An ordinary function evaluates its arguments, so message (1) shows the value of y -
      z. The return value is not evaluated, so message (2) is not printed until the explicit
      evaluation ''%.
              (%i1) x: %pi$
              (%i2) y: 1234$
              (%i3) z: 1729 * w$
              (%i4) printe1 (x) := block (print ("(1) x is equal to", x),
                    '(print ("(2) x is equal to", x)))$
              (%i5) printe1 (y - z);
              (1) x is equal to 1234 - 1729 w
              (%o5)                         print((2) x is equal to, x)
              (%i6) ''%;
              (2) x is equal to %pi
              (%o6)                                       %pi
      macroexpand returns a macro expansion. macroexpand (foo (x)) followed by ''% is
      equivalent to foo (x) when foo is a macro function.
              (%i1) x: %pi$
124                                                                   Maxima 5.45.0 Manual
            (%i2) y: 1234$
            (%i3) z: 1729 * w$
            (%i4) g (x) ::= buildq ([x], print ("x is equal to", x))$
            (%i5) macroexpand (g (y - z));
            (%o5)                     print(x is equal to, y - z)
            (%i6) ''%;
            x is equal to 1234 - 1729 w
            (%o6)                            1234 - 1729 w
            (%i7) g (y - z);
            x is equal to 1234 - 1729 w
            (%o7)                            1234 - 1729 w
:=                                                                                   [Operator]
      The function definition operator.
      f(x_1, ..., x_n) := expr defines a function named f with arguments x 1, . . . , x n
      and function body expr. := never evaluates the function body (unless explicitly
      evaluated by quote-quote ''). The function body is evaluated every time the function
      is called.
      f[x_1, ..., x_n] := expr defines a so-called memoizing function. Its function
      body is evaluated just once for each distinct value of its arguments, and that value is
      returned, without evaluating the function body, whenever the arguments have those
      values again. (A function of this kind is also known as a “array function”.)
      f[x_1, ..., x_n](y_1, ..., y_m) := expr is a special case of a memoizing
      function. f[x_1, ..., x_n] is a memoizing function which returns a lambda
      expression with arguments y_1, ..., y_m. The function body is evaluated once for
      each distinct value of x_1, ..., x_n, and the body of the lambda expression is that
      value.
      When the last or only function argument x n is a list of one element, the function
      defined by := accepts a variable number of arguments. Actual arguments are assigned
      one-to-one to formal arguments x 1, . . . , x (n - 1), and any further actual arguments,
      if present, are assigned to x n as a list.
      All function definitions appear in the same namespace; defining a function f within an-
      other function g does not automatically limit the scope of f to g. However, local(f)
      makes the definition of function f effective only within the block or other compound
      expression in which local appears.
      If some formal argument x k is a quoted symbol, the function defined by := does
      not evaluate the corresponding actual argument. Otherwise all actual arguments are
      evaluated.
      See also define and ::=.
      Examples:
      := never evaluates the function body (unless explicitly evaluated by quote-quote).
             (%i1) expr : cos(y) - sin(x);
             (%o1)                          cos(y) - sin(x)
             (%i2) F1 (x, y) := expr;
             (%o2)                         F1(x, y) := expr
Chapter 7: Operators                                                      125
matchfix                                                                           [Function]
        matchfix (ldelimiter, rdelimiter)
        matchfix (ldelimiter, rdelimiter, arg_pos, pos)
      Declares a matchfix operator with left and right delimiters ldelimiter and rdelimiter.
      The delimiters are specified as strings.
      A "matchfix" operator is a function of any number of arguments, such that the
      arguments occur between matching left and right delimiters. The delimiters may be
      any strings, so long as the parser can distinguish the delimiters from the operands
      and other expressions and operators. In practice this rules out unparseable delimiters
      such as %, ,, $ and ;, and may require isolating the delimiters with white space. The
      right delimiter can be the same or different from the left delimiter.
      A left delimiter can be associated with only one right delimiter; two different matchfix
      operators cannot have the same left delimiter.
      An existing operator may be redeclared as a matchfix operator without changing its
      other properties. In particular, built-in operators such as addition + can be declared
      matchfix, but operator functions cannot be defined for built-in operators.
      The command matchfix (ldelimiter, rdelimiter, arg_pos, pos) declares the
      argument part-of-speech arg pos and result part-of-speech pos, and the delimiters
      ldelimiter and rdelimiter.
      "Part of speech", in reference to operator declarations, means expression type. Three
      types are recognized: expr, clause, and any, indicating an algebraic expression, a
      Boolean expression, or any kind of expression, respectively. Maxima can detect some
      syntax errors by comparing the declared part of speech to an actual expression.
      The function to carry out a matchfix operation is an ordinary user-defined function.
      The operator function is defined in the usual way with the function definition operator
      := or define. The arguments may be written between the delimiters, or with the
      left delimiter as a quoted string and the arguments following in parentheses. dispfun
      (ldelimiter) displays the function definition.
      The only built-in matchfix operator is the list constructor [ ]. Parentheses ( ) and
      double-quotes " " act like matchfix operators, but are not treated as such by the
      Maxima parser.
      matchfix evaluates its arguments. matchfix returns its first argument, ldelimiter.
      Examples:
Chapter 7: Operators                                           129
           (%o5)                              done
           (%i6) !-3, 5-!;
                                                16
           (%o6)                              - --
                                                15
           (%i7) "!-" (3, 5);
                                                16
           (%o7)                              - --
                                                15
130                                                                  Maxima 5.45.0 Manual
nary                                                                              [Function]
           nary (op)
           nary (op, bp, arg_pos, pos)
       An nary operator is used to denote a function of any number of arguments, each
       of which is separated by an occurrence of the operator, e.g. A+B or A+B+C. The
       nary("x") function is a syntax extension function to declare x to be an nary operator.
       Functions may be declared to be nary. If declare(j,nary); is done, this tells the
       simplifier to simplify, e.g. j(j(a,b),j(c,d)) to j(a, b, c, d).
       See also Section 7.1 [Introduction to operators], page 111.
nofix                                                                             [Function]
           nofix (op)
           nofix (op, pos)
       nofix operators are used to denote functions of no arguments. The mere presence of
       such an operator in a command will cause the corresponding function to be evaluated.
       For example, when one types "exit;" to exit from a Maxima break, "exit" is behaving
       similar to a nofix operator. The function nofix("x") is a syntax extension function
       which declares x to be a nofix operator.
       See also Section 7.1 [Introduction to operators], page 111.
postfix                                                                           [Function]
           postfix (op)
           postfix (op, lbp, lpos, pos)
       postfix operators like the prefix variety denote functions of a single argument, but
       in this case the argument immediately precedes an occurrence of the operator in the
       input string, e.g. 3!. The postfix("x") function is a syntax extension function to
       declare x to be a postfix operator.
       See also Section 7.1 [Introduction to operators], page 111.
prefix                                                                            [Function]
           prefix (op)
           prefix (op, rbp, rpos, pos)
       A prefix operator is one which signifies a function of one argument, which argument
       immediately follows an occurrence of the operator. prefix("x") is a syntax extension
       function to declare x to be a prefix operator.
       See also Section 7.1 [Introduction to operators], page 111.
                                                                                          131
8 Evaluation
                                              7
                                             /
                                             [  2
            (%o4)                            I x dx
                                             ]
                                             /
                                              5
            (%i5) %, nouns;
                                                 218
            (%o5)                                ---
                                                  3
      Applied to a parenthesized expression, the single quote prevents evaluation of all
      symbols and function calls in the expression.
            (%i1)   aa: 1024;
            (%o1)                               1024
            (%i2)   bb: 19;
            (%o2)                                19
            (%i3)   sqrt(aa) + bb;
            (%o3)                                51
            (%i4)   '(sqrt(aa) + bb);
            (%o4)                          bb + sqrt(aa)
            (%i5)   ''%;
            (%o5)                                51
      The single quote does not prevent simplification.
            (%i1) sin (17 * %pi) + cos (17 *       %pi);
            (%o1)                          -       1
            (%i2) '(sin (17 * %pi) + cos (17       * %pi));
            (%o2)                          -       1
      Maxima considers floating point operations by its in-built mathematical functions to
      be a simplification.
            (%i1) sin(1.0);
            (%o1)                                .8414709848078965
            (%i2) '(sin(1.0));
            (%o2)                                .8414709848078965
      When the global flag noundisp is true, nouns display with a single quote.
            (%i1)   x:%pi;
            (%o1)                                         %pi
            (%i2)   bfloat(x);
            (%o2)                               3.141592653589793b0
            (%i3)   sin(x);
            (%o3)                                          0
            (%i4)   noundisp;
            (%o4)                                         false
            (%i5)   'bfloat(x);
            (%o5)                                     bfloat(%pi)
Chapter 8: Evaluation                                                                    133
           (%i6) bfloat('x);
           (%o6)                                            x
           (%i7) 'sin(x);
           (%o7)                                            0
           (%i8) sin('x);
           (%o8)                                        sin(x)
           (%i9) noundisp : not noundisp;
           (%o9)                                         true
           (%i10) 'bfloat(x);
           (%o10)                                   'bfloat(%pi)
           (%i11) bfloat('x);
           (%o11)                                           x
           (%i12) 'sin(x);
           (%o12)                                           0
           (%i13) sin('x);
           (%o13)                                       sin(x)
           (%i14)
’’                                                                          [Operator]
     The quote-quote operator '' (two single quote marks) modifies evaluation in input
     expressions.
     Applied to a general expression expr, quote-quote causes the value of expr to be
     substituted for expr in the input expression.
     Applied to the operator of an expression, quote-quote changes the operator from a
     noun to a verb (if it is not already a verb).
     The quote-quote operator is applied by the input parser; it is not stored as part
     of a parsed input expression. The quote-quote operator is always applied as soon
     as it is parsed, and cannot be quoted. Thus quote-quote causes evaluation when
     evaluation is otherwise suppressed, such as in function definitions, lambda expressions,
     and expressions quoted by single quote '.
     Quote-quote is recognized by batch and load.
     See also ev, the single-quote operator [quote], page 131 and nouns.
     Examples:
     Applied to a general expression expr, quote-quote causes the value of expr to be
     substituted for expr in the input expression.
           (%i1) expand ((a + b)^3);
                                3        2              2     3
           (%o1)               b + 3 a b +           3 a b + a
           (%i2) [_, ''_];
                                    3    3                2     2     3
           (%o2)     [expand((b + a) ), b +          3 a b + 3 a b + a ]
           (%i3) [%i1, ''%i1];
                                    3    3                2     2     3
           (%o3)     [expand((b + a) ), b +          3 a b + 3 a b + a ]
           (%i4) [aa : cc, bb : dd, cc : 17,         dd : 29];
134                                                                 Maxima 5.45.0 Manual
op(cc + aa) = +
            (%o3)                               done
            (%i4) ''(aa + cc);
Chapter 8: Evaluation                                                               135
           (%o4)                         6912
           (%i5) display (_, op (_), args (_));
                                      _ = dd + bb
op(dd + bb) = +
(%o5) done
(%t9) foo_2b(x) := %
                                                              1
             (%t7)                                      y = - -
                                                              5
                                                            6
             (%t8)                                      x = -
                                                            5
             (%o8)                                  [[%t7, %t8]]
             (%i8) %o6, %o8;
             (%o8)                                     - 4 = - 4
             (%i9) x + 1/x > gamma (1/2);
                                                      1
             (%o9)                                x + - > sqrt(%pi)
                                                      x
             (%i10) %, numer, x=1/2;
             (%o10)                           2.5 > 1.772453850905516
             (%i11) %, pred;
             (%o11)                                      true
eval                                                                      [Special symbol]
       As an argument in a call to ev (expr), eval causes an extra evaluation of expr. See
       ev.
       Example:
            (%i1) [a:b,b:c,c:d,d:e];
            (%o1)                                  [b, c, d, e]
            (%i2) a;
            (%o2)                                         b
            (%i3) ev(a);
            (%o3)                                         c
            (%i4) ev(a),eval;
            (%o4)                                         e
Chapter 8: Evaluation                                                             139
           (%i5) a,eval,eval;
           (%o5)                                         e
evflag                                                                     [Property]
     When a symbol x has the evflag property, the expressions ev(expr, x) and expr,
     x (at the interactive prompt) are equivalent to ev(expr, x = true). That is, x is
     bound to true while expr is evaluated.
     The expression declare(x, evflag) gives the evflag property to the variable x.
     The flags which have the evflag property by default are the following:
         algebraic            cauchysum          demoivre
         dotscrules           %emode             %enumer
         exponentialize       exptisolate        factorflag
         float                halfangles         infeval
         isolate_wrt_times    keepfloat          letrat
         listarith            logabs             logarc
         logexpand            lognegint
         m1pbranch            numer_pbranch      programmode
         radexpand            ratalgdenom        ratfac
         ratmx                ratsimpexpons      simp
         simpproduct          simpsum            sumexpand
         trigexpand
     Examples:
           (%i1) sin (1/2);
                                                 1
           (%o1)                             sin(-)
                                                 2
           (%i2)   sin (1/2), float;
           (%o2)                   0.479425538604203
           (%i3) sin (1/2), float=true;
           (%o3)                   0.479425538604203
           (%i4) simp : false;
           (%o4)                          false
           (%i5) 1 + 1;
           (%o5)                          1 + 1
           (%i6) 1 + 1, simp;
           (%o6)                            2
           (%i7) simp : true;
           (%o7)                          true
           (%i8) sum (1/k^2, k, 1, inf);
                                       inf
                                       ====
                                       \      1
           (%o8)                         >     --
                                       /        2
                                       ==== k
                                       k = 1
140                                                                 Maxima 5.45.0 Manual
evfun                                                                       [Property]
      When a function F has the evfun property, the expressions ev(expr, F) and expr,
      F (at the interactive prompt) are equivalent to F(ev(expr)).
      If two or more evfun functions F, G, etc., are specified, the functions are applied in
      the order that they are specified.
      The expression declare(F, evfun) gives the evfun property to the function F. The
      functions which have the evfun property by default are the following:
         bfloat              factor          fullratsimp
         logcontract         polarform       radcan
         ratexpand           ratsimp         rectform
         rootscontract       trigexpand      trigreduce
      Examples:
            (%i1) x^3 - 1;
                                                3
            (%o1)                              x - 1
            (%i2) x^3 - 1, factor;
                                             2
            (%o2)                 (x - 1) (x + x + 1)
            (%i3) factor (x^3 - 1);
                                             2
            (%o3)                 (x - 1) (x + x + 1)
            (%i4) cos(4 * x) / sin(x)^4;
                                        cos(4 x)
            (%o4)                        --------
                                            4
                                        sin (x)
            (%i5) cos(4 * x) / sin(x)^4, trigexpand;
                             4            2       2        4
                          sin (x) - 6 cos (x) sin (x) + cos (x)
            (%o5)         -------------------------------------
                                             4
                                          sin (x)
            (%i6) cos(4 * x) / sin(x)^4, trigexpand, ratexpand;
                                       2          4
Chapter 8: Evaluation                                                                    141
      (%i2) 1<2,pred;
      (%o2)             true
                                                                                             143
9 Simplification
antisymmetric                                                                       [Property]
      If declare(h,antisymmetric) is done, this tells the simplifier that h is antisymmet-
      ric. E.g. h(x,z,y) will simplify to - h(x, y, z). That is, it will give (-1)^n times the
      result given by symmetric or commutative, where n is the number of interchanges of
      two arguments necessary to convert it to that form.
      Examples:
             (%i1) S (b, a);
             (%o1)                              S(b, a)
             (%i2) declare (S, symmetric);
             (%o2)                               done
             (%i3) S (b, a);
             (%o3)                              S(a, b)
             (%i4) S (a, c, e, d, b);
             (%o4)                        S(a, b, c, d, e)
             (%i5) T (b, a);
             (%o5)                              T(b, a)
             (%i6) declare (T, antisymmetric);
             (%o6)                               done
             (%i7) T (b, a);
             (%o7)                             - T(a, b)
             (%i8) T (a, c, e, d, b);
             (%o8)                        T(a, b, c, d, e)
commutative                                                                      [Property]
     If declare(h, commutative) is done, this tells the simplifier that h is a commutative
     function. E.g. h(x, z, y) will simplify to h(x, y, z). This is the same as symmetric.
     Example:
           (%i1)   S (b, a);
           (%o1)                          S(b, a)
           (%i2)   S (a, b) + S (b, a);
           (%o2)                     S(b, a) + S(a, b)
           (%i3)   declare (S, commutative);
           (%o3)                           done
           (%i4)   S (b, a);
           (%o4)                          S(a, b)
           (%i5)   S (a, b) + S (b, a);
           (%o5)                         2 S(a, b)
           (%i6)   S (a, c, e, d, b);
           (%o6)                     S(a, b, c, d, e)
evenfun                                                                    [Property]
oddfun                                                                     [Property]
     declare(f, evenfun) or declare(f, oddfun) tells Maxima to recognize the function
     f as an even or odd function.
     Examples:
           (%i1) o (- x) + o (x);
           (%o1)                      o(x) + o(- x)
           (%i2) declare (o, oddfun);
           (%o2)                          done
           (%i3) o (- x) + o (x);
           (%o3)                            0
           (%i4) e (- x) - e (x);
           (%o4)                      e(- x) - e(x)
           (%i5) declare (e, evenfun);
           (%o5)                          done
           (%i6) e (- x) - e (x);
           (%o6)                            0
expand                                                                          [Function]
          expand (expr)
          expand (expr, p, n)
     Expand expression expr. Products of sums and exponentiated sums are multiplied
     out, numerators of rational expressions which are sums are split into their respective
     terms, and multiplication (commutative and non-commutative) are distributed over
     addition at all levels of expr.
     For polynomials one should usually use ratexpand which uses a more efficient algo-
     rithm.
     maxnegex and maxposex control the maximum negative and positive exponents, re-
     spectively, which will expand.
     expand (expr, p, n) expands expr, using p for maxposex and n for maxnegex. This
     is useful in order to expand part but not all of an expression.
     expon - the exponent of the largest negative power which is automatically expanded
     (independent of calls to expand). For example if expon is 4 then (x+1)^(-5) will not
     be automatically expanded.
     expop - the highest positive exponent which is automatically expanded. Thus
     (x+1)^3, when typed, will be automatically expanded only if expop is greater than
150                                                                   Maxima 5.45.0 Manual
           (%i2) exponentialize:true;
           (%o2)                                 true
           (%i3) expand(expr,0,0);
                                           2    %i x     - %i x
                                 %i (x + 1) (%e      - %e       )
           (%o3)               - -------------------------------
                                                2
     maxnegex is the largest negative exponent which will be expanded by the expand
     command, see also maxposex.
multiplicative                                                              [Property]
     declare(f, multiplicative) tells the Maxima simplifier that f is multiplicative.
       1. If f is univariate, whenever the simplifier encounters f applied to a product,
          f distributes over that product. E.g., f(x*y) simplifies to f(x)*f(y). This
          simplification is not applied to expressions of the form f('product(...)).
       2. If f is a function of 2 or more arguments, multiplicativity is defined as multiplica-
          tivity in the first argument to f, e.g., f (g(x) * h(x), x) simplifies to f (g(x)
          ,x) * f (h(x), x).
multthru                                                                          [Function]
        multthru (expr)
        multthru (expr_1, expr_2)
       Multiplies a factor (which should be a sum) of expr by the other factors of expr. That
       is, expr is f_1 f_2 ... f_n where at least one factor, say f i, is a sum of terms. Each
       term in that sum is multiplied by the other factors in the product. (Namely all the
       factors except f i). multthru does not expand exponentiated sums. This function is
       the fastest way to distribute products (commutative or noncommutative) over sums.
       Since quotients are represented as products multthru can be used to divide sums by
       products as well.
       multthru (expr_1, expr_2) multiplies each term in expr 2 (which should be a sum
       or an equation) by expr 1. If expr 1 is not itself a sum then this form is equivalent
       to multthru (expr_1*expr_2).
              (%i1) x/(x-y)^2 - 1/(x-y) - f(x)/(x-y)^3;
                                        1           x           f(x)
              (%o1)                 - ----- + -------- - --------
                                      x - y              2             3
                                                (x - y)       (x - y)
              (%i2) multthru ((x-y)^3, %);
                                               2
              (%o2)                 - (x - y) + x (x - y) - f(x)
              (%i3) ratexpand (%);
                                               2
              (%o3)                        - y + x y - f(x)
              (%i4) ((a+b)^10*s^2 + 2*a*b*s + (a*b)^2)/(a*b*s^2);
                                           10 2                   2 2
                                  (b + a)      s + 2 a b s + a b
              (%o4)               ------------------------------
                                                       2
                                                  a b s
              (%i5) multthru (%); /* note that this does not expand (b+a)^10 */
                                                               10
                                         2     a b    (b + a)
              (%o5)                       - + --- + ---------
                                         s       2         a b
                                               s
              (%i6) multthru (a.(b+c.(d+e)+f));
              (%o6)               a . f + a . c . (e + d) + a . b
              (%i7) expand (a.(b+c.(d+e)+f));
              (%o7)            a . f + a . c . e + a . c . d + a . b
nary                                                                             [Property]
       declare(f, nary) tells Maxima to recognize the function f as an n-ary function.
       The nary declaration is not the same as calling the [function_nary], page 130
       function. The sole effect of declare(f, nary) is to instruct the Maxima simplifier
       to flatten nested expressions, for example, to simplify foo(x, foo(y, z)) to foo(x,
       y, z). See also declare.
Chapter 9: Simplification                                                                155
     Example:
         (%i1) H (H (a, b), H (c, H (d, e)));
         (%o1)               H(H(a, b), H(c, H(d, e)))
         (%i2) declare (H, nary);
         (%o2)                         done
         (%i3) H (H (a, b), H (c, H (d, e)));
         (%o3)                   H(a, b, c, d, e)
negdistrib                                                                 [Option variable]
     Default value: true
     When negdistrib is true, -1 distributes over an expression. E.g., -(x + y) becomes
     - y - x. Setting it to false will allow - (x + y) to be displayed like that. This is
     sometimes useful but be very careful: like the simp flag, this is one flag you do not
     want to set to false as a matter of course or necessarily for other than local use in
     your Maxima.
     Example:
           (%i1) negdistrib;
           (%o1)                               true
           (%i2) -(x+y);
           (%o2)                            (- y) - x
           (%i3) negdistrib : not negdistrib ;
           (%o3)                               false
           (%i4) -(x+y);
           (%o4)                            - (y + x)
opproperties                                                              [System variable]
     opproperties is the list of the special operator properties recognized by the Maxima
     simplifier.
     Items are added to the opproperties list by the function define_opproperty.
     Example:
           (%i1) opproperties;
           (%o1) [linear, additive, multiplicative, outative, evenfun,
           oddfun, commutative, symmetric, antisymmetric, nary,
           lassociative, rassociative]
define_opproperty (property_name, simplifier_fn)                                   [Function]
     Declares the symbol property name to be an operator property, which is simplified
     by simplifier fn, which may be the name of a Maxima or Lisp function or a lambda
     expression. After define_opproperty is called, functions and operators may be de-
     clared to have the property name property, and simplifier fn is called to simplify
     them.
     simplifier fn must be a function of one argument, which is an expression in which the
     main operator is declared to have the property name property.
     simplifier fn is called with the global flag simp disabled. Therefore simplifier fn must
     be able to carry out its simplification without making use of the general simplifier.
     define_opproperty appends property name to the global list opproperties.
156                                                                   Maxima 5.45.0 Manual
outative                                                                       [Property]
      declare(f, outative) tells the Maxima simplifier that constant factors in the argu-
      ment of f can be pulled out.
       1. If f is univariate, whenever the simplifier encounters f applied to a product, that
          product will be partitioned into factors that are constant and factors that are not
          and the constant factors will be pulled out. E.g., f(a*x) will simplify to a*f(x)
          where a is a constant. Non-atomic constant factors will not be pulled out.
       2. If f is a function of 2 or more arguments, outativity is defined as in the case of
          sum or integrate, i.e., f (a*g(x), x) will simplify to a * f(g(x), x) for a free
          of x.
      sum, integrate, and limit are all outative.
      Example:
            (%i1)   F1 (100 * x);
            (%o1)                         F1(100 x)
            (%i2)   declare (F1, outative);
            (%o2)                           done
            (%i3)   F1 (100 * x);
            (%o3)                         100 F1(x)
            (%i4)   declare (zz, constant);
            (%o4)                           done
            (%i5)   F1 (zz * y);
            (%o5)                         zz F1(y)
       For some expressions radcan is quite time consuming. This is the cost of exploring
       certain relationships among the components of the expression for simplifications based
       on factoring and partial-fraction expansions of exponents.
       Examples:
             (%i1) radcan((log(x+x^2)-log(x))^a/log(1+x)^(a/2));
                                                         a/2
             (%o1)                           log(x + 1)
             (%i2) radcan((log(1+2*a^x+a^(2*x))/log(1+a^x)));
             (%o2)                                  2
             (%i3) radcan((%e^x-1)/(1+%e^(x/2)));
                                                 x/2
             (%o3)                             %e      - 1
radexpand                                                                [Option variable]
       Default value: true
       radexpand controls some simplifications of radicals.
       When radexpand is all, causes nth roots of factors of a product which are powers
       of n to be pulled outside of the radical. E.g. if radexpand is all, sqrt (16*x^2)
       simplifies to 4*x.
       More particularly, consider sqrt (x^2).
         • If radexpand is all or assume (x > 0) has been executed, sqrt(x^2) simplifies
            to x.
         • If radexpand is true and domain is real (its default), sqrt(x^2) simplifies to
            abs(x).
         • If radexpand is false, or radexpand is true and domain is complex, sqrt(x^2)
            is not simplified.
       Note that domain only matters when radexpand is true.
rassociative                                                                  [Property]
       declare (g, rassociative) tells the Maxima simplifier that g is right-associative.
       E.g., g(g(a, b), g(c, d)) simplifies to g(a, g(b, g(c, d))).
scsimp (expr, rule_1, . . . , rule_n)                                               [Function]
       Sequential Comparative Simplification (method due to Stoute). scsimp attempts to
       simplify expr according to the rules rule 1, . . . , rule n. If a smaller expression is
       obtained, the process repeats. Otherwise after all simplifications are tried, it returns
       the original answer.
       example (scsimp) displays some examples.
simp                                                                     [Option variable]
       Default value: true
       simp enables simplification. This is the default. simp is also an evflag, which is
       recognized by the function ev. See ev.
       When simp is used as an evflag with a value false, the simplification is suppressed
       only during the evaluation phase of an expression. The flag does not suppress the
       simplification which follows the evaluation phase.
158                                                                 Maxima 5.45.0 Manual
symmetric                                                                    [Property]
      declare (h, symmetric) tells the Maxima simplifier that h is a symmetric function.
      E.g., h (x, z, y) simplifies to h (x, y, z).
      commutative is synonymous with symmetric.
10 Mathematical Functions
           (%i2) abs((1+%i)*(1-%i));
           (%o2)                                     2
           (%i3) abs(%e+%i);
                                           2
           (%o3)                    sqrt(%e + 1)
           (%i4) abs([inf, infinity, minf]);
           (%o4)                   [inf, inf, inf]
     Simplification of expressions containing abs:
           (%i5) abs(x^2);
                                                  2
           (%o5)                                 x
           (%i6) abs(x^3);
                                              2
           (%o6)                             x abs(x)
           (%i7) abs(abs(x));
           (%o7)                             abs(x)
           (%i8) abs(conjugate(x));
           (%o8)                             abs(x)
162                                                                 Maxima 5.45.0 Manual
      Integrating and differentiating with the abs function. Note that more integrals in-
      volving the abs function can be performed, if the abs_integrate package is loaded.
      The last example shows the Laplace transform of abs: see laplace.
            (%i9) diff(x*abs(x),x),expand;
            (%o9)                       2 abs(x)
            (%i10) integrate(abs(x),x);
                                               x abs(x)
            (%o10)                             --------
                                                  2
            (%i11) integrate(x*abs(x),x);
                                       /
                                       [
            (%o11)                     I x abs(x) dx
                                       ]
                                       /
            (%i12) load("abs_integrate")$
            (%i13) integrate(x*abs(x),x);
                                  2           3
                                 x abs(x)    x signum(x)
            (%o13)               --------- - ------------
                                     2            6
            (%i14) integrate(abs(x),x,-2,%pi);
                                            2
                                        %pi
            (%o14)                      ---- + 2
                                         2
            (%i15) laplace(abs(x),x,s);
                                                  1
            (%o15)                                --
                                                   2
                                                  s
      The floor function distributes over lists, matrices and equations. See distribute_
      over.
      Finally, for all inputs that are manifestly complex, floor returns a noun form.
      If the range of a function is a subset of the integers, it can be declared to be
      integervalued. Both the ceiling and floor functions can use this information;
      for example:
            (%i1) declare (f, integervalued)$
            (%i2) floor (f(x));
            (%o2)                                 f(x)
            (%i3) ceiling (f(x) - 1);
            (%o3)                               f(x) - 1
      The round function distributes over lists, matrices and equations. See distribute_
      over.
factorial                                                                   [Function]
!                                                                           [Operator]
     Represents the factorial function. Maxima treats factorial (x) the same as x!.
     For any complex number x, except for negative integers, x! is defined as gamma(x+1).
     For an integer x, x! simplifies to the product of the integers from 1 to x inclusive.
     0! simplifies to 1. For a real or complex number in float or bigfloat precision x, x!
     simplifies to the value of gamma (x+1). For x equal to n/2 where n is an odd integer,
     x! simplifies to a rational factor times sqrt (%pi) (since gamma (1/2) is equal to
     sqrt (%pi)).
     The option variables factlim and gammalim control the numerical evaluation of facto-
     rials for integer and rational arguments. The functions minfactorial and factcomb
     simplifies expressions containing factorials.
     The functions gamma, bffac, and cbffac are varieties of the gamma function. bffac
     and cbffac are called internally by gamma to evaluate the gamma function for real
     and complex numbers in bigfloat precision.
     makegamma substitutes gamma for factorials and related functions.
     Maxima knows the derivative of the factorial function and the limits for specific values
     like negative integers.
     The option variable factorial_expand controls the simplification of expressions like
     (n+x)!, where n is an integer.
     See also binomial.
172                                                                 Maxima 5.45.0 Manual
      this transformation, and more complicated transformations of this ilk as well. The
      logcontract command "contracts" expressions containing log.
%emode                                                                      [Option variable]
      Default value: true
      When %emode is true, %e^(%pi %i x) is simplified as follows.
      %e^(%pi %i x) simplifies to cos (%pi x) + %i sin (%pi x) if x is a floating point
      number, an integer, or a multiple of 1/2, 1/3, 1/4, or 1/6, and then further simplified.
      For other numerical x, %e^(%pi %i x) simplifies to %e^(%pi %i y) where y is x - 2 k
      for some integer k such that abs(y) < 1.
      When %emode is false, no special simplification of %e^(%pi %i x) is carried out.
            (%i1) %emode;
            (%o1)                                true
            (%i2) %e^(%pi*%i*1);
            (%o2)                                  - 1
            (%i3) %e^(%pi*%i*216/144);
            (%o3)                                - %i
            (%i4) %e^(%pi*%i*192/144);
                                            sqrt(3) %i        1
            (%o4)                       (- ----------) - -
                                                 2            2
            (%i5) %e^(%pi*%i*180/144);
                                              %i             1
            (%o5)                      (- -------) - -------
                                           sqrt(2)       sqrt(2)
            (%i6) %e^(%pi*%i*120/144);
                                            %i     sqrt(3)
            (%o6)                           -- - -------
                                            2         2
            (%i7) %e^(%pi*%i*121/144);
                                               121 %i %pi
                                               ----------
                                                   144
            (%o7)                           %e
%enumer                                                                   [Option variable]
      Default value: false
      When %enumer is true, %e is replaced by its numeric value 2.718. . . whenever numer
      is true.
      When %enumer is false, this substitution is carried out only if the exponent in %e^x
      evaluates to a number.
      See also ev and numer.
            (%i1) %enumer;
            (%o1)                              false
            (%i2) numer;
            (%o2)                              false
Chapter 10: Mathematical Functions                                                     175
             (%i3)   2*%e;
             (%o3)                                2 %e
             (%i4)   %enumer: not %enumer;
             (%o4)                                true
             (%i5)   2*%e;
             (%o5)                                2 %e
             (%i6)   numer: not numer;
             (%o6)                                true
             (%i7)   2*%e;
             (%o7)                       5.43656365691809
             (%i8)   2*%e^1;
             (%o8)                       5.43656365691809
             (%i9)   2*%e^x;
                                                         x
             (%o9)                    2 2.718281828459045
exp (x)                                                                       [Function]
     Represents the exponential function. Instances of exp (x) in input are simplified to
     %e^x; exp does not appear in simplified expressions.
     demoivre if true causes %e^(a + b %i) to simplify to %e^(a (cos(b) + %i sin(b)))
     if b is free of %i. See demoivre.
     %emode, when true, causes %e^(%pi %i x) to be simplified. See %emode.
     %enumer, when true causes %e to be replaced by 2.718. . . whenever numer is true.
     See %enumer.
             (%i1) demoivre;
             (%o1)                             false
             (%i2) %e^(a + b*%i);
                                              %i b + a
             (%o2)                         %e
             (%i3) demoivre: not demoivre;
             (%o3)                             true
             (%i4) %e^(a + b*%i);
                                       a
             (%o4)                  %e (%i sin(b) + cos(b))
li [s] (z)                                                                 [Function]
     Represents the polylogarithm function of order s and argument z, defined by the
     infinite series
                                                 ∞
                                                 X zk
                                     Lis (z) =
                                                 k=1
                                                       ks
     li [1] is - log (1 - z). li [2] and li [3] are the dilogarithm and trilogarithm
     functions, respectively.
     When the order is 1, the polylogarithm simplifies to - log (1 - z), which in turn
     simplifies to a numerical value if z is a real or complex floating point number or the
     numer evaluation flag is present.
176                                                                  Maxima 5.45.0 Manual
                                      /
                                      ====
                                      i = 1
     When logexpand is false, these simplifications are disabled.
         (%i1) logexpand : false $
         (%i2) log(n^2);
                                                  2
         (%o2)                              log(n )
         (%i3) log(10*x);
         (%o3)                            log(10 x)
         (%i4) log(a/(n + 1));
                                                 a
         (%o4)                          log(-----)
                                              n + 1
         (%i5) log ('product (X(i), i, 1, n));
                                              n
                                            /===\
                                             ! !
         (%o5)                        log( ! ! X(i))
                                             ! !
                                            i = 1
            (%i2) [sin (%pi * n), cos (%pi * m), sin (%pi/2 * m),
                   cos (%pi/2 * m)];
                                                  m/2
            (%o2)                  [0, 1, 0, (- 1)    ]
     A complicated factor is needed to make this formula correct for all complex arguments
     z:
                realpart(z)
          floor(-----------)
                   2 %pi
     (- 1)                   (1 - unit_step(- imagpart(z))
                                    realpart(z)            realpart(z)
                              floor(-----------) - ceiling(-----------)
                                       2 %pi                  2 %pi
                        ((- 1)                                          + 1))
     Maxima knows this factor and similar factors for the functions sin, cos, sinh, and
     cosh. For special values of the argument z these factors simplify accordingly.
     Examples:
           (%i1) halfangles : false$
           (%i2) sin (x / 2);
                                                  x
           (%o2)                              sin(-)
                                                  2
           (%i3) halfangles : true$
           (%i4) sin (x / 2);
                                         x
                                 floor(-----)
                                       2 %pi
                            (- 1)             sqrt(1 - cos(x))
           (%o4)            ----------------------------------
                                         sqrt(2)
           (%i5)   assume(x>0, x<2*%pi)$
           (%i6)   sin(x / 2);
                                     sqrt(1 - cos(x))
           (%o6)                     ----------------
                                         sqrt(2)
ntrig                                                                         [Package]
     The ntrig package contains a set of simplification rules that are used to simplify
     trigonometric function whose arguments are of the form f(n %pi/10) where f is any
     of the functions sin, cos, tan, csc, sec and cot.
trigreduce                                                                        [Function]
        trigreduce (expr, x)
        trigreduce (expr)
     Combines products and powers of trigonometric and hyperbolic sin’s and cos’s of x
     into those of multiples of x. It also tries to eliminate these functions when they occur
     in denominators. If x is omitted then all variables in expr are used.
     See also poissimp.
           (%i1) trigreduce(-sin(x)^2+3*cos(x)^2+x);
                          cos(2 x)      cos(2 x)   1        1
           (%o1)          -------- + 3 (-------- + -) + x - -
                             2             2       2        2
      (%i2) bc : sin(a)*sin(3*c)/sin(a+b);
                                                   %pi
                        sin(a) sin(3 ((- b) - a + ---))
                                                    3
      (%o2)             -------------------------------
                                   sin(b + a)
      (%i3) ba : bc, c=a, a=c;
                                                 %pi
                           sin(3 a) sin(b + a - ---)
                                                  3
      (%o3)                 -------------------------
                                           %pi
                                  sin(a - ---)
                                            3
      (%i4) ac2 : ba^2 + bc^2 - 2*bc*ba*cos(b);
               2          2          %pi
            sin (3 a) sin (b + a - ---)
                                      3
      (%o4) ---------------------------
                      2       %pi
                   sin (a - ---)
                               3
                                                 %pi
       - (2 sin(a) sin(3 a) sin(3 ((- b) - a + ---)) cos(b)
                                                  3
                   %pi              %pi
       sin(b + a - ---))/(sin(a - ---) sin(b + a))
                    3                3
            2       2                   %pi
         sin (a) sin (3 ((- b) - a + ---))
                                         3
       + ---------------------------------
                        2
                    sin (b + a)
      (%i5) trigrat (ac2);
      (%o5) - (sqrt(3) sin(4 b + 4 a) - cos(4 b + 4 a)
       - 2 sqrt(3) sin(4 b + 2 a) + 2 cos(4 b + 2 a)
       - 2 sqrt(3) sin(2 b + 4 a) + 2 cos(2 b + 4 a)
       + 4 sqrt(3) sin(2 b + 2 a) - 8 cos(2 b + 2 a) - 4 cos(2 b - 2 a)
       + sqrt(3) sin(4 b) - cos(4 b) - 2 sqrt(3) sin(2 b) + 10 cos(2 b)
       + sqrt(3) sin(4 a) - cos(4 a) - 2 sqrt(3) sin(2 a) + 10 cos(2 a)
       - 9)/4
Chapter 10: Mathematical Functions                                                    187
11 Maxima’s Database
            (%i3) c : x;
            (%o3)                                   x
            (%i4) constantp(c);
            (%o4)                                false
constantp (expr)                                                                [Function]
      Returns true if expr is a constant expression, otherwise returns false.
      An expression is considered a constant expression if its arguments are numbers (in-
      cluding rational numbers, as displayed with /R/), symbolic constants such as %pi, %e,
      and %i, variables bound to a constant or declared constant by declare, or functions
      whose arguments are constant.
      constantp evaluates its arguments.
      See the property constant which declares a symbol to be constant.
      Examples:
            (%i1) constantp (7 * sin(2));
            (%o1)                                        true
            (%i2) constantp (rat (17/29));
            (%o2)                                        true
            (%i3) constantp (%pi * sin(%e));
            (%o3)                                        true
            (%i4) constantp (exp (x));
            (%o4)                                        false
            (%i5) declare (x, constant);
            (%o5)                                        done
            (%i6) constantp (exp (x));
            (%o6)                                        true
            (%i7) constantp (foo (x) + bar (%e) + baz (2));
            (%o7)                                        false
            (%i8)
declare (a_1, p_1, a_2, p_2, . . . )                                                [Function]
      Assigns the atom or list of atoms a i the property or list of properties p i. When a i
      and/or p i are lists, each of the atoms gets all of the properties.
      declare quotes its arguments. declare always returns done.
      As noted in the description for each declaration flag, for some flags featurep(object,
      feature) returns true if object has been declared to have feature.
      For more information about the features system, see features. To remove a property
      from an atom, use remove.
      declare recognizes the following properties:
      additive     Tells Maxima to simplify a i expressions by the substitution a_i(x +
                   y + z + ...) --> a_i(x) + a_i(y) + a_i(z) + .... The substitution is
                   carried out on the first argument only.
      alphabetic
                   Tells Maxima to recognize all characters in a i (which must be a string)
                   as alphabetic characters.
Chapter 11: Maxima’s Database                                                        191
       nonscalar
                   Tells Maxima to consider a i a nonscalar variable. The usual application
                   is to declare a variable as a symbolic vector or matrix.
       noun        Tells Maxima to parse a i as a noun. The effect of this is to replace
                   instances of a i with 'a_i or nounify(a_i), depending on the context.
       outative    Tells Maxima to simplify a i expressions by pulling constant factors out
                   of the first argument.
                   When a i has one argument, a factor is considered constant if it is a literal
                   or declared constant.
                   When a i has two or more arguments, a factor is considered constant
                   if the second argument is a symbol and the factor is free of the second
                   argument.
       posfun      Tells Maxima to recognize a i as a positive function.
       rational, irrational
                 Tells Maxima to recognize a i as a rational or irrational real variable.
       real, imaginary, complex
                 Tells Maxima to recognize a i as a real, pure imaginary, or complex vari-
                 able.
       scalar      Tells Maxima to consider a i a scalar variable.
       Examples of the usage of the properties are available in the documentation for each
       separate description of a property.
decreasing                                                                  [Property]
increasing                                                                  [Property]
       The commands declare(f, decreasing) or declare(f, increasing) tell Maxima
       to recognize the function f as an decreasing or increasing function.
       See also declare for more properties.
       Example:
             (%i1) assume(a > b);
             (%o1)                              [a > b]
             (%i2) is(f(a) > f(b));
             (%o2)                              unknown
             (%i3) declare(f, increasing);
             (%o3)                                done
             (%i4) is(f(a) > f(b));
             (%o4)                                true
even                                                                           [Property]
odd                                                                            [Property]
       declare(a, even) or declare(a, odd) tells Maxima to recognize the symbol a as
       an even or odd integer variable. The properties even and odd are not recognized by
       the functions evenp, oddp, and integerp.
       See also declare and askinteger.
Chapter 11: Maxima’s Database                                                          193
     Example:
            (%i1)   declare(n, even);
            (%o1)                              done
            (%i2)   askinteger(n, even);
            (%o2)                                yes
            (%i3)   askinteger(n);
            (%o3)                                yes
            (%i4)   evenp(n);
            (%o4)                              false
feature                                                                       [Property]
     Maxima understands two distinct types of features, system features and features
     which apply to mathematical expressions. See also status for information about sys-
     tem features. See also features and featurep for information about mathematical
     features.
     feature itself is not the name of a function or variable.
features                                                                   [Declaration]
     Maxima recognizes certain mathematical properties of functions and variables. These
     are called "features".
     declare (x, foo) gives the property foo to the function or variable x.
     declare (foo, feature) declares a new feature foo. For example, declare ([red,
     green, blue], feature) declares three new features, red, green, and blue.
     The predicate featurep (x, foo) returns true if x has the foo property, and false
     otherwise.
     The infolist features is a list of known features. These are
          integer          noninteger         even
          odd              rational           irrational
          real             imaginary          complex
          analytic         increasing         decreasing
          oddfun           evenfun            posfun
          constant         commutative        lassociative
          rassociative     symmetric          antisymmetric
          integervalued
194                                                                 Maxima 5.45.0 Manual
integervalued                                                              [Property]
     declare(f, integervalued) tells Maxima to recognize f as an integer-valued func-
     tion.
     See also declare.
     Example:
            (%i1) exp(%i)^f(x);
                                          %i f(x)
            (%o1)                      (%e )
            (%i2) declare(f, integervalued);
            (%o2)                         done
            (%i3) exp(%i)^f(x);
                                          %i f(x)
            (%o3)                       %e
nonarray                                                                       [Property]
     The command declare(a, nonarray) tells Maxima to consider a not an array. This
     declaration prevents multiple evaluation, if a is a subscripted variable.
     See also declare.
     Example:
            (%i1) a:'b$ b:'c$ c:'d$
            (%i4) a[x];
            (%o4)                                d
                                                  x
            (%i5) declare(a, nonarray);
            (%o5)                              done
            (%i6) a[x];
            (%o6)                                a
                                                  x
nonscalar                                                                     [Property]
     Makes atoms behave as does a list or matrix with respect to the dot operator.
     See also declare.
posfun                                                                        [Property]
     declare (f, posfun) declares f to be a positive function. is (f(x) > 0) yields true.
     See also declare.
196                                                                Maxima 5.45.0 Manual
printprops                                                                      [Function]
        printprops (a, i)
        printprops ([a_1, . . . , a_n], i)
        printprops (all, i)
      Displays the property with the indicator i associated with the atom a. a may also
      be a list of atoms or the atom all in which case all of the atoms with the given
      property will be used. For example, printprops ([f, g], atvalue). printprops
      is for properties that cannot otherwise be displayed, i.e. for atvalue, atomgrad,
      gradef, and matchdeclare.
     Example:
         (%i1)    foo: aa$
         (%i2)    bar: bb$
         (%i3)    baz: cc$
         (%i4)    put (foo, bar, baz);
         (%o4)                             bb
         (%i5)    properties (aa);
         (%o5)                   [[user properties, cc]]
         (%i6)    get (aa, cc);
         (%o6)                             bb
         (%i7)    qput (foo, bar, baz);
         (%o7)                             bar
         (%i8)    properties (foo);
         (%o8)               [value, [user properties, baz]]
         (%i9)    get ('foo, 'baz);
         (%o9)                             bar
rational                                                                [Property]
irrational                                                              [Property]
     declare(a, rational) or declare(a, irrational) tells Maxima to recognize a as
     a rational or irrational real variable.
     See also declare.
real                                                                    [Property]
imaginary                                                               [Property]
complex                                                                 [Property]
     declare(a, real), declare(a, imaginary), or declare(a, complex) tells Maxima
     to recognize a as a real, pure imaginary, or complex variable.
     See also declare.
rem (atom, indicator)                                                         [Function]
     Removes the property indicated by indicator from atom. rem reverses the effect of
     put.
     rem returns done if atom had an indicator property when rem was called, or false if
     it had no such property.
remove                                                                          [Function]
         remove  (a_1, p_1, . . . , a_n, p_n)
         remove  ([a_1, . . . , a_m], [p_1, . . . , p_n], . . . )
         remove  ("a", operator)
         remove  (a, transfun)
         remove  (all, p)
     Removes properties associated with atoms.
     remove (a_1, p_1, ..., a_n, p_n) removes property p_k from atom a_k.
     remove ([a_1, ..., a_m], [p_1, ..., p_n], ...) removes properties p_1, ...,
     p_n from atoms a 1, . . . , a m. There may be more than one pair of lists.
     remove (all, p) removes the property p from all atoms which have it.
198                                                                   Maxima 5.45.0 Manual
scalar                                                                              [Property]
      declare(a, scalar) tells Maxima to consider a a scalar variable.
      See also declare.
askinteger                                                                      [Function]
        askinteger      (expr, integer)
        askinteger      (expr)
        askinteger      (expr, even)
        askinteger      (expr, odd)
      askinteger (expr, integer) attempts to determine from the assume database
      whether expr is an integer. askinteger prompts the user if it cannot tell otherwise,
Chapter 11: Maxima’s Database                                                            199
          (%o6)                               pos
          (%i7) asksign (a[1]);
                                            x = a
                                                 1
          (%o7)                               pos
          (%i8) asksign (foo (a));
                                          x = foo(a)
          (%o8)                          pos
          (%i9) asksign (foo (a) + bar (b));
                                     x = foo(a)
x = bar(b)
          (%o9)                               pos
          (%i10) asksign (log (a));
                                             x = a
          p;
          (%o10)                              pos
          (%i11) asksign (a - b);
                                             x = a
x = b
x = a
                                             x = b
202                                                                      Maxima 5.45.0 Manual
            p;
            (%o11)                                 neg
context                                                                   [Option variable]
      Default value: initial
      context names the collection of facts maintained by assume and forget. assume
      adds facts to the collection named by context, while forget removes facts.
      Binding context to a name foo changes the current context to foo. If the specified
      context foo does not yet exist, it is created automatically by a call to newcontext.
      The specified context is activated automatically.
      See contexts for a general description of the context mechanism.
contexts                                                                    [Option variable]
      Default value: [initial, global]
      contexts is a list of the contexts which currently exist, including the currently active
      context.
      The context mechanism makes it possible for an user to bind together and name a
      collection of facts, called a context. Once this is done, the user can have Maxima
      assume or forget large numbers of facts merely by activating or deactivating their
      context.
      Any symbolic atom can be a context, and the facts contained in that context will be
      retained in storage until destroyed one by one by calling forget or destroyed as a
      whole by calling kill to destroy the context to which they belong.
      Contexts exist in a hierarchy, with the root always being the context global, which
      contains information about Maxima that some functions need. When in a given
      context, all the facts in that context are "active" (meaning that they are used in
      deductions and retrievals) as are all the facts in any context which is a subcontext of
      the active context.
      When a fresh Maxima is started up, the user is in a context called initial, which
      has global as a subcontext.
      See also facts, newcontext, supcontext, killcontext, activate, deactivate,
      assume, and forget.
deactivate (context_1, . . . , context_n)                                           [Function]
      Deactivates the specified contexts context 1, . . . , context n.
facts                                                                               [Function]
          facts (item)
          facts ()
      If item is the name of a context, facts (item) returns a list of the facts in the
      specified context.
      If item is not the name of a context, facts (item) returns a list of the facts known
      about item in the current context. Facts that are active, but in a different context,
      are not listed.
Chapter 11: Maxima’s Database                                                         203
forget                                                                         [Function]
         forget (pred_1, . . . , pred_n)
         forget (L)
     Removes predicates established by assume. The predicates may be expressions equiv-
     alent to (but not necessarily identical to) those previously assumed.
     forget (L), where L is a list of predicates, forgets each item on the list.
is (expr)                                                                       [Function]
     Attempts to determine whether the predicate expr is provable from the facts in the
     assume database.
     If the predicate is provably true or false, is returns true or false, respectively.
     Otherwise, the return value is governed by the global flag prederror. When
     prederror is true, is complains with an error message. Otherwise, is returns
     unknown.
     ev(expr, pred) (which can be written expr, pred at the interactive prompt) is
     equivalent to is(expr).
     See also assume, facts, and maybe.
     Examples:
     is causes evaluation of predicates.
            (%i1) %pi > %e;
            (%o1)                             %pi > %e
            (%i2) is (%pi > %e);
            (%o2)                               true
     is attempts to derive predicates from the assume database.
            (%i1) assume (a > b);
            (%o1)                              [a > b]
            (%i2) assume (b > c);
            (%o2)                              [b > c]
            (%i3) is (a < b);
            (%o3)                               false
            (%i4) is (a > c);
            (%o4)                               true
            (%i5) is (equal (a, c));
            (%o5)                               false
     If is can neither prove nor disprove a predicate from the assume database, the global
     flag prederror governs the behavior of is.
            (%i1) assume (a > b);
            (%o1)                              [a > b]
            (%i2) prederror: true$
            (%i3) is (a > 0);
            Maxima was unable to evaluate the predicate:
            a > 0
             -- an error. Quitting. To debug this try debugmode(true);
204                                                                   Maxima 5.45.0 Manual
newcontext                                                                          [Function]
        newcontext (name)
        newcontext ()
      Creates a new, empty context, called name, which has global as its only subcontext.
      The newly-created context becomes the currently active context.
      If name is not specified, a new name is created (via gensym) and returned.
      newcontext evaluates its argument. newcontext returns name (if specified) or the
      new context name.
supcontext                                                                       [Function]
        supcontext (name, context)
        supcontext (name)
        supcontext ()
     Creates a new context, called name, which has context as a subcontext. context must
     exist.
     If context is not specified, the current context is assumed.
     If name is not specified, a new name is created (via gensym) and returned.
     supcontext evaluates its argument. supcontext returns name (if specified) or the
     new context name.
      The function compare doesn’t try to determine whether the real domains of its argu-
      ments are nonempty; thus
            (%i1) compare (acos (x^2 + 1), acos (x^2 + 1) + 1);
            (%o1)                                <
      The real domain of acos (x^2 + 1) is empty.
equal (a, b)                                                                          [Function]
      Represents equivalence, that is, equal value.
      By itself, equal does not evaluate or simplify. The function is attempts to evaluate
      equal to a Boolean value. is(equal(a, b)) returns true (or false) if and only if a
      and b are equal (or not equal) for all possible values of their variables, as determined by
      evaluating ratsimp(a - b); if ratsimp returns 0, the two expressions are considered
      equivalent. Two expressions may be equivalent even if they are not syntactically equal
      (i.e., identical).
      When is fails to reduce equal to true or false, the result is governed by the global
      flag prederror. When prederror is true, is complains with an error message.
      Otherwise, is returns unknown.
      In addition to is, some other operators evaluate equal and notequal to true or
      false, namely if, and, or, and not.
      The negation of equal is notequal.
      Examples:
      By itself, equal does not evaluate or simplify.
              (%i1) equal (x^2 - 1, (x + 1) * (x - 1));
                                            2
              (%o1)              equal(x - 1, (x - 1) (x + 1))
              (%i2) equal (x, x + 1);
              (%o2)                           equal(x, x + 1)
              (%i3) equal (x, y);
              (%o3)                             equal(x, y)
      The function is attempts to evaluate equal to a Boolean value. is(equal(a, b))
      returns true when ratsimp(a - b) returns 0. Two expressions may be equivalent
      even if they are not syntactically equal (i.e., identical).
              (%i1) ratsimp (x^2 - 1 - (x + 1) * (x - 1));
              (%o1)                                    0
              (%i2) is (equal (x^2 - 1, (x + 1) * (x - 1)));
              (%o2)                                 true
              (%i3) is (x^2 - 1 = (x + 1) * (x - 1));
              (%o3)                                 false
              (%i4) ratsimp (x - (x + 1));
              (%o4)                                  - 1
              (%i5) is (equal (x, x + 1));
              (%o5)                                 false
              (%i6) is (x = x + 1);
              (%o6)                                 false
              (%i7) ratsimp (x - y);
Chapter 11: Maxima’s Database                                                        207
          (%o7)                                 x - y
          (%i8) is (equal (x, y));
          (%o8)                                unknown
          (%i9) is (x = y);
          (%o9)                                 false
     When is fails to reduce equal to true or false, the result is governed by the global
     flag prederror.
          (%i1) [aa : x^2 + 2*x + 1, bb : x^2 - 2*x - 1];
                              2             2
          (%o1)             [x + 2 x + 1, x - 2 x - 1]
          (%i2) ratsimp (aa - bb);
          (%o2)                        4 x + 2
          (%i3) prederror : true;
          (%o3)                         true
          (%i4) is (equal (aa, bb));
          Maxima was unable to evaluate the predicate:
                 2              2
          equal(x + 2 x + 1, x - 2 x - 1)
           -- an error. Quitting. To debug this try debugmode(true);
          (%i5) prederror : false;
          (%o5)                         false
          (%i6) is (equal (aa, bb));
          (%o6)                        unknown
     Some operators evaluate equal and notequal to true or false.
          (%i1) if equal (y, y - 1) then FOO else BAR;
          (%o1)                          BAR
          (%i2) eq_1 : equal (x, x + 1);
          (%o2)                    equal(x, x + 1)
          (%i3) eq_2 : equal (y^2 + 2*y + 1, (y + 1)^2);
                                   2                   2
          (%o3)             equal(y + 2 y + 1, (y + 1) )
          (%i4) [eq_1 and eq_2, eq_1 or eq_2, not eq_1];
          (%o4)                  [false, true, true]
     Because not expr causes evaluation of expr, not equal(a, b) is equivalent to
     is(notequal(a, b)).
          (%i1) [notequal (2*z, 2*z - 1), not equal (2*z, 2*z - 1)];
          (%o1)            [notequal(2 z, 2 z - 1), true]
          (%i2) is (notequal (2*z, 2*z - 1));
          (%o2)                         true
12 Plotting
      additional package dynamics, but that package does not have to be loaded; the first
      time julia is used, it will be loaded automatically.
      Each pixel in the grid is given a color corresponding to the number of iterations it
      takes the sequence that starts at that point to move out of the convergence circle of
      radius 2 centered at the origin. The number of pixels in the grid is controlled by the
      grid plot option (default 30 by 30). The maximum number of iterations is set with
      the option iterations. The program sets its own default palette: magenta, violet,
      blue, cyan, green, yellow, orange, red, brown and black, but it can be changed by
      adding an explicit palette option in the command.
      The default domain used goes from -2 to 2 in both axes and can be changed with
      the x and y options. By default, the two axes are shown with the same scale, unless
      the option yx_ratio is used or the option same_xy is disabled. Other general plot
      options are also accepted.
      The following example shows a region of the Julia set for the number -0.55 + i0.6.
      The option color_bar_tics is used to prevent Gnuplot from adjusting the color box
      up to 40, in which case the points corresponding the maximum 36 iterations would
      not be black.
              (%i1) julia (-0.55, 0.6, [iterations, 36], [x, -0.3, 0.2],
                    [y, 0.3, 0.9], [grid, 400, 400], [color_bar_tics, 0, 6, 36])$
0.9 36
0.8 30
               0.7
                                                          24
               0.6
          y
18
               0.5
                                                          12
               0.4
                                                          6
               0.3
                 -0.3   -0.2   -0.1       0   0.1   0.2
                                      x
     This program can be called without any arguments, in which case it will use a default
     value of 9 iterations per point, a grid with dimensions set by the grid plot option
     (default 30 by 30) and a region that extends from -2 to 2 in both axes. The options are
     all the same that plot2d accepts, plus an option iterations to change the number
     of iterations.
     Each pixel in the grid is given a color corresponding to the number of iterations it
     takes the sequence starting at zero to move out of the convergence circle of radius
     2, centered at the origin. The maximum number of iterations is set by the option
     iterations. The program uses its own default palette: magenta,violet, blue, cyan,
     green, yellow, orange, red, brown and black, but it can be changed by adding an
     explicit palette option in the command. By default, the two axes are shown with
     the same scale, unless the option yx_ratio is used or the option same_xy is disabled.
Example:
[grid,400,400])$
                 (%i1) mandelbrot ([iterations, 30], [x, -2, 1], [y, -1.2, 1.2],
                             [grid,400,400])$
                                                       30
            1
                                                       25
          0.5
                                                       20
            0                                          15
      y
                                                       10
          -0.5
                                                       5
           -1
                                                       0
                 -2   -1.5   -1   -0.5   0   0.5   1
                                   x
plot2d                                                                               [Function]
          plot2d    (expr, range_x, options)
          plot2d    (expr_1=expr_2, range_x, range_y, options)
          plot2d    ([parametric, expr_x, expr y, range], options)
          plot2d    ([discrete, points], options)
          plot2d    ([contour, expr], range_x, range_y, options)
          plot2d    ([type_1, . . . , type_n], options)
      There are 5 types of plots that can be plotted by plot2d:
       1. Explicit functions. plot2d (expr, range x, options), where expr is an expression
          that depends on only one variable, or the name of a function with one input
          parameter and numerical results. range x is a list with three elements, the first
          one being the name of the variable that will be shown on the horizontal axis of
          the plot, and the other two elements should be two numbers, the first one smaller
          than the second, that define the minimum and maximum values to be shown on
          the horizontal axis. The name of the variable used in range x must be the same
          variable on which expr depends. The result will show in the vertical axis the
          corresponding values of the expression or function for each value of the variable
          in the horizontal axis.
       2. Implicit functions. plot2d (expr 1=expr 2, range x, range y, options), where
          expr 1 and expr 2 are two expressions that can depend on one or two variables.
          range x and range y must be two lists of three elements that define the ranges
          for the variables in the two axes of the plot; the first element of each list is the
          name of the corresponding variable, and the other two elements are the minimum
          and maximum values for that variable. The two variables on which expr 1 and
          expr 2 can depend are those specified by range x and range y. The result will
          be a curve or a set of curves where the equation expr 1=expr 2 is true.
       3. Parametric functions. plot2d ([parametric, expr x, expr y, range], options),
          where expr x and expr y are two expressions that depend on a single parameter.
          range must be a three-element list; the first element must be the name of the
          parameter on which expr x and expr y depend, and the other two elements must
          be the minimum and maximum values for that parameter. The result will be a
          curve in which the horizontal and vertical coordinates of each point are the values
          of expr x and expr y for a value of the parameter within the range given.
       4. Set of points. plot2d ([discrete, points], options), displays a list of points, joined
          by segments by default. The horizontal and vertical coordinates of each of those
          points can be specified in three different ways: With two lists of the same length,
          in which the elements of the first list are the horizontal coordinates of the points
          and the second list are the vertical coordinates, or with a list of two-element
          lists, each one corresponding to the two coordinates of one of the points, or with
          a single list that defines the vertical coordinates of the points; in this last case,
          the horizontal coordinates of the n points will be assumed to be the first n natural
          numbers.
       5. Contour lines. plot2d ([contour, expr], range x, range y, options), where expr
          is an expression that depends on two variables. range x and range y will be
          lists whose first elements are the names of those two variables, followed by two
          numbers that set the minimum and maximum values for them. The first variable
Chapter 12: Plotting                                                                    215
          will be represented along the horizontal axis and the second along the vertical
          axis. The result will be a set of curves along which the given expression has
          certain values. If those values are not specified with the option levels, plotd2d
          will try to choose, at the most, 8 values of the form d*10^n, where d is either 1,
          2 or 5, all of them within the minimum and maximum values of expr within the
          given ranges.
     At the end of a plot2d command several of the options described in Section 12.4
     Plotting Options can be used. Many instances of the 5 types described above can
     be combined into a single plot, by putting them inside a list: plot2d ([type 1, . . . ,
     type n], options). If one of the types included in the list require range x or range y,
     those ranges should come immediately after the list.
     If there are several plots to be plotted, a legend will be written to identity each of
     the expressions. The labels that should be used in that legend can be given with
     the option legend. If that option is not used, Maxima will create labels from the
     expressions or function names.
Examples:
1. Explicit function.
                   0.5
          sin(x)
-0.5
-1
                          -3   -2   -1    0    1    2    3
                                          x
      2. Implicit function.
216                                                                                                                                         Maxima 5.45.0 Manual
                                                          0
          y
-1
-2
                                                                       -2                  -1         0             1               2
                                                                                                      x
3. Parametric function.
                                                                   (%i1) r: (exp(cos(t))-2*cos(4*t)-sin(t/12)^5)$
                                                                   (%i2) plot2d([parametric, r*sin(t), r*cos(t), [t,-8*%pi,8*%pi]])$
                                                              4
           cos(t)*((-2*cos(4*t))+%e^cos(t)-sin(t/12)^5)
-1
-2
                                                                  -4        -3        -2        -1    0       1         2       3       4
                                                                                 sin(t)*((-2*cos(4*t))+%e^cos(t)-sin(t/12)^5)
4. Set of points.
1.2
               0.8
          y
0.6
0.4
0.2
                         2        4        6        8           10       12           14   16
                                                            x
5. Contour lines.
(%i1) plot2d ([contour, u^3 + v^2], [u, -4, 4], [v, -4, 4])$
               4
                                                                              -40.0
                                                                              -20.0
               3                                                                0.0
                                                                               20.0
                                                                               40.0
               2                                                               60.0
               0
           v
-1
-2
-3
               -4
                    -4       -3       -2       -1       0            1    2           3    4
                                                        u
     If an explicit function grows too fast, the y option can be used to limit the values in
     the vertical axis:
218                                                                                       Maxima 5.45.0 Manual
20
15
10
                5
      sec(x)
-5
-10
-15
               -20
                     -2   -1.5        -1   -0.5        0      0.5       1       1.5   2
                                                       x
      When the plot box is disabled, no labels are created for the axes. In that case, instead
      of using xlabel and ylabel to set the names of the axes, it is better to use option
      label, which allows more flexibility. Option yx_ratio is used to change the default
      rectangular shape of the plot; in this example the plot will fill a square.
A parabola
x^2-1
                                                                            x
                                 -2                                 2
1000
100
                         10
      %e^(3*s)
0.1
0.01
                   0.001
                                 -2   -1.5          -1   -0.5       0   0.5     1       1.5   2
                                                                    s
                 1.5
                                                                                    F
                                                                                    G
                                                                                    H
                   1
0.5
-0.5
-1
                 -1.5
                        -1                   -0.5               0             0.5             1
                                                                u
     Plot of a circle, using its parametric representation, together with the function -|x|.
     The circle will only look like a circle if the scale in the two axes is the same, which is
     done with the option same_xy.
220                                                                                       Maxima 5.45.0 Manual
                     1                                 cos(t), sin(t)
                                                            -abs(x)
0.5
-0.5
-1
                   -1.5
                               -1        -0.5     0       0.5           1
                                                 x
           5
       y
      In the next example a table with three columns is saved in a file “data.txt” which is
      then read and the second and third column are plotted on the two axes:
                   (%i1) display2d:false$
                   (%i2) with_stdout ("data.txt", for x:0 thru 10 do
                                                print (x, x^2, x^3))$
                   (%i3) data: read_matrix ("data.txt")$
                   (%i4) plot2d ([discrete, transpose(data)[2], transpose(data)[3]],
Chapter 12: Plotting                                                                           221
1000
800
                    600
      y
400
200
                             0       20       40          60         80     100
                                                     x
                   1.4                                         experiment
                                                                   theory
1.2
                     1
      period (s)
0.8
0.6
0.4
0.2
                         0           10       20          30         40     50
                                          pendulum's length (cm)
      Examples.
      Plot of a function of two variables:
                 (%i1) plot3d (u^2 - v^2, [u, -2, 2], [v, -3, 3], [grid, 100, 100],
                         nomesh_lines)$
u^2-v^2
             4
             2
             0
            -2
       z
            -4
            -6
                                                                                         3
            -8                                                                       2
           -10 -2                                                             1
                    -1.5 -1                                              0
                            -0.5                                   -1                v
                                   0   0.5   1                -2
                             u                   1.5   2 -3
      Use of the z option to limit a function that goes to infinity (in this case the function
      is minus infinity on the x and y axes); this also shows how to plot with only lines and
      no shading:
                 (%i1) plot3d ( log ( x^2*y^2 ), [x, -2, 2], [y, -2, 2], [z, -8, 4],
                          nopalette, [color, magenta])$
log(x^2*y^2)
z -2
-4
            -6                                                                          2
                                                                                     1.5
                                                                                 1
            -8 -2                                                             0.5
                    -1.5 -1                                               0
                            -0.5                                      -0.5           y
                                   0   0.5                       -1
                             x               1                -1.5
                                                 1.5   2 -2
      The infinite values of z can also be avoided by choosing a grid that does not fall on
      any points where the function is undefined, as in the next example, which also shows
      how to change the palette and how to include a color bar that relates colors to values
      of the z variable:
Chapter 12: Plotting                                                                              223
                (%i1) plot3d (log (x^2*y^2), [x, -2, 2], [y, -2, 2],[grid, 29, 29],
                       [palette, [gradient, red, orange, yellow, green]],
                       color_bar, [xtics, 1], [ytics, 1], [ztics, 4],
                       [color_bar_tics, 4])$
log(x^2*y^2)
4 0
                                                                                            -4
            0
                                                                                            -8
      z    -4
                                                                                            -12
           -8
                                                                                        2
                                                                                1
          -12 -2
                                                                        0
                        -1                                                          y
                                  0                           -1
                             x            1
                                                  2 -2
     Two surfaces in the same plot. Ranges specific to one of the surfaces can be given
     by placing each expression and its ranges in a separate list; global ranges for the
     complete plot are also given after the function definitions.
                (%i1) plot3d ([[-3*x - y, [x, -2, 2], [y, -2, 2]],
                   4*sin(3*(x^2 + y^2))/(x^2 + y^2), [x, -3, 3], [y, -3, 3]],
                   [x, -4, 4], [y, -4, 4])$
                                      (4*sin(3*(y^2+x^2)))/(y^2+x^2)
                                                              (-y)-3*x
15
10
            5
      z
            0
           -5                                                                           4
                                                                                    3
                                                                                2
          -10 -4                                                            1
                   -3                                                   0
                        -2   -1                                    -1               y
                                  0   1                       -2
                             x            2              -3
                                              3   4 -4
Parametric function
             8
             6
             4
             2
       z     0
             -2
             -4
                                                                                      25
             -6                                                                     20
                                                                                  15
                                                                                10
             -8-35                                                          5
                   -30 -25                                              0
                           -20 -15                                 -5             y
                                   -10 -5                        -10
                                                               -15
                             x                  0   5        -20
                                                        10 -25
           0.8
           0.6
           0.4
           0.2
       z     0
           -0.2
           -0.4
                                                                                     0.4
           -0.6                                                                   0.3
                                                                               0.2
           -0.8-0.8                                                         0.1
                    -0.6 -0.4                                          0
                              -0.2                                 -0.1           y
                                      0   0.2 0.4               -0.2
                              x                              -0.3
                                                  0.6 0.8 -0.4
z 0
-2
                -4
                                                            5
                                                           4
                -6 -6                                     3
                                                         2
                        -4                              1
                             -2                        0
                                  0                  -1      y
                                      2            -2
                                                  -3
                              x           4     -4
                                              6-5
3.5
z 2.5
           1.5                                                                       4
                                                                               3.5
            11                                                             3
                   1.5                                               2.5
                          2                                      2             y
                               2.5
                                     3                     1.5
                          x               3.5
                                                    4 1
      By setting the elevation equal to zero, a surface can be seen as a map in which each
      color represents a different level.
                 (%i1) plot3d (cos (-x^2 + y^3/4), [x,-4,4], [y,-4,4], [zlabel,""],
                        [mesh_lines_color,false], [elevation,0], [azimuth,0],
                        color_bar, [grid,80,80], noztics, [color_bar_tics,1])$
cos(y^3/4-x^2)
                                                                         4               1
                                                                         3
                                                                         2
                                                                                         0
                                                                         1
                                                                         0           y
                                                                         -1              -1
                                                                         -2
                                                                         -3
                                                                         -4
                     -4   -3   -2    -1   0     1     2      3       4
      will not be used and the resulting plot will have 1+4*nticks points (see option nticks).
      To have more control on the number of points and their positions, a list of points can
      be created and then plotted using the discrete method of plot2d.
color_bar [color bar, symbol], color bar, nocolor bar                             [Plot option]
      Default value: false in plot3d, true in mandelbrot and julia
      Where symbol can be either true or false. If true, whenever plot3d, mandelbrot
      or julia use a palette to represent different values, a box will be shown on the right,
      showing the corresponding between colors and values. The single keywords color_bar
      and nocolor_bar can be used as synonyms for [color_bar, true] and [color_bar,
      false].
Chapter 12: Plotting                                                                         229
color_bar_tics [color bar tics, x1, x2, x3], color bar tics,                       [Plot option]
        nocolor bar tics
      Defines the values at which a mark and a number will be placed in the color bar. The
      first number is the initial value, the second the increments and the third is the last
      value where a mark is placed. The second and third numbers can be omitted. When
      only one number is given, it will be used as the increment from an initial value that
      will be chosen automatically. The single keyword color_bar_tics removes a value
      given previously, making the graphic program use its default for the values of the tics
      and nocolor_bar_tics will not show any tics on the color bar.
elevation [elevation, number]                                                 [Plot option]
      Default value: 60
      A plot3d plot can be thought of as starting with the x and y axis in the horizontal
      and vertical axis, as in plot2d, and the z axis coming out of the screen. The z axis
      is then rotated around the x axis through an angle equal to elevation and then the
      new xy plane is rotated around the new z axis through an angle azimuth. This option
      sets the value for the elevation, in degrees.
      See also azimuth.
grid [grid, integer, integer]                                                   [Plot option]
      Default value: 30, 30
      Sets the number of grid points to use in the x- and y-directions for three-dimensional
      plotting or for the julia and mandelbrot programs.
      For a way to actually draw a grid See grid2d.
grid2d [grid2d, value], grid2d, nogrid2d                                      [Plot option]
      Default value: false
      Shows a grid of lines on the xy plane. The points where the grid lines are placed are
      the same points where tics are marked in the x and y axes, which can be controlled
      with the xtics and ytics options. The single keywords grid2d and nogrid2d can
      be used as synonyms for [grid2d, true] and [grid2d, false].
      See also grid.
iterations [iterations, value]                                                     [Plot option]
      Default value: 9
      Number of iterations made by the programs mandelbrot and julia.
label [label, [string, x, y], . . . ]                                         [Plot option]
      Writes one or several labels in the points with x, y coordinates indicated after each
      label.
legend [legend, string_1, . . . , string_n], legend, nolegend                       [Plot option]
      It specifies the labels for the plots when various plots are shown. If there are more
      plots than the number of labels given, they will be repeated. If given the value false,
      no legends will be shown. By default, the names of the expressions or functions will
      be used, or the words discrete1, discrete2, . . . , for discrete sets of points. The single
      keyword legend removes any previously defined legends, leaving it to the plotting
      program to set up a legend. The keyword nolegend is a synonym for [legend,
      false].
230                                                                    Maxima 5.45.0 Manual
mesh_lines_color [mesh lines color, color], mesh lines color,                     [Plot option]
        no mesh lines
      Default value: black
      It sets the color used by plot3d to draw the mesh lines, when a palette is being used.
      It accepts the same colors as for the option color (see the list of allowed colors in
      color). It can also be given a value false to eliminate completely the mesh lines.
      The single keyword mesh_lines_color removes any previously defined colors, leaving
      it to the graphic program to decide what color to use. The keyword no_mesh_lines
      is a synonym for [mesh_lines_color, false]
     of the three attributes (hue, saturation or value) will be increased according to the
     values of z. The last number indicates the increase corresponding to the maximum
     value of z. That last number can be bigger than 1 or negative; the corresponding
     values of the modified attribute will be rounded modulo 1.
     Gnuplot only uses the first palette in the list; xmaxima will use the palettes in the
     list sequentially, when several surfaces are plotted together; if the number of palettes
     is exhausted, they will be repeated sequentially.
     The color of the mesh lines will be given by the option mesh_lines_color. If palette
     is given the value false, the surfaces will not be shaded but represented with a mesh
     of curves only. In that case, the colors of the lines will be determined by the option
     color.
     The single keyword palette removes any palette previously defined, leaving it to
     the graphic program to decide the palette to use and nopalette is a synonym for
     [palette, false].
run_viewer [run viewer, symbol], run viewer, norun viewer                         [Plot option]
      Default value: true
      This option is only used when the plot format is gnuplot and the terminal is default
      or when the Gnuplot terminal is set to dumb (see gnuplot_term) and can have a true
      or false value.
      If the terminal is default, a file maxout_xxx.gnuplot (or other name specified with
      gnuplot_out_file) is created with the gnuplot commands necessary to generate the
      plot. Option run_viewer controls whether or not Gnuplot will be launched to execute
      those commands and show the plot.
Chapter 12: Plotting                                                                       233
same_xyz [same xyz , value], same xyz, nosame xyz                                [Plot option]
      It can be either true or false. If true, the scales used in the 3 axes of a 3d plot will
      be the same. same_xyz and nosame_xyz are synonyms for [same_xyz, true] and
      [same_xyz, false].
xtics [xtics, x1, x2, x3], [xtics, false], xtics, noxtics                      [Plot option]
      Defines the values at which a mark and a number will be placed in the x axis. The
      first number is the initial value, the second the increments and the third is the last
      value where a mark is placed. The second and third numbers can be omitted, in
      which case the first number is the increment from an initial value that will be chosen
      by the graphic program. If [xtics, false] is used, no marks or numbers will be
      shown along the x axis.
Chapter 12: Plotting                                                                     235
     The single keyword xtics removes any values previously defined, leaving it to the
     graphic program to decide the values to use and noxtics is a synonym for [xtics,
     false]
ytics [ytics, y1, y2, y3], [ytics, false], ytics, noytics                     [Plot option]
     Defines the values at which a mark and a number will be placed in the y axis. The
     first number is the initial value, the second the increments and the third is the last
     value where a mark is placed. The second and third numbers can be omitted, in
     which case the first number is the increment from an initial value that will be chosen
     by the graphic program. If [ytics, false] is used, no marks or numbers will be
     shown along the y axis.
     The single keyword ytics removes any values previously defined, leaving it to the
     graphic program to decide the values to use and noytics is a synonym for [ytics,
     false]
ztics [ztics, z1, z2, z3], [ztics, false], ztics, noztics                      [Plot option]
      Defines the values at which a mark and a number will be placed in the z axis. The
      first number is the initial value, the second the increments and the third is the last
      value where a mark is placed. The second and third numbers can be omitted, in
      which case the first number is the increment from an initial value that will be chosen
      by the graphic program. If [ztics, false] is used, no marks or numbers will be
      shown along the z axis.
      The single keyword ztics removes any values previously defined, leaving it to the
      graphic program to decide the values to use and noztics is a synonym for [ztics,
      false]
            (%o1) ["/tmp/sin.gnuplot"]
     In this example, gnuplot_maxout_prt(file) is a function that takes the default file
     name, file. It constructs a full file name for the data file by interpolating a random 8-
     digit integer with a pad of zeros into the default file name. The directory is determined
     by maxima_tempdir (it is “/tmp” in this example).
            (%i1) gnuplot_maxout_prt(file) := block([beg,end],
                      [beg,end] : split(file,"."),
                      printf(false,"~a_~8,'0d.~a",beg,random(10^8-1),end)) $
          (%o2) ["/tmp/maxout68715_09606909.gnuplot"]
     By default, the script would have been saved in a file named maxoutXXXXX.gnuplot
     (XXXXX=68715 in this example).
238                                                                     Maxima 5.45.0 Manual
     characters such as ^ and are not printed, but interpreted as formatting characters.
     For a list of the formatting characters and their meaning, see the documentation for
     enhanced in Gnuplot. The default value for this option is false, which will not treat
     any characters as formatting characters.
gnuplot_close ()                                                               [Function]
     Closes the pipe to gnuplot which is used with the gnuplot_pipes format.
gnuplot_restart ()                                                          [Function]
     Closes the pipe to gnuplot which is used with the gnuplot_pipes format and opens
     a new pipe.
gnuplot_replot                                                                 [Function]
        gnuplot_replot ()
        gnuplot_replot (s)
     Updates the gnuplot window. If gnuplot_replot is called with a gnuplot command
     in a string s, then s is sent to gnuplot before reploting the window.
gnuplot_reset ()                                                         [Function]
     Resets the state of gnuplot used with the gnuplot_pipes format. To update the
     gnuplot window call gnuplot_replot after gnuplot_reset.
                                                                                          241
13.1 Comments
A comment in Maxima input is any text between /* and */.
   The Maxima parser treats a comment as whitespace for the purpose of finding tokens
in the input stream; a token always ends at a comment. An input such as a/* foo */b
contains two tokens, a and b, and not a single token ab. Comments are otherwise ignored
by Maxima; neither the content nor the location of comments is stored in parsed input
expressions.
   Comments can be nested to arbitrary depth. The /* and */ delimiters form matching
pairs. There must be the same number of /* as there are */.
   Examples:
      (%i1)   /* aa is a variable of interest */ aa : 1234;
      (%o1)                           1234
      (%i2)   /* Value of bb depends on aa */ bb : aa^2;
      (%o2)                          1522756
      (%i3)   /* User-defined infix operator */ infix ("b");
      (%o3)                             b
      (%i4)   /* Parses same as a b c, not abc */ a/* foo */b/* bar */c;
      (%o4)                           a b c
      (%i5)   /* Comments /* can be nested /* to any depth */ */ */ 1 + xyz;
      (%o5)                          xyz + 1
13.2 Files
A file is simply an area on a particular storage device which contains data or text. Files
on the disks are figuratively grouped into "directories". A directory is just a list of files.
Commands which deal with files are:
   appendfile                batch                       batchload
   closefile                 file_output_append          filename_merge
   file_search               file_search_maxima          file_search_lisp
   file_search_demo          file_search_usage           file_search_tests
   file_type                 file_type_lisp              file_type_maxima
   load                      load_pathname               loadfile
   loadprint                 pathname_directory          pathname_name
   pathname_type             printfile                   save
   stringout                 with_stdout                 writefile
   When a file name is passed to functions like plot2d, save, or writefile and the file
name does not include a path, Maxima stores the file in the current working directory.
The current working directory depends on the system like Windows or Linux and on the
installation.
242                                                                  Maxima 5.45.0 Manual
     The special variable % and the function %th refer to previous results from the interac-
     tive interpreter, not results within the file. The file cannot include :lisp constructs.
     batchload returns the path of filename, as a string. batchload evaluates its argu-
     ment.
     See also batch, and load.
closefile ()                                                                       [Function]
     Closes the transcript file opened by writefile or appendfile.
file_search                                                                        [Function]
        file_search (filename)
        file_search (filename, pathlist)
     file_search searches for the file filename and returns the path to the file (as a string)
     if it can be found; otherwise file_search returns false. file_search (filename)
     searches in the default search directories, which are specified by the file_search_
     maxima, file_search_lisp, and file_search_demo variables.
     file_search first checks if the actual name passed exists, before attempting to match
     it to “wildcard” file search patterns. See file_search_maxima concerning file search
     patterns.
     The argument filename can be a path and file name, or just a file name, or, if a file
     search directory includes a file search pattern, just the base of the file name (without
     an extension). For example,
             file_search ("/home/wfs/special/zeta.mac");
             file_search ("zeta.mac");
             file_search ("zeta");
     all find the same file, assuming the file exists and /home/wfs/special/###.mac is in
     file_search_maxima.
     file_search (filename, pathlist) searches only in the directories specified by
     pathlist, which is a list of strings. The argument pathlist supersedes the default
     search directories, so if the path list is given, file_search searches only the ones
244                                                                  Maxima 5.45.0 Manual
      specified, and not any of the default search directories. Even if there is only one
      directory in pathlist, it must still be given as an one-element list.
      The user may modify the default search directories. See file_search_maxima.
      file_search is invoked by load with file_search_maxima and file_search_lisp
      as the search directories.
file_search_maxima                                                          [Option variable]
file_search_lisp                                                            [Option variable]
file_search_demo                                                            [Option variable]
file_search_usage                                                           [Option variable]
file_search_tests                                                           [Option variable]
      These variables specify lists of directories to be searched by load, demo, and some
      other Maxima functions. The default values of these variables name various directories
      in the Maxima installation.
      The user can modify these variables, either to replace the default values or to append
      additional directories. For example,
            file_search_maxima: ["/usr/local/foo/###.mac",
                  "/usr/local/bar/###.mac"]$
      replaces the default value of file_search_maxima, while
            file_search_maxima: append (file_search_maxima,
                  ["/usr/local/foo/###.mac", "/usr/local/bar/###.mac"])$
      appends two additional directories. It may be convenient to put such an expression
      in the file maxima-init.mac so that the file search path is assigned automatically
      when Maxima starts. See also Section 32.1 [Introduction for Runtime Environment],
      page 557.
      Multiple filename extensions and multiple paths can be specified by special “wildcard”
      constructions. The string ### expands into the sought-after name, while a comma-
      separated list enclosed in curly braces {foo,bar,baz} expands into multiple strings.
      For example, supposing the sought-after name is neumann,
            "/home/{wfs,gcj}/###.{lisp,mac}"
      expands into /home/wfs/neumann.lisp, /home/gcj/neumann.lisp,
      /home/wfs/neumann.mac, and /home/gcj/neumann.mac.
file_type (filename)                                                          [Function]
      Returns a guess about the content of filename, based on the filename extension.
      filename need not refer to an actual file; no attempt is made to open the file and
      inspect the content.
      The return value is a symbol, either object, lisp, or maxima. If the extension is
      matches one of the values in file_type_maxima, file_type returns maxima. If the
      extension matches one of the values in file_type_lisp, file_type returns lisp. If
      none of the above, file_type returns object.
      See also pathname_type.
      See file_type_maxima and file_type_lisp for the default values.
      Examples:
            (%i2) map('file_type,
Chapter 13: File Input and Output                                                        245
stringout                                                                          [Function]
        stringout      (filename, expr_1, expr_2, expr_3, . . . )
        stringout      (filename, [m, n])
        stringout      (filename, input)
        stringout      (filename, functions)
        stringout      (filename, values)
      stringout writes expressions to a file in the same form the expressions would be
      typed for input. The file can then be used as input for the batch or demo commands,
      and it may be edited for any purpose. stringout can be executed while writefile
      is in progress.
      The global flag file_output_append governs whether stringout appends or trun-
      cates the output file. When file_output_append is true, stringout appends to
      the output file. Otherwise, stringout truncates the output file. In either case,
      stringout creates the file if it does not yet exist.
      The general form of stringout writes the values of one or more expressions to the
      output file. Note that if an expression is a variable, only the value of the variable is
      written and not the name of the variable. As an useful special case, the expressions
      may be input labels (%i1, %i2, %i3, . . . ) or output labels (%o1, %o2, %o3, . . . ).
      If grind is true, stringout formats the output using the grind format. Otherwise
      the string format is used. See grind and string.
      The special form stringout (filename, [m, n]) writes the values of input labels m
      through n, inclusive.
      The special form stringout (filename, input) writes all input labels to the file.
      The special form stringout (filename, functions) writes all user-defined func-
      tions (named by the global list functions)) to the file.
      The special form stringout (filename, values) writes all user-assigned variables
      (named by the global list values)) to the file. Each variable is printed as an assign-
      ment statement, with the name of the variable, a colon, and its value. Note that the
      general form of stringout does not print variables as assignment statements.
with_stdout                                                                        [Function]
        with_stdout (f, expr_1, expr_2, expr_3, . . . )
        with_stdout (s, expr_1, expr_2, expr_3, . . . )
      Evaluates expr 1, expr 2, expr 3, . . . and writes any output thus generated to a file f
      or output stream s. The evaluated expressions are not written to the output. Output
      may be generated by print, display, grind, among other functions.
      The global flag file_output_append governs whether with_stdout appends or trun-
      cates the output file f. When file_output_append is true, with_stdout appends
      to the output file. Otherwise, with_stdout truncates the output file. In either case,
      with_stdout creates the file if it does not yet exist.
      with_stdout returns the value of its final argument.
      See also writefile and display2d.
            (%i1) with_stdout ("tmp.out", for i:5 thru 10 do
Chapter 13: File Input and Output                                                        249
      tex (expr, false) and tex (label, false) return their TeX output as a string.
      tex evaluates its first argument after testing it to see if it is a label. Quote-quote
      '' forces evaluation of the argument, thereby defeating the test and preventing the
      label.
      See also tex1 and texput.
      Examples:
             (%i1) integrate (1/(1+x^3), x);
                                                        2 x - 1
                                  2               atan(-------)
                             log(x - x + 1)             sqrt(3)        log(x + 1)
             (%o1)        - --------------- + ------------- + ----------
                                    6                sqrt(3)                3
             (%i2) tex (%o1);
             $$-{{\log \left(x^2-x+1\right)}\over{6}}+{{\arctan \left({{2\,x-1
              }\over{\sqrt{3}}}\right)}\over{\sqrt{3}}}+{{\log \left(x+1\right)
              }\over{3}}\leqno{\tt (\%o1)}$$
             (%o2)                                (\%o1)
             (%i3) tex (integrate (sin(x), x));
             $$-\cos x$$
             (%o3)                                 false
             (%i4) tex (%o1, "foo.tex");
             (%o4)                                (\%o1)
      tex (expr, false) returns its TeX output as a string.
             (%i1) S : tex (x * y * z, false);
             (%o1) $$x\,y\,z$$
             (%i2) S;
             (%o2) $$x\,y\,z$$
tex1 (e)                                                                        [Function]
      Returns a string which represents the TeX output for the expressions e. The TeX
      output is not enclosed in delimiters for an equation or any other environment.
      See also tex and texput.
      Examples:
            (%i1) tex1 (sin(x) + cos(x));
            (%o1)                           \sin x+\cos x
texput                                                                           [Function]
           texput    (a, s)
           texput    (a, f)
           texput    (a, s, operator_type)
           texput    (a, [s_1, s_2], matchfix)
           texput    (a, [s_1, s_2, s_3], matchfix)
      Assign the TeX output for the atom a, which can be a symbol or the name of an
      operator.
      texput (a, s) causes the tex function to interpolate the string s into the TeX output
      in place of a.
Chapter 13: File Input and Output                                                     251
     texput (a, f) causes the tex function to call the function f to generate TeX output.
     f must accept one argument, which is an expression which has operator a, and must
     return a string (the TeX output). f may call tex1 to generate TeX output for the
     arguments of the input expression.
     texput (a, s, operator_type), where operator type is prefix, infix, postfix,
     nary, or nofix, causes the tex function to interpolate s into the TeX output in place
     of a, and to place the interpolated text in the appropriate position.
     texput (a, [s_1, s_2], matchfix) causes the tex function to interpolate s 1 and
     s 2 into the TeX output on either side of the arguments of a. The arguments (if more
     than one) are separated by commas.
     texput (a, [s_1, s_2, s_3], matchfix) causes the tex function to interpolate s 1
     and s 2 into the TeX output on either side of the arguments of a, with s 3 separating
     the arguments.
     See also tex and tex1.
     Examples:
     Assign TeX output for a variable.
           (%i1) texput (me,"\\mu_e");
           (%o1)                                \mu_e
           (%i2) tex (me);
           $$\mu_e$$
           (%o2)                                false
     Assign TeX output for an ordinary function (not an operator).
           (%i1) texput (lcm, "\\mathrm{lcm}");
           (%o1)                     \mathrm{lcm}
           (%i2) tex (lcm (a, b));
           $$\mathrm{lcm}\left(a , b\right)$$
           (%o2)                         false
     Call a function to generate TeX output.
           (%i1) texfoo (e) := block ([a, b], [a, b] : args (e),
             concat("\\left[\\stackrel{",tex1(b),"}{",tex1(a),"}\\right]"))$
           (%i2) texput (foo, texfoo);
           (%o2)                        texfoo
           (%i3) tex (foo (2^x, %pi));
           $$\left[\stackrel{\pi}{2^{x}}\right]$$
           (%o3)                         false
     Assign TeX output for a prefix operator.
           (%i1) prefix ("grad");
           (%o1)                         grad
           (%i2) texput ("grad", " \\nabla ", prefix);
           (%o2)                        \nabla
           (%i3) tex (grad f);
           $$ \nabla f$$
           (%o3)                         false
252                                                      Maxima 5.45.0 Manual
           \begin{verbatim}
           f(x):=1-x;
           \end{verbatim}
           (%o2)                         false
           (%i3) set_tex_environment (":=", "$$", "$$");
           (%o3)                       [$$, $$]
           (%i4) tex (f (x) := 1 - x);
           $$f(x):=1-x$$
           (%o4)                         false
get_tex_environment_default ()                                            [Function]
set_tex_environment_default (before, after)                               [Function]
     Customize the TeX environment output by tex. As maintained by these functions,
     the TeX environment comprises two strings: one is printed before any other TeX
     output, and the other is printed after.
     get_tex_environment_default returns the TeX environment which is applied to
     expressions for which the top-level operator has no specific TeX environment (as
     assigned by set_tex_environment).
254                                                                  Maxima 5.45.0 Manual
     Examples:
     (%i1) expr: (a + b)^12$
     (%i2) fortran (expr);
           (b+a)**12
     (%o2)                          done
     (%i3) fortran ('x=expr);
           x = (b+a)**12
     (%o3)                          done
     (%i4) fortran ('x=expand (expr));
           x = b**12+12*a*b**11+66*a**2*b**10+220*a**3*b**9+495*a**4*b**8+792
          1    *a**5*b**7+924*a**6*b**6+792*a**7*b**5+495*a**8*b**4+220*a**9*b
          2    **3+66*a**10*b**2+12*a**11*b+a**12
     (%o4)                          done
     (%i5) fortran ('x=7+5*%i);
           x = (7,5)
     (%o5)                          done
     (%i6) fortran ('x=[1,2,3,4]);
           x = [1,2,3,4]
     (%o6)                          done
     (%i7) f(x) := x^2$
     (%i8) fortran (f);
           f
     (%o8)                          done
14 Polynomials
     Examples:
     coeff returns the coefficient x^n in expr.
           (%i1) coeff (b^3*a^3 + b^2*a^2 + b*a + 1, a^3);
                                           3
           (%o1)                          b
     coeff(expr, x^n) is equivalent to coeff(expr, x, n).
           (%i1) coeff (c[4]*z^4 - c[3]*z^3 - c[2]*z^2 + c[1]*z, z, 3);
           (%o1)                         - c
                                            3
           (%i2) coeff (c[4]*z^4 - c[3]*z^3 - c[2]*z^2 + c[1]*z, z^3);
           (%o2)                         - c
                                            3
     coeff(expr, x, 0) returns the remainder of expr which is free of x.
           (%i1) coeff (a*u + b^2*u^2 + c^3*u^3, b, 0);
                                       3 3
           (%o1)                      c u + a u
     x may be a simple variable or a subscripted variable, or a subexpression of expr which
     comprises an operator and all of its arguments.
           (%i1) coeff (h^4 - 2*%pi*h^2 + 1, h, 2);
           (%o1)                        - 2 %pi
           (%i2) coeff (v[1]^4 - 2*%pi*v[1]^2 + 1, v[1], 2);
           (%o2)                        - 2 %pi
           (%i3) coeff (sin(1+x)*sin(x) + sin(1+x)^3*sin(x)^3, sin(1+x)^3);
                                           3
           (%o3)                        sin (x)
           (%i4) coeff ((d - a)^2*(b + c)^3 + (a + b)^4*(c - d), a + b, 4);
           (%o4)                         c - d
     coeff itself does not apply expand or factor or any other function.
           (%i1) coeff (c*(a + b)^3, a);
           (%o1)                            0
           (%i2) expand (c*(a + b)^3);
                            3          2        2        3
           (%o2)           b c + 3 a b c + 3 a b c + a c
           (%i3) coeff (%, a);
                                            2
           (%o3)                         3 b c
           (%i4) coeff (b^3*c + 3*a*b^2*c + 3*a^2*b*c + a^3*c, (a + b)^3);
           (%o4)                            0
           (%i5) factor (b^3*c + 3*a*b^2*c + 3*a^2*b*c + a^3*c);
                                              3
           (%o5)                      (b + a) c
           (%i6) coeff (%, (a + b)^3);
           (%o6)                            c
     coeff distributes over lists, matrices, and equations.
260                                                                   Maxima 5.45.0 Manual
                                                         3        2
                                                 - 5154 x - 1291 x + 7688 x + 15376]
(%o5) [2 x - 3, 3 x - 4 x + 1, 2 x - 4 x + 1, - 4 x + x + 1]
factor                                                                               [Function]
          factor (expr)
          factor (expr, p)
      Factors the expression expr, containing any number of variables or functions, into
      factors irreducible over the integers. factor (expr, p) factors expr over the field of
      rationals with an element adjoined whose minimum polynomial is p.
      factor uses ifactors function for factoring integers.
      factorflag if false suppresses the factoring of integer factors of rational expressions.
      dontfactor may be set to a list of variables with respect to which factoring is not
      to occur. (It is initially empty). Factoring also will not take place with respect to
      any variables which are less important (using the variable ordering assumed for CRE
      form) than those on the dontfactor list.
      savefactors if true causes the factors of an expression which is a product of factors
      to be saved by certain functions in order to speed up later factorizations of expressions
      containing some of the same factors.
      berlefact if false then the Kronecker factoring algorithm will be used otherwise
      the Berlekamp algorithm, which is the default, will be used.
      intfaclim if true maxima will give up factorization of integers if no factor is found
      after trial divisions and Pollard’s rho method. If set to false (this is the case when the
      user calls factor explicitly), complete factorization of the integer will be attempted.
      The user’s setting of intfaclim is used for internal calls to factor. Thus, intfaclim
      may be reset to prevent Maxima from taking an inordinately long time factoring large
      integers.
      factor_max_degree if set to a positive integer n will prevent certain polynomials
      from being factored if their degree in any variable exceeds n.
      See also collectterms and sqfr
      Examples:
            (%i1) factor (2^63 - 1);
                                2
            (%o1)              7 73 127 337 92737 649657
            (%i2) factor (-8*y - 4*x + z^2*(2*y + x));
            (%o2)               (2 y + x) (z - 2) (z + 2)
            (%i3) -1 - 2*x - x^2 + y^2 + 2*x*y^2 + x^2*y^2;
                            2 2         2    2    2
            (%o3)          x y + 2 x y + y - x - 2 x - 1
            (%i4) block ([dontfactor: [x]], factor (%/36/(1 + 2*y + y^2)));
Chapter 14: Polynomials                                               263
                                     2
                                   (x + 2 x + 1) (y - 1)
           (%o4)                   ----------------------
                                         36 (y + 1)
           (%i5)   factor (1 + %e^(3*x));
                                    x         2 x      x
           (%o5)                (%e + 1) (%e       - %e + 1)
           (%i6)   factor (1 + x^4, a^2 - 2);
                                 2               2
           (%o6)               (x - a x + 1) (x + a x + 1)
           (%i7)   factor (-y^2*z^2 - x*z^2 + x^2*y^2 + x^3);
                                     2
           (%o7)                - (y + x) (z - x) (z + x)
           (%i8)   (2 + x)/(3 + x)/(b + x)/(c + x)^2;
                                           x + 2
           (%o8)                 ------------------------
                                                         2
                                 (x + 3) (x + b) (x + c)
           (%i9)   ratsimp (%);
                             4                   3
           (%o9)   (x + 2)/(x + (2 c + b + 3) x
                2                      2            2                  2
            + (c + (2 b + 6) c + 3 b) x + ((b + 3) c + 6 b c) x + 3 b c )
           (%i10) partfrac (%, x);
                      2                  4               3
           (%o10) - (c - 4 c - b + 6)/((c + (- 2 b - 6) c
                2             2        2               2
            + (b + 12 b + 9) c + (- 6 b - 18 b) c + 9 b ) (x + c))
                            c - 2
            - ---------------------------------
                2                             2
              (c + (- b - 3) c + 3 b) (x + c)
                                    b - 2
            + -------------------------------------------------
                        2             2       3      2
              ((b - 3) c + (6 b - 2 b ) c + b - 3 b ) (x + b)
                                    1
            - ----------------------------------------------
                        2
              ((b - 3) c + (18 - 6 b) c + 9 b - 27) (x + 3)
           (%i11) map ('factor, %);
264                                                                                                     Maxima 5.45.0 Manual
                         2
                        c - 4 c - b + 6                  c - 2
           (%o11) - ------------------------- - ------------------------
                           2        2                                  2
                    (c - 3) (c - b) (x + c)     (c - 3) (c - b) (x + c)
                                        b - 2                        1
                             + ------------------------ - ------------------------
                                              2                          2
                               (b - 3) (c - b) (x + b)    (b - 3) (c - 3) (x + 3)
           (%i12)       ratsimp ((x^5 - 1)/(x - 1));
                                        4    3      2
           (%o12)                      x + x + x + x + 1
           (%i13)       subst (a, x, %);
                                        4    3      2
           (%o13)                      a + a + a + a + 1
           (%i14)       factor (%th(2), %);
                                        2         3       3    2
           (%o14)         (x - a) (x - a ) (x - a ) (x + a + a + a + 1)
           (%i15)       factor (1 + x^12);
                                        4         8     4
           (%o15)                     (x + 1) (x - x + 1)
           (%i16)       factor (1 + x^99);
                                  2             6     3
           (%o16)       (x + 1) (x - x + 1) (x - x + 1)
                  10         9         8         7         6         5         4         3         2
             (x        - x       + x       - x       + x       - x       + x       - x       + x       - x + 1)
                  20         19         17           16         14         13            11            10         9         7         6
             (x        + x        - x        - x          + x        + x           - x        - x           - x       + x       + x
                   4         3                        60         57            51         48           42          39           33
             - x       - x       + x + 1) (x               + x           - x        - x        + x           + x        - x
                   30         27           21         18         12            9         3
             - x        - x        + x          + x        - x           - x       + x       + 1)
     Example:
           (%i1) factor_max_degree : 100$
           (%i2) factor(x^100-1);
                                       2         4     3      2
           (%o2) (x - 1) (x + 1) (x + 1) (x - x + x - x + 1)
               4    3     2              8     6     4     2
            (x + x + x + x + 1) (x - x + x - x + 1)
               20     15     10     5         20     15      10    5
            (x    - x    + x    - x + 1) (x      + x     + x    + x + 1)
               40     30     20     10
            (x    - x    + x    - x    + 1)
           (%i3) factor(x^101-1);
                                               101
           Refusing to factor polynomial x         - 1
                            because its degree exceeds factor_max_degree (100)
                                             101
           (%o3)                            x    - 1
     See also: factor_max_degree_print_warning
factor_max_degree_print_warning                                       [Option variable]
     Default value: true
     When factor max degree print warning is true, then Maxima will print a warning
     message when the factoring of a polynomial is prevented because its degree exceeds
     the value of factor max degree.
     See also: factor_max_degree
factorflag                                                           [Option variable]
     Default value: false
     When factorflag is false, suppresses the factoring of integer factors of rational
     expressions.
factorout (expr, x_1, x_2, . . . )                                            [Function]
     Rearranges the sum expr into a sum of terms of the form f (x_1, x_2, ...)*g where
     g is a product of expressions not containing any x i and f is factored.
     Note that the option variable keepfloat is ignored by factorout.
     Example:
            (%i1) expand (a*(x+1)*(x-1)*(u+1)^2);
                           2 2              2       2       2
            (%o1)       a u x + 2 a u x + a x - a u - 2 a u - a
            (%i2) factorout(%,x);
                      2
            (%o2) a u (x - 1) (x + 1) + 2 a u (x - 1) (x + 1)
                                                                   + a (x - 1) (x + 1)
factorsum (expr)                                                                [Function]
     Tries to group terms in factors of expr which are sums into groups of terms such that
     their sum is factorable. factorsum can recover the result of expand ((x + y)^2 + (z
266                                                                  Maxima 5.45.0 Manual
      + w)^2) but it can’t recover expand ((x + 1)^2 + (x + y)^2) because the terms have
      variables in common.
      Example:
            (%i1) expand ((x + 1)*((u + v)^2 + a*(w + z)^2));
                       2      2                            2   2
            (%o1) a x z + a z + 2 a w x z + 2 a w z + a w x + v x
                                                      2       2   2           2
                                         + 2 u v x + u x + a w + v + 2 u v + u
            (%i2) factorsum (%);
                                                   2         2
            (%o2)                (x + 1) (a (z + w) + (v + u) )
                                (x   ) - 2 (x    ) + 1
           (%o4)/R/             -----------------------
                                         a
                                        x - 1
            (%o7)                                a         b
      See also lrats_max_iter and fullratsubstflag.
fullratsubstflag                                                          [Option variable]
      Default value: false
      An option variable that is set to true in fullratsubst.
gcd (p_1, p_2, x_1, . . . )                                                     [Function]
      Returns the greatest common divisor of p 1 and p 2. The flag gcd determines which
      algorithm is employed. Setting gcd to ez, subres, red, or spmod selects the ezgcd,
      subresultant prs, reduced, or modular algorithm, respectively. If gcd false then gcd
      (p_1, p_2, x) always returns 1 for all x. Many functions (e.g. ratsimp, factor, etc.)
      cause gcd’s to be taken implicitly. For homogeneous polynomials it is recommended
      that gcd equal to subres be used. To take the gcd when an algebraic is present, e.g.,
      gcd (x^2 - 2*sqrt(2)* x + 2, x - sqrt(2)), the option variable algebraic must
      be true and gcd must not be ez.
      The gcd flag, default: spmod, if false will also prevent the greatest common divisor
      from being taken when expressions are converted to canonical rational expression
      (CRE) form. This will sometimes speed the calculation if gcds are not required.
      See also ezgcd, gcdex, gcdivide, and poly_gcd.
      Example:
            (%i1) p1:6*x^3+19*x^2+19*x+6;
                                          3         2
            (%o1)                     6 x + 19 x + 19 x + 6
            (%i2) p2:6*x^5+13*x^4+12*x^3+13*x^2+6*x;
                                  5          4        3        2
            (%o2)             6 x + 13 x + 12 x + 13 x + 6 x
            (%i3) gcd(p1, p2);
                                               2
            (%o3)                           6 x + 13 x + 6
            (%i4) p1/gcd(p1, p2), ratsimp;
            (%o4)                                 x + 1
            (%i5) p2/gcd(p1, p2), ratsimp;
                                                  3
            (%o5)                                x + x
      ezgcd returns a list whose first element is the greatest common divisor of the poly-
      nomials p 1 and p 2, and whose remaining elements are the polynomials divided by
      the greatest common divisor.
            (%i6) ezgcd(p1, p2);
                                    2                          3
            (%o6)              [6 x + 13 x + 6, x + 1, x + x]
gcdex                                                                           [Function]
          gcdex (f, g)
          gcdex (f, g, x)
      Returns a list [a, b, u] where u is the greatest common divisor (gcd) of f and g, and
      u is equal to a f + b g. The arguments f and g should be univariate polynomials,
Chapter 14: Polynomials                                                                269
      Examples:
            (%i1)   hipow (y^3 * x^2 + x * y^4, x);
            (%o1)                             2
            (%i2)   hipow ((x + y)^5, x);
            (%o2)                             1
            (%i3)   hipow (expand ((x + y)^5), x);
            (%o3)                             5
            (%i4)   hipow ((x + y)^5, x + y);
            (%o4)                             5
            (%i5)   hipow (expand ((x + y)^5), x + y);
            (%o5)                             0
                                                 2
           (%o5)                               a c
           (%i6) lratsubst ([[a^2=b*a, b=c],[a=b]], a^3);
                                            2
           lratsubst: improper argument: [[a = a b, b = c], [a = b]]
           #0: lratsubst(listofeqns=[[a^2 = a*b,b = c],[a = b]],expr=a^3)
            -- an error. To debug this try: debugmode(true);
           (%i3) g2:sin(x)/10*cos(x)/y;
                                     cos(x) sin(x)
           (%o3)                     -------------
                                         10 y
           (%i4) num(g2);
           (%o4)                     cos(x) sin(x)
polymod                                                                           [Function]
          polymod (p)
          polymod (p, m)
      Converts the polynomial p to a modular representation with respect to the current
      modulus which is the value of the variable modulus.
      polymod (p, m) specifies a modulus m to be used instead of the current value of
      modulus.
      See modulus.
polynomialp                                                                       [Function]
        polynomialp (p, L, coeffp, exponp)
        polynomialp (p, L, coeffp)
        polynomialp (p, L)
      Return true if p is a polynomial in the variables in the list L. The predicate coeffp
      must evaluate to true for each coefficient, and the predicate exponp must evaluate
      to true for all exponents of the variables in L. If you want to use a non-default value
      for exponp, you must supply coeffp with a value even if you want to use the default
      for coeffp.
      The command polynomialp (p, L, coeffp) is equivalent to polynomialp (p, L,
      coeffp, 'nonnegintegerp) and the command polynomialp (p, L) is equivalent to
      polynomialp (p, L, 'constantp, 'nonnegintegerp).
      The polynomial needn’t be expanded:
            (%i1) polynomialp ((x + 1)*(x + 2), [x]);
            (%o1)                         true
            (%i2) polynomialp ((x + 1)*(x + 2)^a, [x]);
            (%o2)                         false
      An example using non-default values for coeffp and exponp:
            (%i1) polynomialp ((x + 1)*(x + 2)^(3/2), [x], numberp, numberp);
            (%o1)                         true
            (%i2) polynomialp ((x^(1/2) + 1)*(x + 2)^(3/2), [x], numberp,
                                                                    numberp);
            (%o2)                         true
      Polynomials with two variables:
            (%i1) polynomialp (x^2 + 5*x*y + y^2, [x]);
            (%o1)                         false
            (%i2) polynomialp (x^2 + 5*x*y + y^2, [x, y]);
            (%o2)                         true
quotient                                                                          [Function]
        quotient (p_1, p_2)
        quotient (p_1, p_2, x_1, . . . , x_n)
      Returns the polynomial p 1 divided by the polynomial p 2. The arguments x 1, . . . ,
      x n are interpreted as in ratvars.
      quotient returns the first element of the two-element list returned by divide.
Chapter 14: Polynomials                                                                  275
rat                                                                               [Function]
          rat (expr)
          rat (expr, x_1, . . . , x_n)
      Converts expr to canonical rational expression (CRE) form by expanding and com-
      bining all terms over a common denominator and cancelling out the greatest common
      divisor of the numerator and denominator, as well as converting floating point num-
      bers to rational numbers within a tolerance of ratepsilon. The variables are ordered
      according to the x 1, . . . , x n, if specified, as in ratvars.
      rat does not generally simplify functions other than addition +, subtraction -, mul-
      tiplication *, division /, and exponentiation to an integer power, whereas ratsimp
      does handle those cases. Note that atoms (numbers and variables) in CRE form are
      not the same as they are in the general form. For example, rat(x)- x yields rat(0)
      which has a different internal representation than 0.
      When ratfac is true, rat yields a partially factored form for CRE. During rational
      operations the expression is maintained as fully factored as possible without an actual
      call to the factor package. This should always save space and may save some time
      in some computations. The numerator and denominator are still made relatively
      prime (e.g., rat((x^2 - 1)^4/(x + 1)^2) yields (x - 1)^4 (x + 1)^2 when ratfac
      is true), but the factors within each part may not be relatively prime.
      ratprint if false suppresses the printout of the message informing the user of the
      conversion of floating point numbers to rational numbers.
      keepfloat if true prevents floating point numbers from being converted to rational
      numbers.
      See also ratexpand and ratsimp.
      Examples:
            (%i1) ((x - 2*y)^4/(x^2 - 4*y^2)^2 + 1)*(y + a)*(2*y + x) /
                  (4*y^2 + x^2);
                                                       4
                                              (x - 2 y)
                          (y + a) (2 y + x) (------------ + 1)
                                               2      2 2
                                             (x - 4 y )
            (%o1)         ------------------------------------
                                          2    2
                                       4 y + x
            (%i2) rat (%, y, a, x);
                                        2 a + 2 y
            (%o2)/R/                    ---------
                                         x + 2 y
ratcoef                                                                           [Function]
          ratcoef (expr, x, n)
          ratcoef (expr, x)
      Returns the coefficient of the expression x^n in the expression expr. If omitted, n is
      assumed to be 1.
      The return value is free (except possibly in a non-rational sense) of the variables in
      x. If no coefficient of this type exists, 0 is returned.
      ratcoef expands and rationally simplifies its first argument and thus it may produce
      answers different from those of coeff which is purely syntactic. Thus ratcoef ((x +
      1)/y + x, x) returns (y + 1)/y whereas coeff returns 1.
      ratcoef (expr, x, 0), viewing expr as a sum, returns a sum of those terms which
      do not contain x. Therefore if x occurs to any negative powers, ratcoef should not
      be used.
      Since expr is rationally simplified before it is examined, coefficients may not appear
      quite the way they were envisioned.
      Example:
             (%i1) s: a*x + b*x + 5$
             (%i2) ratcoef (s, a + b);
             (%o2)                                     x
                                    2
                                   x           x         1
           (%o3)                 ------ + ------ + ------
                                  2          2          2
                                 y + 7      y + 7      y + 7
           (%i4)   ratdenomdivide: false$
           (%i5)   ratexpand (expr);
                                          2
                                        x + x + 1
           (%o5)                         ----------
                                             2
                                           y + 7
           (%i6)   expr2: a^2/(b^2 + 3) + b/(b^2 + 3);
                                                     2
                                        b           a
           (%o6)                      ------ + ------
                                       2           2
                                      b + 3      b + 3
           (%i7)   ratexpand (expr2);
                                                 2
                                           b + a
           (%o7)                            ------
                                             2
                                           b + 3
                                            10          5
                                     x   + 10 x + 25
            (%i3) expr: f(x)^3 - f(x)^2 + 7;
                                     3       2
            (%o3)                   f (x) - f (x) + 7
            (%i4) ratdiff (expr, f(x));
                                       2
            (%o4)                   3 f (x) - 2 f(x)
            (%i5) expr: (a + b)^3 + (a + b)^2;
                                          3          2
            (%o5)                  (b + a) + (b + a)
            (%i6) ratdiff (expr, a + b);
                                2                    2
            (%o6)            3 b + (6 a + 2) b + 3 a + 2 a
ratdisrep (expr)                                                                [Function]
      Returns its argument as a general expression. If expr is a general expression, it is
      returned unchanged.
      Typically ratdisrep is called to convert a canonical rational expression (CRE) into
      a general expression. This is sometimes convenient if one wishes to stop the "conta-
      gion", or use rational functions in non-rational contexts.
      See also totaldisrep.
ratexpand (expr)                                                                    [Function]
ratexpand                                                                   [Option variable]
      Expands expr by multiplying out products of sums and exponentiated sums, com-
      bining fractions over a common denominator, cancelling the greatest common divisor
      of the numerator and denominator, then splitting the numerator (if a sum) into its
      respective terms divided by the denominator.
      The return value of ratexpand is a general expression, even if expr is a canonical
      rational expression (CRE).
      The switch ratexpand if true will cause CRE expressions to be fully expanded when
      they are converted back to general form or displayed, while if it is false then they
      will be put into a recursive form. See also ratsimp.
      When ratdenomdivide is true, ratexpand expands a ratio in which the numerator is
      a sum into a sum of ratios, all having a common denominator. Otherwise, ratexpand
      collapses a sum of ratios into a single ratio, the numerator of which is the sum of the
      numerators of each ratio.
      When keepfloat is true, prevents floating point numbers from being rationalized
      when expressions which contain them are converted to canonical rational expression
      (CRE) form.
      Examples:
            (%i1) ratexpand ((2*x - 3*y)^3);
                                       3            2        2          3
            (%o1)              - 27 y + 54 x y - 36 x y + 8 x
            (%i2) expr: (x - 1)/(x + 1)^2 + 1/(x - 1);
Chapter 14: Polynomials                                                                 279
                                         x - 1       1
           (%o2)                        -------- + -----
                                                2  x - 1
                                        (x + 1)
           (%i3) expand (expr);
                               x              1           1
           (%o3)          ------------ - ------------ + -----
                           2              2             x - 1
                          x + 2 x + 1    x + 2 x + 1
           (%i4) ratexpand (expr);
                                    2
                                2 x                 2
           (%o4)           --------------- + ---------------
                             3   2            3    2
                           x + x - x - 1     x + x - x - 1
            (%i2) rat(2*x+y^2);
                                                2
            (%o2)/R/                           y + 2 x
            (%i3) :lisp varlist
            ($X $Y)
            (%i3) rat(2*a+b^2);
                                                2
            (%o3)/R/                           b + 2 a
            (%i5) rat(2*x+y^2);
                                                2
            (%o5)/R/                           y + 2 x
            (%i6) :lisp varlist
            ($X $Y)
            (%i6) rat(2*a+b^2);
                                                2
            (%o6)/R/                           b + 2 a
Chapter 14: Polynomials                                                               283
ratweight                                                                      [Function]
        ratweight (x_1, w_1, . . . , x_n, w_n)
        ratweight ()
     Assigns a weight w i to the variable x i. This causes a term to be replaced by 0 if
     its weight exceeds the value of the variable ratwtlvl (default yields no truncation).
     The weight of a term is the sum of the products of the weight of a variable in the
     term times its power. For example, the weight of 3 x_1^2 x_2 is 2 w_1 + w_2. Trun-
     cation according to ratwtlvl is carried out only when multiplying or exponentiating
     canonical rational expressions (CRE).
     ratweight () returns the cumulative list of weight assignments.
     Note: The ratfac and ratweight schemes are incompatible and may not both be
     used at the same time.
     Examples:
           (%i1) ratweight (a, 1, b, 1);
           (%o1)                     [a, 1, b, 1]
           (%i2) expr1: rat(a + b + 1)$
           (%i3) expr1^2;
                             2                  2
           (%o3)/R/         b + (2 a + 2) b + a + 2 a + 1
           (%i4) ratwtlvl: 1$
           (%i5) expr1^2;
           (%o5)/R/                  2 b + 2 a + 1
remainder                                                                      [Function]
        remainder (p_1, p_2)
        remainder (p_1, p_2, x_1, . . . , x_n)
     Returns the remainder of the polynomial p 1 divided by the polynomial p 2. The
     arguments x 1, . . . , x n are interpreted as in ratvars.
     remainder returns the second element of the two-element list returned by divide.
284                                                                   Maxima 5.45.0 Manual
tellrat                                                                          [Function]
          tellrat (p_1, . . . , p_n)
          tellrat ()
     Adds to the ring of algebraic integers known to Maxima the elements which are the
     solutions of the polynomials p 1, . . . , p n. Each argument p i is a polynomial with
     integer coefficients.
     tellrat (x) effectively means substitute 0 for x in rational functions.
     tellrat () returns a list of the current substitutions.
     algebraic must be set to true in order for the simplification of algebraic integers to
     take effect.
     Maxima initially knows about the imaginary unit %i and all roots of integers.
     There is a command untellrat which takes kernels and removes tellrat properties.
     When tellrat’ing a multivariate polynomial, e.g., tellrat (x^2 - y^2), there would
     be an ambiguity as to whether to substitute y^2 for x^2 or vice versa. Maxima picks
     a particular ordering, but if the user wants to specify which, e.g. tellrat (y^2 =
     x^2) provides a syntax which says replace y^2 by x^2.
     Examples:
           (%i1) 10*(%i + 1)/(%i + 3^(1/3));
                                               10 (%i + 1)
           (%o1)                               -----------
                                                      1/3
                                                %i + 3
           (%i2) ev (ratdisrep (rat(%)), algebraic);
                           2/3        1/3                   2/3       1/3
           (%o2)       (4 3    - 2 3         - 4) %i + 2 3      + 4 3      - 2
           (%i3) tellrat (1 + a + a^2);
                                                2
           (%o3)                             [a + a + 1]
           (%i4) 1/(a*sqrt(2) - 1) + a/(sqrt(3) + sqrt(2));
286                                                                Maxima 5.45.0 Manual
                                    1                  a
            (%o4)             ------------- + -----------------
                              sqrt(2) a - 1    sqrt(3) + sqrt(2)
            (%i5)   ev (ratdisrep (rat(%)), algebraic);
                       (7 sqrt(3) - 10 sqrt(2) + 2) a - 2 sqrt(2) - 1
            (%o5)      ----------------------------------------------
                                             7
            (%i6)   tellrat (y^2 = x^2);
                                      2    2    2
            (%o6)                   [y - x , a + a + 1]
15 Special Functions
                                    ∞     k       z v+2 k
                                                    
                                    X (−1)        2
                                    k=0
                                          k! Γ (v + k + 1)
                               ∞                      v+2 k
                               X           1        z
                               k=0
                                   k! Γ (v + k + 1) 2
     Numerical evaluation:
           (%i1) hankel_1(1,0.5);
           (%o1)          0.24226845767487 - 1.471472392670243 %i
           (%i2) hankel_1(1,0.5+%i);
           (%o2)        - 0.25582879948621 %i - 0.23957560188301
     Expansion of hankel_1 when besselexpand is true:
           (%i1) hankel_1(1/2,z),besselexpand:true;
                            sqrt(2) sin(z) - sqrt(2) %i cos(z)
           (%o1)            ----------------------------------
                                     sqrt(%pi) sqrt(z)
     Derivative of hankel_1 wrt the argument z. The derivative wrt the order v is not
     supported. Maxima returns a noun form:
           (%i1) diff(hankel_1(v,z),z);
                          hankel_1(v - 1, z) - hankel_1(v + 1, z)
           (%o1)          ---------------------------------------
                                              2
           (%i2) diff(hankel_1(v,z),v);
                                     d
           (%o2)                     -- (hankel_1(v, z))
                                     dv
     Maxima simplifies gamma for positive integer and positive and negative rational num-
     bers. For half integral values the result is a rational number times sqrt(%pi).
     The simplification for integer values is controlled by factlim. For integers greater
     than factlim the numerical result of the factorial function, which is used to calcu-
     late gamma, will overflow. The simplification for rational numbers is controlled by
     gammalim to avoid internal overflow. See factlim and gammalim.
     For negative integers gamma is not defined.
     Maxima can evaluate gamma numerically for real and complex values in float and
     bigfloat precision.
     gamma has mirror symmetry.
     When gamma_expand is true, Maxima expands gamma for arguments z+n and z-n
     where n is an integer.
     Maxima knows the derivate of gamma.
     Examples:
     Simplification for integer, half integral, and rational numbers:
            (%i1) map('gamma,[1,2,3,4,5,6,7,8,9]);
            (%o1)           [1, 1, 2, 6, 24, 120, 720, 5040, 40320]
            (%i2) map('gamma,[1/2,3/2,5/2,7/2]);
                                     sqrt(%pi) 3 sqrt(%pi) 15 sqrt(%pi)
            (%o2)     [sqrt(%pi), ---------, -----------, ------------]
292                                                                  Maxima 5.45.0 Manual
                                   2                            4      8
           (%i3) map('gamma,[2/3,5/3,7/3]);
                                                2           1
                                        2 gamma(-) 4 gamma(-)
                                    2           3           3
           (%o3)             [gamma(-), ----------, ----------]
                                    3       3           9
      Numerical evaluation for real and complex values:
           (%i4) map('gamma,[2.5,2.5b0]);
           (%o4)     [1.329340388179137, 1.3293403881791370205b0]
           (%i5) map('gamma,[1.0+%i,1.0b0+%i]);
           (%o5) [0.498015668118356 - .1549498283018107 %i,
                     4.9801566811835604272b-1 - 1.5494982830181068513b-1 %i]
      gamma has mirror symmetry:
           (%i6) declare(z,complex)$
           (%i7) conjugate(gamma(z));
           (%o7)                  gamma(conjugate(z))
      Maxima expands gamma(z+n) and gamma(z-n), when gamma_expand is true:
           (%i8) gamma_expand:true$
           (%i9) [gamma(z+1),gamma(z-1),gamma(z+2)/gamma(z+1)];
                                          gamma(z)
           (%o9)             [z gamma(z), --------, z + 1]
                                           z - 1
      The deriviative of gamma:
           (%i10) diff(gamma(z),z);
           (%o10)                  psi (z) gamma(z)
                                      0
      See also makegamma.
      The Euler-Mascheroni constant is %gamma.
                                               Z    ∞
                                  Γ (a, z) =            ta−1 e−t dt
                                                z
                                                        Γ (a, z)
                                      Q (a, z) =
                                                         Γ (a)
            (%i6) gamma_incomplete(a+2,z);
                         a               - z
            (%o6)       z (z + a + 1) %e     + a (a + 1) gamma_incomplete(a, z)
            (%i7) gamma_incomplete(a-2, z);
                    gamma_incomplete(a, z)    a - 2         z            1      - z
            (%o7)   ---------------------- - z      (--------------- + -----) %e
                       (1 - a) (2 - a)               (a - 2) (a - 1)   a - 2
           (%i9) beta(2.5,1.4+%i);
           (%o9) 0.0640144950796695 - .1502078053286415 %i
           (%i10) beta(2.5b0,2.3b0);
           (%o10) 8.694748611299969b-2
           (%i11) beta(2.5b0,1.4b0+%i);
           (%o11) 6.401449507966944b-2 - 1.502078053286415b-1 %i
     Beta is symmetric and has mirror symmetry:
           (%i14) beta(a,b)-beta(b,a);
           (%o14)                                 0
           (%i15) declare(a,complex,b,complex)$
296                                                                Maxima 5.45.0 Manual
            (%i16) conjugate(beta(a,b));
            (%o16)                 beta(conjugate(a), conjugate(b))
      The derivative of the beta function wrt a:
            (%i17) diff(beta(a,b),a);
            (%o17)               - beta(a, b) (psi (b + a) - psi (a))
                                                  0             0
           (%i24) beta_incomplete(a-1,b,z),beta_expand:true;
                                                                  b a - 1
                  beta_incomplete(a, b, z) (- b - a + 1)   (1 - z) z
           (%o24) -------------------------------------- - ---------------
                                  1 - a                         1 - a
      Derivative and integral for beta_incomplete:
           (%i34) diff(beta_incomplete(a, b, z), z);
                                         b - 1 a - 1
           (%o34)                 (1 - z)      z
           (%i35) integrate(beta_incomplete(a, b, z), z);
                         b a
                  (1 - z) z
           (%o35) ----------- + beta_incomplete(a, b, z) z
                     b + a
                                                  a beta_incomplete(a, b, z)
                                                - --------------------------
                                                            b + a
           (%i36) factor(diff(%, z));
           (%o36)              beta_incomplete(a, b, z)
           (%i2) beta_incomplete_regularized(a,2,z);
                                                               a
           (%o2)                              (a (1 - z) + 1) z
           (%i3) beta_incomplete_regularized(3,2,z);
                                                                  3
           (%o3)                               (3 (1 - z) + 1) z
     For the specific values z = 0 and z = 1, Maxima simplifies:
           (%i4) assume(a>0,b>0)$
           (%i5) beta_incomplete_regularized(a,b,0);
           (%o5)                                        0
           (%i6) beta_incomplete_regularized(a,b,1);
           (%o6)                                        1
     Numerical evaluation for real and complex arguments in float and bigfloat precision:
           (%i7) beta_incomplete_regularized(0.12,0.43,0.9);
           (%o7)                               .9114011367359802
           (%i8) fpprec:32$
           (%i9) beta_incomplete_regularized(0.12,0.43,0.9b0);
           (%o9)                    9.1140113673598075519946998779975b-1
           (%i10) beta_incomplete_regularized(1+%i,3/3,1.5*%i);
           (%o10)                  .2865367499935403 %i - 0.122995963334684
           (%i11) fpprec:20$
           (%i12) beta_incomplete_regularized(1+%i,3/3,1.5b0*%i);
           (%o12)         2.8653674999354036142b-1 %i - 1.2299596333468400163b-1
     Expansion, when beta_expand is true:
           (%i13) beta_incomplete_regularized(a+1,b,z);
                                                                         b a
                                                                 (1 - z) z
           (%o13) beta_incomplete_regularized(a, b, z) - ------------
                                                                 a beta(a, b)
           (%i14) beta_incomplete_regularized(a-1,b,z);
           (%o14) beta_incomplete_regularized(a, b, z)
                                                                         b a - 1
                                                                 (1 - z) z
                                                           - ----------------------
300                                                                 Maxima 5.45.0 Manual
                                                                beta(a, b) (b + a - 1)
      The derivative and the integral wrt z:
            (%i15) diff(beta_incomplete_regularized(a,b,z),z);
                                          b - 1 a - 1
                                   (1 - z)      z
            (%o15)                 -------------------
                                       beta(a, b)
            (%i16) integrate(beta_incomplete_regularized(a,b,z),z);
            (%o16) beta_incomplete_regularized(a, b, z) z
                                                                        b a
                                                                 (1 - z) z
                       a (beta_incomplete_regularized(a, b, z) - ------------)
                                                                 a beta(a, b)
                     - -------------------------------------------------------
                                                b + a
                                         a                      a
                      (a (1 - z2) + 1) z2 - (a (1 - z1) + 1) z1
           (%o2)      -------------------------------------------
                                       a (a + 1)
           (%i3) beta_incomplete_generalized(3,2,z1,z2);
                         2      2                       2      2
                 (1 - z1) (3 z1 + 2 z1 + 1) - (1 - z2) (3 z2 + 2 z2 + 1)
           (%o3) -----------------------------------------------------------
                                             12
     Simplification for specific values z1 = 0, z2 = 0, z1 = 1, or z2 = 1:
           (%i4) assume(a > 0, b > 0)$
           (%i5) beta_incomplete_generalized(a,b,z1,0);
           (%o5)                    - beta_incomplete(a, b, z1)
           (%i6) beta_incomplete_generalized(a,b,0,z2);
           (%o6)                    - beta_incomplete(a, b, z2)
           (%i7) beta_incomplete_generalized(a,b,z1,1);
           (%o7)              beta(a, b) - beta_incomplete(a, b, z1)
           (%i8) beta_incomplete_generalized(a,b,1,z2);
           (%o8)              beta_incomplete(a, b, z2) - beta(a, b)
     Numerical evaluation for real arguments in float or bigfloat precision:
           (%i9) beta_incomplete_generalized(1/2,3/2,0.25,0.31);
           (%o9)                        .09638178086368676
           (%i10) fpprec:32$
           (%i10) beta_incomplete_generalized(1/2,3/2,0.25,0.31b0);
           (%o10)               9.6381780863686935309170054689964b-2
     Numerical evaluation for complex arguments in float or bigfloat precision:
           (%i11) beta_incomplete_generalized(1/2+%i,3/2+%i,0.25,0.31);
           (%o11)           - .09625463003205376 %i - .003323847735353769
           (%i12) fpprec:20$
           (%i13) beta_incomplete_generalized(1/2+%i,3/2+%i,0.25,0.31b0);
           (%o13)     - 9.6254630032054178691b-2 %i - 3.3238477353543591914b-3
     Expansion for a + n or a − n, n a positive integer, when beta_expand is true:
           (%i14) beta_expand:true$
(%i15) beta_incomplete_generalized(a+1,b,z1,z2);
                          b   a           b   a
                  (1 - z1) z1 - (1 - z2) z2
           (%o15) -----------------------------
                              b + a
                                 a beta_incomplete_generalized(a, b, z1, z2)
302                                                                 Maxima 5.45.0 Manual
                                 + -------------------------------------------
                                                      b + a
             (%i16) beta_incomplete_generalized(a-1,b,z1,z2);
                                                  ∞
                                                      e−t
                                              Z
                                   E1 (z) =               dt
                                              z        t
     with | arg z| < π.
(%i7) gamma_expand:true$
           radcan(specint((cos(t)*expintegral_si(t)
                                -sin(t)*expintegral_ci(t))*%e^(-s*t),t));
                                        log(s)
           (%o8)                        ------
                                         2
                                        s + 1
           ratsimp(specint((2*t*log(a)+2/a*sin(a*t)
                                 -2*t*expintegral_ci(a*t))*%e^(-s*t),t));
                                           2   2
                                     log(s + a )
           (%o9)                     ------------
                                            2
                                           s
      Results when using the expansion of gamma_incomplete and when changing the rep-
      resentation to expintegral_e1:
           (%i10) assume(s>0)$
           (%i11) specint(1/sqrt(%pi*t)*unit_step(t-k)*%e^(-s*t),t);
                                                       1
                                       gamma_incomplete(-, k s)
                                                       2
           (%o11)                      ------------------------
                                          sqrt(%pi) sqrt(s)
           (%i12) gamma_expand:true$
           (%i13) specint(1/sqrt(%pi*t)*unit_step(t-k)*%e^(-s*t),t);
                                         erfc(sqrt(k) sqrt(s))
           (%o13)                        ---------------------
                                                sqrt(s)
Chapter 15: Special Functions                                                         309
           (%i14) expintrep:expintegral_e1$
           (%i15) ratsimp(specint(1/(t+a)^2*%e^(-s*t),t));
                                         a s
                                   a s %e    expintegral_e1(a s) - 1
           (%o15)                - ---------------------------------
                                                   a
                                     v/2                                %i z
                                   4     bessel_j(v, z) gamma(v + 1) %e
           (%o2)                   ---------------------------------------
                                                       v
310                                                                Maxima 5.45.0 Manual
                                                         z
            (%i3) hgfred([1,1],[2],z);
                                               log(1 - z)
            (%o3)                            - ----------
                                                   z
            (%i4) hgfred([a,a+1/2],[3/2],z^2);
                                                1 - 2 a           1 - 2 a
                                        (z + 1)         - (1 - z)
            (%o4)                       -------------------------------
                                                  2 (1 - 2 a) z
      It can be beneficial to load orthopoly too as the following example shows. Note that
      L is the generalized Laguerre polynomial.
            (%i5) load(orthopoly)$
            (%i6) hgfred([-2],[a],z);
                                                      (a - 1)
                                                   2 L       (z)
                                                      2
            (%o6)                                  -------------
                                                     a (a + 1)
            (%i7) ev(%);
                                                   2
                                                  z        2 z
            (%o7)                              --------- - --- + 1
                                               a (a + 1)    a
16 Elliptic Functions
     The elliptic functions and integrals are primarily intended to support symbolic compu-
tation. Therefore, most of derivatives of the functions and integrals are known. However,
if floating-point values are given, a floating-point result is returned.
     Support for most of the other properties of elliptic functions and integrals other than
derivatives has not yet been written.
     Some examples of elliptic functions:
       (%i1) jacobi_sn (u, m);
       (%o1)                           jacobi_sn(u, m)
       (%i2) jacobi_sn (u, 1);
       (%o2)                                tanh(u)
       (%i3) jacobi_sn (u, 0);
       (%o3)                                sin(u)
       (%i4) diff (jacobi_sn (u, m), u);
       (%o4)                 jacobi_cn(u, m) jacobi_dn(u, m)
       (%i5) diff (jacobi_sn (u, m), m);
       (%o5) jacobi_cn(u, m) jacobi_dn(u, m)
            elliptic_e(asin(jacobi_sn(u, m)), m)
       (u - ------------------------------------)/(2 m)
                           1 - m
                  2
        jacobi_cn (u, m) jacobi_sn(u, m)
      + --------------------------------
                     2 (1 - m)
   Some examples of elliptic integrals:
     (%i1) elliptic_f (phi, m);
314                                                             Maxima 5.45.0 Manual
      (%o1)                  elliptic_f(phi, m)
      (%i2) elliptic_f (phi, 0);
      (%o2)                           phi
      (%i3) elliptic_f (phi, 1);
                                     phi      %pi
      (%o3)                  log(tan(--- + ---))
                                       2       4
      (%i4) elliptic_e (phi, 1);
      (%o4)                       sin(phi)
      (%i5) elliptic_e (phi, 0);
      (%o5)                           phi
      (%i6) elliptic_kc (1/2);
                                             1
      (%o6)                    elliptic_kc(-)
                                             2
      (%i7) makegamma (%);
                                        2 1
                                  gamma (-)
                                          4
      (%o7)                      -----------
                                 4 sqrt(%pi)
      (%i8) diff (elliptic_f (phi, m), phi);
                                       1
      (%o8)                 ---------------------
                                            2
                            sqrt(1 - m sin (phi))
      (%i9) diff (elliptic_f (phi, m), m);
             elliptic_e(phi, m) - (1 - m) elliptic_f(phi, m)
      (%o9) (-----------------------------------------------
                                    m
                                            cos(phi) sin(phi)
                                        - ---------------------)/(2 (1 - m))
                                                        2
                                          sqrt(1 - m sin (phi))
  Support for elliptic functions and integrals was written by Raymond Toy. It is placed
under the terms of the General Public License (GPL) that governs the distribution of
Maxima.
      See also [elliptic e], page 316, and [elliptic kc], page 317.
elliptic_e (phi, m)                                                                                   [Function]
      The incomplete elliptic integral of the second kind, defined as
                                            Z    φ   q
                                                         1 − m sin2 θdθ
                                             0
      See also [elliptic f], page 316, and [elliptic ec], page 317.
elliptic_eu (u, m)                                                                                    [Function]
      The incomplete elliptic integral of the second kind, defined as
                                                                          s
                                   u                                  τ
                                                                              1 − mt2
                              Z                                  Z
                                       dn(v, m)dv =                                   dt
                               0                                  0            1 − t2
      where τ = sn(u, m).
      This is related to elliptice by
                                            E(u, m) = E(φ, m)
      where φ = sin−1 sn(u, m).
      See also [elliptic e], page 316.
elliptic_pi (n, phi, m)                                                                               [Function]
      The incomplete elliptic integral of the third kind, defined as
                                       φ
                                                                 dθ
                                  Z
                                                                 p
                                   0       (1 − n sin θ) 1 − m sin2 θ
                                                             2
Chapter 16: Elliptic Functions                                                 317
      For certain values of m, the value of the integral is known in terms of Gamma
     functions. Use makegamma to evaluate them.
                                                                                              319
17 Limits
limit                                                                                 [Function]
        limit (expr, x, val, dir)
        limit (expr, x, val)
        limit (expr)
    Computes the limit of expr as the real variable x approaches the value val from the
    direction dir. dir may have the value plus for a limit from above, minus for a limit
    from below, or may be omitted (implying a two-sided limit is to be computed).
    limit uses the following special symbols: inf (positive infinity) and minf (negative
    infinity). On output it may also use und (undefined), ind (indefinite but bounded)
    and infinity (complex infinity).
    infinity (complex infinity) is returned when the limit of the absolute value of the ex-
    pression is positive infinity, but the limit of the expression itself is not positive infinity
    or negative infinity. This includes cases where the limit of the complex argument is
    a constant, as in limit(log(x), x, minf), cases where the complex argument oscil-
    lates, as in limit((-2)^x, x, inf), and cases where the complex argument is differ-
    ent for either side of a two-sided limit, as in limit(1/x, x, 0) and limit(log(x),
    x, 0).
    lhospitallim is the maximum number of times L’Hospital’s rule is used in limit.
    This prevents infinite looping in cases like limit (cot(x)/csc(x), x, 0).
    tlimswitch when true will allow the limit command to use Taylor series expansion
    when necessary.
    limsubst prevents limit from attempting substitutions on unknown forms. This is
    to avoid bugs like limit (f(n)/f(n+1), n, inf) giving 1. Setting limsubst to true
    will allow such substitutions.
    limit with one argument is often called upon to simplify constant expressions, for
    example, limit (inf-1).
    example (limit) displays some examples.
    For the method see Wang, P., "Evaluation of Definite Integrals by Symbolic Manip-
    ulation", Ph.D. thesis, MAC TR-92, October 1971.
tlimit                                                                          [Function]
          tlimit (expr, x, val, dir)
          tlimit (expr, x, val)
          tlimit (expr)
      Take the limit of the Taylor series expansion of expr in x at val from direction dir.
18 Differentiation
      When antidiff succeeds entirely, the resulting expression is free of integral signs
      (that is, free of the integrate noun). Otherwise, antidiff returns an expression
      which is partly or entirely within an integral sign. If antidiff cannot make any
      progress, the return value is entirely within an integral sign.
      load ("antid") loads this function. The antid package also defines the functions
      nonzeroandfreeof and linear.
      antidiff is related to antid as follows. Let L, a list of two elements, be the return
      value of antid. Then the return value of antidiff is equal to L[1] + 'integrate
      (L[2], x) where x is the variable of integration.
Examples:
at                                                                                    [Function]
          at (expr, [eqn_1, . . . , eqn_n])
          at (expr, eqn)
     Evaluates the expression expr with the variables assuming the values as specified for
     them in the list of equations [eqn_1, ..., eqn_n] or the single equation eqn.
     If a subexpression depends on any of the variables for which a value is specified but
     there is no atvalue specified and it can’t be otherwise evaluated, then a noun form
     of the at is returned which displays in a two-dimensional form.
     at carries out multiple substitutions in parallel.
     See also atvalue. For other functions which carry out substitutions, see also subst
     and ev.
     Examples:
           (%i1) atvalue (f(x,y), [x = 0, y = 1], a^2);
                                           2
           (%o1)                          a
           (%i2) atvalue ('diff (f(x,y), x), x = 0, 1 + y);
           (%o2)                        @2 + 1
           (%i3) printprops (all, atvalue);
                                           !
                             d             !
                            --- (f(@1, @2))!       = @2 + 1
                            d@1            !
                                           !@1 = 0
                                                        2
                                             f(0, 1) = a
           (%o3)                         done
           (%i4) diff (4*f(x, y)^2 - u(x, y)^2, x);
                             d                          d
           (%o4) 8 f(x, y) (-- (f(x, y))) - 2 u(x, y) (-- (u(x, y)))
                             dx                         dx
           (%i5) at (%, [x = 0, y = 1]);
                                                      !
                            2              d          !
           (%o5)        16 a - 2 u(0, 1) (-- (u(x, 1))!      )
                                           dx         !
                                                      !x = 0
     Note that in the last line y is treated differently to x as y isn’t used as a differentiation
     variable.
     The difference between subst, at and ev can be seen in the following example:
           (%i1) e1:I(t)=C*diff(U(t),t)$
           (%i2) e2:U(t)=L*diff(I(t),t)$
324                                                                Maxima 5.45.0 Manual
            (%i3) at(e1,e2);
                                              !
                                     d        !
            (%o3)          I(t) = C (-- (U(t))!                     )
                                     dt       !          d
                                              !U(t) = L (-- (I(t)))
                                                         dt
            (%i4)    subst(e2,e1);
                                           d       d
            (%o4)                I(t) = C (-- (L (-- (I(t)))))
                                           dt      dt
            (%i5)    ev(e1,e2,diff);
                                                 2
                                                d
            (%o5)                   I(t) = C L (--- (I(t)))
                                                  2
                                                dt
atomgrad                                                                        [Property]
      atomgrad is the atomic gradient property of an expression. This property is assigned
      by gradef.
atvalue                                                                        [Function]
          atvalue (expr, [x_1 = a_1, . . . , x_m = a_m], c)
          atvalue (expr, x_1 = a_1, c)
      Assigns the value c to expr at the point x = a. Typically boundary values are estab-
      lished by this mechanism.
      expr is a function evaluation, f(x_1, ..., x_m), or a derivative, diff (f(x_1, ...,
      x_m), x_1, n_1, ..., x_n, n_m) in which the function arguments explicitly appear.
      n i is the order of differentiation with respect to x i.
      The point at which the atvalue is established is given by the list of equations [x_1
      = a_1, ..., x_m = a_m]. If there is a single variable x 1, the sole equation may be
      given without enclosing it in a list.
      printprops ([f_1, f_2, ...], atvalue) displays the atvalues of the functions f_
      1, f_2, ... as specified by calls to atvalue. printprops (f, atvalue) displays the
      atvalues of one function f. printprops (all, atvalue) displays the atvalues of all
      functions for which atvalues are defined.
      The symbols @1, @2, . . . represent the variables x 1, x 2, . . . when atvalues are
      displayed.
      atvalue evaluates its arguments. atvalue returns c, the atvalue.
      See also at.
      Examples:
            (%i1) atvalue (f(x,y), [x = 0, y = 1], a^2);
                                            2
            (%o1)                          a
Chapter 18: Differentiation                                                            325
                                                      2
                                           f(0, 1) = a
           (%o3)                         done
           (%i4) diff (4*f(x,y)^2 - u(x,y)^2, x);
                             d                          d
           (%o4) 8 f(x, y) (-- (f(x, y))) - 2 u(x, y) (-- (u(x, y)))
                             dx                         dx
           (%i5) at (%, [x = 0, y = 1]);
                                                      !
                            2              d          !
           (%o5)        16 a - 2 u(0, 1) (-- (u(x, 1))!      )
                                           dx         !
                                                      !x = 0
cartan                                                                          [Function]
     The exterior calculus of differential forms is a basic tool of differential geometry
     developed by Elie Cartan and has important applications in the theory of partial
     differential equations. The cartan package implements the functions ext_diff and
     lie_diff, along with the operators ~ (wedge product) and | (contraction of a form
     with a vector.) Type demo ("tensor") to see a brief description of these commands
     along with examples.
     cartan was implemented by F.B. Estabrook and H.D. Wahlquist.
            p;
                                                  - a s
            (%o1)                      sin(a b) %e
     depends (f, x) is declared, diff (f, x) yields a symbolic derivative (that is, a
     diff noun).
     Each argument f 1, x 1, etc., can be the name of a variable or array, or a list of
     names. Every element of f i (perhaps just a single element) is declared to depend on
     every element of x i (perhaps just a single element). If some f i is the name of an
     array or contains the name of an array, all elements of the array depend on x i.
     diff recognizes indirect dependencies established by depends and applies the chain
     rule in these cases.
     remove (f, dependency) removes all dependencies declared for f.
     depends returns a list of the dependencies established. The dependencies are ap-
     pended to the global variable dependencies. depends evaluates its arguments.
     diff is the only Maxima command which recognizes dependencies established by
     depends. Other functions (integrate, laplace, etc.) only recognize dependencies
     explicitly represented by their arguments. For example, integrate does not recognize
     the dependence of f on x unless explicitly represented as integrate (f(x), x).
     depends(f, [x_1, ..., x_n]) is equivalent to dependencies(f(x_1, ..., x_n)).
     See also diff, del, derivdegree and derivabbrev.
           (%i1) depends ([f, g], x);
           (%o1)                     [f(x), g(x)]
           (%i2) depends ([r, s], [u, v, w]);
           (%o2)               [r(u, v, w), s(u, v, w)]
           (%i3) depends (u, t);
           (%o3)                        [u(t)]
           (%i4) dependencies;
           (%o4)      [f(x), g(x), r(u, v, w), s(u, v, w), u(t)]
           (%i5) diff (r.s, u);
                                    dr           ds
           (%o5)                    -- . s + r . --
                                    du           du
           (%i6) diff (r.s, t);
                                     dr du           ds du
           (%o6)                     -- -- . s + r . -- --
                                     du dt           du dt
           (%i7) remove (r, dependency);
           (%o7)                         done
           (%i8) diff (r.s, t);
                                           ds du
           (%o8)                       r . -- --
                                           du dt
diff                                                                               [Function]
           diff   (expr, x_1, n_1, . . . , x_m, n_m)
           diff   (expr, x, n)
           diff   (expr, x)
           diff   (expr)
       Returns the derivative or differential of expr with respect to some or all variables in
       expr.
       diff (expr, x, n) returns the n’th derivative of expr with respect to x.
       diff (expr, x_1, n_1, ..., x_m, n_m) returns the mixed partial derivative of expr
       with respect to x 1, . . . , x m. It is equivalent to diff (... (diff (expr, x_m, n_m)
       ...), x_1, n_1).
       diff (expr, x) returns the first derivative of expr with respect to the variable x.
       diff (expr) returns the total differential of expr, that is, the sum of the derivatives
       of expr with respect to each its variables times the differential del of each variable.
       No further simplification of del is offered.
       The noun form of diff is required in some contexts, such as stating a differential
       equation. In these cases, diff may be quoted (as 'diff) to yield the noun form
       instead of carrying out the differentiation.
       When derivabbrev is true, derivatives are displayed as subscripts. Otherwise,
       derivatives are displayed in the Leibniz notation, dy/dx.
       See also depends, del, derivdegree and derivabbrev.
       Examples:
             (%i1) diff (exp (f(x)), x, 2);
Chapter 18: Differentiation                                                               329
                                       2
                              f(x) d                 f(x) d          2
             (%o1)          %e     (--- (f(x))) + %e      (-- (f(x)))
                                       2                   dx
                                    dx
             (%i2)   derivabbrev: true$
             (%i3)   'integrate (f(x, y), y, g(x), h(x));
                                          h(x)
                                         /
                                         [
             (%o3)                       I     f(x, y) dy
                                         ]
                                         /
                                          g(x)
             (%i4)   diff (%, x);
                       h(x)
                     /
                     [
             (%o4)   I      f(x, y) dy + f(x, h(x)) h(x) - f(x, g(x)) g(x)
                     ]             x                      x               x
                     /
                      g(x)
       For the tensor package, the following modifications have been incorporated:
       (1) The derivatives of any indexed objects in expr will have the variables x i appended
       as additional arguments. Then all the derivative indices will be sorted.
       (2) The x i may be integers from 1 up to the value of the variable dimension [default
       value: 4]. This will cause the differentiation to be carried out with respect to the
       x i’th member of the list coordinates which should be set to a list of the names of
       the coordinates, e.g., [x, y, z, t]. If coordinates is bound to an atomic variable,
       then that variable subscripted by x i will be used for the variable of differentiation.
       This permits an array of coordinate names or subscripted names like X[1], X[2], . . .
       to be used. If coordinates has not been assigned a value, then the variables will be
       treated as in (1) above.
Examples:
gradef                                                                           [Function]
          gradef (f(x_1, . . . , x_n), g_1, . . . , g_m)
          gradef (a, x, expr)
     Defines the partial derivatives (i.e., the components of the gradient) of the function
     f or variable a.
     gradef (f(x_1, ..., x_n), g_1, ..., g_m) defines df/dx_i as g i, where g i is an
     expression; g i may be a function call, but not the name of a function. The number
     of partial derivatives m may be less than the number of arguments n, in which case
     derivatives are defined with respect to x 1 through x m only.
     gradef (a, x, expr) defines the derivative of variable a with respect to x as expr.
     This also establishes the dependence of a on x (via depends (a, x)).
     The first argument f(x_1, ..., x_n) or a is quoted, but the remaining arguments
     g 1, ..., g m are evaluated. gradef returns the function or variable for which the
     partial derivatives are defined.
     gradef can redefine the derivatives of Maxima’s built-in functions. For example,
     gradef (sin(x), sqrt (1 - sin(x)^2)) redefines the derivative of sin.
     gradef cannot define partial derivatives for a subscripted function.
     printprops ([f_1, ..., f_n], gradef) displays the partial derivatives of the func-
     tions f 1, ..., f n, as defined by gradef.
     printprops ([a_n, ..., a_n], atomgrad) displays the partial derivatives of the
     variables a n, ..., a n, as defined by gradef.
     gradefs is the list of the functions for which partial derivatives have been defined by
     gradef. gradefs does not include any variables for which partial derivatives have
     been defined by gradef.
     Gradients are needed when, for example, a function is not known explicitly but its
     first derivatives are and it is desired to obtain higher order derivatives.
                                                              s
           (%o7)                   -----------------------------------
                                             3/2       s + 1
                                            s    sqrt(-----)
                                                         s
           (%i8)   assume(exp(%pi*s)>1)$
           (%i9)   laplace(sum((-1)^n*unit_step(t-n*%pi)*sin(t),n,0,inf),t,s),
                      simpsum;
                                      %i                          %i
                           ------------------------ - ------------------------
                                           - %pi s                     - %pi s
                           (s + %i) (1 - %e        )   (s - %i) (1 - %e        )
           (%o9)           ---------------------------------------------------
                                                     2
           (%i9)   factor(%);
                                                    %pi s
                                                 %e
           (%o9)                     -------------------------------
                                                           %pi s
                                     (s - %i) (s + %i) (%e       - 1)
                                                                                        335
19 Integration
      The function f must be a translated or compiled function of two variables, and r and
      s must each be a translated or compiled function of one variable, while a and b must
      be floating point numbers. The routine has two global variables which determine
      the number of divisions of the x and y intervals: dblint_x and dblint_y, both of
      which are initially 10, and can be changed independently to other integer values (there
      are 2*dblint_x+1 points computed in the x direction, and 2*dblint_y+1 in the y
      direction). The routine subdivides the X axis and then for each value of X it first
      computes r(x) and s(x); then the Y axis between r(x) and s(x) is subdivided and
      the integral along the Y axis is performed using Simpson’s rule; then the integral
      along the X axis is done using Simpson’s rule with the function values being the Y-
      integrals. This procedure may be numerically unstable for a great variety of reasons,
      but is reasonably fast: avoid using it on highly oscillatory functions and functions
      with singularities (poles or branch points in the region). The Y integrals depend on
      how far apart r(x) and s(x) are, so if the distance s(x) - r(x) varies rapidly with
      X, there may be substantial errors arising from truncation with different step-sizes
      in the various Y integrals. One can increase dblint_x and dblint_y in an effort to
      improve the coverage of the region, at the expense of computation time. The function
      values are not saved, so if the function is very time-consuming, you will have to wait
      for re-computation if you change anything (sorry). It is required that the functions
      f, r, and s be either translated or compiled prior to calling dblint. This will result
      in orders of magnitude speed improvement over interpreted code in many cases!
      demo ("dblint") executes a demonstration of dblint applied to an example problem.
Chapter 19: Integration                                                                  337
     defint returns a symbolic expression, either the computed integral or the noun form
     of the integral. See quad_qag and related functions for numerical approximation of
     definite integrals.
     When erfflag is false, prevents risch from introducing the erf function in the
     answer if there were none in the integrand to begin with.
     By using the functions laplace and ilt together with the solve or linsolve func-
     tions the user can solve a single differential or convolution integral equation or a set
     of them.
            pos;
                           sqrt(a b (a b - 1)) t
                    2 cosh(---------------------)        2
                                     b               a t
            (%o4) - ----------------------------- + -------
                          3 2       2               a b - 1
                         a b - 2 a b + a
                                                                             2
                                                                   + ------------------
                                                                      3 2       2
                                                                     a b - 2 a b + a
            (%i2) integrate(1/(sqrt(x)+1),x,0,1),intanalysis:false;
            (%o2)                            2 - 2 log(2)
            (%i4) intanalysis:false$
            (%i5) integrate(cos(a)/sqrt((tan(a))^2+1),a,-%pi/2,%pi/2);
                                                  %pi
            (%o5)                                 ---
                                                   2
Chapter 19: Integration                                                                  339
integrate                                                                         [Function]
        integrate (expr, x)
        integrate (expr, x, a, b)
     Attempts to symbolically compute the integral of expr with respect to x. integrate
     (expr, x) is an indefinite integral, while integrate (expr, x, a, b) is a definite
     integral, with limits of integration a and b. The limits should not contain x, although
     integrate does not enforce this restriction. a need not be less than b. If b is equal
     to a, integrate returns zero.
     See quad_qag and related functions for numerical approximation of definite integrals.
     See residue for computation of residues (complex integration). See antid for an
     alternative means of computing indefinite integrals.
     The integral (an expression free of integrate) is returned if integrate succeeds.
     Otherwise the return value is the noun form of the integral (the quoted operator
     'integrate) or an expression containing one or more noun forms. The noun form of
     integrate is displayed with an integral sign.
     In some circumstances it is useful to construct a noun form by hand, by quoting
     integrate with a single quote, e.g., 'integrate (expr, x). For example, the inte-
     gral may depend on some parameters which are not yet computed. The noun may be
     applied to its arguments by ev (i, nouns) where i is the noun form of interest.
     integrate handles definite integrals separately from indefinite, and employs a range
     of heuristics to handle each case. Special cases of definite integrals include limits of
     integration equal to zero or infinity (inf or minf), trigonometric functions with limits
     of integration equal to zero and %pi or 2 %pi, rational functions, integrals related to
     the definitions of the beta and psi functions, and some logarithmic and trigonometric
     integrals. Processing rational functions may include computation of residues. If an
     applicable special case is not found, an attempt will be made to compute the indefinite
     integral and evaluate it at the limits of integration. This may include taking a limit
     as a limit of integration goes to infinity or negative infinity; see also ldefint.
     Special cases of indefinite integrals include trigonometric functions, exponential and
     logarithmic functions, and rational functions. integrate may also make use of a
     short table of elementary integrals.
     integrate may carry out a change of variable if the integrand has the form f(g(x))
     * diff(g(x), x). integrate attempts to find a subexpression g(x) such that the
     derivative of g(x) divides the integrand. This search may make use of derivatives
     defined by the gradef function. See also changevar and antid.
     If none of the preceding heuristics find the indefinite integral, the Risch algorithm is
     executed. The flag risch may be set as an evflag, in a call to ev or on the command
     line, e.g., ev (integrate (expr, x), risch) or integrate (expr, x), risch. If
     risch is present, integrate calls the risch function without attempting heuristics
     first. See also risch.
     integrate works only with functional relations represented explicitly with the f(x)
     notation. integrate does not respect implicit dependencies established by the
     depends function.
     integrate may need to know some property of a parameter in the integrand.
     integrate will first consult the assume database, and, if the variable of interest
340                                                               Maxima 5.45.0 Manual
      is not there, integrate will ask the user. Depending on the question, suitable
      responses are yes; or no;, or pos;, zero;, or neg;.
Examples:
                  no;
                  Is 2 a - 3   positive, negative, or zero?
                  neg;
                                                       3
                  (%o2)                    beta(a + 1, - - a)
                                                       2
       • Change of variable. There are two changes of variable in this example: one using
         a derivative established by gradef, and one using the derivation diff(r(x)) of
         an unspecified function r(x).
                  (%i3) gradef (q(x), sin(x**2));
                  (%o3)                         q(x)
Chapter 19: Integration                                                                 341
                                                                       2 x + 1
                                                   2            5 atan(-------)
                                              log(x + x + 1)           sqrt(3)
                                            - --------------- + ---------------
                                                    14             7 sqrt(3)
     Alternatively the user may compute the roots of the denominator separately, and
     then express the integrand in terms of these roots, e.g., 1/((x - a)*(x - b)*(x -
     c)) or 1/((x^2 - (a+b)*x + a*b)*(x - c)) if the denominator is a cubic polynomial.
     Sometimes this will help Maxima obtain a more useful result.
344                                                                    Maxima 5.45.0 Manual
19.3.1 Overview
quad_qag      Integration of a general function over a finite interval. quad_qag implements a
              simple globally adaptive integrator using the strategy of Aind (Piessens, 1973).
              The caller may choose among 6 pairs of Gauss-Kronrod quadrature formulae for
              the rule evaluation component. The high-degree rules are suitable for strongly
              oscillating integrands.
quad_qags
              Integration of a general function over a finite interval. quad_qags implements
              globally adaptive interval subdivision with extrapolation (de Doncker, 1978) by
              the Epsilon algorithm (Wynn, 1956).
quad_qagi
              Integration of a general function over an infinite or semi-infinite interval. The
              interval is mapped onto a finite interval and then the same strategy as in quad_
              qags is applied.
quad_qawo
              Integration of cos (ω x) f (x) or sin (ω x) f (x) over a finite interval, where ω is a
              constant. The rule evaluation component is based on the modified Clenshaw-
              Curtis technique. quad_qawo applies adaptive subdivision with extrapolation,
              similar to quad_qags.
quad_qawf
              Calculates a Fourier cosine or Fourier sine transform on a semi-infinite interval.
              The same approach as in quad_qawo is applied on successive finite intervals,
              and convergence acceleration by means of the Epsilon algorithm (Wynn, 1956)
              is applied to the series of the integral contributions.
quad_qaws
              Integration of w (x) f (x) over a finite interval [a, b], where w is a function of
                                 α       β
              the form (x − a) (b − x) v (x) and v (x) is 1 or log (x − a) or log (b − x) or
              log (x − a) log (b − x), and α > −1 and β > −1.
              A globally adaptive subdivision strategy is applied, with modified Clenshaw-
              Curtis integration on the subintervals which contain a or b.
quad_qawc
              Computes the Cauchy principal value of f (x)/(x − c) over a finite interval (a, b)
              and specified c. The strategy is globally adaptive, and modified Clenshaw-
              Curtis integration is used on the subranges which contain the point x = c.
quad_qagp
              Basically the same as quad_qags but points of singularity or discontinuity of the
              integrand must be supplied. This makes it easier for the integrator to produce
              a good solution.
 7
     R. Piessens, E. de Doncker-Kapenga, C.W. Uberhuber, and D.K. Kahaner. QUADPACK: A Subroutine
     Package for Automatic Integration. Berlin: Springer-Verlag, 1983, ISBN 0387125531.
Chapter 19: Integration                                                                  347
     The function to be integrated is f(x), with dependent variable x, and the function is to
     be integrated between the limits a and b. key is the integrator to be used and should
     be an integer between 1 and 6, inclusive. The value of key selects the order of the
     Gauss-Kronrod integration rule. High-order rules are suitable for strongly oscillating
     integrands.
     The integrand may be specified as the name of a Maxima or Lisp function or operator,
     a Maxima lambda expression, or a general Maxima expression.
     The numerical integration is done adaptively by subdividing the integration region
     into sub-intervals until the desired accuracy is achieved.
     The keyword arguments are optional and may be specified in any order. They all
     take the form key=val. The keyword arguments are:
     epsrel         Desired relative error of approximation. Default is 1d-8.
     epsabs         Desired absolute error of approximation. Default is 0.
     limit          Size of internal work array. limit is the maximum number of subintervals
                    to use. Default is 200.
     quad_qag returns a list of four elements:
         •   an approximation to the integral,
         •   the estimated absolute error of the approximation,
         •   the number integrand evaluations,
         •   an error code.
     The error code (fourth element of the return value) can have the values:
     0              if no problems were encountered;
     1              if too many sub-intervals were done;
     2              if excessive roundoff error is detected;
     3              if extremely bad integrand behavior occurs;
     6              if the input is invalid.
348                                                                    Maxima 5.45.0 Manual
      Examples:
               (%i1) quad_qag (x^(1/2)*log(1/x), x, 0, 1, 3, 'epsrel=5d-8);
               (%o1)    [.4444444444492108, 3.1700968502883E-9, 961, 0]
               (%i2) integrate (x^(1/2)*log(1/x), x, 0, 1);
                                               4
               (%o2)                           -
                                               9
quad_qags                                                                         [Function]
        quad_qags (f(x), x, a, b, [epsrel, epsabs, limit])
        quad_qags (f, x, a, b, [epsrel, epsabs, limit])
      Integration of a general function over a finite interval. quad_qags implements globally
      adaptive interval subdivision with extrapolation (de Doncker, 1978) by the Epsilon
      algorithm (Wynn, 1956).
      quad_qags computes the integral
                                           Z    b
                                                    f (x) dx
                                            a
      The function to be integrated is f(x), with dependent variable x, and the function is
      to be integrated between the limits a and b.
      The integrand may be specified as the name of a Maxima or Lisp function or operator,
      a Maxima lambda expression, or a general Maxima expression.
      The keyword arguments are optional and may be specified in any order. They all
      take the form key=val. The keyword arguments are:
      epsrel         Desired relative error of approximation. Default is 1d-8.
      epsabs         Desired absolute error of approximation. Default is 0.
      limit          Size of internal work array. limit is the maximum number of subintervals
                     to use. Default is 200.
      quad_qags returns a list of four elements:
          •   an approximation to the integral,
          •   the estimated absolute error of the approximation,
          •   the number integrand evaluations,
          •   an error code.
      The error code (fourth element of the return value) can have the values:
      0              no problems were encountered;
      1              too many sub-intervals were done;
      2              excessive roundoff error is detected;
      3              extremely bad integrand behavior occurs;
      4              failed to converge
Chapter 19: Integration                                                                    349
quad_qagi                                                                           [Function]
        quad_qagi (f(x), x, a, b, [epsrel, epsabs, limit])
        quad_qagi (f, x, a, b, [epsrel, epsabs, limit])
     Integration of a general function over an infinite or semi-infinite interval. The interval
     is mapped onto a finite interval and then the same strategy as in quad_qags is applied.
     quad_qagi evaluates one of the following integrals
                                        Z       ∞
                                                    f (x) dx
                                            a
                                            Z   a
                                                    f (x) dx
                                            ∞
                                        Z       ∞
                                                    f (x) dx
                                            −∞
     using the Quadpack QAGI routine. The function to be integrated is f(x), with de-
     pendent variable x, and the function is to be integrated over an infinite range.
     The integrand may be specified as the name of a Maxima or Lisp function or operator,
     a Maxima lambda expression, or a general Maxima expression.
     One of the limits of integration must be infinity. If not, then quad_qagi will just
     return the noun form.
     The keyword arguments are optional and may be specified in any order. They all
     take the form key=val. The keyword arguments are:
     epsrel      Desired relative error of approximation. Default is 1d-8.
     epsabs      Desired absolute error of approximation. Default is 0.
     limit       Size of internal work array. limit is the maximum number of subintervals
                 to use. Default is 200.
     quad_qagi returns a list of four elements:
       • an approximation to the integral,
       • the estimated absolute error of the approximation,
       • the number integrand evaluations,
       • an error code.
350                                                                 Maxima 5.45.0 Manual
      The error code (fourth element of the return value) can have the values:
      0           no problems were encountered;
      1           too many sub-intervals were done;
      2           excessive roundoff error is detected;
      3           extremely bad integrand behavior occurs;
      4           failed to converge
      5           integral is probably divergent or slowly convergent
      6           if the input is invalid.
      Examples:
          (%i1) quad_qagi (x^2*exp(-4*x), x, 0, inf, 'epsrel=1d-8);
          (%o1)        [0.03125, 2.95916102995002E-11, 105, 0]
          (%i2) integrate (x^2*exp(-4*x), x, 0, inf);
                                         1
          (%o2)                          --
                                         32
quad_qawc                                                                        [Function]
        quad_qawc (f(x), x, c, a, b, [epsrel, epsabs, limit])
        quad_qawc (f, x, c, a, b, [epsrel, epsabs, limit])
      Computes the Cauchy principal value of f (x)/(x − c) over a finite interval. The
      strategy is globally adaptive, and modified Clenshaw-Curtis integration is used on
      the subranges which contain the point x = c.
      quad_qawc computes the Cauchy principal value of
                                                 b
                                                     f (x)
                                         Z
                                                           dx
                                             a       x−c
      using the Quadpack QAWC routine. The function to be integrated is f(x)/(x - c),
      with dependent variable x, and the function is to be integrated over the interval a to
      b.
      The integrand may be specified as the name of a Maxima or Lisp function or operator,
      a Maxima lambda expression, or a general Maxima expression.
      The keyword arguments are optional and may be specified in any order. They all
      take the form key=val. The keyword arguments are:
      epsrel      Desired relative error of approximation. Default is 1d-8.
      epsabs      Desired absolute error of approximation. Default is 0.
      limit       Size of internal work array. limit is the maximum number of subintervals
                  to use. Default is 200.
      quad_qawc returns a list of four elements:
        • an approximation to the integral,
Chapter 19: Integration                                                               351
                     3 alpha                              3 alpha
                     -------                              -------
                        2           alpha/2                  2  alpha/2
                 2 4        atan(4 4        )  2 4        atan(4        )  alpha
               - --------------------------- - -------------------------)/2
                           alpha                        alpha
                        2 4      + 2                 2 4      + 2
             (%i3) ev (%, alpha=5, numer);
             (%o3)                    - 3.130120337415917
quad_qawf                                                             [Function]
        quad_qawf (f(x), x, a, omega, trig, [epsabs, limit, maxp1, limlst])
        quad_qawf (f, x, a, omega, trig, [epsabs, limit, maxp1, limlst])
     Calculates a Fourier cosine or Fourier sine transform on a semi-infinite interval us-
     ing the Quadpack QAWF function. The same approach as in quad_qawo is applied
     on successive finite intervals, and convergence acceleration by means of the Epsilon
     algorithm (Wynn, 1956) is applied to the series of the integral contributions.
     quad_qawf computes the integral
352                                                                Maxima 5.45.0 Manual
                                      Z     ∞
                                                f (x) w(x) dx
                                        a
quad_qawo                                                             [Function]
        quad_qawo (f(x), x, a, b, omega, trig, [epsrel, epsabs, limit, maxp1,
        limlst])
        quad_qawo (f, x, a, b, omega, trig, [epsrel, epsabs, limit, maxp1,
        limlst])
     Integration of cos (ω x) f (x) or sin (ω x) f (x) over a finite interval, where ω is a
     constant. The rule evaluation component is based on the modified Clenshaw-Curtis
     technique. quad_qawo applies adaptive subdivision with extrapolation, similar to
     quad_qags.
     quad_qawo computes the integral using the Quadpack QAWO routine:
                                     Z    b
                                              f (x) w(x) dx
                                      a
quad_qaws                                                              [Function]
        quad_qaws (f(x), x, a, b, alpha, beta, wfun, [epsrel, epsabs, limit])
        quad_qaws (f, x, a, b, alpha, beta, wfun, [epsrel, epsabs, limit])
      Integration of w(x)f (x) over a finite interval, where w(x) is a certain algebraic or log-
      arithmic function. A globally adaptive subdivision strategy is applied, with modified
      Clenshaw-Curtis integration on the subintervals which contain the endpoints of the
      interval of integration.
      quad_qaws computes the integral using the Quadpack QAWS routine:
                                       Z    b
                                                f (x) w(x) dx
                                        a
             pos;
                                                        alpha      alpha
                                2 %pi 2        sqrt(2 2    + 1)
             (%o2)              -------------------------------
                                              alpha
                                          4 2       + 2
             (%i3) ev (%, alpha=4, numer);
             (%o3)                      8.750097361672829
quad_qagp                                                                        [Function]
        quad_qagp (f(x), x, a, b, points, [epsrel, epsabs, limit])
        quad_qagp (f, x, a, b, points, [epsrel, epsabs, limit])
     Integration of a general function over a finite interval. quad_qagp implements globally
     adaptive interval subdivision with extrapolation (de Doncker, 1978) by the Epsilon
     algorithm (Wynn, 1956).
     quad_qagp computes the integral
                                                Z   b
                                                        f (x) dx
                                                a
     The function to be integrated is f(x), with dependent variable x, and the function is
     to be integrated between the limits a and b.
     The integrand may be specified as the name of a Maxima or Lisp function or operator,
     a Maxima lambda expression, or a general Maxima expression.
     To help the integrator, the user must supply a list of points where the integrand is
     singular or discontinuous.
356                                                                    Maxima 5.45.0 Manual
      The keyword arguments are optional and may be specified in any order. They all
      take the form key=val. The keyword arguments are:
      epsrel      Desired relative error of approximation. Default is 1d-8.
      epsabs      Desired absolute error of approximation. Default is 0.
      limit       Size of internal work array. limit is the maximum number of subintervals
                  to use. Default is 200.
      quad_qagp returns a list of four elements:
        • an approximation to the integral,
        • the estimated absolute error of the approximation,
        • the number integrand evaluations,
        • an error code.
      The error code (fourth element of the return value) can have the values:
      0           no problems were encountered;
      1           too many sub-intervals were done;
      2           excessive roundoff error is detected;
      3           extremely bad integrand behavior occurs;
      4           failed to converge
      5           integral is probably divergent or slowly convergent
      6           if the input is invalid.
      Examples:
            (%i1) quad_qagp(x^3*log(abs((x^2-1)*(x^2-2))),x,0,3,[1,sqrt(2)]);
            (%o1)    [52.74074838347143, 2.6247632689546663e-7, 1029, 0]
            (%i2) quad_qags(x^3*log(abs((x^2-1)*(x^2-2))), x, 0, 3);
            (%o2)    [52.74074847951494, 4.088443219529836e-7, 1869, 0]
      The integrand has singularities at 1 and sqrt(2) so we supply these points to quad_
      qagp. We also note that quad_qagp is more accurate and more efficient that quad_
      qags.
quad_control (parameter, [value])                                            [Function]
      Control error handling for quadpack. The parameter should be one of the following
      symbols:
      current_error
                The current error number
      control     Controls if messages are printed or not. If it is set to zero or less, messages
                  are suppressed.
      max_message
                The maximum number of times any message is to be printed.
      If value is not given, then the current value of the parameter is returned. If value is
      given, the value of parameter is set to the given value.
                                                                                        357
20 Equations
algsys                                                                                [Function]
          algsys ([expr_1, . . . , expr_m], [x_1, . . . , x_n])
          algsys ([eqn_1, . . . , eqn_m], [x_1, . . . , x_n])
      Solves the simultaneous polynomials expr 1, . . . , expr m or polynomial equations
      eqn 1, . . . , eqn m for the variables x 1, . . . , x n. An expression expr is equivalent
      to an equation expr = 0. There may be more equations than variables or vice versa.
      algsys returns a list of solutions, with each solution given as a list of equations stating
      values of the variables x 1, . . . , x n which satisfy the system of equations. If algsys
      cannot find a solution, an empty list [] is returned.
      The symbols %r1, %r2, . . . , are introduced as needed to represent arbitrary parame-
      ters in the solution; these variables are also appended to the list %rnum_list.
      The method is as follows:
       1. First the equations are factored and split into subsystems.
       2. For each subsystem S i, an equation E and a variable x are selected. The variable
           is chosen to have lowest nonzero degree. Then the resultant of E and E j with
           respect to x is computed for each of the remaining equations E j in the subsystem
           S i. This yields a new subsystem S i’ in one fewer variables, as x has been
           eliminated. The process now returns to (1).
       3. Eventually, a subsystem consisting of a single equation is obtained. If the equa-
           tion is multivariate and no approximations in the form of floating point numbers
           have been introduced, then solve is called to find an exact solution.
           In some cases, solve is not be able to find a solution, or if it does the solution
           may be a very large expression.
           If the equation is univariate and is either linear, quadratic, or biquadratic, then
           again solve is called if no approximations have been introduced. If approxima-
           tions have been introduced or the equation is not univariate and neither linear,
           quadratic, or biquadratic, then if the switch realonly is true, the function
           realroots is called to find the real-valued solutions. If realonly is false, then
           allroots is called which looks for real and complex-valued solutions.
           If algsys produces a solution which has fewer significant digits than required,
           the user can change the value of algepsilon to a higher value.
           If algexact is set to true, solve will always be called.
       4. Finally, the solutions obtained in step (3) are substituted into previous levels and
           the solution process returns to (1).
      When algsys encounters a multivariate equation which contains floating point ap-
      proximations (usually due to its failing to find exact solutions at an earlier stage),
      then it does not attempt to apply exact methods to such equations and instead prints
      the message: "algsys cannot solve - system too complicated."
      Interactions with radcan can produce large or complicated expressions. In that case,
      it may be possible to isolate parts of the result with pickapart or reveal.
      Occasionally, radcan may introduce an imaginary unit %i into a solution which is
      actually real-valued.
      Examples:
            (%i1) e1: 2*x*(1 - a1) - 2*(x - 1)*a2;
Chapter 20: Equations                                                                    359
           (%o1)              2 (1 - a1) x - 2 a2 (x - 1)
           (%i2) e2: a2 - a1;
           (%o2)                        a2 - a1
           (%i3) e3: a1*(-y - x^2 + 1);
                                              2
           (%o3)                   a1 (- y - x + 1)
           (%i4) e4: a2*(y - (x - 1)^2);
                                                  2
           (%o4)                   a2 (y - (x - 1) )
           (%i5) algsys ([e1, e2, e3, e4], [x, y, a1, a2]);
           (%o5) [[x = 0, y = %r1, a1 = 0, a2 = 0],
                                                     [x = 1, y = 0, a1 = 1, a2 = 1]]
           (%i6) e1: x^2 - y^2;
                                           2    2
           (%o6)                          x - y
           (%i7)   e2: -1 - y + 2*y^2 - x + x^2;
                                      2        2
           (%o7)                   2 y - y + x - x - 1
           (%i8)   algsys ([e1, e2], [x, y]);
                              1            1
           (%o8)   [[x = - -------, y = -------],
                           sqrt(3)      sqrt(3)
                   1              1             1        1
           [x = -------, y = - -------], [x = - -, y = - -], [x = 1, y = 1]]
                sqrt(3)        sqrt(3)          3        3
allroots                                                                          [Function]
        allroots (expr)
        allroots (eqn)
     Computes numerical approximations of the real and complex roots of the polynomial
     expr or polynomial equation eqn of one variable.
     The flag polyfactor when true causes allroots to factor the polynomial over the
     real numbers if the polynomial is real, or over the complex numbers, if the polynomial
     is complex.
     allroots may give inaccurate results in case of multiple roots. If the polynomial is
     real, allroots (%i*p) may yield more accurate approximations than allroots (p),
     as allroots invokes a different algorithm in that case.
     allroots rejects non-polynomials. It requires that the numerator after rat’ing should
     be a polynomial, and it requires that the denominator be at most a complex number.
     As a result of this allroots will always return an equivalent (but factored) expression,
     if polyfactor is true.
     For complex polynomials an algorithm by Jenkins and Traub is used (Algorithm 419,
     Comm. ACM, vol. 15, (1972), p. 97). For real polynomials the algorithm used is due
     to Jenkins (Algorithm 493, ACM TOMS, vol. 1, (1975), p.178).
360                                                                Maxima 5.45.0 Manual
      Examples:
          (%i1) eqn: (1 + 2*x)^3 = 13.5*(1 + x^5);
                                      3          5
          (%o1)              (2 x + 1) = 13.5 (x + 1)
          (%i2) soln: allroots (eqn);
          (%o2) [x = .8296749902129361, x = - 1.015755543828121,
x = .9659625152196369 %i - .4069597231924075,
- 5.32907051820075E-15
4.44089209850063E-15 %i - 4.88498130835069E-15
- 4.44089209850063E-15 %i - 4.88498130835069E-15
3.5527136788005E-15
            (%o3)                         done
            (%i4) polyfactor: true$
            (%i5) allroots (eqn);
            (%o5) - 13.5 (x - 1.0) (x - .8296749902129361)
                                       2
             (x + 1.015755543828121) (x + .8139194463848151 x
             + 1.098699797110288)
bfallroots                                                                     [Function]
        bfallroots (expr)
        bfallroots (eqn)
      Computes numerical approximations of the real and complex roots of the polynomial
      expr or polynomial equation eqn of one variable.
      In all respects, bfallroots is identical to allroots except that bfallroots computes
      the roots using bigfloats. See allroots for more information.
backsubst                                                                [Option variable]
      Default value: true
      When backsubst is false, prevents back substitution in linsolve after the equations
      have been triangularized. This may be helpful in very big problems where back
      substitution would cause the generation of extremely large expressions.
            (%i1) eq1 : x + y + z = 6$
            (%i2) eq2 : x - y + z = 2$
Chapter 20: Equations                                                                361
           (%i3)   eq3 : x + y - z = 0$
           (%i4)   backsubst : false$
           (%i5)   linsolve ([eq1, eq2, eq3], [x,y,z]);
           (%o5)               [x = z - y, y = 2, z = 3]
           (%i6)   backsubst : true$
           (%i7)   linsolve ([eq1, eq2, eq3], [x,y,z]);
           (%o7)                 [x = 1, y = 2, z = 3]
                                       sqrt(23)    25 1/3
           (%t3)                      (--------- + --)
                                       6 sqrt(3)   54
           Solution:
                                                     sqrt(3) %i   1
                                                     ---------- - -
                               sqrt(3) %i   1            2        2   1
           (%t4)        x = (- ---------- - -) %t3 + -------------- - -
                                   2        2            9 %t3        3
                                                     sqrt(3) %i   1
                                                   - ---------- - -
                             sqrt(3) %i   1              2        2   1
           (%t5)        x = (---------- - -) %t3 + ---------------- - -
                                 2        2             9 %t3         3
                                                  1     1
           (%t6)                      x = %t3 + ----- - -
                                                9 %t3   3
           (%o6)                        [%t4, %t5, %t6]
           (%i6) breakup: false$
           (%i7) solve (x^3 + x^2 - 1);
           Solution:
                           sqrt(3) %i   1
                           ---------- - -
362                                                                Maxima 5.45.0 Manual
                             2        2        sqrt(23)    25 1/3
            (%t7) x = --------------------- + (--------- + --)
                         sqrt(23)    25 1/3    6 sqrt(3)   54
                      9 (--------- + --)
                         6 sqrt(3)   54
                                                          sqrt(3) %i   1    1
                                                       (- ---------- - -) - -
                                                              2        2    3
                       sqrt(23)    25 1/3 sqrt(3) %i    1
            (%t8) x = (--------- + --)    (---------- - -)
                       6 sqrt(3)   54          2        2
                                                         sqrt(3) %i   1
                                                       - ---------- - -
                                                             2        2      1
                                                   + --------------------- - -
                                                        sqrt(23)    25 1/3   3
                                                     9 (--------- + --)
                                                        6 sqrt(3)   54
                         sqrt(23)    25 1/3             1              1
            (%t9)   x = (--------- + --)    + --------------------- - -
                         6 sqrt(3)   54          sqrt(23)    25 1/3    3
                                              9 (--------- + --)
                                                 6 sqrt(3)   54
            (%o9)                     [%t7, %t8, %t9]
dimension                                                                      [Function]
        dimension (eqn)
        dimension (eqn_1, . . . , eqn_n)
      dimen is a package for dimensional analysis. load ("dimen") loads this package.
      demo ("dimen") displays a short demonstration.
                                                  n + 1            n + 2
           (%i2) funcsolve (eqn, f(n));
                                                  17
           (%t2)                              x : --
                                                  7
                                                   1
           (%t3)                             y : - -
                                                   7
           (%o3)                          [[%t2, %t3]]
           (%i3) x;
                                                17
           (%o3)                                --
                                                7
           (%i4) y;
                                                  1
           (%o4)                                - -
                                                  7
           (%i5) globalsolve: false$
           (%i6) kill (x, y)$
           (%i7) solve ([x + 3*y = 2, 2*x - y = 5], [x, y]);
           Solution
364                                                                             Maxima 5.45.0 Manual
                                                            17
            (%t7)                                       x = --
                                                            7
                                                            1
            (%t8)                                     y = - -
                                                            7
            (%o8)                                  [[%t7, %t8]]
            (%i8) x;
            (%o8)                                           x
            (%i9) y;
            (%o9)                                           y
      The different solution techniques used require particular forms of the expressions q
      and w. The techniques available are the following:
      Second-kind equations
       • flfrnk2nd: For fixed-limit, finite-rank integrands.
       • vlfrnk: For variable-limit, finite-rank integrands.
       • transform: Laplace transform for convolution types.
       • fredseries: Fredholm-Carleman series for linear equations.
       • tailor: Taylor series for quasi-linear variable-limit equations.
       • neumann: Neumann series for quasi-second kind equations.
       • collocate: Collocation using a power series form for p(x) evaluated at equally
         spaced points.
Chapter 20: Equations                                                                    365
     First-kind equations
       • flfrnk1st: For fixed-limit, finite-rank integrands.
       • vlfrnk: For variable-limit, finite-rank integrands.
       • abel: For singular integrands
       • transform: See above
       • collocate: See above
       • firstkindseries: Iteration technique similar to neumann series.
     The default values for the 2nd thru 5th parameters in the calling form are:
     unk: p(x), where p is the first function encountered in an integrand which is unknown
     to Maxima and x is the variable which occurs as an argument to the first occurrence of
     p found outside of an integral in the case of secondkind equations, or is the only other
     variable besides the variable of integration in firstkind equations. If the attempt
     to search for x fails, the user will be asked to supply the independent variable. tech:
     first. n: 1. guess: none which will cause neumann and firstkindseries to use
     f(x) as an initial guess.
     Examples:
           (%i1) load("inteqn")$
(%t7) z = a - 1
(%t8) y = 2 a
           (%t9)                       x = a + 1
           (%o9)                    [%t7, %t8, %t9]
           (%i9) ''%;
           (%o9)            [z = a - 1, y = 2 a, x = a + 1]
           (%i10) [globalsolve: true, programmode: false];
           (%o10)                    [true, false]
           (%i11) linsolve ([e1, e2, e3], [x, y, z]);
           Solution
(%t11) z : a - 1
(%t12) y : 2 a
           (%t13)                      x : a + 1
           (%o13)                 [%t11, %t12, %t13]
           (%i13) ''%;
           (%o13)           [z : a - 1, y : 2 a, x : a + 1]
           (%i14) [x, y, z];
368                                                                    Maxima 5.45.0 Manual
            (%o14)                 [a + 1, 2 a, a - 1]
            (%i15) [globalsolve: true, programmode: true];
            (%o15)                    [true, true]
            (%i16) linsolve ([e1, e2, e3], '[x, y, z]);
            (%o16)           [x : a + 1, y : 2 a, z : a - 1]
            (%i17) [x, y, z];
            (%o17)                 [a + 1, 2 a, a - 1]
      rootsepsilon is the tolerance which establishes the confidence interval for the roots
      found by the realroots function.
solve                                                                               [Function]
          solve (expr, x)
          solve (expr)
          solve ([eqn_1, . . . , eqn_n], [x_1, . . . , x_n])
      Solves the algebraic equation expr for the variable x and returns a list of solution
      equations in x. If expr is not an equation, the equation expr = 0 is assumed in its
      place. x may be a function (e.g. f(x)), or other non-atomic expression except a sum
      or product. x may be omitted if expr contains only one variable. expr may be a
      rational expression, and may contain trigonometric functions, exponentials, etc.
      The following method is used:
      Let E be the expression and X be the variable. If E is linear in X then it is trivially
      solved for X. Otherwise if E is of the form A*X^N + B then the result is (-B/A)^1/N)
      times the N’th roots of unity.
      If E is not linear in X then the gcd of the exponents of X in E (say N ) is divided
      into the exponents and the multiplicity of the roots is multiplied by N. Then solve
      is called again on the result. If E factors then solve is called on each of the factors.
      Finally solve will use the quadratic, cubic, or quartic formulas where necessary.
      In the case where E is a polynomial in some function of the variable to be solved for,
      say F(X), then it is first solved for F(X) (call the result C), then the equation F(X)=C
      can be solved for X provided the inverse of the function F is known.
      breakup if false will cause solve to express the solutions of cubic or quartic equa-
      tions as single expressions rather than as made up of several common subexpressions
      which is the default.
      multiplicities - will be set to a list of the multiplicities of the individual solutions
      returned by solve, realroots, or allroots. Try apropos (solve) for the switches
      which affect solve. describe may then by used on the individual switch names if
      their purpose is not clear.
      solve ([eqn_1, ..., eqn_n], [x_1, ..., x_n]) solves a system of simultaneous
      (linear or non-linear) polynomial equations by calling linsolve or algsys and re-
      turns a list of the solution lists in the variables. In the case of linsolve this list
      would contain a single list of solutions. It takes two lists as arguments. The first list
      represents the equations to be solved; the second list is a list of the unknowns to be
      determined. If the total number of variables in the equations is equal to the number
      of equations, the second argument-list may be omitted.
      When programmode is false, solve displays solutions with intermediate expression
      (%t) labels, and returns the list of labels.
      When globalsolve is true and the problem is to solve two or more linear equations,
      each solved-for variable is bound to its value in the solution of the equations.
      Examples:
             (%i1) solve (asin (cos (3*x))*(f(x) - 1), x);
                                                  3
                         sqrt(3) %i   1   sqrt(4 a + 27)    1 1/3
           (%o5) [x = (- ---------- - -) (--------------- - -)
                             2        2      6 sqrt(3)      2
                   sqrt(3) %i   1
                  (---------- - -) a
                       2        2
            - --------------------------, x =
                         3
                 sqrt(4 a + 27)    1 1/3
              3 (--------------- - -)
                    6 sqrt(3)      2
                                     3
            sqrt(3) %i   1   sqrt(4 a + 27)    1 1/3
           (---------- - -) (--------------- - -)
                2        2      6 sqrt(3)      2
                    sqrt(3) %i   1
                 (- ---------- - -) a
                        2        2
            - --------------------------, x =
                         3
                 sqrt(4 a + 27)    1 1/3
374                                                               Maxima 5.45.0 Manual
               3 (--------------- - -)
                     6 sqrt(3)      2
                    3
            sqrt(4 a + 27)    1 1/3                 a
           (--------------- - -)     - --------------------------]
               6 sqrt(3)      2                    3
                                          sqrt(4 a + 27)    1 1/3
                                       3 (--------------- - -)
                                             6 sqrt(3)      2
           (%i6) solve (x^3 - 1);
                        sqrt(3) %i - 1         sqrt(3) %i + 1
           (%o6)   [x = --------------, x = - --------------, x = 1]
                              2                       2
           (%i7) solve (x^6 - 1);
                      sqrt(3) %i + 1       sqrt(3) %i - 1
           (%o7) [x = --------------, x = --------------, x = - 1,
                            2                    2
                                sqrt(3) %i + 1        sqrt(3) %i - 1
                          x = - --------------, x = - --------------, x = 1]
                                      2                     2
           (%i8) ev (x^6 - 1, %[1]);
                                                 6
                                 (sqrt(3) %i + 1)
           (%o8)                 ----------------- - 1
                                        64
           (%i9) expand (%);
           (%o9)                           0
           (%i10) x^2 - 1;
                                         2
           (%o10)                       x - 1
           (%i11) solve (%, x);
           (%o11)                  [x = - 1, x = 1]
           (%i12) ev (%th(2), %[1]);
           (%o12)                          0
      The symbols %r are used to denote arbitrary constants in a solution.
           (%i1) solve([x+y=1,2*x+2*y=2],[x,y]);
21 Differential Equations
desolve                                                                          [Function]
          desolve (eqn, x)
          desolve ([eqn_1, ..., eqn_n], [x_1, ..., x_n])
     The function desolve solves systems of linear ordinary differential equations using
     Laplace transform. Here the eqn’s are differential equations in the dependent variables
     x 1, ..., x n. The functional dependence of x 1, ..., x n on an independent variable,
     for instance x, must be explicitly indicated in the variables and its derivatives. For
     example, this would not be the correct way to define two equations:
           eqn_1: 'diff(f,x,2) = sin(x) + 'diff(g,x);
           eqn_2: 'diff(f,x) + x^2 - f = 2*'diff(g,x,2);
     The correct way would be:
           eqn_1: 'diff(f(x),x,2) = sin(x) + 'diff(g(x),x);
           eqn_2: 'diff(f(x),x) + x^2 - f(x) = 2*'diff(g(x),x,2);
     The call to the function desolve would then be
           desolve([eqn_1, eqn_2], [f(x),g(x)]);
     If initial conditions at x=0 are known, they can be supplied before calling desolve
     by using atvalue.
           (%i1) 'diff(f(x),x)='diff(g(x),x)+sin(x);
                            d           d
           (%o1)            -- (f(x)) = -- (g(x)) + sin(x)
                            dx          dx
           (%i2) 'diff(g(x),x,2)='diff(f(x),x)-cos(x);
378                                                                   Maxima 5.45.0 Manual
                                2
                               d            d
            (%o2)              --- (g(x)) = -- (f(x)) - cos(x)
                                 2          dx
                               dx
            (%i3)   atvalue('diff(g(x),x),x=0,a);
            (%o3)                              a
            (%i4)   atvalue(f(x),x=0,1);
            (%o4)                              1
            (%i5)   desolve([%o1,%o2],[f(x),g(x)]);
                                x
            (%o5)   [f(x) = a %e - a + 1, g(x) =
                                                                     x
                                                        cos(x) + a %e - a + g(0) - 1]
            (%i6) [%o1,%o2],%o5,diff;
                         x       x     x               x
            (%o6)   [a %e = a %e , a %e - cos(x) = a %e - cos(x)]
     If ode2 cannot obtain a solution for whatever reason, it returns false, after perhaps
     printing out an error message. The methods implemented for first order equations in
     the order in which they are tested are: linear, separable, exact - perhaps requiring
     an integrating factor, homogeneous, Bernoulli’s equation, and a generalized homoge-
     neous method. The types of second-order equations which can be solved are: constant
     coefficients, exact, linear homogeneous with non-constant coefficients which can be
     transformed to constant coefficients, the Euler or equi-dimensional equation, equa-
     tions solvable by the method of variation of parameters, and equations which are free
     of either the independent or of the dependent variable so that they can be reduced to
     two first order linear equations to be solved sequentially.
     In the course of solving ODE’s, several variables are set purely for informational pur-
     poses: method denotes the method of solution used (e.g., linear), intfactor denotes
     any integrating factor used, odeindex denotes the index for Bernoulli’s method or for
     the generalized homogeneous method, and yp denotes the particular solution for the
     variation of parameters technique.
     In order to solve initial value problems (IVP) functions ic1 and ic2 are available for
     first and second order equations, and to solve second-order boundary value problems
     (BVP) the function bc2 can be used.
     See also desolve, drawdf and rk.
     Example:
            (%i1) x^2*'diff(y,x) + 3*y*x = sin(x)/x;
                                        2 dy             sin(x)
            (%o1)                      x -- + 3 x y = ------
                                          dx                x
            (%i2) ode2(%,y,x);
                                                %c - cos(x)
            (%o2)                          y = -----------
                                                     3
                                                    x
            (%i3) ic1(%o2,x=%pi,y=0);
                                                 cos(x) + 1
            (%o3)                         y = - ----------
                                                      3
                                                     x
            (%i4) 'diff(y,x,2) + y*'diff(y,x)^3 = 0;
                                           2
                                          d y       dy 3
            (%o4)                         --- + y (--) = 0
                                            2       dx
                                          dx
            (%i5) ode2(%,y,x);
                                        3
                                       y + 6 %k1 y
            (%o5)                      ------------ = x + %k2
                                            6
            (%i6) ratsimp(ic2(%o5,x=0,y=0,'diff(y,x)=2));
380                                               Maxima 5.45.0 Manual
                                    3
                                 2 y - 3 y
      (%o6)                   - ---------- = x
                                     6
      (%i7) bc2(%o5,x=0,y=1,x=1,y=3);
                               3
                              y - 10 y        3
      (%o7)                   --------- = x - -
                                   6          2
                                                                                        381
22 Numerical
      The inverse discrete Fourier transform is defined as follows. Let x be the output of
      the inverse transform. Then for j from 0 through n - 1,
            x[j] = sum(y[k] exp(-2 %i %pi j k / n), k, 0, n - 1)
      As there are various sign and normalization conventions possible, this definition of
      the transform may differ from that used by other mathematical software.
      load(fft) loads this function.
      See also fft (forward transform), recttopolar, and polartorect.
      Examples:
      Real data.
            (%i1) load ("fft") $
            (%i2) fpprintprec : 4 $
            (%i3) L : [1, 2, 3, 4, -1, -2, -3, -4] $
            (%i4) L1 : inverse_fft (L);
            (%o4) [0.0, 14.49 %i - .8284, 0.0, 2.485 %i + 4.828, 0.0,
                                        4.828 - 2.485 %i, 0.0, - 14.49 %i - .8284]
            (%i5) L2 : fft (L1);
            (%o5) [1.0, 2.0 - 2.168L-19 %i, 3.0 - 7.525L-20 %i,
            4.0 - 4.256L-19 %i, - 1.0, 2.168L-19 %i - 2.0,
            7.525L-20 %i - 3.0, 4.256L-19 %i - 4.0]
            (%i6) lmax (abs (L2 - L));
            (%o6)                            3.545L-16
      Complex data.
            (%i1) load ("fft") $
            (%i2) fpprintprec : 4 $
            (%i3) L : [1, 1 + %i, 1 - %i, -1, -1, 1 - %i, 1 + %i, 1] $
            (%i4) L1 : inverse_fft (L);
            (%o4) [4.0, 2.711L-19 %i + 4.0, 2.0 %i - 2.0,
            - 2.828 %i - 2.828, 0.0, 5.421L-20 %i + 4.0, - 2.0 %i - 2.0,
            2.828 %i + 2.828]
            (%i5) L2 : fft (L1);
            (%o5) [4.066E-20 %i + 1.0, 1.0 %i + 1.0, 1.0 - 1.0 %i,
            1.55L-19 %i - 1.0, - 4.066E-20 %i - 1.0, 1.0 - 1.0 %i,
            1.0 %i + 1.0, 1.0 - 7.368L-20 %i]
            (%i6) lmax (abs (L2 - L));
            (%o6)                            6.841L-17
     of fft that is slower, but supports bfloats. In addition if it is known that the input
     consists of only real values (no imaginary parts), real_fft can be used which is
     potentially faster.
     The discrete Fourier transform is defined as follows. Let y be the output of the
     transform. Then for k from 0 through n - 1,
           y[k] = (1/n) sum(x[j] exp(+2 %i %pi j k / n), j, 0, n - 1)
     As there are various sign and normalization conventions possible, this definition of
     the transform may differ from that used by other mathematical software.
     When the data x are real, real coefficients a and b can be computed such that
           x[j] = sum(a[k]*cos(2*%pi*j*k/n)+b[k]*sin(2*%pi*j*k/n), k, 0, n/2)
     with
           a[0] = realpart (y[0])
           b[0] = 0
     and, for k from 1 through n/2 - 1,
           a[k] = realpart (y[k] + y[n - k])
           b[k] = imagpart (y[n - k] - y[k])
     and
           a[n/2] = realpart (y[n/2])
           b[n/2] = 0
     load(fft) loads this function.
     See also inverse_fft (inverse transform), recttopolar, and polartorect.. See
     real_fft for FFTs of a real-valued input, and bf_fft and bf_real_fft for oper-
     ations on bigfloat values. Finally, for transforms of any size (but limited to float
     values), see fftpack5_fft and fftpack5_real_fft.
     Examples:
     Real data.
           (%i1) load ("fft") $
           (%i2) fpprintprec : 4 $
           (%i3) L : [1, 2, 3, 4, -1, -2, -3, -4] $
           (%i4) L1 : fft (L);
           (%o4) [0.0, 1.811 %i - .1036, 0.0, 0.3107 %i + .6036, 0.0,
                                         0.6036 - 0.3107 %i, 0.0, (- 1.811 %i) - 0.1036]
           (%i5) L2 : inverse_fft (L1);
           (%o5) [1.0, 2.168L-19 %i + 2.0, 7.525L-20 %i + 3.0,
           4.256L-19 %i + 4.0, - 1.0, - 2.168L-19 %i - 2.0,
           - 7.525L-20 %i - 3.0, - 4.256L-19 %i - 4.0]
           (%i6) lmax (abs (L2 - L));
           (%o6)                             3.545L-16
     Complex data.
           (%i1) load ("fft") $
           (%i2) fpprintprec : 4 $
           (%i3) L : [1, 1 + %i, 1 - %i, -1, -1, 1 - %i, 1 + %i, 1] $
           (%i4) L1 : fft (L);
384                                                                  Maxima 5.45.0 Manual
            (%o4) [0.5, 0.5, 0.25 %i - 0.25, (- 0.3536 %i) - 0.3536, 0.0, 0.5,
                                                    (- 0.25 %i) - 0.25, 0.3536 %i + 0.3536]
            (%i5) L2 : inverse_fft (L1);
            (%o5) [1.0, 1.0 %i + 1.0, 1.0 - 1.0 %i, - 1.0, - 1.0, 1.0 - 1.0 %i,
                                                                         1.0 %i + 1.0, 1.0]
            (%i6) lmax (abs (L2 - L));
            (%o6)                       0.0
      Computation of sine and cosine coefficients.
            (%i1) load ("fft") $
            (%i2) fpprintprec : 4 $
            (%i3) L : [1, 2, 3, 4, 5, 6, 7, 8] $
            (%i4) n : length (L) $
            (%i5) x : make_array (any, n) $
            (%i6) fillarray (x, L) $
            (%i7) y : fft (x) $
            (%i8) a : make_array (any, n/2 + 1) $
            (%i9) b : make_array (any, n/2 + 1) $
            (%i10) a[0] : realpart (y[0]) $
            (%i11) b[0] : 0 $
            (%i12) for k : 1 thru n/2 - 1 do
               (a[k] : realpart (y[k] + y[n - k]),
                b[k] : imagpart (y[n - k] - y[k]));
            (%o12)                        done
            (%i13) a[n/2] : y[n/2] $
            (%i14) b[n/2] : 0 $
            (%i15) listarray (a);
            (%o15)          [4.5, - 1.0, - 1.0, - 1.0, - 0.5]
            (%i16) listarray (b);
            (%o16)           [0, - 2.414, - 1.0, - .4142, 0]
            (%i17) f(j) := sum (a[k]*cos(2*%pi*j*k/n) + b[k]*sin(2*%pi*j*k/n),
                                k, 0, n/2) $
            (%i18) makelist (float (f (j)), j, 0, n - 1);
            (%o18)      [1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0]
            (%o6)                       4.441e-16
            (%i7) L : [1, 2, 3, 4, 5, 6]$
            (%i8) L1 : fftpack5_fft(L);
            (%o8) [3.5, (- 0.866 %i) - 0.5, (- 0.2887 %i) - 0.5, (- 1.48e-16 %i) - 0.5,
                                                           0.2887 %i - 0.5, 0.866
                                                                  %%i - 0.5]
            (%i9) L2 : fftpack5_inverse_fft (L1);
            (%o9) [1.0 - 1.48e-16 %i, 3.701e-17 %i + 2.0, 3.0 - 1.48e-16 %i,
                                 4.0 - 1.811e-16 %i, 5.0 - 1.48e-16 %i, 5.881e-16
                                       %i + 6.0]
            (%i10) lmax (abs (L2-L));
            (%o10)                             9.064e-16
      Complex data.
            (%i1)   load("fftpack5") $
            (%i2)   fpprintprec : 4 $
            (%i3)   L : [1, 1 + %i, 1 - %i, -1, -1, 1 - %i, 1 + %i, 1] $
            (%i4)   L1 : fftpack5_inverse_fft (L);
            (%o4)   [4.0, 2.828 %i + 2.828, (- 2.0 %i) - 2.0, 4.0, 0.0,
                                                     (- 2.828 %i) - 2.828, 2.0 %i - 2.0, 4.0]
            (%i5)   L2 : fftpack5_fft(L1);
            (%o5)   [1.0, 1.0 %i + 1.0, 1.0 - 1.0 %i, (- 2.776e-17 %i) - 1.0, - 1.0,
                                              1.0 - 1.0 %i, 1.0 %i + 1.0, 1.0 -
                                                        %2.776e-17 %i]
            (%i6)   lmax(abs(L2-L));
            (%o6)                                1.11e-16
           Automatically continuing.
           To enable the Lisp debugger set *debugger-hook* to nil.
           (%i4) ev (expr2, x=1e155);
           (%o4)                 7.00000000000001e+154
find_root (expr, x, a, b, [abserr, relerr])                                      [Function]
find_root (f, a, b, [abserr, relerr])                                            [Function]
bf_find_root (expr, x, a, b, [abserr, relerr])                                   [Function]
bf_find_root (f, a, b, [abserr, relerr])                                         [Function]
find_root_error                                                          [Option variable]
find_root_abs                                                            [Option variable]
find_root_rel                                                            [Option variable]
     Finds a root of the expression expr or the function f over the closed interval [a, b].
     The expression expr may be an equation, in which case find_root seeks a root of
     lhs(expr) - rhs(expr).
     Given that Maxima can evaluate expr or f over [a, b] and that expr or f is continuous,
     find_root is guaranteed to find the root, or one of the roots if there is more than
     one.
     find_root initially applies binary search. If the function in question appears to be
     smooth enough, find_root applies linear interpolation instead.
388                                                                  Maxima 5.45.0 Manual
            (%i9) fpprec:32;
            (%o9)                           32
            (%i10) bf_find_root (exp(x) = y, x, 0, 100), y = 10;
            (%o10)                  2.3025850929940456840179914546844b0
            (%i11) log(10b0);
            (%o11)                  2.3025850929940456840179914546844b0
newton (expr, x, x_0, eps)                                                       [Function]
      Returns an approximate solution of expr = 0 by Newton’s method, considering expr
      to be a function of one variable, x. The search begins with x = x_0 and proceeds until
      abs(expr) < eps (with expr evaluated at the current value of x).
      newton allows undefined variables to appear in expr, so long as the termination test
      abs(expr) < eps evaluates to true or false. Thus it is not necessary that expr
      evaluate to a number.
      load(newton1) loads this function.
      See also realroots, allroots, find_root and mnewton.
      Examples:
            (%i1) load ("newton1");
            (%o1) /maxima/share/numeric/newton1.mac
            (%i2) newton (cos (u), u, 1, 1/100);
            (%o2)                          1.570675277161251
            (%i3) ev (cos (u), u = %);
            (%o3)                       1.2104963335033529e-4
            (%i4) assume (a > 0);
            (%o4)                                [a > 0]
            (%i5) newton (x^2 - a^2, x, a/2, a^2/100);
            (%o5)                         1.00030487804878 a
            (%i6) ev (x^2 - a^2, x = %);
                                                                 2
            (%o6)                      6.098490481853958e-4 a
    The first argument in the functions will be a list with the expressions on the right-side
of the ODE’s. The variables whose derivatives are represented by those expressions should
390                                                                   Maxima 5.45.0 Manual
be given in a second list. In the case above those variables are x and y. The independent
variable, t in the examples above, might be given in a separated option. If the expressions
given do not depend on that independent variable, the system is called autonomous.
     Icon of a plot. Opens another window with a plot of the two variables in terms of
     time, for the last integral curve that was plotted.
     Plot options:
     Options can also be given within the plotdf itself, each one being a list of two or
     more elements. The first element in each option is the name of the option, and the
     remainder is the value or values assigned to the option.
     The options which are recognized by plotdf are the following:
       • nsteps defines the number of steps that will be used for the independent variable,
         to compute an integral curve. The default value is 100.
       • direction defines the direction of the independent variable that will be followed to
         compute an integral curve. Possible values are forward, to make the independent
         variable increase nsteps times, with increments tstep, backward, to make the
         independent variable decrease, or both that will lead to an integral curve that
         extends nsteps forward, and nsteps backward. The keywords right and left
         can be used as synonyms for forward and backward. The default value is both.
       • tinitial defines the initial value of variable t used to compute integral curves.
         Since the differential equations are autonomous, that setting will only appear in
         the plot of the curves as functions of t. The default value is 0.
       • versus t is used to create a second plot window, with a plot of an integral curve,
         as two functions x, y, of the independent variable t. If versus_t is given any
         value different from 0, the second plot window will be displayed. The second plot
         window includes another menu, similar to the menu of the main plot window.
         The default value is 0.
       • trajectory at defines the coordinates xinitial and yinitial for the starting point
         of an integral curve. The option is empty by default.
       • parameters defines a list of parameters, and their numerical values, used in the
         definition of the differential equations. The name and values of the parameters
         must be given in a string with a comma-separated sequence of pairs name=value.
       • sliders defines a list of parameters that will be changed interactively using slider
         buttons, and the range of variation of those parameters. The names and ranges
         of the parameters must be given in a string with a comma-separated sequence of
         elements name=min:max
       • xfun defines a string with semi-colon-separated sequence of functions of x to be
         displayed, on top of the direction field. Those functions will be parsed by Tcl
         and not by Maxima.
       • x should be followed by two numbers, which will set up the minimum and max-
         imum values shown on the horizontal axis. If the variable on the horizontal axis
         is not x, then this option should have the name of the variable on the horizontal
         axis. The default horizontal range is from -10 to 10.
       • y should be followed by two numbers, which will set up the minimum and max-
         imum values shown on the vertical axis. If the variable on the vertical axis is
         not y, then this option should have the name of the variable on the vertical axis.
         The default vertical range is from -10 to 10.
392                                                                   Maxima 5.45.0 Manual
       • xaxislabel will be used to identify the horizontal axis. Its default value is the
         name of the first state variable.
       • yaxislabel will be used to identify the vertical axis. Its default value is the name
         of the second state variable.
       • number of arrows should be set to a square number and defines the approximate
         density of the arrows being drawn. The default value is 225.
Examples:
       • To show the direction field of the differential equation y 0 = exp(−x) + y and the
         solution that goes through (2, −0.1):
(%i1) plotdf(exp(-x)+y,[trajectory_at,2,-0.1])$
          y
              10
-5
          -10
            -10          -5         0          5          10
                                    x
       • To obtain the direction field for the equation dif f (y, x) = x − y 2 and the solution
         with initial condition y(−1) = 3, we can use the command:
                   (%i1) plotdf(x-y^2,[xfun,"sqrt(x);-sqrt(x)"],
                            [trajectory_at,-1,3], [direction,forward],
                            [y,-5,5], [x,-4,16])$
Chapter 22: Numerical                                                                   393
              y
                  5
                       sqrt(x)
                       -sqrt(x)
2.5
-2.5
                  -5
                                  0        5       10       15
                                               x
       • The following example shows the direction field of a harmonic oscillator, defined
         by the two equations dz/dt = v and dv/dt = −k ∗ z/m, and the integral curve
         through (z, v) = (6, 0), with a slider that will allow you to change the value of m
         interactively (k is fixed at 2):
               (%i1) plotdf([v,-k*z/m], [z,v], [parameters,"m=2,k=2"],
                              [sliders,"m=1:5"], [trajectory_at,6,0])$
             v
               10
-5
              -10
                       -8             -4       0   4    8
                                               z
           m: 2.00
       • To plot the direction field of the Duffing equation, m∗x00 +c∗x0 +k ∗x+b∗x3 = 0,
         we introduce the variable y = x0 and use:
394                                                               Maxima 5.45.0 Manual
              y
                10
-5
               -10
                         -8    -4     0      4     8
                                      x
         k:   -1.00
m: 1.00
      • The direction field for a damped pendulum, including the solution for the given
        initial conditions, with a slider that can be used to change the value of the mass
        m, and with a plot of the two state variables as a function of time:
Chapter 22: Numerical                                                                   395
12
-4
-8
-12
                 -10       -8    -6    -4    -2    0   2
                                       a
          m: 0.297
                       a
               12      w
-4
-8
-12
      the gradient of the expression given. The plot can also show the integral curves for
      that gradient system (option fieldlines).
      This program also requires Xmaxima, even if its run from a Maxima session in a
      console, since the plot will be created by the Tk scripts in Xmaxima. By default, the
      plot region will be empty until the user clicks in a point (or gives its coordinate with
      in the set-up menu or via the trajectory at option).
      Most options accepted by plotdf can also be used for ploteq and the plot interface is
      the same that was described in plotdf.
      Example:
            (%i1) V: 900/((x+1)^2+y^2)^(1/2)-900/((x-1)^2+y^2)^(1/2)$
            (%i2) ploteq(V,[x,-2,2],[y,-2,2],[fieldlines,"blue"])$
      Clicking on a point will plot the equipotential curve that passes by that point (in red)
      and the orthogonal trajectory (in blue).
rk                                                                                  [Function]
          rk (ODE, var, initial, domain)
          rk ([ODE1, . . . , ODEm], [v1, . . . , vm], [init1, . . . , initm], domain)
      The first form solves numerically one first-order ordinary differential equation, and the
      second form solves a system of m of those equations, using the 4th order Runge-Kutta
      method. var represents the dependent variable. ODE must be an expression that
      depends only on the independent and dependent variables and defines the derivative
      of the dependent variable with respect to the independent variable.
      The independent variable is specified with domain, which must be a list of four ele-
      ments as, for instance:
             [t, 0, 10, 0.1]
      the first element of the list identifies the independent variable, the second and third
      elements are the initial and final values for that variable, and the last element sets
      the increments that should be used within that interval.
      If m equations are going to be solved, there should be m dependent variables v1, v2,
      ..., vm. The initial values for those variables will be init1, init2, ..., initm. There
      will still be just one independent variable defined by domain, as in the previous case.
      ODE1, ..., ODEm are the expressions that define the derivatives of each dependent
      variable in terms of the independent variable. The only variables that may appear in
      those expressions are the independent variable and any of the dependent variables. It
      is important to give the derivatives ODE1, ..., ODEm in the list in exactly the same
      order used for the dependent variables; for instance, the third element in the list will
      be interpreted as the derivative of the third dependent variable.
      The program will try to integrate the equations from the initial value of the inde-
      pendent variable until its last value, using constant increments. If at some step one
      of the dependent variables takes an absolute value too large, the integration will be
      interrupted at that point. The result will be a list with as many elements as the
      number of iterations made. Each element in the results list is itself another list with
      m+1 elements: the value of the independent variable, followed by the values of the
      dependent variables corresponding to that point.
      See also drawdf, desolve and ode2.
Chapter 22: Numerical                                                                  397
     Examples:
     To solve numerically the differential equation
                                        dx
                                           = t − x2
                                        dt
     With initial value x(t=0) = 1, in the interval of t from 0 to 8 and with increments of
     0.1 for t, use:
            (%i1) results: rk(t-x^2,x,1,[t,0,8,0.1])$
            (%i2) plot2d ([discrete, results])$
     the results will be saved in the list results and the plot will show the solution
     obtained, with t on the horizontal axis and x on the vertical axis.
     To solve numerically the system:
                                   dx
                                 
                                  dt = 4 − x2 − 4y 2
                                 
                                  dy = y 2 − x2 + 1
                                 
                                   dt
     for t between 0 and 4, and with values of -1.25 and 0.75 for x and y at t=0:
            (%i1) sol: rk([4-x^2-4*y^2, y^2-x^2+1], [x, y], [-1.25, 0.75],
                            [t, 0, 4, 0.02])$
            (%i2) plot2d([discrete, makelist([p[1], p[3]], p, sol)], [xlabel, "t"],
                          [ylabel, "y"])$
     The plot will show the solution for variable y as a function of t.
                                                                                         399
23.1.2 Matrices
Matrices are handled with speed and memory-efficiency in mind. This means that assigning
a matrix to a variable will create a reference to, not a copy of the matrix. If the matrix
is modified all references to the matrix point to the modified object (See copymatrix for a
way of avoiding this):
      (%i1) M1: matrix([0,0],[0,0]);
                                         [ 0 0 ]
      (%o1)                              [        ]
                                         [ 0 0 ]
      (%i2) M2: M1;
                                         [ 0 0 ]
      (%o2)                              [        ]
                                         [ 0 0 ]
      (%i3) M1[1][1]: 2;
      (%o3)                                   2
      (%i4) M2;
                                         [ 2 0 ]
      (%o4)                              [        ]
                                         [ 0 0 ]
   Converting a matrix to nested lists and vice versa works the following way:
      (%i1) l: [[1,2],[3,4]];
      (%o1)                         [[1, 2], [3, 4]]
400                                                                Maxima 5.45.0 Manual
23.1.3 Vectors
vect is a package of functions for vector analysis. load ("vect") loads this package, and
demo ("vect") displays a demonstration.
    The vector analysis package can combine and simplify symbolic expressions including dot
products and cross products, together with the gradient, divergence, curl, and Laplacian
operators. The distribution of these operators over sums or products is governed by several
flags, as are various other expansions, including expansion into components in any specific
orthogonal coordinate systems. There are also functions for deriving the scalar or vector
potential of a field.
    The vect package contains these functions: vectorsimp, scalefactors, express,
potential, and vectorpotential.
    By default the vect package does not declare the dot operator to be a commutative
operator. To get a commutative dot operator ., the command declare(".", commutative)
must be executed.
23.1.4 eigen
The package eigen contains several functions devoted to the symbolic computation of eigen-
values and eigenvectors. Maxima loads the package automatically if one of the functions
eigenvalues or eigenvectors is invoked. The package may be loaded explicitly as load
("eigen").
   demo ("eigen") displays a demonstration of the capabilities of this package. batch
("eigen") executes the same demonstration, but without the user prompt between succes-
sive computations.
   The functions in the eigen package are:
innerproduct, unitvector, columnvector, gramschmidt, eigenvalues,
eigenvectors, uniteigenvectors, and similaritytransform.
cauchy_matrix                                                                       [Function]
        cauchy_matrix ([x_1, x_2, . . . , x_m], [y_1, y_2, . . . , y_n])
        cauchy_matrix ([x_1, x_2, . . . , x_n])
     Returns a n by m Cauchy matrix with the elements a[i,j] = 1/(x i+y i). The second
     argument of cauchy_matrix is optional. For this case the elements of the Cauchy
     matrix are a[i,j] = 1/(x i+x j).
     Remark: In the literature the Cauchy matrix can be found defined in two forms. A
     second definition is a[i,j] = 1/(x i-y i).
     Examples:
           (%i1) cauchy_matrix([x1, x2], [y1, y2]);
                                 [    1        1               ]
                                 [ ------- -------             ]
                                 [ y1 + x1 y2 + x1             ]
           (%o1)                 [                             ]
                                 [    1        1               ]
                                 [ ------- -------             ]
                                 [ y1 + x2 y2 + x2             ]
                                                                   1             2
                                                          [x1 = -------, x2 = -------]]
                                                                sqrt(5)       sqrt(5)
                                              [ c   d ]
            (%i2)   detout: true$
            (%i3)   doallmxops: false$
            (%i4)   doscmxops: false$
            (%i5)   invert (m);
                                           [ d    - b ]
                                           [          ]
                                           [ - c   a ]
            (%o5)                          ------------
                                            a d - b c
            (%o5)                [                              ]
                                 [        b + a             %pi ]
                                 [ (1 - c)           (1 - c)    ]
      The function algsys is used here to solve for the eigenvectors. Sometimes if the
      eigenvalues are messy, algsys may not be able to find a solution. In some cases, it
      may be possible to simplify the eigenvalues by first finding them using eigenvalues
      command and then using other functions to reduce them to something simpler. Fol-
      lowing simplification, eigenvectors can be called again with the knowneigvals flag
      set to true.
Examples:
                                                   mult = 1
                                                       1
                                         val       = sqrt(3) + 9
                                               2
                                                   mult = 1
                                                       2
(%o3) done
      A matrix which has two eigenvectors for one eigenvalue (namely 2).
Chapter 23: Matrices and Linear Algebra                                                409
                                              mult = 2
                                                  1
                                              val       = 2
                                                    2
                                              mult = 2
                                                  2
           (%o3)                                 done
ematrix (m, n, x, i, j)                                                          [Function]
     Returns an m by n matrix, all elements of which are zero except for the [i, j] element
     which is x.
entermatrix (m, n)                                                             [Function]
     Returns an m by n matrix, reading the elements interactively.
     If n is equal to m, Maxima prompts for the type of the matrix (diagonal, symmetric,
     antisymmetric, or general) and for each element. Each response is terminated by a
     semicolon ; or dollar sign $.
     If n is not equal to m, Maxima prompts for each element.
     The elements may be any expressions, which are evaluated. entermatrix evaluates
     its arguments.
            (%i1) n: 3$
410                                                                    Maxima 5.45.0 Manual
            Matrix entered.
            (%i3) m;
                                [        3                            ]
                                [ (b + a)          0           0      ]
                                [                                     ]
            (%o3)               [                        4            ]
                                [    0         (b + a)          0     ]
                                [                                     ]
                                [                                   5 ]
                                [    0             0         (b + a) ]
genmatrix                                                                          [Function]
        genmatrix (a, i_2, j_2, i_1, j_1)
        genmatrix (a, i_2, j_2, i_1)
        genmatrix (a, i_2, j_2)
      Returns a matrix generated from a, taking element a[i_1, j_1] as the upper-left
      element and a[i_2, j_2] as the lower-right element of the matrix. Here a is a declared
      array (created by array but not by make_array) or a hashed array, or a memoizing
      function, or a lambda expression of two arguments. (A memoizing function is
      created like other functions with := or define, but arguments are enclosed in square
      brackets instead of parentheses.)
      If a selected element i,j of the array is undefined, the matrix will contain a symbolic
      element a[i,j].
Examples:
gramschmidt                                                                         [Function]
        gramschmidt (x)
        gramschmidt (x, F)
     Carries out the Gram-Schmidt orthogonalization algorithm on x, which is either a
     matrix or a list of lists. x is not modified by gramschmidt. The inner product
     employed by gramschmidt is F, if present, otherwise the inner product is the function
     innerproduct.
     If x is a matrix, the algorithm is applied to the rows of x. If x is a list of lists, the
     algorithm is applied to the sublists, which must have equal numbers of elements. In
     either case, the return value is a list of lists, the sublists of which are orthogonal and
     span the same space as x. If the dimension of the span of x is less than the number
     of rows or sublists, some sublists of the return value are zero.
412                                                                 Maxima 5.45.0 Manual
                                            [   a       b      ]
       •   Matrix to a scalar exponent, element by element.
             (%i7) x ^ 3;
                                             [ 4913        27 ]
             (%o7)                            [                ]
                                             [ - 512 1331 ]
       •   Scalar base to a matrix exponent, element by element.
             (%i8) exp(y);
                                             [   %pi        %e ]
                                             [ %e        %e    ]
             (%o8)                            [                ]
                                             [     a        b ]
                                             [ %e        %e    ]
       •   Matrix base to a matrix exponent. This is not carried out element by element.
           See also matrixexp.
             (%i9) x ^ y;
                                                      [ %pi %e ]
                                                      [           ]
                                                      [ a      b ]
                                         [ 17   3 ]
             (%o9)                       [           ]
                                         [ - 8 11 ]
       •   Noncommutative matrix multiplication.
             (%i10) x . y;
                                    [ 3 a + 17 %pi 3 b + 17 %e ]
             (%o10)                 [                                ]
                                    [ 11 a - 8 %pi 11 b - 8 %e ]
             (%i11) y . x;
                                  [ 17 %pi - 8 %e 3 %pi + 11 %e ]
             (%o11)               [                                    ]
                                  [ 17 a - 8 b            11 b + 3 a  ]
       •   Noncommutative matrix exponentiation. A scalar base b to a matrix power M
           is carried out element by element and so b^^m is the same as b^m.
             (%i12) x ^^ 3;
                                            [ 3833        1719 ]
             (%o12)                         [                  ]
                                            [ - 4584 395 ]
             (%i13) %e ^^ y;
                                             [    %pi       %e ]
                                             [ %e        %e    ]
             (%o13)                           [                ]
                                             [     a        b ]
                                             [ %e        %e    ]
       •   A matrix raised to a -1 exponent with noncommutative exponentiation is the
           matrix inverse, if it exists.
416                                                               Maxima 5.45.0 Manual
           (%i14) x ^^ -1;
                                         [   11        3 ]
                                         [   ---    - --- ]
                                         [   211      211 ]
           (%o14)                        [                ]
                                         [    8      17   ]
                                         [   ---     --- ]
                                         [   211     211 ]
           (%i15) x . (x ^^ -1);
                                              [ 1   0 ]
           (%o15)                             [       ]
                                              [ 0   1 ]
matrixexp                                                                      [Function]
        matrixexp (M)
        matrixexp (M, n)
        matrixexp (M, V)
      Calculates the matrix exponential eM V e( M ∗V ) . Instead of the vector V a number
      n can be specified as the second argument. If this argument is omitted matrixexp
      replaces it by 1.
      The matrix exponential of a matrix M can be expressed as a power series: eM =
      P∞ M k M
       k=0 k!  e = sum(M k /k!, 0, inf )
                                          [ u   v       w ]
           (%o4)                          [               ]
                                          [ x   y       z ]
           (%i5) aa . transpose (bb);
                                [ u v w              x    y
                                                         z ]
                                [ a b c             a    b ]  c
           (%o5)                [                          ]
                                [ u v w              x y z ]
                                [ d e f             d e f ]
matrix_element_mult                                                    [Option variable]
     Default value: *
     matrix_element_mult is the operation invoked in place of multiplication in a matrix
     multiplication. matrix_element_mult can be assigned any binary operator. The
     assigned value may be the name of an operator enclosed in quote marks, the name of
     a function, or a lambda expression.
     The dot operator . is an useful choice in some contexts.
     See also matrix_element_add and matrix_element_transpose.
     Example:
           (%i1) matrix_element_add: lambda ([[x]], sqrt (apply ("+", x)))$
           (%i2) matrix_element_mult: lambda ([x, y], (x - y)^2)$
           (%i3) [a, b, c] . [x, y, z];
                                          2            2           2
           (%o3)            sqrt((c - z) + (b - y) + (a - x) )
           (%i4) aa: matrix ([a, b, c], [d, e, f]);
                                            [ a b c ]
           (%o4)                            [          ]
                                            [ d e f ]
           (%i5) bb: matrix ([u, v, w], [x, y, z]);
                                            [ u v w ]
           (%o5)                            [          ]
                                            [ x y z ]
           (%i6) aa . transpose (bb);
                             [                2           2            2 ]
                             [ sqrt((c - w) + (b - v) + (a - u) ) ]
           (%o6) Col 1 = [                                                ]
                             [                2           2            2 ]
                             [ sqrt((f - w) + (e - v) + (d - u) ) ]
                                      [             2         2         2             ]
                                      [ sqrt((c - z) + (b - y) + (a - x) )            ]
                              Col 2 = [                                               ]
                                      [             2         2         2             ]
                                      [ sqrt((f - z) + (e - y) + (d - x) )            ]
matrix_element_transpose                                               [Option variable]
     Default value: false
418                                                                Maxima 5.45.0 Manual
submatrix                                                                           [Function]
        submatrix (i_1, . . . , i_m, M, j_1, . . . , j_n)
        submatrix (i_1, . . . , i_m, M)
        submatrix (M, j_1, . . . , j_n)
     Returns a new matrix composed of the matrix M with rows i 1, . . . , i m deleted,
     and columns j 1, . . . , j n deleted.
      correct value. The author assumes that the user knows what he is doing and will not
      try to diagonalize a matrix the eigenvectors of which do not span the vector space of
      the appropriate dimension.
      load ("eigen") loads this function.
      ueivects is a synonym for uniteigenvectors.
24 Affine
25 itensor
the homogeneous and isotropic case (Friedmann equations) and the spherically symmet-
ric, static case (Schwarzschild solution.) The second, bradic.dem, demonstrates how to
compute the Friedmann equations from the action of Brans-Dicke gravity theory, and also
derives the Hamiltonian associated with the theory’s scalar field.
      (%o6)                                 [v(t)]
      (%i7) ishow(diff(v([i],[]),t))$
                                            d
      (%t7)                                 -- (v )
                                            dt   i
      (%i8) ishow(idiff(v([i],[]),j))$
      (%t8)                                  v
                                              i,j
      (%i9) ishow(extdiff(v([i],[]),j))$
      (%t9)                              v     - v
                                          j,i      i,j
                                         -----------
                                               2
      (%i10) ishow(liediff(v,w([i],[])))$
                                     %3             %3
      (%t10)                        v    w       + v    w
                                          i,%3      ,i %3
      (%i11) ishow(covdiff(v([i],[]),j))$
                                                       %4
      (%t11)                        v      - v    ichr2
                                     i,j      %4       i j
      (%i12) ishow(ev(%,ichr2))$
                      %4 %5
      (%t12) v    - (g      v   (e p         + e     p     - e p       - e    p
              i,j            %4     j %5,i       ,i j %5        i j,%5    ,%5 i j
                                                + e p       + e   p    ))/2
                                                     i %5,j    ,j i %5
      (%i13) iframe_flag:true;
      (%o13)                                 true
      (%i14) ishow(covdiff(v([i],[]),j))$
                                                    %6
      (%t14)                         v    - v   icc2
                                      i,j    %6     i j
      (%i15) ishow(ev(%,icc2))$
                                                   %6
      (%t15)                        v    - v   ifc2
                                     i,j    %6     i j
      (%i16) ishow(radcan(ev(%,ifc2,ifc1)))$
                   %6 %7                    %6 %7
      (%t16) - (ifg      v   ifb       + ifg      v    ifb       - 2 v
                          %6    j %7 i             %6     i j %7      i,j
                                                   %6 %7
                                              - ifg      v   ifb       )/2
                                                          %6    %7 i j
      (%i17) ishow(canform(s([i,j],[])-s([j,i])))$
Chapter 25: itensor                                                                      433
     (%t17)                            s    - s
                                        i j    j i
     (%i18) decsym(s,2,0,[sym(all)],[]);
     (%o18)                               done
     (%i19) ishow(canform(s([i,j],[])-s([j,i])))$
     (%t19)                                 0
     (%i20) ishow(canform(a([i,j],[])+a([j,i])))$
     (%t20)                            a    + a
                                        j i    i j
     (%i21) decsym(a,2,0,[anti(all)],[]);
     (%o21)                               done
     (%i22) ishow(canform(a([i,j],[])+a([j,i])))$
     (%t22)                                 0
listoftens                                                                         [Function]
     Lists all tensors in a tensorial expression, complete with their indices. E.g.,
           (%i6) ishow(a([i,j],[k])*b([u],[],v)+c([x,y],[])*d([],[])*e)$
                                                      k
           (%t6)                        d e c     + a     b
                                             x y      i j u,v
           (%i7) ishow(listoftens(%))$
                                          k
           (%t7)                        [a    , b    , c    , d]
                                          i j    u,v    x y
434                                                                   Maxima 5.45.0 Manual
            (%i1) load("itensor");
            (%o1)      /share/tensor/itensor.lisp
            (%i2) ishow(a([i,j],[k,l],m,n)*b([k,o],[j,m,p],q,r))$
                                            k l      j m p
            (%t2)                          a        b
                                            i j,m n k o,q r
            (%i3) indices(%);
            (%o3)                 [[l, p, i, n, o, q, r], [k, j, m]]
      A tensor product containing the same index more than twice is syntactically illegal.
      indices attempts to deal with these expressions in a reasonable manner; however,
      when it is called to operate upon such an illegal expression, its behavior should be
      considered undefined.
rename                                                                              [Function]
          rename (expr)
          rename (expr, count)
      Returns an expression equivalent to expr but with the dummy indices in each term
      chosen from the set [%1, %2,...], if the optional second argument is omitted. Oth-
      erwise, the dummy indices are indexed beginning at the value of count. Each dummy
      index in a product will be different. For a sum, rename will operate upon each term
      in the sum resetting the counter with each term. In this way rename can serve as a
      tensorial simplifier. In addition, the indices will be sorted alphanumerically (if allsym
      is true) with respect to covariant or contravariant indices depending upon the value
      of flipflag. If flipflag is false then the indices will be renamed according to
      the order of the contravariant indices. If flipflag is true the renaming will occur
      according to the order of the covariant indices. It often happens that the combined
      effect of the two renamings will reduce an expression more than either one by itself.
            (%i1) load("itensor");
            (%o1)      /share/tensor/itensor.lisp
            (%i2) allsym:true;
            (%o2)                                true
            (%i3) g([],[%4,%5])*g([],[%6,%7])*ichr2([%1,%4],[%3])*
            ichr2([%2,%3],[u])*ichr2([%5,%6],[%1])*ichr2([%7,r],[%2])-
            g([],[%4,%5])*g([],[%6,%7])*ichr2([%1,%2],[u])*
Chapter 25: itensor                                                                     435
           ichr2([%3,%5],[%1])*ichr2([%4,%6],[%3])*ichr2([%7,r],[%2]),noeval$
           (%i4) expr:ishow(%)$
                   %4 %5 %6 %7       %3         u          %1         %2
           (%t4) g      g      ichr2      ichr2      ichr2      ichr2
                                    %1 %4      %2 %3      %5 %6      %7 r
                       %4 %5       %6 %7         u          %1         %3         %2
                 - g           g           ichr2      ichr2      ichr2      ichr2
                                                %1 %2      %3 %5      %4 %6      %7 r
           (%i5) flipflag:true;
           (%o5)                                 true
           (%i6) ishow(rename(expr))$
                   %2 %5 %6 %7       %4         u           %1         %3
           (%t6) g      g      ichr2      ichr2       ichr2      ichr2
                                    %1 %2      %3 %4       %5 %6      %7 r
                       %4 %5       %6 %7
                                      u            %1           %3          %2
                 - g           gichr2        ichr2        ichr2       ichr2
                                      %1 %2        %3 %4        %5 %6       %7 r
           (%i7) flipflag:false;
           (%o7)                                   false
           (%i8) rename(%th(2));
           (%o8)                                      0
           (%i9) ishow(rename(expr))$
                   %1 %2 %3 %4       %5           %6           %7         u
           (%t9) g      g      ichr2        ichr2        ichr2      ichr2
                                    %1 %6        %2 %3        %4 r       %5 %7
                       %1 %2       %3 %4         %6         %5         %7        u
                 - g           g           ichr2      ichr2      ichr2     ichr2
                                                %1 %3      %2 %6      %4 r      %5 %7
defcon                                                                           [Function]
          defcon (tensor_1)
          defcon (tensor_1, tensor_2, tensor_3)
      gives tensor 1 the property that the contraction of a product of tensor 1 and tensor 2
      results in tensor 3 with the appropriate indices. If only one argument, tensor 1, is
      given, then the contraction of the product of tensor 1 with any indexed object having
      the appropriate indices (say my_tensor) will yield an indexed object with that name,
      i.e. my_tensor, and with a new set of indices reflecting the contractions performed.
      For example, if imetric:g, then defcon(g) will implement the raising and lowering
      of indices through contraction with the metric tensor. More than one defcon can be
      given for the same indexed object; the latest one given which applies in a particular
      contraction will be used. contractions is a list of those indexed objects which have
      been given contraction properties with defcon.
remcon                                                                           [Function]
          remcon (tensor_1, ..., tensor_n)
          remcon (all)
      Removes all the contraction properties from the (tensor 1, ..., tensor n). remcon(all)
      removes all contraction properties from all indexed objects.
contract (expr)                                                                 [Function]
      Carries out the tensorial contractions in expr which may be any combination of sums
      and products. This function uses the information given to the defcon function. For
      best results, expr should be fully expanded. ratexpand is the fastest way to expand
      products and powers of sums if there are no variables in the denominators of the
      terms. The gcd switch should be false if GCD cancellations are unnecessary.
indexed_tensor (tensor)                                                        [Function]
      Must be executed before assigning components to a tensor for which a built in value
      already exists as with ichr1, ichr2, icurvature. See the example under icurvature.
components (tensor, expr)                                                         [Function]
      permits one to assign an indicial value to an expression expr giving the values of the
      components of tensor. These are automatically substituted for the tensor whenever
      it occurs with all of its indices. The tensor must be of the form t([...],[...])
      where either list may be empty. expr can be any indexed expression involving other
      objects with the same free indices as tensor. When used to assign values to the metric
      tensor wherein the components contain dummy indices one must be careful to define
      these indices to avoid the generation of multiple dummy indices. Removal of this
      assignment is given to the function remcomps.
      It is important to keep in mind that components cares only about the valence of a
      tensor, not about any particular index ordering. Thus assigning components to, say,
      x([i,-j],[]), x([-j,i],[]), or x([i],[j]) all produce the same result, namely
      components being assigned to a tensor named x with valence (1,1).
      Components can be assigned to an indexed expression in four ways, two of which
      involve the use of the components command:
      1) As an indexed expression. For instance:
             (%i2) components(g([],[i,j]),e([],[i])*p([],[j]))$
Chapter 25: itensor                                                                    437
           (%i3) ishow(g([],[i,j]))$
                                                         i j
           (%t3)                                        e p
2) As a matrix:
           (%i5) lg:-ident(4)$lg[1,1]:1$lg;
                                       [ 1   0   0              0  ]
                                       [                           ]
                                       [ 0 - 1   0              0 ]
           (%o5)                       [                           ]
                                       [ 0   0  - 1             0 ]
                                       [                           ]
                                       [ 0   0   0             - 1 ]
           (%i6) components(g([i,j],[]),lg);
           (%o6)                               done
           (%i7) ishow(g([i,j],[]))$
           (%t7)                               g
                                                i j
           (%i8) g([1,1],[]);
           (%o8)                                 1
           (%i9) g([4,4],[]);
           (%o9)                                - 1
     3) As a function. You can use a Maxima function to specify the components of a
     tensor based on its indices. For instance, the following code assigns kdelta to h if h
     has the same number of covariant and contravariant indices and no derivative indices,
     and g otherwise:
           (%i1) load("itensor");
           (%o1)      /share/tensor/itensor.lisp
           (%i2) matchdeclare(l1,listp);
           (%o2)                                done
438                                                                   Maxima 5.45.0 Manual
            (%i3) defrule(r1,m(l1,[]),(i1:idummy(),
                  g([l1[1],l1[2]],[])*q([i1],[])*e([],[i1])))$
            (%i4) defrule(r2,m([],l1),(i1:idummy(),
                  w([],[l1[1],l1[2]])*e([i1],[])*q([],[i1])))$
            (%i5) ishow(m([i,n],[])*m([],[i,m]))$
                                                 i m
            (%t5)                               m    m
                                                      i n
            (%i6) ishow(rename(applyb1(%,r1,r2)))$
                                       %1 %2 %3 m
            (%t6)                     e   q   w      q    e g
                                                      %1 %2 %3 n
            (%i1) load(ctensor);
            (%o1)       /share/tensor/ctensor.mac
            (%i2) load("itensor");
            (%o2)      /share/tensor/itensor.lisp
            (%i3) lg:matrix([sqrt(r/(r-2*m)),0,0,0],[0,r,0,0],
                            [0,0,sin(theta)*r,0],[0,0,0,sqrt((r-2*m)/r)]);
                    [         r                                     ]
                    [ sqrt(-------) 0        0              0       ]
                    [      r - 2 m                                  ]
                    [                                               ]
                    [       0        r       0              0       ]
            (%o3)   [                                               ]
                    [       0        0 r sin(theta)         0       ]
                    [                                               ]
                    [                                      r - 2 m ]
                    [       0        0       0        sqrt(-------) ]
                    [                                         r     ]
            (%i4) components(g([i,j],[]),lg);
            (%o4)                                done
            (%i5) showcomps(g([i,j],[]));
                         [         r                                     ]
                         [ sqrt(-------) 0        0              0       ]
                         [      r - 2 m                                  ]
                         [                                               ]
Chapter 25: itensor                                                                       439
                          [          0           r         0                  0     ]
            (%t5) g     = [                                                         ]
                    i j   [          0           0   r sin(theta)           0       ]
                          [                                                         ]
                          [                                                r - 2 m ]
                          [          0           0         0          sqrt(-------) ]
                          [                                                   r     ]
            (%o5)                                         false
     The showcomps command can also display components of a tensor of rank higher than
     2.
idummy ()                                                                       [Function]
     Increments icounter and returns as its value an index of the form %n where n is
     a positive integer. This guarantees that dummy indices which are needed in form-
     ing expressions will not conflict with indices already in use (see the example under
     indices).
            (%i1) load("itensor");
            (%o1)      /share/tensor/itensor.lisp
            (%i2) kdelta([1,2],[2,1]);
            (%o2)                                 - 1
            (%i3) kdels([1,2],[2,1]);
440                                                                 Maxima 5.45.0 Manual
            (%o3)                                 1
            (%i4) ishow(kdelta([a,b],[c,d]))$
                                         c      d        d      c
            (%t4)                  kdelta kdelta - kdelta kdelta
                                         a      b        a      b
            (%i4) ishow(kdels([a,b],[c,d]))$
                                         c      d        d      c
            (%t4)                  kdelta kdelta + kdelta kdelta
                                         a      b        a      b
            (%i1) load("itensor");
            (%o1)      /share/tensor/itensor.lisp
            (%i2) expr:ishow('levi_civita([],[i,j])
                             *'levi_civita([k,l],[])*a([j],[k]))$
                                              i j k
            (%t2)                  levi_civita    a levi_civita
                                                   j            k l
            (%i3) ishow(ev(expr,levi_civita))$
                                              i j k        1 2
            (%t3)                       kdelta    a kdelta
                                              1 2 j        k l
            (%i4) ishow(ev(%,kdelta))$
                         i       j         j       i   k
            (%t4) (kdelta kdelta - kdelta kdelta ) a
                         1       2         1       2   j
                                                  1        2      1    2
                                    (kdelta kdelta - kdelta kdelta )
                                           k      l        k      l
            (%i5) ishow(lc2kdt(expr))$
                                 k       i      j   k       j      i
            (%t5)               a kdelta kdelta - a kdelta kdelta
Chapter 25: itensor                                                                      441
                                      j       k          l      j         k     l
            (%i6) ishow(contract(expand(%)))$
                                                    i              i
            (%t6)                                 a - a kdelta
                                                    l              l
       The lc2kdt function sometimes makes use of the metric tensor. If the metric tensor
       was not defined previously with imetric, this results in an error.
             (%i7) expr:ishow('levi_civita([],[i,j])
                              *'levi_civita([],[k,l])*a([j,k],[]))$
                                              i j            k l
             (%t7)                 levi_civita    levi_civita    a
                                                                  j k
             (%i8) ishow(lc2kdt(expr))$
             Maxima encountered a Lisp error:
             Automatically continuing.
             To re-enable the Lisp debugger set *debugger-hook* to nil.
             (%i9) imetric(g);
             (%o9)                                 done
             (%i10) ishow(lc2kdt(expr))$
                      %3 i       k   %4 j       l      %3 i         l   %4 j
             (%t10) (g     kdelta   g     kdelta    - g       kdelta   g
                                 %3             %4                  %3
                           k
                     kdelta ) a
                           %4   j k
             (%i11) ishow(contract(expand(%)))$
                                               l i     l i j
             (%t11)                           a     - g     a
                                                             j
lc_l                                                                               [Function]
       Simplification rule used for expressions containing the unevaluated Levi-Civita symbol
       (levi_civita). Along with lc_u, it can be used to simplify many expressions more
       efficiently than the evaluation of levi_civita. For example:
             (%i1) load("itensor");
             (%o1)      /share/tensor/itensor.lisp
             (%i2) el1:ishow('levi_civita([i,j,k],[])*a([],[i])*a([],[j]))$
                                          i j
             (%t2)                       a a levi_civita
                                                          i j k
             (%i3) el2:ishow('levi_civita([],[i,j,k])*a([i])*a([j]))$
442                                                                  Maxima 5.45.0 Manual
                                                      i j k
             (%t3)                         levi_civita      a a
                                                             i j
             (%i4)   canform(contract(expand(applyb1(el1,lc_l,lc_u))));
             (%t4)                                    0
             (%i5)   canform(contract(expand(applyb1(el2,lc_l,lc_u))));
             (%t5)                                    0
lc_u                                                                               [Function]
       Simplification rule used for expressions containing the unevaluated Levi-Civita symbol
       (levi_civita). Along with lc_u, it can be used to simplify many expressions more
       efficiently than the evaluation of levi_civita. For details, see lc_l.
     be null. The function which performs the simplifications is canform as the example
     below illustrates.
           (%i1) load("itensor");
           (%o1)      /share/tensor/itensor.lisp
           (%i2) expr:contract( expand( a([i1, j1, k1], [])
                      *kdels([i, j, k], [i1, j1, k1])))$
           (%i3) ishow(expr)$
           (%t3)         a      + a      + a      + a      + a      + a
                          k j i    k i j    j k i    j i k    i k j    i j k
           (%i4) decsym(a,3,0,[sym(all)],[]);
           (%o4)                                done
           (%i5) ishow(canform(expr))$
           (%t5)                              6 a
                                                 i j k
           (%i6) remsym(a,3,0);
           (%o6)                                done
           (%i7) decsym(a,3,0,[anti(all)],[]);
           (%o7)                                done
           (%i8) ishow(canform(expr))$
           (%t8)                                  0
           (%i9) remsym(a,3,0);
           (%o9)                                done
           (%i10) decsym(a,3,0,[cyc(all)],[]);
           (%o10)                               done
           (%i11) ishow(canform(expr))$
           (%t11)                        3 a      + 3 a
                                            i k j      i j k
           (%i12) dispsym(a,3,0);
           (%o12)                     [[cyc, [[1, 2, 3]], []]]
canform                                                                       [Function]
          canform (expr)
          canform (expr, rename)
     Simplifies expr by renaming dummy indices and reordering all indices as dictated by
     symmetry conditions imposed on them. If allsym is true then all indices are assumed
     symmetric, otherwise symmetry information provided by decsym declarations will
     be used. The dummy indices are renamed in the same manner as in the rename
     function. When canform is applied to a large expression the calculation may take a
     considerable amount of time. This time can be shortened by calling rename on the
     expression first. Also see the example under decsym. Note: canform may not be able
444                                                                   Maxima 5.45.0 Manual
      to reduce an expression completely to its simplest form although it will always return
      a mathematically correct result.
      The optional second parameter rename, if set to false, suppresses renaming.
            (%i1) load("itensor");
            (%o1)       /share/tensor/itensor.lisp
            (%i2) ishow(liediff(v,a([i,j],[])*b([],[k],l)))$
                    k     %2              %2          %2
            (%t2) b    (v    a        + v    a    + v    a   )
                    ,l         i j,%2     ,j i %2     ,i %2 j
                                           %1 k         %1 k      %1 k
                                       + (v   b      - b   v   + v   b   ) a
                                               ,%1 l    ,l ,%1    ,l ,%1    i j
Chapter 25: itensor                                                                            445
           Automatically continuing.
           To re-enable the Lisp debugger set *debugger-hook* to nil.
     However, if icurvature is entered in noun form, it can be evaluated using evundiff:
           (%i3) ishow('icurvature([i,j,k],[l],m))$
                                                               l
           (%t3)                                     icurvature
                                                               i j k,m
           (%i4) ishow(evundiff(%))$
                        l              l         %1           l           %1
           (%t4) - ichr2        - ichr2     ichr2      - ichr2       ichr2
                        i k,j m        %1 j      i k,m        %1 j,m      i k
                             l                   l              %1                l                %1
                   + ichr2             + ichr2          ichr2           + ichr2            ichr2
                             i j,k m             %1 k           i j,m             %1 k,m           i j
     Note: In earlier versions of Maxima, derivative forms of the Christoffel-symbols also
     could not be evaluated. This has been fixed now, so evundiff is no longer necessary
     for expressions like this:
           (%i5) imetric(g);
           (%o5)                                 done
           (%i6) ishow(ichr2([i,j],[k],l))$
                   k %3
                 g      (g         - g         + g         )
                          j %3,i l    i j,%3 l    i %3,j l
446                                                                   Maxima 5.45.0 Manual
            (%t6) -----------------------------------------
                                      2
                                           k %3
                                          g     (g       - g        + g       )
                                           ,l     j %3,i     i j,%3    i %3,j
                                        + -----------------------------------
                                                           2
            (%i1) load("itensor");
            (%o1)      /share/tensor/itensor.lisp
            (%i2) ishow(a([i],[J,r],k,r)+a([i],[j,r,s],k,r,s))$
                                            J r      j r s
            (%t2)                          a      + a
                                            i,k r    i,k r s
            (%i3) ishow(flushnd(%,a,3))$
                                                 J r
            (%t3)                               a
                                                 i,k r
remcoord                                                                            [Function]
        remcoord (tensor_1, tensor_2, ...)
        remcoord (all)
      Removes the coordinate differentiation property from the tensor_i that was estab-
      lished by the function coord. remcoord(all) removes this property from all indexed
      objects.
             (%i1) load("itensor");
             (%o1)      /share/tensor/itensor.lisp
             (%i2) ishow(g([],[a,b],c))$
                                                                              a b
             (%t2)                                                           g
                                                                              ,c
             (%i3) ishow(conmetderiv(%,g))$
                                      %1 b      a       %1 a      b
             (%t3)                 - g     ichr2     - g     ichr2
                                                %1 c              %1 c
simpmetderiv                                                                                    [Function]
        simpmetderiv (expr)
        simpmetderiv (expr[, stop])
     Simplifies expressions containing products of the derivatives of the metric tensor.
     Specifically, simpmetderiv recognizes two identities:
                  ab                  ab                     ab                      a
              g        g        + g        g          = (g        g     )   = (kdelta )   = 0
                  ,d       bc                  bc,d                   bc ,d          c ,d
hence
                  ab                    ab
              g        g        = - g          g
                  ,d       bc                      bc,d
     and
              ab         ab
             g   g    = g   g
              ,j ab,i    ,i ab,j
      the following example that explicitly uses the partial simplification features of
      simpmetderiv to obtain a contractible expression:
            (%i1) load("itensor");
            (%o1)      /share/tensor/itensor.lisp
            (%i2) imetric(g);
            (%o2)                                done
            (%i3) ishow(g([],[a,b])*g([],[b,c])*g([a,b],[],d)*g([b,c],[],e))$
                                         a b b c
            (%t3)                       g    g    g      g
                                                   a b,d b c,e
            (%i4) ishow(canform(%))$
      See also weyl.dem for an example that uses simpmetderiv and conmetderiv together
      to simplify contractions of the Weyl tensor.
           (%i1) load("itensor");
           (%o1)      /share/tensor/itensor.lisp
           (%i2) entertensor()$
           Enter tensor name: a;
           Enter a list of the covariant indices: [i,j];
           Enter a list of the contravariant indices: [k];
           Enter a list of the derivative indices: [];
                                                 k
           (%t2)                                a
450                                                                 Maxima 5.45.0 Manual
                                                          i j
            (%i3) ishow(covdiff(%,s))$
                         k         %1     k         %1     k
            (%t3)     - a     ichr2    - a     ichr2    + a
                         i %1      j s    %1 j      i s    i j,s
                             k        %1
                   + ichr2        a
                           %1 s i j
            (%i4) imetric:g;
            (%o4)                                       g
            (%i5) ishow(ev(%th(2),ichr2))$
                     %1 %4 k
                    g        a      (g        - g        + g       )
                              i %1    s %4,j     j s,%4     j %4,s
            (%t5) - ------------------------------------------
                                            2
                %1 %3 k
               g       a       (g        - g       + g       )
                        %1 j     s %3,i     i s,%3    i %3,s
             - ------------------------------------------
                                      2
                k %2 %1
               g      a     (g          - g        + g         )
                       i j    s %2,%1      %1 s,%2    %1 %2,s       k
             + ------------------------------------------- + a
                                       2                            i j,s
            (%i6)
            (%i1) load("itensor");
            (%o1)      /share/tensor/itensor.lisp
            (%i2) ishow(icurvature([r,s,t],[u]))$
                         u            u         %1         u
            (%t2) - ichr2      - ichr2     ichr2    + ichr2
                         r t,s        %1 s      r t        r s,t
Chapter 25: itensor                                                                            451
                                                                       u              %1
                                                             + ichr2          ichr2
                                                                       %1 t           r s
            (%i3) ishow(igeodesic_coords(%,ichr2))$
                                             u            u
            (%t3)                       ichr2      - ichr2
                                             r s,t        r t,s
            (%i4) ishow(igeodesic_coords(icurvature([r,s,t],[u]),ichr2)+
                        igeodesic_coords(icurvature([s,t,r],[u]),ichr2)+
                        igeodesic_coords(icurvature([t,r,s],[u]),ichr2))$
                         u            u            u            u
            (%t4) - ichr2      + ichr2      + ichr2      - ichr2
                         t s,r        t r,s        s t,r        s r,t
                                                                      u                    u
                                                            - ichr2           + ichr2
                                                                      r t,s                r s,t
            (%i5) canform(%);
            (%o5)                                            0
      (%i1) load("itensor");
452                                                                 Maxima 5.45.0 Manual
      (%o1)      /share/tensor/itensor.lisp
      (%i2) iframe_flag:true;
      (%o2)                                 true
      (%i3) ishow(covdiff(v([],[i]),j))$
                                     i          i     %1
      (%t3)                         v    + icc2      v
                                     ,j         %1 j
      (%i4) ishow(ev(%,icc2))$
                                     %1      i        i
      (%t4)                         v    ifc2      + v
                                             %1 j     ,j
      (%i5) ishow(ev(%,ifc2))$
                                %1     i %2                  i
      (%t5)                    v   ifg      ifc1          + v
                                                 %1 j %2     ,j
      (%i6) ishow(ev(%,ifc1))$
                  %1    i %2
                 v   ifg     (ifb         - ifb          + ifb         )
                                 j %2 %1        %2 %1 j        %1 j %2   i
      (%t6)      -------------------------------------------------- + v
                                          2                              ,j
      (%i7) ishow(ifb([a,b,c]))$
                                                            %3     %4
      (%t7)               (ifri         - ifri         ) ifr    ifr
                               a %3,%4         a %4,%3      b      c
   An alternate method is used to compute the frame bracket (ifb) if the iframe_bracket_
form flag is set to false:
      (%i8) block([iframe_bracket_form:false],ishow(ifb([a,b,c])))$
                                      %6    %5        %5      %6
      (%t8)              ifri     (ifr   ifr     - ifr     ifr )
                             a %5     b     c,%6      b,%6    c
iframes ()                                                                     [Function]
      Since in this version of Maxima, contraction identities for ifr and ifri are always
      defined, as is the frame bracket (ifb), this function does nothing.
ifb                                                                              [Variable]
      The frame bracket. The contribution of the frame metric to the connection coefficients
      is expressed using the frame bracket:
       The frame bracket itself is defined in terms of the frame field and frame metric.
       Two alternate methods of computation are used depending on the value of frame_
       bracket_form. If true (the default) or if the itorsion_flag is true:
                      d           e                                                     f
             ifb = ifr         ifr     (ifri           - ifri           - ifri       itr    )
                abc    b           c           a d,e            a e,d            a f     d e
Otherwise:
                             e       d         d       e
             ifb       = (ifr     ifr     - ifr     ifr          ) ifri
                   abc        b       c,e       b,e     c                 a d
icc1                                                                                      [Variable]
       Connection coefficients of the first kind. In itensor, defined as
                 c         c        c         c
             icc2   = ichr2   - ikt2   - inmc2
                 ab        ab       ab        ab
ifc2                                                                              [Variable]
       Frame coefficient of the second kind. This tensor represents the contribution of the
       frame metric to the connection coefficient of the second kind. Defined as a permu-
       tation of the frame bracket (ifb) with the appropriate indices raised and lowered as
       necessary:
                 c       cd
             ifc2   = ifg   ifc1
                 ab             abd
ifr                                                                           [Variable]
       The frame field. Contracts with the inverse frame field (ifri) to form the frame
       metric (ifg).
ifri                                                                                [Variable]
       The inverse frame field. Specifies the frame base (dual basis vectors). Along with the
       frame metric, it forms the basis of all calculations based on frames.
ifg                                                                           [Variable]
       The frame metric. Defaults to kdelta, but can be changed using components.
ifgi                                                                           [Variable]
       The inverse frame metric. Contracts with the frame metric (ifg) to kdelta.
iframe_bracket_form                                                          [Option variable]
       Default value: true
       Specifies how the frame bracket (ifb) is computed.
             g     =- g inm
              ij;k     ij  k
Chapter 25: itensor                                                                      455
inmc1                                                                              [Variable]
       Covariant permutation of the nonmetricity vector components. Defined as
                                   c         c         cd
                         -inmkdelta - kdelta inm + g      inm g
                  c        a       b          a   b          d ab
             inmc2   = -------------------------------------------
                  ab                        2
                               d            d        d
                         -g itr - g      itr    - itr   g
                         ad    cb    bd      ca       ab cd
             ikt1    = ----------------------------------
                 abc                    2
                 c     cd
             ikt2   = g   ikt1
                 ab           abd
      (%i1) load("itensor");
      (%o1)      /share/tensor/itensor.lisp
      (%i2) imetric:g;
      (%o2)                                         g
      (%i3) covdiff( covdiff( f( [], []), i), j)
                             - covdiff( covdiff( f( [], []), j), i)$
      (%i4) ishow(%)$
                                              %4                   %2
      (%t4)                      f      ichr2       - f       ichr2
                                  ,%4         j i       ,%2        i j
      (%i5) canform(%);
      (%o5)                                         0
      (%i6) itorsion_flag:true;
      (%o6)                                      true
      (%i7) covdiff( covdiff( f( [], []), i), j)
                             - covdiff( covdiff( f( [], []), j), i)$
      (%i8) ishow(%)$
                                    %8                  %6
      (%t8)             f     icc2       - f      icc2        - f      + f
                         ,%8        j i      ,%6        i j      ,j i      ,i j
      (%i9) ishow(canform(%))$
                                              %1                  %1
      (%t9)                       f      icc2       - f       icc2
                                    ,%1       j i       ,%1       i j
      (%i10) ishow(canform(ev(%,icc2)))$
                                              %1                  %1
      (%t10)                       f     ikt2       - f       ikt2
                                    ,%1       i j       ,%1       j i
      (%i11) ishow(canform(ev(%,ikt2)))$
                             %2 %1                             %2 %1
      (%t11)          f    g         ikt1           - f       g       ikt1
                       ,%2                i j %1        ,%2                j i %1
      (%i12) ishow(factor(canform(rename(expand(ev(%,ikt1))))))$
                                    %3 %2                  %1         %1
                           f      g        g         (itr       - itr    )
                             ,%3             %2 %1         j i        i j
      (%t12)               ------------------------------------
                                                  2
      (%i13) decsym(itr,2,1,[anti(all)],[]);
      (%o13)                                     done
      (%i14) defcon(g,g,kdelta);
      (%o14)                                     done
      (%i15) subst(g,nounify(g),%th(3))$
      (%i16) ishow(canform(contract(%)))$
                                                         %1
      (%t16)                               - f        itr
                                               ,%1       i j
Chapter 25: itensor                                                                      457
~                                                                               [Operator]
      The wedge product operator is denoted by the tilde ~. This is a binary operator. Its
      arguments should be expressions involving scalars, covariant tensors of rank one, or
      covariant tensors of rank l that have been declared antisymmetric in all covariant
      indices.
      The behavior of the wedge product operator is controlled by the igeowedge_flag
      flag, as in the following example:
             (%i1) load("itensor");
             (%o1)      /share/tensor/itensor.lisp
             (%i2) ishow(a([i])~b([j]))$
                                              a b           - b   a
458                                                                  Maxima 5.45.0 Manual
                                                i j     i j
            (%t2)                              -------------
                                                     2
            (%i3)   decsym(a,2,0,[anti(all)],[]);
            (%o3)                                  done
            (%i4)   ishow(a([i,j])~b([k]))$
                                        a    b + b a      - a    b
                                         i j k     i j k     i k j
            (%t4)                       ---------------------------
                                                     3
            (%i5)   igeowedge_flag:true;
            (%o5)                                  true
            (%i6)   ishow(a([i])~b([j]))$
            (%t6)                              a b - b a
                                                i j     i j
            (%i7)   ishow(a([i,j])~b([k]))$
            (%t7)                       a    b + b a      - a    b
                                         i j k     i j k     i k j
|                                                                                 [Operator]
      The vertical bar | denotes the "contraction with a vector" binary operation. When a
      totally antisymmetric covariant tensor is contracted with a contravariant vector, the
      result is the same regardless which index was used for the contraction. Thus, it is
      possible to define the contraction operation in an index-free manner.
      In the itensor package, contraction with a vector is always carried out with respect
      to the first index in the literal sorting order. This ensures better simplification of
      expressions involving the | operator. For instance:
             (%i1) load("itensor");
             (%o1)        /share/tensor/itensor.lisp
             (%i2) decsym(a,2,0,[anti(all)],[]);
             (%o2)                                        done
             (%i3) ishow(a([i,j],[])|v)$
                                                         %1
             (%t3)                                      v    a
                                                              %1 j
             (%i4) ishow(a([j,i],[])|v)$
                                                          %1
             (%t4)                                     - v     a
                                                                %1 j
      Note that it is essential that the tensors used with the | operator be declared totally
      antisymmetric in their covariant indices. Otherwise, the results will be incorrect.
           (%i1) load("itensor");
           (%o1)      /share/tensor/itensor.lisp
           (%i2) ishow(extdiff(v([i]),j))$
                                             v       - v
                                               j,i      i,j
           (%t2)                              -----------
                                                    2
           (%i3) decsym(a,2,0,[anti(all)],[]);
           (%o3)                                  done
           (%i4) ishow(extdiff(a([i,j]),k))$
                                      a       - a        + a
                                       j k,i      i k,j     i j,k
           (%t4)                      ------------------------
                                                   3
           (%i5) igeowedge_flag:true;
           (%o5)                                  true
           (%i6) ishow(extdiff(v([i]),j))$
           (%t6)                              v      - v
                                               j,i      i,j
           (%i7) ishow(extdiff(a([i,j]),k))$
           (%t7)                    - (a        - a       + a      )
                                        k j,i      k i,j     j i,k
           (%i1)   load("itensor");
           (%o1)        /share/tensor/itensor.lisp
           (%i2)   imetric(g);
           (%o2)                              done
           (%i3)   idim(4);
           (%o3)                              done
           (%i4)   icounter:100;
           (%o4)                               100
           (%i5)   decsym(A,3,0,[anti(all)],[])$
           (%i6) ishow(A([i,j,k],[]))$
           (%t6)                               A
                                                i j k
           (%i7) ishow(canform(hodge(%)))$
                                     %1 %2 %3 %4
                          levi_civita            g        A
                                                  %1 %102 %2 %3 %4
           (%t7)          -----------------------------------------
                                              6
           (%i8) ishow(canform(hodge(%)))$
460                                                                  Maxima 5.45.0 Manual
                             %1 %2 %3 %8            %4 %5 %6 %7
            (%t8) levi_civita            levi_civita            g
                                                                 %1 %106
                                         g        g        g      A      /6
                                          %2 %107 %3 %108 %4 %8 %5 %6 %7
            (%i9) lc2kdt(%)$
(%i10) %,kdelta$
            (%i11) ishow(canform(contract(expand(%))))$
            (%t11)                     - A
                                          %106 %107 %108
                                                                             i
                                                                      + ichr2
                                                                             j k,l
            (%i5) tentex(%)$
            $$\Gamma_{j\,k}^{m_1}\,\Gamma_{l\,m_1}^{i}-\Gamma_{j\,l}^{m_1}\,
             \Gamma_{k\,m_1}^{i}-\Gamma_{j\,l,k}^{i}+\Gamma_{j\,k,l}^{i}$$
Chapter 25: itensor                                                                       461
     Note the use of the idummyx assignment, to avoid the appearance of the percent sign
     in the TeX expression, which may lead to compile errors.
     NB: This version of the tentex function is somewhat experimental.
            g     , l, 1, dim), m, 1, dim)))
             l, m
           (%i4) imetric(g);
           (%o4)                                 done
           (%i5) metricconvert:true;
           (%o5)                                 true
           (%i6) ic_convert(eqn);
           (%o6) for i thru dim do (for j thru dim do (
                   for k thru dim do
                    t        : f sum(sum(diff(a , ct_coords ) b
                     i, j, k                   m           j   i, l, k
            lg       , l, 1, dim), m, 1, dim)))
                 l, m
462                                                           Maxima 5.45.0 Manual
26 ctensor
      Matrix entered.
      Enter functional dependencies with the DEPENDS function or 'N' if none
      depends([a,d],x);
      Do you wish to see the metric?
      y;
                                [ a 0         0          0 ]
                                [                           ]
                                [     2                     ]
                                [ 0 x         0          0 ]
                                [                           ]
                                [         2     2           ]
                                [ 0 0    x sin (y)       0 ]
                                [                           ]
                                [ 0 0         0         - d ]
      (%o2)                                 done
      (%i3) christof(mcs);
                                                    a
                                                     x
      (%t3)                          mcs          = ---
                                        1, 1, 1     2 a
                                                  1
      (%t4)                          mcs        = -
                                        1, 2, 2   x
                                                  1
      (%t5)                          mcs        = -
                                        1, 3, 3   x
                                                 d
                                                  x
      (%t6)                         mcs        = ---
                                       1, 4, 4   2 d
                                                   x
      (%t7)                         mcs        = - -
                                       2, 2, 1     a
                                                cos(y)
      (%t8)                        mcs        = ------
                                      2, 3, 3   sin(y)
                                                    2
                                               x sin (y)
      (%t9)                     mcs        = - ---------
                                   3, 3, 1         a
Chapter 26: ctensor                                                                    465
                                                       d
                                                        x
     (%t11)                               mcs        = ---
                                             4, 4, 1   2 a
     (%o11)                                     done
cmetric                                                                         [Function]
          cmetric (dis)
          cmetric ()
     A function in the ctensor (component tensor) package that computes the metric
     inverse and sets up the package for further calculations.
     If cframe_flag is false, the function computes the inverse metric ug from the (user-
     defined) matrix lg. The metric determinant is also computed and stored in the
     variable gdet. Furthermore, the package determines if the metric is diagonal and sets
     the value of diagmetric accordingly. If the optional argument dis is present and not
     equal to false, the user is prompted to see the metric inverse.
     If cframe_flag is true, the function expects that the values of fri (the inverse frame
     matrix) and lfg (the frame metric) are defined. From these, the frame matrix fr and
     the inverse frame metric ufg are computed.
ct_coordsys                                                                     [Function]
        ct_coordsys (coordinate_system, extra_arg)
        ct_coordsys (coordinate_system)
     Sets up a predefined coordinate system and metric. The argument coordinate system
     can be one of the following symbols:
            (%i1) load("ctensor");
            (%o1)       /share/tensor/ctensor.mac
            (%i2) ct_coordsys([r*cos(theta)*cos(phi),r*cos(theta)*sin(phi),
                  r*sin(theta),[r,theta,phi]]);
            (%o2)                                done
            (%i3) lg:trigsimp(lg);
                                       [ 1 0          0        ]
                                       [                       ]
                                       [     2                 ]
            (%o3)                      [ 0 r          0        ]
Chapter 26: ctensor                                                                    467
                                            [                        ]
                                            [           2   2        ]
                                            [ 0   0    r cos (theta) ]
           (%i4) ct_coords;
           (%o4)                                  [r, theta, phi]
           (%i5) dim;
           (%o5)                                          3
           (%i1) load("ctensor");
           (%o1)       /share/tensor/ctensor.mac
           (%i2) cframe_flag:true;
           (%o2)                                true
           (%i3) ct_coordsys([r*cos(theta)*cos(phi),r*cos(theta)*sin(phi),
                 r*sin(theta),[r,theta,phi]]);
           (%o3)                                done
           (%i4) fri;
           (%o4)
            [cos(phi)cos(theta) -cos(phi) r sin(theta) -sin(phi) r cos(theta)]
            [                                                                ]
            [sin(phi)cos(theta) -sin(phi) r sin(theta) cos(phi) r cos(theta)]
            [                                                                ]
            [    sin(theta)           r cos(theta)                0          ]
           (%i5) cmetric();
           (%o5)                                        false
           (%i6) lg:trigsimp(lg);
                                            [ 1   0           0      ]
                                            [                        ]
                                            [      2                 ]
           (%o6)                            [ 0   r         0        ]
                                            [                        ]
                                            [           2   2        ]
                                            [ 0   0    r cos (theta) ]
     The optional argument extra arg can be any one of the following:
     cylindrical tells ct_coordsys to attach an additional cylindrical coordinate.
     minkowski tells ct_coordsys to attach an additional coordinate with negative metric
     signature.
     all tells ct_coordsys to call cmetric and christof(false) after setting up the
     metric.
     If the global variable verbose is set to true, ct_coordsys displays the values of dim,
     ct_coords, and either lg or lfg and fri, depending on the value of cframe_flag.
468                                                                  Maxima 5.45.0 Manual
init_ctensor ()                                                                   [Function]
      Initializes the ctensor package.
      The init_ctensor function reinitializes the ctensor package. It removes all arrays
      and matrices used by ctensor, resets all flags, resets dim to 4, and resets the frame
      metric to the Lorentz-frame.
       lg -- ug
         \      \
          lcs -- mcs -- ric -- uric
                    \      \        \
                     \       tracer - ein -- lein
                      \
                       riem -- lriem -- weyl
                           \
                            uriem
    ctensor can also work using moving frames. When cframe_flag is set to true, the
following tensors can be calculated:
       lfg -- ufg
           \
       fri -- fr -- lcs -- mcs -- lriem -- ric -- uric
            \                       | \       \       \
             lg -- ug               |   weyl   tracer - ein -- lein
                                    |\
                                    | riem
                                    |
                                    \uriem
     The array elements mcs[i,j,k] are defined in such a manner that the final index is
     contravariant.
scurvature ()                                                                 [Function]
     Returns the scalar curvature (obtained by contracting the Ricci tensor) of the Rie-
     mannian manifold with the given metric.
      If the variable cframe_flag is false, the Riemann tensor is computed directly from
      the Christoffel-symbols. If cframe_flag is true, the covariant Riemann-tensor is
      computed first from the frame field coefficients.
rinvariant ()                                                               [Function]
      Forms the Kretschmann-invariant (kinvariant) obtained by contracting the tensors
            lriem[i,j,k,l]*uriem[i,j,k,l].
      This object is not automatically simplified since it can be very large.
          Function     Comments
          ---------------------------------
          christof()   For mcs only
          ricci()
          uricci()
          einstein()
          riemann()
          weyl()
          checkdiv()
Chapter 26: ctensor                                                                   471
ctaylor ()                                                                     [Function]
     The ctaylor function truncates its argument by converting it to a Taylor-series using
     taylor, and then calling ratdisrep. This has the combined effect of dropping terms
     higher order in the expansion variable ctayvar. The order of terms that should be
     dropped is defined by ctaypov; the point around which the series expansion is carried
     out is specified in ctaypt.
     As an example, consider a simple metric that is a perturbation of the Minkowski
     metric. Without further restrictions, even a diagonal metric produces expressions for
     the Einstein tensor that are far too complex:
           (%i1)   load("ctensor");
           (%o1)         /share/tensor/ctensor.mac
           (%i2)   ratfac:true;
           (%o2)                                     true
           (%i3)   derivabbrev:true;
           (%o3)                                     true
           (%i4)   ct_coords:[t,r,theta,phi];
           (%o4)                            [t, r, theta, phi]
           (%i5)   lg:matrix([-1,0,0,0],[0,1,0,0],[0,0,r^2,0],
                             [0,0,0,r^2*sin(theta)^2]);
                                     [ - 1 0 0              0       ]
                                     [                              ]
                                     [ 0     1 0            0       ]
                                     [                              ]
           (%o5)                      [           2                  ]
                                     [ 0     0 r            0       ]
                                     [                              ]
                                     [                 2    2       ]
                                     [ 0     0 0      r sin (theta) ]
           (%i6)   h:matrix([h11,0,0,0],[0,h22,0,0],[0,0,h33,0],[0,0,0,h44]);
                                         [ h11     0     0    0 ]
                                         [                       ]
                                         [ 0     h22     0    0 ]
           (%o6)                          [                      ]
                                         [ 0       0    h33   0 ]
                                         [                       ]
                                         [ 0       0     0   h44 ]
           (%i7)   depends(l,r);
           (%o7)                                   [l(r)]
           (%i8)   lg:lg+l*h;
                   [ h11 l - 1      0           0                  0                     ]
                   [                                                                     ]
                   [     0      h22 l + 1       0                  0                     ]
                   [                                                                     ]
           (%o8)   [                         2                                           ]
                   [     0          0       r + h33 l              0                     ]
472                                                             Maxima 5.45.0 Manual
                 [                                                                ]
                 [                                           2   2                ]
                 [     0          0              0          r sin (theta) + h44 l ]
           (%i9) cmetric(false);
           (%o9)                                     done
           (%i10) einstein(false);
           (%o10)                                    done
           (%i11) ntermst(ein);
           [[1, 1], 62]
           [[1, 2], 0]
           [[1, 3], 0]
           [[1, 4], 0]
           [[2, 1], 0]
           [[2, 2], 24]
           [[2, 3], 0]
           [[2, 4], 0]
           [[3, 1], 0]
           [[3, 2], 0]
           [[3, 3], 46]
           [[3, 4], 0]
           [[4, 1], 0]
           [[4, 2], 0]
           [[4, 3], 0]
           [[4, 4], 46]
           (%o12)                                    done
           (%i14) ctayswitch:true;
           (%o14)                                    true
           (%i15) ctayvar:l;
           (%o15)                                      l
           (%i16) ctaypov:1;
           (%o16)                                      1
           (%i17) ctaypt:0;
           (%o17)                                      0
           (%i18) christof(false);
           (%o18)                                    done
           (%i19) ricci(false);
           (%o19)                                    done
           (%i20) einstein(false);
           (%o20)                                    done
           (%i21) ntermst(ein);
           [[1, 1], 6]
           [[1, 2], 0]
Chapter 26: ctensor                                                                    473
            [[1, 3], 0]
            [[1, 4], 0]
            [[2, 1], 0]
            [[2, 2], 13]
            [[2, 3], 2]
            [[2, 4], 0]
            [[3, 1], 0]
            [[3, 2], 2]
            [[3, 3], 9]
            [[3, 4], 0]
            [[4, 1], 0]
            [[4, 2], 0]
            [[4, 3], 0]
            [[4, 4], 9]
            (%o21)                              done
            (%i22) ratsimp(ein[1,1]);
                                     2      2 4              2     2
            (%o22) - (((h11 h22 - h11 ) (l ) r - 2 h33 l    r ) sin (theta)
                                          r             r r
                                            2              2      4   2
                              - 2 h44 l    r - h33 h44 (l ) )/(4 r sin (theta))
                                       r r               r
      This capability can be useful, for instance, when working in the weak field limit far
      from a gravitational source.
nptetrad ()                                                                   [Function]
      Computes a Newman-Penrose null tetrad (np) and its raised-index counterpart (npi).
      See petrov for an example.
      The null tetrad is constructed on the assumption that a four-dimensional orthonormal
      frame metric with metric signature (-,+,+,+) is being used. The components of the
      null tetrad are related to the inverse frame matrix as follows:
petrov ()                                                                       [Function]
      Computes the Petrov classification of the metric characterized by psi[0]...psi[4].
      For example, the following demonstrates how to obtain the Petrov-classification of
      the Kerr metric:
            (%i1) load("ctensor");
            (%o1)       /share/tensor/ctensor.mac
            (%i2) (cframe_flag:true,gcd:spmod,ctrgsimp:true,ratfac:true);
            (%o2)                                true
            (%i3) ct_coordsys(exteriorschwarzschild,all);
            (%o3)                                done
Chapter 26: ctensor                                                          475
           (%i4)   ug:invert(lg)$
           (%i5)   weyl(false);
           (%o5)                                done
           (%i6)   nptetrad(true);
           (%t6)   np =
           [ sqrt(r - 2 m)            sqrt(r)                                    ]
           [---------------    ---------------------        0           0        ]
           [sqrt(2) sqrt(r)    sqrt(2) sqrt(r - 2 m)                             ]
           [                                                                     ]
           [ sqrt(r - 2 m)             sqrt(r)                                   ]
           [---------------   - ---------------------       0           0        ]
           [sqrt(2) sqrt(r)     sqrt(2) sqrt(r - 2 m)                            ]
           [                                                                     ]
           [                                          r          %i r sin(theta) ]
           [       0                    0          -------       --------------- ]
           [                                       sqrt(2)           sqrt(2)     ]
           [                                                                     ]
           [                                          r           %i r sin(theta)]
           [       0                    0          -------      - ---------------]
           [                                       sqrt(2)            sqrt(2)    ]
                                        sqrt(r)         sqrt(r - 2 m)
           (%t7) npi = matrix([- ---------------------,---------------, 0, 0],
                                 sqrt(2) sqrt(r - 2 m) sqrt(2) sqrt(r)
                     sqrt(r)            sqrt(r - 2 m)
           [- ---------------------, - ---------------, 0, 0],
              sqrt(2) sqrt(r - 2 m)    sqrt(2) sqrt(r)
                      1               %i
           [0, 0, ---------, --------------------],
                  sqrt(2) r sqrt(2) r sin(theta)
                      1                 %i
           [0, 0, ---------, - --------------------])
                  sqrt(2) r    sqrt(2) r sin(theta)
           (%o7)                                done
           (%i7) psi(true);
           (%t8)                              psi = 0
                                                 0
           (%t9)                              psi = 0
                                                 1
                                                        m
476                                                                  Maxima 5.45.0 Manual
                (%t10)                                 psi = --
                                                          2    3
                                                             r
                (%t11)                                 psi = 0
                                                          3
                (%t12)                                 psi = 0
                                                          4
                (%o12)                                   done
                (%i12) petrov();
                (%o12)                                      D
                     m            m       m
                  - g
                   tr   - g     tr    - tr   g
                 im kj      jm     ki      ij km
      kt    = -------------------------------
         ijk                   2
           k          km
      kt        = g        kt
           ij                   ijm
   Note that only the mixed-index tensor is calculated and stored in the array kt.
   The nonmetricity coefficients are calculated from the user-supplied nonmetricity vector
nm. From this, the nonmetricity coefficients nmc are computed as follows:
                  k    k        km
                  -nm
                 D - D nm + g      nm g
         k     i j     i   j         m ij
      nmc = ------------------------------
Chapter 26: ctensor                                                                     477
ij 2
                                           [ 0   0        0         - d ]
            (%i5)   depends([a,d],x);
            (%o5)                                    [a(x), d(x)]
            (%i6)   ct_coords:[x,y,z,t];
            (%o6)                                    [x, y, z, t]
            (%i7)   cmetric();
            (%o7)                                        done
            (%i8)   einstein(false);
            (%o8)                                        done
            (%i9)   findde(ein,2);
                                                       2
            (%o9) [d x - a d + d, 2 a d d    x - a (d ) x - a d d x
                    x                    x x         x       x   x
                                                                2         2
                                           + 2 a d d     - 2 a d , a x + a - a]
                                                    x         x     x
            (%i10) deindex;
            (%o10)                          [[1, 1], [2, 2], [4, 4]]
cograd ()                                                                       [Function]
      Computes the covariant gradient of a scalar function allowing the user to choose the
      corresponding vector name as the example under contragrad illustrates.
contragrad ()                                                                   [Function]
      Computes the contravariant gradient of a scalar function allowing the user to choose
      the corresponding vector name as the example below for the Schwarzschild metric
      illustrates:
            (%i1)   load("ctensor");
            (%o1)         /share/tensor/ctensor.mac
            (%i2)   derivabbrev:true;
            (%o2)                                   true
            (%i3)   ct_coordsys(exteriorschwarzschild,all);
            (%o3)                                   done
            (%i4)   depends(f,r);
            (%o4)                                  [f(r)]
            (%i5)   cograd(f,g1);
            (%o5)                                   done
            (%i6)   listarray(g1);
            (%o6)                               [0, f , 0, 0]
                                                     r
            (%i7)   contragrad(f,g2);
            (%o7)                                   done
            (%i8)   listarray(g2);
                                             f r - 2 f m
                                              r         r
            (%o8)                        [0, -------------, 0, 0]
Chapter 26: ctensor                                                                     479
                                                        r
dscalar ()                                                                [Function]
     computes the tensor d’Alembertian of the scalar function once dependencies have
     been declared upon the function. For example:
           (%i1) load("ctensor");
           (%o1)        /share/tensor/ctensor.mac
           (%i2) derivabbrev:true;
           (%o2)                                     true
           (%i3) ct_coordsys(exteriorschwarzschild,all);
           (%o3)                                     done
           (%i4) depends(p,r);
           (%o4)                                    [p(r)]
           (%i5) factor(dscalar(p));
                                         2
                                  p     r - 2 m p       r + 2 p r - 2 m p
                                    r r            r r         r          r
           (%o5)                  --------------------------------------
                                                       2
                                                      r
checkdiv ()                                                                    [Function]
     computes the covariant divergence of the mixed second rank tensor (whose first index
     must be covariant) by printing the corresponding n components of the vector field (the
     divergence) where n = dim. If the argument to the function is g then the divergence
     of the Einstein tensor will be formed and must be zero. In addition, the divergence
     (vector) is given the array name div.
cgeodesic (dis)                                                                   [Function]
     A function in the ctensor (component tensor) package. cgeodesic computes the
     geodesic equations of motion for a given metric. They are stored in the array geod[i].
     If the argument dis is true then these equations are displayed.
bdvac (f)                                                                        [Function]
     generates the covariant components of the vacuum field equations of the Brans- Dicke
     gravitational theory. The scalar field is specified by the argument f, which should be
     a (quoted) function name with functional dependencies, e.g., 'p(x).
     The components of the second rank covariant field tensor are represented by the array
     bd.
invariant1 ()                                                                    [Function]
     generates the mixed Euler- Lagrange tensor (field equations) for the invariant density
     of R^2. The field equations are the components of an array named inv1.
invariant2 ()                                                                    [Function]
     *** NOT YET IMPLEMENTED ***
     generates the mixed Euler- Lagrange tensor (field equations) for the invariant density
     of ric[i,j]*uriem[i,j]. The field equations are the components of an array named
     inv2.
480                                                                   Maxima 5.45.0 Manual
bimetric ()                                                                        [Function]
      *** NOT YET IMPLEMENTED ***
      generates the field equations of Rosen’s bimetric theory. The field equations are the
      components of an array named rosen.
                      [                                          4                      ]
                      [                                         r                       ]
                      [                                                                 ]
                      [                                                     m (r - 2 m) ]
                      [ 0           0                            0          ----------- ]
                      [                                                          4      ]
                      [                                                         r       ]
                                        [       2 m (r - 2 m)                 ]
                                        [   0   -------------           0   0 ]
                                        [              4                      ]
                                        [            r                        ]
                             riem     = [                                     ]
                                 1, 2   [   0           0               0   0 ]
                                        [                                     ]
                                        [   0           0               0   0 ]
                                        [                                     ]
                                        [   0           0               0   0 ]
                                        [             m (r - 2 m)             ]
                                        [   0   0   - -----------           0 ]
                                        [                   4                 ]
                                        [                 r                   ]
                             riem     = [                                     ]
                                 1, 3   [   0   0           0               0 ]
                                        [                                     ]
                                        [   0   0           0               0 ]
                                        [                                     ]
                                        [   0   0           0               0 ]
                                        [                 m (r - 2 m)         ]
                                        [   0   0   0   - -----------         ]
                                        [                       4             ]
                                        [                     r               ]
                             riem     = [                                     ]
                                 1, 4   [   0   0   0               0         ]
                                        [                                     ]
                                        [   0   0   0               0         ]
                                        [                                     ]
                                        [   0   0   0               0         ]
                                       [       0                    0   0   0 ]
                                       [                                      ]
                                       [       2 m                            ]
                                       [ - ------------             0   0   0 ]
                            riem     = [    2                                 ]
                                2, 1   [   r (r - 2 m)                        ]
482                                                                Maxima 5.45.0 Manual
                                      [                                           ]
                                      [            0                    0   0   0 ]
                                      [                                           ]
                                      [            0                    0   0   0 ]
                 [     2 m                                                         ]
                 [ ------------   0                0                            0  ]
                 [ 2                                                               ]
                 [ r (r - 2 m)                                                     ]
                 [                                                                 ]
                 [      0         0                0                      0        ]
                 [                                                                 ]
      riem     = [                               m                                 ]
          2, 2   [      0         0       - ------------                  0        ]
                 [                           2                                     ]
                 [                          r (r - 2 m)                            ]
                 [                                                                 ]
                 [                                                          m      ]
                 [      0         0                0                - ------------ ]
                 [                                                     2           ]
                 [                                                    r (r - 2 m) ]
                                   [       0   0               0                0 ]
                                   [                                              ]
                                   [                        m                     ]
                                   [       0   0       ------------             0 ]
                        riem     = [                    2                         ]
                            2, 3   [                   r (r - 2 m)                ]
                                   [                                              ]
                                   [       0   0               0                0 ]
                                   [                                              ]
                                   [       0   0               0                0 ]
                                   [       0   0       0            0   ]
                                   [                                    ]
                                   [                            m       ]
                                   [       0   0       0   ------------ ]
                        riem     = [                        2           ]
                            2, 4   [                       r (r - 2 m) ]
                                   [                                    ]
                                   [       0   0       0        0       ]
                                   [                                    ]
                                   [       0   0       0        0       ]
                                               [ 0         0   0     0 ]
                                               [                       ]
                                               [ 0         0   0     0 ]
Chapter 26: ctensor                                                               483
                                        [                           ]
                             riem     = [    m                      ]
                                 3, 1   [    -       0       0    0 ]
                                        [    r                      ]
                                        [                           ]
                                        [    0       0       0    0 ]
                                        [    0       0       0    0 ]
                                        [                           ]
                                        [    0       0       0    0 ]
                                        [                           ]
                             riem     = [            m              ]
                                 3, 2   [     0      -       0    0 ]
                                        [            r              ]
                                        [                           ]
                                        [    0       0       0    0 ]
                                 [   m                                   ]
                                 [ - -       0       0            0      ]
                                 [   r                                   ]
                                 [                                       ]
                                 [         m                             ]
                                 [ 0     - -         0            0      ]
                      riem     = [         r                             ]
                          3, 3   [                                       ]
                                 [ 0         0       0            0      ]
                                 [                                       ]
                                 [                           2 m - r     ]
                                 [ 0         0       0       ------- + 1 ]
                                 [                              r        ]
                                     [   0       0       0         0   ]
                                     [                                 ]
                                     [   0       0       0         0   ]
                                     [                                 ]
                          riem     = [                             2 m ]
                              3, 4   [   0       0       0       - --- ]
                                     [                              r ]
                                     [                                 ]
                                     [   0       0       0         0   ]
                                  [          0                     0   0    0 ]
                                  [                                           ]
                                  [          0                     0   0    0 ]
                                  [                                           ]
                       riem     = [              0                 0    0   0 ]
                           4, 1   [                                           ]
484                                                           Maxima 5.45.0 Manual
                                       [      2                              ]
                                       [ m sin (theta)                       ]
                                       [ -------------             0   0   0 ]
                                       [        r                            ]
                                     [     0              0            0   0 ]
                                     [                                       ]
                                     [     0              0            0   0 ]
                                     [                                       ]
                          riem     = [     0              0            0   0 ]
                              4, 2   [                                       ]
                                     [                  2                    ]
                                     [             m sin (theta)             ]
                                     [     0       -------------       0   0 ]
                                     [                    r                  ]
                                   [   0   0                  0                0 ]
                                   [                                             ]
                                   [   0   0                  0                0 ]
                                   [                                             ]
                        riem     = [   0       0              0                0 ]
                            4, 3   [                                             ]
                                   [                        2                    ]
                                   [                 2 m sin (theta)             ]
                                   [   0   0       - ---------------           0 ]
                                   [                        r                    ]
                 [        2                                                              ]
                 [   m sin (theta)                                                       ]
                 [ - -------------                 0                       0         0   ]
                 [          r                                                            ]
                 [                                                                       ]
                 [                          2                                            ]
                 [                     m sin (theta)                                     ]
      riem     = [        0          - -------------                       0         0   ]
          4, 4   [                            r                                          ]
                 [                                                                       ]
                 [                                                       2               ]
                 [                                                2 m sin (theta)        ]
                 [        0                        0              ---------------    0   ]
                 [                                                       r               ]
                 [                                                                       ]
                 [        0                        0                       0         0   ]
      (%o5)                                        done
Chapter 26: ctensor                                                                     485
lfg                                                                                 [Variable]
       The covariant frame metric. By default, it is initialized to the 4-dimensional Lorentz
       frame with signature (+,+,+,-). Used when cframe_flag is true.
ufg                                                                            [Variable]
       The inverse frame metric. Computed from lfg when cmetric is called while cframe_
       flag is set to true.
riem                                                                       [Variable]
       The (3,1) Riemann tensor. Computed when the function riemann is invoked. For
       information about index ordering, see the description of riemann.
       If cframe_flag is true, riem is computed from the covariant Riemann-tensor lriem.
lriem                                                                               [Variable]
       The covariant Riemann tensor. Computed by lriemann.
uriem                                                                               [Variable]
       The contravariant Riemann tensor. Computed by uriemann.
ric                                                                                 [Variable]
       The covariant Ricci-tensor. Computed by ricci.
Chapter 26: ctensor                                                                        487
uric                                                                                 [Variable]
       The mixed-index Ricci-tensor. Computed by uricci.
lg                                                                           [Variable]
       The metric tensor. This tensor must be specified (as a dim by dim matrix) before
       other computations can be performed.
ug                                                                                   [Variable]
       The inverse of the metric tensor. Computed by cmetric.
weyl                                                                                 [Variable]
       The Weyl tensor. Computed by weyl.
fb                                                                                   [Variable]
       Frame bracket coefficients, as computed by frame_bracket.
kinvariant                                                                           [Variable]
       The Kretschmann invariant. Computed by rinvariant.
np                                                                                   [Variable]
       A Newman-Penrose null tetrad. Computed by nptetrad.
npi                                                                        [Variable]
       The raised-index Newman-Penrose null tetrad. Computed by nptetrad. Defined as
       ug.np. The product np.transpose(npi) is constant:
             (%i39) trigsimp(np.transpose(npi));
                                           [ 0             - 1   0   0 ]
                                           [                           ]
                                           [ - 1            0    0   0 ]
             (%o39)                        [                           ]
                                           [ 0              0    0   1 ]
                                           [                           ]
                                           [ 0              0    1   0 ]
tr                                                                                   [Variable]
       User-supplied rank-3 tensor representing torsion. Used by contortion.
kt                                                                                   [Variable]
       The contortion tensor, computed from tr by contortion.
nm                                                                                   [Variable]
       User-supplied nonmetricity vector. Used by nonmetricity.
nmc                                                                                  [Variable]
       The nonmetricity coefficients, computed from nm by nonmetricity.
26.2.11 Changes
In November, 2004, the ctensor package was extensively rewritten. Many functions and
variables have been renamed in order to make the package compatible with the commercial
version of Macsyma.
         New Name       Old Name          Description
         ---------------------------------------------------------------------
         ctaylor()      DLGTAYLOR()       Taylor-series expansion of an expression
         lgeod[]        EM                Geodesic equations
         ein[]          G[]               Mixed Einstein-tensor
         ric[]          LR[]              Mixed Ricci-tensor
         ricci()        LRICCICOM()       Compute the mixed Ricci-tensor
         ctaypov        MINP              Maximum power in Taylor-series expansion
         cgeodesic() MOTION               Compute geodesic equations
         ct_coords      OMEGA             Metric coordinates
Chapter 26: ctensor                                                         489
27 atensor
                            [     1          v            v         v   . v ]
                            [                 1            2         1      2 ]
                            [                                                 ]
                            [   v            - 1         v . v       - v      ]
                            [     1                       1   2           2   ]
      (%o10)                [                                                 ]
                            [   v         - v     . v     - 1          v      ]
                            [     2          1       2                  1     ]
                            [                                                 ]
                            [ v . v          v           - v           - 1    ]
                            [ 1     2           2              1              ]
   atensor recognizes as base vectors indexed symbols, where the symbol is that stored in
asymbol and the index runs between 1 and adim. For indexed symbols, and indexed symbols
only, the bilinear forms sf, af, and av are evaluated. The evaluation substitutes the value
of aform[i,j] in place of fun(v[i],v[j]) where v represents the value of asymbol and
fun is either af or sf; or, it substitutes v[aform[i,j]] in place of av(v[i],v[j]).
   Needless to say, the functions sf, af and av can be redefined.
   When the atensor package is loaded, the following flags are set:
      dotscrules:true;
      dotdistrib:true;
      dotexptsimp:false;
   If you wish to experiment with a nonassociative algebra, you may also consider setting
dotassoc to false. In this case, however, atensimp will not always be able to obtain the
desired simplifications.
av (u, v)                                                                      [Function]
      An antisymmetric function that is used in commutation relations. The default imple-
      mentation checks if both arguments are base vectors using abasep and if that is the
      case, substitutes the corresponding value from the matrix aform.
      For instance:
             (%i1) load("atensor");
             (%o1)         /share/tensor/atensor.mac
             (%i2) adim:3;
             (%o2)                                         3
             (%i3) aform:matrix([0,3,-2],[-3,0,1],[2,-1,0]);
                                                  [ 0     3    - 2 ]
                                                  [                ]
             (%o3)                                [ - 3    0    1 ]
                                                  [                ]
                                                  [ 2    - 1    0 ]
             (%i4) asymbol:x;
             (%o4)                                         x
             (%i5) av(x[1],x[2]);
             (%o5)                                       x
                                                          3
      If the upper and lower limits differ by an integer, expr is evaluated for each value of
      the index i, and the result is an explicit product.
      Otherwise, the range of the index is indefinite. Some rules are applied to simplify the
      product. When the global variable simpproduct is true, additional rules are applied.
      In some cases, simplification yields a result which is not a product; otherwise, the
      result is a noun form 'product.
      See also nouns and evflag.
      Examples:
            (%i1) product (x + i*(i+1)/2, i, 1, 4);
            (%o1)           (x + 1) (x + 3) (x + 6) (x + 10)
            (%i2) product (i^2, i, 1, 7);
            (%o2)                       25401600
            (%i3) product (a[i], i, 1, 7);
            (%o3)                 a a a a a a a
                                   1 2 3 4 5 6 7
            (%i4) product (a(i), i, 1, 7);
            (%o4)          a(1) a(2) a(3) a(4) a(5) a(6) a(7)
            (%i5) product (a(i), i, 1, n);
                                         n
                                       /===\
                                        ! !
            (%o5)                       ! ! a(i)
                                        ! !
                                       i = 1
            (%i6) product (k, k, 1, n);
                                            n
                                         /===\
                                          ! !
            (%o6)                          ! ! k
                                          ! !
                                         k = 1
            (%i7) product (k, k, 1, n), simpproduct;
            (%o7)                           n!
            (%i8) product (integrate (x^k, x, 0, 1), k, 1, n);
                                         n
                                       /===\
                                        ! !     1
            (%o8)                       ! ! -----
                                        ! ! k + 1
                                       k = 1
            (%i9) product (if k <= 5 then a^k else b^k, k, 1, 10);
                                          15 40
            (%o9)                        a    b
     When simpsum is true, the result of a sum is simplified. This simplification may
     sometimes be able to produce a closed form. If simpsum is false or if the quoted
     form 'sum is used, the value is a sum noun form which is a representation of the sigma
     notation used in mathematics.
                              \       i   2
      (%o5)                      >  (2 + i )
                               /
                               ====
                               i = 0
      (%i6) sum (2^i + i^2, i, 0, n), simpsum;
                                       3           2
                         n + 1    2 n + 3 n + n
      (%o6)             2      + --------------- - 1
                                              6
      (%i7) sum (1/3^i, i, 1, inf);
                                    inf
                                    ====
                                    \         1
      (%o7)                           >       --
                                    /           i
                                    ==== 3
                                    i = 1
      (%i8) sum (1/3^i, i, 1, inf), simpsum;
                                          1
      (%o8)                                -
                                          2
      (%i9) sum (i^2, i, 1, 4) * sum (1/i^2, i, 1, inf);
                                       inf
                                       ====
                                       \         1
      (%o9)                        30 >           --
                                       /           2
                                       ==== i
                                       i = 1
      (%i10) sum (i^2, i, 1, 4) * sum (1/i^2, i, 1, inf), simpsum;
                                              2
      (%o10)                          5 %pi
      (%i11) sum (integrate (x^k, x, 0, 1), k, 1, n);
                                    n
                                  ====
                                  \             1
      (%o11)                        >        -----
                                  /         k + 1
                                  ====
                                  k = 1
      (%i12) sum (if k <= 5 then a^k else b^k, k, 1, 10);
                10    9    8     7       6        5  4 3 2
      (%o12)   b   + b + b + b + b + a + a + a + a + a
Chapter 28: Sums, Products, and Series                                                   499
      product. In the Cauchy product the index of the inner summation is a function of
      the index of the outer one rather than varying independently.
      Example:
            (%i1) sumexpand: false$
            (%i2) cauchysum: false$
            (%i3) s: sum (f(i), i, 0, inf) * sum (g(j), j, 0, inf);
                                       inf           inf
                                       ====          ====
                                       \             \
            (%o3)                     ( >     f(i)) >      g(j)
                                       /             /
                                       ====          ====
                                       i = 0         j = 0
            (%i4) sumexpand: true$
            (%i5) cauchysum: true$
            (%i6) expand(s,0,0);
                                 inf       i1
                                 ====    ====
                                 \       \
            (%o6)                  >       >     g(i1 - i2) f(i2)
                                 /       /
                                 ====    ====
                                 i1 = 0 i2 = 0
2 18432 307200
                             ! !    \
            (%o2)            ! !      >      f(bar i j + foo)
                             ! !    /
                            bar = 1 ====
                                    foo = 1
            (%i3) niceindices (%);
                                 inf inf
                                /===\ ====
                                 ! ! \
            (%o3)                ! !    >    f(i j q + p)
                                 ! ! /
                                q = 1 ====
                                       p = 1
                                                  8         9          10
                                            5853 x    2847 x    83787 x
                                          + ------- + ------- - --------- + . . .
                                            4194304   8388608   134217728
           (%i4) pade (t, 4, 4);
           (%o4)                                 []
504                                                                 Maxima 5.45.0 Manual
                              2
             - 1619100813312 x - 2176885157888 x - 2386516803584)
                           5                4                 3
            /(47041365435 x + 381702613848 x + 1360678489152 x
                              2
             + 2856700692480 x + 3370143559680 x + 2386516803584)]
                                               /
                                    inf
                                    ====         i1 2 i1              2 i1
                                    \       (- 1)   2     bern(2 i1) x
                                     >      ------------------------------
                                    /                 i1 (2 i1)!
                                    ====
                                    i1 = 1
           (%o2)                      -------------------------------------
                                                       2
                               x    x    x      x    x
            (%o5)/T/       x - -- + -- - -- + -- - -- + . . .
                               2    3    4      5    6
            (%i6) ratsimp (revert (t, x) - taylor (log(x+1), x, 0, 6));
            (%o6)                             0
            (%i7) revert2 (t, x, 4);
                                       4    3      2
                                     x    x      x
            (%o7)                  - -- + -- - -- + x
                                     4    3      2
taylor                                                                                  [Function]
          taylor     (expr, x, a, n)
          taylor     (expr, [x_1, x_2, . . . ], a, n)
          taylor     (expr, [x, a, n, ’asymp])
          taylor     (expr, [x_1, x_2, . . . ], [a_1, a_2, . . . ], [n_1, n_2, . . . ])
          taylor     (expr, [x_1, a_1, n_1], [x_2, a_2, n_2], . . . )
      taylor (expr, x, a, n) expands the expression expr in a truncated Taylor or Lau-
      rent series in the variable x around the point a, containing terms through (x - a)^n.
      If expr is of the form f(x)/g(x) and g(x) has no terms up to degree n then taylor
      attempts to expand g(x) up to degree 2 n. If there are still no nonzero terms, taylor
      doubles the degree of the expansion of g(x) so long as the degree of the expansion is
      less than or equal to n 2^taylordepth.
      taylor (expr, [x_1, x_2, ...], a, n) returns a truncated power series of degree n
      in all variables x 1, x 2, . . . about the point (a, a, ...).
      taylor (expr, [x_1, a_1, n_1], [x_2, a_2, n_2], ...) returns a truncated
      power series in the variables x 1, x 2, . . . about the point (a_1, a_2, ...),
      truncated at n 1, n 2, . . .
      taylor (expr, [x_1, x_2, ...], [a_1, a_2, ...], [n_1, n_2, ...]) returns a
      truncated power series in the variables x 1, x 2, . . . about the point (a_1, a_2,
      ...), truncated at n 1, n 2, . . .
      taylor (expr, [x, a, n, 'asymp]) returns an expansion of expr in negative powers
      of x - a. The highest order term is (x - a)^-n.
      When maxtayorder is true, then during algebraic manipulation of (truncated) Taylor
      series, taylor tries to retain as many terms as are known to be correct.
      When psexpand is true, an extended rational function expression is displayed fully
      expanded. The switch ratexpand has the same effect. When psexpand is false, a
      multivariate expression is displayed just as in the rational function package. When
      psexpand is multi, then terms with the same total degree in the variables are grouped
      together.
      See also the taylor_logexpand switch for controlling expansion.
      Examples:
             (%i1) taylor (sqrt (sin(x) + a*x + 1), x, 0, 3);
                                                2                  2
                             (a + 1) x        (a + 2 a + 1) x
Chapter 28: Sums, Products, and Series                                          507
                                                 3      2             3
                                             (3 a + 9 a + 9 a - 1) x
                                           + -------------------------- + . . .
                                                         48
           (%i2) %^2;
                                                       3
                                                     x
           (%o2)/T/             1 + (a + 1) x - -- + . . .
                                                     6
           (%i3) taylor (sqrt (x + 1), x, 0, 5);
                                    2       3        4        5
                             x     x      x       5 x     7 x
           (%o3)/T/      1 + - - -- + -- - ---- + ---- + . . .
                             2     8      16      128     256
           (%i4) %^2;
           (%o4)/T/                      1 + x + . . .
           (%i5) product ((1 + x^i)^2.5, i, 1, inf)/(1 + x^2);
                                       inf
                                     /===\
                                       ! !       i       2.5
                                       ! ! (x + 1)
                                       ! !
                                     i = 1
           (%o5)                      -----------------
                                              2
                                             x + 1
           (%i6) ev (taylor(%, x, 0, 3), keepfloat);
                                                2              3
           (%o6)/T/    1 + 2.5 x + 3.375 x + 6.5625 x + . . .
           (%i7) taylor (1/log (x + 1), x, 0, 3);
                                                2         3
                            1     1    x      x       19 x
           (%o7)/T/         - + - - -- + -- - ----- + . . .
                            x     2    12     24       720
           (%i8) taylor (cos(x) - sec(x), x, 0, 5);
                                                 4
                                          2     x
           (%o8)/T/                   - x - -- + . . .
                                                6
           (%i9) taylor ((cos(x) - sec(x))^3, x, 0, 5);
           (%o9)/T/                         0 + . . .
           (%i10) taylor (1/(cos(x) - sec(x))^3, x, 0, 5);
                                                                   2        4
                       1      1          11         347      6767 x  15377 x
508                                                 Maxima 5.45.0 Manual
                                                                  + . . .
      (%i11) taylor (sqrt (1 - k^2*sin(x)^2), x, 0, 6);
                     2 2        4      2   4
                    k x     (3 k - 4 k ) x
      (%o11)/T/ 1 - ----- - ----------------
                      2            24
                                          6       4       2   6
                                     (45 k - 60 k + 16 k ) x
                                   - -------------------------- + . . .
                                                720
      (%i12) taylor ((x + 1)^n, x, 0, 4);
                            2       2     3      2          3
                          (n - n) x     (n - 3 n + 2 n) x
      (%o12)/T/ 1 + n x + ----------- + --------------------
                               2                 6
                                     4      3       2         4
                                   (n - 6 n + 11 n - 6 n) x
                                 + ---------------------------- + . . .
                                                24
      (%i13) taylor (sin (y + x), x, 0, 3, y, 0, 3);
                     3                  2
                    y                  y
      (%o13)/T/ y - -- + . . . + (1 - -- + . . .) x
                    6                  2
                          3                       2
                     y   y             2     1   y            3
                + (- - + -- + . . .) x + (- - + -- + . . .) x + . . .
                     2   12                  6   12
      (%i14) taylor (sin (y + x), [x, y], 0, 3);
                           3         2     2      3
                          x + 3 y x + 3 y x + y
      (%o14)/T/   y + x - ------------------------- + . . .
                                       6
      (%i15) taylor (1/sin (y + x), x, 0, 3, y, 0, 3);
                1   y              1     1              1            2
      (%o15)/T/ - + - + . . . + (- -- + - + . . .) x + (-- + . . .) x
                y   6                2   6                3
                                   y                    y
                                                1             3
Chapter 28: Sums, Products, and Series                                                  509
                                                 + (- -- + . . .) x + . . .
                                                        4
                                                       y
           (%i16) taylor (1/sin (y + x), [x, y], 0, 3);
                                        3         2       2        3
                       1     x + y   7 x + 21 y x + 21 y x + 7 y
           (%o16)/T/ ----- + ----- + ------------------------------- + . . .
                     x + y     6                    360
taylordepth                                                                [Option variable]
     Default value: 3
     If there are still no nonzero terms, taylor doubles the degree of the expansion of
     g(x) so long as the degree of the expansion is less than or equal to n 2^taylordepth.
taylorinfo (expr)                                                               [Function]
     Returns information about the Taylor series expr. The return value is a list of lists.
     Each list comprises the name of a variable, the point of expansion, and the degree of
     the expansion.
     taylorinfo returns false if expr is not a Taylor series.
     Example:
           (%i1) taylor ((1 - y^2)/(1 - x), x, 0, 3, [y, a, inf]);
                                2                             2
           (%o1)/T/ - (y - a) - 2 a (y - a) + (1 - a )
                    2                       2
            + (1 - a - 2 a (y - a) - (y - a) ) x
                    2                       2   2
            + (1 - a - 2 a (y - a) - (y - a) ) x
                    2                        2   3
            + (1 - a - 2 a (y - a) - (y - a) ) x + . . .
           (%i2) taylorinfo(%);
           (%o2)               [[y, a, inf], [x, 0, 3]]
taylorp (expr)                                                                   [Function]
     Returns true if expr is a Taylor series, and false otherwise.
taylor_logexpand                                                          [Option variable]
     Default value: true
     taylor_logexpand controls expansions of logarithms in taylor series.
     When taylor_logexpand is true, all logarithms are expanded fully so that zero-
     recognition problems involving logarithmic identities do not disturb the expansion
     process. However, this scheme is not always mathematically correct since it ignores
     branch information.
     When taylor_logexpand is set to false, then the only expansion of logarithms that
     occur is that necessary to obtain a formal power series.
510                                                                   Maxima 5.45.0 Manual
                                      binomial(2 n, n)
            (%i3)   nusum (%, n, 0, n);
                                   4        3       2              n
                    2 (n + 1) (63 n + 112 n + 18 n - 22 n + 3) 4         2
            (%o3)   ------------------------------------------------ - ------
                                  693 binomial(2 n, n)                 3 11 7
            (%i4)   unsum (%, n);
                                            4 n
                                           n 4
            (%o4)                     ----------------
                                      binomial(2 n, n)
verbose                                                                   [Option variable]
       Default value: false
       When verbose is true, powerseries prints progress messages.
29 Number Theory
                                              ∞
                                              X      1
                                 ζ (s, h) =              s
                                              k=0
                                                  (k + h)
      burn may be more efficient than bern for large, isolated n as bern computes all the
      Bernoulli numbers up to index n before returning. burn invokes the approximation
      for even integers n > 255. For odd integers and n <= 255 the function bern is called.
      load ("bffac") loads this function. See also bern.
cf (expr)                                                                          [Function]
      Computes a continued fraction approximation. expr is an expression comprising con-
      tinued fractions, square roots of integers, and literal real numbers (integers, rational
      numbers, ordinary floats, and bigfloats). cf computes exact expansions for ratio-
      nal numbers, but expansions are truncated at ratepsilon for ordinary floats and
      10^(-fpprec) for bigfloats.
      Operands in the expression may be combined with arithmetic operators. Maxima
      does not know about operations on continued fractions outside of cf.
      cf evaluates its arguments after binding listarith to false. cf returns a continued
      fraction, represented as a list.
      A continued fraction a + 1/(b + 1/(c + ...)) is represented by the list [a, b, c,
      ...]. The list elements a, b, c, . . . must evaluate to integers. expr may also contain
      sqrt (n) where n is an integer. In this case cf will give as many terms of the continued
      fraction as the value of the variable cflength times the period.
      A continued fraction can be evaluated to a number by evaluating the arithmetic
      representation returned by cfdisrep. See also cfexpand for another way to evaluate
      a continued fraction.
      See also cfdisrep, cfexpand, and cflength.
      Examples:
        • expr is an expression comprising continued fractions and square roots of integers.
                (%i1) cf ([5, 3, 1]*[11, 9, 7] + [3, 7]/[4, 3, 2]);
Chapter 29: Number Theory                                                             517
divsum                                                                          [Function]
          divsum (n, k)
          divsum (n)
      divsum (n, k) returns the sum of the divisors of n raised to the k’th power.
      divsum (n) returns the sum of the divisors of n.
            (%i1)   divsum (12);
            (%o1)                                28
            (%i2)   1 + 2 + 3 + 4 + 6 + 12;
            (%o2)                                28
            (%i3)   divsum (12, 2);
            (%o3)                            210
            (%i4)   1^2 + 2^2 + 3^2 + 4^2 + 6^2 + 12^2;
            (%o4)                            210
            (%i2) igcdex(30,18);
            (%o2)                      [- 1, 2, 6]
            (%i3) igcdex(1526757668, 7835626735736);
            (%o3)            [845922341123, - 164826435, 4]
            (%i4) igcdex(fib(20), fib(21));
            (%o4)                   [4181, - 2584, 1]
inrt (x, n)                                                         [Function]
      Returns the integer n’th root of the absolute value of x.
           (%i1) l: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]$
           (%i2) map (lambda ([a], inrt (10^a, 3)), l);
           (%o2) [2, 4, 10, 21, 46, 100, 215, 464, 1000, 2154, 4641, 10000]
inv_mod (n, m)                                                             [Function]
      Computes the inverse of n modulo m. inv_mod (n,m) returns false, if n is a zero
      divisor modulo m.
            (%i1) inv_mod(3, 41);
            (%o1)                             14
            (%i2) ratsimp(3^-1), modulus = 41;
            (%o2)                             14
            (%i3) inv_mod(3, 42);
            (%o3)                            false
isqrt (x)                                                                        [Function]
      Returns the "integer square root" of the absolute value of x, which is an integer.
jacobi (p, q)                                                                   [Function]
      Returns the Jacobi symbol of p and q.
           (%i1) l: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]$
Chapter 29: Number Theory                                                              521
                        1     1                       %pi
            (%o1) [0, - --, - -, - 1.460354508809586, ----, zeta(3),
                        12    2                        6
                                                                zeta(%i + 1)]
            (%i2) limit(zeta(x),x,1,plus);
            (%o2)                          inf
            (%i3) limit(zeta(x),x,1,minus);
            (%o3)                         minf
zeta%pi                                                                 [Option variable]
      Default value: true
      When zeta%pi is true, zeta returns an expression proportional to %pi^n for even
      integer n. Otherwise, zeta returns a noun form zeta (n) for even integer n.
      Examples:
            (%i1) zeta%pi: true$
            (%i2) zeta (4);
                                                   4
                                               %pi
            (%o2)                              ----
                                                90
            (%i3) zeta%pi: false$
            (%i4) zeta (4);
            (%o4)                             zeta(4)
zn_add_table (n)                                                                     [Function]
      Shows an addition table of all elements in (Z/nZ).
      See also zn_mult_table, zn_power_table.
zn_characteristic_factors (n)                                                        [Function]
      Returns a list containing the characteristic factors of the totient of n.
      Using the characteristic factors a multiplication group modulo n can be expressed as
      a group direct product of cyclic subgroups.
      In case the group itself is cyclic the list only contains the totient and using zn_
      primroot a generator can be computed. If the totient splits into more than one
      characteristic factors zn_factor_generators finds generators of the corresponding
      subgroups.
      Each of the r factors in the list divides the right following factors. For the last factor
      f_r therefore holds a^f_r = 1 (mod n) for all a coprime to n. This factor is also
      known as Carmichael function or Carmichael lambda.
      If n > 2, then totient(n)/2^r is the number of quadratic residues, and each of these
      has 2^r square roots.
      See also totient, zn_primroot, zn_factor_generators.
      Examples:
      The multiplication group modulo 14 is cyclic and its 6 elements can be generated by
      a primitive root.
             (%i1) [zn_characteristic_factors(14), phi: totient(14)];
Chapter 29: Number Theory                                                                 525
           (%o1)                              [[6], 6]
           (%i2) [zn_factor_generators(14), g: zn_primroot(14)];
           (%o2)                              [[3], 3]
           (%i3) M14: makelist(power_mod(g,i,14), i,0,phi-1);
           (%o3)                         [1, 3, 9, 13, 11, 5]
     The multiplication group modulo 15 is not cyclic and its 8 elements can be generated
     by two factor generators.
           (%i1)   [[f1,f2]: zn_characteristic_factors(15), totient(15)];
           (%o1)                               [[2, 4], 8]
           (%i2)   [[g1,g2]: zn_factor_generators(15), zn_primroot(15)];
           (%o2)                             [[11, 7], false]
           (%i3)   UG1: makelist(power_mod(g1,i,15), i,0,f1-1);
           (%o3)                                 [1, 11]
           (%i4)   UG2: makelist(power_mod(g2,i,15), i,0,f2-1);
           (%o4)                              [1, 7, 4, 13]
           (%i5)   M15: create_list(mod(i*j,15), i,UG1, j,UG2);
           (%o5)                        [1, 7, 4, 13, 11, 2, 14, 8]
     For the last characteristic factor 4 it holds that a^4 = 1 (mod 15) for all a in M15.
     M15 has two characteristic factors and therefore 8/2^2 quadratic residues, and each
     of these has 2^2 square roots.
           (%i6) zn_power_table(15);
                                          [ 1   1 1    1 ]
                                          [              ]
                                          [ 2   4 8    1 ]
                                          [              ]
                                          [ 4   1 4    1 ]
                                          [              ]
                                          [ 7   4 13 1 ]
           (%o6)                          [              ]
                                          [ 8   4 2    1 ]
                                          [              ]
                                          [ 11 1 11 1 ]
                                          [              ]
                                          [ 13 4 7     1 ]
                                          [              ]
                                          [ 14 1 14 1 ]
           (%i7) map(lambda([i], zn_nth_root(i,2,15)), [1,4]);
           (%o7)                   [[1, 4, 11, 14], [2, 7, 8, 13]]
      However if the determinant is equal to zero the LU-decomposition might fail. In that
      case zn_determinant computes the determinant non-modular and reduces thereafter.
      See also zn_invert_by_lu.
      Examples:
            (%i1) m : matrix([1,3],[2,4]);
                                                   [ 1   3 ]
            (%o1)                                  [       ]
                                                   [ 2   4 ]
            (%i2) zn_determinant(m, 5);
            (%o2)                               3
            (%i3) m : matrix([2,4,1],[3,1,4],[4,3,2]);
                                           [ 2 4 1 ]
                                           [         ]
            (%o3)                          [ 3 1 4 ]
                                           [         ]
                                           [ 4 3 2 ]
            (%i4) zn_determinant(m, 5);
            (%o4)                               0
zn_log                                                                        [Function]
         zn_log (a, g, n)
         zn_log (a, g, n, [[p1, e1], . . . , [pk, ek]])
     Computes the discrete logarithm. Let (Z/nZ)* be a cyclic group, g a primitive root
     modulo n or a generator of a subgroup of (Z/nZ)* and let a be a member of this
     group. zn_log (a, g, n) then solves the congruence g^x = a mod n. Please note that
     if a is not a power of g modulo n, zn_log will not terminate.
     The applied algorithm needs a prime factorization of zn_order(g) resp. totient(n)
     in case g is a primitive root modulo n. A precomputed list of factors of zn_order(g)
     might be used as the optional fourth argument. This list must be of the same form
     as the list returned by ifactors(zn_order(g)) using the default option factors_
     only : false. However, compared to the running time of the logarithm algorithm
     providing the list of factors has only a quite small effect.
     The algorithm uses a Pohlig-Hellman-reduction and Pollard’s Rho-method for discrete
     logarithms. The running time of zn_log primarily depends on the bitlength of the
     greatest prime factor of zn_order(g).
     See also zn_primroot, zn_order, ifactors, totient.
     Examples:
     zn_log (a, g, n) solves the congruence g^x = a mod n.
          (%i1)   n : 22$
          (%i2)   g : zn_primroot(n);
          (%o2)                                           7
          (%i3)   ord_7 : zn_order(7, n);
          (%o3)                                10
          (%i4)   powers_7 : makelist(power_mod(g, x, n), x, 0, ord_7 - 1);
          (%o4)                [1, 7, 5, 13, 3, 21, 15, 17, 9, 19]
          (%i5)   zn_log(9, g, n);
          (%o5)                                 8
          (%i6)   map(lambda([x], zn_log(x, g, n)), powers_7);
          (%o6)                  [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
          (%i7)   ord_5 : zn_order(5, n);
          (%o7)                                 5
          (%i8)   powers_5 : makelist(power_mod(5,x,n), x, 0, ord_5 - 1);
          (%o8)                         [1, 5, 3, 15, 9]
          (%i9)   zn_log(9, 5, n);
          (%o9)                                 4
     The optional fourth argument must be of the same form as the list returned by
     ifactors(zn_order(g)). The running time primarily depends on the bitlength of
     the totient’s greatest prime factor.
          (%i1)   (p : 2^127-1, primep(p));
          (%o1)                                      true
          (%i2)   ifs : ifactors(p - 1)$
          (%i3)   g : zn_primroot(p, ifs);
          (%o3)                                       43
          (%i4)   a : power_mod(g, 4711, p)$
528                                                                         Maxima 5.45.0 Manual
zn_mult_table                                                                          [Function]
        zn_mult_table (n)
        zn_mult_table (n, gcd)
      Without the optional argument gcd zn_mult_table(n) shows a multiplication table
      of all elements in (Z/nZ)* which are all elements coprime to n.
      The optional second argument gcd allows to select a specific subset of (Z/nZ). If gcd is
      an integer, a multiplication table of all residues x with gcd(x,n) = gcd are returned.
      Additionally row and column headings are added for better readability. If necessary,
      these can be easily removed by submatrix(1, table, 1).
      If gcd is set to all, the table is printed for all non-zero elements in (Z/nZ).
      The second example shows an alternative way to create a multiplication table for
      subgroups.
      See also zn_add_table, zn_power_table.
      Examples:
      The default table shows all elements in (Z/nZ)* and allows to demonstrate and study
      basic properties of modular multiplication groups. E.g. the principal diagonal con-
      tains all quadratic residues, each row and column contains every element, the tables
      are symmetric, etc..
      If gcd is set to all, the table is printed for all non-zero elements in (Z/nZ).
            (%i1) zn_mult_table(8);
                                                    [   1   3   5   7 ]
                                                    [                 ]
                                                    [   3   1   7   5 ]
            (%o1)                                   [                 ]
                                                    [   5   7   1   3 ]
                                                    [                 ]
                                                    [   7   5   3   1 ]
            (%i2) zn_mult_table(8, all);
                                        [ 1          2      3   4   5   6    7 ]
                                        [                                      ]
                                        [ 2          4      6   0   2   4    6 ]
                                        [                                      ]
                                        [ 3          6      1   4   7   2    5 ]
Chapter 29: Number Theory                                                               529
                                             [                               ]
           (%o2)                             [   4   0   4   0   4   0   4   ]
                                             [                               ]
                                             [   5   2   7   4   1   6   3   ]
                                             [                               ]
                                             [   6   4   2   0   6   4   2   ]
                                             [                               ]
                                             [   7   6   5   4   3   2   1   ]
     If gcd is an integer, row and column headings are added for better readability.
     If the subset chosen by gcd is a group there is another way to create a multiplication
     table. An isomorphic mapping from a group with 1 as identity builds a table which
     is easy to read. The mapping is accomplished via CRT.
     In the second version of T36_4 the identity, here 28, is placed in the top left corner,
     just like in table T9.
           (%i1) T36_4: zn_mult_table(36,4);
                                   [ *    4   8   16 20 28 32 ]
                                   [                            ]
                                   [ 4    16 32 28 8     4   20 ]
                                   [                            ]
                                   [ 8    32 28 20 16 8      4 ]
                                   [                            ]
           (%o1)                   [ 16 28 20 4       32 16 8 ]
                                   [                            ]
                                   [ 20 8     16 32 4    20 28 ]
                                   [                            ]
                                   [ 28 4     8   16 20 28 32 ]
                                   [                            ]
                                   [ 32 20 4      8   28 32 16 ]
           (%i2) T9: zn_mult_table(36/4);
                                        [ 1 2 4 5 7 8 ]
                                        [                  ]
                                        [ 2 4 8 1 5 7 ]
                                        [                  ]
                                        [ 4 8 7 2 1 5 ]
           (%o2)                         [                 ]
                                        [ 5 1 2 7 8 4 ]
                                        [                  ]
                                        [ 7 5 1 8 4 2 ]
                                        [                  ]
                                        [ 8 7 5 4 2 1 ]
           (%i3) T36_4: matrixmap(lambda([x], chinese([0,x],[4,9])), T9);
                                     [ 28 20 4      32 16 8 ]
                                     [                        ]
                                     [ 20 4     8   28 32 16 ]
                                     [                        ]
                                     [ 4    8   16 20 28 32 ]
530                                                                  Maxima 5.45.0 Manual
           (%o3)                          [                              ]
                                          [ 32   28   20   16   8     4 ]
                                          [                              ]
                                          [ 16   32   28   8    4     20 ]
                                          [                              ]
                                          [ 8    16   32   4    20    28 ]
zn_nth_root                                                                     [Function]
        zn_nth_root (x, n, m)
        zn_nth_root (x, n, m, [[p1, e1], . . . , [pk, ek]])
      Returns a list with all n-th roots of x from the multiplication subgroup of (Z/mZ)
      which contains x, or false, if x is no n-th power modulo m or not contained in any
      multiplication subgroup of (Z/mZ).
      x is an element of a multiplication subgroup modulo m, if the greatest common divisor
      g = gcd(x,m) is coprime to m/g.
      zn_nth_root is based on an algorithm by Adleman, Manders and Miller and on
      theorems about modulo multiplication groups by Daniel Shanks.
      The algorithm needs a prime factorization of the modulus m. So in case the factor-
      ization of m is known, the list of factors can be passed as the fourth argument. This
      optional argument must be of the same form as the list returned by ifactors(m)
      using the default option factors_only: false.
      Examples:
      A power table of the multiplication group modulo 14 followed by a list of lists con-
      taining all n-th roots of 1 with n from 1 to 6.
             (%i1) zn_power_table(14);
                                            [ 1    1    1    1   1     1 ]
                                            [                            ]
                                            [ 3    9    13 11 5        1 ]
                                            [                            ]
                                            [ 5    11 13 9       3     1 ]
             (%o1)                          [                            ]
                                            [ 9    11 1      9   11 1 ]
                                            [                            ]
                                            [ 11 9      1    11 9      1 ]
                                            [                            ]
                                            [ 13 1      13 1     13 1 ]
             (%i2) makelist(zn_nth_root(1,n,14), n,1,6);
             (%o2) [[1], [1, 13], [1, 9, 11], [1, 13], [1], [1, 3, 5, 9, 11, 13]]
      In the following example x is not coprime to m, but is a member of a multiplication
      subgroup of (Z/mZ) and any n-th root is a member of the same subgroup.
      The residue class 3 is no member of any multiplication subgroup of (Z/63Z) and is
      therefore not returned as a third root of 27.
      Here zn_power_table shows all residues x in (Z/63Z) with gcd(x,63) = 9. This
      subgroup is isomorphic to (Z/7Z)* and its identity 36 is computed via CRT.
             (%i1) m: 7*9$
Chapter 29: Number Theory                                                                 531
           (%i2) zn_power_table(m,9);
                                    [ 9  18 36 9      18              36 ]
                                    [                                    ]
                                    [ 18 9    36 18 9                 36 ]
                                    [                                    ]
                                    [ 27 36 27 36 27                  36 ]
           (%o2)                    [                                    ]
                                    [ 36 36 36 36 36                  36 ]
                                    [                                    ]
                                    [ 45 9    27 18 54                36 ]
                                    [                                    ]
                                    [ 54 18 27 9      45              36 ]
           (%i3) zn_nth_root(27,3,m);
           (%o3)                           [27, 45, 54]
           (%i4) id7:1$ id63_9: chinese([id7,0],[7,9]);
           (%o5)                                36
     In the following RSA-like example, where the modulus N is squarefree, i.e. it splits into
     exclusively first power factors, every x from 0 to N-1 is contained in a multiplication
     subgroup.
     The process of decryption needs the e-th root. e is coprime to totient(N) and
     therefore the e-th root is unique. In this case zn_nth_root effectively performs CRT-
     RSA. (Please note that flatten removes braces but no solutions.)
           (%i1) [p,q,e]: [5,7,17]$         N: p*q$
zn_order                                                                      [Function]
        zn_order (x, n)
        zn_order (x, n, [[p1, e1], . . . , [pk, ek]])
      Returns the order of x if it is an unit of the finite group (Z/nZ)* or returns false. x
      is an unit modulo n if it is coprime to n.
      The applied algorithm needs a prime factorization of totient(n). This factorization
      might be time consuming in some cases and it can be useful to factor first and then
      to pass the list of factors to zn_log as the third argument. The list must be of the
      same form as the list returned by ifactors(totient(n)) using the default option
      factors_only : false.
      See also zn_primroot, ifactors, totient.
      Examples:
      zn_order computes the order of the unit x in (Z/nZ)*.
            (%i1) n: 22$
            (%i2) g: zn_primroot(n);
            (%o2)                                       7
            (%i3) units_22: sublist(makelist(i,i,1,21), lambda([x], gcd(x,n)=1));
            (%o3)               [1, 3, 5, 7, 9, 13, 15, 17, 19, 21]
            (%i4) (ord_7: zn_order(7, n)) = totient(n);
            (%o4)                                 10 = 10
            (%i5) powers_7: makelist(power_mod(g,i,n), i,0,ord_7 - 1);
            (%o5)               [1, 7, 5, 13, 3, 21, 15, 17, 9, 19]
            (%i6) map(lambda([x], zn_order(x, n)), powers_7);
            (%o6)               [1, 10, 5, 10, 5, 2, 5, 10, 5, 10]
            (%i7) map(lambda([x], ord_7/gcd(x,ord_7)), makelist(i,i,0,ord_7-1));
            (%o7)             [1, 10, 5, 10, 5, 2, 5, 10, 5, 10]
            (%i8) totient(totient(n));
            (%o8)                                   4
      The optional third argument must be of the same form as the list returned by
      ifactors(totient(n)).
            (%i1) (p : 2^142 + 217, primep(p));
            (%o1)                                  true
            (%i2) ifs: ifactors( totient(p) )$
            (%i3) g: zn_primroot(p, ifs);
            (%o3)                                     3
            (%i4) is( (ord_3 : zn_order(g, p, ifs)) = totient(p) );
            (%o4)                                  true
            (%i5) map(lambda([x], ord_3/zn_order(x,p,ifs)), makelist(i,i,2,15));
            (%o5)       [22, 1, 44, 10, 5, 2, 22, 2, 8, 2, 1, 1, 20, 1]
zn_power_table                                                                [Function]
        zn_power_table (n)
        zn_power_table (n, gcd)
        zn_power_table (n, gcd, max_exp)
      Without any optional argument zn_power_table(n) shows a power table of all el-
      ements in (Z/nZ)* which are all residue classes coprime to n. The exponent loops
Chapter 29: Number Theory                                                               533
      The third argument max exp allows to set the highest exponent. The following table
      shows a very small example of RSA.
           (%i1) N:2*5$ phi:totient(N)$ e:7$ d:inv_mod(e,phi)$
          (%o2)                                  3
          (%i3) zn_order(g, n) = totient(n);
          (%o3)                                6 = 6
          (%i4) n : 15$
          (%i5) zn_primroot(n);
          (%o5)                                false
     The optional second argument must be of the same form as the list returned by
     ifactors(totient(n)).
          (%i1) (p : 2^142 + 217, primep(p));
          (%o1)                                true
          (%i2) ifs : ifactors( totient(p) )$
          (%i3) g : zn_primroot(p, ifs);
          (%o3)                                  3
          (%i4) [time(%o2), time(%o3)];
          (%o4)                     [[15.556972], [0.004]]
          (%i5) is(zn_order(g, p, ifs) = p - 1);
          (%o5)                                true
          (%i6) n : 2^142 + 216$
          (%i7) ifs : ifactors(totient(n))$
          (%i8) zn_primroot(n, ifs),
                 zn_primroot_limit : 200, zn_primroot_verbose : true;
          ‘zn_primroot' stopped at zn_primroot_limit = 200
          (%o8)                                false
zn_primroot_limit                                                      [Option variable]
     Default value: 1000
     If zn_primroot cannot find a primitive root, it stops at this upper bound. If the
     option variable zn_primroot_verbose (default: false) is set to true, a message will
     be printed when zn_primroot_limit is reached.
zn_primroot_p                                                                 [Function]
        zn_primroot_p (x, n)
        zn_primroot_p (x, n, [[p1, e1], . . . , [pk, ek]])
     Checks whether x is a primitive root in the multiplicative group (Z/nZ)*.
     The applied algorithm needs a prime factorization of totient(n). This factorization
     might be time consuming and in case zn_primroot_p will be consecutively applied to
     a list of candidates it can be useful to factor first and then to pass the list of factors
     to zn_log as a third argument. The list must be of the same form as the list returned
     by ifactors(totient(n)) using the default option factors_only : false.
     See also zn_primroot, zn_order, ifactors, totient.
     Examples:
     zn_primroot_p as a predicate function.
            (%i1) n : 14$
            (%i2) units_14 : sublist(makelist(i,i,1,13), lambda([i], gcd(i, n) = 1));
            (%o2)                           [1, 3, 5, 9, 11, 13]
            (%i3) zn_primroot_p(13, n);
536                                                                Maxima 5.45.0 Manual
           (%o3)                               false
           (%i4) sublist(units_14, lambda([x], zn_primroot_p(x, n)));
           (%o4)                               [3, 5]
           (%i5) map(lambda([x], zn_order(x, n)), units_14);
           (%o5)                        [1, 6, 6, 3, 3, 2]
      The optional third argument must be of the same form as the list returned by
      ifactors(totient(n)).
           (%i1) (p: 2^142 + 217, primep(p));
           (%o1)                           true
           (%i2) ifs: ifactors( totient(p) )$
           (%i3) sublist(makelist(i,i,1,50), lambda([x], zn_primroot_p(x,p,ifs)));
           (%o3) [3, 12, 13, 15, 21, 24, 26, 27, 29, 33, 38, 42, 48]
           (%i4) [time(%o2), time(%o3)];
           (%o4)                   [[7.748484], [0.036002]]
30 Symmetries
                                                                    + (- 2 (49 - e2) - 2) e2
            (%i2) ratsimp (%);
                                               2
           (%o2)                 28 e3 + 2 e2 - 198 e2 + 2401
      Other functions for changing bases: comp2ele.
mon2schur (L)                                                                            [Function]
      The list L represents the Schur function SL : we have L = [i1 , i2 , . . . , iq ], with i1 ≤
      i2 ≤ . . . ≤ iq . The Schur function Si1 ,i2 ,...,iq is the minor of the infinite matrix hi−j ,
      i ≥ 1, j ≥ 1, consisting of the q first rows and the columns i1 + 1, i2 + 2, . . . , iq + q.
      This Schur function can be written in terms of monomials by using treinat and
      kostka. The form returned is a symmetric polynomial in a contracted representation
      in the variables x1 , x2 , . . .
             (%i1) mon2schur ([1, 1, 1]);
             (%o1)                                x1 x2 x3
             (%i2) mon2schur ([3]);
                                                              2         3
             (%o2)                      x1 x2 x3 + x1 x2 + x1
             (%i3) mon2schur ([1, 2]);
                                                                  2
             (%o3)                         2 x1 x2 x3 + x1 x2
      which means that for 3 variables this gives:
                  2 x1 x2 x3 + x1^2 x2 + x2^2 x1 + x1^2 x3 + x3^2 x1
                   + x2^2 x3 + x3^2 x2
      Other functions for changing bases: comp2ele.
multi_elem (l_elem, multi_pc, l_var)                                                [Function]
      decomposes a multi-symmetric polynomial in the multi-contracted form multi pc in
      the groups of variables contained in the list of lists l var in terms of the elementary
      symmetric functions contained in l elem.
Chapter 30: Symmetries                                                                    539
            (%i1) multi_elem ([[2, e1, e2], [2, f1, f2]], a*x + a^2 + x^3,
                  [[x, y], [a, b]]);
                                                              3
            (%o1)         - 2 f2 + f1 (f1 + e1) - 3 e1 e2 + e1
            (%i2) ratsimp (%);
                                     2                       3
            (%o2)         - 2 f2 + f1 + e1 f1 - 3 e1 e2 + e1
     Other functions for changing bases: comp2ele.
multi_pui                                                                     [Function]
     is to the function pui what the function multi_elem is to the function elem.
            (%i1) multi_pui ([[2, p1, p2], [2, t1, t2]], a*x + a^2 + x^3,
                  [[x, y], [a, b]]);
                                                        3
                                            3 p1 p2   p1
            (%o1)              t2 + p1 t1 + ------- - ---
                                               2       2
                                                               3     4     3   4
                                                          + 2 a b x y + 2 a b x y
           (%i2) contract (psym, [x, y, z]);
                                         3   4
           (%o2)                      2 a b x y
explose (pc, lvar)                                                          [Function]
     returns the symmetric polynomial associated with the contracted form pc. The list
     lvar contains the variables.
           (%i1) explose (a*x + 1, [x, y, z]);
           (%o1)                    a z + a y + a x + 1
part2cont (ppart, lvar)                                                    [Function]
     goes from the partitioned form to the contracted form of a symmetric polynomial.
     The contracted form is rendered with the variables in lvar.
           (%i1) part2cont ([[2*a^3*b, 4, 1]], [x, y]);
                                              3     4
           (%o1)                          2 a b x y
partpol (psym, lvar)                                                              [Function]
     psym is a symmetric polynomial in the variables of the list lvar. This function returns
     its partitioned representation.
           (%i1) partpol (-a*(x + y) + 3*x*y, [x, y]);
           (%o1)                     [[3, 1, 1], [- a, 1, 0]]
542                                                                   Maxima 5.45.0 Manual
                                             2            2             2   2
                              - 4 e2 f2 - (e1 - 2 e2) (f1 - 2 f2) + e1 f1
                            + -----------------------------------------------
                                                     2
            (%i2) ratsimp (%);
                          2                2                   2
            (%o2)        y - e1 f1 y + (e1 - 4 e2) f2 + e2 f1
Chapter 30: Symmetries                                                                 543
                                     3                               3   3
            + ((9 e3 + 5 e1 e2 - 2 e1 ) f1 f2 + (- 2 e3 - 2 e1 e2) f1 ) y
                    2      2       4    2
            + ((9 e2 - 6 e1 e2 + e1 ) f2
                               2      2      2                  2    4
            + (- 9 e1 e3 - 6 e2 + 3 e1 e2) f1 f2 + (2 e1 e3 + e2 ) f1 )
             2         2                     2    3         2
            y + (((9 e1 - 27 e2) e3 + 3 e1 e2 - e1 e2) f1 f2
                            2            2    3               5
            + ((15 e2 - 2 e1 ) e3 - e1 e2 ) f1 f2 - 2 e2 e3 f1 ) y
                      2                  3           3    2  2    3
            + (- 27 e3 + (18 e1 e2 - 4 e1 ) e3 - 4 e2 + e1 e2 ) f2
                    2     3                  3    2  2
            + (27 e3 + (e1 - 9 e1 e2) e3 + e2 ) f1 f2
                              2    4       2  6
            + (e1 e2 e3 - 9 e3 ) f1 f2 + e3 f1
     Finding the polynomial whose roots are the sums a+u where a is a root of z 2 −e1 z +e2
     and u is a root of z 2 − f1 z + f2 .
           (%i1) ratsimp (direct ([z^2 - e1* z + e2, z^2 - f1* z + f2],
                                     z, a + u, [[u], [a]]));
                  4                    3             2
           (%o1) y + (- 2 f1 - 2 e1) y + (2 f2 + f1 + 3 e1 f1 + 2 e2
                2   2                             2              2
            + e1 ) y + ((- 2 f1 - 2 e1) f2 - e1 f1 + (- 2 e2 - e1 ) f1
                             2                    2            2
            - 2 e1 e2) y + f2 + (e1 f1 - 2 e2 + e1 ) f2 + e2 f1 + e1 e2 f1
                2
            + e2
     direct accepts two flags: elementaires and puissances (default) which allow de-
     composing the symmetric polynomials appearing in the calculation into elementary
     symmetric functions, or power functions, respectively.
544                                                                      Maxima 5.45.0 Manual
     The result is in multi-contracted form w.r.t. SD, i.e. only one element is kept per
     orbit, under the action of SD.
           (%i1) l: [[x, y], [a, b]];
           (%o1)                   [[x, y], [a, b]]
           (%i2) pui_direct (multi_orbit (a*x + b*y, l), l, [2, 2]);
                                                  2 2
           (%o2)               [a x, 4 a b x y + a x ]
           (%i3) pui_direct (multi_orbit (a*x + b*y, l), l, [3, 2]);
                                        2 2      2    2        3 3
           (%o3) [2 a x, 4 a b x y + 2 a x , 3 a b x y + 2 a x ,
               2 2 2 2     3   3       4 4
           12 a b x y + 4 a b x y + 2 a x ,
               3 2 3 2     4   4       5 5
           10 a b x y + 5 a b x y + 2 a x ,
               3 3 3 3          4 2 4 2         5    5        6 6
           40 a b x y + 15 a b x y + 6 a b x y + 2 a x ]
           (%i4) pui_direct ([y + x + 2*c, y + x + 2*b, y + x + 2*a],
                 [[x, y], [a, b, c]], [2, 3]);
                                        2              2
           (%o4) [3 x + 2 a, 6 x y + 3 x + 4 a x + 4 a ,
                                  2                        3             2            2          3
                            9 x       y + 12 a x y + 3 x       + 6 a x       + 12 a       x + 8 a ]
30.2.4 Partitions
kostka (part_1, part_2)                                                    [Function]
     written by P. Esperet, calculates the Kostka number of the partition part 1 and
     part 2.
           (%i1) kostka ([3, 3, 3], [2, 2, 2, 1, 1, 1]);
           (%o1)                           6
                                                                          [1, 1, 1, 1, 1]]
            (%i3) treinat ([3, 2]);
            (%o3)                 [[5], [4, 1], [3, 2]]
      See also: lgtreillis, ltreillis and treillis.
30.2.6 Resolvents
resolvante (P, x, f, [x_1,..., x_d])                                               [Function]
     calculates the resolvent of the polynomial P in x of degree n >= d by the function f
     expressed in the variables x 1, ..., x d. For efficiency of computation it is important
     to not include in the list [x_1, ..., x_d] variables which do not appear in the
     transformation function f.
     To increase the efficiency of the computation one may set flags in resolvante so as
     to use appropriate algorithms:
     If the function f is unitary:
       • A polynomial in a single variable,
       • linear,
       • alternating,
       • a sum,
       • symmetric,
       • a product,
       • the function of the Cayley resolvent (usable up to degree 5)
                (x1*x2 + x2*x3 + x3*x4 + x4*x5 + x5*x1 -
                       (x1*x3 + x3*x5 + x5*x2 + x2*x4 + x4*x1))^2
          general,
548                                                                                Maxima 5.45.0 Manual
           " resolvante unitaire " [7, 0, 28, 0, 168, 0, 1120, - 154, 7840,
                                    - 2772, 56448, - 33880,
            12      9     6     3      15      12       9      6     3
           x   - 4 x + 6 x - 4 x + 1, x   - 5 x   + 10 x - 10 x + 5 x
                      18           15            12            9            6           3
             - 1, x        - 6 x        + 15 x        - 20 x       + 15 x       - 6 x       + 1,
            21      18       15       12       9       6      3
           x   - 7 x   + 21 x   - 35 x   + 35 x - 21 x + 7 x - 1]
           [- 7, 1127, - 6139, 431767, - 5472047, 201692519, - 3603982011]
                  7      6        5         4          3           2
           (%o2) y + 7 y - 539 y - 1841 y + 51443 y + 315133 y
                                                         + 376999 y + 125253
           (%i3) resolvante: lineaire$
           (%i4) resolvante (x^4 - 1, x, x1 + 2*x2 + 3*x3, [x1, x2, x3]);
                                                                                   4
                                                                      + 344489984 y + 655360000
           (%i5) resolvante: general$
Chapter 30: Symmetries                                                     549
                                                              4
                                                 + 344489984 y + 655360000
          (%i7) resolvante (x^4 - 1, x, x1 + 2*x2 + 3*x3, [x1, x2, x3, x4]);
                                                                  4
                                                    + 344489984 y + 655360000
          (%i8) direct ([x^4 - 1], x, x1 + 2*x2 + 3*x3, [[x1, x2, x3]]);
                  24        20          16             12              8
          (%o8) y    + 80 y    + 7520 y    + 1107200 y    + 49475840 y
                                                                 4
                                                    + 344489984 y + 655360000
          (%i9) resolvante :lineaire$
          (%i10) resolvante (x^4 - 1, x, x1 + x2 + x3, [x1, x2, x3]);
              24           23          22            21           20
      + 1323 y   + 352947 y   - 46305 y   - 2463339 y   + 324135 y
               19           18             17              15
      - 30618 y   - 453789 y   - 40246444 y   + 282225202 y
                  14              12             11            10
      - 44274492 y   + 155098503 y   + 12252303 y   + 2893401 y
                   9           8           7            6
      - 171532242 y + 6751269 y + 2657205 y - 94517766 y
                  5             3
       - 3720087 y + 26040609 y + 14348907
      (%i18) resolvante: symetrique$
      (%i19) resolvante (x^7 - 7*x + 3, x, x1*x2*x3, [x1, x2, x3]);
              24           23          22            21           20
      + 1323 y   + 352947 y   - 46305 y   - 2463339 y   + 324135 y
               19           18             17              15
      - 30618 y   - 453789 y   - 40246444 y   + 282225202 y
                  14              12             11            10
      - 44274492 y   + 155098503 y   + 12252303 y   + 2893401 y
                   9           8           7            6
      - 171532242 y + 6751269 y + 2657205 y - 94517766 y
                  5             3
       - 3720087 y + 26040609 y + 14348907
      (%i20) resolvante: cayley$
Chapter 30: Symmetries                                                                    551
+ 93392896
     For the Cayley resolvent, the 2 last arguments are neutral and the input polynomial
     must necessarily be of degree 5.
See also:
See also:
See also:
                         6              5                 4                  3                    2
             - 945 x         - 4970 x       - 18333 x          - 29079 x         - 20745 x            - 25326 x
             - 697
      See also:
      hundefinedi resolvante_produit_sym, hundefinedi resolvante_unitaire,
      hundefinedi resolvante_alternee1, hundefinedi resolvante_klein, hundefinedi
      resolvante_klein3,
      hundefinedi resolvante_vierer, hundefinedi resolvante.
resolvante_klein (P, x)                                                                                   [Function]
      calculates the transformation of P(x) by the function x_1 x_2 x_4 + x_4.
      See also:
      hundefinedi resolvante_produit_sym, hundefinedi resolvante_unitaire,
      hundefinedi resolvante_alternee1, hundefinedi resolvante, hundefinedi resolvante_
      klein3,
      hundefinedi resolvante_vierer, hundefinedi resolvante_diedrale.
resolvante_klein3 (P, x)                                                       [Function]
      calculates the transformation of P(x) by the function x_1 x_2 x_4 + x_4.
      See also:
      hundefinedi resolvante_produit_sym, hundefinedi resolvante_unitaire,
      hundefinedi resolvante_alternee1, hundefinedi resolvante_klein, hundefinedi
      resolvante,
      hundefinedi resolvante_vierer, hundefinedi resolvante_diedrale.
resolvante_produit_sym (P, x)                                                 [Function]
      calculates the list of all product resolvents of the polynomial P(x).
            (%i1) resolvante_produit_sym (x^5 + 3*x^4 + 2*x - 1, x);
                       5         4               10         8       7       6     5
            (%o1) [y + 3 y + 2 y - 1, y              - 2 y - 21 y - 31 y - 14 y
                   4            3           2            10           8            7         6            5            4
             - y       + 14 y       + 3 y       + 1, y        + 3 y       + 14 y       - y       - 14 y       - 31 y
                  3      2       5      4
            - 21 y - 2 y + 1, y - 2 y - 3 y - 1, y - 1]
           (%i2) resolvante: produit$
           (%i3) resolvante (x^5 + 3*x^4 + 2*x - 1, x, a*b*c, [a, b, c]);
     See also:
     hundefinedi   resolvante, hundefinedi resolvante_unitaire,
     hundefinedi   resolvante_alternee1, hundefinedi resolvante_klein,
     hundefinedi   resolvante_klein3, hundefinedi resolvante_vierer,
     hundefinedi   resolvante_diedrale.
30.2.7 Miscellaneous
multinomial (r, part)                                                                   [Function]
     where r is the weight of the partition part. This function returns the associate multi-
     nomial coefficient: if the parts of part are i 1, i 2, ..., i k, the result is r!/(i_1! i_2!
     ... i_k!).
31 Groups
                                          <2>
           else (if not i = j then p(i, j)    else p(i, i)), j, 1, n - 1,
         i, 1, j)
         (%i2) p(i,j) := concat(x,i).concat(x,j);
         (%o2)         p(i, j) := concat(x, i) . concat(x, j)
         (%i3) symet(5);
                  <2>            <3>     <2>            <2>            <3>
         (%o3) [x1    , (x1 . x2)    , x2    , (x1 . x3)    , (x2 . x3)    ,
         Rows tried 71
         (%o6)                                20
                                                                                        557
32 Runtime Environment
32.2 Interrupts
The user can stop a time-consuming computation with the ^C (control-C) character. The
default action is to stop the computation and print another user prompt. In this case, it is
not possible to restart a stopped computation.
   If the Lisp variable *debugger-hook* is set to nil, by executing
       :lisp (setq *debugger-hook* nil)
then upon receiving ^C, Maxima will enter the Lisp debugger, and the user may use the
debugger to inspect the Lisp environment. The stopped computation can be restarted by
entering continue in the Lisp debugger. The means of returning to Maxima from the Lisp
debugger (other than running the computation to completion) is different for each version
of Lisp.
   On Unix systems, the character ^Z (control-Z) causes Maxima to stop altogether, and
control is returned to the shell prompt. The fg command causes Maxima to resume from
the point at which it was stopped.
parse_timedate                                                                     [Function]
        parse_timedate (S)
      Parses a string S representing a date or date and time of day and returns the number
      of seconds since midnight, January 1, 1900 GMT. If there is a nonzero fractional part,
      the value returned is a rational number, otherwise, it is an integer. parse_timedate
      returns false if it cannot parse S according to any of the allowed formats.
      The string S must have one of the following formats, optionally followed by a timezone
      designation:
       • YYYY-MM-DD[ T]hh:mm:ss[,.]nnn
       • YYYY-MM-DD[ T]hh:mm:ss
       • YYYY-MM-DD
      where the fields are year, month, day, hours, minutes, seconds, and fraction of a sec-
      ond, and square brackets indicate acceptable alternatives. The fraction may contain
      one or more digits.
      Except for the fraction of a second, each field must have exactly the number of digits
      indicated: four digits for the year, and two for the month, day of the month, hours,
      minutes, and seconds.
      A timezone designation must have one of the following forms:
       •   [+-]hh:mm
       •   [+-]hhmm
       •   [+-]hh
       •   Z
      where hh and mm indicate hours and minutes east (+) or west (-) of GMT. The
      timezone may be from +24 hours (inclusive) to -24 hours (inclusive).
      A literal character Z is equivalent to +00:00 and its variants, indicating GMT.
      If no timezone is indicated, the time is assumed to be in the local time zone.
      Any leading or trailing whitespace (space, tab, newline, and carriage return) is ig-
      nored, but any other leading or trailing characters cause parse_timedate to fail and
      return false.
      See also timedate and absolute_real_time.
      Examples:
      Midnight, January 1, 1900, in the local time zone, in each acceptable format. The
      result is the number of seconds the local time zone is ahead (negative result) or behind
      (positive result) GMT. In this example, the local time zone is 8 hours behind GMT.
            (%i1) parse_timedate ("1900-01-01 00:00:00,000");
            (%o1)                         28800
            (%i2) parse_timedate ("1900-01-01 00:00:00.000");
            (%o2)                         28800
            (%i3) parse_timedate ("1900-01-01T00:00:00,000");
            (%o3)                         28800
Chapter 32: Runtime Environment                                                            561
encode_time                                                        [Function]
        encode_time (year, month, day, hours, minutes, seconds, tz_offset)
        encode_time (year, month, day, hours, minutes, seconds)
     Given a time and date specified by year, month, day, hours, minutes, and seconds,
     encode_time returns the number of seconds (possibly including a fractional part)
     since midnight, January 1, 1900 GMT.
     year must be an integer greater than or equal to 1899. However, 1899 is allowed only
     if the resulting encoded time is greater than or equal to 0.
     month must be an integer from 1 to 12, inclusive.
     day must be an integer from 1 to n, inclusive, where n is the number of days in the
     month specified by month.
     hours must be an integer from 0 to 23, inclusive.
     minutes must be an integer from 0 to 59, inclusive.
     seconds must be an integer, rational, or float greater than or equal to 0 and less than
     60. When seconds is not an integer, encode_time returns a rational, such that the
     fractional part of the return value is equal to the fractional part of seconds. Otherwise,
     seconds is an integer, and the return value is likewise an integer.
     tz offset measures the offset of the time zone, in hours, east (positive) or west (neg-
     ative) of GMT. tz offset must be an integer, rational, or float between -24 and 24,
     inclusive. If tz offset is not a multiple of 1/3600, it is rounded to the nearest multiple
     of 1/3600.
562                                                                    Maxima 5.45.0 Manual
      If tz offset is not present, the offset of the local time zone is assumed.
      See also decode_time.
      Examples:
            (%i1) encode_time (1900, 1, 1, 0, 0, 0, 0);
            (%o1)                            0
            (%i2) encode_time (1970, 1, 1, 0, 0, 0, 0);
            (%o2)                      2208988800
            (%i3) encode_time (1970, 1, 1, 8, 30, 0, 8.5);
            (%o3)                      2208988800
            (%i4) encode_time (1969, 12, 31, 16, 0, 0, -8);
            (%o4)                      2208988800
            (%i5) encode_time (1969, 12, 31, 16, 0, 1/1000, -8);
                                      2208988800001
            (%o5)                     -------------
                                          1000
            (%i6) % - 2208988800;
                                           1
            (%o6)                         ----
                                          1000
decode_time                                                                          [Function]
        decode_time (T, tz_offset)
        decode_time (T)
      Given the number of seconds (possibly including a fractional part) since midnight,
      January 1, 1900 GMT, returns the date and time as represented by a list comprising
      the year, month, day of the month, hours, minutes, seconds, and time zone offset.
      tz offset measures the offset of the time zone, in hours, east (positive) or west (neg-
      ative) of GMT. tz offset must be an integer, rational, or float between -24 and 24,
      inclusive. If tz offset is not a multiple of 1/3600, it is rounded to the nearest multiple
      of 1/3600.
      If tz offset is not present, the offset of the local time zone is assumed.
      See also encode_time.
      Examples:
            (%i1) decode_time (0, 0);
            (%o1)               [1900, 1, 1, 0, 0, 0, 0]
            (%i2) decode_time (0);
            (%o2)             [1899, 12, 31, 16, 0, 0, - 8]
            (%i3) decode_time (2208988800, 9.25);
                                                      37
            (%o3)              [1970, 1, 1, 9, 15, 0, --]
                                                      4
            (%i4) decode_time (2208988800);
            (%o4)             [1969, 12, 31, 16, 0, 0, - 8]
            (%i5) decode_time (2208988800 + 1729/1000, -6);
                                                  1729
Chapter 32: Runtime Environment                                                       563
absolute_real_time ()                                                    [Function]
     Returns the number of seconds since midnight, January 1, 1900 GMT. The return
     value is an integer.
     See also elapsed_real_time and elapsed_run_time.
     Example:
           (%i1) absolute_real_time ();
           (%o1)                         3385045277
           (%i2) 1900 + absolute_real_time () / (365.25 * 24 * 3600);
           (%o2)                     2007.265612087104
elapsed_real_time ()                                                            [Function]
     Returns the number of seconds (including fractions of a second) since Maxima was
     most recently started or restarted. The return value is a floating-point number.
     See also absolute_real_time and elapsed_run_time.
     Example:
           (%i1) elapsed_real_time ();
           (%o1)                            2.559324
           (%i2) expand ((a + b)^500)$
           (%i3) elapsed_real_time ();
           (%o3)                            7.552087
elapsed_run_time ()                                                        [Function]
     Returns an estimate of the number of seconds (including fractions of a second)
     which Maxima has spent in computations since Maxima was most recently started or
     restarted. The return value is a floating-point number.
     See also absolute_real_time and elapsed_real_time.
     Example:
           (%i1) elapsed_run_time ();
           (%o1)                                0.04
           (%i2) expand ((a + b)^500)$
           (%i3) elapsed_run_time ();
           (%o3)                                1.26
                                                                                            565
33 Miscellaneous Options
33.2 Share
The Maxima "share" directory contains programs and other files of interest to Maxima
users, but not part of the core implementation of Maxima. These programs are typically
loaded via load or setup_autoload.
    :lisp *maxima-sharedir* displays the location of the share directory within the user’s
file system.
    printfile ("share.usg") prints an out-of-date list of share packages. Users may find
it more informative to browse the share directory using a file system browser.
      Examples:
          (%i1) gensym();
          (%o1)                                    g887
          (%i2) gensym("new");
          (%o2)                                  new888
          (%i3) gensym(123);
          (%o3)                                    g123
packagefile                                                                   [Option variable]
      Default value: false
      Package designers who use save or translate to create packages (files) for others to
      use may want to set packagefile: true to prevent information from being added to
      Maxima’s information-lists (e.g. values, functions) except where necessary when
      the file is loaded in. In this way, the contents of the package will not get in the user’s
      way when he adds his own data. Note that this will not solve the problem of possible
      name conflicts. Also note that the flag simply affects what is output to the package
      file. Setting the flag to true is also useful for creating Maxima init files.
remvalue                                                                              [Function]
        remvalue (name_1, . . . , name_n)
        remvalue remvalue (all)
      Removes the values of user variables name 1, . . . , name n (which can be subscripted)
      from the system.
      remvalue (all) removes the values of all variables in values, the list of all variables
      given names by the user (as opposed to those which are automatically assigned by
      Maxima).
      See also values.
rncombine (expr)                                                               [Function]
      Transforms expr by combining all terms of expr that have identical denominators or
      denominators that differ from each other by numerical factors only. This is slightly
      different from the behavior of combine, which collects terms that have identical de-
      nominators.
      Setting pfeformat: true and using combine yields results similar to those that can
      be obtained with rncombine, but rncombine takes the additional step of cross-
      multiplying numerical denominator factors. This results in neater forms, and the
      possibility of recognizing some cancellations.
      load(rncomb) loads this function.
setup_autoload (filename, function_1, . . . , function_n)                             [Function]
      Specifies that if any of function 1, . . . , function n are referenced and not yet defined,
      filename is loaded via load. filename usually contains definitions for the functions
      specified, although that is not enforced.
      setup_autoload does not work for memoizing functions.
      setup_autoload quotes its arguments.
      Example:
             (%i1) legendre_p (1, %pi);
Chapter 33: Miscellaneous Options                                                     567
tcl_output                                                                     [Function]
        tcl_output (list, i0, skip)
        tcl_output (list, i0)
        tcl_output ([list_1, . . . , list_n], i)
     Prints elements of a list enclosed by curly braces { }, suitable as part of a program
     in the Tcl/Tk language.
     tcl_output (list, i0, skip) prints list, beginning with element i0 and printing
     elements i0 + skip, i0 + 2 skip, etc.
     tcl_output (list, i0) is equivalent to tcl_output (list, i0, 2).
     tcl_output ([list_1, ..., list_n], i) prints the i’th elements of list 1, . . . ,
     list n.
     Examples:
           (%i1) tcl_output ([1, 2, 3, 4, 5, 6], 1, 3)$
            {1.000000000     4.000000000
            }
           (%i2) tcl_output ([1, 2, 3, 4, 5, 6], 2, 3)$
            {2.000000000     5.000000000
            }
           (%i3) tcl_output ([3/7, 5/9, 11/13, 13/17], 1)$
       }
      (%i5) tcl_output ([[1, 2, 3], [11, 22, 33]], 1)$
     Define a function linearp(expr) which tests expr to see if it is of the form a*x +
     b such that a and b do not contain x and a is nonzero. This match function only
     matches expressions linear in x, not any other variable, because no pattern argument
     is given to defmatch.
disprule                                                                       [Function]
        disprule (rulename_1, . . . , rulename_2)
        disprule (all)
      Display rules with the names rulename 1, . . . , rulename n, as returned by defrule,
      tellsimp, or tellsimpafter, or a pattern defined by defmatch. Each rule is dis-
      played with an intermediate expression label (%t).
      disprule (all) displays all rules.
      disprule quotes its arguments. disprule returns the list of intermediate expression
      labels corresponding to the displayed rules.
      See also letrules, which displays rules defined by let.
      Examples:
           (%i1)   tellsimpafter (foo (x, y), bar (x) + baz (y));
           (%o1)                     [foorule1, false]
           (%i2)   tellsimpafter (x + y, special_add (x, y));
           (%o2)                     [+rule1, simplus]
           (%i3)   defmatch (quux, mumble (x));
           (%o3)                           quux
           (%i4)   disprule (foorule1, ?\+rule1, quux);
           (%t4)          foorule1 : foo(x, y) -> baz(y) + bar(x)
            (%i7) ev(%);
            (%o7) [foorule1 : foo(x, y) -> baz(y) + bar(x),
                 +rule1 : y + x -> special_add(x, y), quux : mumble(x) -> []]
let                                                                             [Function]
          let (prod, repl, predname, arg_1, . . . , arg_n)
          let ([prod, repl, predname, arg_1, . . . , arg_n], package_name)
      Defines a substitution rule for letsimp such that prod is replaced by repl. prod is a
      product of positive or negative powers of the following terms:
        • Atoms which letsimp will search for literally unless previous to calling letsimp
          the matchdeclare function is used to associate a predicate with the atom. In
          this case letsimp will match the atom to any term of a product satisfying the
          predicate.
        • Kernels such as sin(x), n!, f(x,y), etc. As with atoms above letsimp will look
          for a literal match unless matchdeclare is used to associate a predicate with the
          argument of the kernel.
      A term to a positive power will only match a term having at least that power. A
      term to a negative power on the other hand will only match a term with a power at
      least as negative. In the case of negative powers in prod the switch letrat must be
      set to true. See also letrat.
      If a predicate is included in the let function followed by a list of arguments, a
      tentative match (i.e. one that would be accepted if the predicate were omitted) is
      accepted only if predname (arg_1', ..., arg_n') evaluates to true where arg i’ is
      the value matched to arg i. The arg i may be the name of any atom or the argument
      of any kernel appearing in prod. repl may be any rational expression. If any of the
      atoms or arguments from prod appear in repl the appropriate substitutions are made.
      The global flag letrat controls the simplification of quotients by letsimp. When
      letrat is false, letsimp simplifies the numerator and denominator of expr sepa-
      rately, and does not simplify the quotient. Substitutions such as n!/n goes to (n-1)!
      then fail. When letrat is true, then the numerator, denominator, and the quotient
      are simplified in that order.
      These substitution functions allow you to work with several rule packages at once.
      Each rule package can contain any number of let rules and is referenced by an
      user-defined name.      The command let ([prod, repl, predname, arg_1, ...,
      arg_n], package_name) adds the rule predname to the rule package package name.
      The command letsimp (expr, package_name) applies the rules in package name.
      letsimp (expr, package_name1, package_name2, ...) is equivalent to letsimp
      (expr, package_name1) followed by letsimp (%, package_name2), . . .
      current_let_rule_package is the name of the rule package that is presently be-
      ing used. This variable may be assigned the name of any rule package defined via
      the let command. Whenever any of the functions comprising the let package are
      called with no package name, the package named by current_let_rule_package is
      used. If a call such as letsimp (expr, rule_pkg_name) is made, the rule package
      rule pkg name is used for that letsimp command only, and current_let_rule_
      package is not changed. If not otherwise specified, current_let_rule_package de-
      faults to default_let_rule_package.
574                                                               Maxima 5.45.0 Manual
letrules                                                                       [Function]
        letrules ()
        letrules (package_name)
      Displays the rules in a rule package. letrules () displays the rules in the current
      rule package. letrules (package_name) displays the rules in package name.
      The current rule package is named by current_let_rule_package. If not otherwise
      specified, current_let_rule_package defaults to default_let_rule_package.
      See also disprule, which displays rules defined by tellsimp and tellsimpafter.
Chapter 34: Rules and Patterns                                                      575
letsimp                                                                       [Function]
          letsimp (expr)
          letsimp (expr, package_name)
          letsimp (expr, package_name_1, . . . , package_name_n)
     Repeatedly applies the substitution rules defined by let until no further change is
     made to expr.
     letsimp (expr) uses the rules from current_let_rule_package.
     letsimp (expr, package_name) uses the rules from package name without changing
     current_let_rule_package.
     letsimp (expr, package_name_1, ..., package_name_n) is equivalent to letsimp
     (expr, package_name_1), followed by letsimp (%, package_name_2), and so on.
     See also let. For other ways to do substitutions see also subst, psubst, at and
     ratsubst.
           (%i1) e0: e(k) = -(9*y(k))/(5*z)-u(k-1)/(5*z)+(4*y(k))/(5*z^2)
                              +(3*u(k-1))/(5*z^2)+y(k)-(2*u(k-1))/5;
                             9 y(k)       u(k - 1)     4 y(k)   3 u(k - 1)
           (%o1) e(k) = (- ------) - -------- + ------ + ---------- + y(k)
                              5 z           5 z             2            2
                                                        5 z          5 z
                                                                            2 u(k - 1)
                                                                          - ----------
                                                                                 5
           (%i2) matchdeclare(h,any)$
           (%i3) let(u(h)/z,u(h-1));
                                       u(h)
           (%o3)                       ---- --> u(h - 1)
                                        z
           (%i4) let(y(h)/z, y(h-1));
                                       y(h)
           (%o4)                       ---- --> y(h - 1)
                                        z
           (%i5) e1:letsimp(e0);
                             2 u(k - 1)                3 u(k - 3)     4 y(k - 2)
           (%o5) e(k) = (- ----------) + y(k) + ---------- + ----------
                                  5                         5              5
                                                         u(k - 2)          9 y(k - 1)
                                                    + (- --------) + (- ----------)
                                                             5                 5
let_rule_packages                                                      [Option variable]
     Default value: [default_let_rule_package]
     let_rule_packages is a list of all user-defined let rule packages plus the default
     package default_let_rule_package.
matchdeclare (a_1, pred_1, . . . , a_n, pred_n)                               [Function]
     Associates a predicate pred k with a variable or list of variables a k so that a k
     matches expressions for which the predicate returns anything other than false.
576                                                                   Maxima 5.45.0 Manual
     and the new replacement and/or predicate name. Should remlet (prod) now be
     called the original substitution rule is revived.
     See also remrule, which removes a rule defined by tellsimp or tellsimpafter.
remrule                                                                          [Function]
          remrule (op, rulename)
          remrule (op, all)
     Removes rules defined by tellsimp or tellsimpafter.
     remrule (op, rulename) removes the rule with the name rulename from the operator
     op. When op is a built-in or user-defined operator (as defined by infix, prefix, etc.),
     op and rulename must be enclosed in double quote marks.
     remrule (op, all) removes all rules for the operator op.
     See also remlet, which removes a rule defined by let.
     Examples:
           (%i1) tellsimp (foo (aa, bb), bb - aa);
           (%o1)                         [foorule1, false]
           (%i2) tellsimpafter (aa + bb, special_add (aa, bb));
           (%o2)                         [+rule1, simplus]
           (%i3) infix ("@@");
           (%o3)                                 @@
           (%i4) tellsimp (aa @@ bb, bb/aa);
           (%o4)                         [@@rule1, false]
           (%i5) tellsimpafter (quux (%pi, %e), %pi - %e);
           (%o5)                        [quuxrule1, false]
           (%i6) tellsimpafter (quux (%e, %pi), %pi + %e);
           (%o6)                 [quuxrule2, quuxrule1, false]
           (%i7) [foo (aa, bb), aa + bb, aa @@ bb, quux (%pi, %e),
                   quux (%e, %pi)];
                                                         bb
           (%o7) [bb - aa, special_add(aa, bb), --, %pi - %e, %pi + %e]
                                                         aa
           (%i8) remrule (foo, foorule1);
           (%o8)                                 foo
           (%i9) remrule ("+", ?\+rule1);
           (%o9)                                   +
           (%i10) remrule ("@@", ?\@\@rule1);
           (%o10)                                @@
           (%i11) remrule (quux, all);
           (%o11)                               quux
           (%i12) [foo (aa, bb), aa + bb, aa @@ bb, quux (%pi, %e),
                    quux (%e, %pi)];
           (%o12) [foo(aa, bb), bb + aa, aa @@ bb, quux(%pi, %e),
                                                                          quux(%e, %pi)]
tellsimp (pattern, replacement)                                                  [Function]
     is similar to tellsimpafter but places new information before old so that it is applied
     before the built-in simplification rules.
580                                                                Maxima 5.45.0 Manual
      tellsimp is used when it is important to modify the expression before the simplifier
      works on it, for instance if the simplifier "knows" something about the expression,
      but what it returns is not to your liking. If the simplifier "knows" something about
      the main operator of the expression, but is simply not doing enough for you, you
      probably want to use tellsimpafter.
      The pattern may not be a sum, product, single variable, or number.
      The system variable rules is the list of rules defined by defrule, defmatch,
      tellsimp, and tellsimpafter.
      Examples:
           (%i1) matchdeclare (x, freeof (%i));
           (%o1)                         done
           (%i2) %iargs: false$
           (%i3) tellsimp (sin(%i*x), %i*sinh(x));
           (%o3)                 [sinrule1, simp-%sin]
           (%i4) trigexpand (sin (%i*y + x));
           (%o4)         sin(x) cos(%i y) + %i cos(x) sinh(y)
           (%i5) %iargs:true$
           (%i6) errcatch(0^0);
            0
           0 has been generated
           (%o6)                          []
           (%i7) ev (tellsimp (0^0, 1), simp: false);
           (%o7)                  [^rule1, simpexpt]
           (%i8) 0^0;
           (%o8)                           1
           (%i9) remrule ("^", %th(2)[1]);
           (%o9)                           ^
           (%i10) tellsimp (sin(x)^2, 1 - cos(x)^2);
           (%o10)                 [^rule2, simpexpt]
           (%i11) (1 + sin(x))^2;
                                                 2
           (%o11)                    (sin(x) + 1)
           (%i12) expand (%);
                                              2
           (%o12)               2 sin(x) - cos (x) + 2
           (%i13) sin(x)^2;
                                             2
           (%o13)                     1 - cos (x)
           (%i14) kill (rules);
           (%o14)                        done
           (%i15) matchdeclare (a, true);
           (%o15)                        done
           (%i16) tellsimp (sin(a)^2, 1 - cos(a)^2);
           (%o16)                 [^rule3, simpexpt]
           (%i17) sin(y)^2;
                                             2
Chapter 34: Rules and Patterns                                                           581
      See also matchdeclare, defmatch, defrule, tellsimp, let, kill, remrule and
      clear_rules.
      Examples:
      pattern may be any nonatomic expression in which the main operator is not a pattern
      variable.
            (%i1) matchdeclare (aa, atom, [ll, mm], listp, xx, true)$
            (%i2) tellsimpafter (sin (ll), map (sin, ll));
            (%o2)                 [sinrule1, simp-%sin]
            (%i3) sin ([1/6, 1/4, 1/3, 1/2, 1]*%pi);
                                1     1      sqrt(3)
            (%o3)              [-, -------, -------, 1, 0]
                                2 sqrt(2)       2
            (%i4) tellsimpafter (ll^mm, map ("^", ll, mm));
            (%o4)                  [^rule1, simpexpt]
            (%i5) [a, b, c]^[1, 2, 3];
                                             2   3
            (%o5)                       [a, b , c ]
            (%i6) tellsimpafter (foo (aa (xx)), aa (foo (xx)));
            (%o6)                   [foorule1, false]
            (%i7) foo (bar (u - v));
            (%o7)                    bar(foo(u - v))
      Rules are applied in the order they were defined. If two rules can match an expression,
      the rule which was defined first is applied.
            (%i1)   matchdeclare (aa, integerp);
            (%o1)                           done
            (%i2)   tellsimpafter (foo (aa), bar_1 (aa));
            (%o2)                     [foorule1, false]
            (%i3)   tellsimpafter (foo (aa), bar_2 (aa));
            (%o3)                [foorule2, foorule1, false]
            (%i4)   foo (42);
            (%o4)                         bar_1(42)
      Pattern variables are treated as local variables in simplification rules. (Compare to
      defmatch, which treats pattern variables as global variables.)
            (%i1)   matchdeclare (aa, integerp, bb, atom);
            (%o1)                           done
            (%i2)   tellsimpafter (foo(aa, bb), bar('aa=aa, 'bb=bb));
            (%o2)                     [foorule1, false]
            (%i3)   bb: 12345;
            (%o3)                           12345
            (%i4)   foo (42, %e);
            (%o4)                   bar(aa = 42, bb = %e)
            (%i5)   bb;
            (%o5)                           12345
Chapter 34: Rules and Patterns                                                          583
     As with all atoms, properties of pattern variables are global even though values are
     local. In this example, an assignment property is declared via define_variable.
     This is a property of the atom bb throughout Maxima.
           (%i1) matchdeclare (aa, integerp, bb, atom);
           (%o1)                         done
           (%i2) tellsimpafter (foo(aa, bb), bar('aa=aa, 'bb=bb));
           (%o2)                   [foorule1, false]
           (%i3) foo (42, %e);
           (%o3)                 bar(aa = 42, bb = %e)
           (%i4) define_variable (bb, true, boolean);
           (%o4)                         true
           (%i5) foo (42, %e);
           translator: bb was declared with mode boolean, but it has value:
                                                                          %e
            -- an error. To debug this try: debugmode(true);
     Rules are named after main operators. Names of rules for built-in and user-defined
     operators are Lisp identifiers, while names for other functions are Maxima identifiers.
           (%i1) tellsimpafter (foo (%pi + %e), 3*%pi);
           (%o1)                   [foorule1, false]
           (%i2) tellsimpafter (foo (%pi * %e), 17*%e);
           (%o2)              [foorule2, foorule1, false]
           (%i3) tellsimpafter (foo (%i ^ %e), -42*%i);
           (%o3)         [foorule3, foorule2, foorule1, false]
           (%i4) tellsimpafter (foo (9) + foo (13), quux (22));
           (%o4)                   [+rule1, simplus]
           (%i5) tellsimpafter (foo (9) * foo (13), blurf (22));
           (%o5)                  [*rule1, simptimes]
           (%i6) tellsimpafter (foo (9) ^ foo (13), mumble (22));
           (%o6)                  [^rule1, simpexpt]
           (%i7) rules;
           (%o7) [foorule1, foorule2, foorule3, +rule1, *rule1, ^rule1]
           (%i8) foorule_name: first (%o1);
           (%o8)                       foorule1
           (%i9) plusrule_name: first (%o4);
           (%o9)                        +rule1
           (%i10) remrule (foo, foorule1);
           (%o10)                         foo
           (%i11) remrule ("^", ?\^rule1);
           (%o11)                          ^
           (%i12) rules;
           (%o12)        [foorule2, foorule3, +rule1, *rule1]
     A worked example: anticommutative multiplication.
           (%i1) gt (i, j) := integerp(j) and i < j;
           (%o1)          gt(i, j) := integerp(j) and (i < j)
           (%i2) matchdeclare (i, integerp, j, gt(i));
           (%o2)                         done
584                                                            Maxima 5.45.0 Manual
clear_rules ()                                                             [Function]
      Executes kill (rules) and then resets the next rule number to 1 for addition +,
      multiplication *, and exponentiation ^.
                                                                                           585
35 Sets
35.1.1 Usage
To construct a set with members a_1, ..., a_n, write set(a_1, ..., a_n) or {a_1, ...,
a_n}; to construct the empty set, write set() or {}. In input, set(...) and { ... } are
equivalent. Sets are always displayed with curly braces.
    If a member is listed more than once, simplification eliminates the redundant member.
        (%i1) set();
        (%o1)                                {}
        (%i2) set(a, b, a);
        (%o2)                             {a, b}
        (%i3) set(a, set(b));
        (%o3)                            {a, {b}}
        (%i4) set(a, [b]);
        (%o4)                            {a, [b]}
        (%i5) {};
        (%o5)                                {}
        (%i6) {a, b, a};
        (%o6)                             {a, b}
        (%i7) {a, {b}};
        (%o7)                            {a, {b}}
        (%i8) {a, [b]};
        (%o8)                            {a, [b]}
    Two would-be elements x and y are redundant (i.e., considered the same for the purpose
of set construction) if and only if is(x = y) yields true. Note that is(equal(x, y)) can
yield true while is(x = y) yields false; in that case the elements x and y are considered
distinct.
        (%i1) x: a/c + b/c;
                                           b    a
        (%o1)                              - + -
                                           c    c
        (%i2) y: a/c + b/c;
                                           b    a
        (%o2)                              - + -
                                           c    c
586                                                               Maxima 5.45.0 Manual
      (%i3) z: (a + b)/c;
                                         b + a
      (%o3)                              -----
                                           c
      (%i4)   is (x = y);
      (%o4)                              true
      (%i5)   is (y = z);
      (%o5)                              false
      (%i6)   is (equal (y, z));
      (%o6)                              true
      (%i7)   y - z;
                                     b + a   b   a
      (%o7)                        - ----- + - + -
                                       c     c   c
      (%i8) ratsimp (%);
      (%o8)                                0
      (%i9) {x, y, z};
                                      b + a b       a
       (%o9)                         {-----, - + -}
                                         c      c   c
   To construct a set from the elements of a list, use setify.
       (%i1) setify ([b, a]);
       (%o1)                               {a, b}
   Set members x and y are equal provided is(x = y) evaluates to true. Thus rat(x) and
x are equal as set members; consequently,
       (%i1) {x, rat(x)};
       (%o1)                                  {x}
   Further, since is((x - 1)*(x + 1) = x^2 - 1) evaluates to false, (x - 1)*(x + 1) and
x^2 - 1 are distinct set members; thus
       (%i1) {(x - 1)*(x + 1), x^2 - 1};
                                                       2
       (%o1)                   {(x - 1) (x + 1), x - 1}
   To reduce this set to a singleton set, apply rat to each set member:
       (%i1) {(x - 1)*(x + 1), x^2 - 1};
                                                       2
       (%o1)                   {(x - 1) (x + 1), x - 1}
       (%i2) map (rat, %);
                                            2
       (%o2)/R/                          {x - 1}
   To remove redundancies from other sets, you may need to use other simplification func-
tions. Here is an example that uses trigsimp:
       (%i1) {1, cos(x)^2 + sin(x)^2};
                                         2            2
       (%o1)                    {1, sin (x) + cos (x)}
       (%i2) map (trigsimp, %);
Chapter 35: Sets                                                                       587
       (%o2)                                 {1}
    A set is simplified when its members are non-redundant and sorted. The current version
of the set functions uses the Maxima function orderlessp to order sets; however, future
versions of the set functions might use a different ordering function.
    Some operations on sets, such as substitution, automatically force a re-simplification;
for example,
       (%i1) s: {a, b, c}$
       (%i2) subst (c=a, s);
       (%o2)                               {a, b}
       (%i3) subst ([a=x, b=x, c=x], s);
       (%o3)                                 {x}
       (%i4) map (lambda ([x], x^2), set (-1, 0, 1));
       (%o4)                               {0, 1}
    Maxima treats lists and sets as distinct objects; functions such as union and
intersection complain if any argument is not a set. If you need to apply a set function
to a list, use the setify function to convert it to a set. Thus
       (%i1) union ([1, 2], {a, b});
       Function union expects a set, instead found [1,2]
         -- an error. Quitting. To debug this try debugmode(true);
       (%i2) union (setify ([1, 2]), {a, b});
       (%o2)                           {1, 2, a, b}
    To extract all set elements of a set s that satisfy a predicate f, use subset(s, f). (A
predicate is a boolean-valued function.) For example, to find the equations in a given set
that do not depend on a variable z, use
       (%i1) subset ({x + y + z, x - y + 4, x + y - 5},
                                                   lambda ([e], freeof (z, e)));
       (%o1)                     {- y + x + 4, y + x - 5}
    The section Section 35.2 [Functions and Variables for Sets], page 588, has a complete
list of the set functions in Maxima.
there are other Maxima functions that work correctly on sets. In future versions of the set
functions, first and rest may function differently or not at all.
   Maxima’s orderless and ordergreat mechanisms are incompatible with the set func-
tions. If you need to use either orderless or ordergreat, call those functions before
constructing any sets, and do not call unorder.
35.1.3 Authors
Stavros Macrakis of Cambridge, Massachusetts and Barton Willis of the University of Ne-
braska at Kearney (UNK) wrote the Maxima set functions and their documentation.
every                                                                           [Function]
          every (f, s)
          every (f, L_1, ..., L_n)
      Returns true if the predicate f is true for all given arguments.
Chapter 35: Sets                                                                        593
     Given one set as the second argument, every(f, s) returns true if is(f(a_i))
     returns true for all a i in s. every may or may not evaluate f for all a i in s. Since
     sets are unordered, every may evaluate f(a_i) in any order.
     Given one or more lists as arguments, every(f, L_1, ..., L_n) returns true if
     is(f(x_1, ..., x_n)) returns true for all x 1, ..., x n in L 1, ..., L n, respectively.
     every may or may not evaluate f for every combination x 1, ..., x n. every evaluates
     lists in the order of increasing index.
     Given an empty set {} or empty lists [] as arguments, every returns true.
     When the global flag maperror is true, all lists L 1, ..., L n must have equal lengths.
     When maperror is false, list arguments are effectively truncated to the length of the
     shortest list.
     Return values of the predicate f which evaluate (via is) to something other than
     true or false are governed by the global flag prederror. When prederror is true,
     such values are treated as false, and the return value from every is false. When
     prederror is false, such values are treated as unknown, and the return value from
     every is unknown.
     Examples:
     every applied to a single set. The predicate is a function of one argument.
           (%i1) every (integerp, {1, 2, 3, 4, 5, 6});
           (%o1)                         true
           (%i2) every (atom, {1, 2, sin(3), 4, 5 + y, 6});
           (%o2)                         false
     every applied to two lists. The predicate is a function of two arguments.
           (%i1) every ("=", [a, b, c], [a, b, c]);
           (%o1)                         true
           (%i2) every ("#", [a, b, c], [a, b, c]);
           (%o2)                         false
     Return values of the predicate f which evaluate to something other than true or
     false are governed by the global flag prederror.
           (%i1) prederror : false;
           (%o1)                         false
           (%i2) map (lambda ([a, b], is (a < b)), [x, y, z],
                              [x^2, y^2, z^2]);
           (%o2)              [unknown, unknown, unknown]
           (%i3) every ("<", [x, y, z], [x^2, y^2, z^2]);
           (%o3)                        unknown
           (%i4) prederror : true;
           (%o4)                         true
           (%i5) every ("<", [x, y, z], [x^2, y^2, z^2]);
           (%o5)                         false
594                                                                Maxima 5.45.0 Manual
extremal_subset                                                                 [Function]
        extremal_subset (s, f, max)
        extremal_subset (s, f, min)
      Returns the subset of s for which the function f takes on maximum or minimum
      values.
      extremal_subset(s, f, max) returns the subset of the set or list s for which the
      real-valued function f takes on its maximum value.
      extremal_subset(s, f, min) returns the subset of the set or list s for which the
      real-valued function f takes on its minimum value.
      Examples:
            (%i1) extremal_subset ({-2, -1, 0, 1, 2}, abs, max);
            (%o1)                             {- 2, 2}
            (%i2) extremal_subset ({sqrt(2), 1.57, %pi/2}, sin, min);
            (%o2)                             {sqrt(2)}
           (%o3)                             f(g(f(x)))
     flatten treats subscripted functions the same as any other operator.
           (%i1) flatten (f[5] (f[5] (x, y), z));
           (%o1)                      f (x, y, z)
                                       5
     It may be possible for flatten to construct expressions in which the number of
     arguments differs from the declared arguments for an operator;
           (%i1) 'mod (5, 'mod (7, 4));
           (%o1)                   mod(5, mod(7, 4))
           (%i2) flatten (%);
           (%o2)                     mod(5, 7, 4)
           (%i3) ''%, nouns;
           Wrong number of arguments to mod
            -- an error. Quitting. To debug this try debugmode(true);
integer_partitions                                                                      [Function]
        integer_partitions (n)
        integer_partitions (n, len)
      Returns integer partitions of n, that is, lists of integers which sum to n.
      integer_partitions(n) returns the set of all partitions of the integer n. Each
      partition is a list sorted from greatest to least.
      integer_partitions(n, len) returns all partitions that have length len or less; in
      this case, zeros are appended to each partition with fewer than len terms to make
      each partition have exactly len terms. Each partition is a list sorted from greatest to
      least.
      A list [a1 , ..., am ] is a partition of a nonnegative integer n when (1) each ai is a nonzero
      integer, and (2) a1 + ... + am = n. Thus 0 has no partitions.
      Examples:
            (%i1)   integer_partitions (3);
            (%o1)                 {[1, 1, 1], [2, 1], [3]}
            (%i2)   s: integer_partitions (25)$
            (%i3)   cardinality (s);
            (%o3)                           1958
            (%i4)   map (lambda ([x], apply ("+", x)), s);
            (%o4)                           {25}
            (%i5)   integer_partitions (5, 3);
            (%o5)   {[2, 2, 1], [3, 1, 1], [3, 2, 0], [4, 1, 0], [5, 0, 0]}
            (%i6)   integer_partitions (5, 2);
            (%o6)                 {[3, 2], [4, 1], [5, 0]}
      To find all partitions that satisfy a condition, use the function subset; here is an
      example that finds all partitions of 10 that consist of prime numbers.
            (%i1)   s: integer_partitions (10)$
            (%i2)   cardinality (s);
            (%o2)                            42
            (%i3)   xprimep(x) := integerp(x) and (x > 1) and primep(x)$
            (%i4)   subset (s, lambda ([x], every (xprimep, x)));
            (%o4)   {[2, 2, 2, 2, 2], [3, 3, 2, 2], [5, 3, 2], [5, 5], [7, 3]}
           (%o3)                           {c, d, e, f}
           (%i4)   S_4 : {u, v, w};
           (%o4)                         {u, v, w}
           (%i5)   intersection (S_1, S_2);
           (%o5)                            {d}
           (%i6)   intersection (S_2, S_3);
           (%o6)                         {d, e, f}
           (%i7)   intersection (S_1, S_2, S_3);
           (%o7)                            {d}
           (%i8)   intersection (S_1, S_2, S_3, S_4);
           (%o8)                            {}
kron_delta (x1, x2, . . . , xp)                                                   [Function]
     Represents the Kronecker delta function.
     kron_delta simplifies to 1 when xi and yj are equal for all pairs of arguments, and it
     simplifies to 0 when xi and yj are not equal for some pair of arguments. Equality is
     determined using is(equal(xi,xj)) and inequality by is(notequal(xi,xj)). For
     exactly one argument, kron_delta signals an error.
     Examples:
           (%i1) kron_delta(a,a);
           (%o1)                                          1
           (%i2) kron_delta(a,b,a,b);
           (%o2)                                kron_delta(a, b)
           (%i3) kron_delta(a,a,b,a+1);
           (%o3)                                          0
           (%i4) assume(equal(x,y));
           (%o4)                                   [equal(x, y)]
           (%i5) kron_delta(x,y);
           (%o5)                                          1
listify (a)                                                               [Function]
     Returns a list containing the members of a when a is a set. Otherwise, listify
     returns a.
     full_listify replaces all set operators in a by list operators.
     Examples:
           (%i1) listify ({a, b, c, d});
           (%o1)                         [a, b, c, d]
           (%i2) listify (F ({a, b, c, d}));
           (%o2)                        F({a, b, c, d})
makeset (expr, x, s)                                                              [Function]
     Returns a set with members generated from the expression expr, where x is a list of
     variables in expr, and s is a set or list of lists. To generate each set member, expr is
     evaluated with the variables x bound in parallel to a member of s.
     Each member of s must have the same length as x. The list of variables x must be a
     list of symbols, without subscripts. Even if there is only one symbol, x must be a list
     of one element, and each member of s must be a list of one element.
598                                                                 Maxima 5.45.0 Manual
multinomial_coeff                                                                 [Function]
        multinomial_coeff (a_1, ..., a_n)
        multinomial_coeff ()
     Returns the multinomial coefficient.
     When each a k is a nonnegative integer, the multinomial coefficient gives the number
     of ways of placing a_1 + ... + a_n distinct objects into n boxes with a k elements in
     the k’th box. In general, multinomial_coeff (a_1, ..., a_n) evaluates to (a_1 +
     ... + a_n)!/(a_1! ... a_n!).
     multinomial_coeff() (with no arguments) evaluates to 1.
     minfactorial may be able to simplify the value returned by multinomial_coeff.
     Examples:
           (%i1) multinomial_coeff (1, 2, x);
                                       (x + 3)!
           (%o1)                       --------
                                         2 x!
           (%i2) minfactorial (%);
                                (x + 1) (x + 2) (x + 3)
           (%o2)                -----------------------
                                           2
           (%i3) multinomial_coeff (-6, 2);
                                        (- 4)!
           (%o3)                       --------
                                       2 (- 6)!
           (%i4) minfactorial (%);
           (%o4)                          10
num_distinct_partitions                                                           [Function]
        num_distinct_partitions (n)
        num_distinct_partitions (n, list)
     Returns the number of distinct integer partitions of n when n is a nonnegative integer.
     Otherwise, num_distinct_partitions returns a noun expression.
     num_distinct_partitions(n, list) returns a list of the number of distinct parti-
     tions of 1, 2, 3, ..., n.
     A distinct partition of n is a list of distinct positive integers k1 , ..., km such that
     n = k1 + ... + km .
     Examples:
           (%i1) num_distinct_partitions (12);
           (%o1)                          15
           (%i2) num_distinct_partitions (12, list);
           (%o2)      [1, 1, 1, 2, 2, 3, 4, 5, 6, 8, 10, 12, 15]
           (%i3) num_distinct_partitions (n);
           (%o3)              num_distinct_partitions(n)
600                                                                Maxima 5.45.0 Manual
num_partitions                                                                  [Function]
        num_partitions (n)
        num_partitions (n, list)
      Returns the number of integer partitions of n when n is a nonnegative integer. Oth-
      erwise, num_partitions returns a noun expression.
      num_partitions(n, list) returns a list of the number of integer partitions of 1, 2,
      3, ..., n.
      For a nonnegative integer n, num_partitions(n) is equal to cardinality(integer_
      partitions(n)); however, num_partitions does not actually construct the set of
      partitions, so it is much faster.
      Examples:
            (%i1) num_partitions (5) = cardinality (integer_partitions (5));
            (%o1)                         7 = 7
            (%i2) num_partitions (8, list);
            (%o2)            [1, 1, 2, 3, 5, 7, 11, 15, 22]
            (%i3) num_partitions (n);
            (%o3)                   num_partitions(n)
powerset                                                                          [Function]
        powerset (a)
        powerset (a, n)
     Returns the set of all subsets of a, or a subset of that set.
     powerset(a) returns the set of all subsets of the set a. powerset(a) has
     2^cardinality(a) members.
     powerset(a, n) returns the set of all subsets of a that have cardinality n.
     powerset complains if a is not a literal set, or if n is not a nonnegative integer.
     Examples:
          (%i1) powerset ({a, b, c});
          (%o1) {{}, {a}, {a, b}, {a, b, c}, {a, c}, {b}, {b, c}, {c}}
          (%i2) powerset ({w, x, y, z}, 4);
          (%o2)                            {{w, x, y, z}}
          (%i3) powerset ({w, x, y, z}, 3);
          (%o3)        {{w, x, y}, {w, x, z}, {w, y, z}, {x, y, z}}
          (%i4) powerset ({w, x, y, z}, 2);
          (%o4)     {{w, x}, {w, y}, {w, z}, {x, y}, {x, z}, {y, z}}
          (%i5) powerset ({w, x, y, z}, 1);
          (%o5)                        {{w}, {x}, {y}, {z}}
          (%i6) powerset ({w, x, y, z}, 0);
          (%o6)                                  {{}}
set_partitions                                                                     [Function]
        set_partitions (a)
        set_partitions (a, n)
       Returns the set of all partitions of a, or a subset of that set.
       set_partitions(a, n) returns a set of all decompositions of a into n nonempty
       disjoint subsets.
       set_partitions(a) returns the set of all partitions.
       stirling2 returns the cardinality of the set of partitions of a set.
       A set of sets P is a partition of a set S when
        1. each member of P is a nonempty set,
        2. distinct members of P are disjoint,
        3. the union of the members of P equals S.
       Examples:
       The empty set is a partition of itself, the conditions 1 and 2 being vacuously true.
             (%i1) set_partitions ({});
             (%o1)                                 {{}}
       The cardinality of the set of partitions of a set can be found using stirling2.
             (%i1) s: {0, 1, 2, 3, 4, 5}$
             (%i2) p: set_partitions (s, 3)$
             (%i3) cardinality(p) = stirling2 (6, 3);
             (%o3)                        90 = 90
       Each member of p should have n = 3 members; let’s check.
             (%i1) s: {0, 1, 2, 3, 4, 5}$
             (%i2) p: set_partitions (s, 3)$
             (%i3) map (cardinality, p);
             (%o3)                          {3}
       Finally, for each member of p, the union of its members should equal s; again let’s
       check.
             (%i1) s: {0, 1, 2, 3, 4, 5}$
             (%i2) p: set_partitions (s, 3)$
             (%i3) map (lambda ([x], apply (union, listify (x))), p);
             (%o3)                 {{0, 1, 2, 3, 4, 5}}
some                                                                               [Function]
           some (f, a)
           some (f, L_1, ..., L_n)
       Returns true if the predicate f is true for one or more given arguments.
       Given one set as the second argument, some(f, s) returns true if is(f(a_i)) returns
       true for one or more a i in s. some may or may not evaluate f for all a i in s. Since
       sets are unordered, some may evaluate f(a_i) in any order.
604                                                                  Maxima 5.45.0 Manual
      Given one or more lists as arguments, some(f, L_1, ..., L_n) returns true if
      is(f(x_1, ..., x_n)) returns true for one or more x 1, ..., x n in L 1, ..., L n,
      respectively. some may or may not evaluate f for some combinations x 1, ..., x n.
      some evaluates lists in the order of increasing index.
      Given an empty set {} or empty lists [] as arguments, some returns false.
      When the global flag maperror is true, all lists L 1, ..., L n must have equal lengths.
      When maperror is false, list arguments are effectively truncated to the length of the
      shortest list.
      Return values of the predicate f which evaluate (via is) to something other than
      true or false are governed by the global flag prederror. When prederror is true,
      such values are treated as false. When prederror is false, such values are treated
      as unknown.
      Examples:
      some applied to a single set. The predicate is a function of one argument.
            (%i1) some (integerp, {1, 2, 3, 4, 5, 6});
            (%o1)                                 true
            (%i2) some (atom, {1, 2, sin(3), 4, 5 + y, 6});
            (%o2)                                 true
      some applied to two lists. The predicate is a function of two arguments.
            (%i1) some ("=", [a, b, c], [a, b, c]);
            (%o1)                                 true
            (%i2) some ("#", [a, b, c], [a, b, c]);
            (%o2)                                 false
      Return values of the predicate f which evaluate to something other than true or
      false are governed by the global flag prederror.
            (%i1) prederror : false;
            (%o1)                                 false
            (%i2) map (lambda ([a, b], is (a < b)), [x, y, z],
                          [x^2, y^2, z^2]);
            (%o2)                   [unknown, unknown, unknown]
            (%i3) some ("<", [x, y, z], [x^2, y^2, z^2]);
            (%o3)                                unknown
            (%i4) some ("<", [x, y, z], [x^2, y^2, z + 1]);
            (%o4)                                 true
            (%i5) prederror : true;
            (%o5)                                 true
            (%i6) some ("<", [x, y, z], [x^2, y^2, z^2]);
            (%o6)                                 false
            (%i7) some ("<", [x, y, z], [x^2, y^2, z + 1]);
            (%o7)                                 true
stirling1 (n, m)                                                           [Function]
      Represents the Stirling number of the first kind.
      When n and m are nonnegative integers, the magnitude of stirling1 (n, m) is the
      number of permutations of a set with n members that have m cycles.
Chapter 35: Sets                                                                       605
36 Function Definition
36.2 Function
36.2.1 Ordinary functions
To define a function in Maxima you use the := operator. E.g.
        f(x) := sin(x)
defines a function f. Anonymous functions may also be created using lambda. For example
        lambda ([i, j], ...)
can be used instead of f where
        f(i,j) := block ([], ...);
        map (lambda ([i], i+1), l)
would return a list with 1 added to each term.
    You may also define a function with a variable number of arguments, by having a final
argument which is assigned to a list of the extra arguments:
        (%i1) f ([u]) := u;
        (%o1)                            f([u]) := u
        (%i2) f (1, 2, 3, 4);
        (%o2)                          [1, 2, 3, 4]
        (%i3) f (a, b, [u]) := [a, b, u];
        (%o3)                   f(a, b, [u]) := [a, b, u]
        (%i4) f (1, 2, 3, 4, 5, 6);
        (%o4)                      [1, 2, [3, 4, 5, 6]]
    The right hand side of a function is an expression. Thus if you want a sequence of
expressions, you do
        f(x) := (expr1, expr2, ...., exprn);
    and the value of exprn is what is returned by the function.
    If you wish to make a return from some expression inside the function then you must
use block and return.
        block ([], expr1, ..., if (a > 10) then return(a), ..., exprn)
    is itself an expression, and so could take the place of the right hand side of a function
definition. Here it may happen that the return happens earlier than the last expression.
    The first [] in the block, may contain a list of variables and variable assignments, such
as [a: 3, b, c: []], which would cause the three variables a,b,and c to not refer to their
global values, but rather have these special values for as long as the code executes inside
the block, or inside functions called from inside the block. This is called dynamic binding,
since the variables last from the start of the block to the time it exits. Once you return
from the block, or throw out of it, the old values (if any) of the variables will be restored.
It is certainly a good idea to protect your variables in this way. Note that the assignments
in the block variables, are done in parallel. This means, that if you had used c: a in the
610                                                                 Maxima 5.45.0 Manual
above, the value of c would have been the value of a at the time you just entered the block,
but before a was bound. Thus doing something like
      block ([a: a], expr1, ... a: a+3, ..., exprn)
    will protect the external value of a from being altered, but would let you access what
that value was. Thus the right hand side of the assignments, is evaluated in the entering
context, before any binding occurs. Using just block ([x], ...) would cause the x to have
itself as value, just as if it would have if you entered a fresh Maxima session.
   The actual arguments to a function are treated in exactly same way as the variables in
a block. Thus in
      f(x) := (expr1, ..., exprn);
   and
      f(1);
   we would have a similar context for evaluation of the expressions as if we had done
      block ([x: 1], expr1, ..., exprn)
    Inside functions, when the right hand side of a definition, may be computed at runtime,
it is useful to use define and possibly buildq.
      (%i2) a[x]:=float(sum(sin(x*t),t,1,10000));
      Evaluation took 0.0000 seconds (0.0000 elapsed) using 0 bytes.
      (%o2)        a := float(sum(sin(x t), t, 1, 10000))
                    x
      (%i3) a[1];
      Evaluation took 5.1250 seconds (5.1260 elapsed) using 775.250 MB.
      (%o3)                   1.633891021792447
      (%i4) a[1];
      Evaluation took 0.0000 seconds (0.0000 elapsed) using 0 bytes.
      (%o4)                   1.633891021792447
   As the memoizing function is only evaluated once for each input value changes in variables
the memoizing function uses are not considered for values that are already cached:
      (%i1) a[x]:=b*x;
      (%o1)                             a := b x
                                         x
      (%i2)   b:1;
      (%o2)                                  1
      (%i3)   a[2];
      (%o3)                                  2
      (%i4)   b:2;
      (%o4)                                  2
      (%i5)   a[1];
      (%o5)                                  2
      (%i6)   a[2];
      (%o6)                                  2
36.3 Macros
buildq (L, expr)                                                                 [Function]
      Substitutes variables named by the list L into the expression expr, in parallel, with-
      out evaluating expr. The resulting expression is simplified, but not evaluated, after
      buildq carries out the substitution.
      The elements of L are symbols or assignment expressions symbol: value, evaluated
      in parallel. That is, the binding of a variable on the right-hand side of an assignment
      is the binding of that variable in the context from which buildq was called, not the
      binding of that variable in the variable list L. If some variable in L is not given an
      explicit assignment, its binding in buildq is the same as in the context from which
      buildq was called.
      Then the variables named by L are substituted into expr in parallel. That is, the
      substitution for every variable is determined before any substitution is made, so the
      substitution for one variable has no effect on any other.
      If any variable x appears as splice (x) in expr, then x must be bound to a list, and
      the list is spliced (interpolated) into expr instead of substituted.
      Any variables in expr not appearing in L are carried into the result verbatim, even if
      they have bindings in the context from which buildq was called.
612                                                                  Maxima 5.45.0 Manual
      Examples
      a is explicitly bound to x, while b has the same binding (namely 29) as in the calling
      context, and c is carried through verbatim. The resulting expression is not evaluated
      until the explicit evaluation ''%.
            (%i1) (a: 17, b: 29, c: 1729)$
            (%i2) buildq ([a: x, b], a + b + c);
            (%o2)                      x + c + 29
            (%i3) ''%;
            (%o3)                       x + 1758
      e is bound to a list, which appears as such in the arguments of foo, and interpolated
      into the arguments of bar.
            (%i1) buildq ([e: [a, b, c]], foo (x, e, y));
            (%o1)                 foo(x, [a, b, c], y)
            (%i2) buildq ([e: [a, b, c]], bar (x, splice (e), y));
            (%o2)                  bar(x, a, b, c, y)
      The result is simplified after substitution. If simplification were applied before sub-
      stitution, these two results would be the same.
            (%i1) buildq ([e: [a, b, c]], splice (e) + splice (e));
            (%o1)                    2 c + 2 b + 2 a
            (%i2) buildq ([e: [a, b, c]], 2 * splice (e));
            (%o2)                        2 a b c
      The variables in L are bound in parallel; if bound sequentially, the first result would
      be foo (b, b). Substitutions are carried out in parallel; compare the second result
      with the result of subst, which carries out substitutions sequentially.
            (%i1) buildq ([a: b, b: a], foo (a, b));
            (%o1)                       foo(b, a)
            (%i2) buildq ([u: v, v: w, w: x, x: y, y: z, z: u],
                          bar (u, v, w, x, y, z));
            (%o2)                 bar(v, w, x, y, z, u)
            (%i3) subst ([u=v, v=w, w=x, x=y, y=z, z=u],
                         bar (u, v, w, x, y, z));
            (%o3)                 bar(u, u, u, u, u, u)
      Construct a list of equations with some variables or expressions on the left-hand side
      and their values on the right-hand side. macroexpand shows the expression returned
      by show_values.
            (%i1)   show_values ([L]) ::= buildq ([L], map ("=", 'L, L));
            (%o1)     show_values([L]) ::= buildq([L], map("=", 'L, L))
            (%i2)   (a: 17, b: 29, c: 1729)$
            (%i3)   show_values (a, b, c - a - b);
            (%o3)            [a = 17, b = 29, c - b - a = 1683]
            (%i4)   macroexpand (show_values (a, b, c - a - b));
            (%o4)      map(=, '([a, b, c - b - a]), [a, b, c - b - a])
      Given a function of several arguments, create another function for which some of the
      arguments are fixed.
Chapter 36: Function Definition                                                       613
            (%o3)                         [%t3]
            (%i4) dispfun (fname);
            fundef: no such function: fname
             -- an error. To debug this try: debugmode(true);
            (%i5) apply (dispfun, [fname]);
                                               x
            (%t5)                     F(x) := ----
                                              1729
            (%o5)                               [%t5]
      apply evaluates the function name F. Single quote ' defeats evaluation. demoivre is
      the name of a global variable and also a function.
            (%i1) demoivre;
            (%o1)                         false
            (%i2) demoivre (exp (%i * x));
            (%o2)                  %i sin(x) + cos(x)
616                                                                   Maxima 5.45.0 Manual
block                                                                               [Function]
          block ([v_1, . . . , v_m], expr_1, . . . , expr_n)
          block (expr_1, . . . , expr_n)
      The function block allows to make the variables v 1, . . . , v m to be local for a
      sequence of commands. If these variables are already bound block saves the current
      values of the variables v 1, . . . , v m (if any) upon entry to the block, then unbinds
      the variables so that they evaluate to themselves; The local variables may be bound
      to arbitrary values within the block but when the block is exited the saved values are
      restored, and the values assigned within the block are lost.
      If there is no need to define local variables then the list at the beginning of the block
      command may be omitted. In this case if neither return nor go are used block
      behaves similar to the following construct:
            ( expr_1, expr_2,... , expr_n );
      expr 1, . . . , expr n will be evaluated in sequence and the value of the last expression
      will be returned. The sequence can be modified by the go, throw, and return func-
      tions. The last expression is expr n unless return or an expression containing throw
      is evaluated.
      The declaration local(v_1, ..., v_m) within block saves the properties associated
      with the symbols v 1, . . . , v m, removes any properties before evaluating other ex-
      pressions, and restores any saved properties on exit from the block. Some declara-
      tions are implemented as properties of a symbol, including :=, array, dependencies,
      atvalue, matchdeclare, atomgrad, constant, nonscalar, assume, and some oth-
      ers. The effect of local is to make such declarations effective only within the block;
      otherwise declarations within a block are actually global declarations.
      block may appear within another block. Local variables are established each time a
      new block is evaluated. Local variables appear to be global to any enclosed blocks.
      If a variable is non-local in a block, its value is the value most recently assigned
      by an enclosing block, if any, otherwise, it is the value of the variable in the global
      environment. This policy may coincide with the usual understanding of "dynamic
      scope".
      The value of the block is the value of the last statement or the value of the argument
      to the function return which may be used to exit explicitly from the block. The
Chapter 36: Function Definition                                                            617
     function go may be used to transfer control to the statement of the block that is
     tagged with the argument to go. To tag a statement, precede it by an atomic argument
     as another statement in the block. For example: block ([x], x:1, loop, x: x+1,
     ..., go(loop), ...). The argument to go must be the name of a tag appearing
     within the block. One cannot use go to transfer to a tag in a block other than the
     one containing the go.
     Blocks typically appear on the right side of a function definition but can be used in
     other places as well.
     See also return and go.
compfile                                                                            [Function]
        compfile (filename, f_1, . . . , f_n)
        compfile (filename, functions)
        compfile (filename, all)
     Translates Maxima functions into Lisp and writes the translated code into the file
     filename.
     compfile(filename, f_1, ..., f_n) translates the specified functions. compfile
     (filename, functions) and compfile (filename, all) translate all user-defined
     functions.
     The Lisp translations are not evaluated, nor is the output file processed by the Lisp
     compiler. translate creates and evaluates Lisp translations. compile_file trans-
     lates Maxima into Lisp, and then executes the Lisp compiler.
     See also translate, translate_file, and compile_file.
618                                                                   Maxima 5.45.0 Manual
compile                                                                            [Function]
           compile (f_1, . . . , f_n)
           compile (functions)
           compile (all)
      Translates Maxima functions f 1, . . . , f n into Lisp, evaluates the Lisp translations,
      and calls the Lisp function COMPILE on each translated function. compile returns a
      list of the names of the compiled functions.
      compile (all) or compile (functions) compiles all user-defined functions.
      compile quotes its arguments; the quote-quote operator '' defeats quotation.
      Compiling a function to native code can mean a big increase in speed and might cause
      the memory footprint to reduce drastically. Code tends to be especially effective when
      the flexibility it needs to provide is limited. If compilation doesn’t provide the speed
      that is needed a few ways to limit the code’s functionality are the following:
         • If the function accesses global variables the complexity of the function can be
           drastically be reduced by limiting these variables to one data type, for example
           using mode_declare or a statement like the following one: put(x_1, bigfloat,
           numerical_type)
         • The compiler might warn about undeclared variables if text could either be a
           named option to a command or (if they are assigned a value to) the name of a
           variable. Prepending the option with a single quote ' tells the compiler that the
           text is meant as an option.
define                                                                          [Function]
           define   (f(x_1, . . . , x_n), expr)
           define   (f[x_1, . . . , x_n], expr)
           define   (f[x_1, . . . , x_n](y_1, . . . , y_m), expr)
           define   (funmake (f, [x_1, . . . , x_n]), expr)
           define   (arraymake (f, [x_1, . . . , x_n]), expr)
           define   (ev (expr_1), expr_2)
      Defines a function named f with arguments x 1, . . . , x n and function body expr.
      define always evaluates its second argument (unless explicitly quoted). The function
      so defined may be an ordinary Maxima function (with arguments enclosed in paren-
      theses) or a memoizing function (with arguments enclosed in square brackets).
      When the last or only function argument x n is a list of one element, the function
      defined by define accepts a variable number of arguments. Actual arguments are
      assigned one-to-one to formal arguments x 1, . . . , x (n - 1), and any further actual
      arguments, if present, are assigned to x n as a list.
      When the first argument of define is an expression of the form f(x_1, ..., x_n)
      or f[x_1, ..., x_n], the function arguments are evaluated but f is not evaluated,
      even if there is already a function or variable by that name.
      When the first argument is an expression with operator funmake, arraymake, or ev,
      the first argument is evaluated; this allows for the function name to be computed, as
      well as the body.
      All function definitions appear in the same namespace; defining a function f within an-
      other function g does not automatically limit the scope of f to g. However, local(f)
Chapter 36: Function Definition                                                      619
     makes the definition of function f effective only within the block or other compound
     expression in which local appears.
     If some formal argument x k is a quoted symbol (after evaluation), the function
     defined by define does not evaluate the corresponding actual argument. Otherwise
     all actual arguments are evaluated.
     See also := and ::=.
     Examples:
     define always evaluates its second argument (unless explicitly quoted).
           (%i1)   expr : cos(y) - sin(x);
           (%o1)                      cos(y) - sin(x)
           (%i2)   define (F1 (x, y), expr);
           (%o2)                F1(x, y) := cos(y) - sin(x)
           (%i3)   F1 (a, b);
           (%o3)                      cos(b) - sin(a)
           (%i4)   F2 (x, y) := expr;
           (%o4)                     F2(x, y) := expr
           (%i5)   F2 (a, b);
           (%o5)                      cos(y) - sin(x)
     The function defined by define may be an ordinary Maxima function or a memoizing
     function.
           (%i1) define (G1 (x, y), x.y - y.x);
           (%o1)               G1(x, y) := x . y - y . x
           (%i2) define (G2 [x, y], x.y - y.x);
           (%o2)                G2     := x . y - y . x
                                  x, y
     When the last or only function argument x n is a list of one element, the function
     defined by define accepts a variable number of arguments.
           (%i1) define (H ([L]), '(apply ("+", L)));
           (%o1)                H([L]) := apply("+", L)
           (%i2) H (a, b, c);
           (%o2)                       c + b + a
     When the first argument is an expression with operator funmake, arraymake, or ev,
     the first argument is evaluated.
           (%i1)   [F : I, u : x];
           (%o1)                             [I, x]
           (%i2)   funmake (F, [u]);
           (%o2)                         I(x)
           (%i3) define (funmake (F, [u]), cos(u) + 1);
           (%o3)                  I(x) := cos(x) + 1
           (%i4) define (arraymake (F, [u]), cos(u) + 1);
           (%o4)                   I := cos(x) + 1
                                    x
           (%i5) define (foo (x, y), bar (y, x));
           (%o5)                foo(x, y) := bar(y, x)
620                                                                Maxima 5.45.0 Manual
      The value_check property can be assigned to any variable which has been defined
      via define_variable with a mode other than any. The value_check property is a
      lambda expression or the name of a function of one variable, which is called when an
      attempt is made to assign a value to the variable. The argument of the value_check
      function is the would-be assigned value.
      define_variable evaluates default_value, and quotes name and mode. define_
      variable returns the current value of name, which is default_value if name was
      unbound before, and otherwise it is the previous value of name.
      Examples:
      foo is a Boolean variable, with the initial value true.
            (%i1) define_variable (foo, true, boolean);
            (%o1)                         true
            (%i2) foo;
            (%o2)                         true
            (%i3) foo: false;
            (%o3)                         false
            (%i4) foo: %pi;
            translator: foo was declared with mode boolean
                                                      , but it has value: %pi
             -- an error. To debug this try: debugmode(true);
            (%i5) foo;
            (%o5)                         false
      bar is an integer variable, which must be prime.
            (%i1) define_variable (bar, 2, integer);
            (%o1)                           2
            (%i2) qput (bar, prime_test, value_check);
            (%o2)                      prime_test
Chapter 36: Function Definition                                                           621
dispfun                                                                            [Function]
          dispfun (f_1, . . . , f_n)
          dispfun (all)
     Displays the definition of the user-defined functions f 1, . . . , f n. Each argument may
     be the name of a macro (defined with ::=), an ordinary function (defined with := or
     define), an array function (defined with := or define, but enclosing arguments in
     square brackets [ ]), a subscripted function (defined with := or define, but enclosing
     some arguments in square brackets and others in parentheses ( )), one of a family
     of subscripted functions selected by a particular subscript value, or a subscripted
     function defined with a constant subscript.
     dispfun (all) displays all user-defined functions as given by the functions, arrays,
     and macros lists, omitting subscripted functions defined with constant subscripts.
622                                                                  Maxima 5.45.0 Manual
      dispfun creates an intermediate expression label (%t1, %t2, etc.) for each displayed
      function, and assigns the function definition to the label. In contrast, fundef returns
      the function definition.
      dispfun quotes its arguments; the quote-quote operator '' defeats quotation.
      dispfun returns the list of intermediate expression labels corresponding to the
      displayed functions.
      Examples:
            (%i1) m(x, y) ::= x^(-y);
                                                          - y
            (%o1)                        m(x, y) ::= x
            (%i2) f(x, y) := x^(-y);
                                                          - y
            (%o2)                          f(x, y) := x
            (%i3) g[x, y] := x^(-y);
                                                         - y
            (%o3)                           g       := x
                                              x, y
            (%i4) h[x](y) := x^(-y);
                                                         - y
            (%o4)                           h (y) := x
                                              x
            (%i5) i[8](y) := 8^(-y);
                                                         - y
            (%o5)                           i (y) := 8
                                              8
Chapter 36: Function Definition                                                   623
                                                   - y
           (%t7)                       f(x, y) := x
                                                    - y
           (%t8)                        g       := x
                                         x, y
                                                  - y
           (%t9)                        h (y) := x
                                         x
                                                  1
           (%t10)                        h (y) := --
                                          5         y
                                                  5
                                                  1
           (%t11)                       h (y) := ---
                                         10         y
                                                 10
                                                  - y
           (%t12)                       i (y) := 8
                                         8
            (%i1) a + b * c;
            (%o1)                                b c + a
            (%i2) fullmap (g, %);
            (%o2)                        g(b) g(c) + g(a)
            (%i3) map (g, %th(2));
            (%o3)                           g(b c) + g(a)
           (%i8) functions;
           (%o8)                  [F_1(x), F_2(x, y), F_3(x)]
           (%i9) arrays;
           (%o9)                      [G_1, G_2, G_3, H_1]
lambda                                                                            [Function]
           lambda ([x_1, . . . , x_m], expr_1, . . . , expr_n)
           lambda ([[L]], expr_1, . . . , expr_n)
           lambda ([x_1, . . . , x_m, [L]], expr_1, . . . , expr_n)
     Defines and returns a lambda expression (that is, an anonymous function). The
     function may have required arguments x 1, . . . , x m and/or optional arguments L,
     which appear within the function body as a list. The return value of the function
     is expr n. A lambda expression can be assigned to a variable and evaluated like an
     ordinary function. A lambda expression may appear in some contexts in which a
     function name is expected.
     When the function is evaluated, unbound local variables x 1, . . . , x m are created.
     lambda may appear within block or another lambda; local variables are established
     each time another block or lambda is evaluated. Local variables appear to be global
     to any enclosed block or lambda. If a variable is not local, its value is the value most
     recently assigned in an enclosing block or lambda, if any, otherwise, it is the value
     of the variable in the global environment. This policy may coincide with the usual
     understanding of "dynamic scope".
     After local variables are established, expr 1 through expr n are evaluated in turn. The
     special variable %%, representing the value of the preceding expression, is recognized.
     throw and catch may also appear in the list of expressions.
     return cannot appear in a lambda expression unless enclosed by block, in which case
     return defines the return value of the block and not of the lambda expression, unless
     the block happens to be expr n. Likewise, go cannot appear in a lambda expression
     unless enclosed by block.
     lambda quotes its arguments; the quote-quote operator '' defeats quotation.
     Examples:
         • A lambda expression can be assigned to a variable and evaluated like an ordinary
           function.
             (%i1) f: lambda ([x], x^2);
                                                          2
             (%o1)                        lambda([x], x )
             (%i2) f(a);
                                                  2
             (%o2)                               a
         • A lambda expression may appear in contexts in which a function evaluation is
           expected.
            (%i1) lambda ([x], x^2) (a);
                                               2
            (%o1)                             a
            (%i2) apply (lambda ([x], x^2), [a]);
                                               2
            (%o2)                             a
            (%i3) map (lambda ([x], x^2), [a, b, c, d, e]);
                                      2    2   2    2    2
            (%o3)                   [a , b , c , d , e ]
628                                                            Maxima 5.45.0 Manual
          (%i1)   a: %pi$
          (%i2)   b: %e$
          (%i3)   g: lambda ([a], a*b);
          (%o3)                     lambda([a], a b)
          (%i4)   b: %gamma$
          (%i5)   g(1/2);
                                         %gamma
          (%o5)                          ------
                                           2
          (%i6)   g2: lambda ([a], a*''b);
          (%o6)                   lambda([a], a %gamma)
          (%i7)   b: %e$
          (%i8)   g2(1/2);
                                         %gamma
          (%o8)                          ------
                                           2
      • Lambda expressions may be nested. Local variables within the outer lambda
        expression appear to be global to the inner expression unless masked by local
        variables of the same names.
      • Since lambda quotes its arguments, lambda expression i below does not define
        a "multiply by a" function. Such a function can be defined via buildq, as in
        lambda expression i2 below.
             (%i5) i2(1/2)(%pi);
                                               %pi
             (%o5)                             ---
                                                2
       • A lambda expression may take a variable number of arguments, which are indi-
         cated by [L] as the sole or final argument. The arguments appear within the
         function body as a list.
           (%i1) f : lambda ([aa, bb, [cc]], aa * cc + bb);
           (%o1)            lambda([aa, bb, [cc]], aa cc + bb)
           (%i2) f (foo, %i, 17, 29, 256);
           (%o2)        [17 foo + %i, 29 foo + %i, 256 foo + %i]
           (%i3) g : lambda ([[aa]], apply ("+", aa));
           (%o3)                 lambda([[aa]], apply(+, aa))
           (%i4) g (17, 29, x, y, z, %e);
           (%o4)                      z + y + x + %e + 46
local (v_1, . . . , v_n)                                                            [Function]
     Saves the properties associated with the symbols v 1, . . . , v n, removes any properties
     before evaluating other expressions, and restores any saved properties on exit from
     the block or other compound expression in which local appears.
     Some declarations are implemented as properties of a symbol, including :=, array,
     dependencies, atvalue, matchdeclare, atomgrad, constant, nonscalar, assume,
     and some others. The effect of local is to make such declarations effective only
     within the block or other compound expression in which local appears; otherwise
     such declarations are global declarations.
     local can only appear in block or in the body of a function definition or lambda
     expression, and only one occurrence is permitted in each.
     local quotes its arguments. local returns done.
     Example:
     A local function definition.
           (%i1) foo (x) := 1 - x;
           (%o1)                          foo(x) := 1 - x
           (%i2) foo (100);
           (%o2)                                - 99
           (%i3) block (local (foo), foo (x) := 2 * x, foo (100));
           (%o3)                                 200
           (%i4) foo (100);
           (%o4)                                - 99
macroexpansion                                                              [Option variable]
     Default value: false
     macroexpansion controls whether the expansion (that is, the return value) of a macro
     function is substituted for the macro function call. A substitution may speed up
     subsequent expression evaluations, at the cost of storing the expansion.
     false           The expansion of a macro function is not substituted for the macro func-
                     tion call.
630                                                                   Maxima 5.45.0 Manual
      expand       The first time a macro function call is evaluated, the expansion is stored.
                   The expansion is not recomputed on subsequent calls; any side effects
                   (such as print or assignment to global variables) happen only when the
                   macro function call is first evaluated. Expansion in an expression does
                   not affect other expressions which have the same macro function call.
      displace     The first time a macro function call is evaluated, the expansion is substi-
                   tuted for the call, thus modifying the expression from which the macro
                   function was called. The expansion is not recomputed on subsequent
                   calls; any side effects happen only when the macro function call is first
                   evaluated. Expansion in an expression does not affect other expressions
                   which have the same macro function call.
      Examples
      When macroexpansion is false, a macro function is called every time the calling
      expression is evaluated, and the calling expression is not modified.
            (%i1) f (x) := h (x) / g (x);
                                                      h(x)
            (%o1)                           f(x) := ----
                                                      g(x)
            (%i2) g (x) ::= block (print ("x + 99 is equal to", x),
                                        return (x + 99));
            (%o2) g(x) ::= block(print("x + 99 is equal to", x),
                                                                         return(x + 99))
            (%i3) h (x) ::= block (print ("x - 99 is equal to", x),
                                        return (x - 99));
            (%o3) h(x) ::= block(print("x - 99 is equal to", x),
                                                                         return(x - 99))
            (%i4) macroexpansion: false;
            (%o4)                                false
            (%i5) f (a * b);
            x - 99 is equal to x
            x + 99 is equal to x
                                               a b - 99
            (%o5)                              --------
                                               a b + 99
            (%i6) dispfun (f);
                                                      h(x)
            (%t6)                           f(x) := ----
                                                      g(x)
           (%o6)                                  [%t6]
           (%i7) f (a * b);
           x - 99 is equal to x
           x + 99 is equal to x
                                               a b - 99
           (%o7)                               --------
                                               a b + 99
Chapter 36: Function Definition                                                   631
     When macroexpansion is expand, a macro function is called once, and the calling
     expression is not modified.
           (%i1) f (x) := h (x) / g (x);
                                             h(x)
           (%o1)                     f(x) := ----
                                             g(x)
           (%i2) g (x) ::= block (print ("x + 99 is equal to", x),
                                  return (x + 99));
           (%o2) g(x) ::= block(print("x + 99 is equal to", x),
                                                             return(x + 99))
           (%i3) h (x) ::= block (print ("x - 99 is equal to", x),
                                  return (x - 99));
           (%o3) h(x) ::= block(print("x - 99 is equal to", x),
                                                             return(x - 99))
           (%i4) macroexpansion: expand;
           (%o4)                        expand
           (%i5) f (a * b);
           x - 99 is equal to x
           x + 99 is equal to x
                                       a b - 99
           (%o5)                       --------
                                       a b + 99
           (%i6) dispfun (f);
                                 mmacroexpanded(x - 99, h(x))
           (%t6)         f(x) := ----------------------------
                                 mmacroexpanded(x + 99, g(x))
           (%o6)                             [%t6]
           (%i7) f (a * b);
                                           a b - 99
           (%o7)                           --------
                                           a b + 99
     When macroexpansion is displace, a macro function is called once, and the calling
     expression is modified.
           (%i1) f (x) := h (x) / g (x);
                                               h(x)
           (%o1)                       f(x) := ----
                                               g(x)
           (%i2)   g (x) ::= block (print ("x + 99 is equal to", x),
                                    return (x + 99));
           (%o2)   g(x) ::= block(print("x + 99 is equal to", x),
                                                               return(x + 99))
           (%i3)   h (x) ::= block (print ("x - 99 is equal to", x),
                                    return (x - 99));
           (%o3)   h(x) ::= block(print("x - 99 is equal to", x),
                                                               return(x - 99))
632                                                                   Maxima 5.45.0 Manual
            (%o6)                                [%t6]
            (%i7) f (a * b);
                                               a b - 99
            (%o7)                              --------
                                               a b + 99
     Another way to tell that all entries of the array a are of the type (“mode”) m and
     have been assigned a value to would be:
            mode_declare (completearray (a), m))
     Numeric code using arrays might run faster still if the size of the array is known at
     compile time, as well, as in:
            mode_declare (completearray (a [10, 10]), float)
     for a floating point number array named a which is 10 x 10.
     mode_declare also can be used in order to declare the type of the result of a function.
     In this case the function compilation needs to be preceded by another mode_declare
     statement. For example the expression,
            mode_declare ([function (f_1, f_2, ...)], fixnum)
     declares that the values returned by f_1, f_2, . . . are single-word integers.
     modedeclare is a synonym for mode_declare.
     If the type of function parameters and results doesn’t match the declaration by mode_
     declare the function may misbehave or a warning or an error might occur, see mode_
     checkp, mode_check_errorp and mode_check_warnp.
     See mode_identity for declaring the type of lists and define_variable for declaring
     the type of all global variables compiled code uses, as well.
     Example:
            (%i1) square_float(f):=(
                  mode_declare(f,float),
                  f*f
             );
            (%o1)     square_float(f) := (mode_declare(f, float), f f)
            (%i2) mode_declare([function(f)],float);
            (%o2)                         [[function(f)]]
            (%i3) compile(square_float);
            (%o3)                         [square_float]
            (%i4) square_float(100.0);
            (%o4)                              10000.0
            (%i3) compile(square);
            (%o3)                       [square]
            (%i4) square(2.3);
            (%o4)                   5.289999999999999
            (%i5) square(4);
            Maxima encountered a Lisp error:
             The value
               4
             is not of type
               DOUBLE-FLOAT
             when binding $F
            Automatically continuing.
            To enable the Lisp debugger set *debugger-hook* to nil.
remfunction                                                                        [Function]
        remfunction (f_1, . . . , f_n)
        remfunction (all)
     Unbinds the function definitions of the symbols f 1, . . . , f n. The arguments may
     be the names of ordinary functions (created by := or define) or macro functions
     (created by ::=).
     remfunction (all) unbinds all function definitions.
     remfunction quotes its arguments.
     remfunction returns a list of the symbols for which the function definition was un-
     bound. false is returned in place of any symbol for which there is no function
     definition.
     remfunction does not apply to memoizing functions or subscripted functions.
     remarray applies to those types of functions.
translate                                                                          [Function]
        translate (f_1, . . . , f_n)
        translate (functions)
        translate (all)
     Translates the user-defined functions f 1, . . . , f n from the Maxima language into Lisp
     and evaluates the Lisp translations. Typically the translated functions run faster than
     the originals.
     translate (all) or translate (functions) translates all user-defined functions.
     Functions to be translated should include a call to mode_declare at the beginning
     when possible in order to produce more efficient code. For example:
           f (x_1, x_2, ...) := block ([v_1, v_2, ...],
               mode_declare (v_1, mode_1, v_2, mode_2, ...), ...)
     where the x 1, x 2, . . . are the parameters to the function and the v 1, v 2, . . . are
     the local variables.
     The names of translated functions are removed from the functions list if savedef is
     false (see below) and are added to the props lists.
     Functions should not be translated unless they are fully debugged.
     Expressions are assumed simplified; if they are not, correct but non-optimal code gets
     generated. Thus, the user should not set the simp switch to false which inhibits
     simplification of the expressions to be translated.
     The switch translate, if true, causes automatic translation of an user’s function to
     Lisp.
636                                                                   Maxima 5.45.0 Manual
      Note that translated functions may not run identically to the way they did before
      translation as certain incompatibilities may exist between the Lisp and Maxima ver-
      sions. Principally, the rat function with more than one argument and the ratvars
      function should not be used if any variables are mode_declare’d canonical rational
      expressions (CRE). Also the prederror: false setting will not translate.
      savedef - if true will cause the Maxima version of an user function to remain when
      the function is translate’d. This permits the definition to be displayed by dispfun
      and allows the function to be edited.
      transrun - if false will cause the interpreted version of all functions to be run
      (provided they are still around) rather than the translated version.
      The result returned by translate is a list of the names of the functions translated.
translate_file                                                                     [Function]
        translate_file (maxima_filename)
        translate_file (maxima_filename, lisp_filename)
      Translates a file of Maxima code into a file of Lisp code. translate_file returns a
      list of three filenames: the name of the Maxima file, the name of the Lisp file, and the
      name of file containing additional information about the translation. translate_file
      evaluates its arguments.
      translate_file ("foo.mac"); load("foo.LISP") is the same as the command
      batch ("foo.mac") except for certain restrictions, the use of '' and %, for example.
      translate_file (maxima_filename) translates a Maxima file maxima filename into
      a similarly-named Lisp file. For example, foo.mac is translated into foo.LISP. The
      Maxima filename may include a directory name or names, in which case the Lisp
      output file is written to the same directory from which the Maxima input comes.
      translate_file (maxima_filename, lisp_filename) translates a Maxima file
      maxima filename into a Lisp file lisp filename. translate_file ignores the filename
      extension, if any, of lisp_filename; the filename extension of the Lisp output file is
      always LISP. The Lisp filename may include a directory name or names, in which
      case the Lisp output file is written to the specified directory.
      translate_file also writes a file of translator warning messages of various degrees
      of severity. The filename extension of this file is UNLISP. This file may contain
      valuable information, though possibly obscure, for tracking down bugs in translated
      code. The UNLISP file is always written to the same directory from which the Maxima
      input comes.
      translate_file emits Lisp code which causes some declarations and definitions to
      take effect as soon as the Lisp code is compiled. See compile_file for more on this
      topic.
      See also
      tr_array_as_ref
      hundefinedi tr_bound_function_applyp,
      tr_exponent
      hundefinedi tr_file_tty_messagesp,
      hundefinedi tr_float_can_branch_complex,
      hundefinedi tr_function_call_default,
Chapter 36: Function Definition                                                        637
     hundefinedi tr_numer,
     hundefinedi tr_optimize_max_loop,
     hundefinedi tr_state_vars,
     hundefinedi tr_warnings_get,
     tr_warn_bad_function_calls
     hundefinedi tr_warn_fexpr,
     hundefinedi tr_warn_meval,
     hundefinedi tr_warn_mode,
     hundefinedi tr_warn_undeclared,
     and hundefinedi tr_warn_undefined_variable.
tr_warnings_get ()                                                              [Function]
      Prints a list of warnings which have been given by the translator during the current
      translation.
Chapter 36: Function Definition                                                          639
compile_file                                                    [Function]
        compile_file (filename)
        compile_file (filename, compiled_filename)
        compile_file (filename, compiled_filename, lisp_filename)
     Translates the Maxima file filename into Lisp, and executes the Lisp compiler. The
     compiled code is not loaded into Maxima.
     compile_file returns a list of the names of four files: the original Maxima file, the
     Lisp translation, notes on translation, and the compiled code. If the compilation fails,
     the fourth item is false.
     Some declarations and definitions take effect as soon as the Lisp code is compiled
     (without loading the compiled code). These include functions defined with the :=
     operator, macros define with the ::= operator, alias, declare, define_variable,
     mode_declare, and infix, matchfix, nofix, postfix, prefix, and compfile.
     Assignments and function calls are not evaluated until the compiled code is loaded.
     In particular, within the Maxima file, assignments to the translation flags (tr_numer,
     etc.) have no effect on the translation.
     filename may not contain :lisp statements.
     compile_file evaluates its arguments.
640                                                                  Maxima 5.45.0 Manual
37 Program Flow
garbage_collect ()                                                                [Function]
        Tries to manually trigger the lisp’s garbage collection. This rarely is necessary as
        the lisp will employ an excellent algorithm for determining when to start garbage
        collection.
        If maxima knows how to do manually trigger the garbage collection for the current
        lisp garbage_collect returns true, else false.
     The control-variable is always local to the do and thus any variable may be used
     without affecting the value of a variable with the same name outside of the do. The
     control-variable is unbound after the do terminates.
a = 4
a = 11
a = 18
a = 25
           (%i1) s: 0$
           (%i2) for i: 1 while i <= 10 do s: s+i;
           (%o2)                         done
           (%i3) s;
           (%o3)                          55
     Note that the condition while i <= 10 is equivalent to unless i > 10 and also thru
     10.
           (%i1) series: 1$
           (%i2) term: exp (sin (x))$
           (%i3) for p: 1 unless p > 7 do
                     (term: diff (term, x)/p,
                      series: series + subst (x=0, term)*x^p)$
           (%i4) series;
                             7    6     5    4    2
                            x    x     x    x    x
           (%o4)            -- - --- - -- - -- + -- + x + 1
                            90   240   15   8    2
           (%i1) poly: 0$
           (%i2) for i: 1 thru 5 do
                     for j: i step -1 thru 1 do
                         poly: poly + i*x^j$
           (%i3) poly;
                             5      4       3       2
           (%o3)          5 x + 9 x + 12 x + 14 x + 15 x
           (%i4) guess: -3.0$
           (%i5) for i: 1 thru 10 do
                     (guess: subst (guess, x, 0.5*(x + 10/x)),
                      if abs (guess^2 - 10) < 0.00005 then return (guess));
           (%o5)                  - 3.162280701754386
646                                                                  Maxima 5.45.0 Manual
      This example computes the negative square root of 10 using the Newton- Raphson
      iteration a maximum of 10 times. Had the convergence criterion not been met the
      value returned would have been done.
      Instead of always adding a quantity to the control-variable one may sometimes wish
      to change it in some other way for each iteration. In this case one may use next
      expression instead of step increment. This will cause the control-variable to be
      set to the result of evaluating expression each time through the loop.
            (%i6) for count: 2 next 3*count thru 20 do display (count)$
                                        count = 2
count = 6
                                             count = 18
      As an alternative to for variable: value ...do... the syntax for variable from
      value ...do... may be used. This permits the from value to be placed after the
      step or next value or after the termination condition. If from value is omitted then
      1 is used as the initial value.
      Sometimes one may be interested in performing an iteration where the control-variable
      is never actually used. It is thus permissible to give only the termination conditions
      omitting the initialization and updating information as in the following example to
      compute the square-root of 5 using a poor initial guess.
            (%i1)   x: 1000$
            (%i2)   thru 20 do x: 0.5*(x + 5.0/x)$
            (%i3)   x;
            (%o3)                     2.23606797749979
            (%i4)   sqrt(5), numer;
            (%o4)                     2.23606797749979
      If it is desired one may even omit the termination conditions entirely and just give do
      body which will continue to evaluate the body indefinitely. In this case the function
      return should be used to terminate execution of the do.
            (%i1) newton (f, x):= ([y, df, dfx], df: diff (f ('x), 'x),
                      do (y: ev(df), x: x - f(x)/y,
                          if abs (f (x)) < 5e-6 then return (x)))$
            (%i2) sqr (x) := x^2 - 5.0$
            (%i3) newton (sqr, 1000);
            (%o3)                   2.236068027062195
      (Note that return, when executed, causes the current value of x to be returned as
      the value of the do. The block is exited and this value of the do is returned as the
      value of the block because the do is the last statement in the block.)
      One other form of the do is available in Maxima. The syntax is:
            for variable in list end_tests do body
      The elements of list are any expressions which will successively be assigned to the
      variable on each iteration of the body. The optional termination tests end tests
      can be used to terminate execution of the do; otherwise it will terminate when the
Chapter 37: Program Flow                                                                  647
     list is exhausted or when a return is executed in the body. (In fact, list may be
     any non-atomic expression, and successive parts are taken.)
             (%i1) for f in [log, rho, atan] do ldisp(f(1))$
             (%t1)                                        0
             (%t2)                                     rho(1)
                                                       %pi
             (%t3)                                      ---
                                                        4
             (%i4) ev(%t3,numer);
             (%o4)                                 0.78539816
      Example:
      The size of U, as determined by ERROR-SIZE, is 24.
           (%i1) U: (C^D^E + B + A)/(cos(X-1) + 1)$
                                    E
                                   D
                                  C   + B + A
           Example expression is --------------
                                 cos(X - 1) + 1
            -- an error. Quitting. To debug this try debugmode(true);
errormsg ()                                                                  [Function]
      Reprints the most recent error message. The variable error holds the message, and
      errormsg formats and prints it.
     The option variable errormsg can not be set in a block to a local value. The global
     value of errormsg is always present.
           (%i1) errormsg;
           (%o1)                         true
           (%i2) sin(a,b);
           sin: wrong number of arguments.
            -- an error. To debug this try: debugmode(true);
           (%i3) errormsg: false;
           (%o3)                         false
           (%i4) sin(a,b);
            -- an error. To debug this try: debugmode(true);
     The option variable errormsg can not be set in a block to a local value.
           (%i1) f(bool):=block([errormsg:bool],
                                print ("value of errormsg is",errormsg))$
           (%i2) errormsg:true;
           (%o2)                         true
           (%i3) f(false);
           value of errormsg is true
           (%o3)                         true
           (%i4) errormsg:false;
           (%o4)                         false
           (%i5) f(true);
           value of errormsg is false
           (%o5)                         false
go (tag)                                                                          [Function]
     is used within a block to transfer control to the statement of the block which is tagged
     with the argument to go. To tag a statement, precede it by an atomic argument as
     another statement in the block. For example:
           block ([x], x:1, loop, x+1, ..., go(loop), ...)
     The argument to go must be the name of a tag appearing in the same block. One
     cannot use go to transfer to tag in a block other than the one containing the go.
if                                                                     [Special operator]
     Represents conditional evaluation. Various forms of if expressions are recognized.
     if cond_1 then expr_1 else expr_0 evaluates to expr 1 if cond 1 evaluates to true,
     otherwise the expression evaluates to expr 0.
     The command if cond_1 then expr_1 elseif cond_2 then expr_2 elseif ...
     else expr_0 evaluates to expr k if cond k is true and all preceding conditions are
     false. If none of the conditions are true, the expression evaluates to expr_0.
     A trailing else false is assumed if else is missing. That is, the command if cond_1
     then expr_1 is equivalent to if cond_1 then expr_1 else false, and the command
     if cond_1 then expr_1 elseif ... elseif cond_n then expr_n is equivalent to if
     cond_1 then expr_1 elseif ... elseif cond_n then expr_n else false.
650                                                                   Maxima 5.45.0 Manual
scanmap                                                                         [Function]
          scanmap (f, expr)
          scanmap (f, expr, bottomup)
      Recursively applies f to expr, in a top down manner. This is most useful when
      complete factorization is desired, for example:
            (%i1) exp:(a^2+2*a+1)*y + x^2$
            (%i2) scanmap(factor,exp);
                                                      2        2
            (%o2)                               (a + 1)    y + x
      Note the way in which scanmap applies the given function factor to the constituent
      subexpressions of expr; if another form of expr is presented to scanmap then the
      result may be different. Thus, %o2 is not recovered when scanmap is applied to the
      expanded form of exp:
            (%i3) scanmap(factor,expand(exp));
                                       2                           2
Chapter 37: Program Flow                                                                  653
           (%o3)                             a y + 2 a y + y + x
     Here is another example of the way in which scanmap recursively applies a given
     function to all subexpressions, including exponents:
           (%i4) expr : u*v^(a*x+b) + c$
           (%i5) scanmap('f, expr);
                                    f(f(f(a) f(x)) + f(b))
           (%o5) f(f(f(u) f(f(v)                            )) + f(c))
     scanmap (f, expr, bottomup) applies f to expr in a bottom-up manner. E.g., for
     undefined f,
           scanmap(f,a*x+b) ->
               f(a*x+b) -> f(f(a*x)+f(b)) -> f(f(f(a)*f(x))+f(b))
           scanmap(f,a*x+b,bottomup) -> f(a)*f(x)+f(b)
                -> f(f(a)*f(x))+f(b) ->
                  f(f(f(a)*f(x))+f(b))
     In this case, you get the same answer both ways.
throw (expr)                                                               [Function]
     Evaluates expr and throws the value back to the most recent catch. throw is used
     with catch as a nonlocal return mechanism.
outermap (f, a_1, . . . , a_n)                                                      [Function]
     Applies the function f to each one of the elements of the outer product a 1 cross a 2
     . . . cross a n.
     f is the name of a function of n arguments or a lambda expression of n arguments.
     Each argument a k may be a list or nested list, or a matrix, or any other kind of
     expression.
     The outermap return value is a nested structure. Let x be the return value. Then x
     has the same structure as the first list, nested list, or matrix argument, x[i_1]...[i_
     m] has the same structure as the second list, nested list, or matrix argument, x[i_
     1]...[i_m][j_1]...[j_n] has the same structure as the third list, nested list, or
     matrix argument, and so on, where m, n, . . . are the numbers of indices required to
     access the elements of each argument (one for a list, two for a matrix, one or more
     for a nested list). Arguments which are not lists or matrices have no effect on the
     structure of the return value.
     Note that the effect of outermap is different from that of applying f to each one of the
     elements of the outer product returned by cartesian_product. outermap preserves
     the structure of the arguments in the return value, while cartesian_product does
     not.
     outermap evaluates its arguments.
     See also map, maplist, and apply.
     Examples:
     Elementary examples of outermap. To show the argument combinations more clearly,
     F is left undefined.
             (%i1) outermap (F, [a, b, c], [1, 2, 3]);
             (%o1) [[F(a, 1), F(a, 2), F(a, 3)], [F(b, 1), F(b, 2), F(b, 3)],
                                                             [F(c, 1), F(c, 2), F(c, 3)]]
654                                                             Maxima 5.45.0 Manual
           (%i2) outermap (F, matrix ([a, b], [c, d]), matrix ([1, 2], [3, 4]));
                    [ [ F(a, 1) F(a, 2) ] [ F(b, 1) F(b, 2) ] ]
                    [ [                  ] [                   ] ]
                    [ [ F(a, 3) F(a, 4) ] [ F(b, 3) F(b, 4) ] ]
           (%o2)    [                                            ]
                    [ [ F(c, 1) F(c, 2) ] [ F(d, 1) F(d, 2) ] ]
                    [ [                  ] [                   ] ]
                    [ [ F(c, 3) F(c, 4) ] [ F(d, 3) F(d, 4) ] ]
           (%i3) outermap (F, [a, b], x, matrix ([1, 2], [3, 4]));
                  [ F(a, x, 1) F(a, x, 2) ] [ F(b, x, 1) F(b, x, 2) ]
           (%o3) [[                        ], [                        ]]
                  [ F(a, x, 3) F(a, x, 4) ] [ F(b, x, 3) F(b, x, 4) ]
           (%i4) outermap (F, [a, b], matrix ([1, 2]), matrix ([x], [y]));
                  [ [ F(a, 1, x) ] [ F(a, 2, x) ] ]
           (%o4) [[ [            ] [             ] ],
                  [ [ F(a, 1, y) ] [ F(a, 2, y) ] ]
                                         [ [ F(b, 1, x) ] [ F(b, 2, x) ] ]
                                         [ [            ] [             ] ]]
                                         [ [ F(b, 1, y) ] [ F(b, 2, y) ] ]
           (%i5) outermap ("+", [a, b, c], [1, 2, 3]);
           (%o5) [[a + 1, a + 2, a + 3], [b + 1, b + 2, b + 3],
                                                      [c + 1, c + 2, c + 3]]
      A closer examination of the outermap return value. The first, second, and third
      arguments are a matrix, a list, and a matrix, respectively. The return value is a
      matrix. Each element of that matrix is a list, and each element of each list is a
      matrix.
           (%i1) arg_1 :    matrix ([a, b], [c, d]);
                                          [ a b ]
           (%o1)                           [      ]
                                          [ c d ]
           (%i2)   arg_2 : [11, 22];
           (%o2)                           [11, 22]
           (%i3)   arg_3 : matrix ([xx, yy]);
           (%o3)                         [ xx yy ]
           (%i4)   xx_0 : outermap (lambda ([x, y, z], x / y + z), arg_1,
                                                                 arg_2, arg_3);
                            [ [       a          a ] [      a         a ] ]
                            [ [[ xx + -- yy + -- ], [ xx + -- yy + -- ]] ]
                            [ [       11         11 ] [     22        22 ] ]
           (%o4)    Col 1 = [                                               ]
                            [ [       c          c ] [      c         c ] ]
                            [ [[ xx + -- yy + -- ], [ xx + -- yy + -- ]] ]
                            [ [       11         11 ] [     22        22 ] ]
                              [ [        b         b ] [       b        b ] ]
                              [ [[ xx + -- yy + -- ], [ xx + -- yy + -- ]] ]
                              [ [        11        11 ] [      22       22 ] ]
Chapter 37: Program Flow                                                     655
                    Col 2 = [                                                  ]
                            [ [         d          d ] [        d        d ] ]
                            [ [[ xx + -- yy + -- ], [ xx + -- yy + -- ]] ]
                            [ [         11         11 ] [       22       22 ] ]
          (%i5) xx_1 : xx_0 [1][1];
                      [       a         a ] [          a        a ]
          (%o5)      [[ xx + -- yy + -- ], [ xx + -- yy + -- ]]
                      [       11        11 ] [         22       22 ]
          (%i6) xx_2 : xx_0 [1][1] [1];
                                  [       a          a ]
          (%o6)                   [ xx + -- yy + -- ]
                                  [       11         11 ]
          (%i7) xx_3 : xx_0 [1][1] [1] [1][1];
                                                a
          (%o7)                            xx + --
                                                11
          (%i8) [op (arg_1), op (arg_2), op (arg_3)];
          (%o8)                     [matrix, [, matrix]
          (%i9) [op (xx_0), op (xx_1), op (xx_2)];
          (%o9)                     [matrix, [, matrix]
     outermap preserves the structure of the arguments in the return value, while
     cartesian_product does not.
          (%i1) outermap (F, [a, b, c], [1, 2, 3]);
          (%o1) [[F(a, 1), F(a, 2), F(a, 3)], [F(b, 1), F(b, 2), F(b, 3)],
                                                    [F(c, 1), F(c, 2), F(c, 3)]]
          (%i2) setify (flatten (%));
          (%o2) {F(a, 1), F(a, 2), F(a, 3), F(b, 1), F(b, 2), F(b, 3),
                                                      F(c, 1), F(c, 2), F(c, 3)}
          (%i3) map (lambda ([L], apply (F, L)),
                                 cartesian_product ({a, b, c}, {1, 2, 3}));
          (%o3) {F(a, 1), F(a, 2), F(a, 3), F(b, 1), F(b, 2), F(b, 3),
                                                      F(c, 1), F(c, 2), F(c, 3)}
          (%i4) is (equal (%, %th (2)));
          (%o4)                             true
                                                                                     657
38 Debugging
(%o1) /tmp/foobar.mac
     (%o2)                                          1094
   The file /tmp/foobar.mac is the following:
     foo(y) := block ([u:y^2],
        u: u+3,
        u: u^2,
        u);
       bar(x,y) := (
          x: x+2,
          y: y+2,
          x: foo(y),
          x+y);
    USE OF THE DEBUGGER THROUGH EMACS
    If the user is running the code under GNU emacs in a shell window (dbl shell), or is
running the graphical interface version, Xmaxima, then if he stops at a break point, he will
see his current position in the source file which will be displayed in the other half of the
window, either highlighted in red, or with a little arrow pointing at the right line. He can
advance single lines at a time by typing M-n (Alt-n).
    Under Emacs you should run in a dbl shell, which requires the dbl.el file in the elisp
directory. Make sure you install the elisp files or add the Maxima elisp directory to your
path: e.g., add the following to your .emacs file or the site-init.el
       (setq load-path (cons "/usr/share/maxima/5.9.1/emacs" load-path))
       (autoload 'dbl "dbl")
    then in emacs
       M-x dbl
    should start a shell window in which you can run programs, for example Maxima, gcl,
gdb etc. This shell window also knows about source level debugging, and display of source
code in the other window.
    The user may set a break point at a certain line of the file by typing C-x space. This
figures out which function the cursor is in, and then it sees which line of that function the
cursor is on. If the cursor is on, say, line 2 of foo, then it will insert in the other window
the command, “:br foo 2”, to break foo at its second line. To have this enabled, the
user must have maxima-mode.el turned on in the window in which the file foobar.mac is
visiting. There are additional commands available in that file window, such as evaluating
the function into the Maxima, by typing Alt-Control-x.
      5
   The number of arguments taken depends on the particular command. Also, you need
not type the whole command, just enough to be unique among the break keywords. Thus
:br would suffice for :break.
   The keyword commands are listed below.
:break F n
             Set a breakpoint in function F at line offset n from the beginning of the function.
             If F is given as a string, then it is assumed to be a file, and n is the offset from
             the beginning of the file. The offset is optional. If not given, it is assumed to
             be zero (first line of the function or file).
:bt          Print a backtrace of the stack frames
:continue
             Continue the computation
:delete      Delete the specified breakpoints, or all if none are specified
:disable     Disable the specified breakpoints, or all if none are specified
:enable      Enable the specified breakpoints, or all if none are specified
:frame n     Print stack frame n, or the current frame if none is specified
:help        Print help on a debugger command, or all commands if none is specified
:info        Print information about item
:lisp some-form
          Evaluate some-form as a Lisp form
:lisp-quiet some-form
          Evaluate Lisp form some-form without any output
:next        Like :step, except :next steps over function calls
:quit        Quit the current debugger level without completing the computation
:resume      Continue the computation
:step        Continue the computation until it reaches a new source line
:top         Return to the Maxima prompt (from any debugger level) without completing
             the computation
      trace(all) puts all user-defined functions (as named by the global variable
      functions) on the list of functions to be traced.
      With no arguments, trace returns a list of all the functions currently being traced.
      The untrace function disables tracing. See also trace_options.
      trace quotes its arguments. Thus, f(x) := x^2$ g:f$ trace(g)$ does not put f on
      the trace list.
      When a function is redefined, it is removed from the timer list. Thus after timer(f)$
      f(x) := x^2$, function f is no longer on the timer list.
      If timer (f) is in effect, then trace (f) has no effect; trace and timer can’t both
      be in effect for the same function.
            (%i4) ff(3);
Chapter 38: Debugging                                                                     663
     Here is the same function, with the break option conditional on a predicate:
           (%i5) trace_options (ff, break(pp))$
(%i7) ff(6);
untrace                                                                            [Function]
          untrace (f_1, . . . , f_n)
          untrace ()
     Given functions f 1, . . . , f n, untrace disables tracing enabled by the trace function.
     With no arguments, untrace disables tracing for all functions.
     untrace returns a list of the functions for which it disabled tracing.
                                                                                       665
39 alt-display
      (%i3) x/(x^2+y^2) = 1;
      \mbox{\tt\red({\it \%o_3}) \black}$${{x}\over{y^2+x^2}}=1$$
(%i4) set_alt_display(2,mathml_display)$
      (%i5) x/(x^2+y^2) = 1;
      <math xmlns="http://www.w3.org/1998/Math/MathML"> <mi>mlabel</mi>
      <mfenced separators=""><msub><mi>%o</mi> <mn>5</mn></msub>
      <mo>,</mo><mfrac><mrow><mi>x</mi> </mrow> <mrow><msup><mrow>
      <mi>y</mi> </mrow> <mn>2</mn> </msup> <mo>+</mo> <msup><mrow>
      <mi>x</mi> </mrow> <mn>2</mn> </msup> </mrow></mfrac> <mo>=</mo>
      <mn>1</mn> </mfenced> </math>
(%i6) set_alt_display(2,multi_display_for_texinfo)$
(%i7) x/(x^2+y^2) = 1;
      @iftex
      @tex
      \mbox{\tt\red({\it \%o_7}) \black}$${{x}\over{y^2+x^2}}=1$$
      @end tex
      @end iftex
      @ifhtml
      @html
(%i9) x;
      Error in *alt-display2d*.
      Messge: Condition designator ((MLABEL) $%O9 $X) is not of type
              (OR SYMBOL STRING FUNCTION).
      *alt-display2d* reset to nil.
       -- an error. To debug this try: debugmode(true);
      (%i10) x;
      (%o10)                                          x
      (%i2) define_alt_display(my_display(form),
      block([type,txttmplt,labtmplt],
      txttmplt:"~%TEXT;>>~%~a~%<<TEXT;~%",
      labtmplt:"~%OUT;>>~%(~a) ~a~a~a~%<<OUT;~%",
Chapter 39: alt-display                                                                   667
     type:alt_display_output_type(form),
     if type='text then
        printf(true,txttmplt,first(form))
     else if type='label then
          printf(true,labtmplt,first(form),"$$",tex1(second(form)),"$$")
     else
          block([alt_display1d:false, alt_display2d:false], displa(form)))) $
     PROMPT;>>(%i4) <<PROMPT;integrate(x^n,x);
     PROMPT;>>
     TEXT;>>
     Is n equal to -1?
     <<TEXT;
     <<PROMPT;
     n;
     OUT;>>
     (%o4) $$\frac{x^{n+1}}{n+1}$$
     <<OUT;
     PROMPT;>>(%i5) <<PROMPT;
define_alt_display (function(input), expr)                                          [Function]
     This function is similar to define: it evaluates its arguments and expands into a
     function definition. The function is a function of a single input input. For convenience,
     a substitution is applied to expr after evaluation, to provide easy access to Lisp
     variable names.
     Set a time-stamp on each prompt:
           (%i1) load("alt-display.mac")$
           (%i3) define_alt_display(time_stamp(x),
                           block([alt_display1d:false,alt_display2d:false],
                                 prompt_prefix:printf(false,"~a~%",timedate()),
                                 displa(x)));
           (%o3) time_stamp(x):=block(
                            [\*alt\-display1d\*:false,
                             \*alt\-display2d\*:false],
                            \*prompt\-prefix\*
                             :printf(false,"~a~%",timedate()),displa(x))
           (%i4) set_alt_display(1,time_stamp);
           (%o4) done
668                                                                  Maxima 5.45.0 Manual
            2017-11-27 16:15:58-06:00
            (%i5)
      The input line %i3 defines time_stamp using define_alt_display. The output line
      %o3 shows that the Maxima variable names alt_display1d, alt_display2d and
      prompt_prefix have been replaced by their Lisp translations, as has displa been
      replaced by ?displa (the display function).
      The display variables alt_display1d and alt_display2d are both bound to false
      in the body of time_stamp to prevent an infinite recursion in displa.
(%i2) set_alt_display(2,info_display);
            (%o2) done
            (%i3) x/y;
(%o3) x/y
            (%i2) set_alt_display(2,mathml_display);
            <math xmlns="http://www.w3.org/1998/Math/MathML"> <mi>mlabel</mi>
             <mfenced separators=""><msub><mi>%o</mi> <mn>2</mn></msub>
             <mo>,</mo><mi>done</mi> </mfenced> </math>
(%i3) x/(x^2+y^2);
            @iftex
            @tex
            \mbox{\tt\red({\it \%o_3}) \black}$${{x}\over{y^2+x^2}}$$
            @end tex
Chapter 39: alt-display                                                                669
           @end iftex
           @ifhtml
           @html
reset_displays ()                                                            [Functions]
     Resets the prompt prefix and suffix to the empty string, and sets both 1-d and 2-d
     display functions to the default.
           (%i3) integrate(exp(-t^2),t,0,inf);
           $${{\sqrt{\pi}}\over{2}}$$
     A user-defined display function should take care that it prints its output. A display
     function that returns a string will appear to display nothing, nor cause any errors.
        The following example shows the effect of each option, except prolog. Note that the
        epilog prompt is printed as Maxima closes down. The general is printed between
        the end of input and the output, unless the input line ends in $.
        Here is an example to show where the prompt strings are placed.
              (%i1) load("alt-display.mac")$
               (%o2)                                              done
               <<prefix>> (%i3) <<suffix>> x/y;
               <<general>>
                                                                     x
               (%o3)                                                 -
                                                                     y
              <<prefix>> (%i4) <<suffix>> quit();
              <<general>>
              <<epilog>>
        Here is an example that shows how to colorize the input and output when Maxima
        is running in a terminal or terminal emulator like Emacs1 .
        Each prompt string starts with the ASCII escape character (27) followed by an open
        square bracket (91); each string ends with a lower-case m (109). The webpages
        https://misc.flogisoft.com/bash/tip_colors_and_formatting and https://
        www.tldp.org/HOWTO/Bash-Prompt-HOWTO/x329.html provide information on how
        to use control strings to set the terminal colors.
 1
     Readers using the info reader in Emacs will see the actual prompt strings; other readers will see the
     colorized output
                                                                                      671
40 asympa
41 augmented lagrangian
42 Bernstein
          (%i2) bernstein_poly(k,n,x);
          (%o2)                bernstein_poly(k, n, x)
          (%i3) bernstein_poly(k,n,x), bernstein_explicit : true;
                                                 n - k k
          (%o3)            binomial(n, k) (1 - x)      x
     The Bernstein polynomials have both a gradef property and an integrate property:
          (%i4) diff(bernstein_poly(k,n,x),x);
          (%o4) (bernstein_poly(k - 1, n - 1, x)
                                           - bernstein_poly(k, n - 1, x)) n
          (%i5) integrate(bernstein_poly(k,n,x),x);
          (%o5)
                                                                      k + 1
           hypergeometric([k + 1, k - n], [k + 2], x) binomial(n, k) x
           ----------------------------------------------------------------
                                        k + 1
     For numeric inputs, both real and complex, the Bernstein polynomials evaluate to a
     numeric result:
          (%i6) bernstein_poly(5,9, 1/2 + %i);
                                  39375 %i   39375
          (%o6)                   -------- + -----
                                    128       256
          (%i7) bernstein_poly(5,9, 0.5b0 + %i);
          (%o7)           3.076171875b2 %i + 1.5380859375b2
     To use bernstein_poly, first load("bernstein").
bernstein_explicit                                                             [Variable]
     Default value: false
     When either k or n are non integers, the option variable bernstein_explicit controls
     the expansion of bernstein(k,n,x) into its explicit form; example:
          (%i1) bernstein_poly(k,n,x);
          (%o1)                bernstein_poly(k, n, x)
          (%i2) bernstein_poly(k,n,x), bernstein_explicit : true;
676                                                                Maxima 5.45.0 Manual
                                                         n - k k
            (%o2)             binomial(n, k) (1 - x)           x
      When both k and n are explicitly integers, bernstein(k,n,x) always expands to its
      explicit form.
multibernstein_poly ([k1,k2,..., kp], [n1,n2,..., np],                         [Function]
        [x1,x2,..., xp])
      The multibernstein polynomial multibernstein_poly ([k1, k2, ..., kp],
      [n1, n2, ..., np], [x1, x2, ..., xp]) is the product of bernstein poly-
      nomials          bernstein_poly(k1, n1, x1) bernstein_poly(k2, n2, x2) ...
      bernstein_poly(kp, np, xp).
      To use multibernstein_poly, first load("bernstein").
bernstein_approx (f, [x1, x1, ..., xn], n)                                   [Function]
      Return the n-th order uniform Bernstein polynomial approximation for the function
      (x1, x2, ..., xn) |--> f. Examples
           (%i1) bernstein_approx(f(x),[x], 2);
                                2       1                              2
           (%o1)        f(1) x + 2 f(-) (1 - x) x + f(0) (1 - x)
                                        2
           (%i2) bernstein_approx(f(x,y),[x,y], 2);
                             2 2          1                  2
           (%o2) f(1, 1) x y + 2 f(-, 1) (1 - x) x y
                                         2
                                  2 2           1   2
             + f(0, 1) (1 - x) y + 2 f(1, -) x (1 - y) y
                                                2
                    1 1                                    1           2
             + 4 f(-, -) (1 - x) x (1 - y) y + 2 f(0, -) (1 - x) (1 - y) y
                    2 2                                    2
                         2          2         1                        2
             + f(1, 0) x (1 - y) + 2 f(-, 0) (1 - x) x (1 - y)
                                              2
                                  2         2
             + f(0, 0) (1 - x) (1 - y)
      To use bernstein_approx, first load("bernstein").
bernstein_expand (e, [x1, x1, ..., xn])                                         [Function]
      Express the polynomial e exactly as a linear combination of multi-variable Bernstein
      polynomials.
           (%i1) bernstein_expand(x*y+1,[x,y]);
           (%o1)      2 x y + (1 - x) y + x (1 - y) + (1 - x) (1 - y)
           (%i2) expand(%);
           (%o2)                               x y + 1
      Maxima signals an error when the first argument isn’t a polynomial.
      To use bernstein_expand, first load("bernstein").
                                                                                          677
43 bitwise
The package bitwise provides functions that allow to manipulate bits of integer constants.
As always maxima attempts to simplify the result of the operation if the actual value of a
constant isn’t known considering attributes that might be known for the variables, see the
declare mechanism.
            (%i2)   bit_or(i,i);
            (%o2)                                   i
            (%i3)   bit_or(i,i,i);
            (%o3)                                   i
            (%i4)   bit_or(1,3);
            (%o4)                                   3
            (%i5)   bit_or(-7,7);
            (%o5)                                  - 1
      If it is known if one of the parameters to bit_or is even this information is taken into
      consideration by the function.
            (%i1)   load("bitwise")$
            (%i2)   declare(e,even,o,odd);
            (%o2)                                done
            (%i3)   bit_or(1,e);
            (%o3)                                e + 1
            (%i4)   bit_or(1,o);
            (%o4)                                   o
           (%i3)   bit_lsh(1,0);
           (%o3)                                   1
           (%i4)   bit_lsh(1,1);
           (%o4)                                   2
           (%i5)   bit_lsh(1,i);
           (%o5)                           bit_lsh(1, i)
           (%i6)   bit_lsh(-3,1);
           (%o6)                                 - 6
           (%i7)   bit_lsh(-2,1);
           (%o7)                                 - 4
bit_rsh (int, nBits)                                                              [Function]
     This function shifts all bits of the signed integer int to the right by nBits bits. The
     width of the integer is reduced by nBits for this process.
           (%i1) load("bitwise")$
           (%i2) bit_rsh(0,1);
           (%o2)                                    0
           (%i3) bit_rsh(2,0);
           (%o3)                                    2
           (%i4) bit_rsh(2,1);
           (%o4)                                    1
           (%i5) bit_rsh(2,2);
           (%o5)                                    0
           (%i6) bit_rsh(-3,1);
           (%o6)                                   - 2
           (%i7) bit_rsh(-2,1);
           (%o7)                                   - 1
           (%i8) bit_rsh(-2,2);
           (%o8)                                   - 1
bit_length (int)                                                             [Function]
     determines how many bits a variable needs to be long in order to store the number
     int. This function only operates on positive numbers.
          (%i1) load("bitwise")$
          (%i2) bit_length(0);
          (%o2)                                  0
          (%i3) bit_length(1);
          (%o3)                                  1
          (%i4) bit_length(7);
          (%o4)                                  3
          (%i5) bit_length(8);
          (%o5)                                  4
bit_onep (int, nBit)                                                             [Function]
     determines if bits nBit is set in the signed integer int.
          (%i1) load("bitwise")$
          (%i2) bit_onep(85,0);
          (%o2)                                  true
680                                                                   Maxima 5.45.0 Manual
              (%i3) bit_onep(85,1);
              (%o3)                               false
              (%i4) bit_onep(85,2);
              (%o4)                               true
              (%i5) bit_onep(85,3);
              (%o5)                               false
              (%i6) bit_onep(85,100);
              (%o6)                               false
              (%i7) bit_onep(i,100);
              (%o7)                       bit_onep(i, 100)
      For signed numbers the sign bit is interpreted to be more than nBit to the left of the
      leftmost bit of int that reads 1.
              (%i1) load("bitwise")$
              (%i2) bit_onep(-2,0);
              (%o2)                               false
              (%i3) bit_onep(-2,1);
              (%o3)                               true
              (%i4) bit_onep(-2,2);
              (%o4)                               true
              (%i5) bit_onep(-2,3);
              (%o5)                               true
              (%i6) bit_onep(-2,4);
              (%o6)                               true
      If it is known if the number to be tested is even this information is taken into consid-
      eration by the function.
              (%i1) load("bitwise")$
              (%i2) declare(e,even,o,odd);
              (%o2)                               done
              (%i3) bit_onep(e,0);
              (%o3)                               false
              (%i4) bit_onep(o,0);
              (%o4)                               true
                                                                           681
44 bode
45 celine
46 clebsch gordan
47 cobyla
      constraints
                List of inequality and equality constraints that must be satisfied by X.
                The inequality constraints must be actual inequalities of the form g(X)
                >= h(X) or g(X) <= h(X). The equality constraints must be of the form
                g(X) = h(X).
      rhobeg      Initial value of the internal RHO variable which controls the size of sim-
                  plex. (Defaults to 1.0)
      rhoend      The desired final value rho parameter. It is approximately the accuracy
                  in the variables. (Defaults to 1d-6.)
      iprint      Verbose output level. (Defaults to 0)
                   • 0 - No output
                   • 1 - Summary at the end of the calculation
                   • 2 - Each new value of RHO and SIGMA is printed, including the
                      vector of variables, some function information when RHO is reduced.
                   • 3 - Like 2, but information is printed when F(X) is computed.
      maxfun      The maximum number of function evaluations. (Defaults to 1000).
      On return, a vector is given:
       1. The value of the variables giving the minimum. This is a list of elements of the
          form var = value for each of the variables listed in X.
       2. The minimized function value
       3. The number of function evaluations.
       4. Return code with the following meanings
              0 - No errors.
              1 - Limit on maximum number of function evaluations reached.
              2 - Rounding errors inhibiting progress.
              -1 - MAXCV value exceeds RHOEND. This indicates that the constraints
              were probably not satisfied. User should investigate the value of the con-
              straints.
      MAXCV stands for “MAXimum Constraint Violation” and is the value of
      max(0.0, −c1(x), −c2(x), ... − cm(x)) where ck(x) denotes the k’th constraint
      function. (Note that maxima allows constraints of the form f (x) = g(x), which are
      internally converted to f (x) − g(x) >= 0 and g(x) − f (x) >= 0 which is required by
      COBYLA).
      load("fmin_cobyla") loads this function.
bf_fmin_cobyla                                                                   [Function]
        bf_fmin_cobyla (F, X, Y)
        bf_fmin_cobyla (F, X, Y, optional args)
      This function is identical to fmin_cobyla, except that bigfloat operations are used,
      and the default value for rhoend is 10^(fpprec/2).
      See fmin_cobyla for more information.
      load("bf_fmin_cobyla") loads this function.
Chapter 47: cobyla                                                                691
48 combinatorics
     Example:
           (%i1) load("combinatorics")$
           (%i2) perm_length ([4, 6, 3, 1, 7, 5, 2, 8]);
           (%o2)                           12
      Example:
            (%i1) load("combinatorics")$
            (%i2) perm_parity ([4, 6, 3, 1, 7, 5, 2, 8]);
            (%o2)                            0
perms                                                                              [Function]
         perms (n)
         perms (n, i)
         perms (n, i, j)
     perms(n) returns a list of all n-degree permutations in the so-called Trotter-Johnson
     order.
     perms(n, i) returns the n-degree permutation which is at the i th position (from 1
     to n!) in the Trotter-Johnson ordering of the permutations.
     perms(n, i, j) returns a list of the n-degree permutations between positions i and
     j in the Trotter-Johnson ordering of the permutations.
     The sequence of permutations in Trotter-Johnson order starts with the identity per-
     mutation and each consecutive permutation can be obtained from the previous one a
     by single adjacent transposition.
     See also perm_next, perm_rank and perm_unrank.
     Examples:
           (%i1) load("combinatorics")$
           (%i2) perms (4);
           (%o2) [[1, 2, 3, 4], [1, 2, 4, 3], [1, 4, 2, 3], [4, 1, 2, 3],
           [4, 1, 3, 2], [1, 4, 3, 2], [1, 3, 4, 2], [1, 3, 2, 4],
           [3, 1, 2, 4], [3, 1, 4, 2], [3, 4, 1, 2], [4, 3, 1, 2],
           [4, 3, 2, 1], [3, 4, 2, 1], [3, 2, 4, 1], [3, 2, 1, 4],
           [2, 3, 1, 4], [2, 3, 4, 1], [2, 4, 3, 1], [4, 2, 3, 1],
           [4, 2, 1, 3], [2, 4, 1, 3], [2, 1, 4, 3], [2, 1, 3, 4]]
           (%i3) perms (4, 12);
           (%o3)                     [[4, 3, 1, 2]]
           (%i4) perms (4, 12, 14);
           (%o4)       [[4, 3, 1, 2], [4, 3, 2, 1], [3, 4, 2, 1]]
perms_lex                                                                          [Function]
        perms_lex (n)
        perms_lex (n, i)
        perms_lex (n, i, j)
     perms_lex(n) returns a list of all n-degree permutations in the so-called lexicographic
     order.
     perms_lex(n, i) returns the n-degree permutation which is at the i th position (from
     1 to n!) in the lexicographic ordering of the permutations.
     perms_lex(n, i, j) returns a list of the n-degree permutations between positions i
     and j in the lexicographic ordering of the permutations.
     The sequence of permutations in lexicographic order starts with all the permutations
     with the lowest index, 1, followed by all permutations starting with the following
     index, 2, and so on. The permutations starting by an index i are the permutations
     of the first n integers different from i and they are also placed in lexicographic order,
     where the permutations with the lowest of those integers are placed first and so on.
     See also perm_lex_next, perm_lex_rank and perm_lex_unrank.
698                                                                Maxima 5.45.0 Manual
      Examples:
          (%i1) load("combinatorics")$
          (%i2) perms_lex (4);
          (%o2) [[1, 2, 3, 4], [1, 2, 4, 3], [1, 3, 2, 4], [1, 3, 4, 2],
          [1, 4, 2, 3], [1, 4, 3, 2], [2, 1, 3, 4], [2, 1, 4, 3],
          [2, 3, 1, 4], [2, 3, 4, 1], [2, 4, 1, 3], [2, 4, 3, 1],
          [3, 1, 2, 4], [3, 1, 4, 2], [3, 2, 1, 4], [3, 2, 4, 1],
          [3, 4, 1, 2], [3, 4, 2, 1], [4, 1, 2, 3], [4, 1, 3, 2],
          [4, 2, 1, 3], [4, 2, 3, 1], [4, 3, 1, 2], [4, 3, 2, 1]]
          (%i3) perms_lex (4, 12);
          (%o3)                     [[2, 4, 3, 1]]
          (%i4) perms_lex (4, 12, 14);
          (%o4)       [[2, 4, 3, 1], [3, 1, 2, 4], [3, 1, 4, 2]]
49 contrib ode
                                                         x
      (%o3)                  [y = log(x) + %c, y = %c %e ]
      (%i4) method;
      (%o4)                              factor
   Nonlinear ODEs can have singular solutions without constants of integration, as in the
second solution of the following example:
700                                                             Maxima 5.45.0 Manual
      (%i1) load('contrib_ode)$
      (%i2) eqn:'diff(y,x)^2+x*'diff(y,x)-y=0;
                             dy 2     dy
      (%o2)                 (--) + x -- - y = 0
                             dx       dx
      (%i3) contrib_ode(eqn,y,x);
                             dy 2     dy
      (%t3)                 (--) + x -- - y = 0
                             dx       dx
                                                    2
                                         2        x
      (%o3)                [y = %c x + %c , y = - --]
                                                  4
      (%i4) method;
      (%o4)                              clairault
   The following ODE has two parametric solutions in terms of the dummy variable %t. In
this case the parametric solutions can be manipulated to give explicit solutions.
      (%i1) load('contrib_ode)$
      (%i2) eqn:'diff(y,x)=(x+y)^2;
                                      dy           2
      (%o2)                           -- = (x + y)
                                      dx
      (%i3) contrib_ode(eqn,y,x);
      (%o3) [[x = %c - atan(sqrt(%t)), y = (- x) - sqrt(%t)],
                                [x = atan(sqrt(%t)) + %c, y = sqrt(%t) - x]]
      (%i4) method;
      (%o4)                              lagrange
   The following example (Kamke 1.112) demonstrates an implicit solution.
      (%i1) load('contrib_ode)$
      (%i2) assume(x>0,y>0);
      (%o2)                          [x > 0, y > 0]
      (%i3) eqn:x*'diff(y,x)-x*sqrt(y^2+x^2)-y;
                                dy             2     2
      (%o3)                  x -- - x sqrt(y + x ) - y
                                dx
      (%i4) contrib_ode(eqn,y,x);
                                               y
      (%o4)                        [x - asinh(-) = %c]
                                               x
      (%i5) method;
      (%o5)                                 lie
   The following Riccati equation is transformed into a linear second order ODE in the
variable %u. Maxima is unable to solve the new ODE, so it is returned unevaluated.
Chapter 49: contrib ode                                                                701
      (%i1) load('contrib_ode)$
      (%i2) eqn:x^2*'diff(y,x)=a+b*x^n+c*x^2*y^2;
                           2 dy      2 2       n
      (%o2)               x -- = c x y + b x + a
                             dx
      (%i3) contrib_ode(eqn,y,x);
                     d%u
                     ---                              2
                     dx         2 a        n - 2     d %u
      (%o3) [[y = - ----, %u c (-- + b x         ) + ---- c = 0]]
                     %u c           2                   2
                                  x                  dx
      (%i4) method;
      (%o4)                         riccati
    For first order ODEs contrib_ode calls ode2. It then tries the following methods: fac-
torization, Clairault, Lagrange, Riccati, Abel and Lie symmetry methods. The Lie method
is not attempted on Abel equations if the Abel method fails, but it is tried if the Riccati
method returns an unsolved second order ODE.
   For second order ODEs contrib_ode calls ode2 then odelin.
   Extensive debugging traces and messages are displayed if the command put('contrib_
ode,true,'verbose) is executed.
            (%i2) eqn:'diff(y,x,2)+(a*x+b)*y;
                                     2
                                    d y
            (%o2)                   --- + (b + a x) y
                                       2
                                    dx
            (%i3) ans:[y = bessel_y(1/3,2*(a*x+b)^(3/2)/(3*a))*%k2*sqrt(a*x+b)
                     +bessel_j(1/3,2*(a*x+b)^(3/2)/(3*a))*%k1*sqrt(a*x+b)];
                                               3/2
                                1 2 (b + a x)
            (%o3) [y = bessel_y(-, --------------) %k2 sqrt(a x + b)
                                3        3 a
                                                      3/2
                                         1 2 (b + a x)
                             + bessel_j(-, --------------) %k1 sqrt(a x + b)]
                                         3       3 a
            (%i4) ode_check(eqn,ans[1]);
            (%o4)                            0
%c                                                                                [Variable]
      %c is the integration constant for first order ODEs.
%k1                                                                               [Variable]
      %k1 is the first integration constant for second order ODEs.
%k2                                                                               [Variable]
      %k2 is the second integration constant for second order ODEs.
 • Fix the LAGRANGE routine ode1_lagrange to prefer real roots over complex roots.
 • Add additional methods for Riccati equations.
 • Improve the detection of Abel equations of second kind. The existing pattern matching
   is weak.
 • Work on the Lie symmetry group routine ode1_lie. There are quite a few problems
   with it: some parts are unimplemented; some test cases seem to run forever; other test
   cases crash; yet others return very complex "solutions". I wonder if it really ready for
   release yet.
 • Add more test cases.
50 descriptive
                                             [           ]
                                             [   5   6   ]
                                             [           ]
                                             [   5   6   ]
            (%o2)                            [           ]
                                             [   u   2   ]
                                             [           ]
                                             [   6   8   ]
                                             [           ]
                                             [   6   8   ]
            (%i3) cov(sam2);
                   [   2                     2                             ]
                   [ u + 158         (u + 28)     2 u + 174    11 (u + 28) ]
                   [ -------- -      ---------    --------- - ----------- ]
            (%o3) [      6              36            6            12      ]
                   [                                                       ]
                   [ 2 u + 174       11 (u + 28)            21             ]
                   [ --------- -     -----------            --             ]
                   [     6               12                 4              ]
            (%i4) barsplot(sam2,     grouping=stacked) $
continuous_freq                                                                  [Function]
        continuous_freq (data)
        continuous_freq (data, m)
      The first argument of continuous_freq must be a list or 1-dimensional array (as
      created by make_array) of numbers. Divides the range in intervals and counts how
      many values are inside them. The second argument is optional and either equals the
      number of classes we want, 10 by default, or equals a list containing the class limits
      and the number of classes we want, or a list containing only the limits.
      If sample values are all equal, this function returns only one class of amplitude 2.
      Examples:
      Optional argument indicates the number of classes we want. The first list in the
      output contains the interval limits, and the second the corresponding counts: there
      are 16 digits inside the interval [0, 1.8], 24 digits in (1.8, 3.6], and so on.
            (%i1) load ("descriptive")$
            (%i2) s1 : read_list (file_search ("pidigits.data"))$
            (%i3) continuous_freq (s1, 5);
            (%o3) [[0, 1.8, 3.6, 5.4, 7.2, 9.0], [16, 24, 18, 17, 25]]
      Optional argument indicates we want 7 classes with limits -2 and 12:
            (%i1) load ("descriptive")$
            (%i2) s1 : read_list (file_search ("pidigits.data"))$
            (%i3) continuous_freq (s1, [-2,12,7]);
            (%o3) [[- 2, 0, 2, 4, 6, 8, 10, 12], [8, 20, 22, 17, 20, 13, 0]]
      Optional argument indicates we want the default number of classes with limits -2 and
      12:
            (%i1) load ("descriptive")$
Chapter 50: descriptive                                                                709
standardize                                                                      [Function]
        standardize (list)
        standardize (matrix)
      Subtracts to each element of the list the sample mean and divides the result by the
      standard deviation. When the input is a matrix, standardize subtracts to each
      row the multivariate mean, and then divides each component by the corresponding
      standard deviation.
subsample                                                       [Function]
        subsample (data_matrix, predicate_function)
        subsample (data_matrix, predicate_function, col_num1, col_num2,
        ...)
      This is a sort of variant of the Maxima submatrix function. The first argument is
      the data matrix, the second is a predicate function and optional additional arguments
      are the numbers of the columns to be taken. Its behaviour is better understood with
      examples.
      These are multivariate records in which the wind speed in the first meteorological
      station were greater than 18. See that in the lambda expression the i-th component
      is referred to as v[i].
            (%i1) load ("descriptive")$
            (%i2) s2 : read_matrix (file_search ("wind.data"))$
            (%i3) subsample (s2, lambda([v], v[1] > 18));
                          [ 19.38 15.37 15.12 23.09 25.25 ]
                          [                                   ]
                          [ 18.29 18.66 19.08 26.08 27.63 ]
            (%o3)         [                                   ]
                          [ 20.25 21.46 19.95 27.71 23.38 ]
                          [                                   ]
                          [ 18.79 18.96 14.46 26.38 21.84 ]
      In the following example, we request only the first, second and fifth components of
      those records with wind speeds greater or equal than 16 in station number 1 and less
      than 25 knots in station number 4. The sample contains only data from stations 1, 2
      and 5. In this case, the predicate function is defined as an ordinary Maxima function.
            (%i1) load ("descriptive")$
            (%i2) s2 : read_matrix (file_search ("wind.data"))$
            (%i3) g(x):= x[1] >= 16 and x[4] < 25$
            (%i4) subsample (s2, g, 1, 2, 5);
                                 [ 19.38 15.37 25.25 ]
                                 [                     ]
                                 [ 17.33 14.67 19.58 ]
            (%o4)                [                     ]
                                 [ 16.92 13.21 21.21 ]
                                 [                     ]
                                 [ 17.25 18.46 23.87 ]
      Here is an example with the categorical variables of biomed.data. We want the
      records corresponding to those patients in group B who are older than 38 years.
Chapter 50: descriptive                                                         711
Probably, the statistical analysis will involve only the blood measures,
                                                          [   1   3   2 ]
                                                          [             ]
                                                          [   1   3   7 ]
             (%o3)                                        [             ]
                                                          [   1   8   2 ]
                                                          [             ]
                                                          [   1   5   2 ]
       Example:
             (%i1) load ("descriptive")$
             (%i2) s1 : read_list (file_search ("pidigits.data"))$
             (%i3) mean (s1);
                                            471
             (%o3)                          ---
                                            100
             (%i4) %, numer;
             (%o4)                         4.71
             (%i5) s2 : read_matrix (file_search ("wind.data"))$
             (%i6) mean (s2);
             (%o6)     [9.9485, 10.1607, 10.8685, 15.7166, 14.8441]
var                                                                         [Function]
           var (list)
           var (matrix)
       This is the sample variance, defined as
                                          n
                                       1X
                                             (xi − x̄)2
                                       n i=1
       Example:
             (%i1) load ("descriptive")$
             (%i2) s1 : read_list (file_search ("pidigits.data"))$
             (%i3) var (s1), numer;
             (%o3)                   8.425899999999999
       See also function var1.
714                                                                Maxima 5.45.0 Manual
var1                                                                           [Function]
           var1 (list)
           var1 (matrix)
       This is the sample variance, defined as
                                            n
                                       1 X
                                               (xi − x̄)2
                                     n − 1 i=1
       Example:
           (%i1)    load ("descriptive")$
           (%i2)    s1 : read_list (file_search ("pidigits.data"))$
           (%i3)    var1 (s1), numer;
           (%o3)                       8.5110101010101
           (%i4)    s2 : read_matrix (file_search ("wind.data"))$
           (%i5)    var1 (s2);
           (%o5)    [17.39586540404041, 15.13912778787879, 15.63204924242424,
                                          32.50152569696971, 24.66977392929294]
       See also function var.
std                                                                            [Function]
           std (list)
           std (matrix)
       This is the square root of the function var, the variance with denominator n.
       Example:
             (%i1) load ("descriptive")$
             (%i2) s1 : read_list (file_search ("pidigits.data"))$
             (%i3) std (s1), numer;
             (%o3)                         2.902740084816414
             (%i4) s2 : read_matrix (file_search ("wind.data"))$
             (%i5) std (s2);
             (%o5) [4.149928523480858, 3.871399812729241, 3.933920277534866,
                                               5.672434260526957, 4.941970881136392]
       See also functions var and std1.
std1                                                                           [Function]
           std1 (list)
           std1 (matrix)
       This is the square root of the function var1, the variance with denominator n − 1.
       Example:
             (%i1) load ("descriptive")$
             (%i2) s1 : read_list (file_search ("pidigits.data"))$
             (%i3) std1 (s1), numer;
             (%o3)                         2.917363553109228
             (%i4) s2 : read_matrix (file_search ("wind.data"))$
             (%i5) std1 (s2);
             (%o5) [4.170835096721089, 3.89090320978032, 3.953738641137555,
                                               5.701010936401517, 4.966867617451963]
Chapter 50: descriptive                                                               715
noncentral_moment                                                              [Function]
        noncentral_moment (list, k)
        noncentral_moment (matrix, k)
     The non central moment of order k, defined as
                                           n
                                        1X
                                             xk
                                        n i=1 i
     Example:
         (%i1)    load ("descriptive")$
         (%i2)    s1 : read_list (file_search ("pidigits.data"))$
         (%i3)    noncentral_moment (s1, 1), numer; /* the mean */
         (%o3)                            4.71
         (%i5)    s2 : read_matrix (file_search ("wind.data"))$
         (%i6)    noncentral_moment (s2, 5);
         (%o6)    [319793.8724761505, 320532.1923892463,
                  391249.5621381556, 2502278.205988911, 1691881.797742255]
     See also function central_moment.
central_moment                                                                 [Function]
        central_moment (list, k)
        central_moment (matrix, k)
     The central moment of order k, defined as
                                        n
                                     1X
                                           (xi − x̄)k
                                     n i=1
     Example:
         (%i1)    load ("descriptive")$
         (%i2)    s1 : read_list (file_search ("pidigits.data"))$
         (%i3)    central_moment (s1, 2), numer; /* the variance */
         (%o3)                        8.425899999999999
         (%i5)    s2 : read_matrix (file_search ("wind.data"))$
         (%i6)    central_moment (s2, 3);
         (%o6)    [11.29584771375004, 16.97988248298583, 5.626661952750102,
                                           37.5986572057918, 25.85981904394192]
     See also functions central_moment and mean.
cv                                                                             [Function]
          cv (list)
          cv (matrix)
     The variation coefficient is the quotient between the sample standard deviation (std)
     and the mean,
           (%i1) load ("descriptive")$
716                                                                 Maxima 5.45.0 Manual
smin                                                                            [Function]
           smin (list)
           smin (matrix)
       This is the minimum value of the sample list. When the argument is a matrix, smin
       returns a list containing the minimum values of the columns, which are associated to
       statistical variables.
             (%i1)   load ("descriptive")$
             (%i2)   s1 : read_list (file_search ("pidigits.data"))$
             (%i3)   smin (s1);
             (%o3)                             0
             (%i4)   s2 : read_matrix (file_search ("wind.data"))$
             (%i5)   smin (s2);
             (%o5)               [0.58, 0.5, 2.67, 5.25, 5.17]
       See also function smax.
smax                                                                            [Function]
           smax (list)
           smax (matrix)
       This is the maximum value of the sample list. When the argument is a matrix, smax
       returns a list containing the maximum values of the columns, which are associated to
       statistical variables.
             (%i1)   load ("descriptive")$
             (%i2)   s1 : read_list (file_search ("pidigits.data"))$
             (%i3)   smax (s1);
             (%o3)                             9
             (%i4)   s2 : read_matrix (file_search ("wind.data"))$
             (%i5)   smax (s2);
             (%o5)            [20.25, 21.46, 20.04, 29.63, 27.63]
       See also function smin.
range                                                                           [Function]
           range (list)
           range (matrix)
       The range is the difference between the extreme values.
       Example:
             (%i1) load ("descriptive")$
             (%i2) s1 : read_list (file_search ("pidigits.data"))$
Chapter 50: descriptive                                                                   717
      Example:
            (%i1) load ("descriptive")$
            (%i2) s1 : read_list (file_search ("pidigits.data"))$
            (%i3) mean_deviation (s1);
                                           51
            (%o3)                          --
                                           20
            (%i4) s2 : read_matrix (file_search ("wind.data"))$
            (%i5) mean_deviation (s2);
            (%o5) [3.287959999999999, 3.075342, 3.23907, 4.715664000000001,
                                                           4.028546000000002]
      See also function mean.
median_deviation                                                     [Function]
        median_deviation (list)
        median_deviation (matrix)
      The median deviation, defined as
                                          n
                                       1X
                                             |xi − med|
                                       n i=1
      where med is the median of list.
      Example:
          (%i1) load ("descriptive")$
          (%i2) s1 : read_list (file_search ("pidigits.data"))$
          (%i3) median_deviation (s1);
                                          5
          (%o3)                           -
                                          2
Chapter 50: descriptive                                                     719
     Example:
         (%i1)    load ("descriptive")$
         (%i2)    y : [5, 7, 2, 5, 9, 5, 6, 4, 9, 2, 4, 2, 5]$
         (%i3)    harmonic_mean (y), numer;
         (%o3)                        3.901858027632205
         (%i4)    s2 : read_matrix (file_search ("wind.data"))$
         (%i5)    harmonic_mean (s2);
         (%o5)    [6.948015590052786, 7.391967752360356, 9.055658197151745,
                                          13.44199028193692, 13.01439145898509]
     See also functions mean and geometric_mean.
geometric_mean                                                        [Function]
        geometric_mean (list)
        geometric_mean (matrix)
     The geometric mean, defined as
                                           n
                                                      ! n1
                                           Y
                                                 xi
                                           i=1
     Example:
         (%i1)    load ("descriptive")$
         (%i2)    y : [5, 7, 2, 5, 9, 5, 6, 4, 9, 2, 4, 2, 5]$
         (%i3)    geometric_mean (y), numer;
         (%o3)                        4.454845412337012
         (%i4)    s2 : read_matrix (file_search ("wind.data"))$
         (%i5)    geometric_mean (s2);
         (%o5)    [8.82476274347979, 9.22652604739361, 10.0442675714889,
                                          14.61274126349021, 13.96184163444275]
     See also functions mean and harmonic_mean.
kurtosis                                                              [Function]
        kurtosis (list)
        kurtosis (matrix)
     The kurtosis coefficient, defined as
                                         n
                                     1 X
                                            (xi − x̄)4 − 3
                                    ns4 i=1
720                                                          Maxima 5.45.0 Manual
      Example:
            (%i1) load ("descriptive")$
            (%i2) s1 : read_list (file_search ("pidigits.data"))$
            (%i3) kurtosis (s1), numer;
            (%o3)                      - 1.273247946514421
            (%i4) s2 : read_matrix (file_search ("wind.data"))$
            (%i5) kurtosis (s2);
            (%o5) [- .2715445622195385, 0.119998784429451,
                  - .4275233490482861, - .6405361979019522, - .4952382132352935]
      See also functions mean, var and skewness.
skewness                                                                 [Function]
        skewness (list)
        skewness (matrix)
      The skewness coefficient, defined as
                                           n
                                       1 X
                                              (xi − x̄)3
                                      ns3 i=1
      Example:
          (%i1)    load ("descriptive")$
          (%i2)    s1 : read_list (file_search ("pidigits.data"))$
          (%i3)    skewness (s1), numer;
          (%o3)                        .009196180476450424
          (%i4)    s2 : read_matrix (file_search ("wind.data"))$
          (%i5)    skewness (s2);
          (%o5)    [.1580509020000978, .2926379232061854, .09242174416107717,
                                             .2059984348148687, .2142520248890831]
      See also functions mean,, var and kurtosis.
pearson_skewness                                                         [Function]
        pearson_skewness (list)
        pearson_skewness (matrix)
      Pearson’s skewness coefficient, defined as
                                        3 (x̄ − med)
                                              s
      where med is the median of list.
      Example:
          (%i1) load ("descriptive")$
          (%i2) s1 : read_list (file_search ("pidigits.data"))$
          (%i3) pearson_skewness (s1), numer;
          (%o3)                        .2159484029093895
          (%i4) s2 : read_matrix (file_search ("wind.data"))$
Chapter 50: descriptive                                                             721
quartile_skewness                                                             [Function]
        quartile_skewness (list)
        quartile_skewness (matrix)
     The quartile skewness coefficient, defined as
                                     c 34 − 2 c 12 + c 14
                                          c 34 − c 14
km                                                                            [Function]
          km (list, option ...)
          km (matrix, option ...)
     Kaplan Meier estimator of the survival, or reliability, function S(x) = 1 − F (x).
     Data can be introduced as a list of pairs, or as a two column matrix. The first
     component is the observed time, and the second component a censoring index (1 =
     non censored, 0 = right censored).
     The optional argument is the name of the variable in the returned expression, which
     is x by default.
     Examples:
     Sample as a list of pairs.
           (%i1) load ("descriptive")$
           (%i2) S: km([[2,1], [3,1], [5,0], [8,1]]);
                                       charfun((3 <= x) and (x < 8))
           (%o2) charfun(x < 0) + -----------------------------
                                                         2
                                3 charfun((2 <= x) and (x < 3))
                             + -------------------------------
                                                4
                             + charfun((0 <= x) and (x < 2))
           (%i3) load ("draw")$
722                                                                  Maxima 5.45.0 Manual
           (%i4) draw2d(
                     line_width = 3, grid = true,
                     explicit(S, x, -0.1, 10))$
      Estimate survival probabilities.
           (%i1) load ("descriptive")$
           (%i2) S(t):= ''(km([[2,1], [3,1], [5,0], [8,1]], t)) $
           (%i3) S(6);
                                         1
           (%o3)                         -
                                         2
cdf_empirical                                                                   [Function]
        cdf_empirical (list, option ...)
        cdf_empirical (matrix, option ...)
      Empirical distribution function F (x).
      Data can be introduced as a list of numbers, or as an one column matrix.
      The optional argument is the name of the variable in the returned expression, which
      is x by default.
      Example:
      Empirical distribution function.
            (%i1) load ("descriptive")$
            (%i2) F(x):= ''(cdf_empirical([1,3,3,5,7,7,7,8,9]));
            (%o2) F(x) := (charfun(x >= 9) + charfun(x >= 8)
                              + 3 charfun(x >= 7) + charfun(x >= 5)
                              + 2 charfun(x >= 3) + charfun(x >= 1))/9
            (%i3) F(6);
                                             4
            (%o3)                            -
                                             9
            (%i4) load(draw)$
            (%i5) draw2d(
                       line_width = 3,
                       grid        = true,
                       explicit(F(z), z, -2, 12)) $
cov (matrix)                                                                    [Function]
      The covariance matrix of the multivariate sample, defined as
                                      n
                                   1X                   0
                              S=         Xj − X̄ Xj − X̄
                                   n j=1
      where p is the dimension of the multivariate random variable and S1 the covariance
      matrix returned by cov1.
      Option:
       • 'data, default 'true, indicates whether the input matrix contains the sample
         data, in which case the covariance matrix cov1 must be calculated, or not, and
         then the covariance matrix (symmetric) must be given, instead of the data.
      Example:
           (%i1)   load ("descriptive")$
           (%i2)   s2 : read_matrix (file_search ("wind.data"))$
           (%i3)   global_variances (s2);
           (%o3)   [105.338342060606, 21.06766841212119, 12874.34690469686,
                      113.4651792608501, 6.636590811800795, 2.576158149609762]
      Calculate the global_variances from the covariance matrix.
           (%i1)   load ("descriptive")$
           (%i2)   s2 : read_matrix (file_search ("wind.data"))$
           (%i3)   s : cov1 (s2)$
           (%i4)   global_variances (s, data=false);
           (%o4)   [105.338342060606, 21.06766841212119, 12874.34690469686,
                      113.4651792608501, 6.636590811800795, 2.576158149609762]
      See also cov and cov1.
cor                                                                           [Function]
          cor (matrix)
          cor (matrix, logical_value)
      The correlation matrix of the multivariate sample.
      Option:
       • 'data, default 'true, indicates whether the input matrix contains the sample
         data, in which case the covariance matrix cov1 must be calculated, or not, and
         then the covariance matrix (symmetric) must be given, instead of the data.
      Example:
           (%i1) load ("descriptive")$
           (%i2) fpprintprec : 7 $
           (%i3) s2 : read_matrix (file_search ("wind.data"))$
           (%i4) cor (s2);
                 [   1.0     .8476339 .8803515 .8239624 .7519506              ]
                 [                                                            ]
                 [ .8476339    1.0     .8735834 .6902622 0.782502             ]
                 [                                                            ]
           (%o4) [ .8803515 .8735834     1.0     .7764065 .8323358            ]
                 [                                                            ]
                 [ .8239624 .6902622 .7764065      1.0     .7293848           ]
                 [                                                            ]
                 [ .7519506 0.782502 .8323358 .7293848       1.0              ]
Chapter 50: descriptive                                                              725
list_correlations                                                              [Function]
        list_correlations (matrix)
        list_correlations (matrix, options ...)
     Function list_correlations returns a list of correlation measures:
      • precision matrix: the inverse of the covariance matrix S1 ,
                                      S1−1 = sij
                                                   
                                                       i,j=1,2,...,p
                                                           1
                                         Ri2 = 1 −
                                                        sii s   ii
                                                          sij
                                       rij.rest = − √
                                                          sii sjj
     Option:
      • 'data, default 'true, indicates whether the input matrix contains the sample
         data, in which case the covariance matrix cov1 must be calculated, or not, and
         then the covariance matrix (symmetric) must be given, instead of the data.
     Example:
         (%i1) load ("descriptive")$
         (%i2) s2 : read_matrix (file_search ("wind.data"))$
726                                                                   Maxima 5.45.0 Manual
principal_components                                                                [Function]
        principal_components (matrix)
        principal_components (matrix, options ...)
      Calculates the principal components of a multivariate sample. Principal components
      are used in multivariate statistical analysis to reduce the dimensionality of the sample.
      Option:
       • 'data, default 'true, indicates whether the input matrix contains the sample
         data, in which case the covariance matrix cov1 must be calculated, or not, and
         then the covariance matrix (symmetric) must be given, instead of the data.
      The output of function principal_components is a list with the following results:
       • variances of the principal components,
       • percentage of total variance explained by each principal component,
       • rotation matrix.
      Examples:
      In this sample, the first component explains 83.13 per cent of total variance.
            (%i1) load ("descriptive")$
            (%i2) s2 : read_matrix (file_search ("wind.data"))$
            (%i3) fpprintprec:4 $
Chapter 50: descriptive                                                             727
      For bars diagrams related options, see barsplot of package Chapter 53 [draw-pkg],
      page 779, See also functions histogram and piechart.
barsplot_description ( . . . )                                                [Function]
      Function barsplot_description creates a graphic object suitable for creating com-
      plex scenes, together with other graphic objects.
      Example: barsplot in a multiplot context.
            (%i1) load ("descriptive")$
            (%i2) l1:makelist(random(10),k,1,50)$
            (%i3) l2:makelist(random(10),k,1,100)$
            (%i4) bp1 :
                    barsplot_description(
                     l1,
                     box_width = 1,
                     fill_density = 0.5,
                     bars_colors = [blue],
                     frequency = relative)$
            (%i5) bp2 :
                    barsplot_description(
                     l2,
                     box_width = 1,
                     fill_density = 0.5,
                     bars_colors = [red],
                     frequency = relative)$
            (%i6) draw(gr2d(bp1), gr2d(bp2))$
       • range (default, inf): positive coefficient of the interquartilic range to set outliers
         boundaries.
       • outliers size (default, 1): circle size for isolated outliers.
       • All draw options, except points_joined, point_size, point_type, xtics,
         ytics, xrange, and yrange, which are internally assigned by boxplot. If you
         want to set your own values for this options or want to build complex scenes,
         make use of boxplot_description.
       • The following local draw options: key, color, and line_width.
boxplot_description ( . . . )                                                   [Function]
      Function boxplot_description creates a graphic object suitable for creating complex
      scenes, together with other graphic objects.
histogram                                                                          [Function]
        histogram        (list)
        histogram        (list, option_1, option_2, . . . )
        histogram        (one_column_matrix)
        histogram        (one_column_matrix, option_1, option_2, . . . )
        histogram        (one_row_matrix)
        histogram        (one_row_matrix, option_1, option_2, . . . )
      This function plots an histogram from a continuous sample. Sample data must be
      stored in a list of numbers or an one dimensional matrix.
      Available options are:
        • nclasses (default, 10): number of classes of the histogram, or a list indicating the
           limits of the classes and the number of them, or only the limits. This option also
           accepts bounds for varying bin widths, or a symbol with the name of one of the
           three optimal algorithms available for the number of classes: 'fd (Freedman, D.
           and Diaconis, P. (1981) On the histogram as a density estimator: L 2 theory.
           Zeitschrift für Wahrscheinlichkeitstheorie und verwandte Gebiete 57, 453-476.),
           'scott (Scott, D. W. (1979) On optimal and data-based histograms. Biometrika
           66, 605-610.), and 'sturges (Sturges, H. A. (1926) The choice of a class interval.
           Journal of the American Statistical Association 21, 65-66).
        • frequency (default, absolute): indicates the scale of the ordinates. Possible
           values are: absolute, relative, percent, and density. With density, the
           histogram area has a total area of one.
        • htics (default, auto): format of the histogram tics. Possible values are: auto,
           endpoints, intervals, or a list of labels.
        • All global draw options, except xrange, yrange, and xtics, which are internally
           assigned by histogram. If you want to set your own values for these options,
           make use of histogram_description. See examples bellow.
        • The following local Chapter 53 [draw-pkg], page 779, options: key, color, fill_
           color, fill_density and line_width. See also barsplot.
      There is also a function wxhistogram for creating embedded histograms in interfaces
      wxMaxima and iMaxima.
      Examples:
      A simple with eight classes:
           (%i1) load ("descriptive")$
           (%i2) s1 : read_list (file_search ("pidigits.data"))$
           (%i3) histogram (
                          s1,
                          nclasses      = 8,
                          title         = "pi digits",
                          xlabel        = "digits",
                          ylabel        = "Absolute frequency",
Chapter 50: descriptive                                                              733
                          fill_color   = grey,
                          fill_density = 0.6)$
     Setting the limits of the histogram to -2 and 12, with 3 classes. Also, we introduce
     predefined tics:
Freedmann - Diakonis robust method for optimal search of the number of classes.
histogram_description ( . . . )                                            [Function]
     Function histogram_description creates a graphic object suitable for creating
     complex scenes, together with other graphic objects. We make use of histogram_
     description for setting the xrange and adding an explicit curve into the
     scene:
piechart                                                                        [Function]
        piechart     (list)
        piechart     (list, option_1, option_2, . . . )
        piechart     (one_column_matrix)
        piechart     (one_column_matrix, option_1, option_2, . . . )
        piechart     (one_row_matrix)
        piechart     (one_row_matrix, option_1, option_2, . . . )
      Similar to barsplot, but plots sectors instead of rectangles.
      Available options are:
       • sector colors (default, []): a list of colors for sectors. When there are more
         sectors than specified colors, the extra necessary colors are chosen at random.
         See color to learn more about them.
       • pie center (default, [0,0]): diagram’s center.
       • pie radius (default, 1): diagram’s radius.
       • All global draw options, except key, which is internally assigned by piechart. If
         you want to set your own values for this option or want to build complex scenes,
         make use of piechart_description.
       • The following local draw options: key, color, fill_density and line_width.
         See also ellipse
      There is also a function wxpiechart for creating embedded histograms in interfaces
      wxMaxima and iMaxima.
      Example:
            (%i1) load ("descriptive")$
            (%i2) s1 : read_list (file_search ("pidigits.data"))$
            (%i3) piechart(
                    s1,
                    xrange = [-1.1, 1.3],
                    yrange = [-1.1, 1.1],
                    title   = "Digit frequencies in pi")$
      See also function barsplot.
piechart_description ( . . . )                                                [Function]
      Function piechart_description creates a graphic object suitable for creating com-
      plex scenes, together with other graphic objects.
scatterplot                                                                      [Function]
        scatterplot       (list)
        scatterplot       (list, option_1, option_2, . . . )
        scatterplot       (matrix)
        scatterplot       (matrix, option_1, option_2, . . . )
      Plots scatter diagrams both for univariate (list) and multivariate (matrix) samples.
      Available options are the same admitted by histogram.
      There is also a function wxscatterplot for creating embedded histograms in inter-
      faces wxMaxima and iMaxima.
Chapter 50: descriptive                                                                   735
     Examples:
     Univariate scatter diagram from a simulated Gaussian sample.
           (%i1) load ("descriptive")$
           (%i2) load ("distrib")$
           (%i3) scatterplot(
                   random_normal(0,1,200),
                   xaxis      = true,
                   point_size = 2,
                   dimensions = [600,150])$
     Two dimensional scatter plot.
           (%i1) load ("descriptive")$
           (%i2) s2 : read_matrix (file_search ("wind.data"))$
           (%i3) scatterplot(
                  submatrix(s2, 1,2,3),
                  title       = "Data from stations #4 and #5",
                  point_type = diamant,
                  point_size = 2,
                  color       = blue)$
     Three dimensional scatter plot.
           (%i1) load ("descriptive")$
           (%i2) s2 : read_matrix (file_search ("wind.data"))$
           (%i3) scatterplot(submatrix (s2, 1,2), nclasses=4)$
     Five dimensional scatter plot, with five classes histograms.
           (%i1) load ("descriptive")$
           (%i2) s2 : read_matrix (file_search ("wind.data"))$
           (%i3) scatterplot(
                   s2,
                   nclasses     = 5,
                   frequency    = relative,
                   fill_color   = blue,
                   fill_density = 0.3,
                   xtics        = 5)$
     For plotting isolated or line-joined points in two and three dimensions, see points.
     See also histogram.
scatterplot_description ( . . . )                                         [Function]
     Function scatterplot_description creates a graphic object suitable for creating
     complex scenes, together with other graphic objects.
       • stars colors (default, []): a list of colors for multiple samples. When there
         are more samples than specified colors, the extra necessary colors are chosen at
         random. See color to learn more about them.
       • frequency (default, absolute): indicates the scale of the radii. Possible values
         are: absolute and relative.
       • ordering (default, orderlessp): possible values are orderlessp or ordergreatp,
         indicating how statistical outcomes should be ordered.
       • sample keys (default, []): a list with the strings to be used in the legend. When
         the list length is other than 0 or the number of samples, an error message is
         returned.
       • star center (default, [0,0]): diagram’s center.
       • star radius (default, 1): diagram’s radius.
       • All global draw options, except points_joined, point_type, and key, which
         are internally assigned by starplot. If you want to set your own values for this
         options or want to build complex scenes, make use of starplot_description.
       • The following local draw option: line_width.
      There is also a function wxstarplot for creating embedded histograms in interfaces
      wxMaxima and iMaxima.
      Example:
      Plot based on absolute frequencies. Location and radius defined by the user.
            (%i1) load ("descriptive")$
            (%i2) l1: makelist(random(10),k,1,50)$
            (%i3) l2: makelist(random(10),k,1,200)$
            (%i4) starplot(
                      l1, l2,
                      stars_colors = [blue,red],
                      sample_keys = ["1st sample", "2nd sample"],
                      star_center = [1,2],
                      star_radius = 4,
                      proportional_axes = xy,
                      line_width = 2 ) $
starplot_description ( . . . )                                                [Function]
      Function starplot_description creates a graphic object suitable for creating com-
      plex scenes, together with other graphic objects.
stemplot                                                                          [Function]
        stemplot (data)
        stemplot (data, option)
      Plots stem and leaf diagrams.
      Unique available option is:
        • leaf unit (default, 1): indicates the unit of the leaves; must be a power of 10.
      Example:
          (%i1) load ("descriptive")$
Chapter 50: descriptive                         737
           (%i2) load(distrib)$
           (%i3) stemplot(
                   random_normal(15, 6, 100),
                   leaf_unit = 0.1);
           -5|4
            0|37
            1|7
            3|6
            4|4
            5|4
            6|57
            7|0149
            8|3
            9|1334588
           10|07888
           11|01144467789
           12|12566889
           13|24778
           14|047
           15|223458
           16|4
           17|11557
           18|000247
           19|4467799
           20|00
           21|1
           22|2335
           23|01457
           24|12356
           25|455
           27|79
           key: 6|3 = 6.3
           (%o3)                  done
                                                                                       739
51 diag
(%i2) a1:matrix([1,2,3],[0,4,5],[0,0,6])$
(%i3) a2:matrix([1,1],[1,0])$
          (%i4) diag([a1,x,a2]);
                                   [ 1 2 3 0 0          0 ]
                                   [                      ]
                                   [ 0 4 5 0 0          0 ]
                                   [                      ]
                                   [ 0 0 6 0 0          0 ]
          (%o4)                    [                      ]
                                   [ 0 0 0 x 0          0 ]
                                   [                      ]
                                   [ 0 0 0 0 1          1 ]
                                   [                      ]
                                   [ 0 0 0 0 1          0 ]
          (%i5) diag ([matrix([1,2]), 3]);
                                         [ 1 2 0 ]
          (%o5)                          [          ]
                                         [ 0 0 3 ]
     To use this function write first load("diag").
JF (lambda,n)                                                                   [Function]
     Returns the Jordan cell of order n with eigenvalue lambda.
     Example:
          (%i1) load("diag")$
            (%i2) JF(2,5);
                                   [ 2   1   0   0   0 ]
                                   [                   ]
                                   [ 0   2   1   0   0 ]
                                   [                   ]
            (%o2)                  [ 0   0   2   1   0 ]
                                   [                   ]
740                                                                    Maxima 5.45.0 Manual
                                     [ 0   0     0   2     1 ]
                                     [                       ]
                                     [ 0   0     0   0     2 ]
            (%i3) JF(3,2);
                                           [ 3       1 ]
            (%o3)                          [           ]
                                           [ 0       3 ]
      To use this function write first load("diag").
                                  [                                               ]
                                  [ 0       0       0       0       0   0   2   0 ]
                                  [                                               ]
                                  [ 0       0       0       0       0   0   0   3 ]
     To use this function write first load("diag"). See also dispJordan and minimalPoly.
           (%i2) b1:matrix([0,0,1,1,1],
                           [0,0,0,1,1],
                           [0,0,0,0,1],
                           [0,0,0,0,0],
                           [0,0,0,0,0])$
           (%i3) jordan(b1);
           (%o3)                          [[0, 3, 2]]
           (%i4) dispJordan(%);
                               [      0     1       0       0       0 ]
                               [                                      ]
                               [      0     0       1       0       0 ]
                               [                                      ]
           (%o4)               [        0       0       0       0   0 ]
                               [                                      ]
                               [      0     0       0       0       1 ]
                               [                                      ]
                               [      0     0       0       0       0 ]
     To use this function write first load("diag"). See also jordan and minimalPoly.
           (%i2) a:matrix([2,1,2,0],
                          [-2,2,1,2],
                          [-2,-1,-1,1],
                          [3,1,2,-1])$
           (%i3) jordan(a);
742                                                                Maxima 5.45.0 Manual
Example 2:
     Comparison with the Taylor series for the exponential and also comparing exp(%i*A)
     with sine and cosine.
           (%i1) load("diag")$
           (%i2) A: matrix ([0,1,1,1],
                            [0,0,0,1],
                            [0,0,0,1],
                            [0,0,0,0])$
           (%i3) ratsimp (mat_function (exp, t*A));
                                  [           2       ]
                                  [ 1 t t t + t ]
                                  [                   ]
           (%o3)                  [ 0 1 0       t      ]
                                  [                   ]
                                  [ 0 0 1       t     ]
                                  [                   ]
                                  [ 0 0 0       1     ]
           (%i4) minimalPoly (jordan (A));
                                            3
           (%o4)                           x
           (%i5) ratsimp (ident(4) + t*A + 1/2*(t^2)*A^^2);
                                  [           2       ]
                                  [ 1 t t t + t ]
                                  [                   ]
           (%o5)                  [ 0 1 0       t      ]
                                  [                   ]
                                  [ 0 0 1       t     ]
                                  [                   ]
                                  [ 0 0 0       1     ]
           (%i6) ratsimp (mat_function (exp, %i*t*A));
                             [                           2 ]
                             [ 1 %i t %i t %i t - t ]
                             [                             ]
           (%o6)             [ 0    1    0        %i t     ]
                             [                             ]
                             [ 0    0    1        %i t     ]
                             [                             ]
                             [ 0    0    0          1      ]
744                                                      Maxima 5.45.0 Manual
52 distrib
which is a positive real number. The square root of the variance is the standard deviation,
D[X] = sqrt(V [X]), and it is another measure of variation.
  The skewness coefficient is a measure of non-symmetry,
                                      R∞                                 3
                                          −∞   f (x) (x − E [X]) dx
                           SK [X] =                             3
                                                        D [X]
   The mean, variance, standard deviation, skewness coefficient and kurtosis coefficient take
the form                                   X
                                  E [X] =     xi f (xi ),
                                                   xi
746                                                                               Maxima 5.45.0 Manual
                                                                       2
                                      X
                            V [X] =             f (xi ) (xi − E [X]) ,
                                       xi
                                                    q
                                    D [X] =           V [X],
                                                                       3
                                                f (x) (x − E [X]) dx
                                      P
                                           xi
                         SK [X] =                              3
                                                      D [X]
and
                                                                   4
                                           f (x) (x − E [X]) dx
                                  P
                                      xi
                       KU [X] =                            4               − 3,
                                                   D [X]
 respectively.
    There is a naming convention in package distrib. Every function name has two parts,
the first one makes reference to the function or parameter we want to calculate,
       Functions:
           Density function                  (pdf_*)
           Distribution function             (cdf_*)
           Quantile                          (quantile_*)
           Mean                              (mean_*)
           Variance                          (var_*)
           Standard deviation                (std_*)
           Skewness coefficient              (skewness_*)
           Kurtosis coefficient              (kurtosis_*)
           Random variate                    (random_*)
    The second part is an explicit reference to the probabilistic model,
       Continuous distributions:
           Normal                  (*normal)
           Student                 (*student_t)
           Chi^2                   (*chi2)
           Noncentral Chi^2        (*noncentral_chi2)
           F                       (*f)
           Exponential             (*exp)
           Lognormal               (*lognormal)
           Gamma                   (*gamma)
           Beta                    (*beta)
           Continuous uniform (*continuous_uniform)
           Logistic                (*logistic)
           Pareto                  (*pareto)
           Weibull                 (*weibull)
           Rayleigh                (*rayleigh)
           Laplace                 (*laplace)
Chapter 52: distrib                                                                     747
         Cauchy                  (*cauchy)
         Gumbel                  (*gumbel)
       Discrete distributions:
          Binomial                 (*binomial)
          Poisson                  (*poisson)
          Bernoulli                (*bernoulli)
          Geometric                (*geometric)
          Discrete uniform         (*discrete_uniform)
          hypergeometric           (*hypergeometric)
          Negative binomial        (*negative_binomial)
          Finite discrete          (*general_finite_discrete)
    For example, pdf_student_t(x,n) is the density function of the Student distribution
with n degrees of freedom, std_pareto(a,b) is the standard deviation of the Pareto dis-
tribution with parameters a and b and kurtosis_poisson(m) is the kurtosis coefficient of
the Poisson distribution with mean m.
    In order to make use of package distrib you need first to load it by typing
       (%i1) load("distrib")$
    For comments, bugs or suggestions, please contact the author at ’riotorto AT yahoo
DOT com’.
            (%i2) expand(pdf_noncentral_student_t(3,5,0.1));
                                        7/2                         7/2
                  0.04296414417400905 5       1.323650307289301e-6 5
            (%o2) ------------------------ + -------------------------
                     3/2   5/2                        sqrt(%pi)
                    2    14     sqrt(%pi)
                                                                     7/2
                                                1.94793720435093e-4 5
                                              + ------------------------
                                                          %pi
            (%i3) float(%);
            (%o3)           .02080593159405669
                                                           3
            (%o2)      1 - gamma_incomplete_regularized(2, -)
                                                           2
            (%i3) float(%);
            (%o3)               .4421745996289256
                                             nX
                                       F =
                                             mY
            (%i2) quantile_rayleigh(0.99,b);
                                    2.145966026289347
            (%o2)                   -----------------
                                            b
           (%o2)                      --------------------
                                               %pi 3/2
                                          (1 - ---)
                                                4
kurtosis_rayleigh (b)                                                          [Function]
     Returns the kurtosis coefficient of a Rayleigh(b) random variable, with b > 0.
     The Rayleigh(b) random variable is equivalent to the W eibull(2, 1/b).
          (%i1) load ("distrib")$
          (%i2) kurtosis_rayleigh(b);
                                                    2
                                               3 %pi
                                           2 - ------
                                                 16
          (%o2)                            ---------- - 3
                                                %pi 2
                                           (1 - ---)
                                                 4
random_rayleigh (b)                                                              [Function]
        random_rayleigh (b,n)
     Returns a Rayleigh(b) random variate, with b > 0. Calling random_rayleigh with a
     second argument n, a random sample of size n will be simulated.
     The implemented algorithm is based on the general inverse method.
     To make use of this function, write first load("distrib").
pdf_laplace (x,a,b)                                                          [Function]
     Returns the value at x of the density function of a Laplace(a, b) random variable,
     with b > 0. To make use of this function, write first load("distrib").
cdf_laplace (x,a,b)                                                              [Function]
     Returns the value at x of the distribution function of a Laplace(a, b) random variable,
     with b > 0. To make use of this function, write first load("distrib").
quantile_laplace (q,a,b)                                                         [Function]
     Returns the q-quantile of a Laplace(a, b) random variable, with b > 0; in other words,
     this is the inverse of cdf_laplace. Argument q must be an element of [0, 1]. To make
     use of this function, write first load("distrib").
mean_laplace (a,b)                                                        [Function]
     Returns the mean of a Laplace(a, b) random variable, with b > 0. To make use of
     this function, write first load("distrib").
var_laplace (a,b)                                                             [Function]
     Returns the variance of a Laplace(a, b) random variable, with b > 0. To make use of
     this function, write first load("distrib").
std_laplace (a,b)                                                            [Function]
     Returns the standard deviation of a Laplace(a, b) random variable, with b > 0. To
     make use of this function, write first load("distrib").
766                                                                 Maxima 5.45.0 Manual
            (%o2)                           -
                                            7
            (%i3) pdf_general_finite_discrete(2, [1, 4, 2]);
                                            4
            (%o3)                           -
                                            7
cdf_general_finite_discrete (x,v)                                                   [Function]
      Returns the value at x of the distribution function of a general finite discrete random
      variable, with vector probabilities v.
      See pdf_general_finite_discrete for more details.
            (%i1) load ("distrib")$
            (%i2) cdf_general_finite_discrete(2, [1/7, 4/7, 2/7]);
                                                    5
            (%o2)                                   -
                                                    7
            (%i3) cdf_general_finite_discrete(2, [1, 4, 2]);
                                                    5
            (%o3)                                   -
                                                    7
            (%i4) cdf_general_finite_discrete(2+1/2, [1, 4, 2]);
                                                    5
            (%o4)                                   -
                                                    7
quantile_general_finite_discrete (q,v)                                            [Function]
      Returns the q-quantile of a general finite discrete random variable, with vector prob-
      abilities v.
      See pdf_general_finite_discrete for more details.
mean_general_finite_discrete (v)                                                   [Function]
      Returns the mean of a general finite discrete random variable, with vector probabilities
      v.
      See pdf_general_finite_discrete for more details.
var_general_finite_discrete (v)                                                  [Function]
      Returns the variance of a general finite discrete random variable, with vector proba-
      bilities v.
      See pdf_general_finite_discrete for more details.
std_general_finite_discrete (v)                                              [Function]
      Returns the standard deviation of a general finite discrete random variable, with
      vector probabilities v.
      See pdf_general_finite_discrete for more details.
skewness_general_finite_discrete (v)                                           [Function]
      Returns the skewness coefficient of a general finite discrete random variable, with
      vector probabilities v.
      See pdf_general_finite_discrete for more details.
Chapter 52: distrib                                                                    769
53 draw
   Each scene can contain any number of objects and key=value pairs with options for the
scene or the following objects.
   A selection of useful objects a scene can be made up from are:
 • explicit plots a function.
 • implicit plots all points an equation is true at.
 • points plots points that are connected by lines if the option points_joined was set
   to true in a previous line of the current scene.
 • parametric allows to specify separate expressions that calculate the x, y (and in 3d
   plots also for the z) variable.
   A short description of all draw commands and options including example plots (in the
html and pdf version of this manual) can be found in the section See Section 53.2 [Functions
and Variables for draw], page 780. An online version of the html manual can be found at
https://maxima.sourceforge.io/docs/manual/maxima_singlepage.html#draw. More
elaborated examples of this package can be found at the following locations:
   http://riotorto.users.sourceforge.net/Maxima/gnuplot/
http://riotorto.users.sourceforge.net/Maxima/vtk/
   Example:
      (%i1) draw2d(
                title="Two simple plots",
                xlabel="x",ylabel="y",grid=true,
                  color=red,key="A sinus",
                  explicit(sin(x),x,1,10),
                  color=blue,line_type=dots,key="A cosinus",
                  explicit(cos(x),x,1,10)
      )$
780                                                                               Maxima 5.45.0 Manual
0.4
0.2
                      0
                y
-0.2
-0.4
-0.6
-0.8
                     -1
                           1   2   3   4      5       6       7      8        9     10
                                                  x
   You need Gnuplot 4.2 or newer to run draw; If you are using wxMaxima as a front end
wxdraw, wxdraw2d and wxdraw3d are drop-in replacements for draw that do the same as
draw, draw2d and draw3d but embed the resulting plot in the worksheet.
   If you want to use VTK with draw, you need VTK with the Python interface installed
(the Chapter 55 [dynamics-pkg], page 901, uses VTK with the TCL interface!) and set the
variable:
   draw_renderer: 'vtk $
                    explicit(
                        cos(x),
                        x,0,2*%pi
                    )
               )
            );
           (%o1)               [gr2d(explicit), gr2d(explicit)]
                     1
                                                              sin (x)
                    0.5
-0.5
                     -1
                          0    1       2       3       4       5        6
                     1
                                                              cos (x)
                    0.5
-0.5
                     -1
                          0    1       2       3       4       5        6
53.2.2 Functions
draw (<arg_1>, ...)                                                             [Function]
     Plots a series of scenes; its arguments are gr2d and/or gr3d objects, together with
     some options, or lists of scenes and options. By default, the scenes are put together
     in one column.
     Besides scenes the function draw accepts the following global options: terminal,
     columns, dimensions, file_name and delay.
     Functions draw2d and draw3d short cuts that can be used when only one scene is
     required, in two or three dimensions, respectively.
     See also gr2d and gr3d.
782                                                                                           Maxima 5.45.0 Manual
      Examples:
          (%i1) scene1: gr2d(title="Ellipse",
                             nticks=300,
                             parametric(2*cos(t),5*sin(t),t,0,2*%pi))$
          (%i2) scene2: gr2d(title="Triangle",
                             polygon([4,5,7],[6,4,2]))$
          (%i3) draw(scene1, scene2, columns = 2)$
                                    Ellipse                                        Triangle
                    5                                           6
                    4
                                                               5.5
                    3
                                                                5
                    2
                                                               4.5
                    1
0 4
                    -1
                                                               3.5
                    -2
                                                                3
                    -3
                                                               2.5
                    -4
                    -5                                          2
                         -2 -1.5 -1 -0.5 0 0.5 1 1.5 2               4   4.5   5     5.5      6   6.5   7
                                                          A sinus
                         1
0.5
-0.5
                         -1
                              0      1         2           3             4            5             6
                                                         A cosinus
                         1
0.5
-0.5
                         -1
                              0      1         2           3             4            5             6
           (%i1) draw(gr3d(explicit(x^2+y^2,x,-1,1,y,-1,1)));
           (%o1)                           [gr3d(explicit)]
           (%i2) draw3d(explicit(x^2+y^2,x,-1,1,y,-1,1));
           (%o2)                           [gr3d(explicit)]
     Creating an animated gif file:
           (%i1) draw(
                    delay        = 100,
                    file_name = "zzz",
                    terminal = 'animated_gif,
                    gr2d(explicit(x^2,x,-1,1)),
                    gr2d(explicit(x^3,x,-1,1)),
                    gr2d(explicit(x^4,x,-1,1)));
           End of animation sequence
           (%o1)           [gr2d(explicit), gr2d(explicit), gr2d(explicit)]
                       2
                      1.5
                       1
                      0.5
                       0
                                                                           1
                                                                     0.5
                        -1                                       0
                              -0.5
                                      0                   -0.5
                                            0.5
                                                   1 -1
                  draw(gr3d(explicit(x^2+y^2,x,-1,1,y,-1,1)))$
            (%i2) /* same plot in eps format */
                  draw_file(terminal = eps,
                            dimensions = [5,5]) $
0.8
0.6 0.5
                                          Y
                        0.4                    -0.5
                                                -1
                                                      -1   -0.5   0     0.5      1
                        0.2                                       X
                         0
                              -1              -0.5                0                  0.5                 1
                                                                  X
                          2
                        1.5
                    Z     1
                        0.5
                          0
                                                                                                     1
                                                                                           0.5
                          -1                                                         0           Y
                                   -0.5                                       -0.5
                                              X 0          0.5
                                                                      1 -1
                          1
                        0.8
                        0.6
                        0.4
                   Y
                        0.2
                          0
                              -1              -0.5                0                  0.5                 1
                                                                  X
     Example:
           (%i1) draw3d(axis_3d = false,
                        explicit(sin(x^2+y^2),x,-2,2,y,-2,2) )$
                          1
                        0.8
                        0.6
                        0.4
                        0.2
                          0
                       -0.2
                       -0.4
                       -0.6
                       -0.8
                         -1
                                                                                                            2
                                                                                                      1.5
                                                                                                  1
                                                                                            0.5
                                -2 -1.5                                                 0
                                        -1 -0.5                                  -0.5
                                                   0                           -1
                                                       0.5   1             -1.5
                                                                 1.5   2 -2
See also axis_bottom, axis_left, axis_top, and axis_right for axis in 2d.
0.5
-0.5
                     -1
                           -1               -0.5                 0                 0.5                          1
Example:
4.5
3.5
2.5
                    2
                         3   4        5       6       7       8        9
     A list with two possible elements, true and false, indicating whether the extremes
     of a graphic object tube remain closed or open. By default, both extremes are left
     open.
Example:
          (%i1) draw3d(
                  capping = [false, true],
                  tube(0, 0, a, 1,
                       a, 0, 8) )$
790                                                                                             Maxima 5.45.0 Manual
                         8
                         7
                         6
                         5
                         4
                         3
                         2
                         1
                         0
                                                                                                      1
                                                                                     0.8
                                                                                   0.6
                                                                                 0.4
                                                                               0.2
                             -0.8-0.6                                         0
                                     -0.4-0.2                             -0.2
                                              0 0.2                     -0.4
                                                    0.4 0.6          -0.6
                                                                   -0.8
                                                            0.8 1 -1
                                                                                                          10
                                                                                                          8
                         8
                         7                                                                                6
                         6                                                                                4
                         5                                                                                2
                         4
                         3                                                                                0
                         2                                                                                -2
                         1
                         0
                                                                                                      2
                                                                                                1.5
                                                                                            1
                                                                                      0.5
                         -2 -1.5                                                  0
                                 -1 -0.5                                   -0.5
                                             0                           -1
                                                 0.5   1             -1.5
                                                           1.5   2 -2
Chapter 53: draw                                                                                                 791
                                                                                                        High
                        8
                        7
                        6                                                                               Medium
                        5
                        4
                        3
                        2
                        1                                                                               Low
                        0
                                                                                                    2
                                                                                              1.5
                                                                                          1
                                                                                    0.5
                         -2 -1.5                                                0
                                 -1 -0.5                                 -0.5
                                           0                           -1
                                               0.5   1             -1.5
                                                         1.5   2 -2
2.5
1.5
                                            This is a label
                    1
0.5
                    0
                         -1          -0.5         0           0.5        1
           (%i1) draw2d(
                        line_width=50,
                        color="#FF0000",
                        explicit(sin(x),x,0,10),
Chapter 53: draw                                                        793
                                   color="#0000FF80",
                                   explicit(cos(x),x,0,10)
                   );
0.8
0.6
0.4
0.2
                          0
                   Y
-0.2
-0.4
-0.6
-0.8
                         -1
                               0         2       4       6   8   10
                                                     X
                               3
                                  H=5A/M
                                 H=10A/M
                                 H=15A/M
                               2 H=20A/M
                                 H=25A/M
-1
-2
                               -3
                                    -3         -2   -1     0   1     2         3
           (%i1) draw2d(
                   "figures/draw_color4",
                   makelist(
                       [
                           color=i,
                           key=sconcat("color =",i),
                           explicit(sin(i*x),x,0,1)
                       ],
                       i,0,17
                   )
               )$
                      1
                                                                          color =0
                    0.8                                                   color =1
                                                                          color =2
                    0.6                                                   color =3
                                                                          color =4
                                                                          color =5
                    0.4
                                                                          color =6
                                                                          color =7
                    0.2                                                   color =8
                                                                          color =9
                      0                                                  color =10
                                                                         color =11
                    -0.2                                                 color =12
                                                                         color =13
                    -0.4                                                 color =14
                                                                         color =15
                    -0.6                                                 color =16
                                                                         color =17
                    -0.8
                     -1
                           0             0.2         0.4       0.6          0.8         1
     If colorbox is true, a color scale without label is drawn together with image 2D
     objects, or coloured 3d objects. If colorbox is false, no color scale is shown. If
     colorbox is a string, a color scale with label is drawn.
     Since this is a global graphics option, its position in the scene description does not
     matter.
Example:
                   30                                                       200
                                                                            180
                   25                                                       160
                   20                                                       140
                                                                            120
                   15                                                       100
                                                                            80
                   10                                                       60
                    5                                                       40
                                                                            20
                    0                                                       0
                        0   5       10        15        20        25   30
                   30
                   25
                   20
                   15
                   10
                    5
                    0
                        0       5        10        15        20        25     30
           (%i1) draw3d(
                   colorbox   = "Magnitude",
                   enhanced3d = true,
                   explicit(x^2+y^2,x,-1,1,y,-1,1))$
796                                                                                           Maxima 5.45.0 Manual
                                                                                                        2
                          2                                                                             1.5
                                                                                                              Magnitude
                         1.5                                                                            1
                          1
                                                                                                        0.5
                         0.5
                                                                                                        0
                          0
                                                                                                  1
                                                                                           0.5
                           -1                                                       0
                                  -0.5
                                            0                              -0.5
                                                      0.5
                                                                  1 -1
                                  Ellipse                                          Triangle
                     5                                       6
                     4
                                                            5.5
                     3
                                                             5
                     2
                                                            4.5
                     1
0 4
                    -1
                                                            3.5
                    -2
                                                             3
                    -3
                                                            2.5
                    -4
                    -5                                       2
                         -1.5 -1 -0.5 0 0.5 1 1.5 2               4      4.5   5     5.5      6   6.5   7
     Option contour enables the user to select where to plot contour lines. Possible values
     are:
• both: two contour lines are plotted: on the xy plane and on the surface.
       • map: contour lines are projected on the xy plane, and the view point is set just
         in the vertical.
     Since this is a global graphics option, its position in the scene description does not
     matter.
Example:
           (%i1) draw3d(explicit(20*exp(-x^2-y^2)-10,x,0,2,y,-3,3),
                        contour_levels = 15,
                        contour        = both,
                        surface_hide   = true) $
                                                                      10
                                                                       8
                                                                       6
                                                                       4
                                                                       2
                       10                                              0
                        8                                             -2
                        6
                        4                                             -4
                        2
                        0                                             -6
                       -2                                             -8
                       -4
                       -6
                       -8
                      -10
                                                                                   3
                                                                               2
                                                                           1
                            0                                          0
                                0.5                              -1
                                      1                     -2
                                               1.5
                                                     2 -3
           (%i1) draw3d(explicit(20*exp(-x^2-y^2)-10,x,0,2,y,-3,3),
                        contour_levels = 15,
                        contour        = map
                 ) $
798                                                                   Maxima 5.45.0 Manual
                        3
                                                                 10
                                                                  8
                        2                                         6
                                                                  4
                        1                                         2
                                                                  0
                                                                 -2
                        0                                        -4
                                                                 -6
                                                                 -8
                       -1
-2
                       -3
                            0       0.5         1          1.5          2
                           explicit(20*exp(-x^2-y^2)-10,x,0,2,y,-3,3),
                           contour_levels = {-7, -6, 0.8, 5},
                           contour        = both,
                           surface_hide   = true) $
     See also contour.
data_file_name                                                             [Graphic option]
     Default value: "data.gnuplot"
     This is the name of the file with the numeric data needed by Gnuplot to build the
     requested plot.
     Since this is a global graphics option, its position in the scene description does not
     matter. It can be also used as an argument of function draw.
     See example in gnuplot_file_name.
delay                                                                      [Graphic option]
     Default value: 5
     This is the delay in 1/100 seconds of frames in animated gif files.
     Since this is a global graphics option, its position in the scene description does not
     matter. It can be also used as an argument of function draw.
     Example:
           (%i1) draw(
                     delay       = 100,
                     file_name = "zzz",
                     terminal = 'animated_gif,
                     gr2d(explicit(x^2,x,-1,1)),
                     gr2d(explicit(x^3,x,-1,1)),
                     gr2d(explicit(x^4,x,-1,1)));
           End of animation sequence
           (%o2)              [gr2d(explicit), gr2d(explicit), gr2d(explicit)]
     Option delay is only active in animated gif’s; it is ignored in any other case.
     See also terminal, and dimensions.
dimensions                                                                [Graphic option]
     Default value: [600,500]
     Dimensions of the output terminal. Its value is a list formed by the width and the
     height. The meaning of the two numbers depends on the terminal you are working
     with.
     With terminals gif, animated_gif, png, jpg, svg, screen, wxt, and aquaterm, the
     integers represent the number of points in each direction. If they are not integers,
     they are rounded.
     With terminals eps, eps_color, pdf, and pdfcairo, both numbers represent hun-
     dredths of cm, which means that, by default, pictures in these formats are 6 cm in
     width and 5 cm in height.
     Since this is a global graphics option, its position in the scene description does not
     matter. It can be also used as an argument of function draw.
800                                                                 Maxima 5.45.0 Manual
      Examples:
      Option dimensions applied to file output and to wxt canvas.
            (%i1) draw2d(
                    dimensions = [300,300],
                    terminal   = 'png,
                    explicit(x^4,x,-1,1)) $
            (%i2) draw2d(
                    dimensions = [300,300],
                    terminal   = 'wxt,
                    explicit(x^4,x,-1,1)) $
      Option dimensions applied to eps output. We want an eps file with A4 portrait
      dimensions.
            (%i1) A4portrait: 100*[21, 29.7]$
            (%i2) draw3d(
                    dimensions = A4portrait,
                    terminal   = 'eps,
                    explicit(x^2-y^2,x,-2,2,y,-2,2)) $
     on the [x,y] coordinates, [f(x,y), x, y]. 3D graphic object implicit accepts only
     the [f(x,y,z), x, y, z] model. Object points accepts also the [f(x,y,z), x, y,
     z] model, but when points have a chronological nature, model [f(k), k] is also valid,
     being k an ordering parameter.
     The names of the variables defined in the lists may be different to those used in the
     definitions of the graphic objects.
Examples:
           (%i1) draw3d(
                    enhanced3d = [x-z/10,x,y,z],
                    palette    = gray,
                    explicit(20*exp(-x^2-y^2)-10,x,-3,3,y,-3,3))$
                                                                                      4
                                                                                      3
                       10                                                             2
                        8
                        6                                                             1
                        4
                        2                                                             0
                        0                                                             -1
                       -2
                       -4                                                             -2
                       -6                                                             -3
                       -8
                      -10
                                                                                  3
                                                                              2
                                                                          1
                         -3                                           0
                              -2                                 -1
                                   -1
                                        0                   -2
                                            1
                                                2
                                                     3 -3
     explicit object with coloring defined by the [f(x,y), x, y] model. The names of
     the variables defined in the lists may be different to those used in the definitions of
     the graphic objects; in this case, r corresponds to x, and s to y.
           (%i1) draw3d(
                    enhanced3d = [sin(r*s),r,s],
                    explicit(20*exp(-x^2-y^2)-10,x,-3,3,y,-3,3))$
802                                                                                       Maxima 5.45.0 Manual
                                                                                                  1
                                                                                                  0.8
                       10                                                                         0.6
                        8                                                                         0.4
                        6                                                                         0.2
                        4                                                                         0
                        2                                                                         -0.2
                        0                                                                         -0.4
                       -2                                                                         -0.6
                       -4                                                                         -0.8
                       -6                                                                         -1
                       -8
                      -10
                                                                                              3
                                                                                          2
                                                                                      1
                        -3                                                        0
                                 -2                                          -1
                                        -1
                                              0                         -2
                                                     1
                                                           2
                                                                 3 -3
           (%i1) draw3d(
                    nticks = 100,
                    line_width = 2,
                    enhanced3d = [if y>= 0 then 1 else 0, x, y, z],
                    parametric(sin(u)^2,cos(u),u,u,0,4*%pi)) $
                                                                                                  1
                                                                                                  0.8
                      12
                      10                                                                          0.6
                       8                                                                          0.4
                       6
                       4                                                                          0.2
                       2                                                                          0
                       0
                                                                                              1
                                                                                       0.8
                                                                                     0.6
                                                                                   0.4
                            0 0.1                                                0.2
                                                                                0
                                  0.2 0.3                                   -0.2
                                          0.4 0.5                         -0.4
                                                  0.6 0.7              -0.6
                                                          0.8 0.9    -0.8
                                                                  1 -1
      parametric object with coloring defined by the [f(u), u] model. In this case,
      (u-1)^2 is a shortcut for [(u-1)^2,u].
           (%i1) draw3d(
                    nticks = 60,
                    line_width = 3,
                    enhanced3d = (u-1)^2,
                    parametric(cos(5*u)^2,sin(7*u),u-2,u,0,2))$
Chapter 53: draw                                                                                       803
                                                                                                1
                                                                                                0.9
                        0                                                                       0.8
                     -0.2                                                                       0.7
                     -0.4                                                                       0.6
                     -0.6                                                                       0.5
                     -0.8                                                                       0.4
                       -1                                                                       0.3
                     -1.2                                                                       0.2
                     -1.4                                                                       0.1
                     -1.6                                                                       0
                     -1.8
                       -2
                                                                                            1
                                                                                      0.8
                                                                                    0.6
                                                                                  0.4
                                                                                0.2
                             0.1 0.2                                           0
                                     0.3 0.4                               -0.2
                                             0.5 0.6                     -0.4
                                                     0.7 0.8          -0.6
                                                                    -0.8
                                                             0.9 1 -1
                                                                                                1
                                                                                                0.8
                        1                                                                       0.6
                      0.8                                                                       0.4
                      0.6                                                                       0.2
                      0.4                                                                       0
                      0.2                                                                       -0.2
                        0                                                                       -0.4
                     -0.2                                                                       -0.6
                     -0.4                                                                       -0.8
                     -0.6                                                                       -1
                     -0.8
                       -1
                                                                                            1
                                                                                  0.5
                        -1                                                    0
                                  -0.5                                                  y
                                             0                         -0.5
                                         x            0.5
                                                                1 -1
                                                                                               1
                                                                                               0.8
                        1                                                                      0.6
                      0.8                                                                      0.4
                      0.6                                                                      0.2
                      0.4                                                                      0
                      0.2                                                                      -0.2
                        0                                                                      -0.4
                     -0.2                                                                      -0.6
                     -0.4                                                                      -0.8
                     -0.6                                                                      -1
                     -0.8
                                                                                          12
                                                                                     10
                                                                                 8
                            -1.5 -1                                          6
                                    -0.5                                4
                                           0   0.5                 2
                                                     1   1.5   0
      tube object with coloring defined by the [f(u), u] model. Here, enhanced3d = -a
      would be the shortcut for enhanced3d = [-foo,foo].
           (%i1) draw3d(
                    capping = [true, false],
                    palette = [26,15,-2],
                    enhanced3d = [-foo, foo],
                    tube(a, a, a^2, 1, a, -2, 2) )$
                                                                                               2
                                                                                               1.5
                        4                                                                      1
                                                                                               0.5
                        3                                                                      0
                        2                                                                      -0.5
                        1                                                                      -1
                                                                                               -1.5
                        0                                                                      -2
                       -1
                                                                                      2
                                                                                 1
                              -2                                             0
                                   -1                                   -1
                                           0                       -2
                                                 1
                                                         2
           (%i1) draw3d(
                    enhanced3d = [x-y,x,y,z],
                    implicit((x^2+y^2+z^2-1)*(x^2+(y-1.5)^2+z^2-0.5)=0.015,
                             x,-1,1,y,-1.2,2.3,z,-1,1)) $
           (%i2) m: makelist([random(1.0),random(1.0),random(1.0)],k,1,2000)$
Chapter 53: draw                                                                                                    805
                                                                                                             1.5
                                                                                                             1
                       1                                                                                     0.5
                                                                                                             0
                      0.5                                                                                    -0.5
                                                                                                             -1
                       0
                                                                                                             -1.5
                     -0.5                                                                                    -2
                                                                                                             -2.5
                       -1
                                                                                                     2
                                                                                               1.5
                                                                                           1
                        -1                                                           0.5
                                    -0.5                                         0
                                              0                           -0.5
                                                       0.5           -1
                                                                 1
          (%i3) draw3d(
                   point_type = filled_circle,
                   point_size = 2,
                   enhanced3d = [u+v-w,u,v,w],
                   points(m) ) $
                                                                                                             2
                                                                                                             1.5
                        1
                      0.9                                                                                    1
                      0.8
                      0.7                                                                                    0.5
                      0.6
                      0.5                                                                                    0
                      0.4                                                                                    -0.5
                      0.3
                      0.2                                                                                    -1
                      0.1
                        0
                                                                                                         1
                                                                                        0.9
                                                                                      0.8
                                                                                    0.7
                            0 0.1                                                 0.6
                                                                                0.5
                                  0.2 0.3                                     0.4
                                          0.4 0.5                           0.3
                                                  0.6 0.7                 0.2
                                                          0.8 0.9       0.1
                                                                  1 0
     When points have a chronological nature, model [f(k), k] is also valid, being k an
     ordering parameter.
                                                                                                     1
                                                                                                     0.8
                           1                                                                         0.6
                         0.9                                                                         0.4
                         0.8                                                                         0.2
                         0.7                                                                         0
                         0.6                                                                         -0.2
                         0.5                                                                         -0.4
                         0.4                                                                         -0.6
                         0.3                                                                         -0.8
                         0.2                                                                         -1
                         0.1
                           0
                                                                                                 1
                                                                                           0.9
                                                                                         0.8
                                                                                       0.7
                               0 0.1                                                 0.6
                                                                                   0.5
                                     0.2 0.3                                     0.4
                                             0.4 0.5                           0.3
                                                     0.6 0.7                 0.2
                                                             0.8 0.9       0.1
                                                                     1 0
     A useful special case is filled_func=0, which generates the region bond by the
     horizontal axis and the explicit function.
Example:
Region bounded by an explicit object and the bottom of the graphic window.
0.8
0.6
0.4
0.2
-0.2
-0.4
-0.6
-0.8
                     -1
                          0     2         4         6           8     10
     Region bounded by an explicit object and the function defined by option filled_
     func. Note that the variable in filled_func must be the same as that used in
     explicit.
0.5
-0.5
                       -1
                             0   0.5     1       1.5      2      2.5      3
Example:
             (%i1) draw2d(
                    file_name = "my_file",
                    gnuplot_file_name = "my_commands_for_gnuplot",
                    data_file_name    = "my_data_for_gnuplot",
                    terminal          = png,
                    explicit(x^2,x,-1,1)) $
       If grid is not false, a grid will be drawn on the xy plane. If grid is assigned true,
       one grid line per tick of each axis is drawn. If grid is assigned a list nx,ny with
       [nx,ny] > [0,0] instead nx lines per tick of the x axis and ny lines per tick of the y
       axis are drawn.
       Since this is a global graphics option, its position in the scene description does not
       matter.
Example:
0.5
-0.5
                     -1
                          0    1       2       3        4     5       6
head_angle indicates the angle, in degrees, between the arrow heads and the segment.
Example:
                    0
                        0        2           4       6           8        10
                    0
                        0    1       2   3       4       5   6       7    8
                   0
                       0     2        4        6        8      10         12
                             head_type = 'nofilled,
                             vector([6,1],[5,5]))$
10
                     0
                         0     2        4        6      8       10        12
      interpolate_color also accepts a list of two numbers, [m,n]. For positive m and
      n, each quadrangle or triangle is interpolated m times and n times in the respective
      direction. For negative m and n, the interpolation frequency is chosen so that there
      will be at least |m| and |n| points drawn; you can consider this as a special grid-
      ding function. Zeros, i.e. interpolate_color=[0,0], will automatically choose an
      optimal number of interpolated surface points.
Examples:
            (%i1) draw3d(
                    enhanced3d   = sin(x*y),
                    explicit(20*exp(-x^2-y^2)-10, x ,-3, 3, y, -3, 3)) $
Chapter 53: draw                                                                        815
                                                                                 1
                                                                                 0.8
                    10                                                           0.6
                     8                                                           0.4
                     6                                                           0.2
                     4                                                           0
                     2                                                           -0.2
                     0                                                           -0.4
                    -2                                                           -0.6
                    -4                                                           -0.8
                    -6                                                           -1
                    -8
                   -10
                                                                             3
                                                                         2
                                                                     1
                     -3                                          0
                          -2                                -1
                               -1
                                    0                  -2
                                        1
                                            2
                                                3 -3
          (%i2) draw3d(
                  interpolate_color = true,
                  enhanced3d   = sin(x*y),
                  explicit(20*exp(-x^2-y^2)-10, x ,-3, 3, y, -3, 3)) $
                                                                                 1
                                                                                 0.8
                    10                                                           0.6
                     8                                                           0.4
                     6                                                           0.2
                     4                                                           0
                     2                                                           -0.2
                     0                                                           -0.4
                    -2                                                           -0.6
                    -4                                                           -0.8
                    -6                                                           -1
                    -8
                   -10
                                                                             3
                                                                         2
                                                                     1
                     -3                                          0
                          -2                                -1
                               -1
                                    0                  -2
                                        1
                                            2
                                                3 -3
          (%i3) draw3d(
                  interpolate_color = [-10,0],
                  enhanced3d   = sin(x*y),
                  explicit(20*exp(-x^2-y^2)-10, x ,-3, 3, y, -3, 3)) $
816                                                                                            Maxima 5.45.0 Manual
                                                                                                         1
                                                                                                         0.8
                        10                                                                               0.6
                         8                                                                               0.4
                         6                                                                               0.2
                         4                                                                               0
                         2                                                                               -0.2
                         0                                                                               -0.4
                        -2                                                                               -0.6
                        -4                                                                               -0.8
                        -6                                                                               -1
                        -8
                       -10
                                                                                                     3
                                                                                               2
                                                                                          1
                         -3                                                       0
                                  -2                                         -1
                                       -1
                                            0                        -2
                                                 1
                                                          2
                                                              3 -3
            (%i1) draw3d(
                    enhanced3d = true,
                    mesh([[1,1,3],   [7,3,1],[12,-2,4],[15,0,5]],
                         [[2,7,8],   [4,3,1],[10,5,8], [12,7,1]],
                         [[-2,11,10],[6,9,5],[6,15,1], [20,15,2]])) $
                                                                                                         10
                                                                                                         9
                        10                                                                               8
                         9                                                                               7
                         8                                                                               6
                         7                                                                               5
                         6                                                                               4
                         5                                                                               3
                         4                                                                               2
                         3
                         2                                                                               1
                         1
                                                                                                    14
                                                                                               12
                                                                                          10
                                                                                      8
                              0                                                   6
                                       5                                     4
                                            10                           2
                                                     15              0
                                                              20-2
            (%i2) draw3d(
                    enhanced3d        = true,
                    interpolate_color = true,
                    mesh([[1,1,3],   [7,3,1],[12,-2,4],[15,0,5]],
                         [[2,7,8],   [4,3,1],[10,5,8], [12,7,1]],
                         [[-2,11,10],[6,9,5],[6,15,1], [20,15,2]])) $
Chapter 53: draw                                                                                                817
                                                                                                    10
                                                                                                    9
                       10                                                                           8
                        9                                                                           7
                        8                                                                           6
                        7                                                                           5
                        6                                                                           4
                        5                                                                           3
                        4                                                                           2
                        3
                        2                                                                           1
                        1
                                                                                              14
                                                                                         12
                                                                                    10
                                                                                8
                            0                                               6
                                    5                                  4
                                        10                         2
                                              15               0
                                                        20-2
           (%i3) draw3d(
                   enhanced3d        = true,
                   interpolate_color = true,
                   view=map,
                   mesh([[1,1,3],   [7,3,1],[12,-2,4],[15,0,5]],
                        [[2,7,8],   [4,3,1],[10,5,8], [12,7,1]],
                        [[-2,11,10],[6,9,5],[6,15,1], [20,15,2]])) $
                                                                                                     10
                      14
                                                                                                     9
                      12
                                                                                                     8
                      10
                                                                                                     7
                       8
                                                                                                     6
                       6                                                                             5
                       4                                                                             4
                       2                                                                             3
                       0                                                                             2
                       -2                                                                            1
                                0       5          10                  15                      20
                       1
                                                                 Sinus
                     0.8                                       Cosinus
0.6
0.4
0.2
-0.2
-0.4
-0.6
-0.8
                      -1
                            0     2         4          6         8        10
                   explicit(x, x,0,10),
                   color= red,
                   key   = "x squared",
                   explicit(x^2,x,0,10))$
           (%i3) draw3d(
                   key_pos = center,
                   key   = "x",
                   explicit(x+y,x,0,10,y,0,10),
                   color= red,
                   key   = "x squared",
                   explicit(x^2+y^2,x,0,10,y,0,10))$
                   100
                                     x
                             x squared
80
60
40
20
                     0
                         0               2   4         6     8        10
     label_alignment is used to specify where to write labels with respect to the given
     coordinates. Possible values are: center, left, and right.
Example:
10
8 Right alignment
Left alignment
                     0
                         0       2          4                6          8        10
Example:
      In this example, a dummy point is added to get an image. Package draw needs always
      data to draw an scene.
10
                            Vertical orientation
                    6
                    0
                        0                          2          4               6           8   10
     line_type indicates how lines are displayed; possible values are solid and dots, both
     available in all terminals, and dashes, short_dashes, short_long_dashes, short_
     short_long_dashes, and dot_dash, which are not available in png, jpg, and gif
     terminals.
Example:
2.5
1.5
                     1
                          -1      -0.5          0           0.5          1
2.5
1.5
0.5
                     0
                          -1      -0.5          0           0.5          1
100
                                                                                                          10
                         10
                                                                                                          1
                          1
                                                                                                          0.1
                        0.1                                                                               0.01
                                                                                                      2
                                                                                                1.5
                                                                                            1
                                                                                      0.5
                           -2 -1.5                                                0
                                   -1 -0.5                                 -0.5
                                             0                           -1
                                                 0.5   1             -1.5
                                                           1.5   2 -2
                             1                       10                                   100
                     10000
                                                                  x2, linear scale
                      9000                                x2, logarithmic x scale
8000
7000
6000
5000
4000
3000
2000
1000
                         0
                                 10   20   30   40   50     60      70     80        90   100
                                 nticks = 5,
                                 ellipse(0,0,4,2,180,180) )$
1.5
0.5
-0.5
-1
-1.5
                      -2
                            -4    -3    -2     -1   0      1      2    3    4
     n], where color_i is a well formed color (see option color) such that color_1 is
     assigned to the lowest gray level and color_n to the highest. The rest of colors are
     interpolated.
     Since this is a global graphics option, its position in the scene description does not
     matter.
Examples:
           (%i1) draw3d(
                   enhanced3d = [z-x+2*y,x,y,z],
                   palette = [32, -8, 17],
                   explicit(20*exp(-x^2-y^2)-10,x,-3,3,y,-3,3))$
                                                                                     10
                                                                                     5
                       10
                        8                                                            0
                        6
                        4                                                            -5
                        2
                        0                                                            -10
                       -2                                                            -15
                       -4
                       -6                                                            -20
                       -8
                      -10
                                                                                 3
                                                                             2
                                                                         1
                        -3                                           0
                             -2                                 -1
                                  -1
                                       0                   -2
                                           1
                                                2
                                                    3 -3
30 200
                                                                        180
                    25
                                                                        160
                                                                        140
                    20
                                                                        120
15 100
                                                                        80
                    10
                                                                        60
                                                                        40
                     5
                                                                        20
                     0                                                  0
                         0    5      10     15      20     25   30
      palette can be an user defined lookup table. In this example, low values of x are
      colored in red, and higher values in yellow.
            (%i1) draw3d(
                     palette = [red, blue, yellow],
                     enhanced3d = x,
                     explicit(x^2+y^2,x,-1,1,y,-1,1)) $
30 200
                                                                        180
                    25
                                                                        160
                                                                        140
                    20
                                                                        120
15 100
                                                                        80
                    10
                                                                        60
                                                                        40
                     5
                                                                        20
                     0                                                  0
                         0    5      10     15      20     25   30
     Example:
         (%i1) draw2d(points(makelist([random(20),random(50)],k,1,10)),
                 point_size = 5,
                 points(makelist(k,k,1,20),makelist(random(30),k,1,20)))$
40
35
30
25
20
15
10
0 5 10 15 20
                            points([[1,6],[5,6],[9,6]]),
                            point_type = filled_circle,
                            points([[1,7],[5,7],[9,7]]),
                            point_type = 8,
                            points([[1,8],[5,8],[9,8]]),
                            point_type = filled_diamant,
                            points([[1,9],[5,9],[9,9]]) )$
10
                    0
                        0       2         4          6         8         10
points([[1,3],[5,3],[9,3]]) )$
3.5
2.5
1.5
0.5
                       0
                           0       2        4        6          8        10
     When proportional_axes is equal to xy or xyz, the aspect ratio of the axis units will
     be set to 1:1 resulting in a 2D or 3D scene that will be drawn with axes proportional
     to their relative lengths.
     Since this is a global graphics option, its position in the scene description does not
     matter.
Examples:
Single 2D plot.
           (%i1) draw2d(
                   ellipse(0,0,1,1,0,360),
                   transparent=true,
                   color = blue,
                   line_width = 4,
                   ellipse(0,0,2,1/2,0,360),
                   proportional_axes = 'xy) $
832                                                                                         Maxima 5.45.0 Manual
0.5
-0.5
                      -1
                              -2   -1.5         -1   -0.5         0         0.5   1         1.5   2
      Multiplot.
           (%i1) draw(
                   terminal = wxt,
                   gr2d(proportional_axes = 'xy,
                        explicit(x^2,x,0,1)),
                   gr2d(explicit(x^2,x,0,1),
                        xrange = [0,1],
                        yrange = [0,2],
                        proportional_axes='xy),
                   gr2d(explicit(x^2,x,0,1)))$
                                                       1
                                                     0.8
                                                     0.6
                                                     0.4
                                                     0.2
                                                       0
                                                           00.20.40.60.81
                                                         2
                                                       1.5
                                                         1
                                                       0.5
                                                         0
                                                              0
                                                              0.2
                                                                0.4
                                                                 0.6
                                                                  0.81
                      1
                    0.8
                    0.6
                    0.4
                    0.2
                      0
                          0               0.2         0.4                0.6          0.8         1
           (%i1) draw(columns=2,
                      gr3d(explicit(exp(sin(x)+cos(x^2)),x,-3,3,y,-3,3)),
                      gr3d(surface_hide = true,
                           explicit(exp(sin(x)+cos(x^2)),x,-3,3,y,-3,3)) )$
                   4.5                                                     4.5
                     4                                                       4
                   3.5                                                     3.5
                     3                                                       3
                   2.5                                                     2.5
                     2                                                       2
                   1.5                                                     1.5
                     1                                                       1
                   0.5                                                     0.5
                                                                       3                                                       3
                                                                   2                                                       2
                                                               1                                                       1
                         -3                                0                     -3                                0
                              -2                                                      -2
                                   -1                 -1                                   -1                 -1
                                        0                                                       0
                                            1       -2                                              1       -2
                                                2 -3                                                    2 -3
                                                  3                                                       3
                         explicit(x^2,x,-1,1))$
            (%i4) /* eps file */
                  draw2d(file_name = "myfile",
                         explicit(x^2,x,-1,1),
                         terminal = 'eps)$
            (%i5) /* pdf file */
                  draw2d(file_name = "mypdf",
                         dimensions = 100*[12.0,8.0],
                         explicit(x^2,x,-1,1),
                         terminal = 'pdf)$
            (%i6) /* wxwidgets window */
                  draw2d(explicit(x^2,x,-1,1),
                         terminal = 'wxt)$
      Multiple windows.
            (%i1) draw2d(explicit(x^5,x,-2,2), terminal=[screen, 3])$
            (%i2) draw2d(explicit(x^2,x,-2,2), terminal=[screen, 0])$
      An animated gif file.
            (%i1) draw(
                    delay     = 100,
                    file_name = "zzz",
                    terminal = 'animated_gif,
                    gr2d(explicit(x^2,x,-1,1)),
                    gr2d(explicit(x^3,x,-1,1)),
                    gr2d(explicit(x^4,x,-1,1)));
            End of animation sequence
            (%o1)          [gr2d(explicit), gr2d(explicit), gr2d(explicit)]
      Option delay is only active in animated gif’s; it is ignored in any other case.
      Multipage output in eps format.
            (%i1) draw(
                    file_name = "parabol",
                    terminal = multipage_eps,
                    dimensions = 100*[10,10],
                    gr2d(explicit(x^2,x,-1,1)),
                    gr3d(explicit(x^2+y^2,x,-1,1,y,-1,1))) $
      See also file_name, dimensions_draw and delay.
Exponential function
     If transform is none, the space is not transformed and graphic objects are drawn as
     defined. When a space transformation is desired, a list must be assigned to option
     transform. In case of a 2D scene, the list takes the form [f1(x,y), f2(x,y), x, y].
     In case of a 3D scene, the list is of the form [f1(x,y,z), f2(x,y,z), f3(x,y,z),
     x, y, z].
     The names of the variables defined in the lists may be different to those used in the
     definitions of the graphic objects.
Examples:
Rotation in 2D.
            (%i1) th : %pi / 4$
            (%i2) draw2d(
                    color = "#e245f0",
                    proportional_axes = 'xy,
                    line_width = 8,
                    triangle([3,2],[7,2],[5,5]),
                    border     = false,
                    fill_color = yellow,
                    transform = [cos(th)*x - sin(th)*y,
                                  sin(th)*x + cos(th)*y, x, y],
                    triangle([3,2],[7,2],[5,5]) )$
836                                                                 Maxima 5.45.0 Manual
                       2
                           0    1     2      3      4      5    6       7
Translation in 3D.
            (%i1) draw3d(
                    color     = "#a02c00",
                    explicit(20*exp(-x^2-y^2)-10,x,-3,3,y,-3,3),
                    transform = [x+10,y+10,z+10,x,y,z],
                    color     = blue,
                    explicit(20*exp(-x^2-y^2)-10,x,-3,3,y,-3,3) )$
Example:
            (%i1) draw2d(polygon([[3,2],[7,2],[5,5]]),
                         transparent = true,
                         color       = blue,
                         polygon([[5,2],[9,2],[7,5]]) )$
Chapter 53: draw                                                                        837
4.5
3.5
2.5
                        2
                            3       4       5       6       7       8       9
                   -1
                        -1      0       1       2       3       4       5   6
      Expert Gnuplot users can make use of this option to fine tune Gnuplot’s behaviour
      by writing settings to be sent before the plot or splot command.
The value of this option must be a string or a list of strings (one per line).
      Since this is a global graphics option, its position in the scene description does not
      matter.
Example:
            (%i1) draw2d(
                    xaxis =true, xaxis_type=solid,
                    yaxis =true, yaxis_type=solid,
                    user_preamble="set grid front",
                    region(x^2+y^2<1 ,x,-1.5,1.5,y,-1.5,1.5))$
1.5
0.5
-0.5
-1
                     -1.5
                        -1.5     -1      -0.5      0       0.5      1        1.5
            (%i1) draw3d(
                      contour=both,
                      surface_hide=true,enhanced3d=true,wired_surface=true,
                      contour_levels=10,
                      user_preamble="set for [i=1:8] linetype i dashtype i linecolor 0",
                      explicit(sin(x)*cos(y),x,1,10,y,1,10)
                  );
Chapter 53: draw                                                                                                                        839
                                                                                                0.8
                                                                                                0.6
                                                                                                0.4
                                                                                                0.2                          1
                                                                                                  0                          0.8
                                                                                               -0.2                          0.6
                         0.8                                                                                                 0.4
                         0.6                                                                   -0.4                          0.2
                         0.4                                                                   -0.6                          0
                         0.2                                                                                                -0.2
                           0                                                                   -0.8                         -0.4
                        -0.2                                                                                                -0.6
                        -0.4                                                                                                -0.8
                        -0.6                                                                                                -1
                        -0.8
                          -1
                                                                                                                       10
                                                                                                                   9
                                                                                                               8
                                                                                                           7
                               1                                                                       6
                                     2     3                                                       5
                                                 4    5                                        4
                                                           6    7                         3
                                                                     8               2
                                                                          9   10 1
                                                                                                                         1
                                                                                                                         0.8
                                                                                                                         0.6
                                                                                                                         0.4
                                                                                                                         0.2
                                                                                                                         0
                                                                                                                         -0.2
                          1
                        0.8                                                                                              -0.4
                        0.6
                        0.4
                        0.2
                          0                                                                                              -0.6
                       -0.2
                       -0.4
                       -0.6
                       -0.8
                         -1                                                                                            2 -0.8
                                                                                                                   1.5   -1
                              -2
                                   -1.5                                                                        1
                                          -1                                                           0.5
                                               -0.5                                               0
                                                      0
                                                          0.5                                 -0.5
                                                                1                    -1
                                                                    1.5          -1.5
                                                                          2 -2
explicit(sin(x^2+y^2),x,-2,2,y,-2,2) )$
2 1
                      1.5                                                                              0.8
                                                                                                       0.6
                          1
                                                                                                       0.4
                      0.5                                                                              0.2
                          0                                                                            0
                      -0.5                                                                             -0.2
                                                                                                       -0.4
                          -1
                                                                                                       -0.6
                      -1.5                                                                             -0.8
                          -2                                                                           -1
                               -2     -1.5    -1       -0.5         0   0.5      1        1.5     2
                                                                                                      1
                                                                                                      0.8
                               2                                                                      0.6
                                                                                                      0.4
                                                                                                      0.2
                          1.5                                                                         0
                                                                                                      -0.2
                               1                                                                      -0.4
                                                                                                      -0.6
                          0.5                                                                         -0.8
                                                                                                      -1
                               0
                                                                                                  1
                                                                                            0.5
                               -1                                                     0
                                       -0.5
                                                   0                           -0.5
                                                              0.5
                                                                        1 -1
     x_voxel is the number of voxels in the x direction to be used by the marching cubes
     algorithm implemented by the 3d implicit object. It is also used by graphic object
     region.
0.5
-0.5
                     -1
                           -1      -0.5         0           0.5           1
      If xaxis_secondary is true, function values can be plotted with respect to the second
      x axis, which will be drawn on top of the scene.
      Note that this is a local graphics option which only affects to 2d plots.
      Example:
            (%i1) draw2d(
                     key   = "Bottom x-axis",
                     explicit(x+1,x,1,2),
                     color = red,
                     key   = "Above x-axis",
                     xtics_secondary = true,
                     xaxis_secondary = true,
                     explicit(x^2,x,-1,1)) $
                          -1           -0.5         0            0.5              1
                      3
                                                              Bottom x-axis
                                                               Above x-axis
                    2.5
1.5
0.5
                      0
                          1      1.2          1.4       1.6            1.8        2
     Since this is a global graphics option, its position in the scene description does not
     matter.
Example:
           (%i1) draw2d(explicit(x^3,x,-1,1),
                        xaxis       = true,
                        xaxis_width = 3)$
     Option xlabel, a string, is the label for the x axis. By default, the axis is labeled
     with string "x".
     Since this is a global graphics option, its position in the scene description does not
     matter.
Example:
     Option xlabel_secondary, a string, is the label for the secondary x axis. By default,
     no label is written.
     Since this is a global graphics option, its position in the scene description does not
     matter.
Example:
           (%i1) draw2d(
                    xaxis_secondary=true,yaxis_secondary=true,
                    xtics_secondary=true,ytics_secondary=true,
                    xlabel_secondary="t[s]",
                    ylabel_secondary="U[V]",
                    explicit(sin(t),t,0,10) )$
844                                                                   Maxima 5.45.0 Manual
1 1
0.8 0.9
0.6 0.8
0.4 0.7
0.2 0.6
                                                                                  P[W]
                   I[A]
                            0                                               0.5
-0.2 0.4
-0.4 0.3
-0.6 0.2
       • When option xtics is bounded to a positive number, this is the distance between
         two consecutive tic marks.
       • When option xtics is bounded to a list of length three of the form
         [start,incr,end], tic marks are plotted from start to end at intervals of
         length incr.
       • When option xtics is bounded to a set of numbers of the form {n1, n2, ...},
         tic marks are plotted at values n1, n2, ...
       • When option xtics is bounded to a set of pairs of the form {["label1", n1],
         ["label2", n2], ...}, tic marks corresponding to values n1, n2, ... are labeled
         with "label1", "label2", ..., respectively.
     Since this is a global graphics option, its position in the scene description does not
     matter.
     Examples:
     Disable tics.
           (%i1) draw2d(xtics = 'false,
                        explicit(x^3,x,-1,1)          )$
     Tics every 1/4 units.
           (%i1) draw2d(xtics = 1/4,
                        explicit(x^3,x,-1,1)          )$
     Tics from -3/4 to 3/4 in steps of 1/8.
           (%i1) draw2d(xtics = [-3/4,1/8,3/4],
                        explicit(x^3,x,-1,1) )$
     Tics at points -1/2, -1/4 and 3/4.
           (%i1) draw2d(xtics = {-1/2,-1/4,3/4},
                        explicit(x^3,x,-1,1) )$
     Labeled tics.
           (%i1) draw2d(xtics = {["High",0.75],["Medium",0],["Low",-0.75]},
                        explicit(x^3,x,-1,1) )$
     See also ytics_draw, and ztics_draw.
     Example:
         (%i1) draw3d(xyplane = %e-2,
                      explicit(x^2+y^2,x,-1,1,y,-1,1))$
y_voxel                                                                  [Graphic option]
     Default value: 10
     y_voxel is the number of voxels in the y direction to be used by the marching cubes
     algorithm implemented by the 3d implicit object. It is also used by graphic object
     region.
yaxis                                                                     [Graphic option]
     Default value: false
     If yaxis is true, the y axis is drawn.
     Since this is a global graphics option, its position in the scene description does not
     matter.
     Example:
           (%i1) draw2d(explicit(x^3,x,-1,1),
                            yaxis         = true,
                            yaxis_color = blue)$
     See also yaxis_width, yaxis_type and yaxis_color.
yaxis_color                                                                [Graphic option]
     Default value: "black"
     yaxis_color specifies the color for the y axis. See color to know how colors are
     defined.
     Since this is a global graphics option, its position in the scene description does not
     matter.
     Example:
           (%i1) draw2d(explicit(x^3,x,-1,1),
                            yaxis         = true,
                            yaxis_color = red)$
     See also yaxis, yaxis_width and yaxis_type.
yaxis_secondary                                                            [Graphic option]
     Default value: false
     If yaxis_secondary is true, function values can be plotted with respect to the second
     y axis, which will be drawn on the right side of the scene.
     Note that this is a local graphics option which only affects to 2d plots.
     Example:
           (%i1) draw2d(
                      explicit(sin(x),x,0,10),
                      yaxis_secondary = true,
                      ytics_secondary = true,
                      color = blue,
                      explicit(100*sin(x+0.1)+2,x,0,10));
848                                                                 Maxima 5.45.0 Manual
     Example:
           (%i1) draw2d(
                    key_pos=bottom_right,
                    key="current",
                    xlabel="t[s]",
                    ylabel="I[A]",ylabel_secondary="P[W]",
                    explicit(sin(t),t,0,10),
                    yaxis_secondary=true,
                    ytics_secondary=true,
                    color=red,key="Power",
                    explicit((sin(t))^2,t,0,10)
                )$
     See also xlabel_draw, xlabel_secondary, ylabel_draw and zlabel_draw.
yrange                                                                       [Graphic option]
     Default value: auto
     If yrange is auto, the range for the y coordinate is computed automatically.
     If the user wants a specific interval for y, it must be given as a Maxima list, as in
     yrange=[-2, 3].
     Since this is a global graphics option, its position in the scene description does not
     matter.
     Example:
           (%i1) draw2d(yrange = [-2,3],
                            explicit(x^2,x,-1,1),
                            xrange = [-3,3])$
     See also xrange, yrange_secondary and zrange.
yrange_secondary                                                               [Graphic option]
     Default value: auto
     If yrange_secondary is auto, the range for the second y axis is computed automat-
     ically.
     If the user wants a specific interval for the second y axis, it must be given as a Maxima
     list, as in yrange_secondary=[-2, 3].
     Since this is a global graphics option, its position in the scene description does not
     matter.
     Example:
             (%i1) draw2d(
                       explicit(sin(x),x,0,10),
                       yaxis_secondary = true,
                       ytics_secondary = true,
                       yrange = [-3, 3],
                       yrange_secondary = [-20, 20],
                       color = blue,
                       explicit(100*sin(x+0.1)+2,x,0,10)) $
     See also xrange, yrange and zrange.
850                                                                  Maxima 5.45.0 Manual
     Example:
         (%i1) draw3d(xu_grid = 10,
                      yv_grid = 50,
                      explicit(x^2+y^2,x,-3,3,y,-3,3) )$
                         18
                         16
                         14
                         12
                   Z     10
                          8
                          6
                          4
                          2
                          0
                                                                                      3
                                                                                  2
                                                                              1
                          -3                                              0
                               -2                                    -1           Y
                                    -1
                                             0                  -2
                                         X       1
                                                     2
                                                         3 -3
      Example:
            (%i1) draw3d(explicit(x^2+y^2,x,-1,1,y,-1,1),
                           zaxis       = true,
                           zaxis_type = solid,
                           zaxis_color = red)$
      See also zaxis, zaxis_width and zaxis_type.
                                                            Group A
                    6                                       Group B
-2
                   -4
                             1       1.5      2       2.5        3
Example:
(%i1) draw3d(cylindrical(1,z,-2,2,az,0,2*%pi))$
                         2
                       1.5
                         1
                       0.5
                         0
                      -0.5
                        -1
                      -1.5
                        -2
                                                                                           1
                                                                                     0.8
                                                                                   0.6
                                                                                 0.4
                                                                               0.2
                             -0.8-0.6                                         0
                                     -0.4-0.2                             -0.2
                                              0 0.2                     -0.4
                                                    0.4 0.6          -0.6
                                                                   -0.8
                                                            0.8 1 -1
In older versions of Maxima, elevation_grid was called mesh. See also mesh.
Example:
           (%i1) m: apply(
                       matrix,
                       makelist(makelist(random(10.0),k,1,30),i,1,20)) $
           (%i2) draw3d(
                    color = blue,
                    elevation_grid(m,0,0,3,2),
                    xlabel = "x",
                    ylabel = "y",
                    surface_hide = true);
856                                                                              Maxima 5.45.0 Manual
                        10
                         9
                         8
                         7
                         6
                         5
                         4
                         3
                         2
                         1
                         0
                                                                                         2
                                                                               1.5
                             0                                             1
                                 0.5                                                 y
                                       1                             0.5
                                               1.5
                                           x         2
                                                         2.5
                                                               3 0
2D
      ellipse (xc, yc, a, b, ang1, ang2) plots an ellipse centered at [xc, yc] with hor-
      izontal and vertical semi axis a and b, respectively, starting at angle ang1 with an
      amplitude equal to angle ang2.
      This object is affected by the following graphic options: nticks, transparent, fill_
      color, border, line_width, line_type, key and color
Example:
                     2
                         -3   -2   -1     0   1    2     3     4     5     6
2D
Examples:
             (%i1) draw2d(
                     error_type = 'y,
                     errors([[1,2,1], [3,5,3], [10,3,1], [17,6,2]]))$
858                                                             Maxima 5.45.0 Manual
5.5
4.5
3.5
2.5
                      2
                          2      4     6    8   10   12    14     16
5.5
4.5
3.5
2.5
                      2
                          2      4     6    8   10   12    14     16
     This object is affected by the following graphic options: nticks, adapt_depth, draw_
     realpart, line_width, line_type, key, filled_func, fill_color and color
     Example:
          (%i1) draw2d(line_width = 3,
                       color      = blue,
                       explicit(x^2,x,-3,3) )$
                   0
                       -3   -2       -1       0        1       2        3
                   0
                       -3   -2       -1       0        1       2        3
     3D
     explicit(fcn, var1, minval1, maxval1, var2, minval2, maxval2) plots the ex-
     plicit function fcn, with variable var1 taking values from minval1 to maxval1 and
     variable var2 taking values from minval2 to maxval2.
860                                                                      Maxima 5.45.0 Manual
                                                            Gauss
                                                            Plane
                        10
                         5
                         0
                        -5
                       -10
                                                                         4
                                                                     2
                             -4                                  0
                                  -2                        -2
                                       0
                                             2         -4
                                                   4
     palette = gray and palette = color are short cuts for palette = [3,3,3] and
     palette = [7,5,15], respectively.
     If im is a matrix of vectors of length three or an rgb picture object, they are interpreted
     as red, green and blue color components.
Examples:
30 200
                                                                           180
                    25
                                                                           160
                                                                           140
                    20
                                                                           120
15 100
                                                                           80
                    10
                                                                           60
                                                                           40
                     5
                                                                           20
                     0                                                     0
                         0    5      10      15      20      25      30
30 200
                                                                                180
                   25
                                                                                160
                                                                                140
                   20
                                                                                120
15 100
                                                                                80
                   10
                                                                                60
                                                                                40
                    5
                                                                                20
                    0                                                           0
                        0    5       10        15        20        25   30
30
25
20
15
10
                    0
                        0        5        10        15        20        25           30
      If im is a matrix of vectors of length three, they are interpreted as red, green and
      blue color components.
30
25
20
15
10
                    0
                        0       5        10        15        20        25        30
     Package draw automatically loads package picture. In this example, a level picture
     object is built by hand and then rendered.
30 250
                   25
                                                                            200
                   20
                                                                            150
15
                                                                            100
                   10
                                                                            50
                    5
                    0                                                       0
                        0   5       10        15        20        25   30
30 250
                   25
                                                                         200
                   20
                                                                         150
15
                                                                         100
                   10
                                                                         50
                    5
                    0                                                    0
                        0    5      10     15     20     25      30
      http://www.telefonica.net/web2/biomates/maxima/gpdraw/image
      contains more elaborated examples.
2D
      This object is affected by the following graphic options: ip_grid, ip_grid_in, line_
      width, line_type, key and color.
Example:
-1
-2
-3
                   -4
                        -4          -3          -2       -1          0        1                2           3       4
3D
     This object is affected by the following graphic options: x_voxel, y_voxel, z_voxel,
     line_width, line_type, key, wired_surface, enhanced3d and color.
Example:
          (%i1) draw3d(
                  color=blue,
                  implicit((x^2+y^2+z^2-1)*(x^2+(y-1.5)^2+z^2-0.5)=0.015,
                           x,-1,1,y,-1.2,2.3,z,-1,1),
                  surface_hide=true);
                              1
                             0.5
                              0
                         -0.5
                              -1
                                                                                                               2
                                                                                                         1.5
                                                                                                     1
                               -1                                                              0.5
                                         -0.5                                              0
                                                     0                              -0.5
                                                               0.5             -1
                                                                          1
866                                                                        Maxima 5.45.0 Manual
1.4
                     1
                                             Label in light-blue
                    0.8
                    0.4
                                                Label in red
                    0.2
      3D
      label([string,x,y,z]) writes the string at point [x,y,z].
      Example:
            (%i1) draw3d(explicit(exp(sin(x)+cos(x^2)),x,-3,3,y,-3,3),
                         color = red,
                         label(["UP 1",-2,0,3], ["UP 2",1.5,0,4]),
                         color = blue,
                         label(["DOWN 1",2,0,-3]) )$
Chapter 53: draw                                                                                                       867
                                            UP 1
                        4                                        UP 2
                        3
                        2
                        1
                        0
                       -1
                       -2
                       -3                                         DOWN 1
                                                                                                       3
                                                                                                 2
                                                                                            1
                         -3                                                         0
                                  -2                                           -1
                                       -1
                                             0                          -2
                                                   1
                                                            2
                                                                3 -3
                       10
                        9
                        8
                        7
                        6
                        5
                        4
                        3
                        2
                        1
                                                                                                      14
                                                                                                 12
                                                                                            10
                                                                                        8
                              0                                                     6
                                       5                                       4
                                              10                           2
                                                       15              0
                                                                20-2
           (%i1) draw3d(
                   line_width = 2,
                   mesh([[1,0,0],[0,1,0]],
                        [[0,0,1],[0,0,1]])) $
                         1
                       0.8
                       0.6
                       0.4
                       0.2
                         0
                                                                                               1
                                                                                         0.8
                             0                                                    0.6
                                 0.2                                        0.4
                                        0.4                          0.2
                                                  0.6
                                                         0.8
                                                               1 0
Two quadrilaterals.
           (%i1) draw3d(
                   surface_hide =             true,
                   line_width   =             3,
                   color = red,
                   mesh([[0,0,0],             [0,1,0]],
                        [[2,0,2],             [2,2,2]]),
                   color = blue,
                   mesh([[0,0,2],             [0,1,2]],
                        [[2,0,4],             [2,2,4]])) $
                         4
                       3.5
                         3
                       2.5
                         2
                       1.5
                         1
                       0.5
                         0
                                                                                               2
                                                                                        1.5
                             0                                                    1
                                  0.5
                                              1                       0.5
                                                        1.5
                                                               2 0
Chapter 53: draw                                                                         869
30
25
20
15
10
                    0
                        -2    -1         0           1              2        3
     3D
     parametric(xfun, yfun, zfun, par, parmin, parmax) plots the parametric curve
     [xfun, yfun, zfun], with parameter par taking values from parmin to parmax.
     Example:
          (%i1) draw3d(explicit(exp(sin(x)+cos(x^2)),x,-3,3,y,-3,3),
                       color = royalblue,
                       parametric(cos(5*u)^2,sin(7*u),u-2,u,0,2),
                       color      = turquoise,
                       line_width = 2,
                       parametric(t^2,sin(t),2+t,t,0,2),
                       surface_hide = true,
                       title = "Surface & curves" )$
870                                                                                 Maxima 5.45.0 Manual
Surface curves
                        4
                        3
                        2
                        1
                        0
                       -1
                       -2
                                                                                        3
                                                                                    2
                                                                                1
                        -3   -2                                             0
                                  -1   0                               -1
                                           1     2                -2
                                                      3    4 -3
3D
Example:
Sea shell
                        -50
                       -100
                       -150
                       -200
                       -250
                       -300
                       -350
                          -30
                            -20
                              -10 0
                                   1020                                  10   20   30
                                       30   -40   -30    -20   -10   0
                  40                                Small points
                                                    Great points
                  35                          Automatic abscissas
30
25
20
15
10
0 5 10 15 20
Drawing impulses.
           (%i1) draw2d(
                   points_joined = impulses,
                   line_width    = 2,
                   color         = red,
                   points(makelist([random(20),random(50)],k,1,10)))$
Chapter 53: draw                                                                                873
40
35
30
25
20
15
10
0 2 4 6 8 10 12 14 16 18
0.9
0.8
0.7
0.6
0.5
0.4
0.3
0.2
0.1
10 20 30 40 50 60 70 80 90 100
                   0
                       0   0.1   0.2   0.3   0.4   0.5   0.6   0.7   0.8   0.9
      A two-column 2D array.
           (%i1) xy: make_array(flonum, 100, 2) $
           (%i2) for i:0 thru 99 do (
                   xy[i, 0]: float(i/100),
                   xy[i, 1]: random(10) ) $
           (%i3) draw2d(points(xy)) $
                   0
                       0   0.1   0.2   0.3   0.4   0.5   0.6   0.7   0.8   0.9
                       9
                       8
                       7
                       6
                       5
                       4
                       3
                       2
                       1
                                                                                                     9
                                                                                                 8
                                                                                             7
                                                                                         6
                           0                                                         5
                               1   2                                             4
                                       3   4                                 3
                                               5                         2
                                                   6   7             1
                                                           8   9 0
876                                                                                                Maxima 5.45.0 Manual
                                                                                                           9
                                                                                                           8
                         9                                                                                 7
                         8                                                                                 6
                         7                                                                                 5
                         6                                                                                 4
                         5
                         4                                                                                 3
                         3                                                                                 2
                         2                                                                                 1
                         1
                                                                                                       9
                                                                                                   8
                                                                                               7
                                                                                           6
                             0                                                         5
                                 1   2                                             4
                                         3   4                                 3
                                                 5                         2
                                                     6   7             1
                                                             8   9 0
                                                                                                     16
                                                                                                     14
                           1                                                                         12
                         0.8                                                                         10
                         0.6
                         0.4                                                                         8
                         0.2                                                                         6
                           0                                                                         4
                        -0.2
                        -0.4                                                                         2
                        -0.6                                                                         0
                        -0.8
                                                                                               200
                                                                                         150
                               0        2                                          100
                                            4   6    8    10                  50
                                                               12    14   0
Hyperbolic Spiral
-2
-4
                                   -4           -2               0             2                 4
878                                                                Maxima 5.45.0 Manual
4.5
3.5
2.5
                       2
                           3      4        5        6     7    8        9
1.5
0.5
-0.5
-1
-1.5
                    -2
                          1      1.5          2           2.5          3
3D
     quadrilateral([x1, y1, z1], [x2, y2, z2], [x3, y3, z3], [x4, y4, z4]) draws
     a quadrilateral with vertices [x1, y1, z1], [x2, y2, z2], [x3, y3, z3], and [x4,
     y4, z4].
2D
Example:
-1
-2
                     -3
                             -2        0          2       4         6       8           10
1.5
0.5
-0.5
-1
                  -1.5
                     -1.5         -1       -0.5       0       0.5       1         1.5
Chapter 53: draw                                                                                             881
3D
     spherical(radius, azi, minazi, maxazi, zen, minzen, maxzen) plots the func-
     tion radius(azi, zen) defined in spherical coordinates, with azimuth azi taking
     values from minazi to maxazi and zenith zen taking values from minzen to maxzen.
     This object is affected by the following graphic options: xu_grid, yv_grid, line_
     type, key, wired_surface, enhanced3d and color.
Example:
(%i1) draw3d(spherical(1,a,0,2*%pi,z,0,%pi))$
                          1
                         0.5
                          0
                     -0.5
                          -1
                                                                                           0.8
                                                                                         0.6
                                                                                       0.4
                                                                                     0.2
                               -0.8-0.6                                          0
                                       -0.4-0.2                              -0.2
                                                0 0.2                      -0.4
                                                      0.4 0.6           -0.6
                                                                      -0.8
                                                              0.8 1
2D
Example:
          (%i1) draw2d(
                  triangle([1,1],[2,2],[3,-1]))$
882                                                                Maxima 5.45.0 Manual
1.5
0.5
-0.5
                      -1
                           1        1.5          2           2.5          3
3D
3D
      [xfun,yfun,zfun] is the parametric curve with parameter p taking values from pmin
      to pmax. Circles of radius rfun are placed with their centers on the parametric curve
      and perpendicular to it.
      This object is affected by the following graphic options: xu_grid, yv_grid, line_
      type, line_width, key, wired_surface, enhanced3d, color and capping.
Example:
            (%i1) draw3d(
                    enhanced3d = true,
                    xu_grid = 50,
                    tube(cos(a), a, 0, cos(a/10)^2,
                         a, 0, 4*%pi) )$
Chapter 53: draw                                                                                              883
                                                                                                 1
                                                                                                 0.8
                        1                                                                        0.6
                      0.8                                                                        0.4
                      0.6                                                                        0.2
                      0.4                                                                        0
                      0.2                                                                        -0.2
                        0                                                                        -0.4
                     -0.2                                                                        -0.6
                     -0.4                                                                        -0.8
                     -0.6                                                                        -1
                     -0.8
                                                                                            12
                                                                                       10
                                                                                   8
                            -1.5                                               6
                                   -1   -0.5                               4
                                               0   0.5                 2
                                                         1   1.5   0
2D
Example:
10
                    0
                        0            2               4               6              8               10          12
      3D
      vector([x,y,z], [dx,dy,dz]) plots vector [dx,dy,dz] with origin in [x,y,z].
      Example:
           (%i1) draw3d(color = cyan,
                        vector([0,0,0],[1,1,1]/sqrt(3)),
                        vector([0,0,0],[1,-1,0]/sqrt(2)),
                        vector([0,0,0],[1,1,-2]/sqrt(6)) )$
                         0.4
                         0.2
                           0
                        -0.2
                        -0.4
                        -0.6
                        -0.8
                                                                                                          0.4
                                                                                                    0.2
                               0                                                                0
                                   0.1   0.2                                             -0.2
                                               0.3       0.4                         -0.4
                                                               0.5   0.6         -0.6
                                                                           0.7
draw_renderer                                                                                                        [Variable]
      Default value: gnuplot_pipes
      When draw_renderer is set to 'vtk, the VTK interface is used for draw.
make_level_picture                                                            [Function]
        make_level_picture (data)
        make_level_picture (data,width,height)
     Returns a levels picture object. make_level_picture (data) builds the picture ob-
     ject from matrix data. make_level_picture (data,width,height) builds the object
     from a list of numbers; in this case, both the width and the height must be given.
     The returned picture object contains the following four parts:
       1. symbol level
       2. image width
       3. image height
       4. an integer array with pixel data ranging from 0 to 255. Argument data must
           contain only numbers ranged from 0 to 255; negative numbers are substituted by
           0, and those which are greater than 255 are set to 255.
     Example:
     Level picture from matrix.
           (%i1) make_level_picture(matrix([3,2,5],[7,-9,3000]));
           (%o1)           picture(level, 3, 2, {Array: #(3 2 5 7 0 255)})
     Level picture from numeric list.
           (%i1) make_level_picture([-2,0,54,%pi],2,2);
           (%o1)               picture(level, 2, 2, {Array: #(0 0 54 3)})
make_poly_continent                                                                 [Function]
        make_poly_continent (continent_name)
        make_poly_continent (country_list)
     Makes the necessary polygons to draw a colored continent or a list of countries.
Example:
           (%i1) load(worldmap)$
           (%i2) /* A continent */
                 make_poly_continent(Africa)$
           (%i3) apply(draw2d, %)$
30
20
10
-10
-20
-30
-20 -10 0 10 20 30 40 50
62
60
58
56
54
52
50
48
                          -5         0       5        10        15        20
888                                                                Maxima 5.45.0 Manual
35
30
25
20
15
10
70 75 80 85 90 95
           (%o4) {Array:
                  #(91.659554 27.76511 91.6008 27.66666 91.598022 27.62499
                    91.631348 27.536381 91.765533 27.45694 91.775253 27.4161
                    92.007751 27.471939 92.11441 27.28583 92.015259 27.168051
                    92.015533 27.08083 92.083313 27.02277 92.112183 26.920271
                    92.069977 26.86194 91.997192 26.85194 91.915253 26.893881
                    91.916924 26.85416 91.8358 26.863331 91.712479 26.799999
                    91.542191 26.80444 91.492188 26.87472 91.418854 26.873329
                    91.371353 26.800831 91.307457 26.778049 90.682457 26.77417
                    90.392197 26.903601 90.344131 26.894159 90.143044 26.75333
                    89.98996 26.73583 89.841919 26.70138 89.618301 26.72694
                    89.636093 26.771111 89.360786 26.859989 89.22081 26.81472
                    89.110237 26.829161 88.921631 26.98777 88.873016 26.95499
                    88.867737 27.080549 88.843307 27.108601 88.750549
                    27.14727)}
           (%i5) boundaries_array[1143];
           (%o5) {Array:
                  #(91.659554 27.76511 91.666924 27.88888 91.65831 27.94805
                    91.338028 28.05249 91.314972 28.096661 91.108856 27.971109
                    91.015808 27.97777 90.896927 28.05055 90.382462 28.07972
                    90.396088 28.23555 90.366074 28.257771 89.996353 28.32333
                    89.83165 28.24888 89.58609 28.139999 89.35997 27.87166
                    89.225517 27.795 89.125793 27.56749 88.971077 27.47361
                    88.917877 27.321039)}
           (%i6) Bhutan_polygon: make_polygon([171,173,1143])$
           (%i7) draw2d(Bhutan_polygon)$
28.2
28
27.8
27.6
27.4
27.2
27
26.8
            (%i1) load(worldmap)$
            (%i2) region_boundaries(10.4,41.5,20.7,35.4);
            (%o2)                [1846, 1863, 1864, 1881, 1888, 1894]
            (%i3) draw2d(geomap(%))$
40.5
40
39.5
39
38.5
38
37.5
37
36.5
36
13 14 15 16 17 18 19 20
Example:
            (%i1) load(worldmap)$
            (%i2) region_boundaries_plus(10.4,41.5,20.7,35.4);
            (%o2) [1060, 1062, 1076, 1835, 1839, 1844, 1846, 1858,
                   1861, 1863, 1864, 1871, 1881, 1888, 1894, 1897]
            (%i3) draw2d(geomap(%))$
Chapter 53: draw                                                                     891
44
43
42
41
40
39
38
37
36
10 12 14 16 18 20
                    0
                        1       2         3          4         5         6
      The auxiliary package worldmap sets the global variable boundaries_array to real
      world boundaries in (longitude, latitude) coordinates. These data are in the public
      domain and come from https://web.archive.org/web/20100310124019/http://
      www-cger.nies.go.jp/grid-e/gridtxt/grid19.html. Package worldmap defines
      also boundaries for countries, continents and coastlines as lists with the necessary
      components of boundaries_array (see file share/draw/worldmap.mac for more in-
      formation). Package worldmap automatically loads package worldmap.
           (%i1) load(worldmap)$
           (%i2) c1: gr2d(geomap([Canada,United_States,
                                  Mexico,Cuba]))$
           (%i3) c2: gr2d(geomap(Africa))$
           (%i4) c3: gr2d(geomap([Oceania,China,Japan]))$
           (%i5) c4: gr2d(geomap([France,Portugal,Spain,
                                  Morocco,Western_Sahara]))$
           (%i6) draw(columns = 2,
                      c1,c2,c3,c4)$
Chapter 53: draw                                                                                     893
                   80
                                                           30
                   70
                                                           20
                   60                                      10
                   50                                       0
                   40                                     -10
                   30                                     -20
                   20                                     -30
                          -160 -140 -120 -100 -80 -60           -20 -10 0 10 20 30 40 50
                                                          50
                   40
                                                          45
                   20                                     40
                    0                                     35
                   -20                                    30
-40 25
     Package worldmap is also useful for plotting countries as polygons. In this case,
     graphic object geomap is no longer necessary and the polygon object is used instead.
     Since lists are now used and not arrays, maps rendering will be slower. See also
     make_poly_country and make_poly_continent to understand the following code.
          (%i1) load(worldmap)$
          (%i2) mymap: append(
             [color      = white], /* borders are white */
             [fill_color = red],             make_poly_country(Bolivia),
             [fill_color = cyan],            make_poly_country(Paraguay),
             [fill_color = green],           make_poly_country(Colombia),
             [fill_color = blue],            make_poly_country(Chile),
             [fill_color = "#23ab0f"],       make_poly_country(Brazil),
             [fill_color = goldenrod],       make_poly_country(Argentina),
             [fill_color = "midnight-blue"], make_poly_country(Uruguay))$
          (%i3) apply(draw2d, mymap)$
10
-10
-20
-30
-40
-50
     3D
894                                                                                                 Maxima 5.45.0 Manual
Available 3D projections:
                (%i1) load(worldmap)$
                (%i2) draw3d(geomap(Australia), /* default projection */
                             geomap(Australia,
                                    [spherical_projection,2,2,2,3]))$
                           1
                         0.5
                           0
                         -0.5
                                                                                                                  4.5
                                                                                                              4
                                                                                                        3.5
                                                                                                    3
                            -0.8 -0.6                                                         2.5
                                        -0.4 -0.2                                         2
                                                    0   0.2 0.4                     1.5
                                                                                1
                                                                0.6 0.8   0.5
                (%i1) load(worldmap)$
                (%i2) draw3d(geomap([America_coastlines,Eurasia_coastlines],
                                    [cylindrical_projection,2,2,2,3,4]))$
Chapter 53: draw                                                                                               895
                            4
                            3
                            2
                            1
                            0
                                                                                                           6
                                                                                                       5
                                                                                                   4
                                                                                               3
                            -2   -1                                                        2
                                         0   1                                         1
                                                 2                                 0
                                                           3   4              -1
                                                                   5   6 -2
                       1
                      0.5
                       0
                     -0.5
                       -1
                                                                                                   1
                                                                                           0.5
                            -1                                                         0
                                  -0.5                                        -0.5
                                             0
                                                     0.5                -1
                                                               1
54 drawdf
   and the function F should be given as the argument for drawdf. If the independent and
dependent variables are not x, and y, as in the equation above, then those two variables
should be named explicitly in a list given as an argument to the drawdf command (see the
examples).
   To plot the direction field of a set of two autonomous ODE’s, they must be written in
the form
                               dx                dy
                                   = G(x, y)        = F (x, y)
                               dt                dt
   and the argument for drawdf should be a list with the two functions G and F, in that
order; namely, the first expression in the list will be taken to be the time derivative of
the variable represented on the horizontal axis, and the second expression will be the time
derivative of the variable represented on the vertical axis. Those two variables do not have
to be x and y, but if they are not, then the second argument given to drawdf must be
another list naming the two variables, first the one on the horizontal axis and then the one
on the vertical axis.
   If only one ODE is given, drawdf will implicitly admit x=t, and G(x,y)=1, transforming
the non-autonomous equation into a system of two autonomous equations.
      The first argument specifies the derivative(s), and must be either an expression or a
      list of two expressions. dydx, dxdt and dydt are expressions that depend on x and y.
      dvdu, dudt and dvdt are expressions that depend on u and v.
      If the independent and dependent variables are not x and y, then their names must be
      specified immediately following the derivative(s), either as a list of two names [u,v],
      or as two lists of the form [u,umin,umax] and [v,vmin,vmax].
      The remaining arguments are graphic options, graphic objects, or lists containing
      graphic options and objects, nested to arbitrary depth. The set of graphic options
      and objects supported by drawdf is a superset of those supported by draw2d and
      gr2d from the draw package.
      The arguments are interpreted sequentially: graphic options affect all following
      graphic objects. Furthermore, graphic objects are drawn on the canvas in order
      specified, and may obscure graphics drawn earlier. Some graphic options affect the
      global appearance of the scene.
      The additional graphic objects supported by drawdf include: solns_at, points_at,
      saddles_at, soln_at, point_at, and saddle_at.
      The additional graphic options supported by drawdf include: field_degree, soln_
      arrows, field_arrows, field_grid, field_color, show_field, tstep, nsteps,
      duration, direction, field_tstep, field_nsteps, and field_duration.
      Commonly used graphic objects inherited from the draw package include: explicit,
      implicit, parametric, polygon, points, vector, label, and all others supported
      by draw2d and gr2d.
      Commonly used graphic options inherited from the draw package include:
      points_joined, color, point_type, point_size, line_width, line_type, key,
      title, xlabel, ylabel, user_preamble, terminal, dimensions, file_name, and
      all others supported by draw2d and gr2d.
      See also draw2d, rk, desolve and ode2.
      Users of wxMaxima or Imaxima may optionally use wxdrawdf, which is identical to
      drawdf except that the graphics are drawn within the notebook using wxdraw.
      To make use of this function, write first load("drawdf").
      Examples:
            (%i1)   load("drawdf")$
            (%i2)   drawdf(exp(-x)+y)$        /* default vars: x,y */
            (%i3)   drawdf(exp(-t)+y, [t,y])$ /* default range: [-10,10] */
            (%i4)   drawdf([y,-9*sin(x)-y/5], [x,1,5], [y,-2,2])$
      For backward compatibility, drawdf accepts most of the parameters supported by
      plotdf.
            (%i5) drawdf(2*cos(t)-1+y, [t,y], [t,-5,10], [y,-4,9],
                         [trajectory_at,0,0])$
      soln_at and solns_at draw solution curves passing through the specified points,
      using a slightly enhanced 4th-order Runge Kutta numerical integrator.
            (%i6) drawdf(2*cos(t)-1+y, [t,-5,10], [y,-4,9],
                         solns_at([0,0.1],[0,-0.1]),
Chapter 54: drawdf                                                                     899
                            color=blue, soln_at(0,0))$
     field_degree=2 causes the field to be composed of quadratic splines, based on the
     first and second derivatives at each grid point. field_grid=[COLS,ROWS] specifies
     the number of columns and rows in the grid.
            (%i7) drawdf(2*cos(t)-1+y, [t,-5,10], [y,-4,9],
                            field_degree=2, field_grid=[20,15],
                            solns_at([0,0.1],[0,-0.1]),
                            color=blue, soln_at(0,0))$
     soln_arrows=true adds arrows to the solution curves, and (by default) removes them
     from the direction field. It also changes the default colors to emphasize the solution
     curves.
            (%i8) drawdf(2*cos(t)-1+y, [t,-5,10], [y,-4,9],
                            soln_arrows=true,
                            solns_at([0,0.1],[0,-0.1],[0,0]))$
     duration=40 specifies the time duration of numerical integration (default 10). In-
     tegration will also stop automatically if the solution moves too far away from the
     plotted region, or if the derivative becomes complex or infinite. Here we also specify
     field_degree=2 to plot quadratic splines. The equations below model a predator-
     prey system.
            (%i9) drawdf([x*(1-x-y), y*(3/4-y-x/2)], [x,0,1.1], [y,0,1],
                            field_degree=2, duration=40,
                            soln_arrows=true, point_at(1/2,1/2),
                            solns_at([0.1,0.2], [0.2,0.1], [1,0.8], [0.8,1],
                                        [0.1,0.1], [0.6,0.05], [0.05,0.4],
                                        [1,0.01], [0.01,0.75]))$
     field_degree='solns causes the field to be composed of many small solution curves
     computed by 4th-order Runge Kutta, with better results in this case.
            (%i10) drawdf([x*(1-x-y), y*(3/4-y-x/2)], [x,0,1.1], [y,0,1],
                             field_degree='solns, duration=40,
                             soln_arrows=true, point_at(1/2,1/2),
                             solns_at([0.1,0.2], [0.2,0.1], [1,0.8],
                                         [0.8,1], [0.1,0.1], [0.6,0.05],
                                         [0.05,0.4], [1,0.01], [0.01,0.75]))$
     saddles_at attempts to automatically linearize the equation at each saddle, and to
     plot a numerical solution corresponding to each eigenvector, including the separatri-
     ces. tstep=0.05 specifies the maximum time step for the numerical integrator (the
     default is 0.1). Note that smaller time steps will sometimes be used in order to keep
     the x and y steps small. The equations below model a damped pendulum.
            (%i11) drawdf([y,-9*sin(x)-y/5], tstep=0.05,
                             soln_arrows=true, point_size=0.5,
                             points_at([0,0], [2*%pi,0], [-2*%pi,0]),
                             field_degree='solns,
                             saddles_at([%pi,0], [-%pi,0]))$
     show_field=false suppresses the field entirely.
            (%i12) drawdf([y,-9*sin(x)-y/5], tstep=0.05,
900                                                                 Maxima 5.45.0 Manual
                              show_field=false, soln_arrows=true,
                              point_size=0.5,
                              points_at([0,0], [2*%pi,0], [-2*%pi,0]),
                              saddles_at([3*%pi,0], [-3*%pi,0],
                                           [%pi,0], [-%pi,0]))$
      drawdf passes all unrecognized parameters to draw2d or gr2d, allowing you to com-
      bine the full power of the draw package with drawdf.
            (%i13) drawdf(x^2+y^2, [x,-2,2], [y,-2,2], field_color=gray,
                              key="soln 1", color=black, soln_at(0,0),
                              key="soln 2", color=red, soln_at(0,1),
                              key="isocline", color=green, line_width=2,
                              nticks=100, parametric(cos(t),sin(t),t,0,2*%pi))$
      drawdf accepts nested lists of graphic options and objects, allowing convenient use of
      makelist and other function calls to generate graphics.
            (%i14) colors : ['red,'blue,'purple,'orange,'green]$
            (%i15) drawdf([x-x*y/2, (x*y - 3*y)/4],
                              [x,2.5,3.5], [y,1.5,2.5],
                              field_color = gray,
                              makelist([ key      = concat("soln",k),
                                           color = colors[k],
                                           soln_at(3, 2 + k/20) ],
                                        k,1,5))$
                                                                                                          901
55 dynamics
                                              0.9
                                              0.8
                                              0.7
                    contraction factor: 0.5
                                              0.6
                                              0.5
                                              0.4
                                              0.3
                                              0.2
                                              0.1
                                               0
                                                    0   0.1   0.2 0.3 0.4 0.5 0.6 0.7 0.8       0.9   1
                                                                 The chaos game with 3 points
                                                                yn+1 = F (yn )
902                                                                   Maxima 5.45.0 Manual
      With initial value y(0) equal to y0. F must be an expression that depends only on
      one variable (in the example, it depend on y, but any other variable can be used), y0
      must be a real number and n must be a positive integer. This function accepts the
      same options as plot2d.
Example.
1.5
                             1
                    y(n)
0.5
                           -0.5
                                  0        2        4         6   8   10
                                                          n
                                      
                                          un+1 = F (un , vn )
                                          vn+1 = G(un , vn )
      With initial values u0 and v0. F and G must be two expressions that depend only
      on two variables, u and v, which must be named explicitly in a list. The options are
      the same as for plot2d.
            (%i1) f: 0.6*x*(1+2*x)+0.8*y*(x-1)-y^2-0.9$
            (%i2) g: 0.1*x*(1-6*x+4*y)+0.1*y*(1+9*y)-0.4$
            (%i3) evolution2d([f,g], [x,y], [-0.5,0], 50000, [style,dots]);
Chapter 55: dynamics                                                                               903
                           0.1
                             0
                          -0.1
                          -0.2
                          -0.3
                          -0.4
                      y   -0.5
                          -0.6
                          -0.7
                          -0.8
                          -0.9
                                 -1    -0.8    -0.6   -0.4       -0.2   0       0.2   0.4
                                                             x
-0.2
-0.25
                            -0.3
                      y
-0.35
                            -0.4
                                -0.8          -0.75          -0.7       -0.65         -0.6
                                                               x
ifs ([r1, . . . , rm], [A1,. . . , Am], [[x1, y1], . . . , [xm, ym]], [x0, y0], n,           [Function]
         options, . . . );
      Implements the Iterated Function System method. This method is similar to the
      method described in the function chaosgame. but instead of shrinking the segment
      from the current point to the randomly chosen point, the 2 components of that seg-
      ment will be multiplied by the 2 by 2 matrix Ai that corresponds to the point chosen
      randomly.
      The random choice of one of the m attractive points can be made with a non-uniform
      probability distribution defined by the weights r1,...,rm. Those weights are given in
      cumulative form; for instance if there are 3 points with probabilities 0.2, 0.5 and 0.3,
      the weights r1, r2 and r3 could be 2, 7 and 10. The options are the same as for
      plot2d.
904                                                                       Maxima 5.45.0 Manual
                      10
                       9
                       8
                       7
                       6
                       5
                       4
                       3
                       2
                       1
                       0
                           -3   -2      -1      0     1       2      3      4   5
                                Iterated Function System of 4 transformations
orbits (F, y0, n1, n2, [x, x0, xf, xstep], options, . . . );                    [Function]
      Draws the orbits diagram for a family of one-dimensional discrete dynamical systems,
      with one parameter x; that kind of diagram is used to study the bifurcations of an
      one-dimensional discrete system.
      The function F(y) defines a sequence with a starting value of y0, as in the case of the
      function evolution, but in this case that function will also depend on a parameter
      x that will take values in the interval from x0 to xf with increments of xstep. Each
      value used for the parameter x is shown on the horizontal axis. The vertical axis
      will show the n2 values of the sequence y(n1+1),..., y(n1+n2+1) obtained after letting
      the sequence evolve n1 iterations. In addition to the options accepted by plot2d, it
      accepts an option pixels that sets up the maximum number of different points that
      will be represented in the vertical direction.
1.5
0.5
                         0
                  x    -0.5
-1
-1.5
                        -2
                              -2          -1.5       -1         -0.5          0
                                                          a
     To enlarge the region around the lower bifurcation near x = -1.25 use:
           (%i2) orbits(x^2+a, 0, 100, 400, [a,-1,-1.53], [x,-1.6,-0.8],
                          [nticks, 400], [style,dots]);
-0.8
-0.9
-1
-1.1
                       -1.2
                  x
-1.3
-1.4
-1.5
                       -1.6
                                   -1.5    -1.4    -1.3       -1.2     -1.1       -1
                                                          a
     The interpretation and allowed values of the input parameters is the same as for
     the function evolution. A staircase diagram consists of a plot of the function F(y),
     together with the line G(y) = y. A vertical segment is drawn from the point (y0, y0)
     on that line until the point where it intersects the function F. From that point a
     horizontal segment is drawn until it reaches the point (y1, y1) on the line, and the
     procedure is repeated n times until the point (yn, yn) is reached. The options are the
     same as for plot2d.
906                                                                Maxima 5.45.0 Manual
Example.
1.2
                            0.8
                   y(n+1)
0.6
0.4
0.2
                             0
                                  0   0.2   0.4    0.6   0.8      1      1.2
                                                  y(n)
     By holding down the left button of the mouse while it is moved on the graphics
     window, the camera can be rotated showing different views of the pyramid. The two
     plot options [scene_elevation], page 908 and [scene_azimuth], page 908 can
     also be used to change the initial orientation of the viewing camera. The camera
     can be moved by holding the middle mouse button while moving it and holding the
     right-side mouse button while moving it up or down will zoom in or out.
     Each object option should be a list starting with the option name, followed by its
     value. The list of allowed options can be found in the [object_options], page 910
     section.
     Example. This will show a sphere falling to the ground and bouncing off without
     losing any energy. To start or pause the animation, press the play/pause button.
            (%i1) p: makelist ([0,0,2.1- 9.8*t^2/2], t, 0, 0.64, 0.01)$
      The restart option was used to make the animation restart automatically every time
      the last point in the position list is reached. The accepted values for the colors are
      the same as for the color option of plot2d.
     The height, in pixels, of the graphics window. pixels must be a positive integer
     number.
restart [restart, value]                                                       [Scene option]
     Default value: false
     A true value means that animations will restart automatically when the end of the
     list is reached. Writing just “restart” is equivalent to [restart, true].
tstep [tstep, time]                                                       [Scene option]
     Default value: 10
     The amount of time, in mili-seconds, between iterations among consecutive animation
     frames. time must be a real number.
width [width, pixels]                                                [Scene option]
     Default value: 500
     The width, in pixels, of the graphics window. pixels must be a positive integer
     number.
windowname [windowtitle, name]                                         [Scene option]
     Default value: .scene
     name must be a string that can be used as the name of the Tk window created by
     Xmaxima for the scene graphics. The default value .scene implies that a new top
     level window will be created.
windowtitle [windowtitle, name]                                               [Scene option]
     Default value: Xmaxima: scene
     name must be a string that will be written in the title of the window created by
     scene.
56 engineering-format
Engineering-format changes the way maxima outputs floating-point numbers to the notation
engineers are used to: a*10^b with b dividable by three.
57 ezunits
   For the purpose of dimensional analysis, a list of fundamental dimensions and an asso-
ciated list of fundamental units are maintained; by default the fundamental dimensions are
length, mass, time, charge, temperature, and quantity, and the fundamental units are the
associated SI units, but other fundamental dimensions and units can be declared.
            (%o2)                       300 ‘ kg
            (%i3) 100 ‘ m^3 - 100 ‘ m^3;
                                              3
            (%o3)                        0 ‘ m
            (%i4) (10 ‘ kg) * (17 ‘ m/s^2);
                                             kg m
            (%o4)                      170 ‘ ----
                                               2
                                              s
            (%i5) (x ‘ m) / (y ‘ s);
                                          x   m
            (%o5)                         - ‘ -
                                          y   s
            (%i6) (a ‘ m)^2;
                                          2     2
            (%o6)                        a ‘ m
‘‘                                                                              [Operator]
      The unit conversion operator. An expression a‘b‘‘c converts from unit b to unit c.
      ezunits has built-in conversions for SI base units, SI derived units, and some non-
      SI units. Unit conversions not already known to ezunits can be declared. The
      unit conversions known to ezunits are specified by the global variable known_unit_
      conversions, which comprises built-in and user-defined conversions. Conversions
      for products, quotients, and powers of units are derived from the set of known unit
      conversions.
      There is no preferred system for display of units; input units are not converted to
      other units unless conversion is explicitly indicated. ezunits does not attempt to
      simplify units by prefixes (milli-, centi-, deci-, etc) unless such conversion is explicitly
      indicated.
      load ("ezunits") enables this operator.
      Examples:
      The set of known unit conversions.
            (%i1)   load ("ezunits")$
            (%i2)   display2d : false$
            (%i3)   known_unit_conversions;
            (%o3)   {acre = 4840*yard^2,Btu = 1055*J,cfm = feet^3/minute,
                     cm = m/100,day = 86400*s,feet = 381*m/1250,ft = feet,
                     g = kg/1000,gallon = 757*l/200,GHz = 1000000000*Hz,
                     GOhm = 1000000000*Ohm,GPa = 1000000000*Pa,
                     GWb = 1000000000*Wb,Gg = 1000000*kg,Gm = 1000000000*m,
                     Gmol = 1000000*mol,Gs = 1000000000*s,ha = hectare,
                     hectare = 100*m^2,hour = 3600*s,Hz = 1/s,inch = feet/12,
                     km = 1000*m,kmol = 1000*mol,ks = 1000*s,l = liter,
                     lbf = pound_force,lbm = pound_mass,liter = m^3/1000,
                     metric_ton = Mg,mg = kg/1000000,MHz = 1000000*Hz,
                     microgram = kg/1000000000,micrometer = m/1000000,
Chapter 57: ezunits                                                             923
                                            211    hour
            (%i7) %, numer;
                                                    Btu
            (%o7)               3.412322274881517 ‘ ----
                                                    hour
            (%i8) 100 ‘ degC ‘‘ degF;
            (%o8)                      212 ‘ degF
            (%i9) -40 ‘ degF ‘‘ degC;
            (%o9)                     (- 40) ‘ degC
            (%i10) 1 ‘ acre*ft ‘‘ m^3;
                                    60228605349    3
            (%o10)                  ----------- ‘ m
                                     48828125
            (%i11) %, numer;
                                                      3
            (%o11)                1233.48183754752 ‘ m
      Coercing quantities in feet and meters to one or the other.
            (%i1) load ("ezunits")$
            (%i2) 100 ‘ m + 100 ‘ ft;
            (%o2)                  100 ‘ m + 100 ‘ ft
            (%i3) (100 ‘ m + 100 ‘ ft) ‘‘ ft;
            Computing conversions to base units; may take a moment.
                                       163100
            (%o3)                      ------ ‘ ft
                                        381
            (%i4) %, numer;
            (%o4)                428.0839895013123 ‘ ft
            (%i5) (100 ‘ m + 100 ‘ ft) ‘‘ m;
                                        3262
            (%o5)                       ---- ‘ m
                                         25
            (%i6) %, numer;
            (%o6)                      130.48 ‘ m
      Dimensional analysis to find fundamental dimensions and fundamental units.
            (%i1) load ("ezunits")$
            (%i2) foo : 1 ‘ acre * ft;
            (%o2)                      1 ‘ acre ft
            (%i3) dimensions (foo);
                                               3
            (%o3)                        length
            (%i4) fundamental_units (foo);
                                            3
            (%o4)                          m
            (%i5) foo ‘‘ m^3;
            Computing conversions to base units; may take a moment.
                                    60228605349    3
Chapter 57: ezunits                                                                   925
           (%o5)                        ----------- ‘ m
                                         48828125
           (%i6) %, numer;
                                                         3
           (%o6)                     1233.48183754752 ‘ m
     Declared unit conversions.
           (%i1) load ("ezunits")$
           (%i2) declare_unit_conversion (MMBtu = 10^6*Btu, kW = 1000*W);
           (%o2)                          done
           (%i3) declare_unit_conversion (kWh = kW*hour, MWh = 1000*kWh,
                                           bell = 1800*s);
           (%o3)                          done
           (%i4) 1 ‘ kW*s ‘‘ MWh;
           Computing conversions to base units; may take a moment.
                                        1
           (%o4)                     ------- ‘ MWh
                                     3600000
           (%i5) 1 ‘ kW/m^2 ‘‘ MMBtu/bell/ft^2;
                                  1306449       MMBtu
           (%o5)                 ---------- ‘ --------
                                 8242187500            2
                                               bell ft
                                                  lbm
            (%o2)                           100 ‘ ----
                                                  acre
            (%i3) FOO * (50 ‘ acre);
            (%o3)                          50 FOO ‘ acre
            (%i4) constvalue (%);
            (%o4)                           5000 ‘ lbm
     Example:
           (%i1)   load ("ezunits")$
           (%i2)   units (aa);
           (%o2)                                 1
           (%i3)   declare_units (aa, J);
           (%o3)                                 J
           (%i4)   units (aa);
           (%o4)                                 J
           (%i5)   units (aa^2);
                                                 2
           (%o5)                                J
           (%i6) foo : 100 ‘ kg;
           (%o6)                            100 ‘ kg
           (%i7) units (aa * foo);
           (%o7)                               kg J
            (%o3)                                 xx
            (%i4) qty (aa^2);
                                                    2
            (%o4)                                 xx
            (%i5) foo : 100 ‘ kg;
            (%o5)                             100 ‘ kg
            (%i6) qty (aa * foo);
            (%o6)                               100 xx
                                    cattle length
           (%i5) dimensions (x ‘ smile/kg);
                                       happiness
           (%o5)                       ---------
                                         mass
           (%i6) fundamental_units (money*cattle/happiness);
           0 errors, 0 warnings
                                      dollar goat
           (%o6)                      -----------
                                         smile
            (%o5)                     [3, 0, - 1, 0, 0, 0]
fundamental_units                                                               [Function]
        fundamental_units (x)
        fundamental_units ()
      fundamental_units(x) returns the units associated with the fundamental dimensions
      of x. as determined by dimensions(x).
      x may be a literal dimensional expression a‘b, a symbol with declared units via
      declare_units, or an expression containing either or both of those.
      fundamental_units() returns the list of all known fundamental units, as declared
      by declare_fundamental_units.
      load ("ezunits") loads this function.
      Examples:
             (%i1) load ("ezunits")$
             (%i2) fundamental_units ();
             (%o2)                   [m, kg, s, A, K, mol]
             (%i3) fundamental_units (100 ‘ mile/hour);
                                                m
             (%o3)                               -
                                                s
             (%i4) declare_units (aa, g/foot^2);
                                                g
             (%o4)                            -----
                                                   2
                                              foot
             (%i5) fundamental_units (aa);
                                               kg
             (%o5)                             --
                                                2
                                               m
dimensionless (L)                                                               [Function]
      Returns a basis for the dimensionless quantities which can be formed from a list L of
      dimensional quantities.
      load ("ezunits") loads this function.
      Examples:
             (%i1) load ("ezunits") $
             (%i2) dimensionless ([x ‘ m, y ‘ m/s, z ‘ s]);
             0 errors, 0 warnings
             0 errors, 0 warnings
                                                    y z
             (%o2)                                 [---]
                                                     x
      Dimensionless quantities derived from fundamental physical quantities. Note that the
      first element on the list is proportional to the fine-structure constant.
             (%i1) load ("ezunits") $
Chapter 57: ezunits                                                              933
58 f90
      Examples:
            (%i1) load ("f90")$
            (%i2) foo : expand ((xxx + yyy + 7)^4);
                       4              3          3           2     2              2
            (%o2) yyy + 4 xxx yyy + 28 yyy + 6 xxx yyy + 84 xxx yyy
                        2         3               2
             + 294 yyy + 4 xxx yyy + 84 xxx yyy + 588 xxx yyy + 1372 yyy
                   4          3            2
             + xxx + 28 xxx + 294 xxx + 1372 xxx + 2401
            (%i3) f90 ('foo = foo);
            foo = yyy**4+4*xxx*yyy**3+28*yyy**3+6*xxx**2*yyy**2+84*xxx*yyy**2&
            &+294*yyy**2+4*xxx**3*yyy+84*xxx**2*yyy+588*xxx*yyy+1372*yyy+xxx**&
            &4+28*xxx**3+294*xxx**2+1372*xxx+2401
            (%o3)                             false
      Multiple expressions. Capture standard output into a file via the with_stdout func-
      tion.
            (%i1) load ("f90")$
            (%i2) foo : sin (3*x + 1) - cos (7*x - 2);
            (%o2)                 sin(3 x + 1) - cos(7 x - 2)
            (%i3) with_stdout ("foo.f90",
                                  f90 (x=0.25, y=0.625, 'foo=foo, 'stop, 'end));
            (%o3)                             false
            (%i4) printfile ("foo.f90");
            x = 0.25
            y = 0.625
            foo = sin(3*x+1)-cos(7*x-2)
            stop
            end
            (%o4)                            foo.f90
                                                                                        937
59 finance
fv (rate,PV,num)                                                                 [Function]
      We can calculate the future value of a Present one given a certain interest rate. rate
      is the interest rate, PV is the present value and num is the number of periods.
      Example:
            (%i1) load("finance")$
            (%i2) fv(0.12,1000,3);
            (%o2)                          1404.928
pv (rate,FV,num)                                                                 [Function]
      We can calculate the present value of a Future one given a certain interest rate. rate
      is the interest rate, FV is the future value and num is the number of periods.
      Example:
            (%i1) load("finance")$
            (%i2) pv(0.12,1000,3);
            (%o2)                711.7802478134108
     Example:
         (%i1) load("finance")$
         (%i2) res:irr([-5000,0,800,1300,1500,2000],0)$
         (%i3) rhs(res[1][1]);
         (%o3)                .03009250374237132
60 fractals
      Example:
          (%i1) load("fractals")$
          (%i2) n: 10000$
          (%i3) plot2d([discrete,fernfale(n)], [style,dots])$
           (%i2) julia_parameter:1+.1*%i$
           (%i3) plot3d (julia_sin, [x, -2, 2], [y, -3, 3],
                            [gnuplot_preamble, "set view map"],
                            [gnuplot_pm3d, true],
                            [grid, 150, 150])$
     See also julia_parameter.
61 ggf
62 graphs
          (%i3) print_graph(g)$
          Graph on 3 vertices with 3 edges.
          Adjacencies:
             3 : 1 2
             2 : 3 1
             1 : 3 2
      Example 3: create a directed graph:
          (%i1) load ("graphs")$
          (%i2) d : create_graph(
                    [1,2,3,4],
                    [
                      [1,3], [1,4],
                      [2,3], [2,4]
                    ],
                    'directed = true)$
          (%i3) print_graph(d)$
          Digraph on 4 vertices with 4 arcs.
          Adjacencies:
             4 :
             3 :
             2 : 4 3
             1 : 4 3
clebsch_graph ()                                                        [Function]
      Returns the Clebsch graph.
Chapter 62: graphs                                                        951
dodecahedron_graph ()                                               [Function]
     Returns the dodecahedron graph.
frucht_graph ()                                                     [Function]
     Returns the Frucht graph.
great_rhombicosidodecahedron_graph ()                                                  [Function]
      Returns the great rhombicosidodecahedron graph.
great_rhombicuboctahedron_graph ()                                                     [Function]
      Returns the great rhombicuboctahedron graph.
grotzch_graph ()                                                                       [Function]
      Returns the Grotzch graph.
heawood_graph ()                                                                       [Function]
      Returns the Heawood graph.
icosahedron_graph ()                                                                   [Function]
      Returns the icosahedron graph.
icosidodecahedron_graph ()                                                             [Function]
      Returns the icosidodecahedron graph.
make_graph                                                                             [Function]
        make_graph (vrt, f)
        make_graph (vrt, f, oriented)
      Creates a graph using a predicate function f.
      vrt is a list/set of vertices or an integer. If vrt is an integer, then vertices of the graph
      will be integers from 1 to vrt.
      f is a predicate function. Two vertices a and b will be connected if f(a,b)=true.
      If directed is not false, then the graph will be directed.
Chapter 62: graphs                                                                     953
     Example 1:
           (%i1)   load("graphs")$
           (%i2)   g : make_graph(powerset({1,2,3,4,5}, 2), disjointp)$
           (%i3)   is_isomorphic(g, petersen_graph());
           (%o3)                           true
           (%i4)   get_vertex_label(1, g);
           (%o4)                          {1, 2}
     Example 2:
           (%i1)   load("graphs")$
           (%i2)   f(i, j) := is (mod(j, i)=0)$
           (%i3)   g : make_graph(20, f, directed=true)$
           (%i4)   out_neighbors(4, g);
           (%o4)                      [8, 12, 16, 20]
           (%i5)   in_neighbors(18, g);
           (%o5)                      [1, 2, 3, 6, 9]
new_graph ()                                                                  [Function]
     Returns the graph with no vertices and no edges.
petersen_graph                                                                [Function]
        petersen_graph ()
        petersen_graph (n, d)
     Returns the petersen graph P {n,d}. The default values for n and d are n=5 and d=2.
random_regular_graph                                                          [Function]
        random_regular_graph (n)
        random_regular_graph (n, d)
     Returns a random d-regular graph on n vertices. The default value for d is d=3.
get_edge_weight                                                               [Function]
        get_edge_weight (e, gr)
        get_edge_weight (e, gr, ifnot)
     Returns the weight of the edge e in the graph gr.
958                                                                 Maxima 5.45.0 Manual
      If there is no weight assigned to the edge, the function returns 1. If the edge is not
      present in the graph, the function signals an error or returns the optional argument
      ifnot.
      Example:
             (%i1) load ("graphs")$
             (%i2) c5 : cycle_graph(5)$
             (%i3) get_edge_weight([1,2], c5);
             (%o3)                                 1
             (%i4) set_edge_weight([1,2], 2.0, c5);
             (%o4)                               done
             (%i5) get_edge_weight([1,2], c5);
             (%o5)                                2.0
            (%i2) p : petersen_graph()$
            (%i3) hp : hamilton_path(p);
            (%o3)            [0, 5, 7, 2, 1, 6, 8, 3, 4, 9]
            (%i4) draw_graph(p, show_edges=vertices_to_path(hp))$
isomorphism (gr1, gr2)                                                      [Function]
      Returns a an isomorphism between graphs/digraphs gr1 and gr2. If gr1 and gr2 are
      not isomorphic, it returns an empty list.
      Example:
            (%i1) load ("graphs")$
            (%i2) clk5:complement_graph(line_graph(complete_graph(5)))$
            (%i3) isomorphism(clk5, petersen_graph());
            (%o3) [9 -> 0, 2 -> 1, 6 -> 2, 5 -> 3, 0 -> 4, 1 -> 5, 3 -> 6,
                                                          4 -> 7, 7 -> 8, 8 -> 9]
in_neighbors (v, gr)                                                               [Function]
      Returns the list of in-neighbors of the vertex v in the directed graph gr.
      Example:
           (%i1) load ("graphs")$
           (%i2) p : path_digraph(3)$
           (%i3) in_neighbors(2, p);
           (%o3)                                   [1]
           (%i4) out_neighbors(2, p);
           (%o4)                                   []
is_biconnected (gr)                                                                [Function]
      Returns true if gr is 2-connected and false otherwise.
      Example:
           (%i1) load ("graphs")$
           (%i2) is_biconnected(cycle_graph(5));
           (%o2)                               true
           (%i3) is_biconnected(path_graph(5));
           (%o3)                               false
is_bipartite (gr)                                                                  [Function]
      Returns true if gr is bipartite (2-colorable) and false otherwise.
      Example:
           (%i1) load ("graphs")$
           (%i2) is_bipartite(petersen_graph());
           (%o2)                                 false
           (%i3) is_bipartite(heawood_graph());
           (%o3)                                 true
is_connected (gr)                                                                  [Function]
      Returns true if the graph gr is connected and false otherwise.
      Example:
           (%i1) load ("graphs")$
Chapter 62: graphs                                                                   961
      Example:
          (%i1) load ("graphs")$
          (%i2) clk5:complement_graph(line_graph(complete_graph(5)))$
          (%i3) is_isomorphic(clk5, petersen_graph());
          (%o3)                         true
              [[3,4], 0.1],
              [[3,5], 0.1],
              [[4,6], 1.0],
              [[5,6], 1.0]],
             directed=true)$
           (%i3) [flow_value, flow] : max_flow(net, 1, 6);
           (%o3) [0.7, [[[1, 2], 0.5], [[1, 3], 0.2], [[2, 4], 0.2],
           [[2, 5], 0.3], [[3, 4], 0.1], [[3, 5], 0.1], [[4, 6], 0.3],
           [[5, 6], 0.4]]]
           (%i4) fl : 0$
           (%i5) for u in out_neighbors(1, net)
                do fl : fl + assoc([1, u], flow)$
           (%i6) fl;
           (%o6)                          0.7
max_independent_set (gr)                                                      [Function]
      Returns a maximum independent set of the graph gr.
      Example:
           (%i1) load ("graphs")$
           (%i2) d : dodecahedron_graph()$
           (%i3) mi : max_independent_set(d);
           (%o3)              [0, 3, 5, 9, 10, 11, 18, 19]
           (%i4) draw_graph(d, show_vertices=mi)$
max_matching (gr)                                                      [Function]
      Returns a maximum matching of the graph gr.
      Example:
           (%i1) load ("graphs")$
           (%i2) d : dodecahedron_graph()$
           (%i3) m : max_matching(d);
           (%o3) [[5, 7], [8, 9], [6, 10], [14, 19], [13, 18], [12, 17],
                                             [11, 16], [0, 15], [3, 4], [1, 2]]
           (%i4) draw_graph(d, show_edges=m)$
min_degree (gr)                                                               [Function]
      Returns the   minimum degree of vertices of the graph gr and a vertex of minimum
      degree.
      Example:
            (%i1)   load ("graphs")$
            (%i2)   g : random_graph(100, 0.1)$
            (%i3)   min_degree(g);
            (%o3)                          [3, 49]
            (%i4)   vertex_degree(21, g);
            (%o4)                             9
min_edge_cut (gr)                                                             [Function]
      Returns the minimum edge cut in the graph gr.
      See also edge_connectivity.
Chapter 62: graphs                                                                       965
      The algorithm used is the Demoucron’s algorithm, which is a quadratic time algo-
      rithm.
      Example:
            (%i1) load ("graphs")$
            (%i2) planar_embedding(grid_graph(3,3));
            (%o2) [[3, 6, 7, 8, 5, 2, 1, 0], [4, 3, 0, 1], [3, 4, 7, 6],
                                                      [8, 7, 4, 5], [1, 2, 5, 4]]
           (%o3)                          1.2
           (%i4) set_edge_weight([1,2], 2.1, g);
           (%o4)                         done
           (%i5) get_edge_weight([1,2], g);
           (%o5)                          2.1
           (%i2) p5 : path_digraph(5)$
           (%i3) print_graph(p5)$
           Digraph on 5 vertices with 4 arcs.
           Adjacencies:
             4 :
             3 : 4
             2 : 3
             1 : 2
             0 : 1
           (%i4) vertex_in_degree(4, p5);
           (%o4)                           1
           (%i5) in_neighbors(4, p5);
           (%o5)                          [3]
vertex_out_degree (v, gr)                                                      [Function]
     Returns the out-degree of the vertex v in the directed graph gr.
     Example:
          (%i1) load ("graphs")$
          (%i2) t : random_tournament(10)$
          (%i3) vertex_out_degree(0, t);
          (%o3)                                  2
          (%i4) out_neighbors(0, t);
          (%o4)                               [7, 1]
vertices (gr)                                                                  [Function]
     Returns the list of vertices in the graph gr.
     Example:
          (%i1) load ("graphs")$
          (%i2) vertices(complete_graph(4));
          (%o2)                             [3, 2, 1, 0]
vertex_coloring (gr)                                                           [Function]
     Returns an optimal coloring of the vertices of the graph gr.
     The function returns the chromatic number and a list representing the coloring of the
     vertices of gr.
     Example:
           (%i1) load ("graphs")$
           (%i2) p:petersen_graph()$
           (%i3) vertex_coloring(p);
           (%o3) [3, [[0, 2], [1, 3], [2, 2], [3, 3], [4, 1], [5, 3],
                                                   [6, 1], [7, 1], [8, 2], [9, 2]]]
wiener_index (gr)                                                              [Function]
     Returns the Wiener index of the graph gr.
     Example:
          (%i2) wiener_index(dodecahedron_graph());
          (%o2)                                500
970                                                                     Maxima 5.45.0 Manual
     Example:
           (%i1) load ("graphs")$
           (%i2) g : empty_graph(4)$
           (%i3) connect_vertices(0, [1,2,3], g)$
           (%i4) print_graph(g)$
           Graph on 4 vertices with 3 edges.
           Adjacencies:
             3 : 0
             2 : 0
             1 : 0
             0 : 3 2 1
dimacs_export                                                                       [Function]
        dimacs_export (gr, fl)
        dimacs_export (gr, fl, comment1, ..., commentn)
      Exports the graph into the file fl in the DIMACS format. Optional comments will be
      added to the top of the file.
62.2.5 Visualization
draw_graph                                                                      [Function]
        draw_graph (graph)
        draw_graph (graph, option1, ..., optionk)
     Draws the graph using the Chapter 53 [draw-pkg], page 779, package.
     The algorithm used to position vertices is specified by the optional argument program.
     The default value is program=spring_embedding. draw graph can also use the
     graphviz programs for positioning vertices, but graphviz must be installed separately.
     Example 1:
           (%i1) load ("graphs")$
           (%i2) g:grid_graph(10,10)$
           (%i3) m:max_matching(g)$
           (%i4) draw_graph(g,
              spring_embedding_depth=100,
              show_edges=m, edge_type=dots,
              vertex_size=0)$
     Example 2:
           (%i1) load ("graphs")$
           (%i2) g:create_graph(16,
               [
                [0,1],[1,3],[2,3],[0,2],[3,4],[2,4],
                [5,6],[6,4],[4,7],[6,7],[7,8],[7,10],[7,11],
                [8,10],[11,10],[8,9],[11,12],[9,15],[12,13],
                [10,14],[15,14],[13,14]
               ])$
           (%i3) t:minimum_spanning_tree(g)$
           (%i4) draw_graph(
               g,
               show_edges=edges(t),
               show_edge_width=4,
               show_edge_color=green,
               vertex_type=filled_square,
               vertex_size=2
               )$
     Example 3:
           (%i1) load ("graphs")$
           (%i2) g:create_graph(16,
               [
                [0,1],[1,3],[2,3],[0,2],[3,4],[2,4],
                [5,6],[6,4],[4,7],[6,7],[7,8],[7,10],[7,11],
                [8,10],[11,10],[8,9],[11,12],[9,15],[12,13],
                [10,14],[15,14],[13,14]
               ])$
           (%i3) mi : max_independent_set(g)$
974                                                     Maxima 5.45.0 Manual
          (%i4) draw_graph(
               g,
               show_vertices=mi,
               show_vertex_type=filled_up_triangle,
               show_vertex_size=2,
               edge_color=cyan,
               edge_width=3,
               show_id=true,
               text_color=brown
               )$
      Example 4:
          (%i1) load ("graphs")$
          (%i2) net : create_graph(
               [0,1,2,3,4,5],
               [
                 [[0,1], 3], [[0,2], 2],
                 [[1,3], 1], [[1,4], 3],
                 [[2,3], 2], [[2,4], 2],
                 [[4,5], 2], [[3,5], 2]
               ],
               directed=true
               )$
          (%i3) draw_graph(
               net,
               show_weight=true,
               vertex_size=0,
               show_vertices=[0,5],
               show_vertex_type=filled_square,
               head_length=0.2,
               head_angle=10,
               edge_color="dark-green",
               text_color=blue
               )$
      Example 5:
          (%i1) load("graphs")$
          (%i2) g: petersen_graph(20, 2);
          (%o2)                           GRAPH
          (%i3) draw_graph(g, redraw=true, program=planar_embedding);
          (%o3)                           done
      Example 6:
          (%i1) load("graphs")$
          (%i2) t: tutte_graph();
          (%o2)                           GRAPH
          (%i3) draw_graph(t, redraw=true,
                                fixed_vertices=[1,2,3,4,5,6,7,8,9]);
          (%o3)                           done
Chapter 62: graphs                                                                       975
63 grobner
           (%i1) poly_add(z+x^2*y,x-z,[x,y,z]);
                                               2
           (%o1)                              x y + x
           (%i1) poly_subtract(z+x^2*y,x-z,[x,y,z]);
                                                 2
           (%o1)                          2 z + x y - x
           (%i2) poly_multiply(z+x^2*y,x-z,[x,y,z])-(z+x^2*y)*(x-z),expand;
           (%o1)                                  0
            (%i1) poly_expand((x-y)*(y+x),[x,y]);
                                                  2     2
            (%o1)                                x - y
            (%i2) poly_expand((y+x)^2,[x,y]);
                                            2             2
            (%o2)                          y + 2 x y + x
            (%i3) poly_expand((y+x)^5,[x,y]);
                              5      4          2 3         3 2 4   5
            (%o3)            y + 5 x y + 10 x y + 10 x y + 5 x y + x
            (%i4) poly_expand(-1-x*exp(y)+x^2/sqrt(y),[x]);
                                                       2
                                              y       x
            (%o4)                       - x %e + ------- - 1
                                                    sqrt(y)
            (%i5) poly_expand(-1-sin(x)^2+sin(x),[sin(x)]);
                                            2
            (%o5)                      - sin (x) + sin(x) - 1
            (%i1) poly_expt(x-y,3,[x,y])-(x-y)^3,expand;
            (%o1)                                  0
poly_content (poly. varlist)                                                        [Function]
      poly_content extracts the GCD of its coefficients
            (%i1) poly_content(35*y+21*x,[x,y]);
            (%o1)                                                  7
poly_pseudo_divide (poly, polylist, varlist)                                       [Function]
      Pseudo-divide a polynomial poly by the list of n polynomials polylist. Return multiple
      values. The first value is a list of quotients a. The second value is the remainder r.
      The third argument is a scalar coefficient c, such that c ∗ poly can be divided by
      polylist within the ring of coefficients, which is not necessarily a field. Finally, the
      fourth value is an integer count of the number of reductions performed. The resulting
      objects satisfy the equation:
                                           n
                                           X
                              c ∗ poly =         (ai ∗ polylisti ) + r
                                           i=1
Chapter 63: grobner                                                                              983
I(polylist) : poly ∞
     Geometrically, over an algebraically closed field, this is the set of polynomials in the
     ideal generated by polylist which do not identically vanish on the variety of poly.
I(polylist1) : I(polylist2)∞
     Geometrically, over an algebraically closed field, this is the set of polynomials in the
     ideal generated by polylist1 which do not identically vanish on the variety of polylist2.
64 hompack
65 impdiff
66 interpol
       + -------------------------------
                       84
      (%i4) f(x):=''%;
                     (x - 7) (x - 6) (x - 3) (x - 1)
      (%o4) f(x) := -------------------------------
                                    35
         (x - 8) (x - 6) (x - 3) (x - 1)
       - -------------------------------
                       12
         7 (x - 8) (x - 7) (x - 3) (x - 1)
       + ---------------------------------
                        30
         (x - 8) (x - 7) (x - 6) (x - 1)
       - -------------------------------
                       60
         (x - 8) (x - 7) (x - 6) (x - 3)
       + -------------------------------
                       84
      (%i5) /* Evaluate the polynomial at some points */
            expand(map(f,[2.3,5/7,%pi]));
                                         4          3           2
                           919062 73 %pi     701 %pi    8957 %pi
      (%o5) [- 1.567535, ------, ------- - -------- + ---------
                           84035     420       210         420
                                                    5288 %pi   186
                                                  - -------- + ---]
                                                      105       5
      (%i6) %,numer;
      (%o6) [- 1.567535, 10.9366573451538, 2.89319655125692]
      (%i7) load("draw")$ /* load draw package */
      (%i8) /* Plot the polynomial together with points */
            draw2d(
              color       = red,
              key         = "Lagrange polynomial",
              explicit(f(x),x,0,10),
              point_size = 3,
              color       = blue,
              key         = "Sample points",
              points(p))$
      (%i9) /* Change variable name */
            lagrange(p, varname=w);
             (w - 7) (w - 6) (w - 3) (w - 1)
      (%o9) -------------------------------
                            35
         (w - 8) (w - 6) (w - 3) (w - 1)
       - -------------------------------
                       12
Chapter 66: interpol                                                                    995
              7 (w - 8) (w - 7) (w - 3) (w - 1)
            + ---------------------------------
                             30
              (w - 8) (w - 7) (w - 6) (w - 1)
            - -------------------------------
                            60
              (w - 8) (w - 7) (w - 6) (w - 3)
            + -------------------------------
                            84
linearinterpol                                                                   [Function]
        linearinterpol (points)
        linearinterpol (points, option)
     Computes the polynomial interpolation by the linear method. Argument points must
     be either:
       • a two column matrix, p:matrix([2,4],[5,6],[9,3]),
       • a list of pairs, p: [[2,4],[5,6],[9,3]],
996                                                                   Maxima 5.45.0 Manual
       • a list of numbers, p: [4,6,3], in which case the abscissas will be assigned auto-
         matically to 1, 2, 3, etc.
      In the first two cases the pairs are ordered with respect to the first coordinate before
      making computations.
      With the option argument it is possible to select the name for the independent vari-
      able, which is 'x by default; to define another one, write something like varname='z.
      See also lagrange, cspline, and ratinterpol.
      Examples:
            (%i1) load("interpol")$
            (%i2) p: matrix([7,2],[8,3],[1,5],[3,2],[6,7])$
            (%i3) linearinterpol(p);
                    13   3 x
            (%o3) (-- - ---) charfun2(x, minf, 3)
                    2     2
             + (x - 5) charfun2(x, 7, inf) + (37 - 5 x) charfun2(x, 6, 7)
                5 x
             + (--- - 3) charfun2(x, 3, 6)
                 3
            (%i4) f(x):=''%;
                            13   3 x
            (%o4) f(x) := (-- - ---) charfun2(x, minf, 3)
                            2     2
             + (x - 5) charfun2(x, 7, inf) + (37 - 5 x) charfun2(x, 6, 7)
                5 x
             + (--- - 3) charfun2(x, 3, 6)
                 3
            (%i5) /* Evaluate the polynomial at some points */
                   map(f,[7.3,25/7,%pi]);
                                        62 5 %pi
            (%o5)                 [2.3, --, ----- - 3]
                                        21    3
            (%i6) %,numer;
            (%o6) [2.3, 2.952380952380953, 2.235987755982989]
            (%i7) load("draw")$ /* load draw package */
            (%i8) /* Plot the polynomial together with points */
                   draw2d(
                     color      = red,
                     key        = "Linear interpolator",
                     explicit(f(x),x,-5,20),
                     point_size = 3,
                     color      = blue,
                     key        = "Sample points",
                     points(args(p)))$
            (%i9) /* Change variable name */
Chapter 66: interpol                                                                       997
                   linearinterpol(p, varname='s);
                   13   3 s
           (%o9) (-- - ---) charfun2(s, minf, 3)
                   2     2
            + (s - 5) charfun2(s, 7, inf) + (37 - 5 s) charfun2(s, 6, 7)
               5 s
            + (--- - 3) charfun2(s, 3, 6)
                3
cspline                                                                              [Function]
          cspline (points)
          cspline (points, option1, option2, ...)
     Computes the polynomial interpolation by the cubic splines method. Argument points
     must be either:
       • a two column matrix, p:matrix([2,4],[5,6],[9,3]),
       • a list of pairs, p: [[2,4],[5,6],[9,3]],
       • a list of numbers, p: [4,6,3], in which case the abscissas will be assigned auto-
         matically to 1, 2, 3, etc.
     In the first two cases the pairs are ordered with respect to the first coordinate before
     making computations.
     There are three options to fit specific needs:
       • 'd1, default 'unknown, is the first derivative at x1 ; if it is 'unknown,   the second
         derivative at x1 is made equal to 0 (natural cubic spline); if it is        equal to a
         number, the second derivative is calculated based on this number.
       • 'dn, default 'unknown, is the first derivative at xn ; if it is 'unknown,   the second
         derivative at xn is made equal to 0 (natural cubic spline); if it is        equal to a
         number, the second derivative is calculated based on this number.
       • 'varname, default 'x, is the name of the independent variable.
     See also lagrange, linearinterpol, and ratinterpol.
     Examples:
           (%i1) load("interpol")$
           (%i2) p:[[7,2],[8,2],[1,5],[3,2],[6,7]]$
           (%i3) /* Unknown first derivatives at the extremes
                    is equivalent to natural cubic splines */
                 cspline(p);
                          3          2
                   1159 x     1159 x     6091 x 8283
           (%o3) (------- - ------- - ------ + ----) charfun2(x, minf, 3)
                    3288       1096       3288  1096
                        3          2
                 2587 x     5174 x     494117 x 108928
            + (- ------- + ------- - -------- + ------) charfun2(x, 7, inf)
                  1644        137        1644    137
                     3           2
998                                                Maxima 5.45.0 Manual
      (%i4) f(x):=''%$
      (%i5) /* Some evaluations */
            map(f,[2.3,5/7,%pi]), numer;
      (%o5) [1.991460766423356, 5.823200187269903, 2.227405312429507]
      (%i6) load("draw")$ /* load draw package */
      (%i7) /* Plotting interpolating function */
            draw2d(
               color         = red,
               key           = "Cubic splines",
               explicit(f(x),x,0,10),
               point_size = 3,
               color         = blue,
               key           = "Sample points",
               points(p))$
      (%i8) /* New call, but giving values at the derivatives */
            cspline(p,d1=0,dn=0);
                      3             2
               1949 x       11437 x       17027 x     1247
      (%o8) (------- - -------- + ------- + ----) charfun2(x, minf, 3)
                2256          2256         2256       752
                   3             2
            1547 x       35581 x       68068 x     173546
       + (- ------- + -------- - ------- + ------) charfun2(x, 7, inf)
               564          564           141       141
                3             2
          607 x      35147 x       55706 x      38420
       + (------ - -------- + ------- - -----) charfun2(x, 6, 7)
           188          564           141        47
                   3            2
            3895 x       1807 x       5146 x     2148
       + (- ------- + ------- - ------ + ----) charfun2(x, 3, 6)
             5076           188        141        47
      (%i8) /* Defining new interpolating function */
            g(x):=''%$
      (%i9) /* Plotting both functions together */
            draw2d(
               color         = black,
               key           = "Cubic splines (default)",
               explicit(f(x),x,0,10),
Chapter 66: interpol                                                                     999
                       color      = red,
                       key        = "Cubic splines (d1=0,dn=0)",
                       explicit(g(x),x,0,10),
                       point_size = 3,
                       color      = blue,
                       key        = "Sample points",
                       points(p))$
ratinterpol                                                                       [Function]
        ratinterpol (points, numdeg)
        ratinterpol (points, numdeg, option1)
     Generates a rational interpolator for data given by points and the degree of the
     numerator being equal to numdeg; the degree of the denominator is calculated auto-
     matically. Argument points must be either:
       • a two column matrix, p:matrix([2,4],[5,6],[9,3]),
       • a list of pairs, p: [[2,4],[5,6],[9,3]],
       • a list of numbers, p: [4,6,3], in which case the abscissas will be assigned auto-
         matically to 1, 2, 3, etc.
     In the first two cases the pairs are ordered with respect to the first coordinate before
     making computations.
     There is one option to fit specific needs:
       • 'varname, default 'x, is the name of the independent variable.
     See also lagrange, linearinterpol, cspline, minpack_lsquares, and Chapter 68
     [lbfgs-pkg], page 1009,
     Examples:
            (%i1) load("interpol")$
            (%i2) load("draw")$
            (%i3) p:[[7.2,2.5],[8.5,2.1],[1.6,5.1],[3.4,2.4],[6.7,7.9]]$
            (%i4) for k:0 thru length(p)-1 do
                     draw2d(
                        explicit(ratinterpol(p,k),x,0,9),
                        point_size = 3,
                        points(p),
                        title = concat("Degree of numerator = ",k),
                        yrange=[0,10])$
                                                                                      1001
67 lapack
                                                             [ - .856714     - .745378 ]
                                                             [                         ]]
                                                             [ .515792       - .666642 ]
             (%i6) D : apply (diag_matrix, L);
                                   [ 7.54331      0     ]
             (%o6)                  [                   ]
                                   [     0    12.4067 ]
             (%i7) M . v - v . D;
                             [       0.0      - 8.88178E-16 ]
             (%o7)           [                              ]
                             [ - 8.88178E-16        0.0     ]
             (%i8) transpose (u) . M - D . transpose (u);
                                  [ 0.0 - 4.44089E-16 ]
             (%o8)                [                       ]
                                  [ 0.0       0.0        ]
     The elements of A and b must evaluate to real floating point numbers via float;
     thus elements may be any numeric type, symbolic numerical constants, or expressions
     which evaluate to floats. The elements of x are always floating point numbers. All
     arithmetic is carried out as floating point operations.
     dgesv computes the solution via the LU decomposition of A.
     Examples:
     dgesv computes the solution of the linear equation Ax = b.
           (%i1) A : matrix ([1, -2.5], [0.375, 5]);
                                          [   1     - 2.5 ]
           (%o1)                          [               ]
                                          [ 0.375     5   ]
           (%i2) b : matrix ([1.75], [-0.625]);
                                             [ 1.75     ]
           (%o2)                             [          ]
                                             [ - 0.625 ]
           (%i3) x : dgesv (A, b);
                                       [ 1.210526315789474 ]
           (%o3)                       [                     ]
                                       [ - 0.215789473684211 ]
           (%i4) dlange (inf_norm, b - A.x);
           (%o4)                                  0.0
     b is a matrix with the same number of rows as A and any number of columns. x is
     the same size as b.
           (%i1) A : matrix ([1, -0.15], [1.82, 2]);
                                          [ 1     - 0.15 ]
           (%o1)                           [             ]
                                          [ 1.82    2    ]
           (%i2) b : matrix ([3.7, 1, 8], [-2.3, 5, -3.9]);
                                         [ 3.7    1    8   ]
           (%o2)                         [                 ]
                                         [ - 2.3 5 - 3.9 ]
           (%i3) x : dgesv (A, b);
                 [ 3.103827540695117 1.20985481742191      6.781786185657722 ]
           (%o3) [                                                           ]
                 [ -3.974483062032557 1.399032116146062 -8.121425428948527 ]
           (%i4) dlange (inf_norm, b - A . x);
           (%o4)                       1.1102230246251565E-15
     The elements of A and b must evaluate to real floating point numbers.
           (%i1) A : matrix ([5, -%pi], [1b0, 11/17]);
                                          [   5    - %pi          ]
                                          [                       ]
           (%o1)                          [         11            ]
                                          [ 1.0b0   --            ]
                                          [         17            ]
           (%i2) b : matrix ([%e], [sin(1)]);
1004                                                                  Maxima 5.45.0 Manual
                                                       [   %e   ]
             (%o2)                                     [        ]
                                                       [ sin(1) ]
             (%i3) x : dgesv (A, b);
                                          [ 0.690375643155986 ]
             (%o3)                        [                   ]
                                          [ 0.233510982552952 ]
             (%i4) dlange (inf_norm, b - A . x);
             (%o4)                        2.220446049250313E-16
dgesvd                                                                             [Function]
           dgesvd (A)
           dgesvd (A, left_p, right_p)
       Computes the singular value decomposition (SVD) of a matrix A, comprising the
       singular values and, optionally, the left and right singular vectors. All elements of A
       must be integer or floating point numbers. A might or might not be square (same
       number of rows and columns).
       Let m be the number of rows, and n the number of columns of A. The singular value
       decomposition of A comprises three matrices, U, Sigma, and V^T, such that
       A = U .Sigma.V T
       where U is an m-by-m unitary matrix, Sigma is an m-by-n diagonal matrix, and V^T
       is an n-by-n unitary matrix.
       Let sigma[i] be a diagonal element of Sigma, that is, Sigma[i, i] = sigma[i]. The ele-
       ments sigma[i] are the so-called singular values of A; these are real and nonnegative,
       and returned in descending order. The first min(m, n) columns of U and V are the
       left and right singular vectors of A. Note that dgesvd returns the transpose of V, not
       V itself.
       dgesvd(A) computes only the singular values of A. dgesvd(A, left_p, right_p)
       computes the singular values of A and the left singular vectors when left p = true
       and the right singular vectors when right p = true.
       A list of three items is returned. The first item is a list of the singular values. The
       second item is false or the matrix of left singular vectors. The third item is false
       or the matrix of right singular vectors.
       Example:
             (%i1) load ("lapack")$
             (%i2) fpprintprec : 6;
             (%o2)                           6
             (%i3) M: matrix([1, 2, 3], [3.5, 0.5, 8], [-1, 2, -3], [4, 9, 7]);
                                     [ 1     2    3 ]
                                     [               ]
                                     [ 3.5 0.5    8 ]
             (%o3)                   [               ]
                                     [ - 1   2   - 3 ]
                                     [               ]
                                     [ 4     9    7 ]
Chapter 67: lapack                                                           1005
dgemm                                                                              [Function]
             dgemm (A, B)
             dgemm (A, B, options)
       Compute the product of two matrices and optionally add the product to a third
       matrix.
       In the simplest form, dgemm(A, B) computes the product of the two real matrices, A
       and B.
       In the second form, dgemm computes the alpha∗A∗B +beta∗C where A, B, C are real
       matrices of the appropriate sizes and alpha and beta are real numbers. Optionally,
       A and/or B can be transposed before computing the product. The extra parameters
       are specified by optional keyword arguments: The keyword arguments are optional
       and may be specified in any order. They all take the form key=val. The keyword
       arguments are:
       C            The matrix C that should be added. The default is false, which means
                    no matrix is added.
       alpha        The product of A and B is multiplied by this value. The default is 1.
       beta         If a matrix C is given, this value multiplies C before it is added. The
                    default value is 0, which implies that C is not added, even if C is given.
                    Hence, be sure to specify a non-zero value for beta.
       transpose_a
                 If true, the transpose of A is used instead of A for the product. The
                 default is false.
Chapter 67: lapack                                                             1007
     transpose_b
               If true, the transpose of B is used instead of B for the product. The
               default is false.
             (%i9) dgemm(A,B,c=C,beta=1);
                                      [ - 27.0 - 34.0             - 41.0  ]
                                      [                                   ]
             (%o9)                    [ - 60.0 - 76.0             - 92.0 ]
                                      [                                   ]
                                      [ - 93.0 - 118.0            - 143.0 ]
             (%i10) A . B + C;
                                         [ - 27 - 34            - 41  ]
                                         [                            ]
             (%o10)                      [ - 60 - 76            - 92 ]
                                         [                            ]
                                         [ - 93 - 118           - 143 ]
             (%i11) dgemm(A,B,c=C,beta=1, alpha=-1);
                                         [ 33.0   38.0            43.0  ]
                                         [                              ]
             (%o11)                      [ 72.0   86.0            100.0 ]
                                         [                              ]
                                         [ 111.0 134.0            157.0 ]
             (%i12) -A . B + C;
                                            [ 33   38           43  ]
                                            [                       ]
             (%o12)                         [ 72   86           100 ]
                                            [                       ]
                                            [ 111 134           157 ]
zgeev                                                                            [Function]
           zgeev (A)
           zgeev (A, right_p, left_p)
       Like dgeev, but the matrix A is complex.
zheev                                                                            [Function]
           zheev (A)
           zheev (A, eigvec_p)
       Like zheev, but the matrix A is assumed to be a square complex Hermitian matrix.
       If eigvec p is true, then the eigenvectors of the matrix are also computed.
       No check is made that the matrix A is, in fact, Hermitian.
       A list of two items is returned, as in dgeev: a list of eigenvalues, and false or the
       matrix of the eigenvectors.
                                                                                         1009
68 lbfgs
                    iprint[1] > 0
                              Print a message every iprint[1] iterations.
       iprint[2]
                    iprint[2] controls the verbosity of progress messages.
                    iprint[2] = 0
                              Print out iteration count, number of evaluations of FOM,
                              value of FOM, norm of the gradient of FOM, and step length.
                    iprint[2] = 1
                              Same as iprint[2] = 0, plus X0 and the gradient of FOM
                              evaluated at X0.
                    iprint[2] = 2
                              Same as iprint[2] = 1, plus values of X at each iteration.
                    iprint[2] = 3
                              Same as iprint[2] = 2, plus the gradient of FOM at each
                              iteration.
       The columns printed by lbfgs are the following.
       I            Number of iterations. It is incremented for each line search.
       NFN          Number of evaluations of the figure of merit.
       FUNC         Value of the figure of merit at the end of the most recent line search.
       GNORM        Norm of the gradient of the figure of merit at the end of the most recent
                    line search.
       STEPLENGTH
                    An internal parameter of the search algorithm.
       Additional information concerning details of the algorithm are found in the comments
       of the original Fortran code [2].
       See also lbfgs_nfeval_max and lbfgs_ncorrections.
       References:
       [1] D. Liu and J. Nocedal. "On the limited memory BFGS method for large scale
       optimization". Mathematical Programming B 45:503–528 (1989)
       [2] https://www.netlib.org/opt/lbfgs_um.shar
       Examples:
       The same FOM as computed by FGCOMPUTE in the program sdrive.f in the LBFGS
       package from Netlib. Note that the variables in question are subscripted variables.
       The FOM has an exact minimum equal to zero at u[k] = 1 for k = 1, ..., 8.
             (%i1) load ("lbfgs")$
             (%i2) t1[j] := 1 - u[j];
             (%o2)                         t1 := 1 - u
                                              j             j
             (%i3) t2[j] := 10*(u[j + 1] - u[j]^2);
                                                                2
Chapter 68: lbfgs                                                           1011
            (%o3)                  t2 := 10 (u      - u )
                                     j        j + 1    j
            (%i4) n : 8;
            (%o4)                             8
            (%i5) FOM : sum (t1[2*j - 1]^2 + t2[2*j - 1]^2, j, 1, n/2);
                               2 2          2              2 2          2
            (%o5) 100 (u - u ) + (1 - u ) + 100 (u - u ) + (1 - u )
                        8      7          7          6     5          5
                                   2 2           2             2 2          2
                    + 100 (u - u ) + (1 - u ) + 100 (u - u ) + (1 - u )
                             4     3           3         2     1          1
            (%i6) lbfgs (FOM, '[u[1],u[2],u[3],u[4],u[5],u[6],u[7],u[8]],
                   [-1.2, 1, -1.2, 1, -1.2, 1, -1.2, 1], 1e-3, [1, 0]);
            *************************************************
              N=    8    NUMBER OF CORRECTIONS=25
                   INITIAL VALUES
             F= 9.680000000000000D+01     GNORM= 4.657353755084533D+02
            *************************************************
 I   NFN   FUNC                     GNORM                STEPLENGTH
                         A             2            A              2
             + (----------------- - 1) + (----------------- - 0.5)
                   - B (3 - C)                - B (2 - C)
                 %e            + 1          %e            + 1
                          2
                         A
             + --------------------)/5
                   - B (1 - C)     2
               (%e             + 1)
            (%i7) estimates : lbfgs (FOM, '[A, B, C], [1, 1, 1], 1e-4, [1, 0]);
            *************************************************
              N=     3   NUMBER OF CORRECTIONS=25
                    INITIAL VALUES
             F= 1.348738534246918D-01     GNORM= 2.000215531936760D-01
            *************************************************
*************************************************
lbfgs_nfeval_max                                                                [Variable]
        Default value: 100
        lbfgs_nfeval_max is the maximum number of evaluations of the figure of merit
        (FOM) in lbfgs. When lbfgs_nfeval_max is reached, lbfgs returns the result of
        the last successful line search.
lbfgs_ncorrections                                                              [Variable]
        Default value: 25
        lbfgs_ncorrections is the number of corrections applied to the approximate inverse
        Hessian matrix which is maintained by lbfgs.
                                                                                           1015
69 lindstedt
(%i2) load("lindstedt")$
         (%i3) Lindstedt('diff(x,t,2)+x-(e*x^3)/6,e,2,[1,0]);
                      2
                     e (cos(5 T) - 24 cos(3 T) + 23 cos(T))
         (%o3) [[[---------------------------------------
                                          36864
             e (cos(3 T) - cos(T))
           - --------------------- + cos(T)],
                         192
                      2
                   7 e     e
         T = (- ---- - -- + 1) t]]
                   3072    16
    To use this function write first load("makeOrders") and load("lindstedt").
                                                                        1017
70 linearalgebra
                                 3         2
       (%o8)                   [z - 15 z - 18 z]
       (%i9) MM : ratsimp (MM);
                      [ 4 5 - z                 6          ]
                      [                                    ]
                      [                   2                ]
       (%o9)          [     66         7 z - 102 z - 132 ]
                      [ 0   --     - ------------------ ]
                      [     49                    49       ]
                      [                                    ]
                      [ 0    0                  0          ]
       (%i10) nullspace (MM);
                                [          1            ]
                                [                       ]
                                [    2                  ]
                                [ z - 14 z - 16 ]
                                [ -------------- ]
       (%o10)             span([            8           ])
                                [                       ]
                                [      2                ]
                                [    z - 18 z - 12 ]
                                [ - -------------- ]
                                [            12         ]
       (%i11) M : matrix ([1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12],
                          [13, 14, 15, 16]);
                              [ 1     2    3     4 ]
                              [                      ]
                              [ 5     6    7     8 ]
       (%o11)                  [                     ]
                              [ 9     10 11 12 ]
                              [                      ]
                              [ 13 14 15 16 ]
       (%i12) columnspace (M);
                                   [ 1 ] [ 2 ]
                                   [      ] [        ]
                                   [ 5 ] [ 6 ]
       (%o12)                span([       ], [       ])
                                   [ 9 ] [ 10 ]
                                   [      ] [        ]
                                   [ 13 ] [ 14 ]
       (%i13) apply ('orthogonal_complement, args (nullspace (transpose (M))));
                                   [ 0 ] [ 1 ]
                                   [     ] [         ]
                                   [ 1 ] [ 0 ]
       (%o13)                span([      ], [        ])
                                   [ 2 ] [ - 1 ]
                                   [     ] [         ]
Chapter 70: linearalgebra                                                              1019
[ 3 ] [ - 2 ]
                                              [   [ 1   0 ]   [ 0   0 ] ]
                                              [   [       ]   [       ] ]
                                              [   [ 0   2 ]   [ 0   0 ] ]
            (%o1)                             [                         ]
                                              [   [ 0   0 ]   [ 3   0 ] ]
                                              [   [       ]   [       ] ]
                                              [   [ 0   0 ]   [ 0   4 ] ]
            (%i2) diag_matrix(p,q);
                                                        [ p   0 ]
            (%o2)                                       [       ]
                                                        [ 0   q ]
eigens_by_jacobi                                                                [Function]
        eigens_by_jacobi (A)
        eigens_by_jacobi (A, field_type)
       Computes the eigenvalues and eigenvectors of A by the method of Jacobi rotations.
       A must be a symmetric matrix (but it need not be positive definite nor positive
       semidefinite). field type indicates the computational field, either floatfield or
       bigfloatfield. If field type is not specified, it defaults to floatfield.
       The elements of A must be numbers or expressions which evaluate to numbers via
       float or bfloat (depending on field type).
       Examples:
            (%i1) S: matrix([1/sqrt(2), 1/sqrt(2)],[-1/sqrt(2), 1/sqrt(2)]);
                                      [      1              1     ]
                                      [ -------        ------- ]
                                      [ sqrt(2)        sqrt(2) ]
            (%o1)                     [                           ]
                                      [        1            1     ]
                                      [ - ------- ------- ]
                                      [    sqrt(2) sqrt(2) ]
            (%i2) L : matrix ([sqrt(3), 0], [0, sqrt(5)]);
                                       [ sqrt(3)          0     ]
            (%o2)                       [                       ]
                                       [     0       sqrt(5) ]
            (%i3) M : S . L . transpose (S);
                            [ sqrt(5)     sqrt(3) sqrt(5)           sqrt(3) ]
                            [ ------- + ------- ------- - ------- ]
                            [    2           2            2            2    ]
            (%o3)           [                                               ]
                            [ sqrt(5)     sqrt(3) sqrt(5)           sqrt(3) ]
                            [ ------- - ------- ------- + ------- ]
                            [    2           2            2            2    ]
Chapter 70: linearalgebra                                                             1021
hankel                                                                          [Function]
          hankel (col)
          hankel (col, row)
     Return a Hankel matrix H. The first column of H is col; except for the first entry,
     the last row of H is row. The default for row is the zero vector with the same length
     as col.
                                            [   2         2      ]
                                            [ d F        d F     ]
                                            [ ---       -----    ]
                                            [     2     da db    ]
                                            [ da                 ]
             (%o3)                          [                    ]
                                            [   2          2     ]
                                            [ d F         d F    ]
                                            [ -----       ---    ]
                                            [ da db          2   ]
                                            [             db     ]
hilbert_matrix (n)                                                               [Function]
       Return the n by n Hilbert matrix. When n isn’t a positive integer, signal an error.
identfor                                                                                [Function]
        identfor (M)
        identfor (M, fld)
       Return an identity matrix that has the same shape as the matrix M. The diagonal
       entries of the identity matrix are the multiplicative identity of the field fld; the default
       for fld is generalring.
       The first argument M should be a square matrix or a non-matrix. When M is a
       matrix, each entry of M can be a square matrix – thus M can be a blocked Maxima
       matrix. The matrix can be blocked to any (finite) depth.
       See also zerofor
invert_by_lu (M, (rng generalring))                                             [Function]
       Invert a matrix M by using the LU factorization. The LU factorization is done using
       the ring rng.
jacobian (f, x)                                                                [Function]
       Returns the Jacobian matrix of the list of functions f with respect to the list of
       variables x. The (i, j)-th element of the Jacobian matrix is diff(f[i], x[j]).
       Examples:
             (%i1) jacobian ([sin (u - v), sin (u * v)], [u, v]);
                                  [ cos(v - u) - cos(v - u) ]
             (%o1)                [                               ]
                                  [ v cos(u v)      u cos(u v) ]
             (%i2) depends ([F, G], [y, z]);
             (%o2)                     [F(y, z), G(y, z)]
             (%i3) jacobian ([F, G], [y, z]);
                                             [ dF dF ]
                                             [ -- -- ]
                                             [ dy dz ]
             (%o3)                           [         ]
                                             [ dG dG ]
                                             [ -- -- ]
                                             [ dy dz ]
Chapter 70: linearalgebra                                                                1023
listp                                                                              [Function]
          listp (e, p)
          listp (e)
     Given an optional argument p, return true if e is a Maxima list and p evaluates to
     true for every list element. When listp is not given the optional argument, return
     true if e is a Maxima list. In all other cases, return false.
       (%o3)                                 [   ]
                                             [ c ]
       (%i4) x : lu_backsub(M,b);
                                    [                3 a      ]
                                    [       3 (c - -----)     ]
                                    [               1 - z     ]
                                    [ a - -----------------   ]
                                    [                9        ]
                                    [     (- z) - ----- + 8   ]
                                    [             1 - z       ]
                                    [ ---------------------   ]
       (%o4)                        [         1 - z           ]
                                    [                         ]
                                    [            3 a          ]
                                    [       c - -----         ]
                                    [           1 - z         ]
                                    [   -----------------     ]
                                    [             9           ]
                                    [   (- z) - ----- + 8     ]
                                    [           1 - z         ]
       (%i5) ratsimp(A . x - b);
                                             [ 0 ]
       (%o5)                                 [   ]
                                             [ 0 ]
       (%i6) B : matrix([a,d],[c,f]);
                                           [ a   d ]
       (%o6)                               [       ]
                                           [ c   f ]
       (%i7) x : lu_backsub(M,B);
                      [                3 a                     3 d       ]
                      [       3 (c - -----)            3 (f - -----)     ]
                      [               1 - z                   1 - z      ]
                      [ a - -----------------    d - -----------------   ]
                      [                9                       9         ]
                      [     (- z) - ----- + 8        (- z) - ----- + 8   ]
                      [             1 - z                    1 - z       ]
                      [ ---------------------    ---------------------   ]
       (%o7)          [         1 - z                    1 - z           ]
                      [                                                  ]
                      [            3 a                      3 d          ]
                      [       c - -----                f - -----         ]
                      [           1 - z                    1 - z         ]
                      [   -----------------        -----------------     ]
                      [             9                        9           ]
                      [   (- z) - ----- + 8        (- z) - ----- + 8     ]
                      [           1 - z                    1 - z         ]
       (%i8) ratsimp(A . x - B);
Chapter 70: linearalgebra                                                                  1025
                                                        [ 0    0 ]
           (%o8)                                        [        ]
                                                        [ 0    0 ]
       members. After that all that remains is to define a Common Lisp structure mring.
       The file mring has many examples.
       To compute the factorization, the first task is to convert each matrix entry to a mem-
       ber of the indicated field. When conversion isn’t possible, the factorization halts with
       an error message. Members of the field needn’t be Maxima expressions. Members
       of the complexfield, for example, are Common Lisp complex numbers. Thus af-
       ter computing the factorization, the matrix entries must be converted to Maxima
       expressions.
Examples:
mat_cond                                                                        [Function]
        mat_cond (M, 1)
        mat_cond (M, inf)
     Return the p-norm matrix condition number of the matrix m. The allowed values
     for p are 1 and inf. This function uses the LU factorization to invert the matrix
     m. Thus the running time for mat_cond is proportional to the cube of the matrix
     size; lu_factor determines lower and upper bounds for the infinity norm condition
     number in time proportional to the square of the matrix size.
mat_norm                                                                        [Function]
        mat_norm (M, 1)
        mat_norm (M, inf)
        mat_norm (M, frobenius)
     Return the matrix p-norm of the matrix M. The allowed values for p are 1, inf,
     and frobenius (the Frobenius matrix norm). The matrix M should be an unblocked
     matrix.
matrixp                                                                         [Function]
          matrixp (e, p)
          matrixp (e)
     Given an optional argument p, return true if e is a matrix and p evaluates to true
     for every matrix element. When matrixp is not given an optional argument, return
     true if e is a matrix. In all other cases, return false.
     See also blockmatrixp
matrix_size (M)                                                              [Function]
     Return a two member list that gives the number of rows and columns, respectively of
     the matrix M.
mat_fullunblocker (M)                                                            [Function]
     If M is a block matrix, unblock the matrix to all levels. If M is a matrix, return M ;
     otherwise, signal an error.
mat_trace (M)                                                                [Function]
     Return the trace of the matrix M. If M isn’t a matrix, return a noun form. When
     M is a block matrix, mat_trace(M) returns the same value as does mat_trace(mat_
     unblocker(m)).
mat_unblocker (M)                                                              [Function]
     If M is a block matrix, unblock M one level. If M is a matrix, mat_unblocker (M)
     returns M ; otherwise, signal an error.
     Thus if each entry of M is matrix, mat_unblocker (M) returns an unblocked matrix,
     but if each entry of M is a block matrix, mat_unblocker (M) returns a block matrix
     with one less level of blocking.
     If you use block matrices, most likely you’ll want to set matrix_element_mult to "."
     and matrix_element_transpose to 'transpose. See also mat_fullunblocker.
     Example:
            (%i1) A : matrix ([1, 2], [3, 4]);
1028                                                                   Maxima 5.45.0 Manual
                                            [    1  2 ]
             (%o1)                          [         ]
                                            [    3 4 ]
             (%i2)   B : matrix ([7, 8], [9,     10]);
                                            [    7 8 ]
             (%o2)                          [           ]
                                            [    9 10 ]
             (%i3)   matrix ([A, B]);
                                    [ [ 1 2      ]   [ 7      8  ] ]
             (%o3)                  [ [          ]   [           ] ]
                                    [ [ 3 4      ]   [ 9      10 ] ]
             (%i4)   mat_unblocker (%);
                                        [ 1      2   7    8  ]
             (%o4)                      [                    ]
                                        [ 3      4   9    10 ]
toeplitz                                                                            [Function]
        toeplitz (col)
        toeplitz (col, row)
     Return a Toeplitz matrix T. The first first column of      T is col; except for the first
     entry, the first row of T is row. The default for row      is complex conjugate of col.
     Example:
           (%i1) toeplitz([1,2,3],[x,y,z]);
                                                   [ 1 y         z ]
                                                   [               ]
           (%o1)                                   [ 2 1         y ]
                                                   [               ]
                                                   [ 3 2         1 ]
           (%i2) toeplitz([1,1+%i]);
                                                 [   1        1 - %I ]
           (%o2)                                 [                   ]
                                                 [ %I + 1       1    ]
zerofor                                                                             [Function]
          zerofor (M)
          zerofor (M, fld)
     Return a zero matrix that has the same shape as the matrix M. Every entry of the
     zero matrix is the additive identity of the field fld; the default for fld is generalring.
     The first argument M should be a square matrix or a non-matrix. When M is a
     matrix, each entry of M can be a square matrix – thus M can be a blocked Maxima
     matrix. The matrix can be blocked to any (finite) depth.
     See also identfor
71 lsquares
           (%i4) f: y=a*exp(b*t);
                                              b t
           (%o4)                      y = a %e
           (%i5) yvalues_log: log(yvalues)$
           (%i6) f_log: log(subst(y=exp(y),f));
                                               b t
           (%o6)                   y = log(a %e    )
           (%i7) lsquares_estimates (transpose(matrix(yvalues_log,time)),
                                     [y,t], f_log, [a,b]);
           *************************************************
             N=    2   NUMBER OF CORRECTIONS=25
                  INITIAL VALUES
            F= 6.802906290754687D+00    GNORM= 2.851243373781393D+01
           *************************************************
                                            [ 3        ]
                                            [ - 1 2 ]
                                            [ 2        ]
                                            [          ]
             (%o2)                          [ 9        ]
                                            [ - 2 1 ]
                                            [ 4        ]
                                            [          ]
                                            [ 3 2 2 ]
                                            [          ]
                                            [ 2 2 1 ]
             (%i3)   mse : lsquares_mse (M, [z, x, y], (z + D)^2 = A*x + B*y + C);
                        5
                       ====
                       \                                             2     2
                        >     ((- B M     ) - A M      + (M      + D) - C)
                       /              i, 3        i, 2      i, 1
                       ====
                       i = 1
             (%o3)     -------------------------------------------------
                                                 5
             (%i4)   lsquares_estimates_exact (mse, [A, B, C, D]);
                                  59          27      10921         107
             (%o4)        [[A = - --, B = - --, C = -----, D = - ---]]
                                  16          16      1024          32
     where n is the number of data and e[i] is the equation e evaluated with the variables
     in x assigned values from the i-th datum, D[i].
     load(lsquares) loads this function.
     Example:
           (%i1) load ("lsquares")$
           (%i2) M : matrix (
                      [1,1,1], [3/2,1,2], [9/4,2,1], [3,2,2], [2,2,1]);
1036                                                   Maxima 5.45.0 Manual
                                     [ 1 1 1 ]
                                     [          ]
                                     [ 3        ]
                                     [ - 1 2 ]
                                     [ 2        ]
                                     [          ]
       (%o2)                         [ 9        ]
                                     [ - 2 1 ]
                                     [ 4        ]
                                     [          ]
                                     [ 3 2 2 ]
                                     [          ]
                                     [ 2 2 1 ]
       (%i3)   mse : lsquares_mse (M, [z, x, y], (z + D)^2 = A*x + B*y + C);
                  5
                 ====
                 \                                            2     2
                  >    ((- B M     ) - A M      + (M      + D) - C)
                 /             i, 3        i, 2      i, 1
                 ====
                 i = 1
       (%o3)     -------------------------------------------------
                                          5
       (%i4)   diff (mse, D);
       (%o4)
             5
            ====
            \                                                       2
          4 >     (M     + D) ((- B M     ) - A M      + (M     + D) - C)
            /       i, 1             i, 3        i, 2      i, 1
            ====
            i = 1
          --------------------------------------------------------------
                                        5
       (%i5) ''mse, nouns;
                      2                 2          9 2                2
       (%o5) (((D + 3) - C - 2 B - 2 A) + ((D + -) - C - B - 2 A)
                                                   4
                  2               2          3 2                2
        + ((D + 2) - C - B - 2 A) + ((D + -) - C - 2 B - A)
                                             2
                  2             2
        + ((D + 1) - C - B - A) )/5
Chapter 71: lsquares                                                                      1037
           (%i3) mse : lsquares_mse (M, [z, x, y], (z + D)^2 = A*x + B*y + C);
                       5
                     ====
                     \                     2                           2
                       >     ((D + M     ) - C - M       B - M      A)
                     /               i, 1           i, 3       i, 2
                     ====
                     i = 1
           (%o3)      ---------------------------------------------
                                              5
           (%i4) diff (mse, D);
                    5
                   ====
                   \                                  2
                 4 >      (D + M      ) ((D + M     ) - C - M       B - M       A)
                   /             i, 1           i, 1           i, 3       i, 2
                   ====
                   i = 1
           (%o4) ----------------------------------------------------------
                                                 5
           (%i5) ''mse, nouns;
                           2                    2         9 2                 2
           (%o5) (((D + 3) - C - 2 B - 2 A) + ((D + -) - C - B - 2 A)
                                                          4
                       2                 2          3 2                 2
            + ((D + 2) - C - B - 2 A) + ((D + -) - C - 2 B - A)
                                                    2
                       2               2
            + ((D + 1) - C - B - A) )/5
     where e[i] is the equation e evaluated with the variables in x assigned values from
     the i-th datum, D[i], and assigning any remaining free variables from a.
     load(lsquares) loads this function.
     Example:
           (%i1) load ("lsquares")$
           (%i2) M : matrix (
1038                                                               Maxima 5.45.0 Manual
       where e[i] is the equation e evaluated with the variables in x assigned values from
       the i-th datum, D[i], and assigning any remaining free variables from a.
       load(lsquares) loads this function.
       Example:
             (%i1) load ("lsquares")$
             (%i2) M : matrix (
                       [1,1,1], [3/2,1,2], [9/4,2,1], [3,2,2], [2,2,1]);
                                            [ 1 1 1 ]
                                            [           ]
                                            [ 3         ]
                                            [ - 1 2 ]
                                            [ 2         ]
                                            [           ]
Chapter 71: lsquares                                                                  1039
           (%o2)                        [ 9        ]
                                        [ - 2 1 ]
                                        [ 4        ]
                                        [          ]
                                        [ 3 2 2 ]
                                        [          ]
                                        [ 2 2 1 ]
           (%i3)   a : lsquares_estimates (
                    M, [z,x,y], (z+D)^2 = A*x+B*y+C, [A,B,C,D]);
                               59         27      10921       107
           (%o3)       [[A = - --, B = - --, C = -----, D = - ---]]
                               16         16      1024        32
           (%i4)   lsquares_residual_mse (
                    M, [z,x,y], (z + D)^2 = A*x + B*y + C, first (a));
                                            169
           (%o4)                             ----
                                            2560
plsquares                                                                       [Function]
        plsquares (Mat,VarList,depvars)
        plsquares (Mat,VarList,depvars,maxexpon)
        plsquares (Mat,VarList,depvars,maxexpon,maxdegree)
     Multivariable polynomial adjustment of a data table by the "least squares" method.
     Mat is a matrix containing the data, VarList is a list of variable names (one for each
     Mat column, but use "-" instead of varnames to ignore Mat columns), depvars is the
     name of a dependent variable or a list with one or more names of dependent variables
     (which names should be in VarList), maxexpon is the optional maximum exponent
     for each independent variable (1 by default), and maxdegree is the optional maximum
     polynomial degree (maxexpon by default); note that the sum of exponents of each
     term must be equal or smaller than maxdegree, and if maxdgree = 0 then no limit is
     applied.
     If depvars is the name of a dependent variable (not in a list), plsquares returns
     the adjusted polynomial. If depvars is a list of one or more dependent variables,
     plsquares returns a list with the adjusted polynomial(s). The Coefficients of De-
     termination are displayed in order to inform about the goodness of fit, which ranges
     from 0 (no correlation) to 1 (exact correlation). These values are also stored in the
     global variable DETCOEF (a list if depvars is a list).
     A simple example of multivariable linear adjustment:
           (%i1) load("plsquares")$
           (%i2) plsquares(matrix([1,2,0],[3,5,4],[4,7,9],[5,8,10]),
                           [x,y,z],z);
                Determination Coefficient for z = .9897039897039897
                                  11 y - 9 x - 14
           (%o2)              z = ---------------
                                         3
1040                                                            Maxima 5.45.0 Manual
72 minpack
73 makeOrders
         (%i2) makeOrders([a,b],[2,3]);
         (%o2) [[0, 0], [0, 1], [0, 2], [0, 3], [1, 0], [1, 1],
                         [1, 2], [1, 3], [2, 0], [2, 1], [2, 2], [2, 3]]
         (%i3) expand((1+a+a^2)*(1+b+b^2+b^3));
                   2 3         3      3    2 2       2    2     2
         (%o3) a b + a b + b + a b + a b + b + a b + a b
                                                                       2
                                                            + b + a + a + 1
    where [0, 1] is associated with the term b and [2, 3] with a2 b3 .
    To use this function write first load("makeOrders").
                                                                                          1045
74 mnewton
75 numericalio
read_array                                                                            [Function]
        read_array (S, A)
        read_array (S, A, separator_flag)
       Reads the source S into the array A, until A is full or the source is exhausted. Input
       data are read into the array in row-major order; the input need not conform to the
       dimensions of A.
Chapter 75: numericalio                                                               1049
read_hash_table                                                                 [Function]
        read_hash_table (S, A)
        read_hash_table (S, A, separator_flag)
     Reads the source S and returns its entire content as a hashed array. The source S
     may be a file name or a stream.
     read_hash_table treats the first item on each line as a hash key, and associates the
     remainder of the line (as a list) with the key. For example, the line 567 12 17 32 55
     is equivalent to A[567]: [12, 17, 32, 55]$. Lines need not have the same numbers
     of elements.
     The recognized values of separator flag are comma, pipe, semicolon, and space. If
     separator flag is not specified, the file is assumed space-delimited.
     See also openr, read_matrix, read_array, read_list and read_nested_list.
read_nested_list                                                                [Function]
        read_nested_list (S)
        read_nested_list (S, separator_flag)
     Reads the source S and returns its entire content as a nested list. The source S may
     be a file name or a stream.
     read_nested_list returns a list which has a sublist for each line of input. Lines
     need not have the same numbers of elements. Empty lines are not ignored: an empty
     line yields an empty sublist.
     The recognized values of separator flag are comma, pipe, semicolon, and space. If
     separator flag is not specified, the file is assumed space-delimited.
     See also openr, read_matrix, read_array, read_list and read_hash_table.
read_list                                                                       [Function]
        read_list   (S)
        read_list   (S, L)
        read_list   (S, separator_flag)
        read_list   (S, L, separator_flag)
     read_list(S) reads the source S and returns its entire content as a flat list.
     read_list(S, L) reads the source S into the list L, until L is full or the source is
     exhausted.
     The source S may be a file name or a stream.
     The recognized values of separator flag are comma, pipe, semicolon, and space. If
     separator flag is not specified, the file is assumed space-delimited.
     See also openr, read_matrix, read_array, read_nested_list, read_binary_list
     and read_hash_table.
1050                                                                 Maxima 5.45.0 Manual
write_data                                                                        [Function]
        write_data (X, D)
        write_data (X, D, separator_flag)
       Writes the object X to the destination D.
       write_data writes a matrix in row-major order, with one line per row.
       write_data writes an array created by array or make_array in row-major order,
       with a new line at the end of every slab. Higher-dimensional slabs are separated by
       additional new lines.
       write_data writes a hashed array with each key followed by its associated list on one
       line.
       write_data writes a nested list with each sublist on one line.
       write_data writes a flat list all on one line.
       The destination D may be a file name or a stream. When the destination is a file
       name, the global variable file_output_append governs whether the output file is
       appended or truncated. When the destination is a stream, no special action is taken
       by write_data after all the data are written; in particular, the stream remains open.
       The recognized values of separator flag are comma, pipe, semicolon, space, and tab.
       If separator flag is not specified, the file is assumed space-delimited.
       See also openw and read_matrix.
read_binary_list                                                                [Function]
        read_binary_list (S)
        read_binary_list (S, L)
     read_binary_list(S) reads the entire content of the source S as a sequence of binary
     8-byte floating point numbers, and returns it as a list. The source S may be a file
     name or a stream.
     read_binary_list(S, L) reads 8-byte binary floating point numbers from the source
     S until the list L is full, or the source is exhausted.
     The byte order in elements of the source is specified by assume_external_byte_
     order.
     See also read_list.
76 odepack
       for k : 1 thru 12 do
         block([],
           result: dlsode_step(y, t, tout, rtol, atol, istate, state),
           printf(true, "At t = ~12,4,2e   y = ~{~14,6,2e~}~%", result[1], result[2]),
           istate : result[3],
           tout : tout * 10);
   This produces the output:
       At   t   =   4.0000e-01    y   =    9.851726e-01 3.386406e-05         1.479357e-02
       At   t   =   4.0000e+00    y   =    9.055142e-01 2.240418e-05         9.446344e-02
       At   t   =   4.0000e+01    y   =    7.158050e-01 9.184616e-06         2.841858e-01
       At   t   =   4.0000e+02    y   =    4.504846e-01 3.222434e-06         5.495122e-01
       At   t   =   4.0000e+03    y   =    1.831701e-01 8.940379e-07         8.168290e-01
       At   t   =   4.0000e+04    y   =    3.897016e-02 1.621193e-07         9.610297e-01
       At   t   =   4.0000e+05    y   =    4.935213e-03 1.983756e-08         9.950648e-01
       At   t   =   4.0000e+06    y   =    5.159269e-04 2.064759e-09         9.994841e-01
       At   t   =   4.0000e+07    y   =    5.306413e-05 2.122677e-10         9.999469e-01
       At   t   =   4.0000e+08    y   =    5.494530e-06 2.197824e-11         9.999945e-01
       At   t   =   4.0000e+09    y   =    5.129458e-07 2.051784e-12         9.999995e-01
       At   t   =   4.0000e+10    y   =   -7.170563e-08 -2.868225e-13        1.000000e+00
     must be in the same order as the equations if fex. Finally, method indicates the
     method to be used by the solver:
     10          Nonstiff (Adams) method, no Jacobian used.
     21          Stiff (BDF) method, user-supplied full Jacobian.
     22          Stiff method, internally generated full Jacobian.
     The returned state object is a list of lists. The sublist is a list of two elements:
     f           The compiled function for the ODE.
     vars        The list independent and dependent variables (vars).
     mf          The method to be used (method).
     neq         The number of equations.
     lrw         Length of the work vector for real values.
     liw         Length of the work vector for integer values.
     rwork       Lisp array holding the real-valued work vector.
     iwork       Lisp array holding the integer-valued work vector.
     fjac        Compiled analytical Jacobian of the equations
     See also dlsode_step.
dlsode_step (inity, t, tout, rtol, atol, istate, state)                           [Function]
     Performs one step of the solver, returning the values of the independent and dependent
     variables, a success or error code.
     inity       For the first call (when istate = 1), the initial values
     t           Current value of the independent value
     tout        Next point where output is desired which must not be equal to t.
     rtol        relative tolerance parameter
     atol        Absolute tolerance parameter, scalar of vector. If scalar, it applies to
                 all dependent variables. Otherwise it must be the tolerance for each
                 dependent variable.
                 Use rtol = 0 for pure absolute error and use atol = 0 for pure relative
                 error.
     istate      1 for the first call to dlsode, 2 for subsequent calls.
     state       state returned by dlsode init.
     The output is a list of the following items:
     t           independent variable value
     y           list of values of the dependent variables at time t.
     istate      Integration status:
                 1            no work because tout = tt
1056                                                                 Maxima 5.45.0 Manual
                  2            successful result
                  -1           Excess work done on this call
                  -2           Excess accuracy requested
                  -3           Illegal input detected
                  -4           Repeated error test failures
                  -5           Repeated convergence failures (perhaps bad Jacobian or
                               wrong choice of mf or tolerances)
                  -6           Error weight because zero during problem (solution compo-
                               nent is vanished and atol(i) = 0.
       info       association list of various bits of information:
                  n_steps      total steps taken thus far
                  n_f_eval     total number of function evals
                  n_j_eval     total number of Jacobian evals
                  method_order
                            method order
                  len_rwork
                               Actual length used for real work array
                  len_iwork
                               Actual length used for integer work array
       See also dlsode_init.
                                                                                 1057
77 operatingsystem
78 opsubst
           (%i2) opsubst(f,g,g(g(x)));
           (%o2)                          f(f(x))
           (%i3) opsubst(f,g,g(g));
           (%o3)                            f(g)
           (%i4) opsubst(f,g[x],g[x](z));
           (%o4)                            f(z)
           (%i5) opsubst(g[x],f, f(z));
           (%o5)                           g (z)
                                            x
          (%i6) opsubst(tan, sin, sin(sin));
          (%o6)                           tan(sin)
          (%i7) opsubst([f=g,g=h],f(x));
          (%o7)                             h(x)
    Internally, Maxima does not use the unary negation, division, or the subtraction
    operators; thus:
          (%i8) opsubst("+","-",a-b);
          (%o8)                           a - b
          (%i9) opsubst("f","-",-a);
          (%o9)                            - a
          (%i10) opsubst("^^","/",a/b);
                                              a
          (%o10)                              -
                                              b
    The internal representation of -a*b is *(-1,a,b); thus
          (%i11) opsubst("[","*", -a*b);
          (%o11)                       [- 1, a, b]
    When either operator isn’t a Maxima symbol, generally some other function will signal
    an error:
          (%i12) opsubst(a+b,f, f(x));
1060                                                     Maxima 5.45.0 Manual
79 orthopoly
as graphics, you want to suppress the error and output only the center of the interval. To
do this, set the option variable orthopoly_returns_intervals to false.
       (%i1) orthopoly_returns_intervals : false;
       (%o1)                                false
       (%i2) jacobi_p (150, 2, 3, 0.2);
       (%o2)                        - 0.062017037936715
    Refer to the section see [Floating point Evaluation], page 1065, for more information.
    Most functions in orthopoly have a gradef property; thus
       (%i1) diff (hermite (n, x), x);
       (%o1)                           2 n H       (x)
                                             n - 1
       (%i2) diff (gen_laguerre (n, a, x), x);
                        (a)                    (a)
                    n L     (x) - (n + a) L          (x) unit_step(n)
                        n                      n - 1
       (%o2)        ------------------------------------------
                                             x
    The unit step function in the second example prevents an error that would otherwise
arise by evaluating with n equal to 0.
       (%i3) ev (%, n = 0);
       (%o3)                                   0
    The gradef property only applies to the “main” variable; derivatives with respect other
arguments usually result in an error message; for example
       (%i1) diff (hermite (n, x), x);
       (%o1)                           2 n H       (x)
                                             n - 1
       (%i2) diff (hermite (n, x), n);
       Maxima doesn't know the derivative of hermite with respect the first
       argument
        -- an error. Quitting. To debug this try debugmode(true);
    Generally, functions in orthopoly map over lists and matrices. For the mapping to
fully evaluate, the option variables doallmxops and listarith must both be true (the
defaults). To illustrate the mapping over matrices, consider
       (%i1) hermite (2, x);
                                                   2
       (%o1)                         - 2 (1 - 2 x )
       (%i2) m : matrix ([0, x], [y, 0]);
                                        [ 0 x ]
       (%o2)                            [       ]
                                        [ y 0 ]
       (%i3) hermite (2, m);
                          [                                  2 ]
                          [      - 2         - 2 (1 - 2 x ) ]
       (%o3)              [                                    ]
Chapter 79: orthopoly                                                                     1063
                        [               2                      ]
                        [ - 2 (1 - 2 y )             - 2       ]
   In the second example, the i, j element of the value is hermite (2, m[i,j]); this is
not the same as computing -2 + 4 m . m, as seen in the next example.
      (%i4) -2 * matrix ([1, 0], [0, 1]) + 4 * m . m;
                              [ 4 x y - 2          0     ]
      (%o4)                   [                          ]
                              [      0        4 x y - 2 ]
   If you evaluate a function at a point outside its domain, generally orthopoly returns
the function unevaluated. For example,
      (%i1) legendre_p (2/3, x);
      (%o1)                             P     (x)
                                          2/3
   orthopoly supports translation into TeX; it also does two-dimensional output on a
terminal.
      (%i1) spherical_harmonic (l, m, theta, phi);
                                     m
      (%o1)                         Y (theta, phi)
                                     l
      (%i2) tex (%);
      $$Y_{l}^{m}\left(\vartheta,\varphi\right)$$
      (%o2)                               false
      (%i3) jacobi_p (n, a, a - b, x/2);
                                     (a, a - b) x
      (%o3)                         P             (-)
                                     n             2
      (%i4) tex (%);
      $$P_{n}^{\left(a,a-b\right)}\left({{x}\over{2}}\right)$$
      (%o4)                               false
79.1.2 Limitations
When an expression involves several orthogonal polynomials with symbolic orders, it’s pos-
sible that the expression actually vanishes, yet Maxima is unable to simplify it to zero. If
you divide by such a quantity, you’ll be in trouble. For example, the following expression
vanishes for integers n greater than 1, yet Maxima is unable to simplify it to zero.
       (%i1) (2*n - 1) * legendre_p (n - 1, x) * x - n * legendre_p (n, x)
              + (1 - n) * legendre_p (n - 2, x);
       (%o1) (2 n - 1) P           (x) x - n P (x) + (1 - n) P             (x)
                             n - 1              n                   n - 2
    For a specific n, we can reduce the expression to zero.
       (%i2) ev (% ,n = 10, ratsimp);
       (%o2)                                  0
    Generally, the polynomial form of an orthogonal polynomial is ill-suited for floating point
evaluation. Here’s an example.
       (%i1) p : jacobi_p (100, 2, 3, x)$
1064                                                                  Maxima 5.45.0 Manual
      (%o3)                             3628800.0
   The default value of pochhammer_max_index is 100; change its value after loading
orthopoly.
   Finally, be aware that reference books vary on the definitions of the orthogonal polyno-
mials; we’ve generally used the conventions of Abramowitz and Stegun.
   Before you suspect a bug in orthopoly, check some special cases to determine if your
definitions match those used by orthopoly. Definitions often differ by a normalization; oc-
casionally, authors use “shifted” versions of the functions that makes the family orthogonal
on an interval other than (−1, 1). To define, for example, a Legendre polynomial that is
orthogonal on (0, 1), define
      (%i1) shifted_legendre_p (n, x) := legendre_p (n, 2*x - 1)$
   A user could define arithmetic operators that do interval math. To define interval addi-
tion, we can define
       (%i2) "@+"(x,y) := interval (part (x, 1) + part (y, 1), part (x, 2)
             + part (y, 2))$
   The special floating point routines get called when the arguments are complex. For
example,
    Additionally, when the arguments are big floats, the special floating point routines get
called; however, the big floats are converted into double floats and the final result is a
double.
   If function calls aren’t quoted, Maxima evaluates them to polynomials before plotting;
consequently, the specialized floating point code doesn’t get called. Here is an example of
how to plot an expression that involves a Legendre polynomial.
(%o1)
  1
                   -63*(1-x)5/8+315*(1-x)4/8-70*(1-x)3+105*(1-x)2/2-15*(1-x)+1
0.8
0.6
0.4
0.2
-0.2
-0.4
-0.6
       0       0.2               0.4               0.6              0.8          1
   The entire expression legendre_p (5, x) is quoted; this is different than just quoting
the function name using 'legendre_p (5, x).
                                 gamma(x + n)
       (%o1)                     ------------
                                   gamma(x)
       (%i2) sublis ([x=11/3, n= -6], q);
                                      729
       (%o2)                        - ----
                                      2240
   Alternatively, we can get this result directly.
       (%i1) pochhammer (11/3, -6);
                                            729
       (%o1)                              - ----
                                            2240
   The unit step function is left-continuous; thus
       (%i1) [unit_step (-1/10), unit_step (0), unit_step (1/10)];
       (%o1)                       [0, 0, 1]
   If you need an unit step function that is neither left or right continuous at zero, define
your own using signum; for example,
       (%i1) xunit_step (x) := (1 + signum (x))/2$
79.1.6 Algorithms
Generally, orthopoly does symbolic evaluation by using a hypergeometic representation
of the orthogonal polynomials. The hypergeometic functions are evaluated using the (un-
documented) functions hypergeo11 and hypergeo21. The exceptions are the half-integer
Bessel functions and the associated Legendre function of the second kind. The half-integer
Bessel functions are evaluated using an explicit representation, and the associated Legendre
function of the second kind is evaluated using recursion.
   For floating point evaluation, we again convert most functions into a hypergeometic form;
we evaluate the hypergeometic functions using forward recursion. Again, the exceptions are
the half-integer Bessel functions and the associated Legendre function of the second kind.
Numerically, the half-integer Bessel functions are evaluated using the SLATEC code.
                        n + 1                        n + 1
       The second argument to orthopoly_recur must be a list with the correct number of
       arguments for the function f ; if it isn’t, Maxima signals an error.
             (%i1) orthopoly_recur (jacobi_p, [n, x]);
orthopoly_returns_intervals                                                         [Variable]
       Default value: true
       When orthopoly_returns_intervals is true, floating point results are returned in
       the form interval (c, r), where c is the center of an interval and r is its radius. The
       center can be a complex number; in that case, the interval is a disk in the complex
       plane.
80 pytranslate
      • cons-to-ir looks for (caar expr) which specifies the type of expr, in hash-table
        *maxima-direct-ir-map* and if the type is found, then appends the retrieved IR
        with the result of lisp call (mapcar #'maxima-to-ir (cdr expr)), which applies
        maxima-to-ir function to all the elements present in the list. Effectively, recursively
        generate IR for all the elements present in expr and append them to the IR map
1076                                                               Maxima 5.45.0 Manual
81 ratpow
The package ratpow provides functions that find the exponents of the denominator in a
CRE polynomial. If the exponents in the denominator are needed instead ratdenom can
be used to extract this denominator first. Returned coefficients are in CRE form except for
numbers.
   In order to get a list of vars in a CRE polynomial showratvars can be used.
   For information about CREs see also rat, ratdisrep and showratvars.
82 romberg
83 simplex
83.1.1.2 NETLIB
Some smaller problems from netlib (https://www.netlib.org/lp/data/) test suite are
converted to a format, readable by Maxima. Problems are adlittle, afiro, kb2, sc50a
and share2b. Each problem has three input files in CSV format for matrix A and vectors
b and c.
   Example:
      A : read_matrix("adlittle_A.csv", 'csv)$
      b : read_list("adlittle_b.csv", 'csv)$
      c : read_list("adlittle_c.csv", 'csv)$
      linear_program(A, b, c)$
      %[2];
      => 225494.9631623802
   Results:
      PROBLEM          MINIMUM                      SCALING
      adlittle         +2.2549496316E+05            false
      afiro            -4.6475314286E+02            false
      kb2              -1.7499001299E+03            true
      sc50a            -6.4575077059E+01            false
1086                                                                Maxima 5.45.0 Manual
     There is also a limited ability to solve linear programs with symbolic constants.
           (%i1) declare(c,constant)$
           (%i2) maximize_lp(x+y, [y<=-x/c+3, y<=-x+4], [x, y]), epsilon_lp=0;
           Is (c-1)*c positive, negative or zero?
           p;
           Is c*(2*c-1) positive, negative or zero?
           p;
           Is c positive or negative?
           p;
           Is c-1 positive, negative or zero?
1088                                                             Maxima 5.45.0 Manual
             p;
             Is 2*c-1 positive, negative or zero?
             p;
             Is 3*c-4 positive, negative or zero?
             p;
                                                 1               1
             (%o2)                   [4, [x = -----, y = 3 - ---------]]
                                                   1              1
                                               1 - -         (1 - -) c
                                                   c              c
             (%i1) (assume(c>4/3), declare(c,constant))$
             (%i2) maximize_lp(x+y, [y<=-x/c+3, y<=-x+4], [x, y]), epsilon_lp=0;
                                                 1               1
             (%o2)                   [4, [x = -----, y = 3 - ---------]]
                                                   1              1
                                               1 - -         (1 - -) c
                                                   c              c
       See also: maximize_lp, nonnegative_lp, epsilon_lp.
pivot_count_sx                                                                [Variable]
       After linear_program returns, pivot_count_sx is the number of pivots in last com-
       putation.
pivot_max_sx                                                               [Variable]
       pivot_max_sx is the maximum number of pivots allowed by linear_program.
                                                                                          1089
84 simplification
             (%i2) p1:6*x^3+19*x^2+19*x+6;
                                     3       2
             (%o2)                6 x + 19 x + 19 x + 6
             (%i3) p2:6*x^5+13*x^4+12*x^3+13*x^2+6*x;
                               5       4        3     2
             (%o3)          6 x + 13 x + 12 x + 13 x + 6 x
             (%i4) gcdivide(p1, p2);
                                          x + 1
Chapter 84: simplification                                                             1093
           (%o4)                               ------
                                                3
                                               x + x
           (%i5) takegcd:false;
           (%o5)                         false
           (%i6) gcdivide(p1, p2);
                                  3        2
                               6 x + 19 x + 19 x + 6
           (%o6)          ----------------------------------
                             5       4        3      2
                          6 x + 13 x + 12 x + 13 x + 6 x
           (%i7) ratsimp(%);
                                        x + 1
           (%o7)                        ------
                                         3
                                        x + x
gd (x)                                                                           [Function]
     Returns the Gudermannian function 2*atan(%e^x)-%pi/2.
     To use this function write first load(functs).
1094                                                                Maxima 5.45.0 Manual
any that you might have defined); or you may be more selective by killing only some of
them; or use remrule on a specific rule.
     Note that if you load this package after defining your own rules you will clobber your
rules that have the same name. The rules in this package are: *rule1, ..., *rule8, +rule1,
..., +rule18, and you must enclose the rulename in quotes to refer to it, as in remrule
("+", "+rule1") to specifically remove the first rule on "+" or disprule ("*rule2") to
display the definition of the second multiplicative rule.
     Item (3) does not necessarily do an optimal job of pairwise factoring because of the
     combinatorially-difficult nature of finding which of all possible rearrangements of the
     pairs yields the most compact pair-factored result.
     load ("scifac") loads this function. demo ("scifac") shows a demonstration of
     this function.
                                                                                      1099
85 solve rec
                                         n - 1
                                         ====
                                         \
            (%t6)                    %z = >     %u
                                       n /        %j
                                         ====
                                         %j = 0
            (%o6)                (- n - 2) %u      - %u
                                             n + 1      n
1100                                                                   Maxima 5.45.0 Manual
                          n - 1
                          ====         j
                          \      (- 1)
                      %k n >    -------- + %k n
                        2 /     (j + 1)!     1
                          ====
                          j = 0
simplify_products                                                       [Option variable]
       Default value: true
       If simplify_products is true, solve_rec will try to simplify products in result.
       See also: solve_rec.
simplify_sum (expr)                                                                 [Function]
       Tries to simplify all sums appearing in expr to a closed form.
       To use this function first load the simplify_sum package with load(simplify_sum).
       Example:
             (%i1) load("simplify_sum")$
             (%i2) sum(binomial(n+k,k)/2^k,k,1,n)+sum(binomial(2*n,2*k),k,1,n);
                       n                                n
                      ====                            ====
                      \       binomial(n + k, k)      \
             (%o2)     >      ------------------ + >          binomial(2 n, 2 k)
                      /                  k            /
                      ====              2             ====
                      k = 1                           k = 1
             (%i3) simplify_sum(%);
                                            2 n - 1    n
             (%o3)                         2        + 2 - 2
solve_rec (eqn, var, [init])                                                        [Function]
       Solves for hypergeometrical solutions to linear recurrence eqn with polynomials coef-
       ficient in variable var. Optional arguments init are initial conditions.
       solve_rec can solve linear recurrences with constant coefficients, finds hypergeomet-
       rical solutions to homogeneous linear recurrences with polynomial coefficients, rational
       solutions to linear recurrences with polynomial coefficients and can solve Ricatti type
       recurrences.
Chapter 85: solve rec                                                                1101
     Note that the running time of the algorithm used to find hypergeometrical solutions
     is exponential in the degree of the leading and trailing coefficient.
     To use this function first load the solve_rec package with load(solve_rec);.
     Example of linear recurrence with constant coefficients:
           (%i2) solve_rec(a[n]=a[n-1]+a[n-2]+n/2^n, a[n]);
                                    n         n
                      (sqrt(5) - 1) %k (- 1)
                                       1           n
           (%o2) a = ------------------------- - ----
                  n                n                  n
                                 2                5 2
                                                           n
                                              (sqrt(5) + 1) %k
                                                               2    2
                                            + ------------------ - ----
                                                        n             n
                                                       2           5 2
     Example of linear recurrence with polynomial coefficients:
           (%i7) 2*x*(x+1)*y[x] - (x^2+3*x-2)*y[x+1] + (x-1)*y[x+2];
                                    2
           (%o7) (x - 1) y      - (x + 3 x - 2) y       + 2 x (x + 1) y
                          x + 2                   x + 1                x
           (%i8) solve_rec(%, y[x], y[1]=1, y[3]=3);
                                         x
                                      3 2    x!
           (%o9)                 y = ---- - --
                                  x    4     2
     Example of Ricatti type recurrence:
           (%i2) x*y[x+1]*y[x] - y[x+1]/(x+2) + y[x]/(x-1) = 0;
                                       y         y
                                        x + 1     x
           (%o2)         x y y       - ------ + ----- = 0
                             x x + 1   x + 2    x - 1
           (%i3) solve_rec(%, y[x], y[3]=5)$
           (%i4) ratsimp(minfactorial(factcomb(%)));
                                              3
                                          30 x - 30 x
           (%o4) y = - -------------------------------------------------
                  x        6      5       4        3      2
                        5 x - 3 x - 25 x + 15 x + 20 x - 12 x - 1584
     See also: solve_rec_rat, simplify_products and product_use_gamma.
       To use this function first load the solve_rec package with load(solve_rec);.
       Example:
            (%i1) (x+4)*a[x+3] + (x+3)*a[x+2] - x*a[x+1] + (x^2-1)*a[x];
            (%o1) (x + 4) a       + (x + 3) a      - x a
                            x + 3            x + 2      x + 1
                                                               2
                                                           + (x - 1) a
                                                                        x
            (%i2) solve_rec_rat(% = (x+2)/(x+1), a[x]);
                                   1
            (%o2)      a = ---------------
                        x   (x - 1) (x + 1)
       See also: solve_rec.
summand_to_rec                                                                [Function]
        summand_to_rec (summand, k, n)
        summand_to_rec (summand, [k, lo, hi], n)
       Returns the recurrence satisfied by the sum
                  hi
                 ====
                 \
                  >      summand
                 /
                 ====
               k = lo
       where summand is hypergeometrical in k and n. If lo and hi are omitted, they are
       assumed to be lo = -inf and hi = inf.
       To use this function first load the simplify_sum package with load(simplify_sum).
       Example:
            (%i1) load("simplify_sum")$
            (%i2) summand: binom(n,k);
            (%o2)                            binomial(n, k)
            (%i3) summand_to_rec(summand,k,n);
            (%o3)                      2 sm - sm        = 0
                                           n      n + 1
            (%i7) summand: binom(n, k)/(k+1);
                                            binomial(n, k)
            (%o7)                            --------------
                                                 k + 1
Chapter 85: solve rec                                                 1103
86 stats
                                     |    base = 3
                                     |
             (%o3)                   |   height = 2
                                     |
                                     | perimeter = 10
                                     |
                                     |    area = 6
             (%i4) take_inference('diagonal,%);
             (%o4)                        sqrt(13)
       See also take_inference.
take_inference                                                                     [Function]
        take_inference (n, obj)
        take_inference (name, obj)
        take_inference (list, obj)
       Returns the n-th value stored in obj if n is a positive integer, or the item named
       name if this is the name of an item. If the first argument is a list of numbers and/or
       symbols, function take_inference returns a list with the corresponding results.
       Example:
       Given an inference_result object, function take_inference is called in order to
       extract some information stored in it.
             (%i1) load(inference_result)$
             (%i2) b: 3$ h: 2$
             (%i3) sol: inference_result("Rectangle",
                                         ['base=b,
                                          'height=h,
                                          'diagonal=sqrt(b^2+h^2),
Chapter 86: stats                                                                       1107
                                               'area=b*h,
                                               'perimeter=2*(b+h)],
                                              [1,2,5,4] );
                                     |        Rectangle
                                     |
                                     |    base = 3
                                     |
           (%o3)                     |   height = 2
                                     |
                                     | perimeter = 10
                                     |
                                     |    area = 6
           (%i4) take_inference('base,sol);
           (%o4)                             3
           (%i5) take_inference(5,sol);
           (%o5)                            10
           (%i6) take_inference([1,'diagonal],sol);
           (%o6)                       [3, sqrt(13)]
           (%i7) take_inference(items_inference(sol),sol);
           (%o7)                  [3, 2, sqrt(13), 6, 10]
     See also inference_result, and take_inference.
                           'asymptotic=true,'mean=50);
                       |                       MEAN TEST
                       |
                       |           mean_estimate = 74.88571428571429
                       |
                       |                   conf_level = 0.95
                       |
                       | conf_interval = [57.72848600856194, 92.04294256286663]
                       |
           (%o2)       |    method = Large sample z-test. Unknown variance.
                       |
                       |       hypotheses = H0: mean = 50 , H1: mean # 50
                       |
                       |             statistic = 2.842831192874313
                       |
                       |             distribution = [normal, 0, 1]
                       |
                       |             p_value = .004471474652002261
test_means_difference                                                          [Function]
        test_means_difference (x1, x2)
        test_means_difference (x1, x2, options ...)
     This is the difference of means t-test for two samples. Arguments x1 and x2 are lists
     or column matrices containing two independent samples. In case of different unknown
     variances (see options 'dev1, 'dev2 and 'varequal bellow), the degrees of freedom
     are computed by means of the Welch approximation. It also performs an asymptotic
     test based on the Central Limit Theorem if option 'asymptotic is set to true.
     Options:
       •
       • 'alternative, default 'twosided, is the alternative hypothesis; valid values are:
          'twosided, 'greater and 'less.
       • 'dev1, default 'unknown, this is the value of the standard deviation of the x1
          sample when it is known; valid values are: 'unknown or a positive expression.
       • 'dev2, default 'unknown, this is the value of the standard deviation of the x2
          sample when it is known; valid values are: 'unknown or a positive expression.
       • 'varequal, default false, whether variances should be considered to be equal
          or not; this option takes effect only when 'dev1 and/or 'dev2 are 'unknown.
       • 'conflevel, default 95/100, confidence level for the confidence interval; it must
          be an expression which takes a value in (0,1).
       • 'asymptotic, default false, indicates whether it performs an exact t-test or an
          asymptotic one based on the Central Limit Theorem; valid values are true and
          false.
     The output of function test_means_difference is an inference_result Maxima
     object showing the following results:
      1. 'diff_estimate: the difference of means estimate.
1110                                                                  Maxima 5.45.0 Manual
                         |
                         |     conf_interval = [- .7722627696897568, inf]
                         |
           (%o4)         |   method = Exact t-test. Unknown equal variances
                         |
                         | hypotheses = H0: mean1 = mean2 , H1: mean1 > mean2
                         |
                         |           statistic = 1.765996124515009
                         |
                         |           distribution = [student_t, 9]
                         |
                         |            p_value = .05560320992529344
test_variance                                                                  [Function]
        test_variance (x)
        test_variance (x, options, ...)
     This is the variance chi^2-test. Argument x is a list or a column matrix containing
     an one dimensional sample taken from a normal population.
     Options:
       • 'mean, default 'unknown, is the population’s mean, when it is known.
       • 'alternative, default 'twosided, is the alternative hypothesis; valid values are:
         'twosided, 'greater and 'less.
       • 'variance, default 1, this is the variance value (positive) to be checked.
       • 'conflevel, default 95/100, confidence level for the confidence interval; it must
         be an expression which takes a value in (0,1).
     The output of function test_variance is an inference_result Maxima object show-
     ing the following results:
      1. 'var_estimate: the sample variance.
      2. 'conf_level: confidence level selected by the user.
      3. 'conf_interval: confidence interval for the population variance.
      4. 'method: inference procedure.
      5. 'hypotheses: null and alternative hypotheses to be tested.
      6. 'statistic: value of the sample statistic used for testing the null hypothesis.
      7. 'distribution: distribution of the sample statistic, together with its parameter.
      8. 'p_value: p-value of the test.
     Examples:
     It is tested whether the variance of a population with unknown mean is equal to or
     greater than 200.
            (%i1) load("stats")$
            (%i2) x: [203,229,215,220,223,233,208,228,209]$
            (%i3) test_variance(x,'alternative='greater,'variance=200);
                           |                     VARIANCE TEST
                           |
1112                                                                Maxima 5.45.0 Manual
                            |              var_estimate = 110.75
                            |
                            |                conf_level = 0.95
                            |
                            |     conf_interval = [57.13433376937479, inf]
                            |
            (%o3)           | method = Variance Chi-square test. Unknown mean.
                            |
                            |    hypotheses = H0: var = 200 , H1: var > 200
                            |
                            |                 statistic = 4.43
                            |
                            |             distribution = [chi2, 8]
                            |
                            |           p_value = .8163948512777689
test_variance_ratio                                                              [Function]
        test_variance_ratio (x1, x2)
        test_variance_ratio (x1, x2, options ...)
       This is the variance ratio F-test for two normal populations. Arguments x1 and x2
       are lists or column matrices containing two independent samples.
       Options:
        • 'alternative, default 'twosided, is the alternative hypothesis; valid values are:
          'twosided, 'greater and 'less.
        • 'mean1, default 'unknown, when it is known, this is the mean of the population
          from which x1 was taken.
        • 'mean2, default 'unknown, when it is known, this is the mean of the population
          from which x2 was taken.
        • 'conflevel, default 95/100, confidence level for the confidence interval of the
          ratio; it must be an expression which takes a value in (0,1).
       The output of function test_variance_ratio is an inference_result Maxima ob-
       ject showing the following results:
        1. 'ratio_estimate: the sample variance ratio.
        2. 'conf_level: confidence level selected by the user.
        3. 'conf_interval: confidence interval for the variance ratio.
        4. 'method: inference procedure.
        5. 'hypotheses: null and alternative hypotheses to be tested.
        6. 'statistic: value of the sample statistic used for testing the null hypothesis.
        7. 'distribution: distribution of the sample statistic, together with its parame-
           ters.
        8. 'p_value: p-value of the test.
       Examples:
Chapter 86: stats                                                                    1113
     The equality of the variances of two normal populations is checked against the alter-
     native that the first is greater than the second.
           (%i1) load("stats")$
           (%i2) x: [20.4,62.5,61.3,44.2,11.1,23.7]$
           (%i3) y: [1.2,6.9,38.7,20.4,17.2]$
           (%i4) test_variance_ratio(x,y,'alternative='greater);
                         |              VARIANCE RATIO TEST
                         |
                         |       ratio_estimate = 2.316933391522034
                         |
                         |               conf_level = 0.95
                         |
                         |    conf_interval = [.3703504689507268, inf]
                         |
           (%o4)         | method = Variance ratio F-test. Unknown means.
                         |
                         | hypotheses = H0: var1 = var2 , H1: var1 > var2
                         |
                         |         statistic = 2.316933391522034
                         |
                         |            distribution = [f, 5, 4]
                         |
                         |          p_value = .2179269692254457
test_proportion                                                                [Function]
        test_proportion (x, n)
        test_proportion (x, n, options ...)
     Inferences on a proportion. Argument x is the number of successes in n trials in a
     Bernoulli experiment with unknown probability.
     Options:
       • 'proportion, default 1/2, is the value of the proportion to be checked.
       • 'alternative, default 'twosided, is the alternative hypothesis; valid values are:
         'twosided, 'greater and 'less.
       • 'conflevel, default 95/100, confidence level for the confidence interval; it must
         be an expression which takes a value in (0,1).
       • 'asymptotic, default false, indicates whether it performs an exact test based
         on the binomial distribution, or an asymptotic one based on the Central Limit
         Theorem; valid values are true and false.
       • 'correct, default true, indicates whether Yates correction is applied or not.
     The output of function test_proportion is an inference_result Maxima object
     showing the following results:
       1. 'sample_proportion: the sample proportion.
       2. 'conf_level: confidence level selected by the user.
       3. 'conf_interval: Wilson confidence interval for the proportion.
1114                                                               Maxima 5.45.0 Manual
                    |                statistic = .43689
                    |
                    |     distribution = [normal, 0.5, .048872]
                    |
                    |                 p_value = .19662
test_proportions_difference                                          [Function]
        test_proportions_difference (x1, n1, x2, n2)
        test_proportions_difference (x1, n1, x2, n2, options . . . )
     Inferences on the difference of two proportions. Argument x1 is the number of suc-
     cesses in n1 trials in a Bernoulli experiment in the first population, and x2 and n2
     are the corresponding values in the second population. Samples are independent and
     the test is asymptotic.
     Options:
       • 'alternative, default 'twosided, is the alternative hypothesis; valid values are:
          'twosided (p1 # p2), 'greater (p1 > p2) and 'less (p1 < p2).
       • 'conflevel, default 95/100, confidence level for the confidence interval; it must
          be an expression which takes a value in (0,1).
       • 'correct, default true, indicates whether Yates correction is applied or not.
     The output of function test_proportions_difference is an inference_result
     Maxima object showing the following results:
      1. 'proportions: list with the two sample proportions.
      2. 'conf_level: confidence level selected by the user.
      3. 'conf_interval: Confidence interval for the difference of proportions p1 - p2.
      4. 'method: inference procedure and warning message in case of any of the samples
         sizes is less than 10.
      5. 'hypotheses: null and alternative hypotheses to be tested.
      6. 'statistic: value of the sample statistic used for testing the null hypothesis.
      7. 'distribution: distribution of the sample statistic, together with its parame-
         ters.
      8. 'p_value: p-value of the test.
     Examples:
     A machine produced 10 defective articles in a batch of 250. After some maintenance
     work, it produces 4 defective in a batch of 150. In order to know if the machine has
     improved, we test the null hypothesis H0:p1=p2, against the alternative H0:p1>p2,
     where p1 and p2 are the probabilities for one produced article to be defective before
     and after maintenance. According to the p value, there is not enough evidence to
     accept the alternative.
           (%i1) load("stats")$
           (%i2) fpprintprec:7$
           (%i3) test_proportions_difference(10, 250, 4, 150,
                                                  alternative = greater);
                  |          DIFFERENCE OF PROPORTIONS TEST
1116                                                                Maxima 5.45.0 Manual
                   |
                   |        proportions = [0.04, .02666667]
                   |
                   |                  conf_level = 0.95
                   |
                   |       conf_interval = [- .02172761, 1]
                   |
            (%o3) | method = Asymptotic test. Yates correction.
                   |
                   |   hypotheses = H0: p1 = p2 , H1: p1 > p2
                   |
                   |              statistic = .01333333
                   |
                   |    distribution = [normal, 0, .01898069]
                   |
                   |                p_value = .2411936
       Exact standard deviation of the asymptotic normal distribution when the data are
       unknown.
            (%i1) load("stats")$
            (%i2) stats_numer: false$
            (%i3) sol: test_proportions_difference(x1,n1,x2,n2)$
            (%i4) last(take_inference('distribution,sol));
                              1     1                    x2 + x1
                            (-- + --) (x2 + x1) (1 - -------)
                              n2    n1                   n2 + n1
            (%o4)     sqrt(---------------------------------)
                                            n2 + n1
test_sign                                                                        [Function]
        test_sign (x)
        test_sign (x, options . . . )
       This is the non parametric sign test for the median of a continuous population. Ar-
       gument x is a list or a column matrix containing an one dimensional sample.
       Options:
         • 'alternative, default 'twosided, is the alternative hypothesis; valid values are:
           'twosided, 'greater and 'less.
         • 'median, default 0, is the median value to be checked.
       The output of function test_sign is an inference_result Maxima object showing
       the following results:
        1. 'med_estimate: the sample median.
        2. 'method: inference procedure.
        3. 'hypotheses: null and alternative hypotheses to be tested.
        4. 'statistic: value of the sample statistic used for testing the null hypothesis.
        5. 'distribution: distribution of the sample statistic, together with its parame-
            ter(s).
Chapter 86: stats                                                                    1117
test_signed_rank                                                               [Function]
        test_signed_rank (x)
        test_signed_rank (x, options . . . )
     This is the Wilcoxon signed rank test to make inferences about the median of a
     continuous population. Argument x is a list or a column matrix containing an one
     dimensional sample. Performs normal approximation if the sample size is greater
     than 20, or if there are zeroes or ties.
     See also pdf_rank_test and cdf_rank_test
     Options:
       • 'median, default 0, is the median value to be checked.
       • 'alternative, default 'twosided, is the alternative hypothesis; valid values are:
         'twosided, 'greater and 'less.
     The output of function test_signed_rank is an inference_result Maxima object
     with the following results:
      1. 'med_estimate: the sample median.
      2. 'method: inference procedure.
      3. 'hypotheses: null and alternative hypotheses to be tested.
      4. 'statistic: value of the sample statistic used for testing the null hypothesis.
      5. 'distribution: distribution of the sample statistic, together with its parame-
         ter(s).
      6. 'p_value: p-value of the test.
     Examples:
1118                                                              Maxima 5.45.0 Manual
       Checks the null hypothesis H0 : median = 15 against the alternative H1 : median >
       15. This is an exact test, since there are no ties.
            (%i1) load("stats")$
            (%i2) x: [17.1,15.9,13.7,13.4,15.5,17.6]$
            (%i3) test_signed_rank(x,median=15,alternative=greater);
                             |             SIGNED RANK TEST
                             |
                             |           med_estimate = 15.7
                             |
                             |           method = Exact test
                             |
            (%o3)            | hypotheses = H0: med = 15 , H1: med > 15
                             |
                             |              statistic = 14
                             |
                             |     distribution = [signed_rank, 6]
                             |
                             |            p_value = 0.28125
       Checks the null hypothesis H0 : equal(median, 2.5) against the alternative H1 :
       notequal(median, 2.5). This is an approximated test, since there are ties.
            (%i1) load("stats")$
            (%i2) y:[1.9,2.3,2.6,1.9,1.6,3.3,4.2,4,2.4,2.9,1.5,3,2.9,4.2,3.1]$
            (%i3) test_signed_rank(y,median=2.5);
                         |                 SIGNED RANK TEST
                         |
                         |                med_estimate = 2.9
                         |
                         |          method = Asymptotic test. Ties
                         |
            (%o3)        |    hypotheses = H0: med = 2.5 , H1: med # 2.5
                         |
                         |                 statistic = 76.5
                         |
                         | distribution = [normal, 60.5, 17.58195097251724]
                         |
                         |           p_value = .3628097734643669
test_rank_sum                                                                  [Function]
        test_rank_sum (x1, x2)
        test_rank_sum (x1, x2, option)
       This is the Wilcoxon-Mann-Whitney test for comparing the medians of two continuous
       populations. The first two arguments x1 and x2 are lists or column matrices with
       the data of two independent samples. Performs normal approximation if any of the
       sample sizes is greater than 10, or if there are ties.
       Option:
Chapter 86: stats                                                                    1119
linear_regression                                                                           [Function]
        linear_regression (x)
        linear_regression (x option)
       Multivariate linear regression, yi = b0 + b1 ∗ x1 i + b2 ∗ x2 i + ... + bk ∗ xk i + ui , where ui
       are N (0, sigma) independent random variables. Argument x must be a matrix with
       more than one column. The last column is considered as the responses (yi ).
       Option:
         • 'conflevel, default 95/100, confidence level for the confidence intervals; it must
           be an expression which takes a value in (0,1).
       The output of function linear_regression is an inference_result Maxima object
       with the following results:
        1. 'b_estimation: regression coefficients estimates.
        2. 'b_covariances: covariance matrix of the regression coefficients estimates.
        3. b_conf_int: confidence intervals of the regression coefficients.
        4. b_statistics: statistics for testing coefficient.
        5. b_p_values: p-values for coefficient tests.
        6. b_distribution: probability distribution for coefficient tests.
        7. v_estimation: unbiased variance estimator.
        8. v_conf_int: variance confidence interval.
        9. v_distribution: probability distribution for variance test.
       10. residuals: residuals.
Chapter 86: stats                                                                  1121
             (%i9) load("draw")$
             (%i10) draw2d(
                 points_joined = true,
                 grid = true,
                 points(take_inference('residuals, res)) )$
87 stirling
          (%i2) stirling(gamma(%alpha+x)/gamma(x),1);
                  1/2 - x                   x + %alpha - 1/2
          (%o2) x            (x + %alpha)
                                                      1              1
                                              --------------- - ---- - %alpha
                                              12 (x + %alpha)      12 x
                                           %e
          (%i3) taylor(%,x,inf,1);
                                   %alpha          2      %alpha
                       %alpha    x          %alpha - x            %alpha
          (%o3)/T/ x           + -------------------------------- + . . .
                                                   2 x
          (%i4) map('factor,%);
                                                           %alpha - 1
                     %alpha     (%alpha - 1) %alpha x
          (%o4)     x         + -------------------------------
                                                    2
    The function stirling knows the difference between the variable ’gamma’ and the
    function gamma:
          (%i5) stirling(gamma + gamma(x),0);
                                                        x - 1/2    - x
          (%o5)       gamma + sqrt(2) sqrt(%pi) x                %e
          (%i6) stirling(gamma(y) + gamma(x),0);
                                         y - 1/2      - y
          (%o6) sqrt(2) sqrt(%pi) y                %e
                                                                   x - 1/2       - x
                                         + sqrt(2) sqrt(%pi) x                %e
    To apply the Stirling formula only to terms that involve the variable k, use an optional
    third argument; for example
          (%i7) makegamma(pochhammer(a,k)/pochhammer(b,k));
1124                                                          Maxima 5.45.0 Manual
             (%o7) (gamma(b)*gamma(k+a))/(gamma(a)*gamma(k+b))
             (%i8) stirling(%,1, lambda([s], not(freeof(k,s))));
             (%o8) (%e^(b-a)*gamma(b)*(k+a)^(k+a-1/2)*(k+b)^(-k-b+1/2))/gamma(a)
       The terms gamma(a) and gamma(b) are free of k, so the Stirling formula was not
       applied to these two terms.
       To use this function write first load("stirling").
                                                                                        1125
88 stringproc
newline                                                                              [Function]
           newline ()
           newline (stream)
       Writes a new line to the standard output stream. Using the optional argument stream
       the new line is written to that stream. There are some cases, where newline() does
       not work as expected.
       See [sprint], page 1131, for an example of using newline().
openr                                                                                [Function]
           openr (file)
           openr (file, encoding)
       Returns a character input stream to file. openr assumes that file already exists. If
       reading the file results in a lisp error about its encoding passing the correct string as
       the argument encoding might help. The available encodings and their names depend
       on the lisp being used. For sbcl a list of suitable strings can be found at http://
       www.sbcl.org/manual/#External-Formats.
       For binary input see Section 75.3 [openr binary], page 1050, . See also close and
       openw.
             (%i1) istream : openr("data.txt","EUC-JP");
             (%o1)     #<FD-STREAM for "file /home/gunter/data.txt" {10099A3AE3}>
             (%i2) close(istream);
             (%o2)                                true
printf                                                                          [Function]
          printf (dest, string)
          printf (dest, string, expr_1, ..., expr_n)
     Produces formatted output by outputting the characters of control-string string and
     observing that a tilde introduces a directive. The character after the tilde, possibly
     preceded by prefix parameters and modifiers, specifies what kind of formatting is
     desired. Most directives use one or more elements of the arguments expr 1, ..., expr n
     to create their output.
     If dest is a stream or true, then printf returns false. Otherwise, printf returns
     a string containing the output. By default the streams stdin, stdout and stderr
     are defined. If maxima is running as a server (which is the normal case if maxima
     communicating with a graphical user interface) setup-client will define old stdout
     and old stderr, too.
     printf provides the Common Lisp function format in Maxima. The following exam-
     ple illustrates the general relation between these two functions.
           (%i1) printf(true, "R~dD~d~%", 2, 2);
           R2D2
           (%o1)                                false
           (%i2) :lisp (format t "R~dD~d~%" 2 2)
           R2D2
           NIL
     The following description is limited to a rough sketch of the possibilities of printf.
     The Lisp function format is described in detail in many reference books. Of good
     help is e.g. the free available online-manual "Common Lisp the Language" by Guy
     L. Steele. See chapter 22.3.3 there.
     In addition, printf recognizes two format directives which are not known to Lisp
     format. The format directive ~m indicates Maxima pretty printer output. The format
     directive ~h indicates a bigfloat number.
               ~%        new line
               ~&        fresh line
               ~t        tab
               ~$        monetary
               ~d        decimal integer
               ~b        binary integer
               ~o        octal integer
               ~x        hexadecimal integer
               ~br       base-b integer
               ~r        spell an integer
               ~p        plural
               ~f        floating point
               ~e        scientific notation
               ~g        ~f or ~e, depending upon magnitude
               ~h        bigfloat
               ~a        uses Maxima function string
               ~m        Maxima pretty printer output
1130                                                               Maxima 5.45.0 Manual
           |1.414213562373095049|
           (%i10) printf(true, "|~,,,-3h|~%", sqrt(2))$
           |1414.21356237309504880169b-3|
           (%i11) printf(true, "|~,,2,-3h|~%", sqrt(2))$
           |1414.21356237309504880169b-03|
           (%i12) printf(true, "|~20h|~%", sqrt(2))$
           |1.41421356237309504880169|
           (%i13) printf(true, "|~20,,,,'+h|~%", sqrt(2))$
           |++++++++++++++++++++|
     For conversion of objects to strings also see concat, sconcat, string and simplode.
            (%i6) flength(out);
            (%o6)                                  0
            (%i7) flush_output(out);
            (%o7)                                true
            (%i8) flength(out);
            (%o8)                                  3
            (%i9) printfile("test.bin")$
            GNU
            (%i0A) for b in rest(bytes,3) do writebyte(b, out);
            (%o0A)                               done
            (%i0B) close(out);
            (%o0B)                               true
            (%i0C) printfile("test.bin")$
            GNU/Linux
88.3 Characters
Characters are strings of length 1.
adjust_external_format ()                                                        [Function]
       Prints information about the current external format of the Lisp reader and in case
       the external format encoding differs from the encoding of the application which runs
       Maxima adjust_external_format tries to adjust the encoding or prints some help
       or instruction. adjust_external_format returns true when the external format has
       been changed and false otherwise.
Chapter 88: stringproc                                                                1133
     Functions like [cint], page 1134, [unicode], page 1136, [octets to string], page 1145,
     and [string to octets], page 1147, need UTF-8 as the external format of the Lisp
     reader to work properly over the full range of Unicode characters.
     Examples (Maxima on Windows, March 2016): Using adjust_external_format
     when the default external format is not equal to the encoding provided by the appli-
     cation.
     1. Command line Maxima
     In case a terminal session is preferred it is recommended to use Maxima compiled with
     SBCL. Here Unicode support is provided by default and calls to adjust_external_
     format are unnecessary.
     If Maxima is compiled with CLISP or GCL it is recommended to change the terminal
     encoding from CP850 to CP1252. adjust_external_format prints some help.
     CCL reads UTF-8 while the terminal input is CP850 by default. CP1252 is not
     supported by CCL. adjust_external_format prints instructions for changing the
     terminal encoding and external format both to iso-8859-1.
     2. wxMaxima
     In wxMaxima SBCL reads CP1252 by default but the input from the application is
     UTF-8 encoded. Adjustment is needed.
     Calling adjust_external_format and restarting Maxima permanently changes the
     default external format to UTF-8.
           (%i1)adjust_external_format();
           The line
           (setf sb-impl::*default-external-format* :utf-8)
           has been appended to the init file
           C:/Users/Username/.sbclrc
           Please restart Maxima to set the external format to UTF-8.
           (%i1) false
     Restarting Maxima.
           (%i1) adjust_external_format();
           The external format is currently UTF-8
           and has not been changed.
           (%i1) false
            (%o1)                                 true
       In GCL this is not possible. An error break occurs.
            (%i1) alphacharp("u");
            (%o1)                                 true
            (%i2) alphacharp("ü");
      Examples: The hexadecimal code point of some characters (Maxima with SBCL on
      GNU/Linux).
            (%i1) obase: 16.$
            (%i2) map(cint, ["$","¿","e"]);
            (%o2)                           [24, 0A3, 20AC]
      Warning: It is not possible to enter characters corresponding to code points larger
      than 16 bit in wxMaxima with SBCL on Windows when the external format has not
      been set to UTF-8. See [adjust external format], page 1132.
      CMUCL doesn’t process these characters as one character. cint then returns false.
      Converting a character to a code point via UTF-8-octets may serve as a workaround:
      utf8_to_unicode(string_to_octets(character));
      See [utf8 to unicode], page 1137, [string to octets], page 1147.
newline                                                                            [Variable]
      The newline character (ASCII-character 10).
space                                                                              [Variable]
      The space character.
tab                                                                                [Variable]
      The tab character.
1136                                                                Maxima 5.45.0 Manual
us_ascii_only                                                                  [Variable]
     This option variable affects Maxima when the character encoding provided by the
     application which runs Maxima is UTF-8 but the external format of the Lisp reader
     is not equal to UTF-8.
     On GNU/Linux this is true when Maxima is built with GCL and on Windows in
     wxMaxima with GCL- and SBCL-builds. With SBCL it is recommended to change
     the external format to UTF-8. Setting us_ascii_only is unnecessary then. See
     [adjust external format], page 1132, for details.
     us_ascii_only is false by default. Maxima itself then (i.e. in the above described
     situation) parses the UTF-8 encoding.
     When us_ascii_only is set to true it is assumed that all strings used as arguments
     to string processing functions do not contain Non-US-ASCII characters. Given that
     promise, Maxima avoids parsing UTF-8 and strings can be processed more efficiently.
utf8_to_unicode (list)                                                   [Function]
     Returns an Unicode code point corresponding to the list which must contain the
     UTF-8 encoding of a single character.
     Examples: See [unicode to utf8], page 1136.
sdowncase                                                                         [Function]
        sdowncase (string)
        sdowncase (string, start)
        sdowncase (string, start, end)
       Like [supcase], page 1142, but uppercase characters are converted to lowercase.
simplode                                                                          [Function]
        simplode (list)
        simplode (list, delim)
       simplode takes a list of expressions and concatenates them into a string. If no
       delimiter delim is specified, simplode uses no delimiter. delim can be any string.
       See also concat, sconcat, string and printf.
       Examples:
             (%i1) simplode(["xx[",3,"]:",expand((x+y)^3)]);
             (%o1)             xx[3]:y^3+3*x*y^2+3*x^2*y+x^3
             (%i2) simplode( sexplode("stars")," * " );
             (%o2)                   s * t * a * r * s
             (%i3) simplode( ["One","more","coffee."]," " );
             (%o3)                   One more coffee.
Chapter 88: stringproc                                                                  1139
       one. This is useful if tabs are saved as multiple space characters. If multiple is set to
       false, each delimiter is noted.
       Examples:
             (%i1) split("1.2         2.3    3.4    4.5");
             (%o1)                        [1.2, 2.3, 3.4, 4.5]
             (%i2) split("first;;third;fourth",";",false);
             (%o2)                     [first, , third, fourth]
sposition (char, string)                                                             [Function]
       Returns the position of the first character in string which matches char. The first
       character in string is in position 1. For matching characters ignoring case see [ssearch],
       page 1140.
sremove                                                                        [Function]
           sremove     (seq, string)
           sremove     (seq, string, test)
           sremove     (seq, string, test, start)
           sremove     (seq, string, test, start, end)
       Returns a string like string but without all substrings matching seq. Default test
       function for matching is sequal. If sremove should ignore case while searching for
       seq, use sequalignore as test. Use start and end to limit searching. Note that the
       first character in string is in position 1.
       Examples:
              (%i1) sremove("n't","I don't like coffee.");
              (%o1)                          I do like coffee.
              (%i2) sremove ("DO ",%,'sequalignore);
              (%o2)                           I like coffee.
sremovefirst                                                                     [Function]
        sremovefirst       (seq, string)
        sremovefirst       (seq, string, test)
        sremovefirst       (seq, string, test, start)
        sremovefirst       (seq, string, test, start, end)
       Like sremove except that only the first substring that matches seq is removed.
sreverse (string)                                                                     [Function]
       Returns a string with all the characters of string in reverse order.
       See also reverse.
ssearch                                                                               [Function]
           ssearch    (seq, string)
           ssearch    (seq, string, test)
           ssearch    (seq, string, test, start)
           ssearch    (seq, string, test, start, end)
       Returns the position of the first substring of string that matches the string seq.
       Default test function for matching is sequal. If ssearch should ignore case, use
       sequalignore as test. Use start and end to limit searching. Note that the first
       character in string is in position 1.
Chapter 88: stringproc                                                                  1141
     Example:
         (%i1) ssearch("~s","~{~S ~}~%",'sequalignore);
         (%o1)                                  4
ssort                                                                             [Function]
          ssort (string)
          ssort (string, test)
     Returns a string that contains all characters from string in an order such there are no
     two successive characters c and d such that test (c, d) is false and test (d, c) is
     true. Default test function for sorting is clessp. The set of test functions is {clessp,
     clesspignore, cgreaterp, cgreaterpignore, cequal, cequalignore}.
     Examples:
           (%i1) ssort("I don't like Mondays.");
           (%o1)                          '.IMaddeiklnnoosty
           (%i2) ssort("I don't like Mondays.",'cgreaterpignore);
           (%o2)                      ytsoonnMlkIiedda.'
ssubst                                                                      [Function]
          ssubst   (new, old, string)
          ssubst   (new, old, string, test)
          ssubst   (new, old, string, test, start)
          ssubst   (new, old, string, test, start, end)
     Returns a string like string except that all substrings matching old are replaced
     by new. old and new need not to be of the same length. Default test function
     for matching is sequal. If ssubst should ignore case while searching for old, use
     sequalignore as test. Use start and end to limit searching. Note that the first
     character in string is in position 1.
     Examples:
           (%i1) ssubst("like","hate","I hate Thai food. I hate green tea.");
           (%o1)               I like Thai food. I like green tea.
           (%i2) ssubst("Indian","thai",%,'sequalignore,8,12);
           (%o2)             I like Indian food. I like green tea.
ssubstfirst                                                                     [Function]
        ssubstfirst     (new, old, string)
        ssubstfirst     (new, old, string, test)
        ssubstfirst     (new, old, string, test, start)
        ssubstfirst     (new, old, string, test, start, end)
     Like subst except that only the first substring that matches old is replaced.
strim (seq,string)                                                               [Function]
     Returns a string like string, but with all characters that appear in seq removed from
     both ends.
     Examples:
           (%i1) "/* comment */"$
           (%i2) strim(" /*",%);
           (%o2)                                comment
1142                                                                     Maxima 5.45.0 Manual
             (%i3) slength(%);
             (%o3)                                    7
substring                                                                              [Function]
        substring (string, start)
        substring (string, start, end)
       Returns the substring of string beginning at position start and ending at position
       end. The character at position end is not included. If end is not given, the substring
       contains the rest of the string. Note that the first character in string is in position 1.
       Examples:
             (%i1) substring("substring",4);
             (%o1)                        string
             (%i2) substring(%,4,6);
             (%o2)                          in
supcase                                                                                [Function]
           supcase (string)
           supcase (string, start)
           supcase (string, start, end)
       Returns string except that lowercase characters from position start to end are replaced
       by the corresponding uppercase ones. If end is not given, all lowercase characters from
       start to the end of string are replaced.
       Example:
             (%i1) supcase("english",1,2);
             (%o1)                        English
tokens                                                                                 [Function]
           tokens (string)
           tokens (string, test)
       Returns a list of tokens, which have been extracted from string. The tokens are sub-
       strings whose characters satisfy a certain test function. If test is not given, constituent
       is used as the default test. {constituent, alphacharp, digitcharp, lowercasep,
       uppercasep, charp, characterp, alphanumericp} is the set of test functions. (The
       Lisp-version of tokens is written by Paul Graham. ANSI Common Lisp, 1996, page
       67.)
       Examples:
             (%i1) tokens("24 October 2005");
             (%o1)                  [24, October, 2005]
Chapter 88: stringproc                                                                 1143
           (%i2) tokens("05-10-24",'digitcharp);
           (%o2)                     [05, 10, 24]
           (%i3) map(parse_string,%);
           (%o3)                      [5, 10, 24]
           iQEcBAEBAgAGBQJVdCTzAAoJEG/1Mgf2DWAqCSYH/AhVFwhu1D89C3/QFcgVvZTM
           wnOYzBUURJAL/cT+IngkLEpp3hEbREcugWp+Tm6aw3R4CdJ7G3FLxExBH/5KnDHi
1144                                                                Maxima 5.45.0 Manual
             rBQu+I7+3ySK2hpryQ6Wx5J9uZSa4YmfsNteR8up0zGkaulJeWkS4pjiRM+auWVe
             vajlKZCIK52P080DG7Q2dpshh4fgTeNwqCuCiBhQ73t8g1IaLdhDN6EzJVjGIzam
             /spqT/sTo6sw8yDOJjvU+Qvn6/mSMjC/YxjhRMaQt9EMrR1AZ4ukBF5uG1S7mXOH
             WdiwkSPZ3gnIBhM9SuC076gLWZUNs6NqTeE3UzMjDAFhH3jYk1T7mysCvdtIkms=
             =WmeC
             -----END PGP SIGNATURE-----
             (%i1) ibase : obase : 16.$
             (%i2) sig64 : sconcat(
              "iQEcBAEBAgAGBQJVdCTzAAoJEG/1Mgf2DWAqCSYH/AhVFwhu1D89C3/QFcgVvZTM",
              "wnOYzBUURJAL/cT+IngkLEpp3hEbREcugWp+Tm6aw3R4CdJ7G3FLxExBH/5KnDHi",
              "rBQu+I7+3ySK2hpryQ6Wx5J9uZSa4YmfsNteR8up0zGkaulJeWkS4pjiRM+auWVe",
              "vajlKZCIK52P080DG7Q2dpshh4fgTeNwqCuCiBhQ73t8g1IaLdhDN6EzJVjGIzam",
              "/spqT/sTo6sw8yDOJjvU+Qvn6/mSMjC/YxjhRMaQt9EMrR1AZ4ukBF5uG1S7mXOH",
              "WdiwkSPZ3gnIBhM9SuC076gLWZUNs6NqTeE3UzMjDAFhH3jYk1T7mysCvdtIkms=" )$
             (%i3) octets: base64_decode(sig64, 'list)$
             (%i4) crc24: crc24sum(octets, 'list);
             (%o4)                          [5A, 67, 82]
             (%i5) base64(crc24);
             (%o5)                              WmeC
md5sum                                                                           [Function]
           md5sum (arg)
           md5sum (arg, return-type)
       Returns the MD5 checksum of a string, a non-negative integer or a list of octets. The
       default return value is a string containing 32 hex characters.
       The optional argument return-type allows md5sum to alternatively return the corre-
       sponding number or list of octets. return-type may be string, number or list.
       Examples:
             (%i1)   ibase: obase: 16.$
             (%i2)   msg: "foo bar baz"$
             (%i3)   string: md5sum(msg);
             (%o3)                    ab07acbb1e496801937adfa772424bf7
             (%i4)   integer: md5sum(msg, 'number);
             (%o4)                   0ab07acbb1e496801937adfa772424bf7
             (%i5)   octets: md5sum(msg, 'list);
             (%o5)          [0AB,7,0AC,0BB,1E,49,68,1,93,7A,0DF,0A7,72,42,4B,0F7]
             (%i6)   sdowncase( printf(false, "~{~2,'0x~^:~}", octets) );
             (%o6)             ab:07:ac:bb:1e:49:68:01:93:7a:df:a7:72:42:4b:f7
       Note that in case arg contains German umlauts or other non-ASCII characters (resp.
       octets larger than 127) the MD5 checksum is platform dependent.
mgf1_sha1                                                                        [Function]
        mgf1_sha1 (seed, len)
        mgf1_sha1 (seed, len, return-type)
       Returns a pseudo random number of variable length. By default the returned value
       is a number with a length of len octets.
Chapter 88: stringproc                                                             1145
     The optional argument return-type allows mgf1_sha1 to alternatively return the cor-
     responding list of len octets. return-type may be number or list.
     The computation of the returned value is described in RFC 3447, appendix B.2.1
     MGF1. SHA1 ist used as hash function, i.e. the randomness of the computed number
     relies on the randomness of SHA1 hashes.
     Example:
            (%i1) ibase: obase: 16.$
            (%i2) number: mgf1_sha1(4711., 8);
            (%o2)                              0e0252e5a2a42fea1
            (%i3) octets: mgf1_sha1(4711., 8, 'list);
            (%o3)                       [0E0,25,2E,5A,2A,42,0FE,0A1]
octets_to_string                                                              [Function]
        octets_to_string (octets)
        octets_to_string (octets, encoding)
     Decodes the list of octets into a string according to current system defaults. When
     decoding octets corresponding to Non-US-ASCII characters the result depends on the
     platform, application and underlying Lisp.
     Example: Using system defaults (Maxima compiled with GCL, which uses no format
     definition and simply passes through the UTF-8-octets encoded by the GNU/Linux
     terminal).
            (%i1) octets: string_to_octets("abc");
1146                                                                 Maxima 5.45.0 Manual
     Note that in case arg contains German umlauts or other non-ASCII characters (resp.
     octets larger than 127) the SHA1 fingerprint is platform dependent.
sha256sum                                                                       [Function]
        sha256sum (arg)
        sha256sum (arg, return-type)
     Returns the SHA256 fingerprint of a string, a non-negative integer or a list of octets.
     The default return value is a string containing 64 hex characters.
     The optional argument return-type allows sha256sum to alternatively return the cor-
     responding number or list of octets (see [sha1sum], page 1146).
     Example:
           (%i1) string: sha256sum("foo bar baz");
           (%o1) dbd318c1c462aee872f41109a4dfd3048871a03dedd0fe0e757ced57dad6f2d7
     Note that in case arg contains German umlauts or other non-ASCII characters (resp.
     octets larger than 127) the SHA256 fingerprint is platform dependent.
string_to_octets                                                                [Function]
        string_to_octets (string)
        string_to_octets (string, encoding)
     Encodes a string into a list of octets according to current system defaults. When
     encoding strings containing Non-US-ASCII characters the result depends on the plat-
     form, application and underlying Lisp.
     In case the external format of the Lisp reader is equal to UTF-8 the optional argument
     encoding allows to set the encoding for the string to octet conversion. If necessary
     see [adjust external format], page 1132, for changing the external format.
     See [octets to string], page 1145, for examples and some more information.
                                                                                          1149
89 to poly solve
%and                                                                                [Operator]
       The operator %and is a simplifying nonshort-circuited logical conjunction. Maxima
       simplifies an %and expression to either true, false, or a logically equivalent, but sim-
       plified, expression. The operator %and is associative, commutative, and idempotent.
       Thus when %and returns a noun form, the arguments of %and form a non-redundant
       sorted list; for example
               (%i1) a %and (a %and b);
               (%o1)                            a %and b
       If one argument to a conjunction is the explicit the negation of another argument,
       %and returns false:
               (%i2) a %and (not a);
               (%o2)                              false
       If any member of the conjunction is false, the conjunction simplifies to false even if
       other members are manifestly non-boolean; for example
               (%i3) 42 %and false;
               (%o3)                              false
       Any argument of an %and expression that is an inequation (that is, an inequality or
       equation), is simplified using the Fourier elimination package. The Fourier elimination
       simplifier has a pre-processor that converts some, but not all, nonlinear inequations
       into linear inequations; for example the Fourier elimination code simplifies abs(x) +
       1 > 0 to true, so
               (%i4) (x < 1) %and (abs(x) + 1 > 0);
               (%o4)                         x < 1
       Notes
        • The option variable prederror does not alter the simplification %and expressions.
        • To avoid operator precedence errors, compound expressions involving the opera-
          tors %and, %or, and not should be fully parenthesized.
        • The Maxima operators and and or are both short-circuited. Thus and isn’t
          associative or commutative.
       Limitations The conjunction %and simplifies inequations locally, not globally. This
       means that conjunctions such as
               (%i5) (x < 1) %and (x > 1);
1150                                                                     Maxima 5.45.0 Manual
%or                                                                                    [Operator]
       The operator %or is a simplifying nonshort-circuited logical disjunction. Maxima sim-
       plifies an %or expression to either true, false, or a logically equivalent, but simplified,
Chapter 89: to poly solve                                                              1151
                           set(x,y,z));
               (%o2)            [[], [2 z - 7, y + 7, z - x + 1]]
       Of course, the equations needn’t be linear:
               (%i3) elim(set(x^2 - 2 * y^3 = 1, x - y = 5), [x,y]);
                                    3    2
               (%o3)       [[], [2 y - y - 10 y - 24, y - x + 5]]
       The user doesn’t control the order the variables are eliminated. Instead, the algorithm
       uses a heuristic to attempt to choose the best pivot and the best elimination order.
       Notes
        • Unlike the related function eliminate, the function elim does not invoke solve
          when the number of equations equals the number of variables.
        • The function elim works by applying resultants; the option variable resultant
          determines which algorithm Maxima uses. Using sqfr, Maxima factors each
          resultant and suppresses multiple zeros.
        • The elim will triangularize a nonlinear set of polynomial equations; the solution
          set of the triangularized set can be larger than that solution set of the untrian-
          gularized set. Thus, the triangularized equations can have spurious solutions.
       Related functions elim allbut, eliminate using, eliminate
       Option variables resultant
       To use load(to_poly)
       Status The function elim is experimental; its specifications might change and its
       functionality might be merged into other Maxima functions.
                      3                2        2       3    2
            (%o2) {y + (1 - 3 x) y + 3 x y - x - x ,
                                         4     3 3        2 2                   4
                                       y - x y + 13 x y - 75 x y + x + 125}
            (%i3) eliminate_using(eq,second(eq),z);
                      2              2         4     3 3          2 2                 4
            (%o3) {y - 3 x y + x + 5, y - x y + 13 x y - 75 x y + x
                                                                                   + 125}
            (%i4) eliminate_using(eq, third(eq),z);
                      2              2         3                2         2       3    2
            (%o4) {y - 3 x y + x + 5, y + (1 - 3 x) y + 3 x y - x - x }
      Option variables resultant
      Related functions elim, eliminate, elim allbut
      To use load(to_poly)
      Status The function eliminate_using is experimental; its specifications might change
      and its functionality might be merged into other Maxima functions.
fourier_elim ([eq1, eq2, . . . ], [var1, var, . . . ])                              [Function]
      Fourier elimination is the analog of Gauss elimination for linear inequations (equations
      or inequalities). The function call fourier_elim([eq1, eq2, ...], [var1, var2,
      ...]) does Fourier elimination on a list of linear inequations [eq1, eq2, ...] with
      respect to the variables [var1, var2, ...]; for example
             (%i1) fourier_elim([y-x < 5, x - y < 7, 10 < y],[x,y]);
             (%o1)                 [y - 5 < x, x < y + 7, 10 < y]
             (%i2) fourier_elim([y-x < 5, x - y < 7, 10 < y],[y,x]);
             (%o2)            [max(10, x - 7) < y, y < x + 5, 5 < x]
      Eliminating first with respect to x and second with respect to y yields lower and
      upper bounds for x that depend on y, and lower and upper bounds for y that are
      numbers. Eliminating in the other order gives x dependent lower and upper bounds
      for y, and numerical lower and upper bounds for x.
      When necessary, fourier_elim returns a disjunction of lists of inequations:
             (%i3) fourier_elim([x # 6],[x]);
             (%o3)                       [x < 6] or [6 < x]
      When the solution set is empty, fourier_elim returns emptyset, and when the
      solution set is all reals, fourier_elim returns universalset; for example
             (%i4) fourier_elim([x < 1, x > 1],[x]);
             (%o4)                             emptyset
             (%i5) fourier_elim([minf < x, x < inf],[x]);
             (%o5)                           universalset
      For nonlinear inequations, fourier_elim returns a (somewhat) simplified list of in-
      equations:
             (%i6) fourier_elim([x^3 - 1 > 0],[x]);
                                 2                                   2
             (%o6) [1 < x, x + x + 1 > 0] or [x < 1, - (x + x + 1) > 0]
             (%i7) fourier_elim([cos(x) < 1/2],[x]);
1156                                                                  Maxima 5.45.0 Manual
             (%i4) isreal_p(z);
             (%o4)                            isreal_p(z)
       Limitations Too often, isreal_p returns a noun form when it should be able to return
       false; a simple example: the logarithm function isn’t real-valued on the entire real
       line, so isreal_p(log(x)) should return false; however
             (%i5) isreal_p(log(x));
Chapter 89: to poly solve                                                             1157
            (%o5)                       isreal_p(log(x))
     To use load(to_poly_solve)
     Related functions complex number p
     Status The function isreal_p is experimental; its specifications might change and
     its functionality might be merged into other Maxima functions.
           (%i8) new_variable(integer);
           (%o8)                               %g149
           (%i9) new_variable('integer);
           (%o9)                               %z150
     Related functions nicedummies
     To use load(to_poly_solve)
     Status The function new_variable is experimental; its specifications might change
     and its functionality might be merged into other Maxima functions.
nicedummies                                                                      [Function]
     Starting with zero, the function nicedummies re-indexes the variables in an expression
     that were introduced by new_variable;
           (%i1) new_variable('integer) + 52 * new_variable('integer);
           (%o1)                         52 %z136 + %z135
1158                                                                Maxima 5.45.0 Manual
             (%o5) false
             (%i6) simp_inequality(a + 1 # a);
             (%o6) true
             (%i7) simp_inequality(a < a+1);
             (%o7) true
             (%i8) simp_inequality(abs(x) >= 0);
             (%o8) true
             (%i9) simp_inequality(exp(x)         > 0);
             (%o9) true
             (%i10) simp_inequality(x^2 >= 0);
             (%o10) true
             (%i11) simp_inequality(2^x         # 0);
             (%o11) true
             (%i12) simp_inequality(2^(x+1) > 2^x);
             (%o12) true
       The fact database is not consulted. For example:
             (%i13) assume(xx > 0)$
             (%i14) simp_inequality(xx > 0);
             (%o14) xx>0
       And finally, for conjunctions or disjunctions of inequations, each inequation is simpli-
       fied, but no effort is made to simplify the entire logical expression; for example:
             (%i15) simp_inequality((1 > 0) and (x < 0) and (x > 0));
             (%o15) x<0 and x>0
                                                                                    2
           sublis: left-hand side of equation must be a symbol; found: x
             -- an error. To debug this try: debugmode(true);
     The substitutions made by subst_parallel are literal, not semantic; thus subst_
     parallel does not recognize that x ∗ y is a subexpression of x2 ∗ y
           (%i6) subst_parallel([x * y = a], x^2 * y);
                                                 2
           (%o6)                                x y
     The function subst_parallel completes all substitutions before simplifications. This
     allows for substitutions into conditional expressions where errors might occur if the
     simplifications were made earlier:
           (%i7) subst_parallel([x = 0], %if(x < 1, 5, log(x)));
           (%o7)                                   5
           (%i8) subst([x = 0], %if(x < 1, 5, log(x)));
                Unable to solve
                Unable to solve
                (%o9)        %solve([cos(x) = x], [x], maxdepth = 2)
       • parameters = l, where l is a list of symbols. The solver attempts to return a
         solution that is valid for all members of the list l; for example:
                (%i10) to_poly_solve(a * x = x, x);
                (%o10)                   %union([x = 0])
                (%i11) to_poly_solve(a * x = x, x, 'parameters = [a]);
1166                                                                Maxima 5.45.0 Manual
(%i1) declare(x,complex)$
90 unit
    Clifford Yapp is the primary author. He has received valuable assistance from Barton
Willis of the University of Nebraska at Kearney (UNK), Robert Dodier, and other intrepid
folk of the Maxima mailing list.
    There are probably lots of bugs. Let me know. float and numer don’t do what is
expected.
    TODO : dimension functionality, handling of temperature, showabbr and friends. Show
examples with addition of quantities containing units.
           (%i9) g;
           (%o9)                                      (100) (cg)
           (%i10) centigram*inch/minutes^2;
                                                         %in cg
           (%o10)                                        ------
                                                               2
                                                         %min
     The setting of units is quite flexible. For example, if we want to get back to kilograms,
     meters, and seconds as defaults for those dimensions we can do:
           (%i11) setunits([kg,m,s]);
           (%o11)                                          done
           (%i12) centigram*inch/minutes^2;
                                                       127           kg m
           (%o12)                               (-------------) (----)
                                                  1800000000000         2
                                                                      s
     Derived units are also handled by this command:
           (%i17) setunits(N);
           (%o17)                                          done
           (%i18) N;
           (%o18)                                             N
           (%i19) dyn;
                                                         1
           (%o19)                                     (------) (N)
                                                       100000
           (%i20) kg*m/s^2;
           (%o20)                                             N
           (%i21) centigram*inch/minutes^2;
                                                         127
           (%o21)                                  (-------------) (N)
                                                    1800000000000
     Notice that the unit package recognized the non MKS combination of mass, length,
     and inverse time squared as a force, and converted it to Newtons. This is how Maxima
     works in general. If, for example, we prefer dyne to Newtons, we simply do the
     following:
           (%i22) setunits(dyn);
           (%o22)                                          done
           (%i23) kg*m/s^2;
           (%o23)                                    (100000) (dyn)
           (%i24) centigram*inch/minutes^2;
                                                       127
           (%o24)                                   (--------) (dyn)
                                                     18000000
     To discontinue simplifying to any force, we use the uforget command:
           (%i26) uforget(dyn);
           (%o26)                                          false
1172                                                                  Maxima 5.45.0 Manual
             (%i27) kg*m/s^2;
                                                          kg m
             (%o27)                                       ----
                                                            2
                                                           s
             (%i28) centigram*inch/minutes^2;
                                                     127        kg m
             (%o28)                            (-------------) (----)
                                                1800000000000      2
                                                                 s
       This would have worked equally well with uforget(N) or uforget(%force).
       See also uforget. To use this function write first load("unit").
           (%i2) kg*m/s^2;
                                               kg m
           (%o2)                               ----
                                                 2
                                                s
           (%i3) convert(kg*m/s^2,[g,km,s]);
                                                g km
           (%o3)                                ----
                                                  2
                                                 s
           (%i4) convert(kg*m/s^2,[g,inch,minute]);
(%i16) convert(kg*m/s^2,[g,inch,s]);
           (%i6) setunits([dyn,eV]);
           (%o6)                                done
           (%i7) kg*m/s^2;
           (%o7)                           (100000) (dyn)
           (%i8) kg*m^2/s^2;
           (%o8)                     (6241509596477042688) (eV)
           (%i9) kg*m^3/s^2;
           (%o9)                    (6241509596477042688) (eV m)
           (%i10) kg*m*km/s^2;
           (%o10)                   (6241509596477042688000) (eV)
           (%i11) uforget([dyn,eV]);
           (%o11)                           [false, false]
           (%i12) kg*m/s^2;
           (%o12)                                 N
           (%i13) kg*m^2/s^2;
           (%o13)                                 J
           (%i14) kg*m^3/s^2;
           (%o14)                                J m
           (%i15) kg*m*km/s^2;
           (%o15)                            (1000) (J)
     Without usersetunits, the initial inputs would have been converted to MKS, and
     uforget would have resulted in a return to MKS rules. Instead, the user preferences are
     respected in both cases. Notice these can still be overridden if desired. To completely
     eliminate this simplification - i.e. to have the user defaults reset to factory defaults
     - the dontusedimension command can be used. uforget can restore user settings
     again, but only if usedimension frees it for use. Alternately, kill(usersetunits)
     will completely remove all knowledge of the user defaults from the session. Here are
     some examples of how these various options work.
           (%i2) kg*m/s^2;
           (%o2)                                  N
           (%i3) kg*m^2/s^2;
           (%o3)                                  J
           (%i4) setunits([dyn,eV]);
           (%o4)                                done
           (%i5) kg*m/s^2;
           (%o5)                           (100000) (dyn)
           (%i6) kg*m^2/s^2;
           (%o6)                     (6241509596477042688) (eV)
           (%i7) uforget([dyn,eV]);
           (%o7)                          [false, false]
           (%i8) kg*m/s^2;
           (%o8)                                  N
           (%i9) kg*m^2/s^2;
           (%o9)                                  J
           (%i10) dontusedimension(N);
           (%o10)                             [%force]
1176                                                  Maxima 5.45.0 Manual
       (%i11) dontusedimension(J);
       (%o11)                        [%energy, %force]
       (%i12) kg*m/s^2;
                                           kg m
       (%o12)                              ----
                                             2
                                            s
       (%i13) kg*m^2/s^2;
                                               2
                                           kg m
       (%o13)                              -----
                                             2
                                            s
       (%i14) setunits([dyn,eV]);
       (%o14)                              done
       (%i15) kg*m/s^2;
                                           kg m
       (%o15)                              ----
                                             2
                                            s
       (%i16) kg*m^2/s^2;
                                               2
                                           kg m
       (%o16)                              -----
                                             2
                                            s
       (%i17) uforget([dyn,eV]);
       (%o17)                        [false, false]
       (%i18) kg*m/s^2;
                                           kg m
       (%o18)                              ----
                                             2
                                            s
       (%i19) kg*m^2/s^2;
                                               2
                                           kg m
       (%o19)                              -----
                                             2
                                            s
       (%i20) usedimension(N);
       Done. To have Maxima simplify to this dimension, use
       setunits([unit]) to select an unit.
       (%o20)                              true
       (%i21) usedimension(J);
       Done. To have Maxima simplify to this dimension, use
       setunits([unit]) to select an unit.
       (%o21)                              true
Chapter 90: unit                                                                       1177
           (%i22) kg*m/s^2;
                                                        kg m
           (%o22)                                       ----
                                                          2
                                                         s
           (%i23) kg*m^2/s^2;
                                                            2
                                                        kg m
           (%o23)                                       -----
                                                          2
                                                         s
           (%i24)   setunits([dyn,eV]);
           (%o24)                                       done
           (%i25)   kg*m/s^2;
           (%o25)                                 (100000) (dyn)
           (%i26)   kg*m^2/s^2;
           (%o26)                          (6241509596477042688) (eV)
           (%i27)   uforget([dyn,eV]);
           (%o27)                                  [false, false]
           (%i28)   kg*m/s^2;
           (%o28)                                          N
           (%i29)   kg*m^2/s^2;
           (%o29)                                          J
           (%i30)   kill(usersetunits);
           (%o30)                                       done
           (%i31)   uforget([dyn,eV]);
           (%o31)                                 [false, false]
           (%i32)   kg*m/s^2;
                                                        kg m
           (%o32)                                       ----
                                                          2
                                                         s
           (%i33) kg*m^2/s^2;
                                                            2
                                                        kg m
           (%o33)                                       -----
                                                          2
                                                         s
     Unfortunately this wide variety of options is a little confusing at first, but once the
     user grows used to them they should find they have very full control over their working
     environment.
%unitexpand                                                                        [Variable]
       Default value: 2
       This is the value supplied to metricexpandall during the initial loading of unit.
                                                                                       1179
91 wrstcse
             (%i2) vals: [
                 R_1= 1000.0*(1+tol[1]*.01),
                 R_2= 2000.0*(1+tol[2]*.01)
              ];
             (%o2) [R_1 = 1000.0 (0.01 tol + 1),
                                           1
                                                  R_2 = 2000.0 (0.01 tol + 1)]
                                                                        2
             (%i3) wc_inputvalueranges(vals);
                      [ R_1 min = 990.0    typ = 1000.0 max = 1010.0 ]
             (%o3)    [                                               ]
                      [ R_2 min = 1980.0 typ = 2000.0 max = 2020.0 ]
           (%i2) vals: [
               R_1= 1000.0*(1+tol[1]*.01),
               R_2= 2000.0*(1+tol[2]*.01)
            ];
           (%o2) [R_1 = 1000.0 (0.01 tol + 1),
                                         1
                                                R_2 = 2000.0 (0.01 tol + 1)]
                                                                      2
           (%i3) divider: U_Out=U_In*(R_1)/(R_1+R_2);
                                            R_1 U_In
           (%o3)                    U_Out = ---------
                                            R_2 + R_1
           (%i4) wc_montecarlo(subst(vals,rhs(divider)),10);
           (%o4) [0.3365488313167528 U_In, 0.3339089445851889 U_In,
           0.314651402884122 U_In, 0.3447359711624277 U_In,
           0.3294005710066001 U_In, 0.3330897542463686 U_In,
           0.3397591863729343 U_In, 0.3227030530673181 U_In,
           0.3385512773502185 U_In, 0.314764470912582 U_In]
       Example:
           (%i1) load("wrstcse")$
           (%i2) val_a: [
                R_1= 1000.0*(1+tol[1]*.01),
                R_2= 1000.0*(1+tol[2]*.01)
            ];
           (%o2) [R_1 = 1000.0 (0.01 tol + 1),
                                          1
                                              R_2 = 1000.0 (0.01 tol + 1)]
                                                                    2
           (%i3) val_b: [
                R_3= 1000.0*(1+tol[1]*.01),
                R_4= 1000.0*(1+tol[2]*.01)
            ];
           (%o3) [R_3 = 1000.0 (0.01 tol + 1),
                                          1
                                              R_4 = 1000.0 (0.01 tol + 1)]
                                                                    2
           (%i4) wc_tolappend(val_a,val_b);
           (%o4) [R_1 = 1000.0 (0.01 tol + 1),
                                          2
           R_2 = 1000.0 (0.01 tol + 1), R_3 = 1000.0 (0.01 tol + 1),
                                   1                          4
           R_4 = 1000.0 (0.01 tol + 1)]
                                   3
92 zeilberger
Fk = fk+1 − fk .
[R (n, k) , [a0 , a1 , . . . , ad ]] .
[R (n, k) , [a0 , a1 , . . . , ad ]] .
This chapter provides detailed information about the meaning of some error messages or
on how to recover from errors.
 • If maxima is run by sbcl sbcl’s memory limit might be set to a value that is too low to
   solve the current problem. In this case the command-line option --dynamic-space-
   size <n> allows to tell sbcl to reserve n megabytes for the heap. It is to note, though,
   that sbcl has to handle several distinct types of memory and therefore might be able
   to only reserve about half of the available physical memory. Also note that 32-bit
   processes might only be able to access 2GB of physical memory.
94 Command-line options
-u version, --use-version=version
          Launch Maxima version version. Use --list-avail to see the list of possible
          values.
--userdir=directory
          Use directory for user directory (default is %USERPROFILE%/maxima for Win-
          dows, $HOME/.maxima for others)
-v, --verbose
          Print extra information from the Maxima wrapper script.
--version
            Print the (default) installed version.
--very-quiet
          Suppress expression labels and the Maxima start-up message.
-X Lisp options, --lisp-options=Lisp options
           Options to be given to the underlying Lisp.
                                                                                                                                                                                          1193
!                                                                                                  +
! . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171    + . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
!! . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 170
                                                                                                   –
#                                                                                                  - . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
# . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 119
                                                                                                   .
$                                                                                                  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116
$ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
                                                                                                   /
%                                                                                                  / . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
% . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
%% . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16    :
%and. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1149
%c . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 702     : .............................................                                              121
%e . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50    :: . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   122
%e_to_numlog . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173                   ::= . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .    123
%edispflag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25              := . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   124
%emode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 174
%enumer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 174
%f . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 306
                                                                                                   ;
%gamma. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50         ; . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
%i . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
%iargs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181
%if . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1150       <
%k1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 702      < . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
%k2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 702      <= . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
%m . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 306
%or . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1150
%phi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50      =
%pi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51     = . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 119
%piargs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 180
%rnum. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 357
%rnum_list . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 357               >
%s . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 290     > . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
%th . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17     >= . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
%union . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1167
%unitexpand. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1178
%w . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 306     ?
                                                                                                   ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
                                                                                                   ?? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
’
' . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131
'' . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133     [
                                                                                                   [ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
*
* . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113    ]
** . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116     ] . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
1194                                                                                                                                          Maxima 5.45.0 Manual
^                                                                                                  aform. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 493
^ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113    agd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1094
^^ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 116     airy_ai . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 290
                                                                                                   airy_bi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 290
                                                                                                   airy_dai . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 290
                                                                                                   airy_dbi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 290
_ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15   alg_type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 493
__ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15    algebraic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257
                                                                                                   algepsilon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 357
                                                                                                   algexact . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 357
‘                                                                                                  algsys . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 358
                                                                                                   alias . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
‘ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 920
                                                                                                   aliases . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
‘‘ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 922
                                                                                                   all_dotsimp_denoms . . . . . . . . . . . . . . . . . . . . . . . . . . 427
                                                                                                   allbut. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
@                                                                                                  allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 785
                                                                                                   allroots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 359
@ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83   allsym . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 442
                                                                                                   alphabetic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189
                                                                                                   alphacharp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1133
|                                                                                                  alphanumericp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1134
| . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 458    alt_display_output_type . . . . . . . . . . . . . . . . . . . . 666
                                                                                                   amortization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 938
                                                                                                   and . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118
~                                                                                                  animation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 910
~ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 457    annuity_fv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 938
                                                                                                   annuity_pv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 938
                                                                                                   antid. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 321
A                                                                                                  antidiff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 322
abasep . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 494           AntiDifference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1184
abs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161      antisymmetric . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 146
absboxchar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26              append. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
absint . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 511           appendfile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242
absolute_real_time . . . . . . . . . . . . . . . . . . . . . . . . . . 563                         apply. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 615
acos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181       apply_cycles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 693
acosh. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181         apply1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 569
acot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181       apply2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 569
acoth. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181         applyb1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 569
acsc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181       apropos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
acsch. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181         args . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
activate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198             arit_amortization . . . . . . . . . . . . . . . . . . . . . . . . . . . 939
activecontexts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198                     arithmetic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1093
adapt_depth . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 227, 785                     arithsum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1093
add_edge . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 970             array . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
add_edges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 970              arrayapply . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
add_vertex . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 970               arrayinfo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
add_vertices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 970                   arraymake . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
addcol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 400           arrays. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
Addition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113             arraysetapply . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
additive . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145             ascii . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1134
addmatrices. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1019                  asec . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181
addrow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 401           asech. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181
adim . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 493       asin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 182
adjacency_matrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . 955                       asinh. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 182
adjoin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 588           askexp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 565
adjoint . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 401            askinteger . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198
adjust_external_format . . . . . . . . . . . . . . . . . . . . 1132                                asksign . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 199
af . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 493     assoc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
Appendix A: Function and Variable Index                                                                                                                                            1195
C                                                                                                cgreaterpignore . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1134
cabs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166     changename . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 433
canform . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 443          changevar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 335
canten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 442         chaosgame . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 901
capping . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 789, 910               charat . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1137
cardinality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 589              charfun . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205
carg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168     charfun2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 995
cartan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 325         charlist . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1137
cartesian_product . . . . . . . . . . . . . . . . . . . . . . . . . . . 589                      charp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1134
cartesian_product_list . . . . . . . . . . . . . . . . . . . . . 589                             charpoly . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 402
catch. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 617       chdir . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1057
cauchy_matrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 401                  chebyshev_t. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1069
cauchysum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 499            chebyshev_u. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1069
cbffac . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 291         check_overlaps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 426
cbrange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 790          checkdiv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 479
cbtics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 791         chinese . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 516
cdf_bernoulli . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 771                  cholesky . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1019
cdf_beta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 759           christof . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 468
cdf_binomial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 769                 chromatic_index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 956
cdf_cauchy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 766             chromatic_number . . . . . . . . . . . . . . . . . . . . . . . . . . . . 956
cdf_chi2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 751           cint. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1134
cdf_continuous_uniform . . . . . . . . . . . . . . . . . . . . . 760                             circulant_graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 950
cdf_discrete_uniform . . . . . . . . . . . . . . . . . . . . . . . 774                           clear_edge_weight . . . . . . . . . . . . . . . . . . . . . . . . . . . 956
cdf_empirical . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 722                  clear_rules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 584
cdf_exp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 755          clear_vertex_label . . . . . . . . . . . . . . . . . . . . . . . . . . 956
cdf_f. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 754       clebsch_gordan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 687
cdf_gamma . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 758            clebsch_graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 950
cdf_general_finite_discrete . . . . . . . . . . . . . . . 768                                    clessp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1135
cdf_geometric . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 772                  clesspignore . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1135
cdf_gumbel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 766             close . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1126
cdf_hypergeometric . . . . . . . . . . . . . . . . . . . . . . . . . . 775                       closefile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243
cdf_laplace . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 765              cmetric . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 465
cdf_logistic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 761                 cnonmet_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 485
cdf_lognormal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 757                  coeff. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 258
cdf_negative_binomial . . . . . . . . . . . . . . . . . . . . . . 776                            coefmatrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 402
cdf_noncentral_chi2 . . . . . . . . . . . . . . . . . . . . . . . . 753                          cograd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 478
cdf_noncentral_student_t . . . . . . . . . . . . . . . . . . . 750                               col . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 402
cdf_normal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 747             collapse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
cdf_pareto . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 761             collectterms . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1091
cdf_poisson . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 770              color . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228, 791, 910
cdf_rank_sum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1122                  color_bar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228
cdf_rayleigh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 763                 color_bar_tics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229
cdf_signed_rank . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1122                     colorbox . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 794
cdf_student_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 748                  columnop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1019
cdf_weibull . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 762              columns . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 796
cdisplay . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 480           columnspace. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1019
ceiling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 162          columnswap . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1019
center . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 910         columnvector . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 403
central_moment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 715                   combination. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1094
cequal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1134          combine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 146
cequalignore . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1134                  commutative . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 147
cf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 516   comp2pui . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 537
cfdisrep . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 517           compare . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205
cfexpand . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 517           compfile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 617
cflength . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 518           compile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 618
cframe_flag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 485              compile_file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 639
cgeodesic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 479            complement_graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . 951
cgreaterp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1134             complete_bipartite_graph . . . . . . . . . . . . . . . . . . . 951
Appendix A: Function and Variable Index                                                                                                                                             1197
L                                                                                                linearinterpol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 995
label . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229, 866           linechar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
label_alignment . . . . . . . . . . . . . . . . . . . . . . . . 819, 975                         linel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
label_orientation . . . . . . . . . . . . . . . . . . . . . . . . . . . 820                      linenum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
labels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20, 21          linewidth . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 911
lagrange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 993           linsolve . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 366
laguerre . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1069            linsolve_params . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 368
lambda . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 627         linsolvewarn . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 368
lambert_w . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 310            lispdisp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
laplace . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 331          List delimiters. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
laplacian_matrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . 963                     list_correlations . . . . . . . . . . . . . . . . . . . . . . . . . . . 725
lassociative . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152                 list_matrix_entries . . . . . . . . . . . . . . . . . . . . . . . . 413
last . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60    list_nc_monomials . . . . . . . . . . . . . . . . . . . . . . . . . . . 426
lastn . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60     listarith . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
lbfgs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1009         listarray . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
lbfgs_ncorrections . . . . . . . . . . . . . . . . . . . . . . . . 1014                          listconstvars . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
lbfgs_nfeval_max . . . . . . . . . . . . . . . . . . . . . . . . . . . 1014                      listdummyvars . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
lc_l . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 441     listify . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 597
lc_u . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 442     listoftens . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 433
lc2kdt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 440         listofvars . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
lcm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 521    listp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61, 1023
ldefint . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 344          lmax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 165
ldisp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35     lmin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 165
ldisplay . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36          lmxchar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 413
leftjust . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36          load . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 245
legend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229         load_pathname . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 245
legendre_p . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1069              loadfile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246
legendre_q . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1069              loadprint . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246
leinstein . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 469            local. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 629
length. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61       locate_matrix_entry . . . . . . . . . . . . . . . . . . . . . . . 1023
Less than . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117            log . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 176
Less than or equal . . . . . . . . . . . . . . . . . . . . . . . . . . . 117                     log_gamma . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 292
let . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 573    logabs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177
let_rule_packages . . . . . . . . . . . . . . . . . . . . . . . . . . . 575                      logarc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177
letrat . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 574         logcb. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 823
letrules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 574           logconcoeffp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177
letsimp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 575          logcontract . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177
levels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 230         logexpand . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 178
levi_civita . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 440              lognegint . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179
lfg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 486    logsimp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179
lfreeof . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96         logx . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 230, 823
lg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 487   logx_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 823
lgtreillis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 545             logy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 230, 824
lhospitallim . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319                 logy_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 825
lhs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 366    logz . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 825
li . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 175   lopow. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271
liediff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 444          lorentz_gauge . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 450
limit. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319       lowercasep . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1135
limsubst . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319           lpart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
linalg_rank. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1029                lrats_max_iter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271
Lindstedt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1015             lratsubst . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271
line_graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 952             lreduce . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
line_type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 821            lriem. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 486
line_width . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 822             lriemann . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 470
linear. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152, 1092              lsquares_estimates . . . . . . . . . . . . . . . . . . . . . . . . 1031
linear_program . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1086                    lsquares_estimates_approximate . . . . . . . . . . . 1034
linear_regression . . . . . . . . . . . . . . . . . . . . . . . . . . 1120                       lsquares_estimates_exact . . . . . . . . . . . . . . . . . . 1033
linear_solver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1185                   lsquares_mse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1035
Appendix A: Function and Variable Index                                                                                                                                            1205
numfactor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 303             P
nusum. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 502        packagefile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 566
nzeta. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 310        pade . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 503
nzetai . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 311          palette . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 230, 826
nzetar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 311          parabolic_cylinder_d . . . . . . . . . . . . . . . . . . . . . . . 307
                                                                                                  parametric . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 869
                                                                                                  parametric_surface . . . . . . . . . . . . . . . . . . . . . . . . . . 870
O                                                                                                 parg. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1158
                                                                                                  parGosper . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1185
obase . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37      parse_string . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1138
octets_to_number . . . . . . . . . . . . . . . . . . . . . . . . . . . 1145                       parse_timedate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 560
octets_to_oid . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1145                    part . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
octets_to_string . . . . . . . . . . . . . . . . . . . . . . . . . . . 1145                       part2cont . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 541
odd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 192     partfrac . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 522
odd_girth . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 965             partition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
oddfun . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 149          partition_set . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 600
oddp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45     partpol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 541
ode_check . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 701             partswitch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
ode2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 378      path_digraph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 953
odelin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 701          path_graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 953
oid_to_octets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1146                    pathname_directory . . . . . . . . . . . . . . . . . . . . . . . . . . 246
op . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97   pathname_name . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246
opacity . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 911           pathname_type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246
opena . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1128          pdf_bernoulli . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 771
opena_binary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1050                   pdf_beta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 759
openr . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1128          pdf_binomial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 769
openr_binary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1050                   pdf_cauchy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 766
openw . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1128          pdf_chi2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 751
openw_binary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1050                   pdf_continuous_uniform . . . . . . . . . . . . . . . . . . . . . 760
operatorp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98            pdf_discrete_uniform . . . . . . . . . . . . . . . . . . . . . . . 774
opproperties . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 155                  pdf_exp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 755
opsubst . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98, 1059                pdf_f. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 754
optimize . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99           pdf_file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232
optimprefix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99              pdf_gamma . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 758
optionset . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22            pdf_general_finite_discrete . . . . . . . . . . . . . . . 767
or . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118    pdf_geometric . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 772
                                                                                                  pdf_gumbel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 766
orbit. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 544
                                                                                                  pdf_hypergeometric . . . . . . . . . . . . . . . . . . . . . . . . . . 774
orbits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 904
                                                                                                  pdf_laplace . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 765
ordergreat . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
                                                                                                  pdf_logistic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 761
ordergreatp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
                                                                                                  pdf_lognormal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 757
orderless . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
                                                                                                  pdf_negative_binomial . . . . . . . . . . . . . . . . . . . . . . 776
orderlessp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99             pdf_noncentral_chi2 . . . . . . . . . . . . . . . . . . . . . . . . 753
orientation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 911               pdf_noncentral_student_t . . . . . . . . . . . . . . . . . . . 749
origin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 911          pdf_normal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 747
orthogonal_complement . . . . . . . . . . . . . . . . . . . . . 1028                              pdf_pareto . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 761
orthopoly_recur . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1069                      pdf_poisson . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 770
orthopoly_returns_intervals . . . . . . . . . . . . . . 1070                                      pdf_rank_sum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1122
orthopoly_weight . . . . . . . . . . . . . . . . . . . . . . . . . . . 1070                       pdf_rayleigh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 763
out_neighbors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 965                   pdf_signed_rank . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1122
outative . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156            pdf_student_t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 748
outchar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22          pdf_weibull . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 762
outermap . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 653            pearson_skewness . . . . . . . . . . . . . . . . . . . . . . . . . . . . 720
outofpois . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 512             perm_cycles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694
                                                                                                  perm_decomp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694
                                                                                                  perm_inverse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694
                                                                                                  perm_length . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 694
                                                                                                  perm_lex_next . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 695
1208                                                                                                                                       Maxima 5.45.0 Manual
postfix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130          Q
postsubscript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26                 qput . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
postsuperscript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26                   qrange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 717
potential . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 344            qty . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 927
power_mod . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 522            quad_control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 356
powerdisp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38           quad_qag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 347
powerseries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 504              quad_qagi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 349
powerset . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 601           quad_qagp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 355
pred . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141     quad_qags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 348
prederror . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 651            quad_qawc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 350
prefix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130         quad_qawf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 351
presubscript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26              quad_qawo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 353
presuperscript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26                  quad_qaws . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 354
prev_prime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 523             quadrilateral . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 878
primep . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 522         quantile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 717
                                                                                                 quantile_bernoulli . . . . . . . . . . . . . . . . . . . . . . . . . . 771
primep_number_of_tests . . . . . . . . . . . . . . . . . . . . . 523
                                                                                                 quantile_beta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 759
primes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 523
                                                                                                 quantile_binomial . . . . . . . . . . . . . . . . . . . . . . . . . . . 769
principal_components . . . . . . . . . . . . . . . . . . . . . . . 726
                                                                                                 quantile_cauchy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 766
print . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39     quantile_chi2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 752
print_graph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 966              quantile_continuous_uniform . . . . . . . . . . . . . . . 760
printf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1129          quantile_discrete_uniform. . . . . . . . . . . . . . . . . . 774
printfile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 247            quantile_exp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 755
printpois . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 514            quantile_f . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 754
printprops . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196             quantile_gamma . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 758
prodrac . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 547          quantile_general_finite_discrete . . . . . . . . . 768
product . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 495          quantile_geometric . . . . . . . . . . . . . . . . . . . . . . . . . . 773
product_use_gamma . . . . . . . . . . . . . . . . . . . . . . . . . . 1102                       quantile_gumbel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 766
program . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 977          quantile_hypergeometric . . . . . . . . . . . . . . . . . . . . 775
programmode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 369              quantile_laplace . . . . . . . . . . . . . . . . . . . . . . . . . . . . 765
prompt. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23       quantile_logistic . . . . . . . . . . . . . . . . . . . . . . . . . . . 761
properties . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196             quantile_lognormal . . . . . . . . . . . . . . . . . . . . . . . . . . 757
proportional_axes . . . . . . . . . . . . . . . . . . . . . . . . . . . 831                      quantile_negative_binomial . . . . . . . . . . . . . . . . 776
props. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196       quantile_noncentral_chi2 . . . . . . . . . . . . . . . . . . . 753
propvars . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196           quantile_noncentral_student_t . . . . . . . . . . . . . 750
                                                                                                 quantile_normal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 747
ps_file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232
                                                                                                 quantile_pareto . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 762
psexpand . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 505
                                                                                                 quantile_poisson . . . . . . . . . . . . . . . . . . . . . . . . . . . . 770
psi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 302, 474
                                                                                                 quantile_rayleigh . . . . . . . . . . . . . . . . . . . . . . . . . . . 763
psubst . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103         quantile_student_t . . . . . . . . . . . . . . . . . . . . . . . . . . 749
ptriangularize . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1028                    quantile_weibull . . . . . . . . . . . . . . . . . . . . . . . . . . . . 762
pui . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 539    quartile_skewness . . . . . . . . . . . . . . . . . . . . . . . . . . . 721
pui_direct . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 544             quit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
pui2comp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 539           qunit. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 523
pui2ele . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 540          quotient . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 274
pui2polynome . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 547
puireduc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 540
push . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63    R
put . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196    racah_v . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 687
pv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 937   racah_w . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 687
pwilt. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 344       radcan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156
pytranslate. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1074                radexpand . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 157
                                                                                                 radius . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 912, 966
                                                                                                 radsubstflag . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 281
                                                                                                 random . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 187
                                                                                                 random_bernoulli . . . . . . . . . . . . . . . . . . . . . . . . . . . . 772
                                                                                                 random_beta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 760
                                                                                                 random_binomial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 770
1210                                                                                                                                       Maxima 5.45.0 Manual
X                                                                                                 yx_ratio . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235
x . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234
x_voxel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 840
xaxis. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 841        Z
xaxis_color . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 841               z . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235
xaxis_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 841                     z_voxel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 851
xaxis_type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 842              zaxis. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 851
xaxis_width . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 842               zaxis_color . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 851
xlabel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234, 843             zaxis_type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 852
xlabel_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . 843                      zaxis_width . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 852
xlength . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 913           Zeilberger . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1185
xrange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 844          zeroa . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
xrange_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . 844                      zerob . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
xreduce . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69          zerobern . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 523
xthru. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 158        zeroequiv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 208
xtics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234, 844            zerofor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1029
xtics_axis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 845              zeromatrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 423
xtics_rotate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 845                  zeromatrixp. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1029
xtics_rotate_secondary . . . . . . . . . . . . . . . . . . . . . 846                              zeta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 523
xtics_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 846                     zeta%pi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 524
xtics_secondary_axis . . . . . . . . . . . . . . . . . . . . . . . 846                            zgeev . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1008
xu_grid . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 846           zheev . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1008
xy_file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 846           zlabel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235, 852
xy_scale . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235            zlabel_rotate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853
xyplane . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 846           zlange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1006
                                                                                                  zlength . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 913
                                                                                                  zmin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236
Y                                                                                                 zn_add_table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 524
y . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235   zn_carmichael_lambda . . . . . . . . . . . . . . . . . . . . . . . 525
y_voxel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 847           zn_characteristic_factors. . . . . . . . . . . . . . . . . . 524
yaxis. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 847        zn_determinant . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 525
yaxis_color . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 847               zn_factor_generators . . . . . . . . . . . . . . . . . . . . . . . 526
yaxis_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 847                     zn_invert_by_lu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 526
yaxis_type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 848              zn_log . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 527
yaxis_width . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 848               zn_mult_table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 528
ylabel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235, 848             zn_nth_root . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 530
ylabel_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . 848                      zn_order . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 532
ylength . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 913           zn_power_table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 532
yrange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 849          zn_primroot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 534
yrange_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . 849                      zn_primroot_limit . . . . . . . . . . . . . . . . . . . . . . . . . . . 535
ytics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235, 850            zn_primroot_p . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 535
ytics_axis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 850              zn_primroot_pretest . . . . . . . . . . . . . . . . . . . . . . . . 536
ytics_rotate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 850                  zn_primroot_verbose . . . . . . . . . . . . . . . . . . . . . . . . 536
ytics_rotate_secondary . . . . . . . . . . . . . . . . . . . . . 850                              zrange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853
ytics_secondary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 850                     ztics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236, 853
ytics_secondary_axis . . . . . . . . . . . . . . . . . . . . . . . 850                            ztics_axis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853
yv_grid . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 850           ztics_rotate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 853