All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jmol.modelsetbio.Sheet Maven / Gradle / Ivy

There is a newer version: 14.31.10
Show newest version
/* $RCSfile$
 * $Author: hansonr $
 * $Date: 2007-02-25 19:38:15 -0600 (Sun, 25 Feb 2007) $
 * $Revision: 6934 $
 *
 * Copyright (C) 2002-2005  The Jmol Development Team
 *
 * Contact: [email protected]
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2.1 of the License, or (at your option) any later version.
 *
 *  This library 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
 *  Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 */
package org.jmol.modelsetbio;


import org.jmol.c.STR;

import javajs.util.Measure;
import javajs.util.P3;
import javajs.util.V3;

public class Sheet extends ProteinStructure {

  /**
   * @param apolymer
   * @param monomerIndex
   * @param monomerCount
   * @param subtype
   * @j2sIgnoreSuperConstructor
   * @j2sOverride
   * 
   */
  Sheet(AlphaPolymer apolymer, int monomerIndex, int monomerCount, STR subtype) {
    setupPS(apolymer, STR.SHEET, monomerIndex, monomerCount);
    this.subtype = subtype;
  }

  @Override
  public void calcAxis() {
    if (axisA != null)
      return;
    if (nRes == 2) {
      axisA = apolymer.getLeadPoint(monomerIndexFirst);
      axisB = apolymer.getLeadPoint(monomerIndexFirst + 1);
    } else {
      axisA = new P3();
      apolymer.getLeadMidPoint(monomerIndexFirst + 1, axisA);
      axisB = new P3();
      apolymer.getLeadMidPoint(monomerIndexFirst + nRes - 1, axisB);
    }

    axisUnitVector = new V3();
    axisUnitVector.sub2(axisB, axisA);
    axisUnitVector.normalize();

    P3 tempA = new P3();
    apolymer.getLeadMidPoint(monomerIndexFirst, tempA);
    if (notHelixOrSheet(monomerIndexFirst - 1))
      Measure
          .projectOntoAxis(tempA, axisA, axisUnitVector, vectorProjection);
    P3 tempB = new P3();
    apolymer.getLeadMidPoint(monomerIndexFirst + nRes, tempB);
    if (notHelixOrSheet(monomerIndexFirst + nRes))
      Measure
          .projectOntoAxis(tempB, axisA, axisUnitVector, vectorProjection);
    axisA = tempA;
    axisB = tempB;
  }

  private boolean notHelixOrSheet(int i) {
    return (i < 0 || i >= apolymer.monomerCount 
        || !apolymer.monomers[i].isHelix() 
          && !apolymer.monomers[i].isSheet());
  }

  V3 widthUnitVector;
  V3 heightUnitVector;

  void calcSheetUnitVectors() {
    if (!(apolymer instanceof AminoPolymer))
      return;
    if (widthUnitVector == null) {
      V3 vectorCO = new V3();
      V3 vectorCOSum = new V3();
      AminoMonomer amino = (AminoMonomer) apolymer.monomers[monomerIndexFirst];
      vectorCOSum.sub2(amino.getCarbonylOxygenAtom(), amino
          .getCarbonylCarbonAtom());
      for (int i = nRes; --i > monomerIndexFirst;) {
        amino = (AminoMonomer) apolymer.monomers[i];
        vectorCO.sub2(amino.getCarbonylOxygenAtom(), amino
            .getCarbonylCarbonAtom());
        if (vectorCOSum.angle(vectorCO) < (float) Math.PI / 2)
          vectorCOSum.add(vectorCO);
        else
          vectorCOSum.sub(vectorCO);
      }
      heightUnitVector = vectorCO; // just reuse the same temp vector;
      heightUnitVector.cross(axisUnitVector, vectorCOSum);
      heightUnitVector.normalize();
      widthUnitVector = vectorCOSum;
      widthUnitVector.cross(axisUnitVector, heightUnitVector);
    }
  }

  public void setBox(float w, float h, P3 pt, V3 vW, V3 vH, P3 ptC, float scale) {
    if (heightUnitVector == null)
      calcSheetUnitVectors();
    vW.setT(widthUnitVector);
    vW.scale(scale * w);
    vH.setT(heightUnitVector);
    vH.scale(scale * h);
    ptC.ave(vW, vH);
    ptC.sub2(pt, ptC);
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy