| (function(Clazz
|
| ,Clazz_getClassName
|
| ,Clazz_newLongArray
|
| ,Clazz_doubleToByte
|
| ,Clazz_doubleToInt
|
| ,Clazz_doubleToLong
|
| ,Clazz_declarePackage
|
| ,Clazz_instanceOf
|
| ,Clazz_load
|
| ,Clazz_instantialize
|
| ,Clazz_decorateAsClass
|
| ,Clazz_floatToInt
|
| ,Clazz_floatToLong
|
| ,Clazz_makeConstructor
|
| ,Clazz_defineEnumConstant
|
| ,Clazz_exceptionOf
|
| ,Clazz_newIntArray
|
| ,Clazz_defineStatics
|
| ,Clazz_newFloatArray
|
| ,Clazz_declareType
|
| ,Clazz_prepareFields
|
| ,Clazz_superConstructor
|
| ,Clazz_newByteArray
|
| ,Clazz_declareInterface
|
| ,Clazz_p0p
|
| ,Clazz_pu$h
|
| ,Clazz_newShortArray
|
| ,Clazz_innerTypeInstance
|
| ,Clazz_isClassDefined
|
| ,Clazz_prepareCallback
|
| ,Clazz_newArray
|
| ,Clazz_castNullAs
|
| ,Clazz_floatToShort
|
| ,Clazz_superCall
|
| ,Clazz_decorateAsType
|
| ,Clazz_newBooleanArray
|
| ,Clazz_newCharArray
|
| ,Clazz_implementOf
|
| ,Clazz_newDoubleArray
|
| ,Clazz_overrideConstructor
|
| ,Clazz_clone
|
| ,Clazz_doubleToShort
|
| ,Clazz_getInheritedLevel
|
| ,Clazz_getParamsType
|
| ,Clazz_isAF
|
| ,Clazz_isAB
|
| ,Clazz_isAI
|
| ,Clazz_isAS
|
| ,Clazz_isASS
|
| ,Clazz_isAP
|
| ,Clazz_isAFloat
|
| ,Clazz_isAII
|
| ,Clazz_isAFF
|
| ,Clazz_isAFFF
|
| ,Clazz_tryToSearchAndExecute
|
| ,Clazz_getStackTrace
|
| ,Clazz_inheritArgs
|
| ,Clazz_alert
|
| ,Clazz_defineMethod
|
| ,Clazz_overrideMethod
|
| ,Clazz_declareAnonymous
|
|
|
| ,Clazz_cloneFinals
|
| ){
|
| var $t$;
|
|
|
| Clazz_declarePackage ("JS");
|
| Clazz_load (null, "JS.MathExt", ["java.lang.Float", "$.Number", "java.util.Date", "$.Hashtable", "$.Random", "JU.AU", "$.BS", "$.CU", "$.Lst", "$.M4", "$.Measure", "$.OC", "$.P3", "$.P4", "$.PT", "$.Quat", "$.Rdr", "$.SB", "$.V3", "J.api.Interface", "J.atomdata.RadiusData", "J.bspt.PointIterator", "J.c.VDW", "J.i18n.GT", "JM.BondSet", "JS.SV", "$.ScriptParam", "$.T", "JU.BSUtil", "$.Escape", "$.JmolMolecule", "$.Logger", "$.Parser", "$.Point3fi", "$.SimpleUnitCell", "JV.FileManager", "$.JC", "$.Viewer"], function () {
|
| c$ = Clazz_decorateAsClass (function () {
|
| this.vwr = null;
|
| this.e = null;
|
| this.rand = null;
|
| this.pm = null;
|
| Clazz_instantialize (this, arguments);
|
| }, JS, "MathExt");
|
| Clazz_makeConstructor (c$,
|
| function () {
|
| });
|
| Clazz_defineMethod (c$, "init",
|
| function (se) {
|
| this.e = se;
|
| this.vwr = this.e.vwr;
|
| return this;
|
| }, "~O");
|
| Clazz_defineMethod (c$, "evaluate",
|
| function (mp, op, args, tok) {
|
| switch (tok) {
|
| case 134218250:
|
| case 134218242:
|
| case 134218245:
|
| case 134217749:
|
| case 134218244:
|
| case 134218246:
|
| return this.evaluateMath (mp, args, tok);
|
| case 1275069441:
|
| case 1275068928:
|
| case 1275068929:
|
| case 1275068930:
|
| case 1275068931:
|
| case 1275335685:
|
| case 1275334681:
|
| return this.evaluateList (mp, op.intValue, args);
|
| case 268435520:
|
| if (args.length == 0) mp.wasX = false;
|
| case 1275068418:
|
| return this.evaluateArray (mp, args, tok == 1275068418 && op.tok == 268435665);
|
| case 134217731:
|
| case 134221850:
|
| return this.evaluateQuaternion (mp, args, tok);
|
| case 1275068420:
|
| return this.evaluateBin (mp, args);
|
| case 134221829:
|
| return this.evaluateCache (mp, args);
|
| case 1275068934:
|
| case 1275068935:
|
| return this.evaluateRowCol (mp, args, tok);
|
| case 1765808134:
|
| return this.evaluateColor (mp, args);
|
| case 134221831:
|
| return this.evaluateCompare (mp, args);
|
| case 1228931587:
|
| case 134217736:
|
| case 1275203608:
|
| return this.evaluateConnected (mp, args, tok, op.intValue);
|
| case 1814695966:
|
| return this.evaluateUnitCell (mp, args, op.tok == 268435665);
|
| case 134353926:
|
| return this.evaluateContact (mp, args);
|
| case 134221834:
|
| return this.evaluateData (mp, args);
|
| case 1275069444:
|
| case 1275069442:
|
| return this.evaluateDotDist (mp, args, tok, op.intValue);
|
| case 1275069443:
|
| if (op.tok == 268435665) return this.evaluateDotDist (mp, args, tok, op.intValue);
|
| case 134217729:
|
| case 1745489939:
|
| return this.evaluateMeasure (mp, args, op.tok);
|
| case 1228935687:
|
| case 134222849:
|
| return this.evaluateLoad (mp, args, tok == 1228935687);
|
| case 1275068427:
|
| return this.evaluateFind (mp, args);
|
| case 1287653388:
|
| case 1825200146:
|
| return this.evaluateFormat (mp, op.intValue, args, tok == 1825200146);
|
| case 134320141:
|
| return this.evaluateUserFunction (mp, op.value, args, op.intValue, op.tok == 268435665);
|
| case 1275068449:
|
| case 1275082245:
|
| case 1275072526:
|
| return this.evaluateGetProperty (mp, args, tok, op.tok == 268435665);
|
| case 136314895:
|
| return this.evaluateHelix (mp, args);
|
| case 134219265:
|
| case 134217750:
|
| case 134217763:
|
| return this.evaluatePlane (mp, args, tok);
|
| case 134218759:
|
| case 134238732:
|
| case 134222850:
|
| case 134222350:
|
| return this.evaluateScript (mp, args, tok);
|
| case 1275069446:
|
| case 1275069447:
|
| case 1275068932:
|
| return this.evaluateString (mp, op.intValue, args);
|
| case 134217751:
|
| return this.evaluatePoint (mp, args);
|
| case 134217762:
|
| return this.evaluatePointGroup (mp, args);
|
| case 134256131:
|
| return this.evaluatePrompt (mp, args);
|
| case 134219268:
|
| return this.evaluateRandom (mp, args);
|
| case 1275068432:
|
| return this.evaluateIn (mp, args);
|
| case 1275072532:
|
| return this.evaluateModulation (mp, args);
|
| case 1275068443:
|
| return this.evaluateReplace (mp, args);
|
| case 134218756:
|
| case 134218757:
|
| case 1237320707:
|
| return this.evaluateSubstructure (mp, args, tok, op.tok == 268435665);
|
| case 1275068444:
|
| case 1275068425:
|
| return this.evaluateSort (mp, args, tok);
|
| case 1296041986:
|
| return this.evaluateSymop (mp, args, op.tok == 268435665);
|
| case 1275068445:
|
| return this.evaluateTensor (mp, args);
|
| case 134217759:
|
| return this.evaluateWithin (mp, args);
|
| case 134221856:
|
| return this.evaluateWrite (mp, args);
|
| }
|
| return false;
|
| }, "JS.ScriptMathProcessor,JS.T,~A,~N");
|
| Clazz_defineMethod (c$, "evaluatePointGroup",
|
| function (mp, args) {
|
| var pts = null;
|
| var center = null;
|
| var distanceTolerance = NaN;
|
| var linearTolerance = NaN;
|
| var bsAtoms;
|
| switch (args.length) {
|
| case 4:
|
| linearTolerance = args[3].asFloat ();
|
| case 3:
|
| distanceTolerance = args[2].asFloat ();
|
| case 2:
|
| switch (args[1].tok) {
|
| case 8:
|
| center = JS.SV.ptValue (args[1]);
|
| break;
|
| case 10:
|
| bsAtoms = JS.SV.getBitSet (args[1], false);
|
| var iatom = bsAtoms.nextSetBit (0);
|
| if (iatom < 0 || iatom >= this.vwr.ms.ac || bsAtoms.cardinality () != 1) return false;
|
| if (JS.SV.sValue (args[0]).equalsIgnoreCase ("spaceGroup")) {
|
| var lst = this.vwr.ms.generateCrystalClass (iatom, JU.P3.new3 (NaN, NaN, NaN));
|
| pts = new Array (lst.size ());
|
| for (var i = pts.length; --i >= 0; ) pts[i] = lst.get (i);
|
|
|
| center = new JU.P3 ();
|
| if (args.length == 2) distanceTolerance = 0;
|
| } else {
|
| center = this.vwr.ms.at[iatom];
|
| }}
|
| if (pts != null) break;
|
| case 1:
|
| switch (args[0].tok) {
|
| case 7:
|
| var points = args[0].getList ();
|
| pts = new Array (points.size ());
|
| for (var i = pts.length; --i >= 0; ) pts[i] = JS.SV.ptValue (points.get (i));
|
|
|
| break;
|
| case 10:
|
| bsAtoms = JS.SV.getBitSet (args[0], false);
|
| var atoms = this.vwr.ms.getAtomPointVector (bsAtoms);
|
| pts = new Array (atoms.size ());
|
| for (var i = pts.length; --i >= 0; ) pts[i] = atoms.get (i);
|
|
|
| break;
|
| default:
|
| return false;
|
| }
|
| break;
|
| default:
|
| return false;
|
| }
|
| var pointGroup = this.vwr.getSymTemp ().setPointGroup (null, center, pts, null, false, Float.isNaN (distanceTolerance) ? this.vwr.getFloat (570425382) : distanceTolerance, Float.isNaN (linearTolerance) ? this.vwr.getFloat (570425384) : linearTolerance, true);
|
| return mp.addXMap (pointGroup.getPointGroupInfo (-1, null, true, null, 0, 1));
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateUnitCell",
|
| function (mp, args, isSelector) {
|
| var x1 = (isSelector ? JS.SV.getBitSet (mp.getX (), true) : null);
|
| var iatom = ((x1 == null ? this.vwr.getAllAtoms () : x1).nextSetBit (0));
|
| var lastParam = args.length - 1;
|
| var scale = 1;
|
| switch (lastParam < 0 ? 0 : args[lastParam].tok) {
|
| case 2:
|
| case 3:
|
| scale = args[lastParam].asFloat ();
|
| lastParam--;
|
| break;
|
| }
|
| var tok0 = (lastParam < 0 ? 0 : args[0].tok);
|
| var ucnew = null;
|
| var uc = null;
|
| switch (tok0) {
|
| case 7:
|
| uc = args[0].getList ();
|
| break;
|
| case 4:
|
| var s = args[0].asString ();
|
| if (s.indexOf ("a=") == 0) {
|
| ucnew = new Array (4);
|
| for (var i = 0; i < 4; i++) ucnew[i] = new JU.P3 ();
|
|
|
| JU.SimpleUnitCell.setOabc (s, null, ucnew);
|
| } else if (s.indexOf (",") >= 0) {
|
| return mp.addXObj (this.vwr.getV0abc (s));
|
| }break;
|
| }
|
| var u = null;
|
| var haveUC = (uc != null);
|
| if (ucnew == null && haveUC && uc.size () < 4) return false;
|
| var ptParam = (haveUC ? 1 : 0);
|
| if (ucnew == null && !haveUC && tok0 != 8) {
|
| u = (iatom < 0 ? null : this.vwr.ms.getUnitCell (this.vwr.ms.at[iatom].mi));
|
| ucnew = (u == null ? Clazz_newArray (-1, [JU.P3.new3 (0, 0, 0), JU.P3.new3 (1, 0, 0), JU.P3.new3 (0, 1, 0), JU.P3.new3 (0, 0, 1)]) : u.getUnitCellVectors ());
|
| }if (ucnew == null) {
|
| ucnew = new Array (4);
|
| if (haveUC) {
|
| switch (uc.size ()) {
|
| case 3:
|
| ucnew[0] = new JU.P3 ();
|
| for (var i = 0; i < 3; i++) ucnew[i + 1] = JU.P3.newP (JS.SV.ptValue (uc.get (i)));
|
|
|
| break;
|
| case 4:
|
| for (var i = 0; i < 4; i++) ucnew[i] = JU.P3.newP (JS.SV.ptValue (uc.get (i)));
|
|
|
| break;
|
| case 6:
|
| var params = Clazz_newFloatArray (6, 0);
|
| for (var i = 0; i < 6; i++) params[i] = uc.get (i).asFloat ();
|
|
|
| JU.SimpleUnitCell.setOabc (null, params, ucnew);
|
| break;
|
| default:
|
| return false;
|
| }
|
| } else {
|
| ucnew[0] = JS.SV.ptValue (args[0]);
|
| switch (lastParam) {
|
| case 3:
|
| for (var i = 1; i < 4; i++) (ucnew[i] = JU.P3.newP (JS.SV.ptValue (args[i]))).sub (ucnew[0]);
|
|
|
| break;
|
| case 1:
|
| var l = args[1].getList ();
|
| if (l != null && l.size () == 3) {
|
| for (var i = 0; i < 3; i++) ucnew[i + 1] = JS.SV.ptValue (l.get (i));
|
|
|
| break;
|
| }default:
|
| return false;
|
| }
|
| }}var op = (ptParam <= lastParam ? args[ptParam].asString () : null);
|
| var toPrimitive = "primitive".equalsIgnoreCase (op);
|
| if (toPrimitive || "conventional".equalsIgnoreCase (op)) {
|
| var stype = (++ptParam > lastParam ? "" : args[ptParam].asString ().toUpperCase ());
|
| if (stype.equals ("BCC")) stype = "I";
|
| else if (stype.length == 0) stype = this.vwr.getSymTemp ().getSymmetryInfoAtom (this.vwr.ms, iatom, null, 0, null, null, null, 1073741994, 0, -1);
|
| if (stype == null || stype.length == 0) return false;
|
| if (u == null) u = this.vwr.getSymTemp ();
|
| var m3 = this.vwr.getModelForAtomIndex (iatom).auxiliaryInfo.get ("primitiveToCrystal");
|
| if (!u.toFromPrimitive (toPrimitive, stype.charAt (0), ucnew, m3)) return false;
|
| } else if ("reciprocal".equalsIgnoreCase (op)) {
|
| ucnew = JU.SimpleUnitCell.getReciprocal (ucnew, null, scale);
|
| scale = 1;
|
| }if (scale != 1) for (var i = 1; i < 4; i++) ucnew[i].scale (scale);
|
|
|
| return mp.addXObj (ucnew);
|
| }, "JS.ScriptMathProcessor,~A,~B");
|
| Clazz_defineMethod (c$, "evaluateArray",
|
| function (mp, args, isSelector) {
|
| if (isSelector) {
|
| var x1 = mp.getX ();
|
| switch (args.length == 1 ? x1.tok : 0) {
|
| case 6:
|
| var lst = new JU.Lst ();
|
| var id = args[0].asString ();
|
| var map = x1.getMap ();
|
| var keys = x1.getKeys (false);
|
| for (var i = 0, n = keys.length; i < n; i++) if (map.get (keys[i]).getMap () == null) return false;
|
|
|
| for (var i = 0, n = keys.length; i < n; i++) {
|
| var m = map.get (keys[i]);
|
| var m1 = m.getMap ();
|
| var m2 = JS.SV.deepCopy (m1, true, false);
|
| m2.put (id, JS.SV.newS (keys[i]));
|
| lst.addLast (JS.SV.newV (6, m2));
|
| }
|
| return mp.addXList (lst);
|
| case 7:
|
| var map1 = new java.util.Hashtable ();
|
| var lst1 = x1.getList ();
|
| var id1 = args[0].asString ();
|
| for (var i = 0, n = lst1.size (); i < n; i++) {
|
| var m0 = lst1.get (i).getMap ();
|
| if (m0 == null || m0.get (id1) == null) return false;
|
| }
|
| for (var i = 0, n = lst1.size (); i < n; i++) {
|
| var m = lst1.get (i);
|
| var m1 = JS.SV.deepCopy (m.getMap (), true, false);
|
| var mid = m1.remove (id1);
|
| map1.put (mid.asString (), JS.SV.newV (6, m1));
|
| }
|
| return mp.addXObj (map1);
|
| }
|
| return false;
|
| }var a = new Array (args.length);
|
| for (var i = a.length; --i >= 0; ) a[i] = JS.SV.newT (args[i]);
|
|
|
| return mp.addXAV (a);
|
| }, "JS.ScriptMathProcessor,~A,~B");
|
| Clazz_defineMethod (c$, "evaluateBin",
|
| function (mp, args) {
|
| var n = args.length;
|
| if (n < 3 || n > 5) return false;
|
| var x1 = mp.getX ();
|
| var isListf = (x1.tok == 13);
|
| if (!isListf && x1.tok != 7) return mp.addX (x1);
|
| var f0 = JS.SV.fValue (args[0]);
|
| var f1 = JS.SV.fValue (args[1]);
|
| var df = JS.SV.fValue (args[2]);
|
| var addBins = (n >= 4 && args[n - 1].tok == 1073742335);
|
| var key = ((n == 5 || n == 4 && !addBins) && args[3].tok != 1073742334 ? JS.SV.sValue (args[3]) : null);
|
| var data;
|
| var maps = null;
|
| if (isListf) {
|
| data = x1.value;
|
| } else {
|
| var list = x1.getList ();
|
| data = Clazz_newFloatArray (list.size (), 0);
|
| if (key != null) maps = JU.AU.createArrayOfHashtable (list.size ());
|
| try {
|
| for (var i = list.size (); --i >= 0; ) data[i] = JS.SV.fValue (key == null ? list.get (i) : (maps[i] = list.get (i).getMap ()).get (key));
|
|
|
| } catch (e) {
|
| if (Clazz_exceptionOf (e, Exception)) {
|
| return false;
|
| } else {
|
| throw e;
|
| }
|
| }
|
| }var nbins = Math.max (Clazz_doubleToInt (Math.floor ((f1 - f0) / df + 0.01)), 1);
|
| var array = Clazz_newIntArray (nbins, 0);
|
| var nPoints = data.length;
|
| for (var i = 0; i < nPoints; i++) {
|
| var v = data[i];
|
| var bin = Clazz_doubleToInt (Math.floor ((v - f0) / df));
|
| if (bin < 0 || bin >= nbins) continue;
|
| array[bin]++;
|
| if (key != null) {
|
| var map = maps[i];
|
| if (map == null) continue;
|
| map.put ("_bin", JS.SV.newI (bin));
|
| var v1 = f0 + df * bin;
|
| var v2 = v1 + df;
|
| map.put ("_binMin", JS.SV.newF (bin == 0 ? -3.4028235E38 : v1));
|
| map.put ("_binMax", JS.SV.newF (bin == nbins - 1 ? 3.4028235E38 : v2));
|
| }}
|
| if (addBins) {
|
| var lst = new JU.Lst ();
|
| for (var i = 0; i < nbins; i++) lst.addLast ( Clazz_newFloatArray (-1, [f0 + df * i, array[i]]));
|
|
|
| return mp.addXList (lst);
|
| }return mp.addXAI (array);
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateCache",
|
| function (mp, args) {
|
| if (args.length > 0) return false;
|
| return mp.addXMap (this.vwr.fm.cacheList ());
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateColor",
|
| function (mp, args) {
|
| var colorScheme = (args.length > 0 ? JS.SV.sValue (args[0]) : "");
|
| var isIsosurface = colorScheme.startsWith ("$");
|
| if (args.length == 2 && colorScheme.equalsIgnoreCase ("TOHSL")) return mp.addXPt (JU.CU.rgbToHSL (JU.P3.newP (args[1].tok == 8 ? JS.SV.ptValue (args[1]) : JU.CU.colorPtFromString (args[1].asString ())), true));
|
| if (args.length == 2 && colorScheme.equalsIgnoreCase ("TORGB")) {
|
| var pt = JU.P3.newP (args[1].tok == 8 ? JS.SV.ptValue (args[1]) : JU.CU.colorPtFromString (args[1].asString ()));
|
| return mp.addXPt (args[1].tok == 8 ? JU.CU.hslToRGB (pt) : pt);
|
| }if (args.length == 4 && (args[3].tok == 1073742335 || args[3].tok == 1073742334)) {
|
| var pt1 = JU.P3.newP (args[0].tok == 8 ? JS.SV.ptValue (args[0]) : JU.CU.colorPtFromString (args[0].asString ()));
|
| var pt2 = JU.P3.newP (args[1].tok == 8 ? JS.SV.ptValue (args[1]) : JU.CU.colorPtFromString (args[1].asString ()));
|
| var usingHSL = (args[3].tok == 1073742335);
|
| if (usingHSL) {
|
| pt1 = JU.CU.rgbToHSL (pt1, false);
|
| pt2 = JU.CU.rgbToHSL (pt2, false);
|
| }var sb = new JU.SB ();
|
| var vd = JU.V3.newVsub (pt2, pt1);
|
| var n = args[2].asInt ();
|
| if (n < 2) n = 20;
|
| vd.scale (1 / (n - 1));
|
| for (var i = 0; i < n; i++) {
|
| sb.append (JU.Escape.escapeColor (JU.CU.colorPtToFFRGB (usingHSL ? JU.CU.hslToRGB (pt1) : pt1)));
|
| pt1.add (vd);
|
| }
|
| return mp.addXStr (sb.toString ());
|
| }var ce = (isIsosurface ? null : this.vwr.cm.getColorEncoder (colorScheme));
|
| if (!isIsosurface && ce == null) return mp.addXStr ("");
|
| var lo = (args.length > 1 ? JS.SV.fValue (args[1]) : 3.4028235E38);
|
| var hi = (args.length > 2 ? JS.SV.fValue (args[2]) : 3.4028235E38);
|
| var value = (args.length > 3 ? JS.SV.fValue (args[3]) : 3.4028235E38);
|
| var getValue = (value != 3.4028235E38 || lo != 3.4028235E38 && hi == 3.4028235E38);
|
| var haveRange = (hi != 3.4028235E38);
|
| if (!haveRange && colorScheme.length == 0) {
|
| value = lo;
|
| var range = this.vwr.getCurrentColorRange ();
|
| lo = range[0];
|
| hi = range[1];
|
| }if (isIsosurface) {
|
| var id = colorScheme.substring (1);
|
| var data = Clazz_newArray (-1, [id, null]);
|
| if (!this.vwr.shm.getShapePropertyData (24, "colorEncoder", data)) return mp.addXStr ("");
|
| ce = data[1];
|
| } else {
|
| ce.setRange (lo, hi, lo > hi);
|
| }var key = ce.getColorKey ();
|
| if (getValue) return mp.addXPt (JU.CU.colorPtFromInt (ce.getArgb (hi == 3.4028235E38 ? lo : value), null));
|
| return mp.addX (JS.SV.getVariableMap (key));
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateCompare",
|
| function (mp, args) {
|
| if (args.length < 2 || args.length > 5) return false;
|
| var stddev;
|
| var sOpt = JS.SV.sValue (args[args.length - 1]);
|
| var isStdDev = sOpt.equalsIgnoreCase ("stddev");
|
| var isIsomer = sOpt.equalsIgnoreCase ("ISOMER");
|
| var isBonds = sOpt.equalsIgnoreCase ("BONDS");
|
| var isSmiles = (!isIsomer && args.length > (isStdDev ? 3 : 2));
|
| var bs1 = (args[0].tok == 10 ? args[0].value : null);
|
| var bs2 = (args[1].tok == 10 ? args[1].value : null);
|
| var smiles1 = (bs1 == null ? JS.SV.sValue (args[0]) : "");
|
| var smiles2 = (bs2 == null ? JS.SV.sValue (args[1]) : "");
|
| var m = new JU.M4 ();
|
| stddev = NaN;
|
| var ptsA;
|
| var ptsB;
|
| try {
|
| if (isSmiles) {
|
| if (bs1 == null || bs2 == null) return false;
|
| }if (isBonds) {
|
| if (args.length != 4) return false;
|
| smiles1 = JS.SV.sValue (args[2]);
|
| isSmiles = smiles1.equalsIgnoreCase ("SMILES");
|
| try {
|
| if (isSmiles) smiles1 = this.vwr.getSmiles (bs1);
|
| } catch (ex) {
|
| if (Clazz_exceptionOf (ex, Exception)) {
|
| this.e.evalError (ex.getMessage (), null);
|
| } else {
|
| throw ex;
|
| }
|
| }
|
| var data = this.e.getSmilesExt ().getFlexFitList (bs1, bs2, smiles1, !isSmiles);
|
| return (data == null ? mp.addXStr ("") : mp.addXAF (data));
|
| }if (isIsomer) {
|
| if (args.length != 3) return false;
|
| if (bs1 == null && bs2 == null) return mp.addXStr (this.vwr.getSmilesMatcher ().getRelationship (smiles1, smiles2).toUpperCase ());
|
| var mf1 = (bs1 == null ? this.vwr.getSmilesMatcher ().getMolecularFormula (smiles1, false) : JU.JmolMolecule.getMolecularFormulaAtoms (this.vwr.ms.at, bs1, null, false));
|
| var mf2 = (bs2 == null ? this.vwr.getSmilesMatcher ().getMolecularFormula (smiles2, false) : JU.JmolMolecule.getMolecularFormulaAtoms (this.vwr.ms.at, bs2, null, false));
|
| if (!mf1.equals (mf2)) return mp.addXStr ("NONE");
|
| if (bs1 != null) smiles1 = this.e.getSmilesExt ().getSmilesMatches ("/strict///", null, bs1, null, 1, true, false);
|
| var check;
|
| if (bs2 == null) {
|
| check = (this.vwr.getSmilesMatcher ().areEqual (smiles2, smiles1) > 0);
|
| } else {
|
| smiles2 = this.e.getSmilesExt ().getSmilesMatches ("/strict///", null, bs2, null, 1, true, false);
|
| check = ((this.e.getSmilesExt ().getSmilesMatches ("/strict///" + smiles1, null, bs2, null, 1, true, false)).nextSetBit (0) >= 0);
|
| }if (!check) {
|
| var s = smiles1 + smiles2;
|
| if (s.indexOf ("/") >= 0 || s.indexOf ("\\") >= 0 || s.indexOf ("@") >= 0) {
|
| if (smiles1.indexOf ("@") >= 0 && (bs2 != null || smiles2.indexOf ("@") >= 0) && smiles1.indexOf ("@SP") < 0) {
|
| var pt = smiles1.toLowerCase ().indexOf ("invertstereo");
|
| smiles1 = (pt >= 0 ? "/strict/" + smiles1.substring (0, pt) + smiles1.substring (pt + 12) : "/invertstereo strict/" + smiles1);
|
| if (bs2 == null) {
|
| check = (this.vwr.getSmilesMatcher ().areEqual (smiles1, smiles2) > 0);
|
| } else {
|
| check = ((this.e.getSmilesExt ().getSmilesMatches (smiles1, null, bs2, null, 1, true, false)).nextSetBit (0) >= 0);
|
| }if (check) return mp.addXStr ("ENANTIOMERS");
|
| }if (bs2 == null) {
|
| check = (this.vwr.getSmilesMatcher ().areEqual ("/nostereo/" + smiles2, smiles1) > 0);
|
| } else {
|
| var ret = this.e.getSmilesExt ().getSmilesMatches ("/nostereo/" + smiles1, null, bs2, null, 1, true, false);
|
| check = ((ret).nextSetBit (0) >= 0);
|
| }if (check) return mp.addXStr ("DIASTEREOMERS");
|
| }return mp.addXStr ("CONSTITUTIONAL ISOMERS");
|
| }if (bs1 == null || bs2 == null) return mp.addXStr ("IDENTICAL");
|
| stddev = this.e.getSmilesExt ().getSmilesCorrelation (bs1, bs2, smiles1, null, null, null, null, false, null, null, false, 1);
|
| return mp.addXStr (stddev < 0.2 ? "IDENTICAL" : "IDENTICAL or CONFORMATIONAL ISOMERS (RMSD=" + stddev + ")");
|
| }if (isSmiles) {
|
| ptsA = new JU.Lst ();
|
| ptsB = new JU.Lst ();
|
| sOpt = JS.SV.sValue (args[2]);
|
| var isMap = sOpt.equalsIgnoreCase ("MAP");
|
| isSmiles = sOpt.equalsIgnoreCase ("SMILES");
|
| var isSearch = (isMap || sOpt.equalsIgnoreCase ("SMARTS"));
|
| if (isSmiles || isSearch) sOpt = (args.length > (isStdDev ? 4 : 3) ? JS.SV.sValue (args[3]) : null);
|
| var hMaps = (("H".equalsIgnoreCase (sOpt) || "allH".equalsIgnoreCase (sOpt) || "bestH".equalsIgnoreCase (sOpt)));
|
| var isPolyhedron = ("polyhedra".equalsIgnoreCase (sOpt));
|
| if (isPolyhedron) sOpt = (args.length > (isStdDev ? 5 : 4) ? JS.SV.sValue (args[4]) : null);
|
| var allMaps = (("all".equalsIgnoreCase (sOpt) || "allH".equalsIgnoreCase (sOpt)));
|
| var bestMap = (("best".equalsIgnoreCase (sOpt) || "bestH".equalsIgnoreCase (sOpt)));
|
| if ("stddev".equals (sOpt)) sOpt = null;
|
| var pattern = sOpt;
|
| if (sOpt == null || hMaps || allMaps || bestMap) {
|
| if (!isMap && !isSmiles || hMaps && isPolyhedron) return false;
|
| pattern = "/noaromatic" + (allMaps || bestMap ? "/" : " nostereo/") + this.e.getSmilesExt ().getSmilesMatches ((hMaps ? "H" : ""), null, bs1, null, 1, true, false);
|
| } else {
|
| allMaps = true;
|
| }stddev = this.e.getSmilesExt ().getSmilesCorrelation (bs1, bs2, pattern, ptsA, ptsB, m, null, isMap, null, null, bestMap, (isSmiles ? 1 : 2) | (!allMaps && !bestMap ? 8 : 0));
|
| if (isMap) {
|
| var nAtoms = ptsA.size ();
|
| if (nAtoms == 0) return mp.addXStr ("");
|
| var nMatch = Clazz_doubleToInt (ptsB.size () / nAtoms);
|
| var ret = new JU.Lst ();
|
| for (var i = 0, pt = 0; i < nMatch; i++) {
|
| var a = JU.AU.newInt2 (nAtoms);
|
| ret.addLast (a);
|
| for (var j = 0; j < nAtoms; j++, pt++) a[j] = Clazz_newIntArray (-1, [(ptsA.get (j)).i, (ptsB.get (pt)).i]);
|
|
|
| }
|
| return (allMaps ? mp.addXList (ret) : ret.size () > 0 ? mp.addXAII (ret.get (0)) : mp.addXStr (""));
|
| }} else {
|
| switch (args.length) {
|
| case 2:
|
| break;
|
| case 3:
|
| if (isStdDev) break;
|
| default:
|
| return false;
|
| }
|
| ptsA = this.e.getPointVector (args[0], 0);
|
| ptsB = this.e.getPointVector (args[1], 0);
|
| if (ptsA != null && ptsB != null) {
|
| J.api.Interface.getInterface ("JU.Eigen", this.vwr, "script");
|
| stddev = JU.Measure.getTransformMatrix4 (ptsA, ptsB, m, null);
|
| }}return (isStdDev || Float.isNaN (stddev) ? mp.addXFloat (stddev) : mp.addXM4 (m.round (1e-7)));
|
| } catch (ex) {
|
| if (Clazz_exceptionOf (ex, Exception)) {
|
| this.e.evalError (ex.getMessage () == null ? ex.toString () : ex.getMessage (), null);
|
| return false;
|
| } else {
|
| throw ex;
|
| }
|
| }
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateConnected",
|
| function (mp, args, tok, intValue) {
|
| if (args.length > 5) return false;
|
| var min = -2147483648;
|
| var max = 2147483647;
|
| var fmin = 0;
|
| var fmax = 3.4028235E38;
|
| var order = 65535;
|
| var atoms1 = null;
|
| var atoms2 = null;
|
| var haveDecimal = false;
|
| var isBonds = false;
|
| switch (tok) {
|
| case 1275203608:
|
| var nv = -2147483648;
|
| var smiles = null;
|
| if (args.length > 0) {
|
| switch (args[0].tok) {
|
| case 2:
|
| nv = args[0].intValue;
|
| break;
|
| case 4:
|
| smiles = JS.SV.sValue (args[0]);
|
| break;
|
| }
|
| }if (intValue == 1275203608) atoms1 = JS.SV.getBitSet (mp.getX (), true);
|
| var data = Clazz_newArray (-1, [Integer.$valueOf (nv), smiles, atoms1]);
|
| if (!this.vwr.shm.getShapePropertyData (21, "getCenters", data)) data[1] = null;
|
| return mp.addXBs (data[1] == null ? new JU.BS () : data[1]);
|
| case 1228931587:
|
| var x1 = mp.getX ();
|
| if (x1.tok != 10 || args.length != 1 || args[0].tok != 10) return false;
|
| atoms1 = x1.value;
|
| atoms2 = args[0].value;
|
| var list = new JU.Lst ();
|
| var atoms = this.vwr.ms.at;
|
| for (var i = atoms1.nextSetBit (0); i >= 0; i = atoms1.nextSetBit (i + 1)) {
|
| var n = 0;
|
| var b = atoms[i].bonds;
|
| for (var j = b.length; --j >= 0; ) if (atoms2.get (b[j].getOtherAtom (atoms[i]).i)) n++;
|
|
|
| list.addLast (Integer.$valueOf (n));
|
| }
|
| return mp.addXList (list);
|
| }
|
| for (var i = 0; i < args.length; i++) {
|
| var $var = args[i];
|
| switch ($var.tok) {
|
| case 10:
|
| isBonds = (Clazz_instanceOf ($var.value, JM.BondSet));
|
| if (isBonds && atoms1 != null) return false;
|
| if (atoms1 == null) atoms1 = $var.value;
|
| else if (atoms2 == null) atoms2 = $var.value;
|
| else return false;
|
| break;
|
| case 4:
|
| var type = JS.SV.sValue ($var);
|
| if (type.equalsIgnoreCase ("hbond")) order = 30720;
|
| else order = JS.ScriptParam.getBondOrderFromString (type);
|
| if (order == 131071) return false;
|
| break;
|
| case 3:
|
| haveDecimal = true;
|
| default:
|
| var n = $var.asInt ();
|
| var f = $var.asFloat ();
|
| if (max != 2147483647) return false;
|
| if (min == -2147483648) {
|
| min = Math.max (n, 0);
|
| fmin = f;
|
| } else {
|
| max = n;
|
| fmax = f;
|
| }}
|
| }
|
| if (min == -2147483648) {
|
| min = 1;
|
| max = 100;
|
| fmin = 0.1;
|
| fmax = 1.0E8;
|
| } else if (max == 2147483647) {
|
| max = min;
|
| fmax = fmin;
|
| fmin = 0.1;
|
| }if (atoms1 == null) atoms1 = this.vwr.getAllAtoms ();
|
| if (haveDecimal && atoms2 == null) atoms2 = atoms1;
|
| if (atoms2 != null) {
|
| var bsBonds = new JU.BS ();
|
| this.vwr.makeConnections (fmin, fmax, order, 1086324745, atoms1, atoms2, bsBonds, isBonds, false, 0);
|
| return mp.addX (JS.SV.newV (10, JM.BondSet.newBS (bsBonds, this.vwr.ms.getAtomIndices (this.vwr.ms.getAtoms (1677721602, bsBonds)))));
|
| }return mp.addXBs (this.vwr.ms.getAtomsConnected (min, max, order, atoms1));
|
| }, "JS.ScriptMathProcessor,~A,~N,~N");
|
| Clazz_defineMethod (c$, "evaluateContact",
|
| function (mp, args) {
|
| if (args.length < 1 || args.length > 3) return false;
|
| var i = 0;
|
| var distance = 100;
|
| var tok = args[0].tok;
|
| switch (tok) {
|
| case 3:
|
| case 2:
|
| distance = JS.SV.fValue (args[i++]);
|
| break;
|
| case 10:
|
| break;
|
| default:
|
| return false;
|
| }
|
| if (i == args.length || !(Clazz_instanceOf (args[i].value, JU.BS))) return false;
|
| var bsA = JU.BSUtil.copy (args[i++].value);
|
| var bsB = (i < args.length ? JU.BSUtil.copy (args[i].value) : null);
|
| var rd = new J.atomdata.RadiusData (null, (distance > 10 ? distance / 100 : distance), (distance > 10 ? J.atomdata.RadiusData.EnumType.FACTOR : J.atomdata.RadiusData.EnumType.OFFSET), J.c.VDW.AUTO);
|
| bsB = this.setContactBitSets (bsA, bsB, true, NaN, rd, false);
|
| bsB.or (bsA);
|
| return mp.addXBs (bsB);
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateData",
|
| function (mp, args) {
|
| var selected = (args.length == 0 ? "" : JS.SV.sValue (args[0]));
|
| var type = "";
|
| switch (args.length) {
|
| case 0:
|
| case 1:
|
| break;
|
| case 2:
|
| case 3:
|
| if (args[0].tok == 10) return mp.addXStr (this.vwr.getModelFileData (selected, JS.SV.sValue (args[1]), args.length == 3 && JS.SV.bValue (args[2])));
|
| break;
|
| case 4:
|
| var iField = args[1].asInt ();
|
| var nBytes = args[2].asInt ();
|
| var firstLine = args[3].asInt ();
|
| var f = JU.Parser.parseFloatArrayFromMatchAndField (JS.SV.sValue (args[0]), null, 0, 0, null, iField, nBytes, null, firstLine);
|
| return mp.addXStr (JU.Escape.escapeFloatA (f, false));
|
| default:
|
| return false;
|
| }
|
| if (selected.indexOf ("data2d_") == 0) {
|
| var f1 = this.vwr.getDataObj (selected, null, 2);
|
| if (f1 == null) return mp.addXStr ("");
|
| if (args.length == 2 && args[1].tok == 2) {
|
| var pt = args[1].intValue;
|
| if (pt < 0) pt += f1.length;
|
| if (pt >= 0 && pt < f1.length) return mp.addXStr (JU.Escape.escapeFloatA (f1[pt], false));
|
| return mp.addXStr ("");
|
| }return mp.addXStr (JU.Escape.escapeFloatAA (f1, false));
|
| }if (selected.indexOf ("property_") == 0) {
|
| var f1 = this.vwr.getDataObj (selected, null, 1);
|
| if (f1 == null) return mp.addXStr ("");
|
| var f2 = (type.indexOf ("property_") == 0 ? this.vwr.getDataObj (selected, null, 1) : null);
|
| if (f2 != null) {
|
| f1 = JU.AU.arrayCopyF (f1, -1);
|
| for (var i = Math.min (f1.length, f2.length); --i >= 0; ) f1[i] += f2[i];
|
|
|
| }return mp.addXStr (JU.Escape.escapeFloatA (f1, false));
|
| }var data = this.vwr.getDataObj (selected, null, -1);
|
| return mp.addXStr (data == null ? "" : "" + data[1]);
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateDotDist",
|
| function (mp, args, tok, op) {
|
| var isDist = (tok == 1275069443);
|
| var x1;
|
| var x2;
|
| var x3 = null;
|
| switch (args.length) {
|
| case 2:
|
| if (op == 2147483647) {
|
| x1 = args[0];
|
| x2 = args[1];
|
| break;
|
| }x3 = args[1];
|
| case 1:
|
| x1 = mp.getX ();
|
| x2 = args[0];
|
| break;
|
| default:
|
| return false;
|
| }
|
| if (tok == 1275069442) {
|
| var a = JU.P3.newP (mp.ptValue (x1, null));
|
| a.cross (a, mp.ptValue (x2, null));
|
| return mp.addXPt (a);
|
| }var pt2 = (x2.tok == 7 ? null : mp.ptValue (x2, null));
|
| var plane2 = mp.planeValue (x2);
|
| var f = NaN;
|
| try {
|
| if (isDist) {
|
| var minMax = (op == -2147483648 ? 0 : op & 480);
|
| var isMinMax = (minMax == 32 || minMax == 64);
|
| var isAll = minMax == 480;
|
| switch (x1.tok) {
|
| case 7:
|
| case 10:
|
| var isAtomSet1 = (x1.tok == 10);
|
| var isAtomSet2 = (x2.tok == 10);
|
| var isPoint2 = (x2.tok == 8);
|
| var bs1 = (isAtomSet1 ? x1.value : null);
|
| var bs2 = (isAtomSet2 ? x2.value : null);
|
| var list1 = (isAtomSet1 ? null : x1.getList ());
|
| var list2 = (isAtomSet2 ? null : x2.getList ());
|
| var returnAtom = (isMinMax && x3 != null && x3.asBoolean ());
|
| switch (x2.tok) {
|
| case 10:
|
| case 7:
|
| case 8:
|
| var atoms = this.vwr.ms.at;
|
| if (returnAtom) {
|
| var dMinMax = NaN;
|
| var iMinMax = 2147483647;
|
| if (isAtomSet1) {
|
| for (var i = bs1.nextSetBit (0); i >= 0; i = bs1.nextSetBit (i + 1)) {
|
| var d = (isPoint2 ? atoms[i].distanceSquared (pt2) : (this.e.getBitsetProperty (bs2, list2, op, atoms[i], plane2, x1.value, null, false, x1.index, false)).floatValue ());
|
| if (minMax == 32 ? d >= dMinMax : d <= dMinMax) continue;
|
| dMinMax = d;
|
| iMinMax = i;
|
| }
|
| return mp.addXBs (iMinMax == 2147483647 ? new JU.BS () : JU.BSUtil.newAndSetBit (iMinMax));
|
| }for (var i = list1.size (); --i >= 0; ) {
|
| var pt = JS.SV.ptValue (list1.get (i));
|
| var d = (isPoint2 ? pt.distanceSquared (pt2) : (this.e.getBitsetProperty (bs2, list2, op, pt, plane2, x1.value, null, false, 2147483647, false)).floatValue ());
|
| if (minMax == 32 ? d >= dMinMax : d <= dMinMax) continue;
|
| dMinMax = d;
|
| iMinMax = i;
|
| }
|
| return mp.addXInt (iMinMax);
|
| }if (isAll) {
|
| if (bs2 == null) {
|
| var data = Clazz_newFloatArray (bs1.cardinality (), 0);
|
| for (var p = 0, i = bs1.nextSetBit (0); i >= 0; i = bs1.nextSetBit (i + 1), p++) data[p] = atoms[i].distance (pt2);
|
|
|
| return mp.addXAF (data);
|
| }var data2 = Clazz_newFloatArray (bs1.cardinality (), bs2.cardinality (), 0);
|
| for (var p = 0, i = bs1.nextSetBit (0); i >= 0; i = bs1.nextSetBit (i + 1), p++) for (var q = 0, j = bs2.nextSetBit (0); j >= 0; j = bs2.nextSetBit (j + 1), q++) data2[p][q] = atoms[i].distance (atoms[j]);
|
|
|
|
|
| return mp.addXAFF (data2);
|
| }if (isMinMax) {
|
| var data = Clazz_newFloatArray (isAtomSet1 ? bs1.cardinality () : list1.size (), 0);
|
| if (isAtomSet1) {
|
| for (var i = bs1.nextSetBit (0), p = 0; i >= 0; i = bs1.nextSetBit (i + 1)) data[p++] = (this.e.getBitsetProperty (bs2, list2, op, atoms[i], plane2, x1.value, null, false, x1.index, false)).floatValue ();
|
|
|
| return mp.addXAF (data);
|
| }for (var i = data.length; --i >= 0; ) data[i] = (this.e.getBitsetProperty (bs2, list2, op, JS.SV.ptValue (list1.get (i)), plane2, null, null, false, 2147483647, false)).floatValue ();
|
|
|
| return mp.addXAF (data);
|
| }return mp.addXObj (this.e.getBitsetProperty (bs1, list1, op, pt2, plane2, x1.value, null, false, x1.index, false));
|
| }
|
| }
|
| }var pt1 = mp.ptValue (x1, null);
|
| var plane1 = mp.planeValue (x1);
|
| if (isDist) {
|
| if (plane2 != null && x3 != null) f = JU.Measure.directedDistanceToPlane (pt1, plane2, JS.SV.ptValue (x3));
|
| else f = (plane1 == null ? (plane2 == null ? pt2.distance (pt1) : JU.Measure.distanceToPlane (plane2, pt1)) : JU.Measure.distanceToPlane (plane1, pt2));
|
| } else {
|
| if (plane1 != null && plane2 != null) {
|
| f = plane1.x * plane2.x + plane1.y * plane2.y + plane1.z * plane2.z + plane1.w * plane2.w;
|
| } else {
|
| if (plane1 != null) pt1 = JU.P3.new3 (plane1.x, plane1.y, plane1.z);
|
| else if (plane2 != null) pt2 = JU.P3.new3 (plane2.x, plane2.y, plane2.z);
|
| f = pt1.dot (pt2);
|
| }}} catch (e) {
|
| if (Clazz_exceptionOf (e, Exception)) {
|
| } else {
|
| throw e;
|
| }
|
| }
|
| return mp.addXFloat (f);
|
| }, "JS.ScriptMathProcessor,~A,~N,~N");
|
| Clazz_defineMethod (c$, "evaluateHelix",
|
| function (mp, args) {
|
| if (args.length < 1 || args.length > 5) return false;
|
| var pt = (args.length > 2 ? 3 : 1);
|
| var type = (pt >= args.length ? "array" : JS.SV.sValue (args[pt]));
|
| var tok = JS.T.getTokFromName (type);
|
| if (args.length > 2) {
|
| var pta = mp.ptValue (args[0], null);
|
| var ptb = mp.ptValue (args[1], null);
|
| if (tok == 0 || args[2].tok != 9 || pta == null || ptb == null) return false;
|
| var dq = JU.Quat.newP4 (args[2].value);
|
| var data = JU.Measure.computeHelicalAxis (pta, ptb, dq);
|
| return (data == null ? false : mp.addXObj (JU.Escape.escapeHelical (type, tok, pta, ptb, data)));
|
| }var bs = (Clazz_instanceOf (args[0].value, JU.BS) ? args[0].value : this.vwr.ms.getAtoms (1094715412, new Integer (args[0].asInt ())));
|
| switch (tok) {
|
| case 134217751:
|
| case 1073741854:
|
| case 1665140738:
|
| return mp.addXObj (this.getHelixData (bs, tok));
|
| case 134217729:
|
| return mp.addXFloat ((this.getHelixData (bs, 134217729)).floatValue ());
|
| case 135176:
|
| case 1745489939:
|
| return mp.addXObj (this.getHelixData (bs, tok));
|
| case 1275068418:
|
| var data = this.getHelixData (bs, 1073742001);
|
| if (data == null) return false;
|
| return mp.addXAS (data);
|
| }
|
| return false;
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "getHelixData",
|
| function (bs, tokType) {
|
| var iAtom = bs.nextSetBit (0);
|
| return (iAtom < 0 ? "null" : this.vwr.ms.at[iAtom].group.getHelixData (tokType, this.vwr.getQuaternionFrame (), this.vwr.getInt (553648145)));
|
| }, "JU.BS,~N");
|
| Clazz_defineMethod (c$, "evaluateFind",
|
| function (mp, args) {
|
| var x1 = mp.getX ();
|
| var isList = (x1.tok == 7);
|
| var isEmpty = (args.length == 0);
|
| var sFind = (isEmpty ? "" : JS.SV.sValue (args[0]));
|
| var flags = (args.length > 1 && args[1].tok != 1073742335 && args[1].tok != 1073742334 && args[1].tok != 10 ? JS.SV.sValue (args[1]) : "");
|
| var isSequence = !isList && sFind.equalsIgnoreCase ("SEQUENCE");
|
| var isSeq = !isList && sFind.equalsIgnoreCase ("SEQ");
|
| if (sFind.toUpperCase ().startsWith ("SMILES/")) {
|
| if (!sFind.endsWith ("/")) sFind += "/";
|
| var s = sFind.substring (6) + "//";
|
| if (JV.JC.isSmilesCanonical (s)) {
|
| flags = "SMILES";
|
| sFind = "CHEMICAL";
|
| } else {
|
| sFind = "SMILES";
|
| flags = s + flags;
|
| }} else if (sFind.toUpperCase ().startsWith ("SMARTS/")) {
|
| if (!sFind.endsWith ("/")) sFind += "/";
|
| flags = sFind.substring (6) + (flags.length == 0 ? "//" : flags);
|
| sFind = "SMARTS";
|
| }var isSmiles = !isList && sFind.equalsIgnoreCase ("SMILES");
|
| var isSMARTS = !isList && sFind.equalsIgnoreCase ("SMARTS");
|
| var isChemical = !isList && sFind.equalsIgnoreCase ("CHEMICAL");
|
| var isMF = !isList && sFind.equalsIgnoreCase ("MF");
|
| var isCF = !isList && sFind.equalsIgnoreCase ("CELLFORMULA");
|
| var argLast = (args.length > 0 ? args[args.length - 1] : JS.SV.vF);
|
| var isON = !isList && (argLast.tok == 1073742335);
|
| try {
|
| if (isChemical) {
|
| var bsAtoms = (x1.tok == 10 ? x1.value : null);
|
| var data = (bsAtoms == null ? JS.SV.sValue (x1) : this.vwr.getOpenSmiles (bsAtoms));
|
| data = (data.length == 0 ? "" : this.vwr.getChemicalInfo (data, flags.toLowerCase (), bsAtoms)).trim ();
|
| if (data.startsWith ("InChI")) data = JU.PT.rep (JU.PT.rep (data, "InChI=", ""), "InChIKey=", "");
|
| return mp.addXStr (data);
|
| }if (isSmiles || isSMARTS || x1.tok == 10) {
|
| var iPt = (isSmiles || isSMARTS ? 2 : 1);
|
| var bs2 = (iPt < args.length && args[iPt].tok == 10 ? args[iPt++].value : null);
|
| var asBonds = ("bonds".equalsIgnoreCase (JS.SV.sValue (args[args.length - 1])));
|
| var isAll = (asBonds || isON);
|
| var ret = null;
|
| switch (x1.tok) {
|
| case 4:
|
| var smiles = JS.SV.sValue (x1);
|
| if (bs2 != null || isSmiles && args.length == 1) return false;
|
| if (flags.equalsIgnoreCase ("mf")) {
|
| ret = this.vwr.getSmilesMatcher ().getMolecularFormula (smiles, isSMARTS);
|
| } else {
|
| var pattern = flags;
|
| var allMappings = true;
|
| var asMap = false;
|
| switch (args.length) {
|
| case 4:
|
| allMappings = JS.SV.bValue (args[3]);
|
| case 3:
|
| asMap = JS.SV.bValue (args[2]);
|
| break;
|
| }
|
| var justOne = (!asMap && (!allMappings || !isSMARTS && !pattern.equals ("chirality")));
|
| try {
|
| ret = this.e.getSmilesExt ().getSmilesMatches (pattern, smiles, null, null, isSMARTS ? 2 : 1, !asMap, !allMappings);
|
| } catch (ex) {
|
| if (Clazz_exceptionOf (ex, Exception)) {
|
| System.out.println (ex.getMessage ());
|
| return mp.addXInt (-1);
|
| } else {
|
| throw ex;
|
| }
|
| }
|
| if (justOne) {
|
| var len = (ret).length;
|
| return mp.addXInt (!allMappings && len > 0 ? 1 : len);
|
| }}break;
|
| case 10:
|
| var bs = x1.value;
|
| if (isMF && flags.length != 0) return mp.addXBs (JU.JmolMolecule.getBitSetForMF (this.vwr.ms.at, bs, flags));
|
| if (isMF || isCF) return mp.addXStr (JU.JmolMolecule.getMolecularFormulaAtoms (this.vwr.ms.at, bs, (isMF ? null : this.vwr.ms.getCellWeights (bs)), isON));
|
| if (isSequence || isSeq) {
|
| var isHH = (argLast.asString ().equalsIgnoreCase ("H"));
|
| isAll = new Boolean (isAll | isHH).valueOf ();
|
| return mp.addXStr (this.vwr.getSmilesOpt (bs, -1, -1, (isAll ? 3145728 | 5242880 | (isHH ? 9437184 : 0) : 0) | (isSeq ? 34603008 : 1048576), null));
|
| }if (isSmiles || isSMARTS) sFind = (args.length > 1 && args[1].tok == 10 ? this.vwr.getSmilesOpt (args[1].value, 0, 0, 0, flags) : flags);
|
| flags = flags.toUpperCase ();
|
| var bsMatch3D = bs2;
|
| if (asBonds) {
|
| var map = this.vwr.getSmilesMatcher ().getCorrelationMaps (sFind, this.vwr.ms.at, this.vwr.ms.ac, bs, (isSmiles ? 1 : 2) | 8);
|
| ret = (map.length > 0 ? this.vwr.ms.getDihedralMap (map[0]) : Clazz_newIntArray (0, 0));
|
| } else if (flags.equalsIgnoreCase ("map")) {
|
| var map = this.vwr.getSmilesMatcher ().getCorrelationMaps (sFind, this.vwr.ms.at, this.vwr.ms.ac, bs, (isSmiles ? 1 : 2) | 128);
|
| ret = map;
|
| } else if (sFind.equalsIgnoreCase ("crystalClass")) {
|
| ret = this.vwr.ms.generateCrystalClass (bs.nextSetBit (0), (args.length != 2 ? null : argLast.tok == 10 ? this.vwr.ms.getAtomSetCenter (argLast.value) : JS.SV.ptValue (argLast)));
|
| } else {
|
| var smilesFlags = (isSmiles ? (flags.indexOf ("OPEN") >= 0 ? 5 : 1) : 2) | (isON && sFind.length == 0 ? 22020096 : 0);
|
| if (flags.indexOf ("/MOLECULE/") >= 0) {
|
| var mols = this.vwr.ms.getMolecules ();
|
| var molList = new JU.Lst ();
|
| for (var i = 0; i < mols.length; i++) {
|
| if (mols[i].atomList.intersects (bs)) {
|
| var bsRet = this.e.getSmilesExt ().getSmilesMatches (sFind, null, mols[i].atomList, bsMatch3D, smilesFlags, !isON, false);
|
| if (!bsRet.isEmpty ()) molList.addLast (bsRet);
|
| }}
|
| ret = molList;
|
| } else {
|
| ret = this.e.getSmilesExt ().getSmilesMatches (sFind, null, bs, bsMatch3D, smilesFlags, !isON, false);
|
| }}break;
|
| }
|
| if (ret == null) this.e.invArg ();
|
| return mp.addXObj (ret);
|
| }} catch (ex) {
|
| if (Clazz_exceptionOf (ex, Exception)) {
|
| this.e.evalError (ex.getMessage (), null);
|
| } else {
|
| throw ex;
|
| }
|
| }
|
| var isReverse = (flags.indexOf ("v") >= 0);
|
| var isCaseInsensitive = (flags.indexOf ("i") >= 0);
|
| var asMatch = (flags.indexOf ("m") >= 0);
|
| var checkEmpty = (sFind.length == 0);
|
| var isPattern = (!checkEmpty && args.length == 2);
|
| if (isList || isPattern) {
|
| var pm = (isPattern ? this.getPatternMatcher () : null);
|
| var pattern = null;
|
| var svlist = (isList ? x1.getList () : null);
|
| if (isPattern) {
|
| try {
|
| pattern = pm.compile (sFind, isCaseInsensitive);
|
| } catch (ex) {
|
| if (Clazz_exceptionOf (ex, Exception)) {
|
| this.e.evalError (ex.toString (), null);
|
| } else {
|
| throw ex;
|
| }
|
| }
|
| }var list = (checkEmpty ? null : JS.SV.strListValue (x1));
|
| var nlist = (checkEmpty ? svlist.size () : list.length);
|
| if (JU.Logger.debugging) JU.Logger.debug ("finding " + sFind);
|
| var bs = new JU.BS ();
|
| var n = 0;
|
| var matcher = null;
|
| var v = (asMatch ? new JU.Lst () : null);
|
| var what = "";
|
| for (var i = 0; i < nlist; i++) {
|
| var isMatch;
|
| if (checkEmpty) {
|
| var o = svlist.get (i);
|
| switch (o.tok) {
|
| case 6:
|
| isMatch = (o.getMap ().isEmpty () != isEmpty);
|
| break;
|
| case 7:
|
| isMatch = ((o.getList ().size () == 0) != isEmpty);
|
| break;
|
| case 4:
|
| isMatch = ((o.asString ().length == 0) != isEmpty);
|
| break;
|
| default:
|
| isMatch = true;
|
| }
|
| } else if (isPattern) {
|
| what = list[i];
|
| matcher = pattern.matcher (what);
|
| isMatch = matcher.find ();
|
| } else {
|
| isMatch = (JS.SV.sValue (svlist.get (i)).indexOf (sFind) >= 0);
|
| }if (asMatch && isMatch || !asMatch && isMatch == !isReverse) {
|
| n++;
|
| bs.set (i);
|
| if (asMatch) v.addLast (isReverse ? what.substring (0, matcher.start ()) + what.substring (matcher.end ()) : matcher.group ());
|
| }}
|
| if (!isList) {
|
| return (asMatch ? mp.addXStr (v.size () == 1 ? v.get (0) : "") : isReverse ? mp.addXBool (n == 1) : asMatch ? mp.addXStr (n == 0 ? "" : matcher.group ()) : mp.addXInt (n == 0 ? 0 : matcher.start () + 1));
|
| }if (asMatch) {
|
| var listNew = new Array (n);
|
| if (n > 0) for (var i = list.length; --i >= 0; ) if (bs.get (i)) {
|
| --n;
|
| listNew[n] = (asMatch ? v.get (n) : list[i]);
|
| }
|
| return mp.addXAS (listNew);
|
| }var l = new JU.Lst ();
|
| for (var i = bs.nextSetBit (0); i >= 0; i = bs.nextSetBit (i + 1)) l.addLast (svlist.get (i));
|
|
|
| return mp.addXList (l);
|
| }if (isSequence) {
|
| return mp.addXStr (this.vwr.getJBR ().toStdAmino3 (JS.SV.sValue (x1)));
|
| }return mp.addXInt (JS.SV.sValue (x1).indexOf (sFind) + 1);
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateGetProperty",
|
| function (mp, args, tok0, isAtomProperty) {
|
| var isSelect = (isAtomProperty && tok0 == 1275082245);
|
| var isAuxiliary = (tok0 == 1275068449);
|
| var pt = 0;
|
| var tok = (args.length == 0 ? 0 : args[0].tok);
|
| if (args.length == 2 && (tok == 7 || tok == 6 || tok == 14)) {
|
| return mp.addXObj (this.vwr.extractProperty (args[0].value, args[1].value.toString (), -1));
|
| }var bsSelect = (isAtomProperty && args.length == 1 && args[0].tok == 10 ? args[0].value : null);
|
| var pname = (bsSelect == null && args.length > 0 ? JS.SV.sValue (args[pt++]) : "");
|
| var propertyName = pname;
|
| var lc = propertyName.toLowerCase ();
|
| if (!isSelect && lc.indexOf ("[select ") < 0) propertyName = lc;
|
| var isJSON = false;
|
| if (propertyName.equals ("json") && args.length > pt) {
|
| isJSON = true;
|
| propertyName = JS.SV.sValue (args[pt++]);
|
| }var x = null;
|
| if (isAtomProperty) {
|
| x = mp.getX ();
|
| switch (x.tok) {
|
| case 10:
|
| break;
|
| case 4:
|
| var name = x.value;
|
| var data = new Array (3);
|
| var shapeID;
|
| if (name.startsWith ("$")) {
|
| name = name.substring (1);
|
| shapeID = this.vwr.shm.getShapeIdFromObjectName (name);
|
| if (shapeID >= 0) {
|
| data[0] = name;
|
| this.vwr.shm.getShapePropertyData (shapeID, "index", data);
|
| if (data[1] != null && !pname.equals ("index")) {
|
| var index = (data[1]).intValue ();
|
| data[1] = this.vwr.shm.getShapePropertyIndex (shapeID, pname.intern (), index);
|
| }}} else {
|
| shapeID = JV.JC.shapeTokenIndex (JS.T.getTokFromName (name));
|
| if (shapeID >= 0) {
|
| data[0] = pname;
|
| data[1] = Integer.$valueOf (-1);
|
| this.vwr.shm.getShapePropertyData (shapeID, pname.intern (), data);
|
| }}return (data[1] == null ? mp.addXStr ("") : mp.addXObj (data[1]));
|
| case 7:
|
| if (bsSelect != null) {
|
| var l0 = x.getList ();
|
| var lst = new JU.Lst ();
|
| for (var i = bsSelect.nextSetBit (0); i >= 0; i = bsSelect.nextSetBit (i + 1)) lst.addLast (l0.get (i));
|
|
|
| return mp.addXList (lst);
|
| }default:
|
| if (isSelect) propertyName = "[SELECT " + propertyName + "]";
|
| return mp.addXObj (this.vwr.extractProperty (x, propertyName, -1));
|
| }
|
| if (!lc.startsWith ("bondinfo") && !lc.startsWith ("atominfo")) propertyName = "atomInfo." + propertyName;
|
| }var propertyValue = "";
|
| if (propertyName.equalsIgnoreCase ("fileContents") && args.length > 2) {
|
| var s = JS.SV.sValue (args[1]);
|
| for (var i = 2; i < args.length; i++) s += "|" + JS.SV.sValue (args[i]);
|
|
|
| propertyValue = s;
|
| pt = args.length;
|
| } else if (args.length > pt) {
|
| switch (args[pt].tok) {
|
| case 10:
|
| propertyValue = args[pt++].value;
|
| if (propertyName.equalsIgnoreCase ("bondInfo") && args.length > pt && args[pt].tok == 10) propertyValue = Clazz_newArray (-1, [propertyValue, args[pt].value]);
|
| break;
|
| case 6:
|
| case 4:
|
| if (this.vwr.checkPropertyParameter (propertyName)) propertyValue = args[pt++].value;
|
| break;
|
| }
|
| }if (isAtomProperty) {
|
| var bs = x.value;
|
| var iAtom = bs.nextSetBit (0);
|
| if (iAtom < 0) return mp.addXStr ("");
|
| propertyValue = bs;
|
| }if (isAuxiliary && !isAtomProperty) propertyName = "auxiliaryInfo.models." + propertyName;
|
| propertyName = JU.PT.rep (propertyName, ".[", "[");
|
| var property = this.vwr.getProperty (null, propertyName, propertyValue);
|
| if (pt < args.length) property = this.vwr.extractProperty (property, args, pt);
|
| return mp.addXObj (isJSON ? JS.SV.safeJSON ("value", property) : JS.SV.isVariableType (property) ? property : JU.Escape.toReadable (propertyName, property));
|
| }, "JS.ScriptMathProcessor,~A,~N,~B");
|
| Clazz_defineMethod (c$, "evaluateFormat",
|
| function (mp, intValue, args, isLabel) {
|
| var x1 = (args.length < 2 || intValue == 1287653388 ? mp.getX () : null);
|
| var format = (args.length == 0 ? "%U" : args[0].tok == 7 ? null : JS.SV.sValue (args[0]));
|
| if (!isLabel && args.length > 0 && x1 != null && x1.tok != 10 && format != null) {
|
| if (args.length == 2) {
|
| var listIn = x1.getList ();
|
| var formatList = args[1].getList ();
|
| if (listIn == null || formatList == null) return false;
|
| x1 = JS.SV.getVariableList (this.getSublist (listIn, formatList));
|
| }args = Clazz_newArray (-1, [args[0], x1]);
|
| x1 = null;
|
| }if (x1 == null) {
|
| var pt = (isLabel ? -1 : JS.SV.getFormatType (format));
|
| if (pt >= 0 && args.length != 2) return false;
|
| if (pt >= 0 || args.length < 2 || args[1].tok != 7) {
|
| var o = JS.SV.format (args, pt);
|
| return (format.equalsIgnoreCase ("json") ? mp.addXStr (o) : mp.addXObj (o));
|
| }var a = args[1].getList ();
|
| var args2 = Clazz_newArray (-1, [args[0], null]);
|
| var sa = new Array (a.size ());
|
| for (var i = sa.length; --i >= 0; ) {
|
| args2[1] = a.get (i);
|
| sa[i] = JS.SV.format (args2, pt).toString ();
|
| }
|
| return mp.addXAS (sa);
|
| }if (x1.tok == 7 && format == null) {
|
| var listIn = x1.getList ();
|
| var formatList = args[0].getList ();
|
| var listOut = this.getSublist (listIn, formatList);
|
| return mp.addXList (listOut);
|
| }var bs = (x1.tok == 10 ? x1.value : null);
|
| var asArray = JS.T.tokAttr (intValue, 480);
|
| return mp.addXObj (format == null ? "" : bs == null ? JS.SV.sprintf (JU.PT.formatCheck (format), x1) : this.e.getCmdExt ().getBitsetIdent (bs, format, x1.value, true, x1.index, asArray));
|
| }, "JS.ScriptMathProcessor,~N,~A,~B");
|
| Clazz_defineMethod (c$, "getSublist",
|
| function (listIn, formatList) {
|
| var listOut = new JU.Lst ();
|
| var map;
|
| var v;
|
| var list;
|
| for (var i = 0, n = listIn.size (); i < n; i++) {
|
| var element = listIn.get (i);
|
| switch (element.tok) {
|
| case 6:
|
| map = element.getMap ();
|
| list = new JU.Lst ();
|
| for (var j = 0, n1 = formatList.size (); j < n1; j++) {
|
| v = map.get (JS.SV.sValue (formatList.get (j)));
|
| list.addLast (v == null ? JS.SV.newS ("") : v);
|
| }
|
| listOut.addLast (JS.SV.getVariableList (list));
|
| break;
|
| case 7:
|
| map = new java.util.Hashtable ();
|
| list = element.getList ();
|
| for (var j = 0, n1 = Math.min (list.size (), formatList.size ()); j < n1; j++) {
|
| map.put (JS.SV.sValue (formatList.get (j)), list.get (j));
|
| }
|
| listOut.addLast (JS.SV.getVariable (map));
|
| }
|
| }
|
| return listOut;
|
| }, "JU.Lst,JU.Lst");
|
| Clazz_defineMethod (c$, "evaluateList",
|
| function (mp, tok, args) {
|
| var len = args.length;
|
| var x1 = mp.getX ();
|
| var isArray1 = (x1.tok == 7);
|
| var x2;
|
| switch (tok) {
|
| case 1275335685:
|
| return (len == 2 && mp.addX (x1.pushPop (args[0], args[1])) || len == 1 && mp.addX (x1.pushPop (null, args[0])));
|
| case 1275334681:
|
| return (len == 1 && mp.addX (x1.pushPop (args[0], null)) || len == 0 && mp.addX (x1.pushPop (null, null)));
|
| case 1275069441:
|
| if (len != 1 && len != 2) return false;
|
| break;
|
| case 1275069447:
|
| case 1275069446:
|
| break;
|
| default:
|
| if (len != 1) return false;
|
| }
|
| var sList1 = null;
|
| var sList2 = null;
|
| var sList3 = null;
|
| if (len == 2) {
|
| var tab = JS.SV.sValue (args[0]);
|
| x2 = args[1];
|
| if (tok == 1275069441) {
|
| sList1 = (isArray1 ? JS.SV.strListValue (x1) : JU.PT.split (JS.SV.sValue (x1), "\n"));
|
| sList2 = (x2.tok == 7 ? JS.SV.strListValue (x2) : JU.PT.split (JS.SV.sValue (x2), "\n"));
|
| sList3 = new Array (len = Math.max (sList1.length, sList2.length));
|
| for (var i = 0; i < len; i++) sList3[i] = (i >= sList1.length ? "" : sList1[i]) + tab + (i >= sList2.length ? "" : sList2[i]);
|
|
|
| return mp.addXAS (sList3);
|
| }if (x2.tok != 1073742335) return false;
|
| var l = x1.getList ();
|
| var isCSV = (tab.length == 0);
|
| if (isCSV) tab = ",";
|
| if (tok == 1275069446) {
|
| var s2 = new Array (l.size ());
|
| for (var i = l.size (); --i >= 0; ) {
|
| var a = l.get (i).getList ();
|
| if (a == null) s2[i] = l.get (i);
|
| else {
|
| var sb = new JU.SB ();
|
| for (var j = 0, n = a.size (); j < n; j++) {
|
| if (j > 0) sb.append (tab);
|
| var sv = a.get (j);
|
| sb.append (isCSV && sv.tok == 4 ? "\"" + JU.PT.rep (sv.value, "\"", "\"\"") + "\"" : "" + sv.asString ());
|
| }
|
| s2[i] = JS.SV.newS (sb.toString ());
|
| }}
|
| return mp.addXAV (s2);
|
| }var sa = new JU.Lst ();
|
| if (isCSV) tab = "\0";
|
| var next = Clazz_newIntArray (2, 0);
|
| for (var i = 0, nl = l.size (); i < nl; i++) {
|
| var line = l.get (i).asString ();
|
| if (isCSV) {
|
| next[1] = 0;
|
| next[0] = 0;
|
| var last = 0;
|
| while (true) {
|
| var s = JU.PT.getCSVString (line, next);
|
| if (s == null) {
|
| if (next[1] == -1) {
|
| line += (++i < nl ? "\n" + l.get (i).asString () : "\"");
|
| next[1] = last;
|
| continue;
|
| }line = line.substring (0, last) + line.substring (last).$replace (',', '\0');
|
| break;
|
| }line = line.substring (0, last) + line.substring (last, next[0]).$replace (',', '\0') + s + line.substring (next[1]);
|
| next[1] = last = next[0] + s.length;
|
| }
|
| }var linaa = line.$plit (tab);
|
| var la = new JU.Lst ();
|
| for (var j = 0, n = linaa.length; j < n; j++) {
|
| var s = linaa[j];
|
| if (s.indexOf (".") < 0) try {
|
| la.addLast (JS.SV.newI (Integer.parseInt (s)));
|
| continue;
|
| } catch (e) {
|
| if (Clazz_exceptionOf (e, Exception)) {
|
| } else {
|
| throw e;
|
| }
|
| }
|
| else try {
|
| la.addLast (JS.SV.getVariable (Float.$valueOf (Float.parseFloat (s))));
|
| continue;
|
| } catch (ee) {
|
| if (Clazz_exceptionOf (ee, Exception)) {
|
| } else {
|
| throw ee;
|
| }
|
| }
|
| la.addLast (JS.SV.newS (s));
|
| }
|
| sa.addLast (JS.SV.getVariableList (la));
|
| }
|
| return mp.addXObj (JS.SV.getVariableList (sa));
|
| }x2 = (len == 0 ? JS.SV.newV (1073742327, "all") : args[0]);
|
| var isAll = (x2.tok == 1073742327);
|
| if (!isArray1 && x1.tok != 4) return mp.binaryOp (this.opTokenFor (tok), x1, x2);
|
| var isScalar1 = JS.SV.isScalar (x1);
|
| var isScalar2 = JS.SV.isScalar (x2);
|
| var list1 = null;
|
| var list2 = null;
|
| var alist1 = x1.getList ();
|
| var alist2 = x2.getList ();
|
| if (isArray1) {
|
| len = alist1.size ();
|
| } else if (isScalar1) {
|
| len = 2147483647;
|
| } else {
|
| sList1 = (JU.PT.split (JS.SV.sValue (x1), "\n"));
|
| list1 = Clazz_newFloatArray (len = sList1.length, 0);
|
| JU.PT.parseFloatArrayData (sList1, list1);
|
| }if (isAll && tok != 1275069446) {
|
| var sum = 0;
|
| if (isArray1) {
|
| for (var i = len; --i >= 0; ) sum += JS.SV.fValue (alist1.get (i));
|
|
|
| } else if (!isScalar1) {
|
| for (var i = len; --i >= 0; ) sum += list1[i];
|
|
|
| }return mp.addXFloat (sum);
|
| }if (tok == 1275069446 && x2.tok == 4) {
|
| var sb = new JU.SB ();
|
| if (isScalar1) {
|
| sb.append (JS.SV.sValue (x1));
|
| } else {
|
| var s = (isAll ? "" : x2.value.toString ());
|
| for (var i = 0; i < len; i++) sb.append (i > 0 ? s : "").append (JS.SV.sValue (alist1.get (i)));
|
|
|
| }return mp.addXStr (sb.toString ());
|
| }var scalar = null;
|
| if (isScalar2) {
|
| scalar = x2;
|
| } else if (x2.tok == 7) {
|
| len = Math.min (len, alist2.size ());
|
| } else {
|
| sList2 = JU.PT.split (JS.SV.sValue (x2), "\n");
|
| list2 = Clazz_newFloatArray (sList2.length, 0);
|
| JU.PT.parseFloatArrayData (sList2, list2);
|
| len = Math.min (len, list2.length);
|
| }var token = this.opTokenFor (tok);
|
| var olist = new Array (len);
|
| if (isArray1 && isAll) {
|
| var llist = new JU.Lst ();
|
| return mp.addXList (this.addAllLists (x1.getList (), llist));
|
| }var a = (isScalar1 ? x1 : null);
|
| var b;
|
| for (var i = 0; i < len; i++) {
|
| if (isScalar2) b = scalar;
|
| else if (x2.tok == 7) b = alist2.get (i);
|
| else if (Float.isNaN (list2[i])) b = JS.SV.getVariable (JS.SV.unescapePointOrBitsetAsVariable (sList2[i]));
|
| else b = JS.SV.newF (list2[i]);
|
| if (!isScalar1) {
|
| if (isArray1) a = alist1.get (i);
|
| else if (Float.isNaN (list1[i])) a = JS.SV.getVariable (JS.SV.unescapePointOrBitsetAsVariable (sList1[i]));
|
| else a = JS.SV.newF (list1[i]);
|
| }if (tok == 1275069446) {
|
| if (a.tok != 7) {
|
| var l = new JU.Lst ();
|
| l.addLast (a);
|
| a = JS.SV.getVariableList (l);
|
| }}if (!mp.binaryOp (token, a, b)) return false;
|
| olist[i] = mp.getX ();
|
| }
|
| return mp.addXAV (olist);
|
| }, "JS.ScriptMathProcessor,~N,~A");
|
| Clazz_defineMethod (c$, "addAllLists",
|
| function (list, l) {
|
| var n = list.size ();
|
| for (var i = 0; i < n; i++) {
|
| var v = list.get (i);
|
| if (v.tok == 7) this.addAllLists (v.getList (), l);
|
| else l.addLast (v);
|
| }
|
| return l;
|
| }, "JU.Lst,JU.Lst");
|
| Clazz_defineMethod (c$, "evaluateLoad",
|
| function (mp, args, isFile) {
|
| if (args.length < 1 || args.length > 3) return false;
|
| var file = JV.FileManager.fixDOSName (JS.SV.sValue (args[0]));
|
| var asBytes = (args.length > 1 && args[1].tok == 1073742335);
|
| var async = (this.vwr.async || args.length > 2 && args[args.length - 1].tok == 1073742335);
|
| var nBytesMax = (args.length > 1 && args[1].tok == 2 ? args[1].asInt () : -1);
|
| var asJSON = (args.length > 1 && args[1].asString ().equalsIgnoreCase ("JSON"));
|
| if (asBytes) return mp.addXMap (this.vwr.fm.getFileAsMap (file, null));
|
| var isQues = file.startsWith ("?");
|
| if (JV.Viewer.isJS && (isQues || async)) {
|
| if (isFile && isQues) return mp.addXStr ("");
|
| file = this.e.loadFileAsync ("load()_", file, mp.oPt, true);
|
| }var str = isFile ? this.vwr.fm.getFilePath (file, false, false) : this.vwr.getFileAsString4 (file, nBytesMax, false, false, true, "script");
|
| try {
|
| return (asJSON ? mp.addXObj (this.vwr.parseJSON (str)) : mp.addXStr (str));
|
| } catch (e) {
|
| if (Clazz_exceptionOf (e, Exception)) {
|
| return false;
|
| } else {
|
| throw e;
|
| }
|
| }
|
| }, "JS.ScriptMathProcessor,~A,~B");
|
| Clazz_defineMethod (c$, "evaluateMath",
|
| function (mp, args, tok) {
|
| if (tok == 134217749) {
|
| if (args.length == 1 && args[0].tok == 4) return mp.addXStr (( new java.util.Date ()) + "\t" + JS.SV.sValue (args[0]));
|
| return mp.addXInt ((System.currentTimeMillis () & 0x7FFFFFFF) - (args.length == 0 ? 0 : args[0].asInt ()));
|
| }if (args.length != 1) return false;
|
| if (tok == 134218250) {
|
| if (args[0].tok == 2) return mp.addXInt (Math.abs (args[0].asInt ()));
|
| return mp.addXFloat (Math.abs (args[0].asFloat ()));
|
| }var x = JS.SV.fValue (args[0]);
|
| switch (tok) {
|
| case 134218242:
|
| return mp.addXFloat ((Math.acos (x) * 180 / 3.141592653589793));
|
| case 134218245:
|
| return mp.addXFloat (Math.cos (x * 3.141592653589793 / 180));
|
| case 134218244:
|
| return mp.addXFloat (Math.sin (x * 3.141592653589793 / 180));
|
| case 134218246:
|
| return mp.addXFloat (Math.sqrt (x));
|
| }
|
| return false;
|
| }, "JS.ScriptMathProcessor,~A,~N");
|
| Clazz_defineMethod (c$, "evaluateMeasure",
|
| function (mp, args, tok) {
|
| var nPoints = 0;
|
| switch (tok) {
|
| case 1745489939:
|
| var points = new JU.Lst ();
|
| var rangeMinMax = Clazz_newFloatArray (-1, [3.4028235E38, 3.4028235E38]);
|
| var strFormat = null;
|
| var units = null;
|
| var isAllConnected = false;
|
| var isNotConnected = false;
|
| var rPt = 0;
|
| var isNull = false;
|
| var rd = null;
|
| var nBitSets = 0;
|
| var vdw = 3.4028235E38;
|
| var asMinArray = false;
|
| var asArray = false;
|
| for (var i = 0; i < args.length; i++) {
|
| switch (args[i].tok) {
|
| case 10:
|
| var bs = args[i].value;
|
| if (bs.length () == 0) isNull = true;
|
| points.addLast (bs);
|
| nPoints++;
|
| nBitSets++;
|
| break;
|
| case 8:
|
| var v = new JU.Point3fi ();
|
| v.setT (args[i].value);
|
| points.addLast (v);
|
| nPoints++;
|
| break;
|
| case 2:
|
| case 3:
|
| rangeMinMax[rPt++ % 2] = JS.SV.fValue (args[i]);
|
| break;
|
| case 4:
|
| var s = JS.SV.sValue (args[i]);
|
| if (s.equalsIgnoreCase ("vdw") || s.equalsIgnoreCase ("vanderwaals")) vdw = (i + 1 < args.length && args[i + 1].tok == 2 ? args[++i].asInt () : 100) / 100;
|
| else if (s.equalsIgnoreCase ("notConnected")) isNotConnected = true;
|
| else if (s.equalsIgnoreCase ("connected")) isAllConnected = true;
|
| else if (s.equalsIgnoreCase ("minArray")) asMinArray = (nBitSets >= 1);
|
| else if (s.equalsIgnoreCase ("asArray")) asArray = (nBitSets >= 1);
|
| else if (JU.PT.isOneOf (s.toLowerCase (), ";nm;nanometers;pm;picometers;angstroms;ang;au;") || s.endsWith ("hz")) units = s.toLowerCase ();
|
| else strFormat = nPoints + ":" + s;
|
| break;
|
| default:
|
| return false;
|
| }
|
| }
|
| if (nPoints < 2 || nPoints > 4 || rPt > 2 || isNotConnected && isAllConnected) return false;
|
| if (isNull) return mp.addXStr ("");
|
| if (vdw != 3.4028235E38 && (nBitSets != 2 || nPoints != 2)) return mp.addXStr ("");
|
| rd = (vdw == 3.4028235E38 ? new J.atomdata.RadiusData (rangeMinMax, 0, null, null) : new J.atomdata.RadiusData (null, vdw, J.atomdata.RadiusData.EnumType.FACTOR, J.c.VDW.AUTO));
|
| return mp.addXObj ((this.vwr.newMeasurementData (null, points)).set (0, null, rd, strFormat, units, null, isAllConnected, isNotConnected, null, true, 0, 0, null).getMeasurements (asArray, asMinArray));
|
| case 134217729:
|
| if ((nPoints = args.length) != 3 && nPoints != 4) return false;
|
| break;
|
| default:
|
| if ((nPoints = args.length) != 2) return false;
|
| }
|
| var pts = new Array (nPoints);
|
| for (var i = 0; i < nPoints; i++) {
|
| if ((pts[i] = mp.ptValue (args[i], null)) == null) return false;
|
| }
|
| switch (nPoints) {
|
| case 2:
|
| return mp.addXFloat (pts[0].distance (pts[1]));
|
| case 3:
|
| return mp.addXFloat (JU.Measure.computeAngleABC (pts[0], pts[1], pts[2], true));
|
| case 4:
|
| return mp.addXFloat (JU.Measure.computeTorsion (pts[0], pts[1], pts[2], pts[3], true));
|
| }
|
| return false;
|
| }, "JS.ScriptMathProcessor,~A,~N");
|
| Clazz_defineMethod (c$, "evaluateModulation",
|
| function (mp, args) {
|
| var type = "";
|
| var t = NaN;
|
| var t456 = null;
|
| switch (args.length) {
|
| case 0:
|
| break;
|
| case 1:
|
| switch (args[0].tok) {
|
| case 8:
|
| t456 = args[0].value;
|
| break;
|
| case 4:
|
| type = args[0].asString ();
|
| break;
|
| default:
|
| t = JS.SV.fValue (args[0]);
|
| }
|
| break;
|
| case 2:
|
| type = JS.SV.sValue (args[0]);
|
| t = JS.SV.fValue (args[1]);
|
| break;
|
| default:
|
| return false;
|
| }
|
| if (t456 == null && t < 1e6) t456 = JU.P3.new3 (t, t, t);
|
| var x = mp.getX ();
|
| var bs = (x.tok == 10 ? x.value : new JU.BS ());
|
| return mp.addXList (this.vwr.ms.getModulationList (bs, (type + "D").toUpperCase ().charAt (0), t456));
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluatePlane",
|
| function (mp, args, tok) {
|
| if (tok == 134219265 && args.length != 3 || tok == 134217763 && args.length != 2 && args.length != 3 && args.length != 4 || args.length == 0 || args.length > 4) return false;
|
| var pt1;
|
| var pt2;
|
| var pt3;
|
| var plane;
|
| var norm;
|
| var vTemp;
|
| switch (args.length) {
|
| case 1:
|
| if (args[0].tok == 10) {
|
| var bs = args[0].value;
|
| if (bs.cardinality () == 3) {
|
| var pts = this.vwr.ms.getAtomPointVector (bs);
|
| return mp.addXPt4 (JU.Measure.getPlaneThroughPoints (pts.get (0), pts.get (1), pts.get (2), new JU.V3 (), new JU.V3 (), new JU.P4 ()));
|
| }}var pt = JU.Escape.uP (JS.SV.sValue (args[0]));
|
| if (Clazz_instanceOf (pt, JU.P4)) return mp.addXPt4 (pt);
|
| return mp.addXStr ("" + pt);
|
| case 2:
|
| if (tok == 134217763) {
|
| if (args[1].tok != 9) return false;
|
| pt3 = new JU.P3 ();
|
| norm = new JU.V3 ();
|
| vTemp = new JU.V3 ();
|
| plane = args[1].value;
|
| if (args[0].tok == 9) {
|
| var list = JU.Measure.getIntersectionPP (args[0].value, plane);
|
| if (list == null) return mp.addXStr ("");
|
| return mp.addXList (list);
|
| }pt2 = mp.ptValue (args[0], null);
|
| if (pt2 == null) return mp.addXStr ("");
|
| return mp.addXPt (JU.Measure.getIntersection (pt2, null, plane, pt3, norm, vTemp));
|
| }case 3:
|
| case 4:
|
| switch (tok) {
|
| case 134219265:
|
| return mp.addXPt4 (this.e.getHklPlane (JU.P3.new3 (JS.SV.fValue (args[0]), JS.SV.fValue (args[1]), JS.SV.fValue (args[2]))));
|
| case 134217763:
|
| pt1 = mp.ptValue (args[0], null);
|
| pt2 = mp.ptValue (args[1], null);
|
| if (pt1 == null || pt2 == null) return mp.addXStr ("");
|
| var vLine = JU.V3.newV (pt2);
|
| vLine.normalize ();
|
| if (args[2].tok == 9) {
|
| pt3 = new JU.P3 ();
|
| norm = new JU.V3 ();
|
| vTemp = new JU.V3 ();
|
| pt1 = JU.Measure.getIntersection (pt1, vLine, args[2].value, pt3, norm, vTemp);
|
| if (pt1 == null) return mp.addXStr ("");
|
| return mp.addXPt (pt1);
|
| }pt3 = mp.ptValue (args[2], null);
|
| if (pt3 == null) return mp.addXStr ("");
|
| var v = new JU.V3 ();
|
| pt3 = JU.P3.newP (pt3);
|
| if (args.length == 3) {
|
| JU.Measure.projectOntoAxis (pt3, pt1, vLine, v);
|
| return mp.addXPt (pt3);
|
| }var r = JS.SV.fValue (args[3]);
|
| var ptCenter = JU.P3.newP (pt3);
|
| JU.Measure.projectOntoAxis (pt3, pt1, vLine, v);
|
| var d = ptCenter.distance (pt3);
|
| var l = new JU.Lst ();
|
| if (d == r) {
|
| l.addLast (pt3);
|
| } else if (d < r) {
|
| d = Math.sqrt (r * r - d * d);
|
| v.scaleAdd2 (d, vLine, pt3);
|
| l.addLast (JU.P3.newP (v));
|
| v.scaleAdd2 (-d, vLine, pt3);
|
| l.addLast (JU.P3.newP (v));
|
| }return mp.addXList (l);
|
| }
|
| switch (args[0].tok) {
|
| case 2:
|
| case 3:
|
| if (args.length == 3) {
|
| var r = JS.SV.fValue (args[0]);
|
| var theta = JS.SV.fValue (args[1]);
|
| var phi = JS.SV.fValue (args[2]);
|
| norm = JU.V3.new3 (0, 0, 1);
|
| pt2 = JU.P3.new3 (0, 1, 0);
|
| var q = JU.Quat.newVA (pt2, phi);
|
| q.getMatrix ().rotate (norm);
|
| pt2.set (0, 0, 1);
|
| q = JU.Quat.newVA (pt2, theta);
|
| q.getMatrix ().rotate (norm);
|
| pt2.setT (norm);
|
| pt2.scale (r);
|
| plane = new JU.P4 ();
|
| JU.Measure.getPlaneThroughPoint (pt2, norm, plane);
|
| return mp.addXPt4 (plane);
|
| }break;
|
| case 10:
|
| case 8:
|
| pt1 = mp.ptValue (args[0], null);
|
| pt2 = mp.ptValue (args[1], null);
|
| if (pt2 == null) return false;
|
| pt3 = (args.length > 2 && (args[2].tok == 10 || args[2].tok == 8) ? mp.ptValue (args[2], null) : null);
|
| norm = JU.V3.newV (pt2);
|
| if (pt3 == null) {
|
| plane = new JU.P4 ();
|
| if (args.length == 2 || args[2].tok != 2 && args[2].tok != 3 && !args[2].asBoolean ()) {
|
| pt3 = JU.P3.newP (pt1);
|
| pt3.add (pt2);
|
| pt3.scale (0.5);
|
| norm.sub (pt1);
|
| norm.normalize ();
|
| } else if (args[2].tok == 1073742335) {
|
| pt3 = pt1;
|
| } else {
|
| norm.sub (pt1);
|
| pt3 = new JU.P3 ();
|
| pt3.scaleAdd2 (args[2].asFloat (), norm, pt1);
|
| }JU.Measure.getPlaneThroughPoint (pt3, norm, plane);
|
| return mp.addXPt4 (plane);
|
| }var vAB = new JU.V3 ();
|
| var ptref = (args.length == 4 ? mp.ptValue (args[3], null) : null);
|
| var nd = JU.Measure.getDirectedNormalThroughPoints (pt1, pt2, pt3, ptref, norm, vAB);
|
| return mp.addXPt4 (JU.P4.new4 (norm.x, norm.y, norm.z, nd));
|
| }
|
| }
|
| if (args.length != 4) return false;
|
| var x = JS.SV.fValue (args[0]);
|
| var y = JS.SV.fValue (args[1]);
|
| var z = JS.SV.fValue (args[2]);
|
| var w = JS.SV.fValue (args[3]);
|
| return mp.addXPt4 (JU.P4.new4 (x, y, z, w));
|
| }, "JS.ScriptMathProcessor,~A,~N");
|
| Clazz_defineMethod (c$, "evaluatePoint",
|
| function (mp, args) {
|
| switch (args.length) {
|
| default:
|
| return false;
|
| case 1:
|
| if (args[0].tok == 3 || args[0].tok == 2) return mp.addXInt (args[0].asInt ());
|
| var s = JS.SV.sValue (args[0]);
|
| if (args[0].tok == 7) s = "{" + s + "}";
|
| var pt = JU.Escape.uP (s);
|
| return (Clazz_instanceOf (pt, JU.P3) ? mp.addXPt (pt) : mp.addXStr ("" + pt));
|
| case 2:
|
| var pt3;
|
| switch (args[1].tok) {
|
| case 1073742334:
|
| case 1073742335:
|
| switch (args[0].tok) {
|
| case 8:
|
| pt3 = JU.P3.newP (args[0].value);
|
| break;
|
| case 10:
|
| pt3 = this.vwr.ms.getAtomSetCenter (args[0].value);
|
| break;
|
| default:
|
| return false;
|
| }
|
| if (args[1].tok == 1073742335) {
|
| this.vwr.tm.transformPt3f (pt3, pt3);
|
| pt3.y = this.vwr.tm.height - pt3.y;
|
| if (this.vwr.antialiased) pt3.scale (0.5);
|
| } else {
|
| if (this.vwr.antialiased) pt3.scale (2);
|
| pt3.y = this.vwr.tm.height - pt3.y;
|
| this.vwr.tm.unTransformPoint (pt3, pt3);
|
| }break;
|
| case 8:
|
| var sv = args[0].getList ();
|
| if (sv == null || sv.size () != 4) return false;
|
| var pt1 = JS.SV.ptValue (args[1]);
|
| pt3 = JU.P3.newP (JS.SV.ptValue (sv.get (0)));
|
| pt3.scaleAdd2 (pt1.x, JS.SV.ptValue (sv.get (1)), pt3);
|
| pt3.scaleAdd2 (pt1.y, JS.SV.ptValue (sv.get (2)), pt3);
|
| pt3.scaleAdd2 (pt1.z, JS.SV.ptValue (sv.get (3)), pt3);
|
| break;
|
| default:
|
| return false;
|
| }
|
| return mp.addXPt (pt3);
|
| case 3:
|
| return mp.addXPt (JU.P3.new3 (args[0].asFloat (), args[1].asFloat (), args[2].asFloat ()));
|
| case 4:
|
| return mp.addXPt4 (JU.P4.new4 (args[0].asFloat (), args[1].asFloat (), args[2].asFloat (), args[3].asFloat ()));
|
| }
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluatePrompt",
|
| function (mp, args) {
|
| if (args.length != 1 && args.length != 2 && args.length != 3) return false;
|
| var label = JS.SV.sValue (args[0]);
|
| var buttonArray = (args.length > 1 && args[1].tok == 7 ? JS.SV.strListValue (args[1]) : null);
|
| var asButtons = (buttonArray != null || args.length == 1 || args.length == 3 && args[2].asBoolean ());
|
| var input = (buttonArray != null ? null : args.length >= 2 ? JS.SV.sValue (args[1]) : "OK");
|
| var s = "" + this.vwr.prompt (label, input, buttonArray, asButtons);
|
| return (asButtons && buttonArray != null ? mp.addXInt (Integer.parseInt (s) + 1) : mp.addXStr (s));
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateQuaternion",
|
| function (mp, args, tok) {
|
| var pt0 = null;
|
| var nArgs = args.length;
|
| var nMax = 2147483647;
|
| var isRelative = false;
|
| if (tok == 134221850) {
|
| if (nArgs > 1 && args[nArgs - 1].tok == 4 && (args[nArgs - 1].value).equalsIgnoreCase ("relative")) {
|
| nArgs--;
|
| isRelative = true;
|
| }if (nArgs > 1 && args[nArgs - 1].tok == 2 && args[0].tok == 10) {
|
| nMax = args[nArgs - 1].asInt ();
|
| if (nMax <= 0) nMax = 2147483646;
|
| nArgs--;
|
| }}switch (nArgs) {
|
| case 0:
|
| case 1:
|
| case 4:
|
| break;
|
| case 2:
|
| if (tok == 134221850) {
|
| if (args[0].tok == 7 && (args[1].tok == 7 || args[1].tok == 1073742335)) break;
|
| if (args[0].tok == 10 && (args[1].tok == 2 || args[1].tok == 10)) break;
|
| }if ((pt0 = mp.ptValue (args[0], null)) == null || tok != 134221850 && args[1].tok == 8) return false;
|
| break;
|
| case 3:
|
| if (tok != 134221850) return false;
|
| if (args[0].tok == 9) {
|
| if (args[2].tok != 8 && args[2].tok != 10) return false;
|
| break;
|
| }for (var i = 0; i < 3; i++) if (args[i].tok != 8 && args[i].tok != 10) return false;
|
|
|
| break;
|
| default:
|
| return false;
|
| }
|
| var q = null;
|
| var qs = null;
|
| var p4 = null;
|
| switch (nArgs) {
|
| case 0:
|
| return mp.addXPt4 (this.vwr.tm.getRotationQ ().toPoint4f ());
|
| case 1:
|
| default:
|
| if (tok == 134221850 && args[0].tok == 7) {
|
| var data1 = this.e.getQuaternionArray (args[0].getList (), 1073742001);
|
| var mean = JU.Quat.sphereMean (data1, null, 0.0001);
|
| q = (Clazz_instanceOf (mean, JU.Quat) ? mean : null);
|
| break;
|
| } else if (tok == 134221850 && args[0].tok == 10) {
|
| qs = this.vwr.getAtomGroupQuaternions (args[0].value, nMax);
|
| } else if (args[0].tok == 11) {
|
| q = JU.Quat.newM (args[0].value);
|
| } else if (args[0].tok == 9) {
|
| p4 = args[0].value;
|
| } else {
|
| var s = JS.SV.sValue (args[0]);
|
| var v = JU.Escape.uP (s.equalsIgnoreCase ("best") ? this.vwr.getOrientationText (1073741864, "best", null).toString () : s);
|
| if (!(Clazz_instanceOf (v, JU.P4))) return false;
|
| p4 = v;
|
| }if (tok == 134217731) q = JU.Quat.newVA (JU.P3.new3 (p4.x, p4.y, p4.z), p4.w);
|
| break;
|
| case 2:
|
| if (tok == 134221850) {
|
| if (args[0].tok == 7 && args[1].tok == 7) {
|
| var data1 = this.e.getQuaternionArray (args[0].getList (), 1073742001);
|
| var data2 = this.e.getQuaternionArray (args[1].getList (), 1073742001);
|
| qs = JU.Quat.div (data2, data1, nMax, isRelative);
|
| break;
|
| }if (args[0].tok == 7 && args[1].tok == 1073742335) {
|
| var data1 = this.e.getQuaternionArray (args[0].getList (), 1073742001);
|
| var stddev = Clazz_newFloatArray (1, 0);
|
| JU.Quat.sphereMean (data1, stddev, 0.0001);
|
| return mp.addXFloat (stddev[0]);
|
| }if (args[0].tok == 10 && args[1].tok == 10) {
|
| var data1 = this.vwr.getAtomGroupQuaternions (args[0].value, 2147483647);
|
| var data2 = this.vwr.getAtomGroupQuaternions (args[1].value, 2147483647);
|
| qs = JU.Quat.div (data2, data1, nMax, isRelative);
|
| break;
|
| }}var pt1 = mp.ptValue (args[1], null);
|
| p4 = mp.planeValue (args[0]);
|
| if (pt1 != null) q = JU.Quat.getQuaternionFrame (JU.P3.new3 (0, 0, 0), pt0, pt1);
|
| else q = JU.Quat.newVA (pt0, JS.SV.fValue (args[1]));
|
| break;
|
| case 3:
|
| if (args[0].tok == 9) {
|
| var pt = (args[2].tok == 8 ? args[2].value : this.vwr.ms.getAtomSetCenter (args[2].value));
|
| return mp.addXStr (JU.Escape.drawQuat (JU.Quat.newP4 (args[0].value), "q", JS.SV.sValue (args[1]), pt, 1));
|
| }var pts = new Array (3);
|
| for (var i = 0; i < 3; i++) pts[i] = (args[i].tok == 8 ? args[i].value : this.vwr.ms.getAtomSetCenter (args[i].value));
|
|
|
| q = JU.Quat.getQuaternionFrame (pts[0], pts[1], pts[2]);
|
| break;
|
| case 4:
|
| if (tok == 134221850) p4 = JU.P4.new4 (JS.SV.fValue (args[1]), JS.SV.fValue (args[2]), JS.SV.fValue (args[3]), JS.SV.fValue (args[0]));
|
| else q = JU.Quat.newVA (JU.P3.new3 (JS.SV.fValue (args[0]), JS.SV.fValue (args[1]), JS.SV.fValue (args[2])), JS.SV.fValue (args[3]));
|
| break;
|
| }
|
| if (qs != null) {
|
| if (nMax != 2147483647) {
|
| var list = new JU.Lst ();
|
| for (var i = 0; i < qs.length; i++) list.addLast (qs[i].toPoint4f ());
|
|
|
| return mp.addXList (list);
|
| }q = (qs.length > 0 ? qs[0] : null);
|
| }return mp.addXPt4 ((q == null ? JU.Quat.newP4 (p4) : q).toPoint4f ());
|
| }, "JS.ScriptMathProcessor,~A,~N");
|
| Clazz_defineMethod (c$, "evaluateRandom",
|
| function (mp, args) {
|
| if (args.length > 3) return false;
|
| if (this.rand == null) this.rand = new java.util.Random ();
|
| var lower = 0;
|
| var upper = 1;
|
| switch (args.length) {
|
| case 3:
|
| this.rand.setSeed (Clazz_floatToInt (JS.SV.fValue (args[2])));
|
| case 2:
|
| upper = JS.SV.fValue (args[1]);
|
| case 1:
|
| lower = JS.SV.fValue (args[0]);
|
| case 0:
|
| break;
|
| default:
|
| return false;
|
| }
|
| return mp.addXFloat ((this.rand.nextFloat () * (upper - lower)) + lower);
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateRowCol",
|
| function (mp, args, tok) {
|
| if (args.length != 1) return false;
|
| var n = args[0].asInt () - 1;
|
| var x1 = mp.getX ();
|
| var f;
|
| switch (x1.tok) {
|
| case 11:
|
| if (n < 0 || n > 2) return false;
|
| var m = x1.value;
|
| switch (tok) {
|
| case 1275068935:
|
| f = Clazz_newFloatArray (3, 0);
|
| m.getRow (n, f);
|
| return mp.addXAF (f);
|
| case 1275068934:
|
| default:
|
| f = Clazz_newFloatArray (3, 0);
|
| m.getColumn (n, f);
|
| return mp.addXAF (f);
|
| }
|
| case 12:
|
| if (n < 0 || n > 2) return false;
|
| var m4 = x1.value;
|
| switch (tok) {
|
| case 1275068935:
|
| f = Clazz_newFloatArray (4, 0);
|
| m4.getRow (n, f);
|
| return mp.addXAF (f);
|
| case 1275068934:
|
| default:
|
| f = Clazz_newFloatArray (4, 0);
|
| m4.getColumn (n, f);
|
| return mp.addXAF (f);
|
| }
|
| case 7:
|
| var l1 = x1.getList ();
|
| var l2 = new JU.Lst ();
|
| for (var i = 0, len = l1.size (); i < len; i++) {
|
| var l3 = l1.get (i).getList ();
|
| if (l3 == null) return mp.addXStr ("");
|
| l2.addLast (n < l3.size () ? l3.get (n) : JS.SV.newS (""));
|
| }
|
| return mp.addXList (l2);
|
| }
|
| return false;
|
| }, "JS.ScriptMathProcessor,~A,~N");
|
| Clazz_defineMethod (c$, "evaluateIn",
|
| function (mp, args) {
|
| var x1 = mp.getX ();
|
| switch (args.length) {
|
| case 1:
|
| var lst = args[0].getList ();
|
| if (lst != null) for (var i = 0, n = lst.size (); i < n; i++) if (JS.SV.areEqual (x1, lst.get (i))) return mp.addXInt (i + 1);
|
|
|
| break;
|
| default:
|
| for (var i = 0; i < args.length; i++) if (JS.SV.areEqual (x1, args[i])) return mp.addXInt (i + 1);
|
|
|
| break;
|
| }
|
| return mp.addXInt (0);
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateReplace",
|
| function (mp, args) {
|
| var isAll = false;
|
| var sFind;
|
| var sReplace;
|
| switch (args.length) {
|
| case 0:
|
| isAll = true;
|
| sFind = sReplace = null;
|
| break;
|
| case 3:
|
| isAll = JS.SV.bValue (args[2]);
|
| case 2:
|
| sFind = JS.SV.sValue (args[0]);
|
| sReplace = JS.SV.sValue (args[1]);
|
| break;
|
| default:
|
| return false;
|
| }
|
| var x = mp.getX ();
|
| if (x.tok == 7) {
|
| var list = JS.SV.strListValue (x);
|
| var l = new Array (list.length);
|
| for (var i = list.length; --i >= 0; ) l[i] = (sFind == null ? JU.PT.clean (list[i]) : isAll ? JU.PT.replaceAllCharacters (list[i], sFind, sReplace) : JU.PT.rep (list[i], sFind, sReplace));
|
|
|
| return mp.addXAS (l);
|
| }var s = JS.SV.sValue (x);
|
| return mp.addXStr (sFind == null ? JU.PT.clean (s) : isAll ? JU.PT.replaceAllCharacters (s, sFind, sReplace) : JU.PT.rep (s, sFind, sReplace));
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateScript",
|
| function (mp, args, tok) {
|
| if ((tok == 134222350 || tok == 134238732) && args.length != 1 || args.length == 0) return false;
|
| var s = JS.SV.sValue (args[0]);
|
| var sb = new JU.SB ();
|
| switch (tok) {
|
| case 134218759:
|
| return (args.length == 2 ? s.equalsIgnoreCase ("JSON") && mp.addXObj (this.vwr.parseJSONMap (JS.SV.sValue (args[1]))) : mp.addXObj (this.vwr.evaluateExpressionAsVariable (s)));
|
| case 134222850:
|
| var appID = (args.length == 2 ? JS.SV.sValue (args[1]) : ".");
|
| if (!appID.equals (".")) sb.append (this.vwr.jsEval (appID + "\1" + s));
|
| if (appID.equals (".") || appID.equals ("*")) this.e.runScriptBuffer (s, sb, true);
|
| break;
|
| case 134222350:
|
| this.e.runScriptBuffer ("show " + s, sb, true);
|
| break;
|
| case 134238732:
|
| return mp.addX (this.vwr.jsEvalSV (s));
|
| }
|
| s = sb.toString ();
|
| var f;
|
| return (Float.isNaN (f = JU.PT.parseFloatStrict (s)) ? mp.addXStr (s) : s.indexOf (".") >= 0 ? mp.addXFloat (f) : mp.addXInt (JU.PT.parseInt (s)));
|
| }, "JS.ScriptMathProcessor,~A,~N");
|
| Clazz_defineMethod (c$, "evaluateSort",
|
| function (mp, args, tok) {
|
| if (args.length > 1) return false;
|
| if (tok == 1275068444) {
|
| if (args.length == 1 && args[0].tok == 4) {
|
| return mp.addX (mp.getX ().sortMapArray (args[0].asString ()));
|
| }var n = (args.length == 0 ? 0 : args[0].asInt ());
|
| return mp.addX (mp.getX ().sortOrReverse (n));
|
| }var x = mp.getX ();
|
| var match = (args.length == 0 ? null : args[0]);
|
| if (x.tok == 4) {
|
| var n = 0;
|
| var s = JS.SV.sValue (x);
|
| if (match == null) return mp.addXInt (0);
|
| var m = JS.SV.sValue (match);
|
| for (var i = 0; i < s.length; i++) {
|
| var pt = s.indexOf (m, i);
|
| if (pt < 0) break;
|
| n++;
|
| i = pt;
|
| }
|
| return mp.addXInt (n);
|
| }var counts = new JU.Lst ();
|
| var last = null;
|
| var count = null;
|
| var xList = JS.SV.getVariable (x.value).sortOrReverse (0).getList ();
|
| if (xList == null) return (match == null ? mp.addXStr ("") : mp.addXInt (0));
|
| for (var i = 0, nLast = xList.size (); i <= nLast; i++) {
|
| var a = (i == nLast ? null : xList.get (i));
|
| if (match != null && a != null && !JS.SV.areEqual (a, match)) continue;
|
| if (JS.SV.areEqual (a, last)) {
|
| count.intValue++;
|
| continue;
|
| } else if (last != null) {
|
| var y = new JU.Lst ();
|
| y.addLast (last);
|
| y.addLast (count);
|
| counts.addLast (JS.SV.getVariableList (y));
|
| }count = JS.SV.newI (1);
|
| last = a;
|
| }
|
| if (match == null) return mp.addX (JS.SV.getVariableList (counts));
|
| if (counts.isEmpty ()) return mp.addXInt (0);
|
| return mp.addX (counts.get (0).getList ().get (1));
|
| }, "JS.ScriptMathProcessor,~A,~N");
|
| Clazz_defineMethod (c$, "evaluateString",
|
| function (mp, tok, args) {
|
| var x = mp.getX ();
|
| var sArg = (args.length > 0 ? JS.SV.sValue (args[0]) : tok == 1275068932 ? "" : "\n");
|
| switch (args.length) {
|
| case 0:
|
| break;
|
| case 1:
|
| if (args[0].tok == 1073742335) {
|
| return mp.addX (JS.SV.getVariable (JU.PT.getTokens (x.asString ())));
|
| }break;
|
| case 2:
|
| if (x.tok == 7) break;
|
| if (tok == 1275069447) {
|
| x = JS.SV.getVariable (JU.PT.split (JU.PT.rep (x.value, "\n\r", "\n").$replace ('\r', '\n'), "\n"));
|
| break;
|
| }default:
|
| return false;
|
| }
|
| if (x.tok == 7 && tok != 1275068932 && (tok != 1275069447 || args.length == 2)) {
|
| mp.addX (x);
|
| return this.evaluateList (mp, tok, args);
|
| }var s = (tok == 1275069447 && x.tok == 10 || tok == 1275068932 && x.tok == 7 ? null : JS.SV.sValue (x));
|
| switch (tok) {
|
| case 1275069447:
|
| if (x.tok == 10) {
|
| var bsSelected = x.value;
|
| var modelCount = this.vwr.ms.mc;
|
| var lst = new JU.Lst ();
|
| for (var i = 0; i < modelCount; i++) {
|
| var bs = this.vwr.getModelUndeletedAtomsBitSet (i);
|
| bs.and (bsSelected);
|
| lst.addLast (JS.SV.getVariable (bs));
|
| }
|
| return mp.addXList (lst);
|
| }return mp.addXAS (JU.PT.split (s, sArg));
|
| case 1275069446:
|
| if (s.length > 0 && s.charAt (s.length - 1) == '\n') s = s.substring (0, s.length - 1);
|
| return mp.addXStr (JU.PT.rep (s, "\n", sArg));
|
| case 1275068932:
|
| if (s != null) return mp.addXStr (JU.PT.trim (s, sArg));
|
| var list = JS.SV.strListValue (x);
|
| for (var i = list.length; --i >= 0; ) list[i] = JU.PT.trim (list[i], sArg);
|
|
|
| return mp.addXAS (list);
|
| }
|
| return mp.addXStr ("");
|
| }, "JS.ScriptMathProcessor,~N,~A");
|
| Clazz_defineMethod (c$, "evaluateSubstructure",
|
| function (mp, args, tok, isSelector) {
|
| if (args.length == 0 || isSelector && args.length > 1) return false;
|
| var bs = new JU.BS ();
|
| var pattern = JS.SV.sValue (args[0]);
|
| if (pattern.length > 0) try {
|
| var bsSelected = (isSelector ? mp.getX ().value : args.length == 2 && args[1].tok == 10 ? args[1].value : null);
|
| bs = this.vwr.getSmilesMatcher ().getSubstructureSet (pattern, this.vwr.ms.at, this.vwr.ms.ac, bsSelected, (tok == 134218757 ? 1 : 2));
|
| } catch (ex) {
|
| if (Clazz_exceptionOf (ex, Exception)) {
|
| this.e.evalError (ex.getMessage (), null);
|
| } else {
|
| throw ex;
|
| }
|
| }
|
| return mp.addXBs (bs);
|
| }, "JS.ScriptMathProcessor,~A,~N,~B");
|
| Clazz_defineMethod (c$, "evaluateSymop",
|
| function (mp, args, haveBitSet) {
|
| var x1 = (haveBitSet ? mp.getX () : null);
|
| if (x1 != null && x1.tok != 10) return false;
|
| var bsAtoms = (x1 == null ? null : x1.value);
|
| if (bsAtoms == null && this.vwr.ms.mc == 1) bsAtoms = this.vwr.getModelUndeletedAtomsBitSet (0);
|
| var narg = args.length;
|
| if (narg == 0) {
|
| if (bsAtoms.isEmpty ()) return false;
|
| var ops = JU.PT.split (JU.PT.trim (this.vwr.getSymTemp ().getSpaceGroupInfo (this.vwr.ms, null, this.vwr.ms.at[bsAtoms.nextSetBit (0)].mi, false).get ("symmetryInfo"), "\n"), "\n");
|
| var lst = new JU.Lst ();
|
| for (var i = 0, n = ops.length; i < n; i++) lst.addLast (JU.PT.split (ops[i], "\t"));
|
|
|
| return mp.addXList (lst);
|
| }var xyz = null;
|
| var iOp = -2147483648;
|
| var apt = 0;
|
| switch (args[0].tok) {
|
| case 4:
|
| xyz = JS.SV.sValue (args[0]);
|
| apt++;
|
| break;
|
| case 12:
|
| xyz = args[0].escape ();
|
| apt++;
|
| break;
|
| case 2:
|
| iOp = args[0].asInt ();
|
| apt++;
|
| break;
|
| }
|
| if (bsAtoms == null) {
|
| if (apt < narg && args[apt].tok == 10) (bsAtoms = new JU.BS ()).or (args[apt].value);
|
| if (apt + 1 < narg && args[apt + 1].tok == 10) (bsAtoms == null ? (bsAtoms = new JU.BS ()) : bsAtoms).or (args[apt + 1].value);
|
| }var pt1 = null;
|
| var pt2 = null;
|
| if ((pt1 = (narg > apt ? mp.ptValue (args[apt], bsAtoms) : null)) != null) apt++;
|
| if ((pt2 = (narg > apt ? mp.ptValue (args[apt], bsAtoms) : null)) != null) apt++;
|
| var nth = (pt2 != null && args.length > apt && iOp == -2147483648 && args[apt].tok == 2 ? args[apt].intValue : 0);
|
| if (nth > 0) apt++;
|
| if (iOp == -2147483648) iOp = 0;
|
| var desc = (narg == apt ? (pt2 != null ? "all" : pt1 != null ? "point" : "matrix") : JS.SV.sValue (args[apt++]).toLowerCase ());
|
| return (bsAtoms != null && !bsAtoms.isEmpty () && apt == args.length && mp.addXObj (this.vwr.getSymTemp ().getSymmetryInfoAtom (this.vwr.ms, bsAtoms.nextSetBit (0), xyz, iOp, pt1, pt2, desc, 0, 0, nth)));
|
| }, "JS.ScriptMathProcessor,~A,~B");
|
| Clazz_defineMethod (c$, "evaluateTensor",
|
| function (mp, args) {
|
| var x = mp.getX ();
|
| if (args.length > 2 || x.tok != 10) return false;
|
| var bs = x.value;
|
| var tensorType = (args.length == 0 ? null : JS.SV.sValue (args[0]).toLowerCase ());
|
| var calc = this.vwr.getNMRCalculation ();
|
| if ("unique".equals (tensorType)) return mp.addXBs (calc.getUniqueTensorSet (bs));
|
| var infoType = (args.length < 2 ? null : JS.SV.sValue (args[1]).toLowerCase ());
|
| return mp.addXList (calc.getTensorInfo (tensorType, infoType, bs));
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateUserFunction",
|
| function (mp, name, args, tok, isSelector) {
|
| var x1 = null;
|
| if (isSelector) {
|
| x1 = mp.getX ();
|
| switch (x1.tok) {
|
| case 10:
|
| break;
|
| case 6:
|
| if (args.length > 0) return false;
|
| x1 = x1.getMap ().get (name);
|
| return (x1 == null ? mp.addXStr ("") : mp.addX (x1));
|
| default:
|
| return false;
|
| }
|
| }name = name.toLowerCase ();
|
| mp.wasX = false;
|
| var params = new JU.Lst ();
|
| for (var i = 0; i < args.length; i++) {
|
| params.addLast (args[i]);
|
| }
|
| if (isSelector) {
|
| return mp.addXObj (this.e.getBitsetProperty (x1.value, null, tok, null, null, x1.value, Clazz_newArray (-1, [name, params]), false, x1.index, false));
|
| }var $var = this.e.getUserFunctionResult (name, params, null);
|
| return ($var == null ? false : mp.addX ($var));
|
| }, "JS.ScriptMathProcessor,~S,~A,~N,~B");
|
| Clazz_defineMethod (c$, "evaluateWithin",
|
| function (mp, args) {
|
| if (args.length < 1 || args.length > 5) return false;
|
| var len = args.length;
|
| if (len == 1 && args[0].tok == 10) return mp.addX (args[0]);
|
| var distance = 0;
|
| var withinSpec = args[0].value;
|
| var withinStr = "" + withinSpec;
|
| var tok = args[0].tok;
|
| if (tok == 4) tok = JS.T.getTokFromName (withinStr);
|
| var ms = this.vwr.ms;
|
| var isVdw = false;
|
| var isWithinModelSet = false;
|
| var isWithinGroup = false;
|
| var isDistance = false;
|
| var rd = null;
|
| switch (tok) {
|
| case 1648363544:
|
| isVdw = true;
|
| withinSpec = null;
|
| case 3:
|
| case 2:
|
| isDistance = true;
|
| if (len < 2 || len == 3 && args[1].tok == 7 && args[2].tok != 7) return false;
|
| distance = (isVdw ? 100 : JS.SV.fValue (args[0]));
|
| switch (tok = args[1].tok) {
|
| case 1073742335:
|
| case 1073742334:
|
| isWithinModelSet = args[1].asBoolean ();
|
| if (len > 2 && JS.SV.sValue (args[2]).equalsIgnoreCase ("unitcell")) tok = 1814695966;
|
| len = 0;
|
| break;
|
| case 4:
|
| var s = JS.SV.sValue (args[1]);
|
| if (s.startsWith ("$")) return mp.addXBs (this.getAtomsNearSurface (distance, s.substring (1)));
|
| if (s.equalsIgnoreCase ("group")) {
|
| isWithinGroup = true;
|
| tok = 1086324742;
|
| } else if (s.equalsIgnoreCase ("vanderwaals") || s.equalsIgnoreCase ("vdw")) {
|
| withinSpec = null;
|
| isVdw = true;
|
| tok = 1648363544;
|
| } else if (s.equalsIgnoreCase ("unitcell")) {
|
| tok = 1814695966;
|
| } else {
|
| return false;
|
| }break;
|
| }
|
| break;
|
| case 7:
|
| if (len == 1) {
|
| withinSpec = args[0].asString ();
|
| tok = 0;
|
| }break;
|
| case 1073742328:
|
| return (len == 3 && Clazz_instanceOf (args[1].value, JU.BS) && Clazz_instanceOf (args[2].value, JU.BS) && mp.addXBs (this.vwr.getBranchBitSet ((args[2].value).nextSetBit (0), (args[1].value).nextSetBit (0), true)));
|
| case 134218757:
|
| case 1237320707:
|
| case 134218756:
|
| var bsSelected = null;
|
| var isOK = true;
|
| switch (len) {
|
| case 2:
|
| break;
|
| case 3:
|
| isOK = (args[2].tok == 10);
|
| if (isOK) bsSelected = args[2].value;
|
| break;
|
| default:
|
| isOK = false;
|
| }
|
| if (!isOK) this.e.invArg ();
|
| return mp.addXObj (this.e.getSmilesExt ().getSmilesMatches (JS.SV.sValue (args[1]), null, bsSelected, null, tok == 134218756 ? 2 : 1, mp.asBitSet, false));
|
| }
|
| if (Clazz_instanceOf (withinSpec, String)) {
|
| if (tok == 0) {
|
| tok = 1073742362;
|
| if (len > 2) return false;
|
| len = 2;
|
| }} else if (!isDistance) {
|
| return false;
|
| }switch (len) {
|
| case 1:
|
| switch (tok) {
|
| case 136314895:
|
| case 2097184:
|
| case 1678381065:
|
| return mp.addXBs (ms.getAtoms (tok, null));
|
| case 1073741863:
|
| return mp.addXBs (ms.getAtoms (tok, ""));
|
| case 1073742362:
|
| return mp.addXBs (ms.getAtoms (1086324744, withinStr));
|
| }
|
| return false;
|
| case 2:
|
| switch (tok) {
|
| case 1073742362:
|
| tok = 1086324744;
|
| break;
|
| case 1073741824:
|
| case 1086326786:
|
| case 1086326785:
|
| case 1073741863:
|
| case 1086324744:
|
| case 1111490587:
|
| case 1073742128:
|
| case 1073741925:
|
| case 1073742189:
|
| return mp.addXBs (this.vwr.ms.getAtoms (tok, JS.SV.sValue (args[args.length - 1])));
|
| }
|
| break;
|
| case 3:
|
| switch (tok) {
|
| case 1073742335:
|
| case 1073742334:
|
| case 1086324742:
|
| case 1648363544:
|
| case 1814695966:
|
| case 134217750:
|
| case 134219265:
|
| case 1073742329:
|
| case 8:
|
| case 7:
|
| break;
|
| case 1086324744:
|
| withinStr = JS.SV.sValue (args[2]);
|
| break;
|
| default:
|
| return false;
|
| }
|
| break;
|
| }
|
| var plane = null;
|
| var pt = null;
|
| var pts1 = null;
|
| var last = args.length - 1;
|
| switch (args[last].tok) {
|
| case 9:
|
| plane = args[last].value;
|
| break;
|
| case 8:
|
| pt = args[last].value;
|
| if (JS.SV.sValue (args[1]).equalsIgnoreCase ("hkl")) plane = this.e.getHklPlane (pt);
|
| break;
|
| case 7:
|
| pts1 = (last == 2 && args[1].tok == 7 ? args[1].getList () : null);
|
| pt = (last == 2 ? JS.SV.ptValue (args[1]) : last == 1 ? JU.P3.new3 (NaN, 0, 0) : null);
|
| break;
|
| }
|
| if (plane != null) return mp.addXBs (ms.getAtomsNearPlane (distance, plane));
|
| var bs = (args[last].tok == 10 ? args[last].value : null);
|
| if (last > 0 && pt == null && pts1 == null && bs == null) return false;
|
| if (tok == 1814695966) {
|
| var asMap = isWithinModelSet;
|
| return ((bs != null || pt != null) && mp.addXObj (this.vwr.ms.getUnitCellPointsWithin (distance, bs, pt, asMap)));
|
| }if (pt != null || pts1 != null) {
|
| if (args[last].tok == 7) {
|
| var sv = args[last].getList ();
|
| var ap3 = new Array (sv.size ());
|
| for (var i = ap3.length; --i >= 0; ) ap3[i] = JS.SV.ptValue (sv.get (i));
|
|
|
| var ap31 = null;
|
| if (pts1 != null) {
|
| ap31 = new Array (pts1.size ());
|
| for (var i = ap31.length; --i >= 0; ) ap31[i] = JS.SV.ptValue (pts1.get (i));
|
|
|
| }var ret = new Array (1);
|
| switch (J.bspt.PointIterator.withinDistPoints (distance, pt, ap3, ap31, ret)) {
|
| case 134217751:
|
| return mp.addXPt (ret[0]);
|
| case 1073742001:
|
| return mp.addXList (ret[0]);
|
| case 1275068418:
|
| return mp.addXAI (ret[0]);
|
| case 4:
|
| return mp.addXStr (ret[0]);
|
| default:
|
| return false;
|
| }
|
| }return mp.addXBs (this.vwr.getAtomsNearPt (distance, pt));
|
| }if (tok == 1086324744) return mp.addXBs (this.vwr.ms.getSequenceBits (withinStr, bs, new JU.BS ()));
|
| if (bs == null) bs = new JU.BS ();
|
| if (!isDistance) return mp.addXBs (this.vwr.ms.getAtoms (tok, bs));
|
| if (isWithinGroup) return mp.addXBs (this.vwr.getGroupsWithin (Clazz_floatToInt (distance), bs));
|
| if (isVdw) {
|
| rd = new J.atomdata.RadiusData (null, (distance > 10 ? distance / 100 : distance), (distance > 10 ? J.atomdata.RadiusData.EnumType.FACTOR : J.atomdata.RadiusData.EnumType.OFFSET), J.c.VDW.AUTO);
|
| if (distance < 0) distance = 0;
|
| }return mp.addXBs (this.vwr.ms.getAtomsWithinRadius (distance, bs, isWithinModelSet, rd));
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "evaluateWrite",
|
| function (mp, args) {
|
| switch (args.length) {
|
| case 0:
|
| return false;
|
| case 1:
|
| var type = args[0].asString ().toUpperCase ();
|
| if (type.equals ("PNGJ")) {
|
| return mp.addXMap (this.vwr.fm.getFileAsMap (null, "PNGJ"));
|
| }if (JU.PT.isOneOf (type, ";ZIP;ZIPALL;JMOL;")) {
|
| var params = new java.util.Hashtable ();
|
| var oc = new JU.OC ();
|
| params.put ("outputChannel", oc);
|
| this.vwr.createZip (null, type, params);
|
| var bis = JU.Rdr.getBIS (oc.toByteArray ());
|
| params = new java.util.Hashtable ();
|
| this.vwr.getJzt ().readFileAsMap (bis, params, null);
|
| return mp.addXMap (params);
|
| }break;
|
| }
|
| return mp.addXStr (this.e.getCmdExt ().dispatch (134221856, true, args));
|
| }, "JS.ScriptMathProcessor,~A");
|
| Clazz_defineMethod (c$, "getAtomsNearSurface",
|
| function (distance, surfaceId) {
|
| var data = Clazz_newArray (-1, [surfaceId, null, null]);
|
| if (this.e.getShapePropertyData (24, "getVertices", data)) return this.getAtomsNearPts (distance, data[1], data[2]);
|
| data[1] = Integer.$valueOf (0);
|
| data[2] = Integer.$valueOf (-1);
|
| if (this.e.getShapePropertyData (22, "getCenter", data)) return this.vwr.getAtomsNearPt (distance, data[2]);
|
| data[1] = Float.$valueOf (distance);
|
| if (this.e.getShapePropertyData (21, "getAtomsWithin", data)) return data[2];
|
| return new JU.BS ();
|
| }, "~N,~S");
|
| Clazz_defineMethod (c$, "getAtomsNearPts",
|
| function (distance, points, bsInclude) {
|
| var bsResult = new JU.BS ();
|
| if (points.length == 0 || bsInclude != null && bsInclude.isEmpty ()) return bsResult;
|
| if (bsInclude == null) bsInclude = JU.BSUtil.setAll (points.length);
|
| var at = this.vwr.ms.at;
|
| for (var i = this.vwr.ms.ac; --i >= 0; ) {
|
| var atom = at[i];
|
| for (var j = bsInclude.nextSetBit (0); j >= 0; j = bsInclude.nextSetBit (j + 1)) if (atom.distance (points[j]) < distance) {
|
| bsResult.set (i);
|
| break;
|
| }
|
| }
|
| return bsResult;
|
| }, "~N,~A,JU.BS");
|
| Clazz_defineMethod (c$, "getMinMax",
|
| function (floatOrSVArray, tok) {
|
| var data = null;
|
| var sv = null;
|
| var ndata = 0;
|
| var htPivot = null;
|
| while (true) {
|
| if (JU.AU.isAF (floatOrSVArray)) {
|
| if (tok == 1140850707) return "NaN";
|
| data = floatOrSVArray;
|
| ndata = data.length;
|
| if (ndata == 0) break;
|
| } else if (Clazz_instanceOf (floatOrSVArray, JU.Lst)) {
|
| sv = floatOrSVArray;
|
| ndata = sv.size ();
|
| if (ndata == 0) {
|
| if (tok != 1140850707) break;
|
| } else {
|
| var sv0 = sv.get (0);
|
| if (sv0.tok == 8) return this.getMinMaxPoint (sv, tok);
|
| if (sv0.tok == 4 && (sv0.value).startsWith ("{")) {
|
| var pt = JS.SV.ptValue (sv0);
|
| if (Clazz_instanceOf (pt, JU.P3)) return this.getMinMaxPoint (sv, tok);
|
| if (Clazz_instanceOf (pt, JU.P4)) return this.getMinMaxQuaternion (sv, tok);
|
| break;
|
| }}} else {
|
| break;
|
| }var sum;
|
| var minMax;
|
| var isMin = false;
|
| switch (tok) {
|
| case 1140850707:
|
| htPivot = new java.util.Hashtable ();
|
| sum = minMax = 0;
|
| break;
|
| case 32:
|
| isMin = true;
|
| sum = 3.4028235E38;
|
| minMax = 2147483647;
|
| break;
|
| case 64:
|
| sum = -3.4028235E38;
|
| minMax = -2147483647;
|
| break;
|
| default:
|
| sum = minMax = 0;
|
| }
|
| var sum2 = 0;
|
| var n = 0;
|
| var isInt = true;
|
| var isPivot = (tok == 1140850707);
|
| for (var i = ndata; --i >= 0; ) {
|
| var svi = (sv == null ? JS.SV.vF : sv.get (i));
|
| var v = (isPivot ? 1 : data == null ? JS.SV.fValue (svi) : data[i]);
|
| if (Float.isNaN (v)) continue;
|
| n++;
|
| switch (tok) {
|
| case 160:
|
| case 192:
|
| sum2 += (v) * v;
|
| case 128:
|
| case 96:
|
| sum += v;
|
| break;
|
| case 1140850707:
|
| isInt = new Boolean (isInt & (svi.tok == 2)).valueOf ();
|
| var key = svi.asString ();
|
| var ii = htPivot.get (key);
|
| htPivot.put (key, (ii == null ? new Integer (1) : new Integer (ii.intValue () + 1)));
|
| break;
|
| case 32:
|
| case 64:
|
| isInt = new Boolean (isInt & (svi.tok == 2)).valueOf ();
|
| if (isMin == (v < sum)) {
|
| sum = v;
|
| if (isInt) minMax = svi.intValue;
|
| }break;
|
| }
|
| }
|
| if (tok == 1140850707) {
|
| return htPivot;
|
| }if (n == 0) break;
|
| switch (tok) {
|
| case 96:
|
| sum /= n;
|
| break;
|
| case 192:
|
| if (n == 1) break;
|
| sum = Math.sqrt ((sum2 - sum * sum / n) / (n - 1));
|
| break;
|
| case 32:
|
| case 64:
|
| if (isInt) return Integer.$valueOf (minMax);
|
| break;
|
| case 128:
|
| break;
|
| case 160:
|
| sum = sum2;
|
| break;
|
| }
|
| return Float.$valueOf (sum);
|
| }
|
| return "NaN";
|
| }, "~O,~N");
|
| Clazz_defineMethod (c$, "getMinMaxPoint",
|
| function (pointOrSVArray, tok) {
|
| var data = null;
|
| var sv = null;
|
| var ndata = 0;
|
| if (Clazz_instanceOf (pointOrSVArray, Array)) {
|
| data = pointOrSVArray;
|
| ndata = data.length;
|
| } else if (Clazz_instanceOf (pointOrSVArray, JU.Lst)) {
|
| sv = pointOrSVArray;
|
| ndata = sv.size ();
|
| }if (sv == null && data == null) return "NaN";
|
| var result = new JU.P3 ();
|
| var fdata = Clazz_newFloatArray (ndata, 0);
|
| for (var xyz = 0; xyz < 3; xyz++) {
|
| for (var i = 0; i < ndata; i++) {
|
| var pt = (data == null ? JS.SV.ptValue (sv.get (i)) : data[i]);
|
| if (pt == null) return "NaN";
|
| switch (xyz) {
|
| case 0:
|
| fdata[i] = pt.x;
|
| break;
|
| case 1:
|
| fdata[i] = pt.y;
|
| break;
|
| case 2:
|
| fdata[i] = pt.z;
|
| break;
|
| }
|
| }
|
| var f = this.getMinMax (fdata, tok);
|
| if (!(Clazz_instanceOf (f, Number))) return "NaN";
|
| var value = (f).floatValue ();
|
| switch (xyz) {
|
| case 0:
|
| result.x = value;
|
| break;
|
| case 1:
|
| result.y = value;
|
| break;
|
| case 2:
|
| result.z = value;
|
| break;
|
| }
|
| }
|
| return result;
|
| }, "~O,~N");
|
| Clazz_defineMethod (c$, "getMinMaxQuaternion",
|
| function (svData, tok) {
|
| var data;
|
| switch (tok) {
|
| case 32:
|
| case 64:
|
| case 128:
|
| case 160:
|
| return "NaN";
|
| }
|
| while (true) {
|
| data = this.e.getQuaternionArray (svData, 1073742001);
|
| if (data == null) break;
|
| var retStddev = Clazz_newFloatArray (1, 0);
|
| var result = JU.Quat.sphereMean (data, retStddev, 0.0001);
|
| switch (tok) {
|
| case 96:
|
| return result;
|
| case 192:
|
| return Float.$valueOf (retStddev[0]);
|
| }
|
| break;
|
| }
|
| return "NaN";
|
| }, "JU.Lst,~N");
|
| Clazz_defineMethod (c$, "getPatternMatcher",
|
| function () {
|
| return (this.pm == null ? this.pm = J.api.Interface.getUtil ("PatternMatcher", this.e.vwr, "script") : this.pm);
|
| });
|
| Clazz_defineMethod (c$, "opTokenFor",
|
| function (tok) {
|
| switch (tok) {
|
| case 1275069441:
|
| case 1275069446:
|
| return JS.T.tokenPlus;
|
| case 1275068931:
|
| return JS.T.tokenMinus;
|
| case 1275068929:
|
| return JS.T.tokenTimes;
|
| case 1275068930:
|
| return JS.T.tokenMul3;
|
| case 1275068928:
|
| return JS.T.tokenDivide;
|
| }
|
| return null;
|
| }, "~N");
|
| Clazz_defineMethod (c$, "setContactBitSets",
|
| function (bsA, bsB, localOnly, distance, rd, warnMultiModel) {
|
| var withinAllModels;
|
| var bs;
|
| if (bsB == null) {
|
| bsB = JU.BSUtil.setAll (this.vwr.ms.ac);
|
| JU.BSUtil.andNot (bsB, this.vwr.slm.bsDeleted);
|
| bsB.andNot (bsA);
|
| withinAllModels = false;
|
| } else {
|
| bs = JU.BSUtil.copy (bsA);
|
| bs.or (bsB);
|
| var nModels = this.vwr.ms.getModelBS (bs, false).cardinality ();
|
| withinAllModels = (nModels > 1);
|
| if (warnMultiModel && nModels > 1 && !this.e.tQuiet) this.e.showString (J.i18n.GT.$ ("Note: More than one model is involved in this contact!"));
|
| }if (!bsA.equals (bsB)) {
|
| var setBfirst = (!localOnly || bsA.cardinality () < bsB.cardinality ());
|
| if (setBfirst) {
|
| bs = this.vwr.ms.getAtomsWithinRadius (distance, bsA, withinAllModels, (Float.isNaN (distance) ? rd : null));
|
| bsB.and (bs);
|
| }if (localOnly) {
|
| bs = this.vwr.ms.getAtomsWithinRadius (distance, bsB, withinAllModels, (Float.isNaN (distance) ? rd : null));
|
| bsA.and (bs);
|
| if (!setBfirst) {
|
| bs = this.vwr.ms.getAtomsWithinRadius (distance, bsA, withinAllModels, (Float.isNaN (distance) ? rd : null));
|
| bsB.and (bs);
|
| }bs = JU.BSUtil.copy (bsB);
|
| bs.and (bsA);
|
| if (bs.equals (bsA)) bsB.andNot (bsA);
|
| else if (bs.equals (bsB)) bsA.andNot (bsB);
|
| }}return bsB;
|
| }, "JU.BS,JU.BS,~B,~N,J.atomdata.RadiusData,~B");
|
| });
|
| })(Clazz
|
| ,Clazz.getClassName
|
| ,Clazz.newLongArray
|
| ,Clazz.doubleToByte
|
| ,Clazz.doubleToInt
|
| ,Clazz.doubleToLong
|
| ,Clazz.declarePackage
|
| ,Clazz.instanceOf
|
| ,Clazz.load
|
| ,Clazz.instantialize
|
| ,Clazz.decorateAsClass
|
| ,Clazz.floatToInt
|
| ,Clazz.floatToLong
|
| ,Clazz.makeConstructor
|
| ,Clazz.defineEnumConstant
|
| ,Clazz.exceptionOf
|
| ,Clazz.newIntArray
|
| ,Clazz.defineStatics
|
| ,Clazz.newFloatArray
|
| ,Clazz.declareType
|
| ,Clazz.prepareFields
|
| ,Clazz.superConstructor
|
| ,Clazz.newByteArray
|
| ,Clazz.declareInterface
|
| ,Clazz.p0p
|
| ,Clazz.pu$h
|
| ,Clazz.newShortArray
|
| ,Clazz.innerTypeInstance
|
| ,Clazz.isClassDefined
|
| ,Clazz.prepareCallback
|
| ,Clazz.newArray
|
| ,Clazz.castNullAs
|
| ,Clazz.floatToShort
|
| ,Clazz.superCall
|
| ,Clazz.decorateAsType
|
| ,Clazz.newBooleanArray
|
| ,Clazz.newCharArray
|
| ,Clazz.implementOf
|
| ,Clazz.newDoubleArray
|
| ,Clazz.overrideConstructor
|
| ,Clazz.clone
|
| ,Clazz.doubleToShort
|
| ,Clazz.getInheritedLevel
|
| ,Clazz.getParamsType
|
| ,Clazz.isAF
|
| ,Clazz.isAB
|
| ,Clazz.isAI
|
| ,Clazz.isAS
|
| ,Clazz.isASS
|
| ,Clazz.isAP
|
| ,Clazz.isAFloat
|
| ,Clazz.isAII
|
| ,Clazz.isAFF
|
| ,Clazz.isAFFF
|
| ,Clazz.tryToSearchAndExecute
|
| ,Clazz.getStackTrace
|
| ,Clazz.inheritArgs
|
| ,Clazz.alert
|
| ,Clazz.defineMethod
|
| ,Clazz.overrideMethod
|
| ,Clazz.declareAnonymous
|
|
|
| ,Clazz.cloneFinals
|
| );
|
|
|