public class Symmetry extends Object implements SymmetryInterface
| Modifier and Type | Field and Description |
|---|---|
private SymmetryDesc |
desc |
private boolean |
isBio |
private PointGroup |
pointGroup |
(package 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.Lst<float[]> lattvecs) |
String |
addOp(String code,
javajs.util.Matrix rs,
javajs.util.Matrix vs,
javajs.util.Matrix sigma) |
int |
addSpaceGroupOperation(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,
String name,
Object data) |
String |
fcoord(javajs.util.T3 p) |
javajs.util.Lst<javajs.util.P3> |
generateCrystalClass(javajs.util.P3 pt0) |
javajs.util.P3[] |
getCanonicalCopy(float scale,
boolean withOffset) |
javajs.util.P3 |
getCartesianOffset() |
int[] |
getCellRange() |
boolean |
getCoordinatesAreFractional() |
private SymmetryDesc |
getDesc(ModelSet modelSet) |
javajs.util.P3 |
getFractionalOffset() |
javajs.util.T3 |
getFractionalOrigin() |
String |
getIntTableNumber() |
AtomIndexIterator |
getIterator(Viewer vwr,
Atom atom,
Atom[] atoms,
BS bsAtoms,
float radius) |
Object |
getLatticeDesignation() |
int |
getLatticeOp() |
String |
getLatticeType() |
String |
getMatrixFromString(String xyz,
float[] rotTransMatrix,
boolean allowScaling,
int modDim) |
javajs.util.Lst<String> |
getMoreInfo() |
javajs.util.Matrix |
getOperationRsVs(int iop) |
Object |
getPointGroupInfo(int modelIndex,
String drawID,
boolean asInfo,
String type,
int index,
float scale) |
String |
getPointGroupName() |
javajs.util.Quat |
getQuaternionRotation(String abc) |
int |
getSiteMultiplicity(javajs.util.P3 pt) |
Object |
getSpaceGroup() |
Map<String,Object> |
getSpaceGroupInfo(ModelSet modelSet,
String sgName,
int modelIndex) |
String |
getSpaceGroupInfoStr(String name,
SymmetryInterface cellInfo) |
String |
getSpaceGroupName() |
javajs.util.M4 |
getSpaceGroupOperation(int i) |
String |
getSpaceGroupOperationCode(int iOp) |
int |
getSpaceGroupOperationCount() |
String |
getSpaceGroupXyz(int i,
boolean doNormalize) |
float |
getSpinOp(int op) |
boolean |
getState(javajs.util.SB commands) |
Object |
getSymmetryInfoAtom(ModelSet modelSet,
int iatom,
String xyz,
int op,
javajs.util.P3 pt,
javajs.util.P3 pt2,
String id,
int type,
float scaleFactor,
int nth) |
String |
getSymmetryInfoStr() |
javajs.util.M4[] |
getSymmetryOperations() |
Tensor |
getTensor(Viewer vwr,
float[] parBorU) |
SymmetryInterface |
getUnitCell(javajs.util.T3[] points,
boolean setRelative,
String name) |
float[] |
getUnitCellAsArray(boolean vectorsOnly) |
String |
getUnitCellInfo() |
float |
getUnitCellInfoType(int infoType) |
javajs.util.P3 |
getUnitCellMultiplier() |
float[] |
getUnitCellParams() |
String |
getUnitCellState() |
javajs.util.P3[] |
getUnitCellVectors() |
javajs.util.P3[] |
getUnitCellVerticesNoOffset() |
String |
getUnitsymmetryInfo() |
javajs.util.T3[] |
getV0abc(Object def) |
boolean |
haveUnitCell() |
void |
initializeOrientation(javajs.util.M3 mat) |
boolean |
isBio() |
private boolean |
isNotCentroid(javajs.util.P3 center,
int n,
int[] minmax,
boolean centroidPacked) |
boolean |
isPolymer() |
boolean |
isSimple() |
boolean |
isSlab() |
boolean |
isSupercell() |
void |
newSpaceGroupPoint(int i,
javajs.util.P3 atom1,
javajs.util.P3 atom2,
int transX,
int transY,
int transZ,
javajs.util.M4 o) |
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 |
setFinalOperations(String name,
javajs.util.P3[] atoms,
int iAtomFirst,
int noSymmetryCount,
boolean doNormalize,
String filterSymop) |
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.T3 pt) |
SymmetryInterface |
setPointGroup(SymmetryInterface siLast,
javajs.util.T3 center,
javajs.util.T3[] atomset,
BS bsAtoms,
boolean haveVibration,
float distanceTolerance,
float linearTolerance,
boolean localEnvOnly) |
void |
setSpaceGroup(boolean doNormalize) |
void |
setSpaceGroupFrom(SymmetryInterface symmetry) |
SymmetryInterface |
setSymmetryInfo(int modelIndex,
Map<String,Object> modelAuxiliaryInfo,
float[] unitCellParams)
Set space group and unit cell from the auxiliary info generated by the
model adapter.
|
void |
setTimeReversal(int op,
int val) |
void |
setUnitCell(float[] unitCellParams,
boolean setRelative) |
void |
toCartesian(javajs.util.T3 fpt,
boolean ignoreOffset) |
void |
toFractional(javajs.util.T3 pt,
boolean isAbsolute) |
void |
toFractionalM(javajs.util.M4 m) |
boolean |
toFromPrimitive(boolean toPrimitive,
char type,
javajs.util.T3[] oabc) |
javajs.util.P3 |
toSupercell(javajs.util.P3 fpt) |
void |
toUnitCell(javajs.util.T3 pt,
javajs.util.T3 offset) |
boolean |
unitCellEquals(SymmetryInterface uc2) |
void |
unitize(javajs.util.T3 ptFrac) |
private PointGroup pointGroup
SpaceGroup spaceGroup
private SymmetryInfo symmetryInfo
private UnitCell unitCell
private boolean isBio
private SymmetryDesc desc
public boolean isBio()
isBio in interface SymmetryInterfacepublic SymmetryInterface setPointGroup(SymmetryInterface siLast, javajs.util.T3 center, javajs.util.T3[] atomset, BS bsAtoms, boolean haveVibration, float distanceTolerance, float linearTolerance, boolean localEnvOnly)
setPointGroup in interface SymmetryInterfacepublic String getPointGroupName()
getPointGroupName in interface SymmetryInterfacepublic Object getPointGroupInfo(int modelIndex, String drawID, boolean asInfo, String type, int index, float scale)
getPointGroupInfo in interface SymmetryInterfacepublic void setSpaceGroup(boolean doNormalize)
setSpaceGroup in interface SymmetryInterfacepublic int addSpaceGroupOperation(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 Object getSpaceGroup()
getSpaceGroup in interface SymmetryInterfacepublic void setSpaceGroupFrom(SymmetryInterface symmetry)
setSpaceGroupFrom in interface SymmetryInterfacepublic boolean createSpaceGroup(int desiredSpaceGroupIndex,
String name,
Object data)
createSpaceGroup in interface SymmetryInterfacedesiredSpaceGroupIndex - name - data - a Lstpublic String getSpaceGroupInfoStr(String name, SymmetryInterface cellInfo)
getSpaceGroupInfoStr in interface SymmetryInterfacepublic Object getLatticeDesignation()
getLatticeDesignation in interface SymmetryInterfacepublic void setFinalOperations(String name, javajs.util.P3[] atoms, int iAtomFirst, int noSymmetryCount, boolean doNormalize, String filterSymop)
setFinalOperations in interface SymmetryInterfacepublic javajs.util.M4 getSpaceGroupOperation(int i)
getSpaceGroupOperation in interface SymmetryInterfacepublic 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,
javajs.util.M4 o)
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 String getSpaceGroupOperationCode(int iOp)
getSpaceGroupOperationCode in interface SymmetryInterfacepublic void setTimeReversal(int op,
int val)
setTimeReversal in interface SymmetryInterfacepublic float getSpinOp(int op)
getSpinOp in interface SymmetryInterfacepublic boolean addLatticeVectors(javajs.util.Lst<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 String addOp(String code, javajs.util.Matrix rs, javajs.util.Matrix vs, javajs.util.Matrix sigma)
addOp in interface SymmetryInterfacepublic String getMatrixFromString(String xyz, float[] rotTransMatrix, boolean allowScaling, int modDim)
getMatrixFromString in interface SymmetryInterfacepublic String getSpaceGroupName()
getSpaceGroupName in interface SymmetryInterfacepublic int getSpaceGroupOperationCount()
getSpaceGroupOperationCount in interface SymmetryInterfacepublic String getLatticeType()
getLatticeType in interface SymmetryInterfacepublic String getIntTableNumber()
getIntTableNumber in interface SymmetryInterfacepublic boolean getCoordinatesAreFractional()
getCoordinatesAreFractional in interface SymmetryInterfacepublic int[] getCellRange()
getCellRange in interface SymmetryInterfacepublic String getSymmetryInfoStr()
getSymmetryInfoStr in interface SymmetryInterfacepublic javajs.util.M4[] getSymmetryOperations()
getSymmetryOperations in interface SymmetryInterfacepublic boolean isSimple()
isSimple in interface SymmetryInterfacepublic SymmetryInterface setSymmetryInfo(int modelIndex, Map<String,Object> modelAuxiliaryInfo, float[] unitCellParams)
setSymmetryInfo in interface SymmetryInterfacepublic boolean haveUnitCell()
haveUnitCell in interface SymmetryInterfacepublic boolean checkUnitCell(SymmetryInterface uc, javajs.util.P3 cell, javajs.util.P3 ptTemp, boolean isAbsolute)
checkUnitCell in interface SymmetryInterfacepublic void setUnitCell(float[] unitCellParams,
boolean setRelative)
setUnitCell in interface SymmetryInterfacepublic boolean unitCellEquals(SymmetryInterface uc2)
unitCellEquals in interface SymmetryInterfacepublic String getUnitCellState()
getUnitCellState in interface SymmetryInterfacepublic javajs.util.Lst<String> getMoreInfo()
getMoreInfo in interface SymmetryInterfacepublic String getUnitsymmetryInfo()
public void initializeOrientation(javajs.util.M3 mat)
initializeOrientation in interface SymmetryInterfacepublic void unitize(javajs.util.T3 ptFrac)
unitize in interface SymmetryInterfacepublic void toUnitCell(javajs.util.T3 pt,
javajs.util.T3 offset)
toUnitCell 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 void toFractionalM(javajs.util.M4 m)
toFractionalM in interface SymmetryInterfacepublic void toCartesian(javajs.util.T3 fpt,
boolean ignoreOffset)
toCartesian in interface SymmetryInterfacepublic float[] getUnitCellParams()
getUnitCellParams in interface SymmetryInterfacepublic float[] getUnitCellAsArray(boolean vectorsOnly)
getUnitCellAsArray in interface SymmetryInterfacepublic Tensor getTensor(Viewer vwr, float[] parBorU)
getTensor in interface SymmetryInterfacepublic javajs.util.P3[] getUnitCellVerticesNoOffset()
getUnitCellVerticesNoOffset in interface SymmetryInterfacepublic javajs.util.P3 getCartesianOffset()
getCartesianOffset in interface SymmetryInterfacepublic javajs.util.P3 getFractionalOffset()
getFractionalOffset in interface SymmetryInterfacepublic void setOffsetPt(javajs.util.T3 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 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 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.P3[] getUnitCellVectors()
getUnitCellVectors in interface SymmetryInterfacepublic SymmetryInterface getUnitCell(javajs.util.T3[] points, boolean setRelative, String name)
getUnitCell in interface SymmetryInterfacepublic boolean isSupercell()
isSupercell 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)
private SymmetryDesc getDesc(ModelSet modelSet)
public Object getSymmetryInfoAtom(ModelSet modelSet, int iatom, String xyz, int op, javajs.util.P3 pt, javajs.util.P3 pt2, String id, int type, float scaleFactor, int nth)
getSymmetryInfoAtom in interface SymmetryInterfacetype - T.point, T.lattice, or T.draw, T.matrix4f, T.label, T.list, T.info, T.translation, T.axis, T.plane, T.angle, T.centernth - TODOpublic Map<String,Object> getSpaceGroupInfo(ModelSet modelSet, String sgName, int modelIndex)
getSpaceGroupInfo in interface SymmetryInterfacepublic String fcoord(javajs.util.T3 p)
fcoord in interface SymmetryInterfacepublic javajs.util.T3[] getV0abc(Object def)
getV0abc in interface SymmetryInterfacepublic javajs.util.Quat getQuaternionRotation(String abc)
getQuaternionRotation in interface SymmetryInterfacepublic javajs.util.T3 getFractionalOrigin()
getFractionalOrigin in interface SymmetryInterfacepublic boolean getState(javajs.util.SB commands)
getState in interface SymmetryInterfacepublic AtomIndexIterator getIterator(Viewer vwr, Atom atom, Atom[] atoms, BS bsAtoms, float radius)
getIterator in interface SymmetryInterfacepublic boolean toFromPrimitive(boolean toPrimitive,
char type,
javajs.util.T3[] oabc)
toFromPrimitive in interface SymmetryInterfacepublic javajs.util.Lst<javajs.util.P3> generateCrystalClass(javajs.util.P3 pt0)
generateCrystalClass in interface SymmetryInterface