@datagrok/sequence-translator 0.0.6 → 0.0.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/css/style.css +18 -0
- package/dist/package-test.js +2387 -0
- package/dist/package.js +5151 -0
- package/jest.config.js +33 -0
- package/package.json +21 -5
- package/setup.cmd +1 -1
- package/src/ICDs.ts +3 -0
- package/src/IDPs.ts +3 -0
- package/src/__jest__/remote.test.ts +49 -0
- package/src/__jest__/test-node.ts +96 -0
- package/src/defineAxolabsPattern.ts +2 -8
- package/src/package-test.ts +2 -1
- package/src/package.ts +186 -703
- package/src/salts.ts +2 -0
- package/src/sources.ts +3 -0
- package/src/structures-works/converters.ts +288 -0
- package/src/structures-works/from-monomers.ts +104 -0
- package/src/{map.ts → structures-works/map.ts} +28 -6
- package/src/structures-works/mol-transformations.ts +432 -0
- package/src/structures-works/save-sense-antisense.ts +51 -0
- package/src/structures-works/sequence-codes-tools.ts +252 -0
- package/src/tests/smiles-tests.ts +1 -1
- package/src/users.ts +3 -0
- package/test-SequenceTranslator-c2bbc2b235db-afc0e1c5.html +245 -0
- package/tsconfig.json +2 -1
- package/src/save-sense-antisense.ts +0 -44
|
@@ -0,0 +1,2387 @@
|
|
|
1
|
+
var sequencetranslator_test;
|
|
2
|
+
/******/ (() => { // webpackBootstrap
|
|
3
|
+
/******/ "use strict";
|
|
4
|
+
/******/ var __webpack_modules__ = ({
|
|
5
|
+
|
|
6
|
+
/***/ "./node_modules/@datagrok-libraries/utils/src/test.js":
|
|
7
|
+
/*!************************************************************!*\
|
|
8
|
+
!*** ./node_modules/@datagrok-libraries/utils/src/test.js ***!
|
|
9
|
+
\************************************************************/
|
|
10
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
11
|
+
|
|
12
|
+
__webpack_require__.r(__webpack_exports__);
|
|
13
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
14
|
+
/* harmony export */ "tests": () => (/* binding */ tests),
|
|
15
|
+
/* harmony export */ "currentCategory": () => (/* binding */ currentCategory),
|
|
16
|
+
/* harmony export */ "assure": () => (/* binding */ assure),
|
|
17
|
+
/* harmony export */ "Test": () => (/* binding */ Test),
|
|
18
|
+
/* harmony export */ "test": () => (/* binding */ test),
|
|
19
|
+
/* harmony export */ "assertNoError": () => (/* binding */ assertNoError),
|
|
20
|
+
/* harmony export */ "expect": () => (/* binding */ expect),
|
|
21
|
+
/* harmony export */ "expectFloat": () => (/* binding */ expectFloat),
|
|
22
|
+
/* harmony export */ "category": () => (/* binding */ category),
|
|
23
|
+
/* harmony export */ "before": () => (/* binding */ before),
|
|
24
|
+
/* harmony export */ "after": () => (/* binding */ after),
|
|
25
|
+
/* harmony export */ "runTests": () => (/* binding */ runTests),
|
|
26
|
+
/* harmony export */ "delay": () => (/* binding */ delay)
|
|
27
|
+
/* harmony export */ });
|
|
28
|
+
/* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
|
|
29
|
+
/* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
|
|
30
|
+
var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
31
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
32
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
33
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
34
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
35
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
36
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
let tests = {};
|
|
41
|
+
let currentCategory;
|
|
42
|
+
var assure;
|
|
43
|
+
(function (assure) {
|
|
44
|
+
function notNull(value, name) {
|
|
45
|
+
if (value == null)
|
|
46
|
+
throw `${name == null ? 'Value' : name} not defined`;
|
|
47
|
+
}
|
|
48
|
+
assure.notNull = notNull;
|
|
49
|
+
})(assure || (assure = {}));
|
|
50
|
+
class Test {
|
|
51
|
+
constructor(category, name, test, options) {
|
|
52
|
+
var _a, _b;
|
|
53
|
+
this.category = category;
|
|
54
|
+
this.name = name;
|
|
55
|
+
options !== null && options !== void 0 ? options : (options = {});
|
|
56
|
+
(_a = options.timeout) !== null && _a !== void 0 ? _a : (options.timeout = 30000);
|
|
57
|
+
(_b = options.unhandledExceptionTimeout) !== null && _b !== void 0 ? _b : (options.unhandledExceptionTimeout = 2000);
|
|
58
|
+
this.options = options;
|
|
59
|
+
this.test = () => __awaiter(this, void 0, void 0, function* () {
|
|
60
|
+
return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
|
|
61
|
+
let result = '';
|
|
62
|
+
try {
|
|
63
|
+
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError = '';
|
|
64
|
+
result = yield test();
|
|
65
|
+
}
|
|
66
|
+
catch (e) {
|
|
67
|
+
reject(e);
|
|
68
|
+
}
|
|
69
|
+
if (!(yield assertNoError(options.unhandledExceptionTimeout)))
|
|
70
|
+
reject(`Unhandled exception during test: ${datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError}`);
|
|
71
|
+
resolve(result);
|
|
72
|
+
}));
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
function test(name, test, options) {
|
|
77
|
+
if (tests[currentCategory] == undefined)
|
|
78
|
+
tests[currentCategory] = {};
|
|
79
|
+
if (tests[currentCategory].tests == undefined)
|
|
80
|
+
tests[currentCategory].tests = [];
|
|
81
|
+
tests[currentCategory].tests.push(new Test(currentCategory, name, test, options));
|
|
82
|
+
}
|
|
83
|
+
/** Awaits for a while checking the error status of the platform */
|
|
84
|
+
function assertNoError(ms) {
|
|
85
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
86
|
+
for (let i = 0; i < ms / 500; ++i) {
|
|
87
|
+
yield delay(500);
|
|
88
|
+
if (datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.lastError.length !== 0)
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
return true;
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
/** Tests two objects for equality, throws an exception if they are not equal. */
|
|
95
|
+
function expect(actual, expected) {
|
|
96
|
+
if (actual !== expected)
|
|
97
|
+
throw `Expected "${expected}", got "${actual}"`;
|
|
98
|
+
}
|
|
99
|
+
function expectFloat(actual, expected, tolerance = 0.001) {
|
|
100
|
+
const areEqual = Math.abs(actual - expected) < 0.001;
|
|
101
|
+
if (!areEqual)
|
|
102
|
+
throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;
|
|
103
|
+
}
|
|
104
|
+
/** Defines a test suite. */
|
|
105
|
+
function category(category, tests) {
|
|
106
|
+
currentCategory = category;
|
|
107
|
+
tests();
|
|
108
|
+
}
|
|
109
|
+
/** Defines a function to be executed before the tests in this category are executed. */
|
|
110
|
+
function before(before) {
|
|
111
|
+
if (tests[currentCategory] == undefined)
|
|
112
|
+
tests[currentCategory] = {};
|
|
113
|
+
tests[currentCategory].before = before;
|
|
114
|
+
}
|
|
115
|
+
/** Defines a function to be executed after the tests in this category are executed. */
|
|
116
|
+
function after(after) {
|
|
117
|
+
if (tests[currentCategory] == undefined)
|
|
118
|
+
tests[currentCategory] = {};
|
|
119
|
+
tests[currentCategory].after = after;
|
|
120
|
+
}
|
|
121
|
+
function runTests(options) {
|
|
122
|
+
var _a;
|
|
123
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
124
|
+
let results = [];
|
|
125
|
+
for (const [key, value] of Object.entries(tests)) {
|
|
126
|
+
if ((options === null || options === void 0 ? void 0 : options.category) != undefined) {
|
|
127
|
+
if (!key.toLowerCase().startsWith(options === null || options === void 0 ? void 0 : options.category.toLowerCase()))
|
|
128
|
+
continue;
|
|
129
|
+
}
|
|
130
|
+
try {
|
|
131
|
+
if (value.before)
|
|
132
|
+
yield value.before();
|
|
133
|
+
}
|
|
134
|
+
catch (x) {
|
|
135
|
+
value.beforeStatus = x.toString();
|
|
136
|
+
}
|
|
137
|
+
let t = (_a = value.tests) !== null && _a !== void 0 ? _a : [];
|
|
138
|
+
let res = [];
|
|
139
|
+
for (let i = 0; i < t.length; i++) {
|
|
140
|
+
res.push(yield execTest(t[i], options === null || options === void 0 ? void 0 : options.test));
|
|
141
|
+
}
|
|
142
|
+
let data = (yield Promise.all(res)).filter((d) => d.result != 'skipped');
|
|
143
|
+
try {
|
|
144
|
+
if (value.after)
|
|
145
|
+
yield value.after();
|
|
146
|
+
}
|
|
147
|
+
catch (x) {
|
|
148
|
+
value.afterStatus = x.toString();
|
|
149
|
+
}
|
|
150
|
+
if (value.afterStatus)
|
|
151
|
+
data.push({ category: key, name: 'init', result: value.afterStatus, success: false });
|
|
152
|
+
if (value.beforeStatus)
|
|
153
|
+
data.push({ category: key, name: 'init', result: value.beforeStatus, success: false });
|
|
154
|
+
results.push(...data);
|
|
155
|
+
}
|
|
156
|
+
return results;
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
function execTest(t, predicate) {
|
|
160
|
+
var _a;
|
|
161
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
162
|
+
let r;
|
|
163
|
+
try {
|
|
164
|
+
if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))
|
|
165
|
+
r = { success: true, result: 'skipped' };
|
|
166
|
+
else
|
|
167
|
+
r = { success: true, result: (_a = yield t.test()) !== null && _a !== void 0 ? _a : 'OK' };
|
|
168
|
+
}
|
|
169
|
+
catch (x) {
|
|
170
|
+
r = { success: false, result: x.toString() };
|
|
171
|
+
}
|
|
172
|
+
r.category = t.category;
|
|
173
|
+
r.name = t.name;
|
|
174
|
+
return r;
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
function delay(ms) {
|
|
178
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
179
|
+
yield new Promise(r => setTimeout(r, ms));
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,KAAK,IAAI,MAAM,mBAAmB,CAAC;AAE1C,MAAM,CAAC,IAAI,KAAK,GAA8I,EAAE,CAAC;AAEjK,MAAM,CAAC,IAAI,eAAuB,CAAC;AAEnC,MAAM,KAAW,MAAM,CAMtB;AAND,WAAiB,MAAM;IAErB,SAAgB,OAAO,CAAC,KAAU,EAAE,IAAa;QAC/C,IAAI,KAAK,IAAI,IAAI;YACf,MAAM,GAAG,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,cAAc,CAAC;IACzD,CAAC;IAHe,cAAO,UAGtB,CAAA;AACH,CAAC,EANgB,MAAM,KAAN,MAAM,QAMtB;AAOD,MAAM,OAAO,IAAI;IAMf,YAAY,QAAgB,EAAE,IAAY,EAAE,IAAwB,EAAE,OAAqB;;QACzF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,OAAO,aAAP,OAAO,cAAP,OAAO,IAAP,OAAO,GAAK,EAAE,EAAC;QACf,MAAA,OAAO,CAAC,OAAO,oCAAf,OAAO,CAAC,OAAO,GAAK,KAAK,EAAC;QAC1B,MAAA,OAAO,CAAC,yBAAyB,oCAAjC,OAAO,CAAC,yBAAyB,GAAK,IAAI,EAAC;QAC3C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,GAAuB,EAAE;YACnC,OAAO,IAAI,OAAO,CAAC,CAAO,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC3C,IAAI,MAAM,GAAG,EAAE,CAAC;gBAChB,IAAI;oBACF,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC;oBAC1B,MAAM,GAAG,MAAM,IAAI,EAAE,CAAC;iBACvB;gBAAC,OAAO,CAAM,EAAE;oBACf,MAAM,CAAC,CAAC,CAAC,CAAC;iBACX;gBACD,IAAI,CAAC,CAAC,MAAM,aAAa,CAAC,OAAQ,CAAC,yBAA0B,CAAC,CAAC;oBAC7D,MAAM,CAAC,oCAAoC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;gBACrE,OAAO,CAAC,MAAM,CAAC,CAAC;YAClB,CAAC,CAAA,CAAC,CAAC;QACL,CAAC,CAAA,CAAC;IACJ,CAAC;CACF;AAED,MAAM,UAAU,IAAI,CAAC,IAAY,EAAE,IAAwB,EAAE,OAAqB;IAChF,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,IAAI,SAAS;QAC3C,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;IACpC,KAAK,CAAC,eAAe,CAAC,CAAC,KAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;AACrF,CAAC;AAED,mEAAmE;AACnE,MAAM,UAAgB,aAAa,CAAC,EAAU;;QAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE;YACjC,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;YACjB,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC;gBACnC,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CAAA;AAED,iFAAiF;AACjF,MAAM,UAAU,MAAM,CAAC,MAAW,EAAE,QAAa;IAC/C,IAAI,MAAM,KAAK,QAAQ;QACrB,MAAM,aAAa,QAAQ,WAAW,MAAM,GAAG,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,MAAc,EAAE,QAAgB,EAAE,SAAS,GAAG,KAAK;IAC7E,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,KAAK,CAAC;IACrD,IAAI,CAAC,QAAQ;QACX,MAAM,YAAY,QAAQ,SAAS,MAAM,iBAAiB,SAAS,GAAG,CAAC;AAC3E,CAAC;AAED,4BAA4B;AAC5B,MAAM,UAAU,QAAQ,CAAC,QAAgB,EAAE,KAAiB;IAC1D,eAAe,GAAG,QAAQ,CAAC;IAC3B,KAAK,EAAE,CAAC;AACV,CAAC;AAED,wFAAwF;AACxF,MAAM,UAAU,MAAM,CAAC,MAA2B;IAChD,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,KAAK,CAAC,eAAe,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;AACzC,CAAC;AAED,uFAAuF;AACvF,MAAM,UAAU,KAAK,CAAC,KAA0B;IAC9C,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;AACvC,CAAC;AAGD,MAAM,UAAgB,QAAQ,CAAC,OAA4C;;;QACzE,IAAI,OAAO,GAA4E,EAAE,CAAC;QAE1F,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAChD,IAAI,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,KAAI,SAAS,EAAE;gBAClC,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,CAAC,WAAW,EAAE,CAAC;oBAChE,SAAS;aACZ;YACD,IAAI;gBACF,IAAI,KAAK,CAAC,MAAM;oBACd,MAAM,KAAK,CAAC,MAAM,EAAE,CAAC;aACxB;YAAC,OAAO,CAAM,EAAE;gBACf,KAAK,CAAC,YAAY,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aACnC;YACD,IAAI,CAAC,GAAG,MAAA,KAAK,CAAC,KAAK,mCAAI,EAAE,CAAC;YAC1B,IAAI,GAAG,GAAG,EAAE,CAAC;YACb,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAChC,GAAG,CAAC,IAAI,CAAC,MAAM,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,CAAC,CAAC,CAAC;aAC/C;YAED,IAAI,IAAI,GAAG,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,SAAS,CAAC,CAAC;YACzE,IAAI;gBACF,IAAI,KAAK,CAAC,KAAK;oBACb,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;aACvB;YAAC,OAAO,CAAM,EAAE;gBACf,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aAClC;YACD,IAAI,KAAK,CAAC,WAAW;gBACnB,IAAI,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,WAAW,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YACtF,IAAI,KAAK,CAAC,YAAY;gBACpB,IAAI,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,YAAY,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YACvF,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;SACvB;QAED,OAAO,OAAO,CAAC;;CAChB;AAED,SAAe,QAAQ,CAAC,CAAO,EAAE,SAA6B;;;QAC5D,IAAI,CAAyE,CAAC;QAC9E,IAAI;YACF,IAAI,SAAS,IAAI,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;gBACvF,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAC,CAAC;;gBAEvC,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAA,MAAM,CAAC,CAAC,IAAI,EAAE,mCAAI,IAAI,EAAC,CAAC;SACvD;QAAC,OAAO,CAAM,EAAE;YACf,CAAC,GAAG,EAAC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAC,CAAC;SAC5C;QACD,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC;QACxB,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC;QAChB,OAAO,CAAC,CAAC;;CACV;AAED,MAAM,UAAgB,KAAK,CAAC,EAAU;;QACpC,MAAO,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;IAC7C,CAAC;CAAA","sourcesContent":["import * as grok from \"datagrok-api/grok\";\n\nexport let tests: {[key: string]: {tests?: Test[], before?: () => Promise<void>, after?: () => Promise<void>, beforeStatus?: string, afterStatus?: string}} = {};\n\nexport let currentCategory: string;\n\nexport namespace assure {\n\n  export function notNull(value: any, name?: string) {\n    if (value == null)\n      throw `${name == null ? 'Value' : name} not defined`;\n  }\n}\n\nexport interface TestOptions {\n  timeout? : number;\n  unhandledExceptionTimeout? : number;\n}\n\nexport class Test {\n  test: () => Promise<any>;\n  name: string;\n  category: string;\n  options?: TestOptions;\n\n  constructor(category: string, name: string, test: () => Promise<any>, options?: TestOptions) {\n    this.category = category;\n    this.name = name;\n    options ??= {};\n    options.timeout ??= 30000;\n    options.unhandledExceptionTimeout ??= 2000;\n    this.options = options;\n    this.test = async (): Promise<any> => {\n      return new Promise(async (resolve, reject) => {\n        let result = '';\n        try {\n          grok.shell.lastError = '';\n          result = await test();\n        } catch (e: any) {\n          reject(e);\n        }\n        if (!(await assertNoError(options!.unhandledExceptionTimeout!)))\n          reject(`Unhandled exception during test: ${grok.shell.lastError}`);\n        resolve(result);\n      });\n    };\n  }\n}\n\nexport function test(name: string, test: () => Promise<any>, options?: TestOptions): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  if (tests[currentCategory].tests == undefined)\n    tests[currentCategory].tests = [];\n  tests[currentCategory].tests!.push(new Test(currentCategory, name, test, options));\n}\n\n/** Awaits for a while checking the error status of the platform */\nexport async function assertNoError(ms: number): Promise<boolean> {\n  for (let i = 0; i < ms / 500; ++i) {\n    await delay(500);\n    if (grok.shell.lastError.length !== 0)\n      return false;\n  }\n  return true;\n}\n\n/** Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual: any, expected: any): void {\n  if (actual !== expected)\n    throw `Expected \"${expected}\", got \"${actual}\"`;\n}\n\nexport function expectFloat(actual: number, expected: number, tolerance = 0.001): void {\n  const areEqual = Math.abs(actual - expected) < 0.001;\n  if (!areEqual)\n    throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;\n}\n\n/** Defines a test suite. */\nexport function category(category: string, tests: () => void): void {\n  currentCategory = category;\n  tests();\n}\n\n/** Defines a function to be executed before the tests in this category are executed. */\nexport function before(before: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].before = before;\n}\n\n/** Defines a function to be executed after the tests in this category are executed. */\nexport function after(after: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].after = after;\n}\n\n\nexport async function runTests(options?: {category?: string, test?: string}) {\n  let results: { category?: string, name?: string, success: boolean, result: string}[] = [];\n\n  for (const [key, value] of Object.entries(tests)) {\n    if (options?.category != undefined) {\n      if (!key.toLowerCase().startsWith(options?.category.toLowerCase()))\n        continue;\n    }\n    try {\n      if (value.before)\n        await value.before();\n    } catch (x: any) {\n      value.beforeStatus = x.toString();\n    }\n    let t = value.tests ?? [];\n    let res = [];\n    for(let i = 0; i < t.length; i++) {\n      res.push(await execTest(t[i], options?.test));\n    }\n\n    let data = (await Promise.all(res)).filter((d) => d.result != 'skipped');\n    try {\n      if (value.after)\n        await value.after();\n    } catch (x: any) {\n      value.afterStatus = x.toString();\n    }\n    if (value.afterStatus)\n      data.push({category: key, name: 'init', result: value.afterStatus, success: false});\n    if (value.beforeStatus)\n      data.push({category: key, name: 'init', result: value.beforeStatus, success: false});\n    results.push(...data);\n  }\n\n  return results;\n}\n\nasync function execTest(t: Test, predicate: string | undefined) {\n  let r: { category?: string, name?: string, success: boolean, result: string };\n  try {\n    if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))\n      r = {success: true, result: 'skipped'};\n    else\n      r = {success: true, result: await t.test() ?? 'OK'};\n  } catch (x: any) {\n    r = {success: false, result: x.toString()};\n  }\n  r.category = t.category;\n  r.name = t.name;\n  return r;\n}\n\nexport async function delay(ms: number) {\n  await  new Promise(r => setTimeout(r, ms));\n}\n"]}
|
|
183
|
+
|
|
184
|
+
/***/ }),
|
|
185
|
+
|
|
186
|
+
/***/ "./src/structures-works/converters.ts":
|
|
187
|
+
/*!********************************************!*\
|
|
188
|
+
!*** ./src/structures-works/converters.ts ***!
|
|
189
|
+
\********************************************/
|
|
190
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
191
|
+
|
|
192
|
+
__webpack_require__.r(__webpack_exports__);
|
|
193
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
194
|
+
/* harmony export */ "asoGapmersNucleotidesToBioSpring": () => (/* binding */ asoGapmersNucleotidesToBioSpring),
|
|
195
|
+
/* harmony export */ "asoGapmersNucleotidesToGcrs": () => (/* binding */ asoGapmersNucleotidesToGcrs),
|
|
196
|
+
/* harmony export */ "asoGapmersBioSpringToNucleotides": () => (/* binding */ asoGapmersBioSpringToNucleotides),
|
|
197
|
+
/* harmony export */ "asoGapmersBioSpringToGcrs": () => (/* binding */ asoGapmersBioSpringToGcrs),
|
|
198
|
+
/* harmony export */ "asoGapmersGcrsToBioSpring": () => (/* binding */ asoGapmersGcrsToBioSpring),
|
|
199
|
+
/* harmony export */ "asoGapmersGcrsToNucleotides": () => (/* binding */ asoGapmersGcrsToNucleotides),
|
|
200
|
+
/* harmony export */ "siRnaBioSpringToNucleotides": () => (/* binding */ siRnaBioSpringToNucleotides),
|
|
201
|
+
/* harmony export */ "siRnaBioSpringToAxolabs": () => (/* binding */ siRnaBioSpringToAxolabs),
|
|
202
|
+
/* harmony export */ "siRnaBioSpringToGcrs": () => (/* binding */ siRnaBioSpringToGcrs),
|
|
203
|
+
/* harmony export */ "siRnaAxolabsToGcrs": () => (/* binding */ siRnaAxolabsToGcrs),
|
|
204
|
+
/* harmony export */ "siRnaAxolabsToBioSpring": () => (/* binding */ siRnaAxolabsToBioSpring),
|
|
205
|
+
/* harmony export */ "siRnaAxolabsToNucleotides": () => (/* binding */ siRnaAxolabsToNucleotides),
|
|
206
|
+
/* harmony export */ "siRnaGcrsToNucleotides": () => (/* binding */ siRnaGcrsToNucleotides),
|
|
207
|
+
/* harmony export */ "siRnaGcrsToBioSpring": () => (/* binding */ siRnaGcrsToBioSpring),
|
|
208
|
+
/* harmony export */ "siRnaGcrsToAxolabs": () => (/* binding */ siRnaGcrsToAxolabs),
|
|
209
|
+
/* harmony export */ "siRnaNucleotideToBioSpringSenseStrand": () => (/* binding */ siRnaNucleotideToBioSpringSenseStrand),
|
|
210
|
+
/* harmony export */ "siRnaNucleotidesToGcrs": () => (/* binding */ siRnaNucleotidesToGcrs),
|
|
211
|
+
/* harmony export */ "siRnaNucleotideToAxolabsSenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsSenseStrand),
|
|
212
|
+
/* harmony export */ "siRnaNucleotideToAxolabsAntisenseStrand": () => (/* binding */ siRnaNucleotideToAxolabsAntisenseStrand),
|
|
213
|
+
/* harmony export */ "gcrsToNucleotides": () => (/* binding */ gcrsToNucleotides),
|
|
214
|
+
/* harmony export */ "gcrsToMermade12": () => (/* binding */ gcrsToMermade12)
|
|
215
|
+
/* harmony export */ });
|
|
216
|
+
//name: asoGapmersNucleotidesToBioSpring
|
|
217
|
+
//input: string nucleotides {semType: DNA nucleotides}
|
|
218
|
+
//output: string result {semType: BioSpring / Gapmers}
|
|
219
|
+
function asoGapmersNucleotidesToBioSpring(nucleotides) {
|
|
220
|
+
let count = -1;
|
|
221
|
+
const objForEdges = {
|
|
222
|
+
'(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'
|
|
223
|
+
};
|
|
224
|
+
const objForCenter = {
|
|
225
|
+
'(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'
|
|
226
|
+
};
|
|
227
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
|
|
228
|
+
count++;
|
|
229
|
+
return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];
|
|
230
|
+
}).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
|
|
231
|
+
nucleotides.length : 2 * count + 1);
|
|
232
|
+
}
|
|
233
|
+
//name: asoGapmersNucleotidesToGcrs
|
|
234
|
+
//input: string nucleotides {semType: DNA nucleotides}
|
|
235
|
+
//output: string result {semType: GCRS / Gapmers}
|
|
236
|
+
function asoGapmersNucleotidesToGcrs(nucleotides) {
|
|
237
|
+
let count = -1;
|
|
238
|
+
const objForEdges = {
|
|
239
|
+
'(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',
|
|
240
|
+
'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'
|
|
241
|
+
};
|
|
242
|
+
const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
243
|
+
'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };
|
|
244
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|T|C|G)/g, function (x) {
|
|
245
|
+
count++;
|
|
246
|
+
if (count < 5)
|
|
247
|
+
return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];
|
|
248
|
+
if (count < 15)
|
|
249
|
+
return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];
|
|
250
|
+
return objForEdges[x];
|
|
251
|
+
}).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?
|
|
252
|
+
nucleotides.length : -3);
|
|
253
|
+
}
|
|
254
|
+
//name: asoGapmersBioSpringToNucleotides
|
|
255
|
+
//input: string nucleotides {semType: BioSpring / Gapmers}
|
|
256
|
+
//output: string result {semType: DNA nucleotides}
|
|
257
|
+
function asoGapmersBioSpringToNucleotides(nucleotides) {
|
|
258
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
259
|
+
'*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };
|
|
260
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|\*|5|6|7|8|9)/g, function (x) { return obj[x]; });
|
|
261
|
+
}
|
|
262
|
+
//name: asoGapmersBioSpringToGcrs
|
|
263
|
+
//input: string nucleotides {semType: BioSpring / Gapmers}
|
|
264
|
+
//output: string result {semType: GCRS / Gapmers}
|
|
265
|
+
function asoGapmersBioSpringToGcrs(nucleotides) {
|
|
266
|
+
let count = -1;
|
|
267
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
268
|
+
'5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',
|
|
269
|
+
'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',
|
|
270
|
+
};
|
|
271
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|5\*|6\*|7\*|8\*|9\*|A\*|T\*|G\*|C\*|5|6|7|8)/g, function (x) {
|
|
272
|
+
count++;
|
|
273
|
+
return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
//name: asoGapmersGcrsToBioSpring
|
|
277
|
+
//input: string nucleotides {semType: GCRS / Gapmers}
|
|
278
|
+
//output: string result {semType: BioSpring / Gapmers}
|
|
279
|
+
function asoGapmersGcrsToBioSpring(nucleotides) {
|
|
280
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
281
|
+
'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',
|
|
282
|
+
};
|
|
283
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });
|
|
284
|
+
}
|
|
285
|
+
//name: asoGapmersGcrsToNucleotides
|
|
286
|
+
//input: string nucleotides {semType: GCRS / Gapmers}
|
|
287
|
+
//output: string result {semType: DNA nucleotides}
|
|
288
|
+
function asoGapmersGcrsToNucleotides(nucleotides) {
|
|
289
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
290
|
+
'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };
|
|
291
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });
|
|
292
|
+
}
|
|
293
|
+
//name: siRnaBioSpringToNucleotides
|
|
294
|
+
//input: string nucleotides {semType: BioSpring / siRNA}
|
|
295
|
+
//output: string result {semType: RNA nucleotides}
|
|
296
|
+
function siRnaBioSpringToNucleotides(nucleotides) {
|
|
297
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
298
|
+
'1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };
|
|
299
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
|
|
300
|
+
}
|
|
301
|
+
//name: siRnaBioSpringToAxolabs
|
|
302
|
+
//input: string nucleotides {semType: BioSpring / siRNA}
|
|
303
|
+
//output: string result {semType: Axolabs / siRNA}
|
|
304
|
+
function siRnaBioSpringToAxolabs(nucleotides) {
|
|
305
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
306
|
+
'1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };
|
|
307
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
|
|
308
|
+
}
|
|
309
|
+
//name: siRnaBioSpringToGcrs
|
|
310
|
+
//input: string nucleotides {semType: BioSpring / siRNA}
|
|
311
|
+
//output: string result {semType: GCRS}
|
|
312
|
+
function siRnaBioSpringToGcrs(nucleotides) {
|
|
313
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
314
|
+
'1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };
|
|
315
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|1|2|3|4|5|6|7|8|\*)/g, function (x) { return obj[x]; });
|
|
316
|
+
}
|
|
317
|
+
//name: siRnaAxolabsToGcrs
|
|
318
|
+
//input: string nucleotides {semType: Axolabs / siRNA}
|
|
319
|
+
//output: string result {semType: GCRS}
|
|
320
|
+
function siRnaAxolabsToGcrs(nucleotides) {
|
|
321
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
322
|
+
'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',
|
|
323
|
+
};
|
|
324
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
|
|
325
|
+
}
|
|
326
|
+
//name: siRnaAxolabsToBioSpring
|
|
327
|
+
//input: string nucleotides {semType: Axolabs / siRNA}
|
|
328
|
+
//output: string result {semType: BioSpring / siRNA}
|
|
329
|
+
function siRnaAxolabsToBioSpring(nucleotides) {
|
|
330
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
331
|
+
'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',
|
|
332
|
+
};
|
|
333
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
|
|
334
|
+
}
|
|
335
|
+
//name: siRnaAxolabsToNucleotides
|
|
336
|
+
//input: string nucleotides {semType: Axolabs / siRNA}
|
|
337
|
+
//output: string result {semType: RNA nucleotides}
|
|
338
|
+
function siRnaAxolabsToNucleotides(nucleotides) {
|
|
339
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
340
|
+
'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',
|
|
341
|
+
};
|
|
342
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });
|
|
343
|
+
}
|
|
344
|
+
//name: siRnaGcrsToNucleotides
|
|
345
|
+
//input: string nucleotides {semType: GCRS}
|
|
346
|
+
//output: string result {semType: RNA nucleotides}
|
|
347
|
+
function siRnaGcrsToNucleotides(nucleotides) {
|
|
348
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
349
|
+
'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',
|
|
350
|
+
};
|
|
351
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
|
|
352
|
+
}
|
|
353
|
+
//name: siRnaGcrsToBioSpring
|
|
354
|
+
//input: string nucleotides {semType: GCRS}
|
|
355
|
+
//output: string result {semType: BioSpring / siRNA}
|
|
356
|
+
function siRnaGcrsToBioSpring(nucleotides) {
|
|
357
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
358
|
+
'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',
|
|
359
|
+
};
|
|
360
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
|
|
361
|
+
}
|
|
362
|
+
//name: siRnaGcrsToAxolabs
|
|
363
|
+
//input: string nucleotides {semType: GCRS}
|
|
364
|
+
//output: string result {semType: Axolabs / siRNA}
|
|
365
|
+
function siRnaGcrsToAxolabs(nucleotides) {
|
|
366
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
367
|
+
'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',
|
|
368
|
+
};
|
|
369
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });
|
|
370
|
+
}
|
|
371
|
+
//name: siRnaNucleotideToBioSpringSenseStrand
|
|
372
|
+
//input: string nucleotides {semType: RNA nucleotides}
|
|
373
|
+
//output: string result {semType: BioSpring / siRNA}
|
|
374
|
+
function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {
|
|
375
|
+
let count = -1;
|
|
376
|
+
const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
377
|
+
'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };
|
|
378
|
+
const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
379
|
+
'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };
|
|
380
|
+
const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
381
|
+
'A': '6', 'U': '5', 'G': '8', 'C': '7' };
|
|
382
|
+
const objForEvenIndices = { '(invabasic)': '(invabasic)',
|
|
383
|
+
'(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };
|
|
384
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
|
|
385
|
+
count++;
|
|
386
|
+
if (count < 2)
|
|
387
|
+
return objForLeftEdge[x];
|
|
388
|
+
if (count > nucleotides.length - 3)
|
|
389
|
+
return objForRightEdge[x];
|
|
390
|
+
return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];
|
|
391
|
+
});
|
|
392
|
+
}
|
|
393
|
+
//name: siRnaNucleotidesToGcrs
|
|
394
|
+
//input: string nucleotides {semType: RNA nucleotides}
|
|
395
|
+
//output: string result {semType: GCRS}
|
|
396
|
+
function siRnaNucleotidesToGcrs(nucleotides) {
|
|
397
|
+
let count = -1;
|
|
398
|
+
const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
399
|
+
'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };
|
|
400
|
+
const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
401
|
+
'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };
|
|
402
|
+
const objForEvenIndices = { '(invabasic)': '(invabasic)',
|
|
403
|
+
'(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };
|
|
404
|
+
const objForOddIndices = { '(invabasic)': '(invabasic)',
|
|
405
|
+
'(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };
|
|
406
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
|
|
407
|
+
count++;
|
|
408
|
+
if (count < 2)
|
|
409
|
+
return objForLeftEdge[x];
|
|
410
|
+
if (count > nucleotides.length - 3)
|
|
411
|
+
return objForRightEdge[x];
|
|
412
|
+
return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];
|
|
413
|
+
});
|
|
414
|
+
}
|
|
415
|
+
//name: siRnaNucleotideToAxolabsSenseStrand
|
|
416
|
+
//input: string nucleotides {semType: RNA nucleotides}
|
|
417
|
+
//output: string result {semType: Axolabs}
|
|
418
|
+
function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {
|
|
419
|
+
let count = -1;
|
|
420
|
+
const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
421
|
+
'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };
|
|
422
|
+
const objForSomeIndices = { '(invabasic)': '(invabasic)',
|
|
423
|
+
'(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };
|
|
424
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
425
|
+
'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };
|
|
426
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
|
|
427
|
+
count++;
|
|
428
|
+
if (count < 2)
|
|
429
|
+
return objForLeftEdge[x];
|
|
430
|
+
if (count == 6 || (count > 7 && count < 11))
|
|
431
|
+
return objForSomeIndices[x];
|
|
432
|
+
if (count == nucleotides.length - 1)
|
|
433
|
+
return 'a';
|
|
434
|
+
return obj[x];
|
|
435
|
+
});
|
|
436
|
+
}
|
|
437
|
+
//name: siRnaNucleotideToAxolabsAntisenseStrand
|
|
438
|
+
//input: string nucleotides {semType: RNA nucleotides}
|
|
439
|
+
//output: string result {semType: Axolabs}
|
|
440
|
+
function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {
|
|
441
|
+
let count = -1;
|
|
442
|
+
const objForSmallLinkages = { '(invabasic)': '(invabasic)',
|
|
443
|
+
'(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };
|
|
444
|
+
const objForBigLinkages = { '(invabasic)': '(invabasic)',
|
|
445
|
+
'(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };
|
|
446
|
+
const objForSomeIndices = { '(invabasic)': '(invabasic)',
|
|
447
|
+
'(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };
|
|
448
|
+
const obj = { '(invabasic)': '(invabasic)',
|
|
449
|
+
'(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };
|
|
450
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|A|U|G|C)/g, function (x) {
|
|
451
|
+
count++;
|
|
452
|
+
if (count > 19 && count < 22)
|
|
453
|
+
return objForSmallLinkages[x];
|
|
454
|
+
if (count == 0)
|
|
455
|
+
return 'us';
|
|
456
|
+
if (count == 1)
|
|
457
|
+
return objForBigLinkages[x];
|
|
458
|
+
return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];
|
|
459
|
+
});
|
|
460
|
+
}
|
|
461
|
+
//name: gcrsToNucleotides
|
|
462
|
+
//input: string nucleotides {semType: GCRS}
|
|
463
|
+
//output: string result {semType: RNA nucleotides}
|
|
464
|
+
function gcrsToNucleotides(nucleotides) {
|
|
465
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
466
|
+
'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',
|
|
467
|
+
'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',
|
|
468
|
+
};
|
|
469
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });
|
|
470
|
+
}
|
|
471
|
+
//name: gcrsToMermade12
|
|
472
|
+
//input: string nucleotides {semType: GCRS}
|
|
473
|
+
//output: string result {semType: Mermade 12 / siRNA}
|
|
474
|
+
function gcrsToMermade12(nucleotides) {
|
|
475
|
+
const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',
|
|
476
|
+
'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',
|
|
477
|
+
'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',
|
|
478
|
+
};
|
|
479
|
+
return nucleotides.replace(/(\(invabasic\)|\(GalNAc-2-JNJ\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });
|
|
480
|
+
}
|
|
481
|
+
|
|
482
|
+
|
|
483
|
+
/***/ }),
|
|
484
|
+
|
|
485
|
+
/***/ "./src/structures-works/from-monomers.ts":
|
|
486
|
+
/*!***********************************************!*\
|
|
487
|
+
!*** ./src/structures-works/from-monomers.ts ***!
|
|
488
|
+
\***********************************************/
|
|
489
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
490
|
+
|
|
491
|
+
__webpack_require__.r(__webpack_exports__);
|
|
492
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
493
|
+
/* harmony export */ "sequenceToMolV3000": () => (/* binding */ sequenceToMolV3000),
|
|
494
|
+
/* harmony export */ "sequenceToSmiles": () => (/* binding */ sequenceToSmiles)
|
|
495
|
+
/* harmony export */ });
|
|
496
|
+
/* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
|
|
497
|
+
/* harmony import */ var _sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./sequence-codes-tools */ "./src/structures-works/sequence-codes-tools.ts");
|
|
498
|
+
/* harmony import */ var _mol_transformations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./mol-transformations */ "./src/structures-works/mol-transformations.ts");
|
|
499
|
+
|
|
500
|
+
|
|
501
|
+
|
|
502
|
+
function sequenceToMolV3000(sequence, inverted = false, oclRender = false) {
|
|
503
|
+
const obj = getObjectWithCodesAndSmiles(sequence);
|
|
504
|
+
let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));
|
|
505
|
+
let i = 0;
|
|
506
|
+
const smilesCodes = [];
|
|
507
|
+
const codesList = [];
|
|
508
|
+
const links = ['s', 'ps', '*'];
|
|
509
|
+
const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];
|
|
510
|
+
const dropdowns = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS);
|
|
511
|
+
codes = codes.concat(dropdowns);
|
|
512
|
+
while (i < sequence.length) {
|
|
513
|
+
const code = codes.find((s) => s == sequence.slice(i, i + s.length));
|
|
514
|
+
i += code.length;
|
|
515
|
+
inverted ? codesList.unshift(code) : codesList.push(code);
|
|
516
|
+
}
|
|
517
|
+
for (let i = 0; i < codesList.length; i++) {
|
|
518
|
+
if (dropdowns.includes(codesList[i])) {
|
|
519
|
+
smilesCodes.push((i >= codesList.length / 2) ?
|
|
520
|
+
_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].right : _map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].left);
|
|
521
|
+
smilesCodes.push(_map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles);
|
|
522
|
+
}
|
|
523
|
+
else {
|
|
524
|
+
if (links.includes(codesList[i]) ||
|
|
525
|
+
includesStandardLinkAlready.includes(codesList[i]) ||
|
|
526
|
+
(i < codesList.length - 1 && links.includes(codesList[i + 1])))
|
|
527
|
+
smilesCodes.push(obj[codesList[i]]);
|
|
528
|
+
else {
|
|
529
|
+
smilesCodes.push(obj[codesList[i]]);
|
|
530
|
+
smilesCodes.push(_map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles);
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
return (0,_mol_transformations__WEBPACK_IMPORTED_MODULE_2__.getNucleotidesMol)(smilesCodes, oclRender);
|
|
535
|
+
}
|
|
536
|
+
function sequenceToSmiles(sequence, inverted = false) {
|
|
537
|
+
const obj = getObjectWithCodesAndSmiles(sequence);
|
|
538
|
+
let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));
|
|
539
|
+
let i = 0;
|
|
540
|
+
let smiles = '';
|
|
541
|
+
const codesList = [];
|
|
542
|
+
const links = ['s', 'ps', '*'];
|
|
543
|
+
const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];
|
|
544
|
+
const dropdowns = Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS);
|
|
545
|
+
codes = codes.concat(dropdowns);
|
|
546
|
+
while (i < sequence.length) {
|
|
547
|
+
const code = codes.find((s) => s == sequence.slice(i, i + s.length));
|
|
548
|
+
i += code.length;
|
|
549
|
+
inverted ? codesList.unshift(code) : codesList.push(code);
|
|
550
|
+
}
|
|
551
|
+
for (let i = 0; i < codesList.length; i++) {
|
|
552
|
+
if (dropdowns.includes(codesList[i])) {
|
|
553
|
+
smiles += (i >= codesList.length / 2) ?
|
|
554
|
+
_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].right + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles :
|
|
555
|
+
_map__WEBPACK_IMPORTED_MODULE_0__.MODIFICATIONS[codesList[i]].left + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles;
|
|
556
|
+
}
|
|
557
|
+
else {
|
|
558
|
+
if (links.includes(codesList[i]) ||
|
|
559
|
+
includesStandardLinkAlready.includes(codesList[i]) ||
|
|
560
|
+
(i < codesList.length - 1 && links.includes(codesList[i + 1])))
|
|
561
|
+
smiles += obj[codesList[i]];
|
|
562
|
+
else
|
|
563
|
+
smiles += obj[codesList[i]] + _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles;
|
|
564
|
+
}
|
|
565
|
+
}
|
|
566
|
+
smiles = smiles.replace(/OO/g, 'O');
|
|
567
|
+
return ((links.includes(codesList[codesList.length - 1]) &&
|
|
568
|
+
codesList.length > 1 &&
|
|
569
|
+
!includesStandardLinkAlready.includes(codesList[codesList.length - 2])) ||
|
|
570
|
+
dropdowns.includes(codesList[codesList.length - 1]) ||
|
|
571
|
+
includesStandardLinkAlready.includes(codesList[codesList.length - 1])) ?
|
|
572
|
+
smiles :
|
|
573
|
+
smiles.slice(0, smiles.length - _map__WEBPACK_IMPORTED_MODULE_0__.stadardPhosphateLinkSmiles.length + 1);
|
|
574
|
+
}
|
|
575
|
+
function getObjectWithCodesAndSmiles(sequence) {
|
|
576
|
+
const obj = {};
|
|
577
|
+
for (const synthesizer of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map)) {
|
|
578
|
+
for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer])) {
|
|
579
|
+
for (const code of Object.keys(_map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology]))
|
|
580
|
+
obj[code] = _map__WEBPACK_IMPORTED_MODULE_0__.map[synthesizer][technology][code].SMILES;
|
|
581
|
+
}
|
|
582
|
+
}
|
|
583
|
+
// TODO: create object based from synthesizer type to avoid key(codes) duplicates
|
|
584
|
+
const output = (0,_sequence_codes_tools__WEBPACK_IMPORTED_MODULE_1__.isValidSequence)(sequence);
|
|
585
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12)
|
|
586
|
+
obj['g'] = _map__WEBPACK_IMPORTED_MODULE_0__.map[_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.MERMADE_12][_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA]['g'].SMILES;
|
|
587
|
+
else if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.AXOLABS)
|
|
588
|
+
obj['g'] = _map__WEBPACK_IMPORTED_MODULE_0__.map[_map__WEBPACK_IMPORTED_MODULE_0__.SYNTHESIZERS.AXOLABS][_map__WEBPACK_IMPORTED_MODULE_0__.TECHNOLOGIES.SI_RNA]['g'].SMILES;
|
|
589
|
+
return obj;
|
|
590
|
+
}
|
|
591
|
+
function sortByStringLengthInDescendingOrder(array) {
|
|
592
|
+
return array.sort(function (a, b) { return b.length - a.length; });
|
|
593
|
+
}
|
|
594
|
+
|
|
595
|
+
|
|
596
|
+
/***/ }),
|
|
597
|
+
|
|
598
|
+
/***/ "./src/structures-works/map.ts":
|
|
599
|
+
/*!*************************************!*\
|
|
600
|
+
!*** ./src/structures-works/map.ts ***!
|
|
601
|
+
\*************************************/
|
|
602
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
603
|
+
|
|
604
|
+
__webpack_require__.r(__webpack_exports__);
|
|
605
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
606
|
+
/* harmony export */ "SYNTHESIZERS": () => (/* binding */ SYNTHESIZERS),
|
|
607
|
+
/* harmony export */ "TECHNOLOGIES": () => (/* binding */ TECHNOLOGIES),
|
|
608
|
+
/* harmony export */ "COL_NAMES": () => (/* binding */ COL_NAMES),
|
|
609
|
+
/* harmony export */ "MODIFICATIONS": () => (/* binding */ MODIFICATIONS),
|
|
610
|
+
/* harmony export */ "stadardPhosphateLinkSmiles": () => (/* binding */ stadardPhosphateLinkSmiles),
|
|
611
|
+
/* harmony export */ "map": () => (/* binding */ map)
|
|
612
|
+
/* harmony export */ });
|
|
613
|
+
const SYNTHESIZERS = {
|
|
614
|
+
RAW_NUCLEOTIDES: 'Raw Nucleotides',
|
|
615
|
+
BIOSPRING: 'BioSpring Codes',
|
|
616
|
+
GCRS: 'Janssen GCRS Codes',
|
|
617
|
+
AXOLABS: 'Axolabs Codes',
|
|
618
|
+
MERMADE_12: 'Mermade 12',
|
|
619
|
+
};
|
|
620
|
+
const TECHNOLOGIES = {
|
|
621
|
+
DNA: 'DNA',
|
|
622
|
+
RNA: 'RNA',
|
|
623
|
+
ASO_GAPMERS: 'For ASO Gapmers',
|
|
624
|
+
SI_RNA: 'For 2\'-OMe and 2\'-F modified siRNA',
|
|
625
|
+
};
|
|
626
|
+
const COL_NAMES = {
|
|
627
|
+
CHEMISTRY: 'Chemistry',
|
|
628
|
+
NUMBER: 'Number',
|
|
629
|
+
TYPE: 'Type',
|
|
630
|
+
CHEMISTRY_NAME: 'Chemistry Name',
|
|
631
|
+
INTERNAL_COMPOUND_ID: 'Internal compound ID',
|
|
632
|
+
IDP: 'IDP',
|
|
633
|
+
SEQUENCE: 'Sequence',
|
|
634
|
+
COMPOUND_NAME: 'Compound Name',
|
|
635
|
+
COMPOUND_COMMENTS: 'Compound Comments',
|
|
636
|
+
SALT: 'Salt',
|
|
637
|
+
EQUIVALENTS: 'Equivalents',
|
|
638
|
+
PURITY: 'Purity',
|
|
639
|
+
CPD_MW: 'Cpd MW',
|
|
640
|
+
SALT_MASS: 'Salt mass',
|
|
641
|
+
BATCH_MW: 'Batch MW',
|
|
642
|
+
SOURCE: 'Source',
|
|
643
|
+
ICD: 'ICD',
|
|
644
|
+
OWNER: 'Owner',
|
|
645
|
+
};
|
|
646
|
+
// interface CODES {
|
|
647
|
+
// }
|
|
648
|
+
const MODIFICATIONS = {
|
|
649
|
+
'(invabasic)': {
|
|
650
|
+
molecularWeight: 118.13,
|
|
651
|
+
left: 'O[C@@H]1C[C@@H]O[C@H]1CO',
|
|
652
|
+
right: 'O[C@@H]1C[C@@H]O[C@H]1CO',
|
|
653
|
+
},
|
|
654
|
+
'(GalNAc-2-JNJ)': {
|
|
655
|
+
molecularWeight: 1273.3,
|
|
656
|
+
left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
657
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
658
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',
|
|
659
|
+
right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
660
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
661
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',
|
|
662
|
+
},
|
|
663
|
+
};
|
|
664
|
+
const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';
|
|
665
|
+
const map = {
|
|
666
|
+
'Raw Nucleotides': {
|
|
667
|
+
'DNA': {
|
|
668
|
+
'A': {
|
|
669
|
+
'name': 'Adenine',
|
|
670
|
+
'weight': 313.21,
|
|
671
|
+
'normalized': 'dA',
|
|
672
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
|
|
673
|
+
},
|
|
674
|
+
'T': {
|
|
675
|
+
'name': 'Tyrosine',
|
|
676
|
+
'weight': 304.2,
|
|
677
|
+
'normalized': 'dT',
|
|
678
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
|
|
679
|
+
},
|
|
680
|
+
'G': {
|
|
681
|
+
'name': 'Guanine',
|
|
682
|
+
'weight': 329.21,
|
|
683
|
+
'normalized': 'dG',
|
|
684
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
|
|
685
|
+
},
|
|
686
|
+
'C': {
|
|
687
|
+
'name': 'Cytosine',
|
|
688
|
+
'weight': 289.18,
|
|
689
|
+
'normalized': 'dC',
|
|
690
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
|
|
691
|
+
},
|
|
692
|
+
},
|
|
693
|
+
'RNA': {
|
|
694
|
+
'A': {
|
|
695
|
+
'name': 'Adenine',
|
|
696
|
+
'weight': 313.21,
|
|
697
|
+
'normalized': 'dA',
|
|
698
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
|
|
699
|
+
},
|
|
700
|
+
'U': {
|
|
701
|
+
'name': 'Uracil',
|
|
702
|
+
'weight': 306.17,
|
|
703
|
+
'normalized': 'rU',
|
|
704
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',
|
|
705
|
+
},
|
|
706
|
+
'G': {
|
|
707
|
+
'name': 'Guanine',
|
|
708
|
+
'weight': 329.21,
|
|
709
|
+
'normalized': 'dG',
|
|
710
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
|
|
711
|
+
},
|
|
712
|
+
'C': {
|
|
713
|
+
'name': 'Cytosine',
|
|
714
|
+
'weight': 289.18,
|
|
715
|
+
'normalized': 'dC',
|
|
716
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
|
|
717
|
+
},
|
|
718
|
+
},
|
|
719
|
+
},
|
|
720
|
+
'BioSpring Codes': {
|
|
721
|
+
'For ASO Gapmers': {
|
|
722
|
+
'5': {
|
|
723
|
+
'name': '2\'MOE-5Me-rU',
|
|
724
|
+
'weight': 378.27,
|
|
725
|
+
'normalized': 'rU',
|
|
726
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',
|
|
727
|
+
},
|
|
728
|
+
'6': {
|
|
729
|
+
'name': '2\'MOE-rA',
|
|
730
|
+
'weight': 387.29,
|
|
731
|
+
'normalized': 'rA',
|
|
732
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
|
|
733
|
+
},
|
|
734
|
+
'7': {
|
|
735
|
+
'name': '2\'MOE-5Me-rC',
|
|
736
|
+
'weight': 377.29,
|
|
737
|
+
'normalized': 'rC',
|
|
738
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
|
|
739
|
+
},
|
|
740
|
+
'8': {
|
|
741
|
+
'name': '2\'MOE-rG',
|
|
742
|
+
'weight': 403.28,
|
|
743
|
+
'normalized': 'rG',
|
|
744
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
|
|
745
|
+
},
|
|
746
|
+
'9': {
|
|
747
|
+
'name': '5-Methyl-dC',
|
|
748
|
+
'weight': 303.21,
|
|
749
|
+
'normalized': 'dC',
|
|
750
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
|
|
751
|
+
},
|
|
752
|
+
'*': {
|
|
753
|
+
'name': 'ps linkage',
|
|
754
|
+
'weight': 16.07,
|
|
755
|
+
'normalized': '',
|
|
756
|
+
'SMILES': 'OP(=O)(S)O',
|
|
757
|
+
},
|
|
758
|
+
'A': {
|
|
759
|
+
'name': 'Adenine',
|
|
760
|
+
'weight': 313.21,
|
|
761
|
+
'normalized': 'dA',
|
|
762
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
|
|
763
|
+
},
|
|
764
|
+
'C': {
|
|
765
|
+
'name': 'Cytosine',
|
|
766
|
+
'weight': 289.18,
|
|
767
|
+
'normalized': 'dC',
|
|
768
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
|
|
769
|
+
},
|
|
770
|
+
'G': {
|
|
771
|
+
'name': 'Guanine',
|
|
772
|
+
'weight': 329.21,
|
|
773
|
+
'normalized': 'dG',
|
|
774
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
|
|
775
|
+
},
|
|
776
|
+
'T': {
|
|
777
|
+
'name': 'Tyrosine',
|
|
778
|
+
'weight': 304.2,
|
|
779
|
+
'normalized': 'dT',
|
|
780
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
|
|
781
|
+
},
|
|
782
|
+
},
|
|
783
|
+
'For 2\'-OMe and 2\'-F modified siRNA': {
|
|
784
|
+
'1': {
|
|
785
|
+
'name': '2\'-fluoro-U',
|
|
786
|
+
'weight': 308.16,
|
|
787
|
+
'normalized': 'rU',
|
|
788
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
|
|
789
|
+
},
|
|
790
|
+
'2': {
|
|
791
|
+
'name': '2\'-fluoro-A',
|
|
792
|
+
'weight': 331.2,
|
|
793
|
+
'normalized': 'rA',
|
|
794
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
|
|
795
|
+
},
|
|
796
|
+
'3': {
|
|
797
|
+
'name': '2\'-fluoro-C',
|
|
798
|
+
'weight': 307.18,
|
|
799
|
+
'normalized': 'rC',
|
|
800
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
|
|
801
|
+
},
|
|
802
|
+
'4': {
|
|
803
|
+
'name': '2\'-fluoro-G',
|
|
804
|
+
'weight': 347.19,
|
|
805
|
+
'normalized': 'rG',
|
|
806
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
|
|
807
|
+
},
|
|
808
|
+
'5': {
|
|
809
|
+
'name': '2\'OMe-rU',
|
|
810
|
+
'weight': 320.2,
|
|
811
|
+
'normalized': 'rU',
|
|
812
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
|
|
813
|
+
},
|
|
814
|
+
'6': {
|
|
815
|
+
'name': '2\'OMe-rA',
|
|
816
|
+
'weight': 343.24,
|
|
817
|
+
'normalized': 'rA',
|
|
818
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
819
|
+
},
|
|
820
|
+
'7': {
|
|
821
|
+
'name': '2\'OMe-rC',
|
|
822
|
+
'weight': 319.21,
|
|
823
|
+
'normalized': 'rC',
|
|
824
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
|
|
825
|
+
},
|
|
826
|
+
'8': {
|
|
827
|
+
'name': '2\'OMe-rG',
|
|
828
|
+
'weight': 359.24,
|
|
829
|
+
'normalized': 'rG',
|
|
830
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
831
|
+
},
|
|
832
|
+
'*': {
|
|
833
|
+
'name': 'ps linkage',
|
|
834
|
+
'weight': 16.07,
|
|
835
|
+
'normalized': '',
|
|
836
|
+
'SMILES': 'OP(=O)(S)O',
|
|
837
|
+
},
|
|
838
|
+
},
|
|
839
|
+
},
|
|
840
|
+
'Axolabs Codes': {
|
|
841
|
+
'For 2\'-OMe and 2\'-F modified siRNA': {
|
|
842
|
+
'Uf': {
|
|
843
|
+
'name': '2\'-fluoro-U',
|
|
844
|
+
'weight': 308.16,
|
|
845
|
+
'normalized': 'rU',
|
|
846
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
|
|
847
|
+
},
|
|
848
|
+
'Af': {
|
|
849
|
+
'name': '2\'-fluoro-A',
|
|
850
|
+
'weight': 331.2,
|
|
851
|
+
'normalized': 'rA',
|
|
852
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
|
|
853
|
+
},
|
|
854
|
+
'Cf': {
|
|
855
|
+
'name': '2\'-fluoro-C',
|
|
856
|
+
'weight': 307.18,
|
|
857
|
+
'normalized': 'rC',
|
|
858
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
|
|
859
|
+
},
|
|
860
|
+
'Gf': {
|
|
861
|
+
'name': '2\'-fluoro-G',
|
|
862
|
+
'weight': 347.19,
|
|
863
|
+
'normalized': 'rG',
|
|
864
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
|
|
865
|
+
},
|
|
866
|
+
'u': {
|
|
867
|
+
'name': '2\'OMe-rU',
|
|
868
|
+
'weight': 320.2,
|
|
869
|
+
'normalized': 'rU',
|
|
870
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
|
|
871
|
+
},
|
|
872
|
+
'a': {
|
|
873
|
+
'name': '2\'OMe-rA',
|
|
874
|
+
'weight': 343.24,
|
|
875
|
+
'normalized': 'rA',
|
|
876
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
877
|
+
},
|
|
878
|
+
'c': {
|
|
879
|
+
'name': '2\'OMe-rC',
|
|
880
|
+
'weight': 319.21,
|
|
881
|
+
'normalized': 'rC',
|
|
882
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
|
|
883
|
+
},
|
|
884
|
+
'g': {
|
|
885
|
+
'name': '2\'OMe-rG',
|
|
886
|
+
'weight': 359.,
|
|
887
|
+
'normalized': 'rG',
|
|
888
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
889
|
+
},
|
|
890
|
+
's': {
|
|
891
|
+
'name': 'ps linkage',
|
|
892
|
+
'weight': 16.07,
|
|
893
|
+
'normalized': '',
|
|
894
|
+
'SMILES': 'OP(=O)(S)O',
|
|
895
|
+
},
|
|
896
|
+
},
|
|
897
|
+
},
|
|
898
|
+
'Janssen GCRS Codes': {
|
|
899
|
+
'For ASO Gapmers': {
|
|
900
|
+
'moeT': {
|
|
901
|
+
'name': '2\'MOE-5Me-rU',
|
|
902
|
+
'weight': 378.27,
|
|
903
|
+
'normalized': 'rU',
|
|
904
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',
|
|
905
|
+
},
|
|
906
|
+
'moeA': {
|
|
907
|
+
'name': '2\'MOE-rA',
|
|
908
|
+
'weight': 387.29,
|
|
909
|
+
'normalized': 'rA',
|
|
910
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
|
|
911
|
+
},
|
|
912
|
+
'moe5mC': {
|
|
913
|
+
'name': '2\'MOE-5Me-rC',
|
|
914
|
+
'weight': 377.29,
|
|
915
|
+
'normalized': 'rC',
|
|
916
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
|
|
917
|
+
},
|
|
918
|
+
'(5m)moeC': {
|
|
919
|
+
'name': '2\'MOE-5Me-rC',
|
|
920
|
+
'weight': 377.29,
|
|
921
|
+
'normalized': 'rC',
|
|
922
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',
|
|
923
|
+
},
|
|
924
|
+
'moeG': {
|
|
925
|
+
'name': '2\'MOE-rG',
|
|
926
|
+
'weight': 403.28,
|
|
927
|
+
'normalized': 'rG',
|
|
928
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',
|
|
929
|
+
},
|
|
930
|
+
'5mC': {
|
|
931
|
+
'name': '5-Methyl-dC',
|
|
932
|
+
'weight': 303.28,
|
|
933
|
+
'normalized': 'dC',
|
|
934
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
|
|
935
|
+
},
|
|
936
|
+
'(5m)C': {
|
|
937
|
+
'name': '5-Methyl-dC',
|
|
938
|
+
'weight': 303.28,
|
|
939
|
+
'normalized': 'dC',
|
|
940
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',
|
|
941
|
+
},
|
|
942
|
+
'ps': {
|
|
943
|
+
'name': 'ps linkage',
|
|
944
|
+
'weight': 16.07,
|
|
945
|
+
'normalized': '',
|
|
946
|
+
'SMILES': 'OP(=O)(S)O',
|
|
947
|
+
},
|
|
948
|
+
'A': {
|
|
949
|
+
'name': 'Adenine',
|
|
950
|
+
'weight': 313.21,
|
|
951
|
+
'normalized': 'dA',
|
|
952
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
|
|
953
|
+
},
|
|
954
|
+
'dA': {
|
|
955
|
+
'name': 'Adenine',
|
|
956
|
+
'weight': 313.21,
|
|
957
|
+
'normalized': 'dA',
|
|
958
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',
|
|
959
|
+
},
|
|
960
|
+
'C': {
|
|
961
|
+
'name': 'Cytosine',
|
|
962
|
+
'weight': 289.18,
|
|
963
|
+
'normalized': 'dC',
|
|
964
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
|
|
965
|
+
},
|
|
966
|
+
'dC': {
|
|
967
|
+
'name': 'Cytosine',
|
|
968
|
+
'weight': 289.18,
|
|
969
|
+
'normalized': 'dC',
|
|
970
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',
|
|
971
|
+
},
|
|
972
|
+
'G': {
|
|
973
|
+
'name': 'Guanine',
|
|
974
|
+
'weight': 329.21,
|
|
975
|
+
'normalized': 'dG',
|
|
976
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
|
|
977
|
+
},
|
|
978
|
+
'dG': {
|
|
979
|
+
'name': 'Guanine',
|
|
980
|
+
'weight': 329.21,
|
|
981
|
+
'normalized': 'dG',
|
|
982
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',
|
|
983
|
+
},
|
|
984
|
+
'T': {
|
|
985
|
+
'name': 'Tyrosine',
|
|
986
|
+
'weight': 304.2,
|
|
987
|
+
'normalized': 'dT',
|
|
988
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
|
|
989
|
+
},
|
|
990
|
+
'dT': {
|
|
991
|
+
'name': 'Tyrosine',
|
|
992
|
+
'weight': 304.2,
|
|
993
|
+
'normalized': 'dT',
|
|
994
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',
|
|
995
|
+
},
|
|
996
|
+
'rA': {
|
|
997
|
+
'name': 'Adenine',
|
|
998
|
+
'weight': 329.21,
|
|
999
|
+
'normalized': 'rA',
|
|
1000
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',
|
|
1001
|
+
},
|
|
1002
|
+
'rC': {
|
|
1003
|
+
'name': 'Cytosine',
|
|
1004
|
+
'weight': 305.18,
|
|
1005
|
+
'normalized': 'rC',
|
|
1006
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',
|
|
1007
|
+
},
|
|
1008
|
+
'rG': {
|
|
1009
|
+
'name': 'Guanine',
|
|
1010
|
+
'weight': 345.21,
|
|
1011
|
+
'normalized': 'rG',
|
|
1012
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',
|
|
1013
|
+
},
|
|
1014
|
+
'rU': {
|
|
1015
|
+
'name': 'Uracil',
|
|
1016
|
+
'weight': 306.17,
|
|
1017
|
+
'normalized': 'rU',
|
|
1018
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',
|
|
1019
|
+
},
|
|
1020
|
+
},
|
|
1021
|
+
'For 2\'-OMe and 2\'-F modified siRNA': {
|
|
1022
|
+
'fU': {
|
|
1023
|
+
'name': '2\'-fluoro-U',
|
|
1024
|
+
'weight': 308.16,
|
|
1025
|
+
'normalized': 'rU',
|
|
1026
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
|
|
1027
|
+
},
|
|
1028
|
+
'fA': {
|
|
1029
|
+
'name': '2\'-fluoro-A',
|
|
1030
|
+
'weight': 331.2,
|
|
1031
|
+
'normalized': 'rA',
|
|
1032
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
|
|
1033
|
+
},
|
|
1034
|
+
'fC': {
|
|
1035
|
+
'name': '2\'-fluoro-C',
|
|
1036
|
+
'weight': 307.18,
|
|
1037
|
+
'normalized': 'rC',
|
|
1038
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
|
|
1039
|
+
},
|
|
1040
|
+
'fG': {
|
|
1041
|
+
'name': '2\'-fluoro-G',
|
|
1042
|
+
'weight': 347.19,
|
|
1043
|
+
'normalized': 'rG',
|
|
1044
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
|
|
1045
|
+
},
|
|
1046
|
+
'mU': {
|
|
1047
|
+
'name': '2\'OMe-rU',
|
|
1048
|
+
'weight': 320.2,
|
|
1049
|
+
'normalized': 'rU',
|
|
1050
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
|
|
1051
|
+
},
|
|
1052
|
+
'mA': {
|
|
1053
|
+
'name': '2\'OMe-rA',
|
|
1054
|
+
'weight': 343.24,
|
|
1055
|
+
'normalized': 'rA',
|
|
1056
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
1057
|
+
},
|
|
1058
|
+
'mC': {
|
|
1059
|
+
'name': '2\'OMe-rC',
|
|
1060
|
+
'weight': 319.21,
|
|
1061
|
+
'normalized': 'rC',
|
|
1062
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
|
|
1063
|
+
},
|
|
1064
|
+
'mG': {
|
|
1065
|
+
'name': '2\'OMe-rG',
|
|
1066
|
+
'weight': 359.24,
|
|
1067
|
+
'normalized': 'rG',
|
|
1068
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
1069
|
+
},
|
|
1070
|
+
},
|
|
1071
|
+
},
|
|
1072
|
+
'Mermade 12': {
|
|
1073
|
+
'For 2\'-OMe and 2\'-F modified siRNA': {
|
|
1074
|
+
'e': {
|
|
1075
|
+
'name': '2\'OMe-rA-ps',
|
|
1076
|
+
'weight': 359.31,
|
|
1077
|
+
'normalized': 'rA',
|
|
1078
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',
|
|
1079
|
+
},
|
|
1080
|
+
'h': {
|
|
1081
|
+
'name': '2\'OMe-rU-ps',
|
|
1082
|
+
'weight': 336.27,
|
|
1083
|
+
'normalized': 'rU',
|
|
1084
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',
|
|
1085
|
+
},
|
|
1086
|
+
'g': {
|
|
1087
|
+
'name': '2\'OMe-rG-ps',
|
|
1088
|
+
'weight': 375.31,
|
|
1089
|
+
'normalized': 'rG',
|
|
1090
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',
|
|
1091
|
+
},
|
|
1092
|
+
'f': {
|
|
1093
|
+
'name': '2\'OMe-rC-ps',
|
|
1094
|
+
'weight': 335.28,
|
|
1095
|
+
'normalized': 'rC',
|
|
1096
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',
|
|
1097
|
+
},
|
|
1098
|
+
'i': {
|
|
1099
|
+
'name': '2\'-fluoro-A-ps',
|
|
1100
|
+
'weight': 347.27,
|
|
1101
|
+
'normalized': 'rA',
|
|
1102
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',
|
|
1103
|
+
},
|
|
1104
|
+
'l': {
|
|
1105
|
+
'name': '2\'-fluoro-U-ps',
|
|
1106
|
+
'weight': 324.23,
|
|
1107
|
+
'normalized': 'rU',
|
|
1108
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',
|
|
1109
|
+
},
|
|
1110
|
+
'k': {
|
|
1111
|
+
'name': '2\'-fluoro-G-ps',
|
|
1112
|
+
'weight': 363.26,
|
|
1113
|
+
'normalized': 'rG',
|
|
1114
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',
|
|
1115
|
+
},
|
|
1116
|
+
'j': {
|
|
1117
|
+
'name': '2\'-fluoro-C-ps',
|
|
1118
|
+
'weight': 323.25,
|
|
1119
|
+
'normalized': 'rC',
|
|
1120
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',
|
|
1121
|
+
},
|
|
1122
|
+
'L': {
|
|
1123
|
+
'name': '2\'-fluoro-U',
|
|
1124
|
+
'weight': 308.16,
|
|
1125
|
+
'normalized': 'rU',
|
|
1126
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',
|
|
1127
|
+
},
|
|
1128
|
+
'I': {
|
|
1129
|
+
'name': '2\'-fluoro-A',
|
|
1130
|
+
'weight': 331.2,
|
|
1131
|
+
'normalized': 'rA',
|
|
1132
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',
|
|
1133
|
+
},
|
|
1134
|
+
'J': {
|
|
1135
|
+
'name': '2\'-fluoro-C',
|
|
1136
|
+
'weight': 307.18,
|
|
1137
|
+
'normalized': 'rC',
|
|
1138
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',
|
|
1139
|
+
},
|
|
1140
|
+
'K': {
|
|
1141
|
+
'name': '2\'-fluoro-G',
|
|
1142
|
+
'weight': 347.19,
|
|
1143
|
+
'normalized': 'rG',
|
|
1144
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',
|
|
1145
|
+
},
|
|
1146
|
+
'H': {
|
|
1147
|
+
'name': '2\'OMe-rU',
|
|
1148
|
+
'weight': 320.2,
|
|
1149
|
+
'normalized': 'rU',
|
|
1150
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',
|
|
1151
|
+
},
|
|
1152
|
+
'E': {
|
|
1153
|
+
'name': '2\'OMe-rA',
|
|
1154
|
+
'weight': 343.24,
|
|
1155
|
+
'normalized': 'rA',
|
|
1156
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
1157
|
+
},
|
|
1158
|
+
'F': {
|
|
1159
|
+
'name': '2\'OMe-rC',
|
|
1160
|
+
'weight': 319.21,
|
|
1161
|
+
'normalized': 'rC',
|
|
1162
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',
|
|
1163
|
+
},
|
|
1164
|
+
'G': {
|
|
1165
|
+
'name': '2\'OMe-rG',
|
|
1166
|
+
'weight': 359.24,
|
|
1167
|
+
'normalized': 'rG',
|
|
1168
|
+
'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',
|
|
1169
|
+
},
|
|
1170
|
+
},
|
|
1171
|
+
},
|
|
1172
|
+
};
|
|
1173
|
+
|
|
1174
|
+
|
|
1175
|
+
/***/ }),
|
|
1176
|
+
|
|
1177
|
+
/***/ "./src/structures-works/mol-transformations.ts":
|
|
1178
|
+
/*!*****************************************************!*\
|
|
1179
|
+
!*** ./src/structures-works/mol-transformations.ts ***!
|
|
1180
|
+
\*****************************************************/
|
|
1181
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
1182
|
+
|
|
1183
|
+
__webpack_require__.r(__webpack_exports__);
|
|
1184
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
1185
|
+
/* harmony export */ "getNucleotidesMol": () => (/* binding */ getNucleotidesMol),
|
|
1186
|
+
/* harmony export */ "linkV3000": () => (/* binding */ linkV3000)
|
|
1187
|
+
/* harmony export */ });
|
|
1188
|
+
/* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! openchemlib/full.js */ "openchemlib/full.js");
|
|
1189
|
+
/* harmony import */ var openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__);
|
|
1190
|
+
|
|
1191
|
+
const PHOSHATE = `
|
|
1192
|
+
Datagrok monomer library Nucleotides
|
|
1193
|
+
|
|
1194
|
+
0 0 0 0 0 0 0 V3000
|
|
1195
|
+
M V30 BEGIN CTAB
|
|
1196
|
+
M V30 COUNTS 5 4 0 0 0
|
|
1197
|
+
M V30 BEGIN ATOM
|
|
1198
|
+
M V30 1 O -1.5 0 0 0
|
|
1199
|
+
M V30 2 P 0 0 0 0
|
|
1200
|
+
M V30 3 O 0 1 0 0
|
|
1201
|
+
M V30 4 O 0 -1 0 0
|
|
1202
|
+
M V30 5 O 1.5 0 0 0
|
|
1203
|
+
M V30 END ATOM
|
|
1204
|
+
M V30 BEGIN BOND
|
|
1205
|
+
M V30 1 1 1 2
|
|
1206
|
+
M V30 2 2 2 3
|
|
1207
|
+
M V30 3 1 2 4
|
|
1208
|
+
M V30 4 1 2 5
|
|
1209
|
+
M V30 END BOND
|
|
1210
|
+
M V30 END CTAB
|
|
1211
|
+
M V30 BEGIN COLLECTION
|
|
1212
|
+
M V30 END COLLECTION
|
|
1213
|
+
M END`;
|
|
1214
|
+
const THIOPHOSHATE = `
|
|
1215
|
+
Datagrok monomer library Nucleotides
|
|
1216
|
+
|
|
1217
|
+
0 0 0 0 0 0 0 V3000
|
|
1218
|
+
M V30 BEGIN CTAB
|
|
1219
|
+
M V30 COUNTS 5 4 0 0 0
|
|
1220
|
+
M V30 BEGIN ATOM
|
|
1221
|
+
M V30 1 O -1.5 0 0 0
|
|
1222
|
+
M V30 2 P 0 0 0 0
|
|
1223
|
+
M V30 3 O 0 1 0 0
|
|
1224
|
+
M V30 4 S 0 -1 0 0
|
|
1225
|
+
M V30 5 O 1.5 0 0 0
|
|
1226
|
+
M V30 END ATOM
|
|
1227
|
+
M V30 BEGIN BOND
|
|
1228
|
+
M V30 1 1 1 2
|
|
1229
|
+
M V30 2 2 2 3
|
|
1230
|
+
M V30 3 1 2 4
|
|
1231
|
+
M V30 4 1 2 5
|
|
1232
|
+
M V30 END BOND
|
|
1233
|
+
M V30 END CTAB
|
|
1234
|
+
M V30 BEGIN COLLECTION
|
|
1235
|
+
M V30 END COLLECTION
|
|
1236
|
+
M END`;
|
|
1237
|
+
const INVABASIC = `
|
|
1238
|
+
Datagrok monomer library Nucleotides
|
|
1239
|
+
|
|
1240
|
+
0 0 0 0 0 0 0 V3000
|
|
1241
|
+
M V30 BEGIN CTAB
|
|
1242
|
+
M V30 COUNTS 8 8 0 0 0
|
|
1243
|
+
M V30 BEGIN ATOM
|
|
1244
|
+
M V30 1 O 1.0934 -2.1636 0 0
|
|
1245
|
+
M V30 2 C 1.8365 -1.4945 0 0 CFG=2
|
|
1246
|
+
M V30 3 C 2.8147 -1.7024 0 0
|
|
1247
|
+
M V30 4 C 3.3147 -0.8364 0 0 VAL=3
|
|
1248
|
+
M V30 5 O 2.6455 -0.0932 0 0
|
|
1249
|
+
M V30 6 C 1.732 -0.5 0 0 CFG=1
|
|
1250
|
+
M V30 7 C 0.866 0 0 0
|
|
1251
|
+
M V30 8 O 0.866 1 0 0
|
|
1252
|
+
M V30 END ATOM
|
|
1253
|
+
M V30 BEGIN BOND
|
|
1254
|
+
M V30 1 1 2 1 CFG=1
|
|
1255
|
+
M V30 2 1 2 3
|
|
1256
|
+
M V30 3 1 3 4
|
|
1257
|
+
M V30 4 1 4 5
|
|
1258
|
+
M V30 5 1 6 5
|
|
1259
|
+
M V30 6 1 2 6
|
|
1260
|
+
M V30 7 1 6 7 CFG=3
|
|
1261
|
+
M V30 8 1 7 8
|
|
1262
|
+
M V30 END BOND
|
|
1263
|
+
M V30 BEGIN COLLECTION
|
|
1264
|
+
M V30 MDLV30/STEABS ATOMS=(2 2 6)
|
|
1265
|
+
M V30 END COLLECTION
|
|
1266
|
+
M V30 END CTAB
|
|
1267
|
+
M END`;
|
|
1268
|
+
function getNucleotidesMol(smilesCodes, oclRender = false) {
|
|
1269
|
+
const molBlocks = [];
|
|
1270
|
+
for (let i = 0; i < smilesCodes.length - 1; i++) {
|
|
1271
|
+
smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :
|
|
1272
|
+
smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :
|
|
1273
|
+
smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :
|
|
1274
|
+
molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));
|
|
1275
|
+
}
|
|
1276
|
+
return linkV3000(molBlocks, false, oclRender);
|
|
1277
|
+
}
|
|
1278
|
+
function linkV3000(molBlocks, twoMolecules = false, oclRender = false) {
|
|
1279
|
+
let macroMolBlock = '\nDatagrok macromolecule handler\n\n';
|
|
1280
|
+
macroMolBlock += ' 0 0 0 0 0 0 999 V3000\n';
|
|
1281
|
+
macroMolBlock += 'M V30 BEGIN CTAB\n';
|
|
1282
|
+
let atomBlock = '';
|
|
1283
|
+
let bondBlock = '';
|
|
1284
|
+
let collectionBlock = '';
|
|
1285
|
+
const collection = [];
|
|
1286
|
+
let natom = 0;
|
|
1287
|
+
let nbond = 0;
|
|
1288
|
+
let sequenceShift = 0;
|
|
1289
|
+
let xShift = 0;
|
|
1290
|
+
if (twoMolecules && molBlocks.length > 1)
|
|
1291
|
+
molBlocks[1] = invertNucleotidesV3000(molBlocks[1]);
|
|
1292
|
+
for (let i = 0; i < molBlocks.length; i++) {
|
|
1293
|
+
molBlocks[i] = molBlocks[i].replaceAll('(-\nM V30 ', '(')
|
|
1294
|
+
.replaceAll('-\nM V30 ', '').replaceAll(' )', ')');
|
|
1295
|
+
const numbers = extractAtomsBondsNumbersV3000(molBlocks[i]);
|
|
1296
|
+
const coordinates = extractAtomDataV3000(molBlocks[i]);
|
|
1297
|
+
let indexAtoms = molBlocks[i].indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
|
|
1298
|
+
indexAtoms = molBlocks[i].indexOf('\n', indexAtoms);
|
|
1299
|
+
let index = indexAtoms;
|
|
1300
|
+
let indexEnd = indexAtoms;
|
|
1301
|
+
for (let j = 0; j < numbers.natom; j++) {
|
|
1302
|
+
if (coordinates.atomIndex[j] != 1 || i == 0 || twoMolecules) {
|
|
1303
|
+
//rewrite atom number
|
|
1304
|
+
index = molBlocks[i].indexOf('V30', index) + 4;
|
|
1305
|
+
indexEnd = molBlocks[i].indexOf(' ', index);
|
|
1306
|
+
const atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
|
|
1307
|
+
molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
|
|
1308
|
+
//rewrite coordinates
|
|
1309
|
+
index = molBlocks[i].indexOf(' ', index) + 1;
|
|
1310
|
+
index = molBlocks[i].indexOf(' ', index) + 1;
|
|
1311
|
+
indexEnd = molBlocks[i].indexOf(' ', index);
|
|
1312
|
+
const totalShift = xShift - coordinates.x[0];
|
|
1313
|
+
let coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + totalShift)) / 10000;
|
|
1314
|
+
molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);
|
|
1315
|
+
index = molBlocks[i].indexOf(' ', index) + 1;
|
|
1316
|
+
indexEnd = molBlocks[i].indexOf(' ', index);
|
|
1317
|
+
coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + sequenceShift)) / 10000;
|
|
1318
|
+
molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);
|
|
1319
|
+
index = molBlocks[i].indexOf('\n', index) + 1;
|
|
1320
|
+
}
|
|
1321
|
+
else {
|
|
1322
|
+
index = molBlocks[i].indexOf('M V30', index) - 1;
|
|
1323
|
+
indexEnd = molBlocks[i].indexOf('\n', index + 1);
|
|
1324
|
+
molBlocks[i] = molBlocks[i].slice(0, index) + molBlocks[i].slice(indexEnd);
|
|
1325
|
+
}
|
|
1326
|
+
}
|
|
1327
|
+
const indexAtomsEnd = molBlocks[i].indexOf('M V30 END ATOM');
|
|
1328
|
+
atomBlock += molBlocks[i].substring(indexAtoms + 1, indexAtomsEnd);
|
|
1329
|
+
let indexBonds = molBlocks[i].indexOf('M V30 BEGIN BOND'); // V3000 index for bonds
|
|
1330
|
+
indexBonds = molBlocks[i].indexOf('\n', indexBonds);
|
|
1331
|
+
index = indexBonds;
|
|
1332
|
+
indexEnd = indexBonds;
|
|
1333
|
+
for (let j = 0; j < numbers.nbond; j++) {
|
|
1334
|
+
//rewrite bond number
|
|
1335
|
+
index = molBlocks[i].indexOf('V30', index) + 4;
|
|
1336
|
+
indexEnd = molBlocks[i].indexOf(' ', index);
|
|
1337
|
+
const bondNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + nbond;
|
|
1338
|
+
molBlocks[i] = molBlocks[i].slice(0, index) + bondNumber + molBlocks[i].slice(indexEnd);
|
|
1339
|
+
//rewrite atom pair in bond
|
|
1340
|
+
index = molBlocks[i].indexOf(' ', index) + 1;
|
|
1341
|
+
index = molBlocks[i].indexOf(' ', index) + 1;
|
|
1342
|
+
indexEnd = molBlocks[i].indexOf(' ', index);
|
|
1343
|
+
let atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
|
|
1344
|
+
molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
|
|
1345
|
+
index = molBlocks[i].indexOf(' ', index) + 1;
|
|
1346
|
+
indexEnd = Math.min(molBlocks[i].indexOf('\n', index), molBlocks[i].indexOf(' ', index));
|
|
1347
|
+
atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;
|
|
1348
|
+
molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);
|
|
1349
|
+
index = molBlocks[i].indexOf('\n', index) + 1;
|
|
1350
|
+
}
|
|
1351
|
+
const indexBondEnd = molBlocks[i].indexOf('M V30 END BOND');
|
|
1352
|
+
bondBlock += molBlocks[i].substring(indexBonds + 1, indexBondEnd);
|
|
1353
|
+
let indexCollection = molBlocks[i].indexOf('M V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections
|
|
1354
|
+
while (indexCollection != -1) {
|
|
1355
|
+
indexCollection += 28;
|
|
1356
|
+
const collectionEnd = molBlocks[i].indexOf(')', indexCollection);
|
|
1357
|
+
const collectionEntries = molBlocks[i].substring(indexCollection, collectionEnd).split(' ').slice(1);
|
|
1358
|
+
collectionEntries.forEach((e) => {
|
|
1359
|
+
collection.push(parseInt(e) + natom);
|
|
1360
|
+
});
|
|
1361
|
+
indexCollection = collectionEnd;
|
|
1362
|
+
indexCollection = molBlocks[i].indexOf('M V30 MDLV30/STEABS ATOMS=(', indexCollection);
|
|
1363
|
+
}
|
|
1364
|
+
natom += twoMolecules ? numbers.natom : numbers.natom - 1;
|
|
1365
|
+
nbond += numbers.nbond;
|
|
1366
|
+
xShift += twoMolecules ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[0];
|
|
1367
|
+
sequenceShift += twoMolecules ? -7 : 0;
|
|
1368
|
+
}
|
|
1369
|
+
const entries = 4;
|
|
1370
|
+
const collNumber = Math.ceil(collection.length / entries);
|
|
1371
|
+
if (oclRender) {
|
|
1372
|
+
collectionBlock += 'M V30 MDLV30/STEABS ATOMS=(' + collection.length;
|
|
1373
|
+
for (let j = 0; j < collection.length; j++)
|
|
1374
|
+
collectionBlock += ' ' + collection[j];
|
|
1375
|
+
collectionBlock += ')\n';
|
|
1376
|
+
}
|
|
1377
|
+
else {
|
|
1378
|
+
collectionBlock += 'M V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\n';
|
|
1379
|
+
for (let i = 0; i < collNumber; i++) {
|
|
1380
|
+
collectionBlock += 'M V30 ';
|
|
1381
|
+
const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1) * entries : entries;
|
|
1382
|
+
for (let j = 0; j < entriesCurrent; j++) {
|
|
1383
|
+
collectionBlock += (j + 1 == entriesCurrent) ?
|
|
1384
|
+
(i == collNumber - 1 ? collection[entries * i + j] + ')\n' : collection[entries * i + j] + ' -\n') :
|
|
1385
|
+
collection[entries * i + j] + ' ';
|
|
1386
|
+
}
|
|
1387
|
+
}
|
|
1388
|
+
}
|
|
1389
|
+
//generate file
|
|
1390
|
+
twoMolecules ? natom : natom++;
|
|
1391
|
+
macroMolBlock += 'M V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\n';
|
|
1392
|
+
macroMolBlock += 'M V30 BEGIN ATOM\n';
|
|
1393
|
+
macroMolBlock += atomBlock;
|
|
1394
|
+
macroMolBlock += 'M V30 END ATOM\n';
|
|
1395
|
+
macroMolBlock += 'M V30 BEGIN BOND\n';
|
|
1396
|
+
macroMolBlock += bondBlock;
|
|
1397
|
+
macroMolBlock += 'M V30 END BOND\n';
|
|
1398
|
+
macroMolBlock += 'M V30 BEGIN COLLECTION\n';
|
|
1399
|
+
macroMolBlock += collectionBlock;
|
|
1400
|
+
macroMolBlock += 'M V30 END COLLECTION\n';
|
|
1401
|
+
macroMolBlock += 'M V30 END CTAB\n';
|
|
1402
|
+
macroMolBlock += 'M END\n';
|
|
1403
|
+
return macroMolBlock;
|
|
1404
|
+
}
|
|
1405
|
+
function rotateNucleotidesV3000(molecule) {
|
|
1406
|
+
let molBlock = molecule.includes('M END') ? molecule : openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__.Molecule.fromSmiles(molecule).toMolfileV3();
|
|
1407
|
+
const coordinates = extractAtomDataV3000(molBlock);
|
|
1408
|
+
const natom = coordinates.atomIndex.length;
|
|
1409
|
+
const indexFivePrime = coordinates.atomIndex.indexOf(1);
|
|
1410
|
+
const indexThreePrime = coordinates.atomIndex.indexOf(natom);
|
|
1411
|
+
//fix 5 prime if inadequate
|
|
1412
|
+
if (natom > 8)
|
|
1413
|
+
fix5Prime(coordinates, indexFivePrime, indexThreePrime);
|
|
1414
|
+
const xCenter = (coordinates.x[indexThreePrime] + coordinates.x[indexFivePrime]) / 2;
|
|
1415
|
+
const yCenter = (coordinates.y[indexThreePrime] + coordinates.y[indexFivePrime]) / 2;
|
|
1416
|
+
//place to center
|
|
1417
|
+
for (let i = 0; i < natom; i++) {
|
|
1418
|
+
coordinates.x[i] -= xCenter;
|
|
1419
|
+
coordinates.y[i] -= yCenter;
|
|
1420
|
+
}
|
|
1421
|
+
let angle = 0;
|
|
1422
|
+
if (coordinates.x[indexFivePrime] == 0)
|
|
1423
|
+
angle = coordinates.y[indexFivePrime] > coordinates.y[indexThreePrime] ? Math.PI / 2 : 3 * Math.PI / 2;
|
|
1424
|
+
else if (coordinates.y[indexFivePrime] == 0)
|
|
1425
|
+
angle = coordinates.x[indexFivePrime] > coordinates.x[indexThreePrime] ? Math.PI : 0;
|
|
1426
|
+
else {
|
|
1427
|
+
const derivative = coordinates.y[indexFivePrime] / coordinates.x[indexFivePrime];
|
|
1428
|
+
angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);
|
|
1429
|
+
}
|
|
1430
|
+
const cos = Math.cos(angle);
|
|
1431
|
+
const sin = Math.sin(angle);
|
|
1432
|
+
for (let i = 0; i < natom; i++) {
|
|
1433
|
+
const xAdd = coordinates.x[i];
|
|
1434
|
+
coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;
|
|
1435
|
+
coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;
|
|
1436
|
+
}
|
|
1437
|
+
//place to right
|
|
1438
|
+
const xShift = coordinates.x[indexFivePrime];
|
|
1439
|
+
for (let i = 0; i < natom; i++)
|
|
1440
|
+
coordinates.x[i] -= xShift;
|
|
1441
|
+
//rewrite molBlock
|
|
1442
|
+
let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
|
|
1443
|
+
index = molBlock.indexOf('\n', index);
|
|
1444
|
+
let indexEnd = index;
|
|
1445
|
+
for (let i = 0; i < natom; i++) {
|
|
1446
|
+
index = molBlock.indexOf('V30', index) + 4;
|
|
1447
|
+
index = molBlock.indexOf(' ', index) + 1;
|
|
1448
|
+
index = molBlock.indexOf(' ', index) + 1;
|
|
1449
|
+
indexEnd = molBlock.indexOf(' ', index) + 1;
|
|
1450
|
+
indexEnd = molBlock.indexOf(' ', indexEnd);
|
|
1451
|
+
molBlock = molBlock.slice(0, index) +
|
|
1452
|
+
coordinates.x[i] + ' ' + coordinates.y[i] +
|
|
1453
|
+
molBlock.slice(indexEnd);
|
|
1454
|
+
index = molBlock.indexOf('\n', index) + 1;
|
|
1455
|
+
}
|
|
1456
|
+
return molBlock;
|
|
1457
|
+
}
|
|
1458
|
+
function invertNucleotidesV3000(molecule) {
|
|
1459
|
+
let molBlock = molecule.includes('M END') ? molecule : openchemlib_full_js__WEBPACK_IMPORTED_MODULE_0__.Molecule.fromSmiles(molecule).toMolfileV3();
|
|
1460
|
+
const coordinates = extractAtomDataV3000(molBlock);
|
|
1461
|
+
const natom = coordinates.atomIndex.length;
|
|
1462
|
+
const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;
|
|
1463
|
+
const yCenter = (Math.max(...coordinates.y) + Math.min(...coordinates.y)) / 2;
|
|
1464
|
+
//place to center
|
|
1465
|
+
for (let i = 0; i < natom; i++) {
|
|
1466
|
+
coordinates.x[i] -= xCenter;
|
|
1467
|
+
coordinates.y[i] -= yCenter;
|
|
1468
|
+
}
|
|
1469
|
+
const angle = Math.PI;
|
|
1470
|
+
const cos = Math.cos(angle);
|
|
1471
|
+
const sin = Math.sin(angle);
|
|
1472
|
+
for (let i = 0; i < natom; i++) {
|
|
1473
|
+
const xAdd = coordinates.x[i];
|
|
1474
|
+
coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;
|
|
1475
|
+
coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;
|
|
1476
|
+
}
|
|
1477
|
+
//place back
|
|
1478
|
+
const yShift = Math.max(...coordinates.y);
|
|
1479
|
+
for (let i = 0; i < natom; i++) {
|
|
1480
|
+
coordinates.x[i] += xCenter;
|
|
1481
|
+
coordinates.y[i] -= yShift;
|
|
1482
|
+
}
|
|
1483
|
+
//rewrite molBlock
|
|
1484
|
+
let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
|
|
1485
|
+
index = molBlock.indexOf('\n', index);
|
|
1486
|
+
let indexEnd = index;
|
|
1487
|
+
for (let i = 0; i < natom; i++) {
|
|
1488
|
+
index = molBlock.indexOf('V30', index) + 4;
|
|
1489
|
+
index = molBlock.indexOf(' ', index) + 1;
|
|
1490
|
+
index = molBlock.indexOf(' ', index) + 1;
|
|
1491
|
+
indexEnd = molBlock.indexOf(' ', index) + 1;
|
|
1492
|
+
indexEnd = molBlock.indexOf(' ', indexEnd);
|
|
1493
|
+
molBlock = molBlock.slice(0, index) +
|
|
1494
|
+
coordinates.x[i] + ' ' + coordinates.y[i] +
|
|
1495
|
+
molBlock.slice(indexEnd);
|
|
1496
|
+
index = molBlock.indexOf('\n', index) + 1;
|
|
1497
|
+
}
|
|
1498
|
+
return molBlock;
|
|
1499
|
+
}
|
|
1500
|
+
function fix5Prime(coordinates, indexFivePrime, indexThreePrime) {
|
|
1501
|
+
const indexFivePrimeNeighbour = indexFivePrime + 1;
|
|
1502
|
+
const xShift = coordinates.x[indexFivePrimeNeighbour];
|
|
1503
|
+
const yShift = coordinates.y[indexFivePrimeNeighbour];
|
|
1504
|
+
const base3PrimeX = coordinates.x[indexThreePrime] - xShift;
|
|
1505
|
+
const base3PrimeY = coordinates.y[indexThreePrime] - yShift;
|
|
1506
|
+
const base5PrimeX = coordinates.x[indexFivePrime] - xShift;
|
|
1507
|
+
const base5PrimeY = coordinates.y[indexFivePrime] - yShift;
|
|
1508
|
+
const rotated5PrimeX = base5PrimeX * Math.cos(Math.PI * 2 / 3) - base5PrimeY * Math.sin(Math.PI * 2 / 3);
|
|
1509
|
+
const rotated5PrimeY = base5PrimeX * Math.sin(Math.PI * 2 / 3) + base5PrimeY * Math.cos(Math.PI * 2 / 3);
|
|
1510
|
+
const dx = base5PrimeX - base3PrimeX;
|
|
1511
|
+
const dy = base5PrimeY - base3PrimeY;
|
|
1512
|
+
const dxRotated = rotated5PrimeX - base3PrimeX;
|
|
1513
|
+
const dyRotated = rotated5PrimeY - base3PrimeY;
|
|
1514
|
+
if (Math.sqrt(dyRotated * dyRotated + dxRotated * dxRotated) >= Math.sqrt(dy * dy + dx * dx)) {
|
|
1515
|
+
coordinates.x[indexFivePrime] = rotated5PrimeX + xShift;
|
|
1516
|
+
coordinates.y[indexFivePrime] = rotated5PrimeY + yShift;
|
|
1517
|
+
}
|
|
1518
|
+
}
|
|
1519
|
+
function extractAtomsBondsNumbersV3000(molBlock) {
|
|
1520
|
+
molBlock = molBlock.replaceAll('\r', ''); //equalize old and new sdf standards
|
|
1521
|
+
let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number
|
|
1522
|
+
let indexEnd = molBlock.indexOf(' ', index);
|
|
1523
|
+
const atomsNumber = parseInt(molBlock.substring(index, indexEnd));
|
|
1524
|
+
index = indexEnd + 1;
|
|
1525
|
+
indexEnd = molBlock.indexOf(' ', index);
|
|
1526
|
+
const bondsNumber = parseInt(molBlock.substring(index, indexEnd));
|
|
1527
|
+
return { natom: atomsNumber, nbond: bondsNumber };
|
|
1528
|
+
}
|
|
1529
|
+
function extractAtomDataV3000(molBlock) {
|
|
1530
|
+
const numbers = extractAtomsBondsNumbersV3000(molBlock);
|
|
1531
|
+
let index = molBlock.indexOf('M V30 BEGIN ATOM'); // V3000 index for atoms coordinates
|
|
1532
|
+
index = molBlock.indexOf('\n', index);
|
|
1533
|
+
let indexEnd = index;
|
|
1534
|
+
const indexes = Array(numbers.natom);
|
|
1535
|
+
const types = Array(numbers.natom);
|
|
1536
|
+
const x = Array(numbers.natom);
|
|
1537
|
+
const y = Array(numbers.natom);
|
|
1538
|
+
for (let i = 0; i < numbers.natom; i++) {
|
|
1539
|
+
index = molBlock.indexOf('V30', index) + 4;
|
|
1540
|
+
indexEnd = molBlock.indexOf(' ', index);
|
|
1541
|
+
indexes[i] = parseInt(molBlock.substring(index, indexEnd));
|
|
1542
|
+
index = indexEnd + 1;
|
|
1543
|
+
indexEnd = molBlock.indexOf(' ', index);
|
|
1544
|
+
types[i] = molBlock.substring(index, indexEnd);
|
|
1545
|
+
index = indexEnd + 1;
|
|
1546
|
+
indexEnd = molBlock.indexOf(' ', index);
|
|
1547
|
+
x[i] = parseFloat(molBlock.substring(index, indexEnd));
|
|
1548
|
+
index = indexEnd + 1;
|
|
1549
|
+
indexEnd = molBlock.indexOf(' ', index);
|
|
1550
|
+
y[i] = parseFloat(molBlock.substring(index, indexEnd));
|
|
1551
|
+
index = molBlock.indexOf('\n', index) + 1;
|
|
1552
|
+
}
|
|
1553
|
+
return { atomIndex: indexes, atomType: types, x: x, y: y };
|
|
1554
|
+
}
|
|
1555
|
+
|
|
1556
|
+
|
|
1557
|
+
/***/ }),
|
|
1558
|
+
|
|
1559
|
+
/***/ "./src/structures-works/sequence-codes-tools.ts":
|
|
1560
|
+
/*!******************************************************!*\
|
|
1561
|
+
!*** ./src/structures-works/sequence-codes-tools.ts ***!
|
|
1562
|
+
\******************************************************/
|
|
1563
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
1564
|
+
|
|
1565
|
+
__webpack_require__.r(__webpack_exports__);
|
|
1566
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
1567
|
+
/* harmony export */ "undefinedInputSequence": () => (/* binding */ undefinedInputSequence),
|
|
1568
|
+
/* harmony export */ "isValidSequence": () => (/* binding */ isValidSequence),
|
|
1569
|
+
/* harmony export */ "convertSequence": () => (/* binding */ convertSequence)
|
|
1570
|
+
/* harmony export */ });
|
|
1571
|
+
/* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/grok */ "datagrok-api/grok");
|
|
1572
|
+
/* harmony import */ var datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__);
|
|
1573
|
+
/* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! datagrok-api/ui */ "datagrok-api/ui");
|
|
1574
|
+
/* harmony import */ var datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__);
|
|
1575
|
+
/* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./map */ "./src/structures-works/map.ts");
|
|
1576
|
+
/* harmony import */ var _converters__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./converters */ "./src/structures-works/converters.ts");
|
|
1577
|
+
|
|
1578
|
+
|
|
1579
|
+
// import * as DG from 'datagrok-api/dg';
|
|
1580
|
+
|
|
1581
|
+
|
|
1582
|
+
const noTranslationTableAvailable = 'No translation table available';
|
|
1583
|
+
const undefinedInputSequence = 'Type of input sequence is undefined';
|
|
1584
|
+
function isValidSequence(sequence) {
|
|
1585
|
+
let possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);
|
|
1586
|
+
if (possibleSynthesizers.length > 1) {
|
|
1587
|
+
const synthesizer = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0], possibleSynthesizers);
|
|
1588
|
+
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Choose Synthesizer')
|
|
1589
|
+
.add(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.panel([synthesizer.root], { style: { fontWeight: 'bold' } }))
|
|
1590
|
+
.onOK(() => possibleSynthesizers = [synthesizer.value])
|
|
1591
|
+
.onCancel(() => {
|
|
1592
|
+
possibleSynthesizers = [possibleSynthesizers[0]];
|
|
1593
|
+
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.warning('Input sequence is expected to be in format ' + possibleSynthesizers[0]);
|
|
1594
|
+
})
|
|
1595
|
+
.show();
|
|
1596
|
+
}
|
|
1597
|
+
else if (possibleSynthesizers.length == 0)
|
|
1598
|
+
return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };
|
|
1599
|
+
let outputIndex = 0;
|
|
1600
|
+
const firstUniqueCharacters = ['r', 'd'];
|
|
1601
|
+
const nucleotides = ['A', 'U', 'T', 'C', 'G'];
|
|
1602
|
+
possibleSynthesizers.forEach((synthesizer) => {
|
|
1603
|
+
const codes = getAllCodesOfSynthesizer(synthesizer);
|
|
1604
|
+
while (outputIndex < sequence.length) {
|
|
1605
|
+
const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
|
|
1606
|
+
if (matchedCode == null)
|
|
1607
|
+
break;
|
|
1608
|
+
if ( // for mistake pattern 'rAA'
|
|
1609
|
+
outputIndex > 1 &&
|
|
1610
|
+
nucleotides.includes(sequence[outputIndex]) &&
|
|
1611
|
+
firstUniqueCharacters.includes(sequence[outputIndex - 2]))
|
|
1612
|
+
break;
|
|
1613
|
+
if ( // for mistake pattern 'ArA'
|
|
1614
|
+
firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
|
|
1615
|
+
nucleotides.includes(sequence[outputIndex])) {
|
|
1616
|
+
outputIndex++;
|
|
1617
|
+
break;
|
|
1618
|
+
}
|
|
1619
|
+
outputIndex += matchedCode.length;
|
|
1620
|
+
}
|
|
1621
|
+
});
|
|
1622
|
+
const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;
|
|
1623
|
+
if (indexOfFirstNotValidChar != -1) {
|
|
1624
|
+
return {
|
|
1625
|
+
indexOfFirstNotValidChar: indexOfFirstNotValidChar,
|
|
1626
|
+
synthesizer: possibleSynthesizers[0],
|
|
1627
|
+
technology: null,
|
|
1628
|
+
};
|
|
1629
|
+
}
|
|
1630
|
+
let possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);
|
|
1631
|
+
if (possibleTechnologies.length > 1) {
|
|
1632
|
+
const technology = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.choiceInput('Choose technology from list: ', possibleTechnologies[0], possibleTechnologies);
|
|
1633
|
+
datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.dialog('Choose Technology')
|
|
1634
|
+
.add(datagrok_api_ui__WEBPACK_IMPORTED_MODULE_1__.panel([technology.root], { style: { fontWeight: 'bold' } }))
|
|
1635
|
+
.onOK(() => possibleTechnologies = [technology.value])
|
|
1636
|
+
.onCancel(() => {
|
|
1637
|
+
possibleTechnologies = [possibleTechnologies[0]];
|
|
1638
|
+
datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);
|
|
1639
|
+
})
|
|
1640
|
+
.show();
|
|
1641
|
+
}
|
|
1642
|
+
else if (possibleTechnologies.length == 0)
|
|
1643
|
+
return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };
|
|
1644
|
+
outputIndex = 0;
|
|
1645
|
+
possibleTechnologies.forEach((technology) => {
|
|
1646
|
+
const codes = Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[possibleSynthesizers[0]][technology]);
|
|
1647
|
+
while (outputIndex < sequence.length) {
|
|
1648
|
+
const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));
|
|
1649
|
+
if (matchedCode == null)
|
|
1650
|
+
break;
|
|
1651
|
+
if ( // for mistake pattern 'rAA'
|
|
1652
|
+
outputIndex > 1 &&
|
|
1653
|
+
nucleotides.includes(sequence[outputIndex]) &&
|
|
1654
|
+
firstUniqueCharacters.includes(sequence[outputIndex - 2]))
|
|
1655
|
+
break;
|
|
1656
|
+
if ( // for mistake pattern 'ArA'
|
|
1657
|
+
firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&
|
|
1658
|
+
nucleotides.includes(sequence[outputIndex])) {
|
|
1659
|
+
outputIndex++;
|
|
1660
|
+
break;
|
|
1661
|
+
}
|
|
1662
|
+
outputIndex += matchedCode.length;
|
|
1663
|
+
}
|
|
1664
|
+
});
|
|
1665
|
+
return {
|
|
1666
|
+
indexOfFirstNotValidChar: indexOfFirstNotValidChar,
|
|
1667
|
+
synthesizer: possibleSynthesizers[0],
|
|
1668
|
+
technology: possibleTechnologies[outputIndex],
|
|
1669
|
+
};
|
|
1670
|
+
}
|
|
1671
|
+
function getAllCodesOfSynthesizer(synthesizer) {
|
|
1672
|
+
let codes = [];
|
|
1673
|
+
for (const technology of Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[synthesizer]))
|
|
1674
|
+
codes = codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[synthesizer][technology]));
|
|
1675
|
+
return codes.concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.MODIFICATIONS));
|
|
1676
|
+
}
|
|
1677
|
+
function getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {
|
|
1678
|
+
const synthesizers = [];
|
|
1679
|
+
Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map).forEach((synthesizer) => {
|
|
1680
|
+
const codes = getAllCodesOfSynthesizer(synthesizer);
|
|
1681
|
+
//TODO: get first non-dropdown code when there are two modifications
|
|
1682
|
+
let start = 0;
|
|
1683
|
+
for (let i = 0; i < sequence.length; i++) {
|
|
1684
|
+
if (sequence[i] == ')' && i != sequence.length - 1) {
|
|
1685
|
+
start = i + 1;
|
|
1686
|
+
break;
|
|
1687
|
+
}
|
|
1688
|
+
}
|
|
1689
|
+
if (codes.some((s) => s == sequence.slice(start, start + s.length)))
|
|
1690
|
+
synthesizers.push(synthesizer);
|
|
1691
|
+
});
|
|
1692
|
+
return synthesizers;
|
|
1693
|
+
}
|
|
1694
|
+
function getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {
|
|
1695
|
+
const technologies = [];
|
|
1696
|
+
Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[synthesizer]).forEach((technology) => {
|
|
1697
|
+
const codes = Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.map[synthesizer][technology]).concat(Object.keys(_map__WEBPACK_IMPORTED_MODULE_2__.MODIFICATIONS));
|
|
1698
|
+
if (codes.some((s) => s == sequence.slice(0, s.length)))
|
|
1699
|
+
technologies.push(technology);
|
|
1700
|
+
});
|
|
1701
|
+
return technologies;
|
|
1702
|
+
}
|
|
1703
|
+
function convertSequence(sequence, output) {
|
|
1704
|
+
if (output.indexOfFirstNotValidChar != -1) {
|
|
1705
|
+
return {
|
|
1706
|
+
// type: '',
|
|
1707
|
+
indexOfFirstNotValidChar: JSON.stringify(output),
|
|
1708
|
+
Error: undefinedInputSequence,
|
|
1709
|
+
};
|
|
1710
|
+
}
|
|
1711
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.DNA) {
|
|
1712
|
+
return {
|
|
1713
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.DNA,
|
|
1714
|
+
Nucleotides: sequence,
|
|
1715
|
+
BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersNucleotidesToBioSpring)(sequence),
|
|
1716
|
+
GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersNucleotidesToGcrs)(sequence),
|
|
1717
|
+
};
|
|
1718
|
+
}
|
|
1719
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.BIOSPRING && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.ASO_GAPMERS) {
|
|
1720
|
+
return {
|
|
1721
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.BIOSPRING + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.ASO_GAPMERS,
|
|
1722
|
+
Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersBioSpringToNucleotides)(sequence),
|
|
1723
|
+
BioSpring: sequence,
|
|
1724
|
+
GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersBioSpringToGcrs)(sequence),
|
|
1725
|
+
};
|
|
1726
|
+
}
|
|
1727
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.ASO_GAPMERS) {
|
|
1728
|
+
return {
|
|
1729
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.ASO_GAPMERS,
|
|
1730
|
+
Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersGcrsToNucleotides)(sequence),
|
|
1731
|
+
BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.asoGapmersGcrsToBioSpring)(sequence),
|
|
1732
|
+
Mermade12: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToMermade12)(sequence),
|
|
1733
|
+
GCRS: sequence,
|
|
1734
|
+
};
|
|
1735
|
+
}
|
|
1736
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.RNA) {
|
|
1737
|
+
return {
|
|
1738
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.RNA,
|
|
1739
|
+
Nucleotides: sequence,
|
|
1740
|
+
BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaNucleotideToBioSpringSenseStrand)(sequence),
|
|
1741
|
+
Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaNucleotideToAxolabsSenseStrand)(sequence),
|
|
1742
|
+
GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaNucleotidesToGcrs)(sequence),
|
|
1743
|
+
};
|
|
1744
|
+
}
|
|
1745
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.BIOSPRING && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA) {
|
|
1746
|
+
return {
|
|
1747
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.BIOSPRING + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA,
|
|
1748
|
+
Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaBioSpringToNucleotides)(sequence),
|
|
1749
|
+
BioSpring: sequence,
|
|
1750
|
+
Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaBioSpringToAxolabs)(sequence),
|
|
1751
|
+
GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaBioSpringToGcrs)(sequence),
|
|
1752
|
+
};
|
|
1753
|
+
}
|
|
1754
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA) {
|
|
1755
|
+
return {
|
|
1756
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.AXOLABS + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA,
|
|
1757
|
+
Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToNucleotides)(sequence),
|
|
1758
|
+
BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToBioSpring)(sequence),
|
|
1759
|
+
Axolabs: sequence,
|
|
1760
|
+
GCRS: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaAxolabsToGcrs)(sequence),
|
|
1761
|
+
};
|
|
1762
|
+
}
|
|
1763
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS && output.technology == _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA) {
|
|
1764
|
+
return {
|
|
1765
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS + ' ' + _map__WEBPACK_IMPORTED_MODULE_2__.TECHNOLOGIES.SI_RNA,
|
|
1766
|
+
Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaGcrsToNucleotides)(sequence),
|
|
1767
|
+
BioSpring: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaGcrsToBioSpring)(sequence),
|
|
1768
|
+
Axolabs: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.siRnaGcrsToAxolabs)(sequence),
|
|
1769
|
+
MM12: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToMermade12)(sequence),
|
|
1770
|
+
GCRS: sequence,
|
|
1771
|
+
};
|
|
1772
|
+
}
|
|
1773
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS) {
|
|
1774
|
+
return {
|
|
1775
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.GCRS,
|
|
1776
|
+
Nucleotides: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToNucleotides)(sequence),
|
|
1777
|
+
GCRS: sequence,
|
|
1778
|
+
Mermade12: (0,_converters__WEBPACK_IMPORTED_MODULE_3__.gcrsToMermade12)(sequence),
|
|
1779
|
+
};
|
|
1780
|
+
}
|
|
1781
|
+
if (output.synthesizer == _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.MERMADE_12) {
|
|
1782
|
+
return {
|
|
1783
|
+
type: _map__WEBPACK_IMPORTED_MODULE_2__.SYNTHESIZERS.MERMADE_12,
|
|
1784
|
+
Nucleotides: noTranslationTableAvailable,
|
|
1785
|
+
GCRS: noTranslationTableAvailable,
|
|
1786
|
+
Mermade12: sequence,
|
|
1787
|
+
};
|
|
1788
|
+
}
|
|
1789
|
+
return {
|
|
1790
|
+
type: undefinedInputSequence,
|
|
1791
|
+
Nucleotides: undefinedInputSequence,
|
|
1792
|
+
};
|
|
1793
|
+
}
|
|
1794
|
+
|
|
1795
|
+
|
|
1796
|
+
/***/ }),
|
|
1797
|
+
|
|
1798
|
+
/***/ "./src/tests/smiles-tests.ts":
|
|
1799
|
+
/*!***********************************!*\
|
|
1800
|
+
!*** ./src/tests/smiles-tests.ts ***!
|
|
1801
|
+
\***********************************/
|
|
1802
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
1803
|
+
|
|
1804
|
+
__webpack_require__.r(__webpack_exports__);
|
|
1805
|
+
/* harmony import */ var _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @datagrok-libraries/utils/src/test */ "./node_modules/@datagrok-libraries/utils/src/test.js");
|
|
1806
|
+
/* harmony import */ var _structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../structures-works/from-monomers */ "./src/structures-works/from-monomers.ts");
|
|
1807
|
+
var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
1808
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
1809
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
1810
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
1811
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
1812
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
1813
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
1814
|
+
});
|
|
1815
|
+
};
|
|
1816
|
+
|
|
1817
|
+
|
|
1818
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.category)('sequence-translator', () => {
|
|
1819
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('AGGTCCTCTTGACTTAGGCC', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1820
|
+
const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
|
|
1821
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1822
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1823
|
+
'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1824
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1825
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1826
|
+
'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1827
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1828
|
+
'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1829
|
+
'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1830
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1831
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
|
|
1832
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1833
|
+
'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1834
|
+
'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +
|
|
1835
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +
|
|
1836
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1837
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1838
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O';
|
|
1839
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('AGGTCCTCTTGACTTAGGCC'), expected);
|
|
1840
|
+
}));
|
|
1841
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac1', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1842
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
1843
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1844
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1845
|
+
'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
1846
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
1847
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
1848
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
1849
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgg(invabasic)(GalNAc-2-JNJ)'), expected);
|
|
1850
|
+
}));
|
|
1851
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac2', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1852
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
1853
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1854
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1855
|
+
'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
1856
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
1857
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
1858
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
1859
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgsg(invabasic)(GalNAc-2-JNJ)'), expected);
|
|
1860
|
+
}));
|
|
1861
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac3', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1862
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
1863
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1864
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1865
|
+
'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
1866
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
1867
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
1868
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
1869
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sggs(invabasic)(GalNAc-2-JNJ)'), expected);
|
|
1870
|
+
}));
|
|
1871
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('invabasic/galnac4', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1872
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
1873
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1874
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1875
|
+
'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
1876
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
1877
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
1878
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
1879
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sgg(invabasic)s(GalNAc-2-JNJ)'), expected);
|
|
1880
|
+
}));
|
|
1881
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('usCfCfUfGfAf', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1882
|
+
const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1883
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1884
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1885
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1886
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1887
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O';
|
|
1888
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('usCfCfUfGfAf'), expected);
|
|
1889
|
+
}));
|
|
1890
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('usAfsusgsgsg', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1891
|
+
const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1892
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
|
|
1893
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1894
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1895
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1896
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
|
|
1897
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('usAfsusgsgsg'), expected);
|
|
1898
|
+
}));
|
|
1899
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('UfUfUfsCfsuacg', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1900
|
+
const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1901
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1902
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
|
|
1903
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
|
|
1904
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1905
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1906
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1907
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
|
|
1908
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('UfUfUfsCfsuacg'), expected);
|
|
1909
|
+
}));
|
|
1910
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('susususauasu', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1911
|
+
const expected = 'OP(=O)(S)OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1912
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1913
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1914
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1915
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1916
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1917
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';
|
|
1918
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('susususauasu'), expected);
|
|
1919
|
+
}));
|
|
1920
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('CfGfCfsGfsCf', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1921
|
+
const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1922
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1923
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
|
|
1924
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
|
|
1925
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O';
|
|
1926
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('CfGfCfsGfsCf'), expected);
|
|
1927
|
+
}));
|
|
1928
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('acacacsacsac', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1929
|
+
const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1930
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1931
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1932
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1933
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1934
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1935
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1936
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1937
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1938
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';
|
|
1939
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('acacacsacsac'), expected);
|
|
1940
|
+
}));
|
|
1941
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('cccgggusug', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1942
|
+
const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1943
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1944
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1945
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1946
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1947
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1948
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1949
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1950
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';
|
|
1951
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('cccgggusug'), expected);
|
|
1952
|
+
}));
|
|
1953
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('UfAfCfGfGfCfAfUf', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1954
|
+
const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1955
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1956
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1957
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1958
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1959
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1960
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1961
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
|
|
1962
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('UfAfCfGfGfCfAfUf'), expected);
|
|
1963
|
+
}));
|
|
1964
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sucuCfuUf', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1965
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
1966
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1967
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1968
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1969
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1970
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1971
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
|
|
1972
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sucuCfuUf'), expected);
|
|
1973
|
+
}));
|
|
1974
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sAfgcugUf', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1975
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
1976
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1977
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1978
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1979
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1980
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1981
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';
|
|
1982
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sAfgcugUf'), expected);
|
|
1983
|
+
}));
|
|
1984
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)cuCfuUfsc', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1985
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
1986
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1987
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1988
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
1989
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1990
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +
|
|
1991
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';
|
|
1992
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)cuCfuUfsc'), expected);
|
|
1993
|
+
}));
|
|
1994
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scususu(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
1995
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
1996
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
1997
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1998
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
1999
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2000
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2001
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2002
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
2003
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scususu(GalNAc-2-JNJ)'), expected);
|
|
2004
|
+
}));
|
|
2005
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2006
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
2007
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2008
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
|
|
2009
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2010
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2011
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2012
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2013
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2014
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2015
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2016
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2017
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2018
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2019
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2020
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2021
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2022
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2023
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2024
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2025
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2026
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2027
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';
|
|
2028
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu'), expected);
|
|
2029
|
+
}));
|
|
2030
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)asacgGfuGfCfAfacucuauuca', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2031
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
2032
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2033
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2034
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2035
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2036
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2037
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2038
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2039
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2040
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2041
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2042
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2043
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2044
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2045
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2046
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2047
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2048
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2049
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2050
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
|
|
2051
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)asacgGfuGfCfAfacucuauuca'), expected);
|
|
2052
|
+
}));
|
|
2053
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsgguGfcAfAfCfucuauucuga', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2054
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
2055
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2056
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2057
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2058
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2059
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2060
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2061
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2062
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2063
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2064
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2065
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2066
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2067
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2068
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2069
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2070
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2071
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2072
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2073
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
|
|
2074
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsgguGfcAfAfCfucuauucuga'), expected);
|
|
2075
|
+
}));
|
|
2076
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsaacUfcUfAfUfucuggacuua', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2077
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
2078
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2079
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2080
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2081
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2082
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2083
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2084
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2085
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2086
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2087
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2088
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2089
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2090
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2091
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2092
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2093
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2094
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2095
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2096
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
|
|
2097
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsaacUfcUfAfUfucuggacuua'), expected);
|
|
2098
|
+
}));
|
|
2099
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasacuCfuAfUfUfcuggacuuua', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2100
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
2101
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2102
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2103
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2104
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2105
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2106
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2107
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2108
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2109
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2110
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2111
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2112
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2113
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2114
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2115
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2116
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2117
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2118
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2119
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';
|
|
2120
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasacuCfuAfUfUfcuggacuuua'), expected);
|
|
2121
|
+
}));
|
|
2122
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2123
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
2124
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2125
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +
|
|
2126
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2127
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2128
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2129
|
+
'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
2130
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2131
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2132
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
2133
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)'), expected);
|
|
2134
|
+
}));
|
|
2135
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2136
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
2137
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2138
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2139
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2140
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2141
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2142
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2143
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2144
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2145
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2146
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
2147
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)'), expected);
|
|
2148
|
+
}));
|
|
2149
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2150
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
2151
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2152
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2153
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2154
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2155
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2156
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2157
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2158
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2159
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2160
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2161
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2162
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2163
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2164
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2165
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2166
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2167
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2168
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2169
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2170
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2171
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2172
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
2173
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)'), expected);
|
|
2174
|
+
}));
|
|
2175
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2176
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
2177
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2178
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2179
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2180
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2181
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2182
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2183
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2184
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2185
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2186
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2187
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2188
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2189
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2190
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2191
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2192
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2193
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2194
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2195
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2196
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2197
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2198
|
+
'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +
|
|
2199
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2200
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2201
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
2202
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)'), expected);
|
|
2203
|
+
}));
|
|
2204
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.test)('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
2205
|
+
const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +
|
|
2206
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +
|
|
2207
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2208
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2209
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2210
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2211
|
+
'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2212
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2213
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2214
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +
|
|
2215
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2216
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2217
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2218
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2219
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2220
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2221
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2222
|
+
'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2223
|
+
'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2224
|
+
'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +
|
|
2225
|
+
'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2226
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +
|
|
2227
|
+
'(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';
|
|
2228
|
+
(0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_0__.expect)((0,_structures_works_from_monomers__WEBPACK_IMPORTED_MODULE_1__.sequenceToSmiles)('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)'), expected);
|
|
2229
|
+
}));
|
|
2230
|
+
});
|
|
2231
|
+
|
|
2232
|
+
|
|
2233
|
+
/***/ }),
|
|
2234
|
+
|
|
2235
|
+
/***/ "datagrok-api/dg":
|
|
2236
|
+
/*!*********************!*\
|
|
2237
|
+
!*** external "DG" ***!
|
|
2238
|
+
\*********************/
|
|
2239
|
+
/***/ ((module) => {
|
|
2240
|
+
|
|
2241
|
+
module.exports = DG;
|
|
2242
|
+
|
|
2243
|
+
/***/ }),
|
|
2244
|
+
|
|
2245
|
+
/***/ "openchemlib/full.js":
|
|
2246
|
+
/*!**********************!*\
|
|
2247
|
+
!*** external "OCL" ***!
|
|
2248
|
+
\**********************/
|
|
2249
|
+
/***/ ((module) => {
|
|
2250
|
+
|
|
2251
|
+
module.exports = OCL;
|
|
2252
|
+
|
|
2253
|
+
/***/ }),
|
|
2254
|
+
|
|
2255
|
+
/***/ "datagrok-api/grok":
|
|
2256
|
+
/*!***********************!*\
|
|
2257
|
+
!*** external "grok" ***!
|
|
2258
|
+
\***********************/
|
|
2259
|
+
/***/ ((module) => {
|
|
2260
|
+
|
|
2261
|
+
module.exports = grok;
|
|
2262
|
+
|
|
2263
|
+
/***/ }),
|
|
2264
|
+
|
|
2265
|
+
/***/ "datagrok-api/ui":
|
|
2266
|
+
/*!*********************!*\
|
|
2267
|
+
!*** external "ui" ***!
|
|
2268
|
+
\*********************/
|
|
2269
|
+
/***/ ((module) => {
|
|
2270
|
+
|
|
2271
|
+
module.exports = ui;
|
|
2272
|
+
|
|
2273
|
+
/***/ })
|
|
2274
|
+
|
|
2275
|
+
/******/ });
|
|
2276
|
+
/************************************************************************/
|
|
2277
|
+
/******/ // The module cache
|
|
2278
|
+
/******/ var __webpack_module_cache__ = {};
|
|
2279
|
+
/******/
|
|
2280
|
+
/******/ // The require function
|
|
2281
|
+
/******/ function __webpack_require__(moduleId) {
|
|
2282
|
+
/******/ // Check if module is in cache
|
|
2283
|
+
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
|
2284
|
+
/******/ if (cachedModule !== undefined) {
|
|
2285
|
+
/******/ return cachedModule.exports;
|
|
2286
|
+
/******/ }
|
|
2287
|
+
/******/ // Create a new module (and put it into the cache)
|
|
2288
|
+
/******/ var module = __webpack_module_cache__[moduleId] = {
|
|
2289
|
+
/******/ // no module.id needed
|
|
2290
|
+
/******/ // no module.loaded needed
|
|
2291
|
+
/******/ exports: {}
|
|
2292
|
+
/******/ };
|
|
2293
|
+
/******/
|
|
2294
|
+
/******/ // Execute the module function
|
|
2295
|
+
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
2296
|
+
/******/
|
|
2297
|
+
/******/ // Return the exports of the module
|
|
2298
|
+
/******/ return module.exports;
|
|
2299
|
+
/******/ }
|
|
2300
|
+
/******/
|
|
2301
|
+
/************************************************************************/
|
|
2302
|
+
/******/ /* webpack/runtime/compat get default export */
|
|
2303
|
+
/******/ (() => {
|
|
2304
|
+
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|
2305
|
+
/******/ __webpack_require__.n = (module) => {
|
|
2306
|
+
/******/ var getter = module && module.__esModule ?
|
|
2307
|
+
/******/ () => (module['default']) :
|
|
2308
|
+
/******/ () => (module);
|
|
2309
|
+
/******/ __webpack_require__.d(getter, { a: getter });
|
|
2310
|
+
/******/ return getter;
|
|
2311
|
+
/******/ };
|
|
2312
|
+
/******/ })();
|
|
2313
|
+
/******/
|
|
2314
|
+
/******/ /* webpack/runtime/define property getters */
|
|
2315
|
+
/******/ (() => {
|
|
2316
|
+
/******/ // define getter functions for harmony exports
|
|
2317
|
+
/******/ __webpack_require__.d = (exports, definition) => {
|
|
2318
|
+
/******/ for(var key in definition) {
|
|
2319
|
+
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
|
2320
|
+
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
|
2321
|
+
/******/ }
|
|
2322
|
+
/******/ }
|
|
2323
|
+
/******/ };
|
|
2324
|
+
/******/ })();
|
|
2325
|
+
/******/
|
|
2326
|
+
/******/ /* webpack/runtime/hasOwnProperty shorthand */
|
|
2327
|
+
/******/ (() => {
|
|
2328
|
+
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
|
2329
|
+
/******/ })();
|
|
2330
|
+
/******/
|
|
2331
|
+
/******/ /* webpack/runtime/make namespace object */
|
|
2332
|
+
/******/ (() => {
|
|
2333
|
+
/******/ // define __esModule on exports
|
|
2334
|
+
/******/ __webpack_require__.r = (exports) => {
|
|
2335
|
+
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
2336
|
+
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
2337
|
+
/******/ }
|
|
2338
|
+
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|
2339
|
+
/******/ };
|
|
2340
|
+
/******/ })();
|
|
2341
|
+
/******/
|
|
2342
|
+
/************************************************************************/
|
|
2343
|
+
var __webpack_exports__ = {};
|
|
2344
|
+
// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
|
|
2345
|
+
(() => {
|
|
2346
|
+
/*!*****************************!*\
|
|
2347
|
+
!*** ./src/package-test.ts ***!
|
|
2348
|
+
\*****************************/
|
|
2349
|
+
__webpack_require__.r(__webpack_exports__);
|
|
2350
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
2351
|
+
/* harmony export */ "_package": () => (/* binding */ _package),
|
|
2352
|
+
/* harmony export */ "tests": () => (/* reexport safe */ _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__.tests),
|
|
2353
|
+
/* harmony export */ "test": () => (/* binding */ test)
|
|
2354
|
+
/* harmony export */ });
|
|
2355
|
+
/* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! datagrok-api/dg */ "datagrok-api/dg");
|
|
2356
|
+
/* harmony import */ var datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__);
|
|
2357
|
+
/* harmony import */ var _datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @datagrok-libraries/utils/src/test */ "./node_modules/@datagrok-libraries/utils/src/test.js");
|
|
2358
|
+
/* harmony import */ var _tests_smiles_tests__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./tests/smiles-tests */ "./src/tests/smiles-tests.ts");
|
|
2359
|
+
var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2360
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
2361
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
2362
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
2363
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
2364
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
2365
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
2366
|
+
});
|
|
2367
|
+
};
|
|
2368
|
+
|
|
2369
|
+
|
|
2370
|
+
|
|
2371
|
+
const _package = new datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.Package();
|
|
2372
|
+
|
|
2373
|
+
//name: test
|
|
2374
|
+
//output: dataframe result
|
|
2375
|
+
function test() {
|
|
2376
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
2377
|
+
const data = yield (0,_datagrok_libraries_utils_src_test__WEBPACK_IMPORTED_MODULE_1__.runTests)();
|
|
2378
|
+
return datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.DataFrame.fromObjects(data);
|
|
2379
|
+
});
|
|
2380
|
+
}
|
|
2381
|
+
|
|
2382
|
+
})();
|
|
2383
|
+
|
|
2384
|
+
sequencetranslator_test = __webpack_exports__;
|
|
2385
|
+
/******/ })()
|
|
2386
|
+
;
|
|
2387
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package-test.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC0C;AACnC;AACA;AACA;AACP;AACA;AACA;AACA,qBAAqB,+BAA+B;AACpD;AACA;AACA,CAAC,wBAAwB;AAClB;AACP;AACA;AACA;AACA;AACA,wEAAwE;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,8DAAoB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,8DAAoB,CAAC;AACpF;AACA,aAAa;AACb,SAAS;AACT;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,wBAAwB,cAAc;AACtC;AACA,gBAAgB,qEAA2B;AAC3C;AACA;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA,2BAA2B,SAAS,UAAU,OAAO;AACrD;AACO;AACP;AACA;AACA,0BAA0B,SAAS,QAAQ,QAAQ,eAAe,UAAU;AAC5E;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,cAAc;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,wEAAwE;AACpG;AACA,4BAA4B,yEAAyE;AACrG;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA,sBAAsB;AACtB;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACP;AACA;AACA,KAAK;AACL;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACxJ3C;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,gGAAgG,gBAAgB;AAChH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,2HAA2H,gBAAgB;AAC3I;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,iGAAiG,gBAAgB;AACjH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA,sGAAsG,gBAAgB;AACtH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,yGAAyG,gBAAgB;AACzH;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA,8GAA8G,gBAAgB;AAC9H;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,+BAA+B;AAC/B;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,8BAA8B;AAC9B;AACA,gCAAgC;AAChC;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,6BAA6B;AAC7B;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP;AACA,kCAAkC;AAClC;AACA,gCAAgC;AAChC;AACA,gCAAgC;AAChC;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;AACA;AACA,6BAA6B;AAC7B,yBAAyB;AAClB;AACP,kBAAkB;AAClB;AACA;AACA;AACA,mJAAmJ,gBAAgB;AACnK;;;;;;;;;;;;;;;;;;;ACxQmG;AAC1C;AACC;AACnD;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,+CAAa;AACjE,6BAA6B,4DAA0B;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,4DAA0B;AAC3D;AACA;AACA;AACA,WAAW,uEAAiB;AAC5B;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,+CAAa;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA,gBAAgB,+CAAa,uBAAuB,4DAA0B;AAC9E,gBAAgB,+CAAa,sBAAsB,4DAA0B;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,4DAA0B;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,mEAAiC;AACzE;AACA;AACA;AACA,0CAA0C,qCAAG;AAC7C,6CAA6C,qCAAG;AAChD,2CAA2C,qCAAG;AAC9C,4BAA4B,qCAAG;AAC/B;AACA;AACA;AACA,mBAAmB,sEAAe;AAClC,8BAA8B,yDAAuB;AACrD,mBAAmB,qCAAG,CAAC,yDAAuB,EAAE,qDAAmB;AACnE,mCAAmC,sDAAoB;AACvD,mBAAmB,qCAAG,CAAC,sDAAoB,EAAE,qDAAmB;AAChE;AACA;AACA;AACA,wCAAwC,6BAA6B;AACrE;;;;;;;;;;;;;;;;;;;;AC9FO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;;;;;;;;;;;;;;;;;;AC/iB2C;AAC3C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,oBAAoB,4BAA4B;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,sBAAsB;AAC1C;AACA;AACA;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oFAAoF;AACpF;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA,4BAA4B,oBAAoB;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,oEAAuB;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,oEAAuB;AACnF;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C;AAC9C,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;;;;;;;;;;;;;;;;;;;;;;AC5W0C;AACJ;AACtC;AACuE;AACye;AAChjB;AACO;AACA;AACP;AACA;AACA,4BAA4B,wDAAc;AAC1C,QAAQ,mDAAS;AACjB,iBAAiB,kDAAQ,uBAAuB,SAAS,sBAAsB;AAC/E;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,SAAS;AACT;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,wDAAc;AACzC,QAAQ,mDAAS;AACjB,iBAAiB,kDAAQ,sBAAsB,SAAS,sBAAsB;AAC9E;AACA;AACA;AACA,YAAY,4DAAkB;AAC9B,SAAS;AACT;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,kCAAkC,qCAAG;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,qCAAG;AAC5C,yCAAyC,qCAAG;AAC5C,oCAAoC,+CAAa;AACjD;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB;AACA;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,gBAAgB,qCAAG;AACnB,kCAAkC,qCAAG,8CAA8C,+CAAa;AAChG;AACA;AACA,KAAK;AACL;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,8DAA4B,yBAAyB,kDAAgB;AACnG;AACA,kBAAkB,8DAA4B,SAAS,kDAAgB;AACvE;AACA,uBAAuB,6EAAgC;AACvD,kBAAkB,wEAA2B;AAC7C;AACA;AACA,8BAA8B,wDAAsB,yBAAyB,0DAAwB;AACrG;AACA,kBAAkB,wDAAsB,SAAS,0DAAwB;AACzE,yBAAyB,6EAAgC;AACzD;AACA,kBAAkB,sEAAyB;AAC3C;AACA;AACA,8BAA8B,mDAAiB,yBAAyB,0DAAwB;AAChG;AACA,kBAAkB,mDAAiB,SAAS,0DAAwB;AACpE,yBAAyB,wEAA2B;AACpD,uBAAuB,sEAAyB;AAChD,uBAAuB,4DAAe;AACtC;AACA;AACA;AACA,8BAA8B,8DAA4B,yBAAyB,kDAAgB;AACnG;AACA,kBAAkB,8DAA4B,SAAS,kDAAgB;AACvE;AACA,uBAAuB,kFAAqC;AAC5D,qBAAqB,gFAAmC;AACxD,kBAAkB,mEAAsB;AACxC;AACA;AACA,8BAA8B,wDAAsB,yBAAyB,qDAAmB;AAChG;AACA,kBAAkB,wDAAsB,SAAS,qDAAmB;AACpE,yBAAyB,wEAA2B;AACpD;AACA,qBAAqB,oEAAuB;AAC5C,kBAAkB,iEAAoB;AACtC;AACA;AACA,8BAA8B,sDAAoB,yBAAyB,qDAAmB;AAC9F;AACA,kBAAkB,sDAAoB,SAAS,qDAAmB;AAClE,yBAAyB,sEAAyB;AAClD,uBAAuB,oEAAuB;AAC9C;AACA,kBAAkB,+DAAkB;AACpC;AACA;AACA,8BAA8B,mDAAiB,yBAAyB,qDAAmB;AAC3F;AACA,kBAAkB,mDAAiB,SAAS,qDAAmB;AAC/D,yBAAyB,mEAAsB;AAC/C,uBAAuB,iEAAoB;AAC3C,qBAAqB,+DAAkB;AACvC,kBAAkB,4DAAe;AACjC;AACA;AACA;AACA,8BAA8B,mDAAiB;AAC/C;AACA,kBAAkB,mDAAiB;AACnC,yBAAyB,8DAAiB;AAC1C;AACA,uBAAuB,4DAAe;AACtC;AACA;AACA,8BAA8B,yDAAuB;AACrD;AACA,kBAAkB,yDAAuB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;ACxNA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC4E;AACP;AACrE,4EAAQ;AACR,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,IAAI,wEAAI;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,0EAAM,CAAC,iFAAgB;AAC/B,KAAK;AACL,CAAC;;;;;;;;;;;ACvaD;;;;;;;;;;ACAA;;;;;;;;;;ACAA;;;;;;;;;;ACAA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;;;;;;;ACNA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AAC+B;AACvC;AACvB,qBAAqB,oDAAU;AACrB;AACjB;AACA;AACO;AACP;AACA,2BAA2B,4EAAQ;AACnC,eAAe,kEAAwB;AACvC,KAAK;AACL","sources":["webpack://sequencetranslator/./node_modules/@datagrok-libraries/utils/src/test.js","webpack://sequencetranslator/./src/structures-works/converters.ts","webpack://sequencetranslator/./src/structures-works/from-monomers.ts","webpack://sequencetranslator/./src/structures-works/map.ts","webpack://sequencetranslator/./src/structures-works/mol-transformations.ts","webpack://sequencetranslator/./src/structures-works/sequence-codes-tools.ts","webpack://sequencetranslator/./src/tests/smiles-tests.ts","webpack://sequencetranslator/external var \"DG\"","webpack://sequencetranslator/external var \"OCL\"","webpack://sequencetranslator/external var \"grok\"","webpack://sequencetranslator/external var \"ui\"","webpack://sequencetranslator/webpack/bootstrap","webpack://sequencetranslator/webpack/runtime/compat get default export","webpack://sequencetranslator/webpack/runtime/define property getters","webpack://sequencetranslator/webpack/runtime/hasOwnProperty shorthand","webpack://sequencetranslator/webpack/runtime/make namespace object","webpack://sequencetranslator/./src/package-test.ts"],"sourcesContent":["var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as grok from \"datagrok-api/grok\";\nexport let tests = {};\nexport let currentCategory;\nexport var assure;\n(function (assure) {\n    function notNull(value, name) {\n        if (value == null)\n            throw `${name == null ? 'Value' : name} not defined`;\n    }\n    assure.notNull = notNull;\n})(assure || (assure = {}));\nexport class Test {\n    constructor(category, name, test, options) {\n        var _a, _b;\n        this.category = category;\n        this.name = name;\n        options !== null && options !== void 0 ? options : (options = {});\n        (_a = options.timeout) !== null && _a !== void 0 ? _a : (options.timeout = 30000);\n        (_b = options.unhandledExceptionTimeout) !== null && _b !== void 0 ? _b : (options.unhandledExceptionTimeout = 2000);\n        this.options = options;\n        this.test = () => __awaiter(this, void 0, void 0, function* () {\n            return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {\n                let result = '';\n                try {\n                    grok.shell.lastError = '';\n                    result = yield test();\n                }\n                catch (e) {\n                    reject(e);\n                }\n                if (!(yield assertNoError(options.unhandledExceptionTimeout)))\n                    reject(`Unhandled exception during test: ${grok.shell.lastError}`);\n                resolve(result);\n            }));\n        });\n    }\n}\nexport function test(name, test, options) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    if (tests[currentCategory].tests == undefined)\n        tests[currentCategory].tests = [];\n    tests[currentCategory].tests.push(new Test(currentCategory, name, test, options));\n}\n/** Awaits for a while checking the error status of the platform */\nexport function assertNoError(ms) {\n    return __awaiter(this, void 0, void 0, function* () {\n        for (let i = 0; i < ms / 500; ++i) {\n            yield delay(500);\n            if (grok.shell.lastError.length !== 0)\n                return false;\n        }\n        return true;\n    });\n}\n/** Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual, expected) {\n    if (actual !== expected)\n        throw `Expected \"${expected}\", got \"${actual}\"`;\n}\nexport function expectFloat(actual, expected, tolerance = 0.001) {\n    const areEqual = Math.abs(actual - expected) < 0.001;\n    if (!areEqual)\n        throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;\n}\n/** Defines a test suite. */\nexport function category(category, tests) {\n    currentCategory = category;\n    tests();\n}\n/** Defines a function to be executed before the tests in this category are executed. */\nexport function before(before) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    tests[currentCategory].before = before;\n}\n/** Defines a function to be executed after the tests in this category are executed. */\nexport function after(after) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    tests[currentCategory].after = after;\n}\nexport function runTests(options) {\n    var _a;\n    return __awaiter(this, void 0, void 0, function* () {\n        let results = [];\n        for (const [key, value] of Object.entries(tests)) {\n            if ((options === null || options === void 0 ? void 0 : options.category) != undefined) {\n                if (!key.toLowerCase().startsWith(options === null || options === void 0 ? void 0 : options.category.toLowerCase()))\n                    continue;\n            }\n            try {\n                if (value.before)\n                    yield value.before();\n            }\n            catch (x) {\n                value.beforeStatus = x.toString();\n            }\n            let t = (_a = value.tests) !== null && _a !== void 0 ? _a : [];\n            let res = [];\n            for (let i = 0; i < t.length; i++) {\n                res.push(yield execTest(t[i], options === null || options === void 0 ? void 0 : options.test));\n            }\n            let data = (yield Promise.all(res)).filter((d) => d.result != 'skipped');\n            try {\n                if (value.after)\n                    yield value.after();\n            }\n            catch (x) {\n                value.afterStatus = x.toString();\n            }\n            if (value.afterStatus)\n                data.push({ category: key, name: 'init', result: value.afterStatus, success: false });\n            if (value.beforeStatus)\n                data.push({ category: key, name: 'init', result: value.beforeStatus, success: false });\n            results.push(...data);\n        }\n        return results;\n    });\n}\nfunction execTest(t, predicate) {\n    var _a;\n    return __awaiter(this, void 0, void 0, function* () {\n        let r;\n        try {\n            if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))\n                r = { success: true, result: 'skipped' };\n            else\n                r = { success: true, result: (_a = yield t.test()) !== null && _a !== void 0 ? _a : 'OK' };\n        }\n        catch (x) {\n            r = { success: false, result: x.toString() };\n        }\n        r.category = t.category;\n        r.name = t.name;\n        return r;\n    });\n}\nexport function delay(ms) {\n    return __awaiter(this, void 0, void 0, function* () {\n        yield new Promise(r => setTimeout(r, ms));\n    });\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,KAAK,IAAI,MAAM,mBAAmB,CAAC;AAE1C,MAAM,CAAC,IAAI,KAAK,GAA8I,EAAE,CAAC;AAEjK,MAAM,CAAC,IAAI,eAAuB,CAAC;AAEnC,MAAM,KAAW,MAAM,CAMtB;AAND,WAAiB,MAAM;IAErB,SAAgB,OAAO,CAAC,KAAU,EAAE,IAAa;QAC/C,IAAI,KAAK,IAAI,IAAI;YACf,MAAM,GAAG,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,cAAc,CAAC;IACzD,CAAC;IAHe,cAAO,UAGtB,CAAA;AACH,CAAC,EANgB,MAAM,KAAN,MAAM,QAMtB;AAOD,MAAM,OAAO,IAAI;IAMf,YAAY,QAAgB,EAAE,IAAY,EAAE,IAAwB,EAAE,OAAqB;;QACzF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,OAAO,aAAP,OAAO,cAAP,OAAO,IAAP,OAAO,GAAK,EAAE,EAAC;QACf,MAAA,OAAO,CAAC,OAAO,oCAAf,OAAO,CAAC,OAAO,GAAK,KAAK,EAAC;QAC1B,MAAA,OAAO,CAAC,yBAAyB,oCAAjC,OAAO,CAAC,yBAAyB,GAAK,IAAI,EAAC;QAC3C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,GAAuB,EAAE;YACnC,OAAO,IAAI,OAAO,CAAC,CAAO,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC3C,IAAI,MAAM,GAAG,EAAE,CAAC;gBAChB,IAAI;oBACF,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC;oBAC1B,MAAM,GAAG,MAAM,IAAI,EAAE,CAAC;iBACvB;gBAAC,OAAO,CAAM,EAAE;oBACf,MAAM,CAAC,CAAC,CAAC,CAAC;iBACX;gBACD,IAAI,CAAC,CAAC,MAAM,aAAa,CAAC,OAAQ,CAAC,yBAA0B,CAAC,CAAC;oBAC7D,MAAM,CAAC,oCAAoC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;gBACrE,OAAO,CAAC,MAAM,CAAC,CAAC;YAClB,CAAC,CAAA,CAAC,CAAC;QACL,CAAC,CAAA,CAAC;IACJ,CAAC;CACF;AAED,MAAM,UAAU,IAAI,CAAC,IAAY,EAAE,IAAwB,EAAE,OAAqB;IAChF,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,IAAI,SAAS;QAC3C,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;IACpC,KAAK,CAAC,eAAe,CAAC,CAAC,KAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;AACrF,CAAC;AAED,mEAAmE;AACnE,MAAM,UAAgB,aAAa,CAAC,EAAU;;QAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE;YACjC,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;YACjB,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC;gBACnC,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CAAA;AAED,iFAAiF;AACjF,MAAM,UAAU,MAAM,CAAC,MAAW,EAAE,QAAa;IAC/C,IAAI,MAAM,KAAK,QAAQ;QACrB,MAAM,aAAa,QAAQ,WAAW,MAAM,GAAG,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,MAAc,EAAE,QAAgB,EAAE,SAAS,GAAG,KAAK;IAC7E,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,KAAK,CAAC;IACrD,IAAI,CAAC,QAAQ;QACX,MAAM,YAAY,QAAQ,SAAS,MAAM,iBAAiB,SAAS,GAAG,CAAC;AAC3E,CAAC;AAED,4BAA4B;AAC5B,MAAM,UAAU,QAAQ,CAAC,QAAgB,EAAE,KAAiB;IAC1D,eAAe,GAAG,QAAQ,CAAC;IAC3B,KAAK,EAAE,CAAC;AACV,CAAC;AAED,wFAAwF;AACxF,MAAM,UAAU,MAAM,CAAC,MAA2B;IAChD,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,KAAK,CAAC,eAAe,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;AACzC,CAAC;AAED,uFAAuF;AACvF,MAAM,UAAU,KAAK,CAAC,KAA0B;IAC9C,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,SAAS;QACrC,KAAK,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9B,KAAK,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;AACvC,CAAC;AAGD,MAAM,UAAgB,QAAQ,CAAC,OAA4C;;;QACzE,IAAI,OAAO,GAA4E,EAAE,CAAC;QAE1F,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAChD,IAAI,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,KAAI,SAAS,EAAE;gBAClC,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,CAAC,WAAW,EAAE,CAAC;oBAChE,SAAS;aACZ;YACD,IAAI;gBACF,IAAI,KAAK,CAAC,MAAM;oBACd,MAAM,KAAK,CAAC,MAAM,EAAE,CAAC;aACxB;YAAC,OAAO,CAAM,EAAE;gBACf,KAAK,CAAC,YAAY,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aACnC;YACD,IAAI,CAAC,GAAG,MAAA,KAAK,CAAC,KAAK,mCAAI,EAAE,CAAC;YAC1B,IAAI,GAAG,GAAG,EAAE,CAAC;YACb,KAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAChC,GAAG,CAAC,IAAI,CAAC,MAAM,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,CAAC,CAAC,CAAC;aAC/C;YAED,IAAI,IAAI,GAAG,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,SAAS,CAAC,CAAC;YACzE,IAAI;gBACF,IAAI,KAAK,CAAC,KAAK;oBACb,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;aACvB;YAAC,OAAO,CAAM,EAAE;gBACf,KAAK,CAAC,WAAW,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aAClC;YACD,IAAI,KAAK,CAAC,WAAW;gBACnB,IAAI,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,WAAW,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YACtF,IAAI,KAAK,CAAC,YAAY;gBACpB,IAAI,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,YAAY,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YACvF,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;SACvB;QAED,OAAO,OAAO,CAAC;;CAChB;AAED,SAAe,QAAQ,CAAC,CAAO,EAAE,SAA6B;;;QAC5D,IAAI,CAAyE,CAAC;QAC9E,IAAI;YACF,IAAI,SAAS,IAAI,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;gBACvF,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAC,CAAC;;gBAEvC,CAAC,GAAG,EAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAA,MAAM,CAAC,CAAC,IAAI,EAAE,mCAAI,IAAI,EAAC,CAAC;SACvD;QAAC,OAAO,CAAM,EAAE;YACf,CAAC,GAAG,EAAC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAC,CAAC;SAC5C;QACD,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC;QACxB,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC;QAChB,OAAO,CAAC,CAAC;;CACV;AAED,MAAM,UAAgB,KAAK,CAAC,EAAU;;QACpC,MAAO,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;IAC7C,CAAC;CAAA","sourcesContent":["import * as grok from \"datagrok-api/grok\";\n\nexport let tests: {[key: string]: {tests?: Test[], before?: () => Promise<void>, after?: () => Promise<void>, beforeStatus?: string, afterStatus?: string}} = {};\n\nexport let currentCategory: string;\n\nexport namespace assure {\n\n  export function notNull(value: any, name?: string) {\n    if (value == null)\n      throw `${name == null ? 'Value' : name} not defined`;\n  }\n}\n\nexport interface TestOptions {\n  timeout? : number;\n  unhandledExceptionTimeout? : number;\n}\n\nexport class Test {\n  test: () => Promise<any>;\n  name: string;\n  category: string;\n  options?: TestOptions;\n\n  constructor(category: string, name: string, test: () => Promise<any>, options?: TestOptions) {\n    this.category = category;\n    this.name = name;\n    options ??= {};\n    options.timeout ??= 30000;\n    options.unhandledExceptionTimeout ??= 2000;\n    this.options = options;\n    this.test = async (): Promise<any> => {\n      return new Promise(async (resolve, reject) => {\n        let result = '';\n        try {\n          grok.shell.lastError = '';\n          result = await test();\n        } catch (e: any) {\n          reject(e);\n        }\n        if (!(await assertNoError(options!.unhandledExceptionTimeout!)))\n          reject(`Unhandled exception during test: ${grok.shell.lastError}`);\n        resolve(result);\n      });\n    };\n  }\n}\n\nexport function test(name: string, test: () => Promise<any>, options?: TestOptions): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  if (tests[currentCategory].tests == undefined)\n    tests[currentCategory].tests = [];\n  tests[currentCategory].tests!.push(new Test(currentCategory, name, test, options));\n}\n\n/** Awaits for a while checking the error status of the platform */\nexport async function assertNoError(ms: number): Promise<boolean> {\n  for (let i = 0; i < ms / 500; ++i) {\n    await delay(500);\n    if (grok.shell.lastError.length !== 0)\n      return false;\n  }\n  return true;\n}\n\n/** Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual: any, expected: any): void {\n  if (actual !== expected)\n    throw `Expected \"${expected}\", got \"${actual}\"`;\n}\n\nexport function expectFloat(actual: number, expected: number, tolerance = 0.001): void {\n  const areEqual = Math.abs(actual - expected) < 0.001;\n  if (!areEqual)\n    throw `Expected ${expected}, got ${actual} (tolerance = ${tolerance})`;\n}\n\n/** Defines a test suite. */\nexport function category(category: string, tests: () => void): void {\n  currentCategory = category;\n  tests();\n}\n\n/** Defines a function to be executed before the tests in this category are executed. */\nexport function before(before: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].before = before;\n}\n\n/** Defines a function to be executed after the tests in this category are executed. */\nexport function after(after: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].after = after;\n}\n\n\nexport async function runTests(options?: {category?: string, test?: string}) {\n  let results: { category?: string, name?: string, success: boolean, result: string}[] = [];\n\n  for (const [key, value] of Object.entries(tests)) {\n    if (options?.category != undefined) {\n      if (!key.toLowerCase().startsWith(options?.category.toLowerCase()))\n        continue;\n    }\n    try {\n      if (value.before)\n        await value.before();\n    } catch (x: any) {\n      value.beforeStatus = x.toString();\n    }\n    let t = value.tests ?? [];\n    let res = [];\n    for(let i = 0; i < t.length; i++) {\n      res.push(await execTest(t[i], options?.test));\n    }\n\n    let data = (await Promise.all(res)).filter((d) => d.result != 'skipped');\n    try {\n      if (value.after)\n        await value.after();\n    } catch (x: any) {\n      value.afterStatus = x.toString();\n    }\n    if (value.afterStatus)\n      data.push({category: key, name: 'init', result: value.afterStatus, success: false});\n    if (value.beforeStatus)\n      data.push({category: key, name: 'init', result: value.beforeStatus, success: false});\n    results.push(...data);\n  }\n\n  return results;\n}\n\nasync function execTest(t: Test, predicate: string | undefined) {\n  let r: { category?: string, name?: string, success: boolean, result: string };\n  try {\n    if (predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase())))\n      r = {success: true, result: 'skipped'};\n    else\n      r = {success: true, result: await t.test() ?? 'OK'};\n  } catch (x: any) {\n    r = {success: false, result: x.toString()};\n  }\n  r.category = t.category;\n  r.name = t.name;\n  return r;\n}\n\nexport async function delay(ms: number) {\n  await  new Promise(r => setTimeout(r, ms));\n}\n"]}","//name: asoGapmersNucleotidesToBioSpring\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersNucleotidesToBioSpring(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': '5*', 'A': '6*', 'C': '7*', 'G': '8*'\n    };\n    const objForCenter = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'T*', 'A': 'A*', 'C': '9*', 'G': 'G*'\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        return (count > 4 && count < 15) ? objForCenter[x] : objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : 2 * count + 1);\n}\n//name: asoGapmersNucleotidesToGcrs\n//input: string nucleotides {semType: DNA nucleotides}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForEdges = {\n        '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'T': 'moeUnps',\n        'A': 'moeAnps', 'C': 'moe5mCnps', 'G': 'moeGnps'\n    };\n    const objForCenter = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'C': '5mCps', 'A': 'Aps', 'T': 'Tps', 'G': 'Gps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|T|C|G)/g, function (x) {\n        count++;\n        if (count < 5)\n            return (count == 4) ? objForEdges[x].slice(0, -3) + 'ps' : objForEdges[x];\n        if (count < 15)\n            return (count == 14) ? objForCenter[x].slice(0, -2) + 'nps' : objForCenter[x];\n        return objForEdges[x];\n    }).slice(0, (nucleotides.endsWith('(invabasic)') || nucleotides.endsWith('(GalNAc-2-JNJ)')) ?\n        nucleotides.length : -3);\n}\n//name: asoGapmersBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '*': '', '5': 'T', '6': 'A', '7': 'C', '8': 'G', '9': 'C' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|\\*|5|6|7|8|9)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / Gapmers}\n//output: string result {semType: GCRS / Gapmers}\nexport function asoGapmersBioSpringToGcrs(nucleotides) {\n    let count = -1;\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '5*': 'moeUnps', '6*': 'moeAnps', '7*': 'moe5mCnps', '8*': 'moeGnps', '9*': '5mCps', 'A*': 'Aps', 'T*': 'Tps',\n        'G*': 'Gps', 'C*': 'Cps', '5': 'moeU', '6': 'moeA', '7': 'moe5mC', '8': 'moeG',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|5\\*|6\\*|7\\*|8\\*|9\\*|A\\*|T\\*|G\\*|C\\*|5|6|7|8)/g, function (x) {\n        count++;\n        return (count == 4) ? obj[x].slice(0, -3) + 'ps' : (count == 14) ? obj[x].slice(0, -2) + 'nps' : obj[x];\n    });\n}\n//name: asoGapmersGcrsToBioSpring\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: BioSpring / Gapmers}\nexport function asoGapmersGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moeT': '5', 'moeA': '6', 'moe5mC': '7', 'moeG': '8', 'moeU': '5', '5mC': '9', 'nps': '*', 'ps': '*', 'U': 'T',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moeT|moeA|moe5mC|moeG|moeU|5mC|nps|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: asoGapmersGcrsToNucleotides\n//input: string nucleotides {semType: GCRS / Gapmers}\n//output: string result {semType: DNA nucleotides}\nexport function asoGapmersGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'moe': '', '5m': '', 'n': '', 'ps': '', 'U': 'T' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|moe|5m|n|ps|U)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToNucleotides\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaBioSpringToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'U', '2': 'A', '3': 'C', '4': 'G', '5': 'U', '6': 'A', '7': 'C', '8': 'G', '*': '' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToAxolabs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaBioSpringToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'Uf', '2': 'Af', '3': 'Cf', '4': 'Gf', '5': 'u', '6': 'a', '7': 'c', '8': 'g', '*': 's' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaBioSpringToGcrs\n//input: string nucleotides {semType: BioSpring / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaBioSpringToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        '1': 'fU', '2': 'fA', '3': 'fC', '4': 'fG', '5': 'mU', '6': 'mA', '7': 'mC', '8': 'mG', '*': 'ps' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|1|2|3|4|5|6|7|8|\\*)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToGcrs\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: GCRS}\nexport function siRnaAxolabsToGcrs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'fU', 'Af': 'fA', 'Cf': 'fC', 'Gf': 'fG', 'u': 'mU', 'a': 'mA', 'c': 'mC', 'g': 'mG', 's': 'ps',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToBioSpring\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaAxolabsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': '1', 'Af': '2', 'Cf': '3', 'Gf': '4', 'u': '5', 'a': '6', 'c': '7', 'g': '8', 's': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaAxolabsToNucleotides\n//input: string nucleotides {semType: Axolabs / siRNA}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaAxolabsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'Uf': 'U', 'Af': 'A', 'Cf': 'C', 'Gf': 'G', 'u': 'U', 'a': 'A', 'c': 'C', 'g': 'G', 's': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|Uf|Af|Cf|Gf|u|a|c|g|s)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function siRnaGcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G', 'ps': '',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToBioSpring\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaGcrsToBioSpring(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': '1', 'fA': '2', 'fC': '3', 'fG': '4', 'mU': '5', 'mA': '6', 'mC': '7', 'mG': '8', 'ps': '*',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaGcrsToAxolabs\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Axolabs / siRNA}\nexport function siRnaGcrsToAxolabs(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'fU': 'Uf', 'fA': 'Af', 'fC': 'Cf', 'fG': 'Gf', 'mU': 'u', 'mA': 'a', 'mC': 'c', 'mG': 'g', 'ps': 's',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|fU|fA|fC|fG|mU|mA|mC|mG|ps)/g, function (x) { return obj[x]; });\n}\n//name: siRnaNucleotideToBioSpringSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: BioSpring / siRNA}\nexport function siRnaNucleotideToBioSpringSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6*', 'U': '5*', 'G': '8*', 'C': '7*' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '*6', 'U': '*5', 'G': '*8', 'C': '*7' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': '6', 'U': '5', 'G': '8', 'C': '7' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': '2', 'U': '1', 'G': '4', 'C': '3' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotidesToGcrs\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: GCRS}\nexport function siRnaNucleotidesToGcrs(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'mAps', 'U': 'mUps', 'G': 'mGps', 'C': 'mCps' };\n    const objForRightEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'psmA', 'U': 'psmU', 'G': 'psmG', 'C': 'psmC' };\n    const objForEvenIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'fA', 'U': 'fU', 'G': 'fG', 'C': 'fC' };\n    const objForOddIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'mA', 'U': 'mU', 'G': 'mG', 'C': 'mC' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count > nucleotides.length - 3)\n            return objForRightEdge[x];\n        return (count % 2 == 0) ? objForEvenIndices[x] : objForOddIndices[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsSenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsSenseStrand(nucleotides) {\n    let count = -1;\n    const objForLeftEdge = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count < 2)\n            return objForLeftEdge[x];\n        if (count == 6 || (count > 7 && count < 11))\n            return objForSomeIndices[x];\n        if (count == nucleotides.length - 1)\n            return 'a';\n        return obj[x];\n    });\n}\n//name: siRnaNucleotideToAxolabsAntisenseStrand\n//input: string nucleotides {semType: RNA nucleotides}\n//output: string result {semType: Axolabs}\nexport function siRnaNucleotideToAxolabsAntisenseStrand(nucleotides) {\n    let count = -1;\n    const objForSmallLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'as', 'U': 'us', 'G': 'gs', 'C': 'cs' };\n    const objForBigLinkages = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Afs', 'U': 'Ufs', 'G': 'Gfs', 'C': 'Cfs' };\n    const objForSomeIndices = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'Af', 'U': 'Uf', 'G': 'Gf', 'C': 'Cf' };\n    const obj = { '(invabasic)': '(invabasic)',\n        '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)', 'A': 'a', 'U': 'u', 'G': 'g', 'C': 'c' };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|A|U|G|C)/g, function (x) {\n        count++;\n        if (count > 19 && count < 22)\n            return objForSmallLinkages[x];\n        if (count == 0)\n            return 'us';\n        if (count == 1)\n            return objForBigLinkages[x];\n        return (count == 5 || count == 7 || count == 8 || count == 13 || count == 15) ? objForSomeIndices[x] : obj[x];\n    });\n}\n//name: gcrsToNucleotides\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: RNA nucleotides}\nexport function gcrsToNucleotides(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'A', 'mUps': 'U', 'mGps': 'G', 'mCps': 'C', 'fAps': 'A', 'fUps': 'U', 'fGps': 'G', 'fCps': 'C',\n        'fU': 'U', 'fA': 'A', 'fC': 'C', 'fG': 'G', 'mU': 'U', 'mA': 'A', 'mC': 'C', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n//name: gcrsToMermade12\n//input: string nucleotides {semType: GCRS}\n//output: string result {semType: Mermade 12 / siRNA}\nexport function gcrsToMermade12(nucleotides) {\n    const obj = { '(invabasic)': '(invabasic)', '(GalNAc-2-JNJ)': '(GalNAc-2-JNJ)',\n        'mAps': 'e', 'mUps': 'h', 'mGps': 'g', 'mCps': 'f', 'fAps': 'i', 'fUps': 'l', 'fGps': 'k', 'fCps': 'j', 'fU': 'L',\n        'fA': 'I', 'fC': 'J', 'fG': 'K', 'mU': 'H', 'mA': 'E', 'mC': 'F', 'mG': 'G',\n    };\n    return nucleotides.replace(/(\\(invabasic\\)|\\(GalNAc-2-JNJ\\)|mAps|mUps|mGps|mCps|fAps|fUps|fGps|fCps|fU|fA|fC|fG|mU|mA|mC|mG)/g, function (x) { return obj[x]; });\n}\n","import { map, stadardPhosphateLinkSmiles, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { isValidSequence } from './sequence-codes-tools';\nimport { getNucleotidesMol } from './mol-transformations';\nexport function sequenceToMolV3000(sequence, inverted = false, oclRender = false) {\n    const obj = getObjectWithCodesAndSmiles(sequence);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    const smilesCodes = [];\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smilesCodes.push((i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right : MODIFICATIONS[codesList[i]].left);\n            smilesCodes.push(stadardPhosphateLinkSmiles);\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smilesCodes.push(obj[codesList[i]]);\n            else {\n                smilesCodes.push(obj[codesList[i]]);\n                smilesCodes.push(stadardPhosphateLinkSmiles);\n            }\n        }\n    }\n    return getNucleotidesMol(smilesCodes, oclRender);\n}\nexport function sequenceToSmiles(sequence, inverted = false) {\n    const obj = getObjectWithCodesAndSmiles(sequence);\n    let codes = sortByStringLengthInDescendingOrder(Object.keys(obj));\n    let i = 0;\n    let smiles = '';\n    const codesList = [];\n    const links = ['s', 'ps', '*'];\n    const includesStandardLinkAlready = ['e', 'h', /*'g',*/ 'f', 'i', 'l', 'k', 'j'];\n    const dropdowns = Object.keys(MODIFICATIONS);\n    codes = codes.concat(dropdowns);\n    while (i < sequence.length) {\n        const code = codes.find((s) => s == sequence.slice(i, i + s.length));\n        i += code.length;\n        inverted ? codesList.unshift(code) : codesList.push(code);\n    }\n    for (let i = 0; i < codesList.length; i++) {\n        if (dropdowns.includes(codesList[i])) {\n            smiles += (i >= codesList.length / 2) ?\n                MODIFICATIONS[codesList[i]].right + stadardPhosphateLinkSmiles :\n                MODIFICATIONS[codesList[i]].left + stadardPhosphateLinkSmiles;\n        }\n        else {\n            if (links.includes(codesList[i]) ||\n                includesStandardLinkAlready.includes(codesList[i]) ||\n                (i < codesList.length - 1 && links.includes(codesList[i + 1])))\n                smiles += obj[codesList[i]];\n            else\n                smiles += obj[codesList[i]] + stadardPhosphateLinkSmiles;\n        }\n    }\n    smiles = smiles.replace(/OO/g, 'O');\n    return ((links.includes(codesList[codesList.length - 1]) &&\n        codesList.length > 1 &&\n        !includesStandardLinkAlready.includes(codesList[codesList.length - 2])) ||\n        dropdowns.includes(codesList[codesList.length - 1]) ||\n        includesStandardLinkAlready.includes(codesList[codesList.length - 1])) ?\n        smiles :\n        smiles.slice(0, smiles.length - stadardPhosphateLinkSmiles.length + 1);\n}\nfunction getObjectWithCodesAndSmiles(sequence) {\n    const obj = {};\n    for (const synthesizer of Object.keys(map)) {\n        for (const technology of Object.keys(map[synthesizer])) {\n            for (const code of Object.keys(map[synthesizer][technology]))\n                obj[code] = map[synthesizer][technology][code].SMILES;\n        }\n    }\n    // TODO: create object based from synthesizer type to avoid key(codes) duplicates\n    const output = isValidSequence(sequence);\n    if (output.synthesizer == SYNTHESIZERS.MERMADE_12)\n        obj['g'] = map[SYNTHESIZERS.MERMADE_12][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    else if (output.synthesizer == SYNTHESIZERS.AXOLABS)\n        obj['g'] = map[SYNTHESIZERS.AXOLABS][TECHNOLOGIES.SI_RNA]['g'].SMILES;\n    return obj;\n}\nfunction sortByStringLengthInDescendingOrder(array) {\n    return array.sort(function (a, b) { return b.length - a.length; });\n}\n","export const SYNTHESIZERS = {\n    RAW_NUCLEOTIDES: 'Raw Nucleotides',\n    BIOSPRING: 'BioSpring Codes',\n    GCRS: 'Janssen GCRS Codes',\n    AXOLABS: 'Axolabs Codes',\n    MERMADE_12: 'Mermade 12',\n};\nexport const TECHNOLOGIES = {\n    DNA: 'DNA',\n    RNA: 'RNA',\n    ASO_GAPMERS: 'For ASO Gapmers',\n    SI_RNA: 'For 2\\'-OMe and 2\\'-F modified siRNA',\n};\nexport const COL_NAMES = {\n    CHEMISTRY: 'Chemistry',\n    NUMBER: 'Number',\n    TYPE: 'Type',\n    CHEMISTRY_NAME: 'Chemistry Name',\n    INTERNAL_COMPOUND_ID: 'Internal compound ID',\n    IDP: 'IDP',\n    SEQUENCE: 'Sequence',\n    COMPOUND_NAME: 'Compound Name',\n    COMPOUND_COMMENTS: 'Compound Comments',\n    SALT: 'Salt',\n    EQUIVALENTS: 'Equivalents',\n    PURITY: 'Purity',\n    CPD_MW: 'Cpd MW',\n    SALT_MASS: 'Salt mass',\n    BATCH_MW: 'Batch MW',\n    SOURCE: 'Source',\n    ICD: 'ICD',\n    OWNER: 'Owner',\n};\n// interface CODES {\n// }\nexport const MODIFICATIONS = {\n    '(invabasic)': {\n        molecularWeight: 118.13,\n        left: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n        right: 'O[C@@H]1C[C@@H]O[C@H]1CO',\n    },\n    '(GalNAc-2-JNJ)': {\n        molecularWeight: 1273.3,\n        left: 'C(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)NC(=O)CCCC(=O)NCC(O)CO',\n        right: 'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)',\n    },\n};\nexport const stadardPhosphateLinkSmiles = 'OP(=O)(O)O';\nexport const map = {\n    'Raw Nucleotides': {\n        'DNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n        'RNA': {\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'U': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n        },\n    },\n    'BioSpring Codes': {\n        'For ASO Gapmers': {\n            '5': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '9': {\n                'name': '5-Methyl-dC',\n                'weight': 303.21,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            '1': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '2': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '3': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            '4': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            '5': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '6': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '7': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            '8': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            '*': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Axolabs Codes': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'Uf': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Af': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'Cf': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'Gf': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'u': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'a': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'c': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            's': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n        },\n    },\n    'Janssen GCRS Codes': {\n        'For ASO Gapmers': {\n            'moeT': {\n                'name': '2\\'MOE-5Me-rU',\n                'weight': 378.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeA': {\n                'name': '2\\'MOE-rA',\n                'weight': 387.29,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            'moe5mC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            '(5m)moeC': {\n                'name': '2\\'MOE-5Me-rC',\n                'weight': 377.29,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))[C@H](OCCOC)[C@@H]1O',\n            },\n            'moeG': {\n                'name': '2\\'MOE-rG',\n                'weight': 403.28,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OCCOC)[C@@H]1O',\n            },\n            '5mC': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            '(5m)C': {\n                'name': '5-Methyl-dC',\n                'weight': 303.28,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(N)=NC2(=O))C[C@@H]1O',\n            },\n            'ps': {\n                'name': 'ps linkage',\n                'weight': 16.07,\n                'normalized': '',\n                'SMILES': 'OP(=O)(S)O',\n            },\n            'A': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'dA': {\n                'name': 'Adenine',\n                'weight': 313.21,\n                'normalized': 'dA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1O',\n            },\n            'C': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'dC': {\n                'name': 'Cytosine',\n                'weight': 289.18,\n                'normalized': 'dC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O',\n            },\n            'G': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'dG': {\n                'name': 'Guanine',\n                'weight': 329.21,\n                'normalized': 'dG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)C[C@@H]1O',\n            },\n            'T': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'dT': {\n                'name': 'Tyrosine',\n                'weight': 304.2,\n                'normalized': 'dT',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1O',\n            },\n            'rA': {\n                'name': 'Adenine',\n                'weight': 329.21,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rC': {\n                'name': 'Cytosine',\n                'weight': 305.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](O)[C@@H]1O',\n            },\n            'rG': {\n                'name': 'Guanine',\n                'weight': 345.21,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](O)[C@@H]1O',\n            },\n            'rU': {\n                'name': 'Uracil',\n                'weight': 306.17,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](O)[C@@H]1O',\n            },\n        },\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'fU': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fA': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'fC': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'fG': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'mU': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mA': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'mC': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'mG': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n    },\n    'Mermade 12': {\n        'For 2\\'-OMe and 2\\'-F modified siRNA': {\n            'e': {\n                'name': '2\\'OMe-rA-ps',\n                'weight': 359.31,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'h': {\n                'name': '2\\'OMe-rU-ps',\n                'weight': 336.27,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'g': {\n                'name': '2\\'OMe-rG-ps',\n                'weight': 375.31,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'f': {\n                'name': '2\\'OMe-rC-ps',\n                'weight': 335.28,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)O',\n            },\n            'i': {\n                'name': '2\\'-fluoro-A-ps',\n                'weight': 347.27,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'l': {\n                'name': '2\\'-fluoro-U-ps',\n                'weight': 324.23,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'k': {\n                'name': '2\\'-fluoro-G-ps',\n                'weight': 363.26,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'j': {\n                'name': '2\\'-fluoro-C-ps',\n                'weight': 323.25,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)O',\n            },\n            'L': {\n                'name': '2\\'-fluoro-U',\n                'weight': 308.16,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'I': {\n                'name': '2\\'-fluoro-A',\n                'weight': 331.2,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'J': {\n                'name': '2\\'-fluoro-C',\n                'weight': 307.18,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O',\n            },\n            'K': {\n                'name': '2\\'-fluoro-G',\n                'weight': 347.19,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1O',\n            },\n            'H': {\n                'name': '2\\'OMe-rU',\n                'weight': 320.2,\n                'normalized': 'rU',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'E': {\n                'name': '2\\'OMe-rA',\n                'weight': 343.24,\n                'normalized': 'rA',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n            'F': {\n                'name': '2\\'OMe-rC',\n                'weight': 319.21,\n                'normalized': 'rC',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O',\n            },\n            'G': {\n                'name': '2\\'OMe-rG',\n                'weight': 359.24,\n                'normalized': 'rG',\n                'SMILES': 'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O',\n            },\n        },\n    },\n};\n","import * as OCL from 'openchemlib/full.js';\nconst PHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 O 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst THIOPHOSHATE = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 5 4 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O -1.5 0 0 0\nM  V30 2 P 0 0 0 0\nM  V30 3 O 0 1 0 0\nM  V30 4 S 0 -1 0 0\nM  V30 5 O 1.5 0 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 1 2\nM  V30 2 2 2 3\nM  V30 3 1 2 4\nM  V30 4 1 2 5\nM  V30 END BOND\nM  V30 END CTAB\nM  V30 BEGIN COLLECTION\nM  V30 END COLLECTION\nM  END`;\nconst INVABASIC = `\nDatagrok monomer library Nucleotides\n\n  0  0  0  0  0  0              0 V3000\nM  V30 BEGIN CTAB\nM  V30 COUNTS 8 8 0 0 0\nM  V30 BEGIN ATOM\nM  V30 1 O 1.0934 -2.1636 0 0\nM  V30 2 C 1.8365 -1.4945 0 0 CFG=2\nM  V30 3 C 2.8147 -1.7024 0 0\nM  V30 4 C 3.3147 -0.8364 0 0 VAL=3\nM  V30 5 O 2.6455 -0.0932 0 0\nM  V30 6 C 1.732 -0.5 0 0 CFG=1\nM  V30 7 C 0.866 0 0 0\nM  V30 8 O 0.866 1 0 0\nM  V30 END ATOM\nM  V30 BEGIN BOND\nM  V30 1 1 2 1 CFG=1\nM  V30 2 1 2 3\nM  V30 3 1 3 4\nM  V30 4 1 4 5\nM  V30 5 1 6 5\nM  V30 6 1 2 6\nM  V30 7 1 6 7 CFG=3\nM  V30 8 1 7 8\nM  V30 END BOND\nM  V30 BEGIN COLLECTION\nM  V30 MDLV30/STEABS ATOMS=(2 2 6)\nM  V30 END COLLECTION\nM  V30 END CTAB\nM  END`;\nexport function getNucleotidesMol(smilesCodes, oclRender = false) {\n    const molBlocks = [];\n    for (let i = 0; i < smilesCodes.length - 1; i++) {\n        smilesCodes[i] == 'OP(=O)(O)O' ? molBlocks.push(PHOSHATE) :\n            smilesCodes[i] == 'OP(=O)(S)O' ? molBlocks.push(THIOPHOSHATE) :\n                smilesCodes[i] == 'O[C@@H]1C[C@@H]O[C@H]1CO' ? molBlocks.push(rotateNucleotidesV3000(INVABASIC)) :\n                    molBlocks.push(rotateNucleotidesV3000(smilesCodes[i]));\n    }\n    return linkV3000(molBlocks, false, oclRender);\n}\nexport function linkV3000(molBlocks, twoMolecules = false, oclRender = false) {\n    let macroMolBlock = '\\nDatagrok macromolecule handler\\n\\n';\n    macroMolBlock += '  0  0  0  0  0  0            999 V3000\\n';\n    macroMolBlock += 'M  V30 BEGIN CTAB\\n';\n    let atomBlock = '';\n    let bondBlock = '';\n    let collectionBlock = '';\n    const collection = [];\n    let natom = 0;\n    let nbond = 0;\n    let sequenceShift = 0;\n    let xShift = 0;\n    if (twoMolecules && molBlocks.length > 1)\n        molBlocks[1] = invertNucleotidesV3000(molBlocks[1]);\n    for (let i = 0; i < molBlocks.length; i++) {\n        molBlocks[i] = molBlocks[i].replaceAll('(-\\nM  V30 ', '(')\n            .replaceAll('-\\nM  V30 ', '').replaceAll(' )', ')');\n        const numbers = extractAtomsBondsNumbersV3000(molBlocks[i]);\n        const coordinates = extractAtomDataV3000(molBlocks[i]);\n        let indexAtoms = molBlocks[i].indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n        indexAtoms = molBlocks[i].indexOf('\\n', indexAtoms);\n        let index = indexAtoms;\n        let indexEnd = indexAtoms;\n        for (let j = 0; j < numbers.natom; j++) {\n            if (coordinates.atomIndex[j] != 1 || i == 0 || twoMolecules) {\n                //rewrite atom number\n                index = molBlocks[i].indexOf('V30', index) + 4;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                const atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n                molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n                //rewrite coordinates\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                const totalShift = xShift - coordinates.x[0];\n                let coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + totalShift)) / 10000;\n                molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);\n                index = molBlocks[i].indexOf(' ', index) + 1;\n                indexEnd = molBlocks[i].indexOf(' ', index);\n                coordinate = Math.round(10000 * (parseFloat(molBlocks[i].substring(index, indexEnd)) + sequenceShift)) / 10000;\n                molBlocks[i] = molBlocks[i].slice(0, index) + coordinate + molBlocks[i].slice(indexEnd);\n                index = molBlocks[i].indexOf('\\n', index) + 1;\n            }\n            else {\n                index = molBlocks[i].indexOf('M  V30', index) - 1;\n                indexEnd = molBlocks[i].indexOf('\\n', index + 1);\n                molBlocks[i] = molBlocks[i].slice(0, index) + molBlocks[i].slice(indexEnd);\n            }\n        }\n        const indexAtomsEnd = molBlocks[i].indexOf('M  V30 END ATOM');\n        atomBlock += molBlocks[i].substring(indexAtoms + 1, indexAtomsEnd);\n        let indexBonds = molBlocks[i].indexOf('M  V30 BEGIN BOND'); // V3000 index for bonds\n        indexBonds = molBlocks[i].indexOf('\\n', indexBonds);\n        index = indexBonds;\n        indexEnd = indexBonds;\n        for (let j = 0; j < numbers.nbond; j++) {\n            //rewrite bond number\n            index = molBlocks[i].indexOf('V30', index) + 4;\n            indexEnd = molBlocks[i].indexOf(' ', index);\n            const bondNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + nbond;\n            molBlocks[i] = molBlocks[i].slice(0, index) + bondNumber + molBlocks[i].slice(indexEnd);\n            //rewrite atom pair in bond\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            indexEnd = molBlocks[i].indexOf(' ', index);\n            let atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n            molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n            index = molBlocks[i].indexOf(' ', index) + 1;\n            indexEnd = Math.min(molBlocks[i].indexOf('\\n', index), molBlocks[i].indexOf(' ', index));\n            atomNumber = parseInt(molBlocks[i].substring(index, indexEnd)) + natom;\n            molBlocks[i] = molBlocks[i].slice(0, index) + atomNumber + molBlocks[i].slice(indexEnd);\n            index = molBlocks[i].indexOf('\\n', index) + 1;\n        }\n        const indexBondEnd = molBlocks[i].indexOf('M  V30 END BOND');\n        bondBlock += molBlocks[i].substring(indexBonds + 1, indexBondEnd);\n        let indexCollection = molBlocks[i].indexOf('M  V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections\n        while (indexCollection != -1) {\n            indexCollection += 28;\n            const collectionEnd = molBlocks[i].indexOf(')', indexCollection);\n            const collectionEntries = molBlocks[i].substring(indexCollection, collectionEnd).split(' ').slice(1);\n            collectionEntries.forEach((e) => {\n                collection.push(parseInt(e) + natom);\n            });\n            indexCollection = collectionEnd;\n            indexCollection = molBlocks[i].indexOf('M  V30 MDLV30/STEABS ATOMS=(', indexCollection);\n        }\n        natom += twoMolecules ? numbers.natom : numbers.natom - 1;\n        nbond += numbers.nbond;\n        xShift += twoMolecules ? 0 : coordinates.x[numbers.natom - 1] - coordinates.x[0];\n        sequenceShift += twoMolecules ? -7 : 0;\n    }\n    const entries = 4;\n    const collNumber = Math.ceil(collection.length / entries);\n    if (oclRender) {\n        collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length;\n        for (let j = 0; j < collection.length; j++)\n            collectionBlock += ' ' + collection[j];\n        collectionBlock += ')\\n';\n    }\n    else {\n        collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\\n';\n        for (let i = 0; i < collNumber; i++) {\n            collectionBlock += 'M  V30 ';\n            const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1) * entries : entries;\n            for (let j = 0; j < entriesCurrent; j++) {\n                collectionBlock += (j + 1 == entriesCurrent) ?\n                    (i == collNumber - 1 ? collection[entries * i + j] + ')\\n' : collection[entries * i + j] + ' -\\n') :\n                    collection[entries * i + j] + ' ';\n            }\n        }\n    }\n    //generate file\n    twoMolecules ? natom : natom++;\n    macroMolBlock += 'M  V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\\n';\n    macroMolBlock += 'M  V30 BEGIN ATOM\\n';\n    macroMolBlock += atomBlock;\n    macroMolBlock += 'M  V30 END ATOM\\n';\n    macroMolBlock += 'M  V30 BEGIN BOND\\n';\n    macroMolBlock += bondBlock;\n    macroMolBlock += 'M  V30 END BOND\\n';\n    macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n    macroMolBlock += collectionBlock;\n    macroMolBlock += 'M  V30 END COLLECTION\\n';\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END\\n';\n    return macroMolBlock;\n}\nfunction rotateNucleotidesV3000(molecule) {\n    let molBlock = molecule.includes('M  END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();\n    const coordinates = extractAtomDataV3000(molBlock);\n    const natom = coordinates.atomIndex.length;\n    const indexFivePrime = coordinates.atomIndex.indexOf(1);\n    const indexThreePrime = coordinates.atomIndex.indexOf(natom);\n    //fix 5 prime if inadequate\n    if (natom > 8)\n        fix5Prime(coordinates, indexFivePrime, indexThreePrime);\n    const xCenter = (coordinates.x[indexThreePrime] + coordinates.x[indexFivePrime]) / 2;\n    const yCenter = (coordinates.y[indexThreePrime] + coordinates.y[indexFivePrime]) / 2;\n    //place to center\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] -= xCenter;\n        coordinates.y[i] -= yCenter;\n    }\n    let angle = 0;\n    if (coordinates.x[indexFivePrime] == 0)\n        angle = coordinates.y[indexFivePrime] > coordinates.y[indexThreePrime] ? Math.PI / 2 : 3 * Math.PI / 2;\n    else if (coordinates.y[indexFivePrime] == 0)\n        angle = coordinates.x[indexFivePrime] > coordinates.x[indexThreePrime] ? Math.PI : 0;\n    else {\n        const derivative = coordinates.y[indexFivePrime] / coordinates.x[indexFivePrime];\n        angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);\n    }\n    const cos = Math.cos(angle);\n    const sin = Math.sin(angle);\n    for (let i = 0; i < natom; i++) {\n        const xAdd = coordinates.x[i];\n        coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n        coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n    }\n    //place to right\n    const xShift = coordinates.x[indexFivePrime];\n    for (let i = 0; i < natom; i++)\n        coordinates.x[i] -= xShift;\n    //rewrite molBlock\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    for (let i = 0; i < natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        index = molBlock.indexOf(' ', index) + 1;\n        index = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', indexEnd);\n        molBlock = molBlock.slice(0, index) +\n            coordinates.x[i] + ' ' + coordinates.y[i] +\n            molBlock.slice(indexEnd);\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return molBlock;\n}\nfunction invertNucleotidesV3000(molecule) {\n    let molBlock = molecule.includes('M  END') ? molecule : OCL.Molecule.fromSmiles(molecule).toMolfileV3();\n    const coordinates = extractAtomDataV3000(molBlock);\n    const natom = coordinates.atomIndex.length;\n    const xCenter = (Math.max(...coordinates.x) + Math.min(...coordinates.x)) / 2;\n    const yCenter = (Math.max(...coordinates.y) + Math.min(...coordinates.y)) / 2;\n    //place to center\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] -= xCenter;\n        coordinates.y[i] -= yCenter;\n    }\n    const angle = Math.PI;\n    const cos = Math.cos(angle);\n    const sin = Math.sin(angle);\n    for (let i = 0; i < natom; i++) {\n        const xAdd = coordinates.x[i];\n        coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n        coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n    }\n    //place back\n    const yShift = Math.max(...coordinates.y);\n    for (let i = 0; i < natom; i++) {\n        coordinates.x[i] += xCenter;\n        coordinates.y[i] -= yShift;\n    }\n    //rewrite molBlock\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    for (let i = 0; i < natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        index = molBlock.indexOf(' ', index) + 1;\n        index = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', index) + 1;\n        indexEnd = molBlock.indexOf(' ', indexEnd);\n        molBlock = molBlock.slice(0, index) +\n            coordinates.x[i] + ' ' + coordinates.y[i] +\n            molBlock.slice(indexEnd);\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return molBlock;\n}\nfunction fix5Prime(coordinates, indexFivePrime, indexThreePrime) {\n    const indexFivePrimeNeighbour = indexFivePrime + 1;\n    const xShift = coordinates.x[indexFivePrimeNeighbour];\n    const yShift = coordinates.y[indexFivePrimeNeighbour];\n    const base3PrimeX = coordinates.x[indexThreePrime] - xShift;\n    const base3PrimeY = coordinates.y[indexThreePrime] - yShift;\n    const base5PrimeX = coordinates.x[indexFivePrime] - xShift;\n    const base5PrimeY = coordinates.y[indexFivePrime] - yShift;\n    const rotated5PrimeX = base5PrimeX * Math.cos(Math.PI * 2 / 3) - base5PrimeY * Math.sin(Math.PI * 2 / 3);\n    const rotated5PrimeY = base5PrimeX * Math.sin(Math.PI * 2 / 3) + base5PrimeY * Math.cos(Math.PI * 2 / 3);\n    const dx = base5PrimeX - base3PrimeX;\n    const dy = base5PrimeY - base3PrimeY;\n    const dxRotated = rotated5PrimeX - base3PrimeX;\n    const dyRotated = rotated5PrimeY - base3PrimeY;\n    if (Math.sqrt(dyRotated * dyRotated + dxRotated * dxRotated) >= Math.sqrt(dy * dy + dx * dx)) {\n        coordinates.x[indexFivePrime] = rotated5PrimeX + xShift;\n        coordinates.y[indexFivePrime] = rotated5PrimeY + yShift;\n    }\n}\nfunction extractAtomsBondsNumbersV3000(molBlock) {\n    molBlock = molBlock.replaceAll('\\r', ''); //equalize old and new sdf standards\n    let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number\n    let indexEnd = molBlock.indexOf(' ', index);\n    const atomsNumber = parseInt(molBlock.substring(index, indexEnd));\n    index = indexEnd + 1;\n    indexEnd = molBlock.indexOf(' ', index);\n    const bondsNumber = parseInt(molBlock.substring(index, indexEnd));\n    return { natom: atomsNumber, nbond: bondsNumber };\n}\nfunction extractAtomDataV3000(molBlock) {\n    const numbers = extractAtomsBondsNumbersV3000(molBlock);\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    const indexes = Array(numbers.natom);\n    const types = Array(numbers.natom);\n    const x = Array(numbers.natom);\n    const y = Array(numbers.natom);\n    for (let i = 0; i < numbers.natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        indexEnd = molBlock.indexOf(' ', index);\n        indexes[i] = parseInt(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        types[i] = molBlock.substring(index, indexEnd);\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        x[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        y[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return { atomIndex: indexes, atomType: types, x: x, y: y };\n}\n","import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\n// import * as DG from 'datagrok-api/dg';\nimport { map, SYNTHESIZERS, TECHNOLOGIES, MODIFICATIONS } from './map';\nimport { asoGapmersNucleotidesToBioSpring, asoGapmersNucleotidesToGcrs, asoGapmersBioSpringToNucleotides, asoGapmersBioSpringToGcrs, asoGapmersGcrsToNucleotides, asoGapmersGcrsToBioSpring, gcrsToMermade12, siRnaNucleotideToBioSpringSenseStrand, siRnaNucleotideToAxolabsSenseStrand, siRnaNucleotidesToGcrs, siRnaBioSpringToNucleotides, siRnaBioSpringToAxolabs, siRnaBioSpringToGcrs, siRnaAxolabsToNucleotides, siRnaAxolabsToBioSpring, siRnaAxolabsToGcrs, siRnaGcrsToNucleotides, siRnaGcrsToBioSpring, siRnaGcrsToAxolabs, gcrsToNucleotides } from './converters';\nconst noTranslationTableAvailable = 'No translation table available';\nexport const undefinedInputSequence = 'Type of input sequence is undefined';\nexport function isValidSequence(sequence) {\n    let possibleSynthesizers = getListOfPossibleSynthesizersByFirstMatchedCode(sequence);\n    if (possibleSynthesizers.length > 1) {\n        const synthesizer = ui.choiceInput('Choose synthesizer from list: ', possibleSynthesizers[0], possibleSynthesizers);\n        ui.dialog('Choose Synthesizer')\n            .add(ui.panel([synthesizer.root], { style: { fontWeight: 'bold' } }))\n            .onOK(() => possibleSynthesizers = [synthesizer.value])\n            .onCancel(() => {\n            possibleSynthesizers = [possibleSynthesizers[0]];\n            grok.shell.warning('Input sequence is expected to be in format ' + possibleSynthesizers[0]);\n        })\n            .show();\n    }\n    else if (possibleSynthesizers.length == 0)\n        return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };\n    let outputIndex = 0;\n    const firstUniqueCharacters = ['r', 'd'];\n    const nucleotides = ['A', 'U', 'T', 'C', 'G'];\n    possibleSynthesizers.forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    const indexOfFirstNotValidChar = (outputIndex == sequence.length) ? -1 : outputIndex;\n    if (indexOfFirstNotValidChar != -1) {\n        return {\n            indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n            synthesizer: possibleSynthesizers[0],\n            technology: null,\n        };\n    }\n    let possibleTechnologies = getListOfPossibleTechnologiesByFirstMatchedCode(sequence, possibleSynthesizers[0]);\n    if (possibleTechnologies.length > 1) {\n        const technology = ui.choiceInput('Choose technology from list: ', possibleTechnologies[0], possibleTechnologies);\n        ui.dialog('Choose Technology')\n            .add(ui.panel([technology.root], { style: { fontWeight: 'bold' } }))\n            .onOK(() => possibleTechnologies = [technology.value])\n            .onCancel(() => {\n            possibleTechnologies = [possibleTechnologies[0]];\n            grok.shell.warning('Input sequence is expected to be in format ' + possibleTechnologies[0]);\n        })\n            .show();\n    }\n    else if (possibleTechnologies.length == 0)\n        return { indexOfFirstNotValidChar: 0, synthesizer: null, technology: null };\n    outputIndex = 0;\n    possibleTechnologies.forEach((technology) => {\n        const codes = Object.keys(map[possibleSynthesizers[0]][technology]);\n        while (outputIndex < sequence.length) {\n            const matchedCode = codes.find((c) => c == sequence.slice(outputIndex, outputIndex + c.length));\n            if (matchedCode == null)\n                break;\n            if ( // for mistake pattern 'rAA'\n            outputIndex > 1 &&\n                nucleotides.includes(sequence[outputIndex]) &&\n                firstUniqueCharacters.includes(sequence[outputIndex - 2]))\n                break;\n            if ( // for mistake pattern 'ArA'\n            firstUniqueCharacters.includes(sequence[outputIndex + 1]) &&\n                nucleotides.includes(sequence[outputIndex])) {\n                outputIndex++;\n                break;\n            }\n            outputIndex += matchedCode.length;\n        }\n    });\n    return {\n        indexOfFirstNotValidChar: indexOfFirstNotValidChar,\n        synthesizer: possibleSynthesizers[0],\n        technology: possibleTechnologies[outputIndex],\n    };\n}\nfunction getAllCodesOfSynthesizer(synthesizer) {\n    let codes = [];\n    for (const technology of Object.keys(map[synthesizer]))\n        codes = codes.concat(Object.keys(map[synthesizer][technology]));\n    return codes.concat(Object.keys(MODIFICATIONS));\n}\nfunction getListOfPossibleSynthesizersByFirstMatchedCode(sequence) {\n    const synthesizers = [];\n    Object.keys(map).forEach((synthesizer) => {\n        const codes = getAllCodesOfSynthesizer(synthesizer);\n        //TODO: get first non-dropdown code when there are two modifications\n        let start = 0;\n        for (let i = 0; i < sequence.length; i++) {\n            if (sequence[i] == ')' && i != sequence.length - 1) {\n                start = i + 1;\n                break;\n            }\n        }\n        if (codes.some((s) => s == sequence.slice(start, start + s.length)))\n            synthesizers.push(synthesizer);\n    });\n    return synthesizers;\n}\nfunction getListOfPossibleTechnologiesByFirstMatchedCode(sequence, synthesizer) {\n    const technologies = [];\n    Object.keys(map[synthesizer]).forEach((technology) => {\n        const codes = Object.keys(map[synthesizer][technology]).concat(Object.keys(MODIFICATIONS));\n        if (codes.some((s) => s == sequence.slice(0, s.length)))\n            technologies.push(technology);\n    });\n    return technologies;\n}\nexport function convertSequence(sequence, output) {\n    if (output.indexOfFirstNotValidChar != -1) {\n        return {\n            // type: '',\n            indexOfFirstNotValidChar: JSON.stringify(output),\n            Error: undefinedInputSequence,\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.RAW_NUCLEOTIDES && output.technology == TECHNOLOGIES.DNA) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + TECHNOLOGIES.DNA,\n            Nucleotides: sequence,\n            BioSpring: asoGapmersNucleotidesToBioSpring(sequence),\n            GCRS: asoGapmersNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.BIOSPRING && output.technology == TECHNOLOGIES.ASO_GAPMERS) {\n        return {\n            type: SYNTHESIZERS.BIOSPRING + ' ' + TECHNOLOGIES.ASO_GAPMERS,\n            Nucleotides: asoGapmersBioSpringToNucleotides(sequence),\n            BioSpring: sequence,\n            GCRS: asoGapmersBioSpringToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.GCRS && output.technology == TECHNOLOGIES.ASO_GAPMERS) {\n        return {\n            type: SYNTHESIZERS.GCRS + ' ' + TECHNOLOGIES.ASO_GAPMERS,\n            Nucleotides: asoGapmersGcrsToNucleotides(sequence),\n            BioSpring: asoGapmersGcrsToBioSpring(sequence),\n            Mermade12: gcrsToMermade12(sequence),\n            GCRS: sequence,\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.RAW_NUCLEOTIDES && output.technology == TECHNOLOGIES.RNA) {\n        return {\n            type: SYNTHESIZERS.RAW_NUCLEOTIDES + ' ' + TECHNOLOGIES.RNA,\n            Nucleotides: sequence,\n            BioSpring: siRnaNucleotideToBioSpringSenseStrand(sequence),\n            Axolabs: siRnaNucleotideToAxolabsSenseStrand(sequence),\n            GCRS: siRnaNucleotidesToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.BIOSPRING && output.technology == TECHNOLOGIES.SI_RNA) {\n        return {\n            type: SYNTHESIZERS.BIOSPRING + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaBioSpringToNucleotides(sequence),\n            BioSpring: sequence,\n            Axolabs: siRnaBioSpringToAxolabs(sequence),\n            GCRS: siRnaBioSpringToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.AXOLABS && output.technology == TECHNOLOGIES.SI_RNA) {\n        return {\n            type: SYNTHESIZERS.AXOLABS + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaAxolabsToNucleotides(sequence),\n            BioSpring: siRnaAxolabsToBioSpring(sequence),\n            Axolabs: sequence,\n            GCRS: siRnaAxolabsToGcrs(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.GCRS && output.technology == TECHNOLOGIES.SI_RNA) {\n        return {\n            type: SYNTHESIZERS.GCRS + ' ' + TECHNOLOGIES.SI_RNA,\n            Nucleotides: siRnaGcrsToNucleotides(sequence),\n            BioSpring: siRnaGcrsToBioSpring(sequence),\n            Axolabs: siRnaGcrsToAxolabs(sequence),\n            MM12: gcrsToMermade12(sequence),\n            GCRS: sequence,\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.GCRS) {\n        return {\n            type: SYNTHESIZERS.GCRS,\n            Nucleotides: gcrsToNucleotides(sequence),\n            GCRS: sequence,\n            Mermade12: gcrsToMermade12(sequence),\n        };\n    }\n    if (output.synthesizer == SYNTHESIZERS.MERMADE_12) {\n        return {\n            type: SYNTHESIZERS.MERMADE_12,\n            Nucleotides: noTranslationTableAvailable,\n            GCRS: noTranslationTableAvailable,\n            Mermade12: sequence,\n        };\n    }\n    return {\n        type: undefinedInputSequence,\n        Nucleotides: undefinedInputSequence,\n    };\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport { category, expect, test } from '@datagrok-libraries/utils/src/test';\nimport { sequenceToSmiles } from '../structures-works/from-monomers';\ncategory('sequence-translator', () => {\n    test('AGGTCCTCTTGACTTAGGCC', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=C(C)C(=O)NC2(=O))C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)C[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1OP(=O)(O)OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))C[C@@H]1O';\n        expect(sequenceToSmiles('AGGTCCTCTTGACTTAGGCC'), expected);\n    }));\n    test('invabasic/galnac1', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sgg(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('invabasic/galnac2', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sgsg(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('invabasic/galnac3', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sggs(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('invabasic/galnac4', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sgg(invabasic)s(GalNAc-2-JNJ)'), expected);\n    }));\n    test('usCfCfUfGfAf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('usCfCfUfGfAf'), expected);\n    }));\n    test('usAfsusgsgsg', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('usAfsusgsgsg'), expected);\n    }));\n    test('UfUfUfsCfsuacg', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('UfUfUfsCfsuacg'), expected);\n    }));\n    test('susususauasu', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OP(=O)(S)OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('susususauasu'), expected);\n    }));\n    test('CfGfCfsGfsCf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('CfGfCfsGfsCf'), expected);\n    }));\n    test('acacacsacsac', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('acacacsacsac'), expected);\n    }));\n    test('cccgggusug', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('cccgggusug'), expected);\n    }));\n    test('UfAfCfGfGfCfAfUf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('UfAfCfGfGfCfAfUf'), expected);\n    }));\n    test('(invabasic)sucuCfuUf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)sucuCfuUf'), expected);\n    }));\n    test('(invabasic)sAfgcugUf', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)sAfgcugUf'), expected);\n    }));\n    test('(invabasic)cuCfuUfsc', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)cuCfuUfsc'), expected);\n    }));\n    test('(invabasic)scususu(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)scususu(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)usAfsucuCfuUfAfgcugUfgCfacususu'), expected);\n    }));\n    test('(invabasic)asacgGfuGfCfAfacucuauuca', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)asacgGfuGfCfAfacucuauuca'), expected);\n    }));\n    test('(invabasic)scsgguGfcAfAfCfucuauucuga', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)scsgguGfcAfAfCfucuauucuga'), expected);\n    }));\n    test('(invabasic)scsaacUfcUfAfUfucuggacuua', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)scsaacUfcUfAfUfucuggacuua'), expected);\n    }));\n    test('(invabasic)sasacuCfuAfUfUfcuggacuuua', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1O';\n        expect(sequenceToSmiles('(invabasic)sasacuCfuAfUfUfcuggacuuua'), expected);\n    }));\n    test('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)usAfscug(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sasuaaCfcUf(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)sasuaaCfcUfCfUfuguaguuaua(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)scsaucacguUfGfCfagccgucuua(invabasic)(GalNAc-2-JNJ)'), expected);\n    }));\n    test('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)', () => __awaiter(void 0, void 0, void 0, function* () {\n        const expected = 'O[C@@H]1C[C@@H]O[C@H]1COP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(S)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=C(N)NC(=O)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](F)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(N)=NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C=CC(=O)NC2(=O))[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OC[C@H]1O[C@@H](N2C3N=CN=C(N)C=3N=C2)[C@H](OC)[C@@H]1OP(=O)(O)' +\n            'OCC(O)CNC(=O)CCCC(=O)NC(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)' +\n            '(COCCC(=O)NCCCNC(=O)CCCCOC2OC(CO)C(O)C(O)C2NC(=O)C)';\n        expect(sequenceToSmiles('(invabasic)susguuUfgCfCfUfacaucuacua(GalNAc-2-JNJ)'), expected);\n    }));\n});\n","module.exports = DG;","module.exports = OCL;","module.exports = grok;","module.exports = ui;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as DG from 'datagrok-api/dg';\nimport { runTests, tests } from '@datagrok-libraries/utils/src/test';\nimport './tests/smiles-tests';\nexport const _package = new DG.Package();\nexport { tests };\n//name: test\n//output: dataframe result\nexport function test() {\n    return __awaiter(this, void 0, void 0, function* () {\n        const data = yield runTests();\n        return DG.DataFrame.fromObjects(data);\n    });\n}\n"],"names":[],"sourceRoot":""}
|