Package ket.math.purpose.symbolicFunctions

Source Code of ket.math.purpose.symbolicFunctions.SymbolicFunctionVector

/*
* Copyright (C) 2011  Alasdair C. Hamilton
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program.  If not, see <http://www.gnu.org/licenses/>
*/

package ket.math.purpose.symbolicFunctions;

import java.awt.*;
import java.util.*;

import ket.display.*;
import ket.display.LatexTools;
import ket.display.box.Box;
import ket.display.box.BoxGraphic;
import ket.display.box.BoxList;
import ket.display.box.BoxTools;
import ket.display.box.BoxWord;
import ket.math.*;
import ket.math.convert.Like;
import ket.math.purpose.SymbolicState;

/**
* A specific mathematical operation that acts on arguments in a case-specific
* way.
*/
public class SymbolicFunctionVector extends SymbolicFunctionForm {

  @Override
  public String toLatex(Vector<Argument> args) {
    Argument[][] table = asTable(args);
    if (table==null) {
      table = new Argument[args.size()][1];
      for (int i=0; i<args.size(); i++) {
        table[i][0] = args.get(i);
      }
    }
    return LatexTools.tableToLatex(table, "[", "]");
  }

  private String tableToLatex(Vector<Argument> args) {
    String latex = "";
    for (Argument next : args) {
      latex += rowToLatex((Branch) next);
      if (next!=args.lastElement()) {
        latex += " \\\\";
      }
      latex += " \n";
    }
    return latex;
  }

  private String rowToLatex(Branch row) {
    String latex = "";
    Vector<Argument> args = row.getChildren();
    for (Argument element : args) {
      latex += element.toLatex();
      if (element!=args.lastElement()) {
        latex += " & ";
      }
    }
    return latex;
  }

  @Override
  public String toHTML(Vector<Argument> args) {
    Argument[][] table = asTable(args); // [[11,12], [21,22]]
    if (table==null) { // [1,2,3,4]
      table = asColumn(args);
    }
    if (table!=null) { //> square brackets
      return HTMLTools.toHTMLMatrix(table);
    } else {
      return super.toHTML(args);
    }
  }

  private Argument[][] asColumn(Vector<Argument> args) {
    if (args.size()==0) return null;
    Argument[][] column = new Argument[args.size()][1];
    for (int i=0; i<args.size(); i++) {
      column[i][0] = args.get(i);
    }
    return column;
  }

  private Argument[][] asTable(Vector<Argument> args) {
    return ArgumentTools.asTable(args, false);
  }

  @Override
  public Box toBox(Argument argument, long settings, ColourScheme colourScheme, Vector<Argument> args) {
    if (args.size()==0) {
      return super.toBox(argument, settings, colourScheme, args);
    }
    Argument[][] table = asTable(args);
    if (table!=null) {
      Box[][] boxTable = BoxTools.toBoxTable(table, colourScheme);
      Box[][] grid = BoxTools.padBoxTable(boxTable);
      Box matrixWithoutBrackets = BoxTools.gridToBox(argument, grid);
      matrixWithoutBrackets.setArgument(argument);
      return BoxTools.squareBrackets(argument, matrixWithoutBrackets, settings, colourScheme);
    } else {
      Vector<Box> boxArgs = BoxTools.padArgs(args, getArgLowerLimit(args.size()), colourScheme);
      Box box = BoxTools.centredVerticalBoxList(argument, 0L, boxArgs);
      return BoxTools.squareBrackets(argument, box, settings, colourScheme);
    }
  }
}
TOP

Related Classes of ket.math.purpose.symbolicFunctions.SymbolicFunctionVector

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.