1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825 |
- import {
- AlignmentResponse, GroupReference,
- SequenceReference,
- } from "@rcsb/rcsb-api-tools/build/RcsbGraphQL/Types/Borrego/GqlTypes";
- import {
- AlignmentCollectConfig,
- AlignmentCollectorInterface
- } from "@rcsb/rcsb-saguaro-app/build/dist/RcsbCollectTools/AlignmentCollector/AlignmentCollectorInterface";
- import {RcsbRequestContextManager} from "@rcsb/rcsb-saguaro-app";
- import {
- RcsbModuleDataProviderInterface
- } from "@rcsb/rcsb-saguaro-app/build/dist/RcsbFvWeb/RcsbFvModule/RcsbFvModuleInterface";
- import {AlignmentReference} from "./AlignmentReference";
- import {
- LocationProviderInterface,
- RigidTransformType, TransformMatrixType,
- TransformProviderInterface
- } from "../../../RcsbFvStructure/StructureUtils/StructureLoaderInterface";
- import {
- InstanceSequenceInterface
- } from "@rcsb/rcsb-saguaro-app/build/dist/RcsbCollectTools/DataCollectors/MultipleInstanceSequencesCollector";
- import {Alignment, AlignmentRegion, StructureAlignmentResponse} from "./alignment-response";
- const alignment = {
- "info": {
- "uuid": "e6e216de-c650-4ad5-bd81-45e75dfbe180",
- "status": "COMPLETE"
- },
- "meta": {
- "alignment_mode": "pairwise",
- "alignment_method": "fatcat-rigid"
- },
- "results": [
- {
- "structures": [
- {
- "entry_id": "101M",
- "selection": {
- "asym_id": "A"
- }
- },
- {
- "entry_id": "1ASH",
- "selection": {
- "asym_id": "A"
- }
- }
- ],
- "structure_alignment": [
- {
- "regions": [
- [
- {
- "asym_id": "A",
- "beg_seq_id": 4,
- "beg_index": 0,
- "length": 47
- },
- {
- "asym_id": "A",
- "beg_seq_id": 52,
- "beg_index": 52,
- "length": 70
- },
- {
- "asym_id": "A",
- "beg_seq_id": 124,
- "beg_index": 128,
- "length": 22
- }
- ],
- [
- {
- "asym_id": "A",
- "beg_seq_id": 1,
- "beg_index": 0,
- "length": 17
- },
- {
- "asym_id": "A",
- "beg_seq_id": 22,
- "beg_index": 21,
- "length": 61
- },
- {
- "asym_id": "A",
- "beg_seq_id": 86,
- "beg_index": 86,
- "length": 14
- },
- {
- "asym_id": "A",
- "beg_seq_id": 101,
- "beg_index": 101,
- "length": 47
- }
- ]
- ],
- "transformations": [
- [
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1
- ],
- [
- -0.7671995717115603,
- -0.5623954843039239,
- 0.30840904072376607,
- 0,
- -0.6011420900233072,
- 0.4627787494512096,
- -0.6515090303739346,
- 0,
- 0.2236805864799372,
- -0.6852351043918645,
- -0.6931232552303105,
- 0,
- 37.48154540719762,
- 28.2044983569036,
- -7.345065372687518,
- 1
- ]
- ],
- "summary": {
- "scores": [
- {
- "value": 1.95,
- "type": "RMSD"
- },
- {
- "value": 330.13,
- "type": "similarity-score"
- }
- ],
- "n_aln_residue_pairs": 139
- }
- }
- ],
- "sequence_alignment": [
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 4,
- "beg_index": 0,
- "length": 17
- },
- {
- "asym_id": "A",
- "beg_seq_id": 21,
- "beg_index": 21,
- "length": 62
- },
- {
- "asym_id": "A",
- "beg_seq_id": 83,
- "beg_index": 86,
- "length": 14
- },
- {
- "asym_id": "A",
- "beg_seq_id": 97,
- "beg_index": 101,
- "length": 49
- }
- ],
- "gaps": [
- {
- "beg_index": 17,
- "length": 4
- },
- {
- "beg_index": 83,
- "length": 3
- },
- {
- "beg_index": 100,
- "length": 1
- }
- ]
- },
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 1,
- "beg_index": 0,
- "length": 51
- },
- {
- "asym_id": "A",
- "beg_seq_id": 52,
- "beg_index": 52,
- "length": 74
- },
- {
- "asym_id": "A",
- "beg_seq_id": 126,
- "beg_index": 128,
- "length": 22
- }
- ],
- "gaps": [
- {
- "beg_index": 51,
- "length": 1
- },
- {
- "beg_index": 126,
- "length": 2
- }
- ]
- }
- ],
- "summary": {
- "scores": [
- {
- "value": 0.15,
- "type": "sequence-identity"
- },
- {
- "value": 1.94,
- "type": "RMSD"
- },
- {
- "value": 0.79,
- "type": "TM-score"
- },
- {
- "value": 330.13,
- "type": "similarity-score"
- },
- {
- "value": 0.34,
- "type": "sequence-similarity"
- }
- ],
- "n_aln_residue_pairs": 139,
- "n_modeled_residues": [
- 154,
- 147
- ],
- "seq_aln_len": 150,
- "aln_coverage": [
- 90,
- 95
- ]
- }
- },
- {
- "structures": [
- {
- "entry_id": "101M",
- "selection": {
- "asym_id": "A"
- }
- },
- {
- "entry_id": "4HHB",
- "selection": {
- "asym_id": "A"
- }
- }
- ],
- "structure_alignment": [
- {
- "regions": [
- [
- {
- "asym_id": "A",
- "beg_seq_id": 2,
- "beg_index": 0,
- "length": 48
- },
- {
- "asym_id": "A",
- "beg_seq_id": 56,
- "beg_index": 54,
- "length": 93
- }
- ],
- [
- {
- "asym_id": "A",
- "beg_seq_id": 1,
- "beg_index": 0,
- "length": 141
- }
- ]
- ],
- "transformations": [
- [
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1
- ],
- [
- 0.5659010881349978,
- 0.8158255303919226,
- 0.11909938038614465,
- 0,
- 0.49060456462775587,
- -0.21711201635870375,
- -0.8439013766543271,
- 0,
- -0.6626183815847819,
- 0.5359954069890864,
- -0.5231116554547112,
- 0,
- 16.44633740010974,
- 7.329736404913569,
- 7.069768946221407,
- 1
- ]
- ],
- "summary": {
- "scores": [
- {
- "value": 1.41,
- "type": "RMSD"
- },
- {
- "value": 360.42,
- "type": "similarity-score"
- }
- ],
- "n_aln_residue_pairs": 141
- }
- }
- ],
- "sequence_alignment": [
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 2,
- "beg_index": 0,
- "length": 147
- }
- ]
- },
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 1,
- "beg_index": 0,
- "length": 48
- },
- {
- "asym_id": "A",
- "beg_seq_id": 49,
- "beg_index": 54,
- "length": 93
- }
- ],
- "gaps": [
- {
- "beg_index": 48,
- "length": 6
- }
- ]
- }
- ],
- "summary": {
- "scores": [
- {
- "value": 1.63,
- "type": "RMSD"
- },
- {
- "value": 360.42,
- "type": "similarity-score"
- },
- {
- "value": 0.26,
- "type": "sequence-identity"
- },
- {
- "value": 0.83,
- "type": "TM-score"
- },
- {
- "value": 0.4,
- "type": "sequence-similarity"
- }
- ],
- "n_aln_residue_pairs": 141,
- "n_modeled_residues": [
- 154,
- 141
- ],
- "seq_aln_len": 147,
- "aln_coverage": [
- 92,
- 100
- ]
- }
- },
- {
- "structures": [
- {
- "entry_id": "101M",
- "selection": {
- "asym_id": "A"
- }
- },
- {
- "entry_id": "3IA3",
- "selection": {
- "asym_id": "A"
- }
- }
- ],
- "structure_alignment": [
- {
- "regions": [
- [
- {
- "asym_id": "A",
- "beg_seq_id": 6,
- "beg_index": 0,
- "length": 2
- },
- {
- "asym_id": "A",
- "beg_seq_id": 9,
- "beg_index": 3,
- "length": 10
- },
- {
- "asym_id": "A",
- "beg_seq_id": 70,
- "beg_index": 64,
- "length": 7
- },
- {
- "asym_id": "A",
- "beg_seq_id": 90,
- "beg_index": 84,
- "length": 64
- }
- ],
- [
- {
- "asym_id": "A",
- "beg_seq_id": 2,
- "beg_index": 0,
- "length": 2
- },
- {
- "asym_id": "A",
- "beg_seq_id": 5,
- "beg_index": 3,
- "length": 28
- },
- {
- "asym_id": "A",
- "beg_seq_id": 37,
- "beg_index": 99,
- "length": 23
- },
- {
- "asym_id": "A",
- "beg_seq_id": 62,
- "beg_index": 124,
- "length": 30
- }
- ]
- ],
- "transformations": [
- [
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1
- ],
- [
- 0.5053504853280419,
- -0.8551690322642134,
- -0.11535516128462073,
- 0,
- 0.8381805444620154,
- 0.45468307113605794,
- 0.3011920976845868,
- 0,
- -0.20512011569826996,
- -0.248896024633924,
- 0.946560355739325,
- 0,
- 54.00745824109328,
- 20.631415015987336,
- 1.2186542597577539,
- 1
- ]
- ],
- "summary": {
- "scores": [
- {
- "value": 10.35,
- "type": "RMSD"
- },
- {
- "value": 163.43,
- "type": "similarity-score"
- }
- ],
- "n_aln_residue_pairs": 83
- }
- }
- ],
- "sequence_alignment": [
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 6,
- "beg_index": 0,
- "length": 95
- },
- {
- "asym_id": "A",
- "beg_seq_id": 101,
- "beg_index": 99,
- "length": 23
- },
- {
- "asym_id": "A",
- "beg_seq_id": 124,
- "beg_index": 124,
- "length": 30
- }
- ],
- "gaps": [
- {
- "beg_index": 95,
- "length": 4
- },
- {
- "beg_index": 122,
- "length": 2
- }
- ]
- },
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 2,
- "beg_index": 0,
- "length": 13
- },
- {
- "asym_id": "A",
- "beg_seq_id": 15,
- "beg_index": 64,
- "length": 7
- },
- {
- "asym_id": "A",
- "beg_seq_id": 22,
- "beg_index": 84,
- "length": 70
- }
- ],
- "gaps": [
- {
- "beg_index": 13,
- "length": 51
- },
- {
- "beg_index": 71,
- "length": 13
- }
- ]
- }
- ],
- "summary": {
- "scores": [
- {
- "value": 0.38,
- "type": "TM-score"
- },
- {
- "value": 4.06,
- "type": "RMSD"
- },
- {
- "value": 163.43,
- "type": "similarity-score"
- },
- {
- "value": 0.13,
- "type": "sequence-identity"
- },
- {
- "value": 0.29,
- "type": "sequence-similarity"
- }
- ],
- "n_aln_residue_pairs": 83,
- "n_modeled_residues": [
- 154,
- 90
- ],
- "seq_aln_len": 154,
- "aln_coverage": [
- 54,
- 92
- ]
- }
- },
- {
- "structures": [
- {
- "entry_id": "101M",
- "selection": {
- "asym_id": "A"
- }
- },
- {
- "entry_id": "3IA3",
- "selection": {
- "asym_id": "B"
- }
- }
- ],
- "structure_alignment": [
- {
- "regions": [
- [
- {
- "asym_id": "A",
- "beg_seq_id": 1,
- "beg_index": 0,
- "length": 18
- },
- {
- "asym_id": "A",
- "beg_seq_id": 22,
- "beg_index": 22,
- "length": 30
- },
- {
- "asym_id": "A",
- "beg_seq_id": 58,
- "beg_index": 58,
- "length": 85
- }
- ],
- [
- {
- "asym_id": "B",
- "beg_seq_id": 6,
- "beg_index": 0,
- "length": 4
- },
- {
- "asym_id": "B",
- "beg_seq_id": 11,
- "beg_index": 5,
- "length": 129
- }
- ]
- ],
- "transformations": [
- [
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1
- ],
- [
- -0.42302765123934255,
- -0.016759653799444912,
- 0.9059617653584768,
- 0,
- 0.36791779101822186,
- 0.910522894182729,
- 0.18863869757125365,
- 0,
- -0.8280604478775673,
- 0.41311883662407556,
- -0.3790101865216464,
- 0,
- 80.69972926533072,
- -0.278244322992661,
- 6.001546353485595,
- 1
- ]
- ],
- "summary": {
- "scores": [
- {
- "value": 278.41,
- "type": "similarity-score"
- },
- {
- "value": 2.79,
- "type": "RMSD"
- }
- ],
- "n_aln_residue_pairs": 133
- }
- }
- ],
- "sequence_alignment": [
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 1,
- "beg_index": 0,
- "length": 4
- },
- {
- "asym_id": "A",
- "beg_seq_id": 5,
- "beg_index": 5,
- "length": 138
- }
- ],
- "gaps": [
- {
- "beg_index": 4,
- "length": 1
- }
- ]
- },
- {
- "regions": [
- {
- "asym_id": "B",
- "beg_seq_id": 6,
- "beg_index": 0,
- "length": 19
- },
- {
- "asym_id": "B",
- "beg_seq_id": 25,
- "beg_index": 22,
- "length": 30
- },
- {
- "asym_id": "B",
- "beg_seq_id": 55,
- "beg_index": 58,
- "length": 85
- }
- ],
- "gaps": [
- {
- "beg_index": 19,
- "length": 3
- },
- {
- "beg_index": 52,
- "length": 6
- }
- ]
- }
- ],
- "summary": {
- "scores": [
- {
- "value": 278.41,
- "type": "similarity-score"
- },
- {
- "value": 0.35,
- "type": "sequence-similarity"
- },
- {
- "value": 3.03,
- "type": "RMSD"
- },
- {
- "value": 0.66,
- "type": "TM-score"
- },
- {
- "value": 0.2,
- "type": "sequence-identity"
- }
- ],
- "n_aln_residue_pairs": 133,
- "n_modeled_residues": [
- 154,
- 135
- ],
- "seq_aln_len": 143,
- "aln_coverage": [
- 86,
- 99
- ]
- }
- }
- ]
- };
- const flexAlignment = {
- "info": {
- "uuid": "c74f1b38-ad36-4c24-88ea-c947eba2b965",
- "status": "COMPLETE"
- },
- "meta": {
- "alignment_mode": "pairwise",
- "alignment_method": "fatcat-flexible"
- },
- "results": [
- {
- "structures": [
- {
- "entry_id": "1SR6",
- "selection": {
- "asym_id": "A"
- }
- },
- {
- "entry_id": "1KWO",
- "selection": {
- "asym_id": "A"
- }
- }
- ],
- "structure_alignment": [
- {
- "regions": [
- [
- {
- "asym_id": "A",
- "beg_seq_id": 6,
- "beg_index": 0,
- "length": 18
- },
- {
- "asym_id": "A",
- "beg_seq_id": 26,
- "beg_index": 20,
- "length": 11
- },
- {
- "asym_id": "A",
- "beg_seq_id": 38,
- "beg_index": 32,
- "length": 163
- },
- {
- "asym_id": "A",
- "beg_seq_id": 213,
- "beg_index": 198,
- "length": 194
- },
- {
- "asym_id": "A",
- "beg_seq_id": 410,
- "beg_index": 395,
- "length": 153
- },
- {
- "asym_id": "A",
- "beg_seq_id": 566,
- "beg_index": 551,
- "length": 3
- },
- {
- "asym_id": "A",
- "beg_seq_id": 572,
- "beg_index": 557,
- "length": 54
- },
- {
- "asym_id": "A",
- "beg_seq_id": 643,
- "beg_index": 612,
- "length": 51
- }
- ],
- [
- {
- "asym_id": "A",
- "beg_seq_id": 6,
- "beg_index": 0,
- "length": 18
- },
- {
- "asym_id": "A",
- "beg_seq_id": 27,
- "beg_index": 20,
- "length": 174
- },
- {
- "asym_id": "A",
- "beg_seq_id": 213,
- "beg_index": 198,
- "length": 194
- },
- {
- "asym_id": "A",
- "beg_seq_id": 410,
- "beg_index": 395,
- "length": 153
- },
- {
- "asym_id": "A",
- "beg_seq_id": 569,
- "beg_index": 551,
- "length": 56
- },
- {
- "asym_id": "A",
- "beg_seq_id": 642,
- "beg_index": 610,
- "length": 52
- }
- ]
- ],
- "transformations": [
- [
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1
- ],
- [
- 0.5748680038797991,
- -0.6350218438618033,
- -0.5160174763839023,
- 0,
- 0.4813145452568598,
- 0.7724272890898242,
- -0.4143578062418128,
- 0,
- 0.6617122385443976,
- -0.010165672024066708,
- 0.7496889838278681,
- 0,
- -3.505312472354479,
- -5.385563704760273,
- 52.46070687230462,
- 1
- ]
- ],
- "summary": {
- "scores": [
- {
- "value": 1772.68,
- "type": "similarity-score"
- },
- {
- "value": 2.63,
- "type": "RMSD"
- }
- ],
- "n_aln_residue_pairs": 647
- }
- },
- {
- "regions": [
- [
- {
- "asym_id": "A",
- "beg_seq_id": 699,
- "beg_index": 668,
- "length": 3
- },
- {
- "asym_id": "A",
- "beg_seq_id": 707,
- "beg_index": 676,
- "length": 20
- },
- {
- "asym_id": "A",
- "beg_seq_id": 734,
- "beg_index": 700,
- "length": 102
- }
- ],
- [
- {
- "asym_id": "A",
- "beg_seq_id": 704,
- "beg_index": 668,
- "length": 23
- },
- {
- "asym_id": "A",
- "beg_seq_id": 734,
- "beg_index": 700,
- "length": 102
- }
- ]
- ],
- "transformations": [
- [
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1
- ],
- [
- 0.03983531379027039,
- -0.9969211935123139,
- -0.06753726157621881,
- 0,
- 0.5428660722665761,
- 0.07833822385293923,
- -0.8361576108996602,
- 0,
- 0.8388739925382667,
- -0.0033550871152113193,
- 0.5443153204102911,
- 0,
- 10.707819252191578,
- 1.4313621373339025,
- 38.51048821786332,
- 1
- ]
- ],
- "summary": {
- "scores": [
- {
- "value": 2.01,
- "type": "RMSD"
- },
- {
- "value": 328.8,
- "type": "similarity-score"
- }
- ],
- "n_aln_residue_pairs": 125
- }
- }
- ],
- "sequence_alignment": [
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 6,
- "beg_index": 0,
- "length": 195
- },
- {
- "asym_id": "A",
- "beg_seq_id": 213,
- "beg_index": 198,
- "length": 414
- },
- {
- "asym_id": "A",
- "beg_seq_id": 643,
- "beg_index": 612,
- "length": 88
- },
- {
- "asym_id": "A",
- "beg_seq_id": 734,
- "beg_index": 700,
- "length": 102
- }
- ],
- "gaps": [
- {
- "beg_index": 195,
- "length": 3
- }
- ]
- },
- {
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 6,
- "beg_index": 0,
- "length": 18
- },
- {
- "asym_id": "A",
- "beg_seq_id": 27,
- "beg_index": 20,
- "length": 11
- },
- {
- "asym_id": "A",
- "beg_seq_id": 38,
- "beg_index": 32,
- "length": 163
- },
- {
- "asym_id": "A",
- "beg_seq_id": 210,
- "beg_index": 195,
- "length": 197
- },
- {
- "asym_id": "A",
- "beg_seq_id": 410,
- "beg_index": 395,
- "length": 153
- },
- {
- "asym_id": "A",
- "beg_seq_id": 569,
- "beg_index": 551,
- "length": 3
- },
- {
- "asym_id": "A",
- "beg_seq_id": 572,
- "beg_index": 557,
- "length": 53
- },
- {
- "asym_id": "A",
- "beg_seq_id": 642,
- "beg_index": 610,
- "length": 1
- },
- {
- "asym_id": "A",
- "beg_seq_id": 643,
- "beg_index": 612,
- "length": 55
- },
- {
- "asym_id": "A",
- "beg_seq_id": 704,
- "beg_index": 668,
- "length": 3
- },
- {
- "asym_id": "A",
- "beg_seq_id": 707,
- "beg_index": 676,
- "length": 20
- },
- {
- "asym_id": "A",
- "beg_seq_id": 734,
- "beg_index": 700,
- "length": 102
- }
- ],
- "gaps": [
- {
- "beg_index": 18,
- "length": 2
- },
- {
- "beg_index": 31,
- "length": 1
- },
- {
- "beg_index": 392,
- "length": 3
- },
- {
- "beg_index": 548,
- "length": 3
- },
- {
- "beg_index": 554,
- "length": 3
- },
- {
- "beg_index": 611,
- "length": 1
- },
- {
- "beg_index": 667,
- "length": 1
- },
- {
- "beg_index": 671,
- "length": 5
- },
- {
- "beg_index": 696,
- "length": 4
- }
- ]
- }
- ],
- "summary": {
- "scores": [
- {
- "value": 2.48,
- "type": "RMSD"
- },
- {
- "value": 0.6,
- "type": "TM-score"
- },
- {
- "value": 2076.04,
- "type": "similarity-score"
- },
- {
- "value": 0.98,
- "type": "sequence-identity"
- },
- {
- "value": 0.98,
- "type": "sequence-similarity"
- }
- ],
- "n_aln_residue_pairs": 772,
- "n_modeled_residues": [
- 801,
- 780
- ],
- "seq_aln_len": 802,
- "aln_coverage": [
- 96,
- 99
- ]
- }
- }
- ]
- };
- const alignmentExample = {
- "info": {
- "uuid": "538d54e2-039c-44c8-bd5f-bb26af9c45bb",
- "status": "COMPLETE"
- },
- "meta": {
- "alignment_mode": "pairwise",
- "alignment_method": "fatcat-rigid"
- },
- "results": [
- {
- "structures": [
- {
- "url": "https://alphafold.ebi.ac.uk/files/AF-P41235-F1-model_v2.cif",
- "format": "mmcif",
- "is_binary": false,
- "name": "AF-P41235-F1",
- "selection": {
- "asym_id": "A"
- }
- },
- {
- "entry_id": "3CBB",
- "selection": {
- "asym_id": "C"
- }
- }
- ],
- "structure_alignment": [
- {
- "regions": [
- [
- {
- "asym_id": "A",
- "beg_seq_id": 58,
- "beg_index": 0,
- "length": 76
- }
- ],
- [
- {
- "asym_id": "C",
- "beg_seq_id": 1,
- "beg_index": 0,
- "length": 76
- }
- ]
- ],
- "transformations": [
- [
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1
- ],
- [
- 0.663932900191227,
- -0.6410962059424273,
- 0.3849529305900804,
- 0,
- -0.6205267418674186,
- -0.18505769796524382,
- 0.7620368829992492,
- 0,
- -0.4173004513190375,
- -0.7448149455737514,
- -0.5206832340097945,
- 0,
- 2.241812113864647,
- 17.198483576583477,
- -52.357664887014344,
- 1
- ]
- ],
- "summary": {
- "scores": [
- {
- "value": 214.71,
- "type": "similarity-score"
- },
- {
- "value": 0.47,
- "type": "RMSD"
- }
- ],
- "n_aln_residue_pairs": 76
- }
- }
- ],
- "sequence_alignment": [
- {
- "sequence": "MRLSKTLVDMDMADYSAALDPAYTTLEFENVQVLTMGNDTSPSEGTNLNAPNSLGVSALCAICGDRATGKHYGASSCDGCKGFFRRSVRKNHMYSCRFSRQCVVDKDKRNQCRYCRLKKCFRAGMKKEAVQNERDRISTRRSSYEDSSLPSINALLQAEVLSRQITSPVSGINGDIRAKKIASIADVCESMKEQLLVLVEWAKYIPAFCELPLDDQVALLRAHAGEHLLLGATKRSMVFKDVLLLGNDYIVPRHCPELAEMSRVSIRILDELVLPFQELQIDDNEYAYLKAIIFFDPDAKGLSDPGKIKRLRSQVQVSLEDYINDRQYDSRGRFGELLLLLPTLQSITWQMIEQIQFIKLFGMAKIDNLLQEMLLGGSPSDAPHAHHPLHPHLMQEHMGTNVIVANTMPTHLSNGQMCEWPRPRGQAATPETPQPSPPGGSGSEPYKLLPGAVATIVKPLSAIPQPTITKQEVI",
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 58,
- "beg_index": 0,
- "length": 76
- }
- ]
- },
- {
- "sequence": "ALCAICGDRATGKHYGASSCDGCKGFFRRSVRKNHMYSCRFSRQCVVDKDKRNQCRYCRLKKCFRAGMKKEAVQNERD",
- "regions": [
- {
- "asym_id": "C",
- "beg_seq_id": 1,
- "beg_index": 0,
- "length": 76
- }
- ]
- }
- ],
- "summary": {
- "scores": [
- {
- "value": 1,
- "type": "sequence-identity"
- },
- {
- "value": 214.71,
- "type": "similarity-score"
- },
- {
- "value": 1,
- "type": "sequence-similarity"
- },
- {
- "value": 0.49,
- "type": "RMSD"
- },
- {
- "value": 0.16,
- "type": "TM-score"
- }
- ],
- "n_aln_residue_pairs": 76,
- "n_modeled_residues": [
- 474,
- 76
- ],
- "seq_aln_len": 76,
- "aln_coverage": [
- 16,
- 100
- ]
- }
- },
- {
- "structures": [
- {
- "url": "https://alphafold.ebi.ac.uk/files/AF-P41235-F1-model_v2.cif",
- "format": "mmcif",
- "is_binary": false,
- "name": "AF-P41235-F1",
- "selection": {
- "asym_id": "A"
- }
- },
- {
- "entry_id": "1PZL",
- "selection": {
- "asym_id": "A"
- }
- }
- ],
- "structure_alignment": [
- {
- "regions": [
- [
- {
- "asym_id": "A",
- "beg_seq_id": 146,
- "beg_index": 0,
- "length": 21
- },
- {
- "asym_id": "A",
- "beg_seq_id": 173,
- "beg_index": 27,
- "length": 206
- }
- ],
- [
- {
- "asym_id": "A",
- "beg_seq_id": 5,
- "beg_index": 0,
- "length": 21
- },
- {
- "asym_id": "A",
- "beg_seq_id": 32,
- "beg_index": 27,
- "length": 206
- }
- ]
- ],
- "transformations": [
- [
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1,
- 0,
- 0,
- 0,
- 0,
- 1
- ],
- [
- -0.010053370832324049,
- -0.2331468555903751,
- -0.9723895687754106,
- 0,
- -0.5818706004499447,
- -0.7894818469306177,
- 0.19530749524542618,
- 0,
- -0.813219241082581,
- 0.5677684009306454,
- -0.12772434708280683,
- 0,
- 26.741147368855113,
- 9.829205405298664,
- 85.1383381307709,
- 1
- ]
- ],
- "summary": {
- "scores": [
- {
- "value": 0.85,
- "type": "RMSD"
- },
- {
- "value": 638.55,
- "type": "similarity-score"
- }
- ],
- "n_aln_residue_pairs": 227
- }
- }
- ],
- "sequence_alignment": [
- {
- "sequence": "MRLSKTLVDMDMADYSAALDPAYTTLEFENVQVLTMGNDTSPSEGTNLNAPNSLGVSALCAICGDRATGKHYGASSCDGCKGFFRRSVRKNHMYSCRFSRQCVVDKDKRNQCRYCRLKKCFRAGMKKEAVQNERDRISTRRSSYEDSSLPSINALLQAEVLSRQITSPVSGINGDIRAKKIASIADVCESMKEQLLVLVEWAKYIPAFCELPLDDQVALLRAHAGEHLLLGATKRSMVFKDVLLLGNDYIVPRHCPELAEMSRVSIRILDELVLPFQELQIDDNEYAYLKAIIFFDPDAKGLSDPGKIKRLRSQVQVSLEDYINDRQYDSRGRFGELLLLLPTLQSITWQMIEQIQFIKLFGMAKIDNLLQEMLLGGSPSDAPHAHHPLHPHLMQEHMGTNVIVANTMPTHLSNGQMCEWPRPRGQAATPETPQPSPPGGSGSEPYKLLPGAVATIVKPLSAIPQPTITKQEVI",
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 146,
- "beg_index": 0,
- "length": 233
- }
- ]
- },
- {
- "sequence": "SSYELASLPSINALLQAEVLSRQITSPVSGINGDIRAKKIASIADVCESMKEQLLVLVEWAKYIPAFCELPLDDQVALLRAHAGEHLLLGATKRSMVFKDVLLLGNDYIVPRHCPELAEMSRVSIRILDELVLPFQELQIDDNEYAYLKAIIFFDPDAKGLSDPGKIKRLRSQVQVSLEDYINDRQYDSRGRFGELLLLLPTLQSITWQMIEQIQFIKLFGMAKIDNLLQEMLLGGS",
- "regions": [
- {
- "asym_id": "A",
- "beg_seq_id": 5,
- "beg_index": 0,
- "length": 21
- },
- {
- "asym_id": "A",
- "beg_seq_id": 32,
- "beg_index": 27,
- "length": 206
- }
- ],
- "gaps": [
- {
- "beg_index": 21,
- "length": 6
- }
- ]
- }
- ],
- "summary": {
- "scores": [
- {
- "value": 1.1,
- "type": "RMSD"
- },
- {
- "value": 0.47,
- "type": "TM-score"
- },
- {
- "value": 638.55,
- "type": "similarity-score"
- },
- {
- "value": 1,
- "type": "sequence-similarity"
- },
- {
- "value": 0.99,
- "type": "sequence-identity"
- }
- ],
- "n_aln_residue_pairs": 227,
- "n_modeled_residues": [
- 474,
- 227
- ],
- "seq_aln_len": 233,
- "aln_coverage": [
- 48,
- 100
- ]
- }
- }
- ]
- };
- class RcsbStructuralAlignmentProvider implements AlignmentCollectorInterface {
- private alignmentResponse: AlignmentResponse | undefined = undefined;
- private readonly alignment: StructureAlignmentResponse;
- constructor(alignment: StructureAlignmentResponse) {
- this.alignment = alignment;
- }
- async collect(requestConfig: AlignmentCollectConfig, filter?: Array<string>): Promise<AlignmentResponse> {
- return new Promise(async (resolve)=>{
- resolve(await this.data());
- });
- }
- async getTargets(): Promise<string[]> {
- return new Promise(async (resolve)=>{
- resolve((await this.data()).target_alignment?.map(ta=>ta?.target_id ?? "NA") ?? [])
- })
- }
- async getAlignmentLength(): Promise<number> {
- return new Promise(async (resolve)=>{
- const ends = (await this.data() ).target_alignment?.map(ta=>ta?.aligned_regions?.[ta?.aligned_regions?.length-1]?.query_end);
- resolve(Math.max(...(ends as number[])))
- })
- }
- async getAlignment(): Promise<AlignmentResponse> {
- return new Promise(async (resolve)=>{
- resolve(this.data());
- });
- }
- private async data(): Promise<AlignmentResponse> {
- if(this.alignmentResponse)
- return this.alignmentResponse;
- return new Promise((resolve)=>{
- alignmentTransform(this.alignment).then(ar=>{
- this.alignmentResponse = ar;
- resolve(ar);
- })
- });
- }
- }
- class RcsbStructuralTransformProvider implements TransformProviderInterface {
- private readonly alignment: StructureAlignmentResponse;
- constructor(alignment: StructureAlignmentResponse) {
- this.alignment = alignment;
- }
- get(entryId: string, asymId?: string): RigidTransformType[] {
- const res = this.alignment.results?.find(res=>{
- const r = res.structures[1];
- return ("entry_id" in r && r.entry_id == entryId && r.selection && "asym_id" in r.selection && r.selection.asym_id == asymId)
- });
- if(res?.structure_alignment.length == 1) {
- return [{
- transform: res.structure_alignment[0].transformations[1] as TransformMatrixType
- }];
- }else if(res?.structure_alignment.length && res?.structure_alignment.length > 1){
- return res.structure_alignment.map(sa=>({
- transform: sa.transformations[1] as TransformMatrixType,
- regions: sa.regions?.[1].map(r=>[r.beg_seq_id,r.beg_seq_id+r.length-1])
- }));
- }else{
- return [{
- transform: [1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1]
- }];
- }
- }
- }
- class RcsbStructureLocationProvider implements LocationProviderInterface {
- private readonly alignment: StructureAlignmentResponse;
- constructor(alignment: StructureAlignmentResponse) {
- this.alignment = alignment;
- }
- get(entryId:string): string|undefined {
- for(const res of this.alignment.results ?? []){
- if("url" in res.structures[0] && res.structures[0].url && res.structures[0].name == entryId ){
- return res.structures[0].url;
- }
- if("url" in res.structures[1] && res.structures[1].url && res.structures[1].name == entryId ){
- return res.structures[1].url;
- }
- }
- return undefined;
- }
- }
- async function alignmentTransform(alignment: StructureAlignmentResponse): Promise<AlignmentResponse> {
- if(!alignment.results)
- return {};
- const alignmentRef = await mergeAlignments(alignment.results);
- const out: AlignmentResponse = alignmentRef.buildAlignments();
- const seqs = await getSequences(alignment.results);
- out.target_alignment?.forEach(ta=>{
- const seq = seqs.find(s=>s.rcsbId===ta?.target_id)?.sequence
- if(seq && ta)
- ta.target_sequence = seq;
- });
- return out;
- }
- async function mergeAlignments(results: Alignment[]): Promise<AlignmentReference> {
- const result = results[0];
- if(!result)
- throw "Results not available";
- const seqs = await getSequences([result]);
- const alignmentRef = new AlignmentReference( getInstanceId(result, 0), seqs[0].sequence.length)
- results.forEach(result=>{
- if(result.sequence_alignment)
- alignmentRef.addAlignment(getInstanceId(result), transformToGapedDomain(result.sequence_alignment[0].regions), transformToGapedDomain(result.sequence_alignment[1].regions));
- else if(result.structure_alignment && result.structure_alignment[0].regions && result.structure_alignment[1].regions)
- alignmentRef.addAlignment(getInstanceId(result), transformToGapedDomain(result.structure_alignment[0].regions.flat()), transformToGapedDomain(result.structure_alignment[1].regions.flat()));
- });
- return alignmentRef;
- }
- function getInstanceId(result: Alignment, index: 0|1 = 1): string {
- const res = result.structures[index];
- if("entry_id" in res && res.entry_id && res.selection && "asym_id" in res.selection)
- return`${res.entry_id}.${res.selection.asym_id}`;
- else if("name" in res && res.selection &&"asym_id" in res.selection)
- return `${res.name}.${res.selection.asym_id}`;
- throw new Error("Missing entry_id and name from result");
- }
- function transformToGapedDomain(regions: AlignmentRegion[]): (number|undefined)[] {
- const out: (number|undefined)[] = [];
- let prevRegionEnd = 0;
- regions.forEach(region=>{
- const beg = region.beg_index+1;
- const end = region.beg_index+region.length;
- if(beg > (prevRegionEnd+1)){
- const nGaps = beg - (prevRegionEnd+1);
- out.push(...Array(nGaps).fill(undefined));
- }
- prevRegionEnd = end;
- const seqBeg = region.beg_seq_id;
- const seqEnd = region.beg_seq_id+region.length-1;
- for(let i=seqBeg;i<=seqEnd;i++){
- out.push(i);
- }
- });
- return out;
- }
- async function getSequences(results: Alignment[]): Promise<InstanceSequenceInterface[]> {
- const out: InstanceSequenceInterface[] = [];
- const missingIds: string[] = [];
- const res = results[0];
- if(res.sequence_alignment?.[0].sequence) {
- out.push( {
- rcsbId: getInstanceId(res,0),
- sequence: res.sequence_alignment[0].sequence
- })
- }else{
- missingIds.push( getInstanceId(res, 0) )
- }
- results.forEach(res=>{
- if(res.sequence_alignment?.[1].sequence) {
- out.push( {
- rcsbId: getInstanceId(res,1),
- sequence: res.sequence_alignment[1].sequence
- })
- }else{
- missingIds.push( getInstanceId(res) )
- }
- });
- return out.concat(await RcsbRequestContextManager.getInstanceSequences(missingIds));
- }
- const structuralAlignment: StructureAlignmentResponse = alignmentExample as StructureAlignmentResponse;
- export const dataProvider: RcsbModuleDataProviderInterface = {
- alignments: {
- collector: new RcsbStructuralAlignmentProvider(structuralAlignment),
- context:{
- queryId: "structural-alignment",
- group: GroupReference.MatchingUniprotAccession,
- to: SequenceReference.PdbInstance
- }
- }
- };
- export const transformProvider = new RcsbStructuralTransformProvider(structuralAlignment);
- export const structureLocationProvider = new RcsbStructureLocationProvider(structuralAlignment);
|