public class Symmetry extends java.lang.Object implements SymmetryInterface
| Modifier and Type | Field and Description |
|---|---|
private boolean |
isBio |
private PointGroup |
pointGroup |
private SpaceGroup |
spaceGroup |
private SymmetryInfo |
symmetryInfo |
private UnitCell |
unitCell |
| Constructor and Description |
|---|
Symmetry() |
| Modifier and Type | Method and Description |
|---|---|
int |
addBioMoleculeOperation(javajs.util.M4 mat,
boolean isReverse) |
boolean |
addLatticeVectors(javajs.util.List<float[]> lattvecs) |
java.lang.String |
addOp(java.lang.String code,
javajs.util.Matrix rs,
javajs.util.Matrix vs,
javajs.util.Matrix sigma) |
int |
addSpaceGroupOperation(java.lang.String xyz,
int opId) |
boolean |
checkDistance(javajs.util.P3 f1,
javajs.util.P3 f2,
float distance,
float dx,
int iRange,
int jRange,
int kRange,
javajs.util.P3 ptOffset) |
boolean |
checkUnitCell(SymmetryInterface uc,
javajs.util.P3 cell,
javajs.util.P3 ptTemp,
boolean isAbsolute) |
boolean |
createSpaceGroup(int desiredSpaceGroupIndex,
java.lang.String name,
java.lang.Object object) |
java.lang.String |
fcoord(javajs.util.T3 p) |
javajs.util.P3[] |
getCanonicalCopy(float scale,
boolean withOffset) |
javajs.util.P3 |
getCartesianOffset() |
int[] |
getCellRange() |
boolean |
getCoordinatesAreFractional() |
javajs.util.P3 |
getFractionalOffset() |
java.lang.Object |
getLatticeDesignation() |
int |
getLatticeOp() |
java.lang.String |
getMatrixFromString(java.lang.String xyz,
float[] rotTransMatrix,
boolean allowScaling,
int modDim) |
float[] |
getNotionalUnitCell() |
javajs.util.Matrix |
getOperationRsVs(int iop) |
java.lang.Object |
getPointGroupInfo(int modelIndex,
boolean asDraw,
boolean asInfo,
java.lang.String type,
int index,
float scale) |
java.lang.String |
getPointGroupName() |
int |
getSiteMultiplicity(javajs.util.P3 pt) |
java.lang.Object |
getSpaceGroup() |
java.util.Map<java.lang.String,java.lang.Object> |
getSpaceGroupInfo(ModelSet modelSet,
int modelIndex,
java.lang.String spaceGroup,
int symOp,
javajs.util.P3 pt1,
javajs.util.P3 pt2,
java.lang.String drawID) |
java.lang.String |
getSpaceGroupInfo(java.lang.String name,
SymmetryInterface cellInfo) |
java.lang.String |
getSpaceGroupName() |
javajs.util.M4 |
getSpaceGroupOperation(int i) |
java.lang.String |
getSpaceGroupOperationCode(int iOp) |
int |
getSpaceGroupOperationCount() |
java.lang.String |
getSpaceGroupXyz(int i,
boolean doNormalize) |
java.lang.Object |
getSymmetryInfo(ModelSet modelSet,
int iModel,
int iAtom,
SymmetryInterface uc,
java.lang.String xyz,
int op,
javajs.util.P3 pt,
javajs.util.P3 pt2,
java.lang.String id,
int type) |
java.lang.String |
getSymmetryInfoString() |
java.lang.String |
getSymmetryInfoString(java.util.Map<java.lang.String,java.lang.Object> sginfo,
int symOp,
java.lang.String drawID,
boolean labelOnly) |
java.lang.Object[] |
getSymmetryOperationDescription(ModelSet modelSet,
int isym,
SymmetryInterface cellInfo,
javajs.util.P3 pt1,
javajs.util.P3 pt2,
java.lang.String id) |
java.lang.String[] |
getSymmetryOperations() |
Tensor |
getTensor(float[] parBorU) |
SymmetryInterface |
getUnitCell(javajs.util.T3[] points,
boolean setRelative) |
float[] |
getUnitCellAsArray(boolean vectorsOnly) |
java.lang.String |
getUnitCellInfo() |
float |
getUnitCellInfoType(int infoType) |
javajs.util.P3 |
getUnitCellMultiplier() |
java.lang.String |
getUnitCellState() |
javajs.util.V3[] |
getUnitCellVectors() |
javajs.util.P3[] |
getUnitCellVertices() |
java.lang.String |
getUnitsymmetryInfo() |
boolean |
haveUnitCell() |
boolean |
isBio() |
private boolean |
isNotCentroid(javajs.util.P3 center,
int n,
int[] minmax,
boolean centroidPacked) |
boolean |
isPeriodic() |
boolean |
isPolymer() |
boolean |
isSlab() |
boolean |
isSupercell() |
void |
newSpaceGroupPoint(int i,
javajs.util.P3 atom1,
javajs.util.P3 atom2,
int transX,
int transY,
int transZ) |
BS |
notInCentroid(ModelSet modelSet,
BS bsAtoms,
int[] minmax) |
javajs.util.V3[] |
rotateAxes(int iop,
javajs.util.V3[] axes,
javajs.util.P3 ptTemp,
javajs.util.M3 mTemp) |
void |
setCartesianOffset(javajs.util.T3 origin) |
void |
setFinalOperations(java.lang.String name,
javajs.util.P3[] atoms,
int iAtomFirst,
int noSymmetryCount,
boolean doNormalize) |
void |
setLattice(int latt)
set symmetry lattice type using Hall rotations
|
void |
setMinMaxLatticeParameters(javajs.util.P3i minXYZ,
javajs.util.P3i maxXYZ) |
void |
setOffset(int nnn) |
void |
setOffsetPt(javajs.util.P3 pt) |
SymmetryInterface |
setPointGroup(SymmetryInterface siLast,
Atom[] atomset,
BS bsAtoms,
boolean haveVibration,
float distanceTolerance,
float linearTolerance) |
void |
setSpaceGroup(boolean doNormalize) |
void |
setSpaceGroupFrom(SymmetryInterface symmetry) |
void |
setSymmetryInfo(int modelIndex,
java.util.Map<java.lang.String,java.lang.Object> modelAuxiliaryInfo) |
void |
setUnitCell(float[] notionalUnitCell) |
void |
setUnitCellAllFractionalRelative(boolean TF) |
void |
setUnitCellOrientation(javajs.util.M3 matUnitCellOrientation) |
void |
toCartesian(javajs.util.T3 fpt,
boolean isAbsolute) |
void |
toFractional(javajs.util.T3 pt,
boolean isAbsolute) |
javajs.util.P3 |
toSupercell(javajs.util.P3 fpt) |
void |
toUnitCell(javajs.util.P3 pt,
javajs.util.P3 offset) |
boolean |
unitCellEquals(SymmetryInterface uc2) |
void |
unitize(javajs.util.P3 ptFrac) |
private PointGroup pointGroup
private SpaceGroup spaceGroup
private SymmetryInfo symmetryInfo
private UnitCell unitCell
private boolean isBio
public SymmetryInterface setPointGroup(SymmetryInterface siLast, Atom[] atomset, BS bsAtoms, boolean haveVibration, float distanceTolerance, float linearTolerance)
setPointGroup in interface SymmetryInterfacepublic java.lang.String getPointGroupName()
getPointGroupName in interface SymmetryInterfacepublic java.lang.Object getPointGroupInfo(int modelIndex,
boolean asDraw,
boolean asInfo,
java.lang.String type,
int index,
float scale)
getPointGroupInfo in interface SymmetryInterfacepublic void setSpaceGroup(boolean doNormalize)
setSpaceGroup in interface SymmetryInterfacepublic int addSpaceGroupOperation(java.lang.String xyz,
int opId)
addSpaceGroupOperation in interface SymmetryInterfacepublic int addBioMoleculeOperation(javajs.util.M4 mat,
boolean isReverse)
addBioMoleculeOperation in interface SymmetryInterfacepublic void setLattice(int latt)
SymmetryInterfacesetLattice in interface SymmetryInterfacelatt - SHELX index or character lattice character P I R F A B C S T or \0public java.lang.String getSpaceGroupName()
getSpaceGroupName in interface SymmetryInterfacepublic java.lang.Object getSpaceGroup()
getSpaceGroup in interface SymmetryInterfacepublic void setSpaceGroupFrom(SymmetryInterface symmetry)
setSpaceGroupFrom in interface SymmetryInterfacepublic boolean createSpaceGroup(int desiredSpaceGroupIndex,
java.lang.String name,
java.lang.Object object)
createSpaceGroup in interface SymmetryInterfacepublic java.lang.String getSpaceGroupInfo(java.lang.String name,
SymmetryInterface cellInfo)
getSpaceGroupInfo in interface SymmetryInterfacepublic java.lang.Object getLatticeDesignation()
getLatticeDesignation in interface SymmetryInterfacepublic void setFinalOperations(java.lang.String name,
javajs.util.P3[] atoms,
int iAtomFirst,
int noSymmetryCount,
boolean doNormalize)
setFinalOperations in interface SymmetryInterfacepublic int getSpaceGroupOperationCount()
getSpaceGroupOperationCount in interface SymmetryInterfacepublic javajs.util.M4 getSpaceGroupOperation(int i)
getSpaceGroupOperation in interface SymmetryInterfacepublic java.lang.String getSpaceGroupXyz(int i,
boolean doNormalize)
getSpaceGroupXyz in interface SymmetryInterfacepublic void newSpaceGroupPoint(int i,
javajs.util.P3 atom1,
javajs.util.P3 atom2,
int transX,
int transY,
int transZ)
newSpaceGroupPoint in interface SymmetryInterfacepublic javajs.util.V3[] rotateAxes(int iop,
javajs.util.V3[] axes,
javajs.util.P3 ptTemp,
javajs.util.M3 mTemp)
rotateAxes in interface SymmetryInterfacepublic java.lang.Object[] getSymmetryOperationDescription(ModelSet modelSet, int isym, SymmetryInterface cellInfo, javajs.util.P3 pt1, javajs.util.P3 pt2, java.lang.String id)
public java.lang.String fcoord(javajs.util.T3 p)
fcoord in interface SymmetryInterfacepublic java.lang.String getMatrixFromString(java.lang.String xyz,
float[] rotTransMatrix,
boolean allowScaling,
int modDim)
getMatrixFromString in interface SymmetryInterfacepublic boolean getCoordinatesAreFractional()
getCoordinatesAreFractional in interface SymmetryInterfacepublic int[] getCellRange()
getCellRange in interface SymmetryInterfacepublic java.lang.String getSymmetryInfoString()
getSymmetryInfoString in interface SymmetryInterfacepublic java.lang.String[] getSymmetryOperations()
getSymmetryOperations in interface SymmetryInterfacepublic boolean isPeriodic()
isPeriodic in interface SymmetryInterfacepublic void setSymmetryInfo(int modelIndex,
java.util.Map<java.lang.String,java.lang.Object> modelAuxiliaryInfo)
setSymmetryInfo in interface SymmetryInterfacepublic void setUnitCell(float[] notionalUnitCell)
setUnitCell in interface SymmetryInterfacepublic boolean haveUnitCell()
haveUnitCell in interface SymmetryInterfacepublic java.lang.String getUnitsymmetryInfo()
public void setUnitCellOrientation(javajs.util.M3 matUnitCellOrientation)
setUnitCellOrientation in interface SymmetryInterfacepublic void unitize(javajs.util.P3 ptFrac)
unitize in interface SymmetryInterfacepublic void toUnitCell(javajs.util.P3 pt,
javajs.util.P3 offset)
toUnitCell in interface SymmetryInterfacepublic void toCartesian(javajs.util.T3 fpt,
boolean isAbsolute)
toCartesian in interface SymmetryInterfacepublic javajs.util.P3 toSupercell(javajs.util.P3 fpt)
toSupercell in interface SymmetryInterfacepublic void toFractional(javajs.util.T3 pt,
boolean isAbsolute)
toFractional in interface SymmetryInterfacepublic float[] getNotionalUnitCell()
getNotionalUnitCell in interface SymmetryInterfacepublic float[] getUnitCellAsArray(boolean vectorsOnly)
getUnitCellAsArray in interface SymmetryInterfacepublic Tensor getTensor(float[] parBorU)
getTensor in interface SymmetryInterfacepublic javajs.util.P3[] getUnitCellVertices()
getUnitCellVertices in interface SymmetryInterfacepublic javajs.util.P3 getCartesianOffset()
getCartesianOffset in interface SymmetryInterfacepublic void setCartesianOffset(javajs.util.T3 origin)
setCartesianOffset in interface SymmetryInterfacepublic javajs.util.P3 getFractionalOffset()
getFractionalOffset in interface SymmetryInterfacepublic void setOffsetPt(javajs.util.P3 pt)
setOffsetPt in interface SymmetryInterfacepublic void setOffset(int nnn)
setOffset in interface SymmetryInterfacepublic javajs.util.P3 getUnitCellMultiplier()
getUnitCellMultiplier in interface SymmetryInterfacepublic javajs.util.P3[] getCanonicalCopy(float scale,
boolean withOffset)
getCanonicalCopy in interface SymmetryInterfacepublic float getUnitCellInfoType(int infoType)
getUnitCellInfoType in interface SymmetryInterfacepublic java.lang.String getUnitCellInfo()
getUnitCellInfo in interface SymmetryInterfacepublic boolean isSlab()
isSlab in interface SymmetryInterfacepublic boolean isPolymer()
isPolymer in interface SymmetryInterfacepublic void setMinMaxLatticeParameters(javajs.util.P3i minXYZ,
javajs.util.P3i maxXYZ)
setMinMaxLatticeParameters in interface SymmetryInterfacepublic void setUnitCellAllFractionalRelative(boolean TF)
setUnitCellAllFractionalRelative in interface SymmetryInterfacepublic boolean checkDistance(javajs.util.P3 f1,
javajs.util.P3 f2,
float distance,
float dx,
int iRange,
int jRange,
int kRange,
javajs.util.P3 ptOffset)
checkDistance in interface SymmetryInterfacepublic javajs.util.V3[] getUnitCellVectors()
getUnitCellVectors in interface SymmetryInterfacepublic SymmetryInterface getUnitCell(javajs.util.T3[] points, boolean setRelative)
getUnitCell in interface SymmetryInterfacepublic boolean isSupercell()
isSupercell in interface SymmetryInterfacepublic java.lang.String getSymmetryInfoString(java.util.Map<java.lang.String,java.lang.Object> sginfo,
int symOp,
java.lang.String drawID,
boolean labelOnly)
getSymmetryInfoString in interface SymmetryInterfacepublic java.util.Map<java.lang.String,java.lang.Object> getSpaceGroupInfo(ModelSet modelSet, int modelIndex, java.lang.String spaceGroup, int symOp, javajs.util.P3 pt1, javajs.util.P3 pt2, java.lang.String drawID)
getSpaceGroupInfo in interface SymmetryInterfacepublic java.lang.Object getSymmetryInfo(ModelSet modelSet, int iModel, int iAtom, SymmetryInterface uc, java.lang.String xyz, int op, javajs.util.P3 pt, javajs.util.P3 pt2, java.lang.String id, int type)
getSymmetryInfo in interface SymmetryInterfacepublic BS notInCentroid(ModelSet modelSet, BS bsAtoms, int[] minmax)
notInCentroid in interface SymmetryInterfaceprivate boolean isNotCentroid(javajs.util.P3 center,
int n,
int[] minmax,
boolean centroidPacked)
public boolean checkUnitCell(SymmetryInterface uc, javajs.util.P3 cell, javajs.util.P3 ptTemp, boolean isAbsolute)
checkUnitCell in interface SymmetryInterfacepublic boolean unitCellEquals(SymmetryInterface uc2)
unitCellEquals in interface SymmetryInterfacepublic boolean addLatticeVectors(javajs.util.List<float[]> lattvecs)
addLatticeVectors in interface SymmetryInterfacepublic int getLatticeOp()
getLatticeOp in interface SymmetryInterfacepublic javajs.util.Matrix getOperationRsVs(int iop)
getOperationRsVs in interface SymmetryInterfacepublic int getSiteMultiplicity(javajs.util.P3 pt)
getSiteMultiplicity in interface SymmetryInterfacepublic boolean isBio()
isBio in interface SymmetryInterfacepublic java.lang.String addOp(java.lang.String code,
javajs.util.Matrix rs,
javajs.util.Matrix vs,
javajs.util.Matrix sigma)
addOp in interface SymmetryInterfacepublic java.lang.String getUnitCellState()
getUnitCellState in interface SymmetryInterfacepublic java.lang.String getSpaceGroupOperationCode(int iOp)
getSpaceGroupOperationCode in interface SymmetryInterface