aboutsummaryrefslogtreecommitdiff
path: root/src/interp/bc-matrix.boot
diff options
context:
space:
mode:
Diffstat (limited to 'src/interp/bc-matrix.boot')
-rw-r--r--src/interp/bc-matrix.boot153
1 files changed, 153 insertions, 0 deletions
diff --git a/src/interp/bc-matrix.boot b/src/interp/bc-matrix.boot
new file mode 100644
index 00000000..bdfcbb9f
--- /dev/null
+++ b/src/interp/bc-matrix.boot
@@ -0,0 +1,153 @@
+-- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd.
+-- All rights reserved.
+--
+-- Redistribution and use in source and binary forms, with or without
+-- modification, are permitted provided that the following conditions are
+-- met:
+--
+-- - Redistributions of source code must retain the above copyright
+-- notice, this list of conditions and the following disclaimer.
+--
+-- - Redistributions in binary form must reproduce the above copyright
+-- notice, this list of conditions and the following disclaimer in
+-- the documentation and/or other materials provided with the
+-- distribution.
+--
+-- - Neither the name of The Numerical ALgorithms Group Ltd. nor the
+-- names of its contributors may be used to endorse or promote products
+-- derived from this software without specific prior written permission.
+--
+-- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
+-- IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+-- TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
+-- PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
+-- OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+-- EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+-- PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+-- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
+-- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+-- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+-- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+
+-- Basic Command matrix entry
+
+bcMatrix() == bcReadMatrix nil
+
+bcReadMatrix exitFunctionOrNil ==
+ page := htInitPage('"Matrix Basic Command", nil)
+ htpSetProperty(page,'exitFunction,exitFunctionOrNil)
+ htMakePage
+ '((domainConditions
+ (isDomain PI (PositiveInteger)))
+ (text . "Enter the size of the matrix:")
+ (inputStrings
+ ("Number of {\em rows}:\space{3}" "" 5 2 rows PI)
+ ("Number of {\em columns}: " "" 5 2 cols PI))
+ (text . "\blankline ")
+ (text . "How would you like to enter the matrix?")
+ (text . "\beginmenu")
+ (text . "\item ")
+ (bcLinks ("\menuitemstyle{By entering individual entries}" "" bcInputExplicitMatrix explicit))
+ (text . "\item ")
+ (bcLinks ("\menuitemstyle{By formula}" "" bcInputMatrixByFormula formula))
+ (text . "\endmenu"))
+ htShowPage()
+
+bcInputMatrixByFormula(htPage,junk) ==
+ page := htInitPage('"Basic Matrix Command", htpPropertyList htPage)
+ htMakePage '(
+ (domainConditions
+ (isDomain S (Symbol))
+ (isDomain FE (Expression (Integer))))
+ (text . "\menuitemstyle{}\tab{2}")
+ (text . "Enter the {\em row variable}: ")
+ (text . "\tab{36}")
+ (bcStrings (6 i rowVar S))
+ (text . "\blankline ")
+ (text . "\newline ")
+ (text . "\menuitemstyle{}\tab{2}")
+ (text . "Enter the {\em column variable}: ")
+ (text . "\tab{36}")
+ (bcStrings (6 j colVar S))
+ (text . "\blankline ")
+ (text . "\newline ")
+ (text . "\menuitemstyle{}\tab{2}")
+ (text . "Enter the general {\em formula} for the entries:")
+ (text . "\newline\tab{2} ")
+ (bcStrings (40 "1/(x - i - j - 1)" formula FE)))
+ htMakeDoneButton('"Continue", 'bcInputMatrixByFormulaGen)
+ nrows :=
+ null $bcParseOnly => objValUnwrap htpLabelSpadValue(htPage,'rows)
+ PARSE_-INTEGER htpLabelInputString(htPage,'rows)
+ ncols :=
+ null $bcParseOnly => objValUnwrap htpLabelSpadValue(htPage,'cols)
+ PARSE_-INTEGER htpLabelInputString(htPage,'cols)
+ htpSetProperty(page, 'nrows, nrows)
+ htpSetProperty(page, 'ncols, ncols)
+ htShowPage()
+
+bcInputMatrixByFormulaGen htPage ==
+ fun := htpProperty(htPage,'exitFunction) => FUNCALL(fun, htPage)
+ formula := htpLabelInputString(htPage,'formula)
+ rowVar := htpLabelInputString(htPage,'rowVar)
+ colVar := htpLabelInputString(htPage,'colVar)
+ nrows := htpProperty(htPage,'nrows)
+ ncols := htpProperty(htPage,'ncols)
+ bcGen STRCONC('"matrix([[",formula,'" for ",colVar,'" in 1..",
+ STRINGIMAGE ncols,'"] for ",rowVar,'" in 1..",STRINGIMAGE nrows,'"])")
+
+bcInputExplicitMatrix(htPage,junk) ==
+ nrows :=
+ null $bcParseOnly => objValUnwrap htpLabelSpadValue(htPage,'rows)
+ PARSE_-INTEGER htpLabelInputString(htPage,'rows)
+ ncols :=
+ null $bcParseOnly => objValUnwrap htpLabelSpadValue(htPage,'cols)
+ PARSE_-INTEGER htpLabelInputString(htPage,'cols)
+ cond := nil
+ k := 0
+ wrows := # STRINGIMAGE nrows
+ wcols := # STRINGIMAGE ncols
+ labelList :=
+ "append"/[[f for j in 1..ncols] for i in 1..nrows] where f ==
+ rowpart := STRCONC('"{\em Row",htStringPad(i,wrows))
+ colpart := STRCONC('", Column",htStringPad(j,wcols),'":}\space{2}")
+ prefix := STRCONC(rowpart,colpart)
+ -- name := INTERN STRCONC(htMkName('"row",i),htMkName('"col",j))
+ name := INTERN STRINGIMAGE (k := k + 1)
+ [prefix,'"",30, 0,name,'P]
+ labelList :=
+ [['domainConditions, '(isDomain P (Polynomial $EmptyMode)), cond],
+ ['inputStrings, :labelList] ]
+ page := htInitPage('"Solve Basic Command", htpPropertyList htPage)
+ bcHt '"Enter the entries of the matrix:"
+ htMakePage labelList
+ htMakeDoneButton('"Continue", 'bcGenExplicitMatrix)
+ htpSetProperty(page,'nrows,nrows)
+ htpSetProperty(page,'ncols,ncols)
+ htShowPage()
+
+bcGenExplicitMatrix htPage ==
+ htpSetProperty(htPage,'matrix,htpInputAreaAlist htPage)
+ fun := htpProperty(htPage,'exitFunction) => FUNCALL(fun, htPage)
+ bcGen bcMatrixGen htPage
+
+bcMatrixGen htPage ==
+ nrows := htpProperty(htPage,'nrows)
+ ncols := htpProperty(htPage,'ncols)
+ mat := htpProperty(htPage,'matrix)
+ formula := LASSOC('formula,mat) =>
+ formula := formula.0
+ rowVar := LASSOC('rowVar,mat).0
+ colVar := LASSOC('colVar,mat).0
+ STRCONC('"matrix([[",formula,'" for ",colVar,'" in 1..",
+ STRINGIMAGE ncols,'"] for ",rowVar,'" in 1..",STRINGIMAGE nrows,'"])")
+ mat := htpProperty(htPage,'matrix) =>
+ mat := REVERSE mat
+ k := -1
+ matform := [[mat.(k := k + 1).1
+ for j in 0..(ncols-1)] for i in 0..(nrows-1)]
+ matstring := bcwords2liststring [bcwords2liststring x for x in matform]
+ STRCONC('"matrix(",matstring,'")")
+ systemError nil
+