= NIAID SOW Proposed deliverables (based on 2 FTE), January 2020 = August 1, 2020 - February 28 , 2021. Original [https://docs.google.com/document/d/1YY4Gp-2HSKM3SKT-kBkrUm92gCu6ocptIbgMHk15Qjs/edit# Google doc version]. Earlier [wiki:NeteSOWDraft SOW draft]. Extra [wiki:NeteSOWExtra 2.5 FTE deliverables]. 1. Extensions to ChimeraX to support the NIH 3D pipeline a. Support the conversion of existing NIH 3D Print Exchange Chimera scripts to ChimeraX, advising on ChimeraX syntax for capabilities where available and noting missing features in ChimeraX where comparable features don’t exist i. **Investigate using Smart Display** i. **Discuss Python vs. ChimeraX command line** a. ~~Implement essential missing features discovered above, including: i. ~~!PubChem fetch i. ~~Additional import formats, including mol and sdf i. ~~PDB biounit fetch~~ #3515 a. ~~Sequence conservation coloring in ChimeraX a. Fetch sequence annotations (!UniProt, domains, disease-associated mutations) (Eric) i. Automatic labels a. Enhancements to X3D export format (Greg) i. Look at GLTF export improvements (support for both per vertex coloring and **texture coloring**) a. Read and visualize segmentation models (see deliverable 2) (Tom) 2. Significantly enhance ChimeraX’s segmentation capabilities for 3d electron microscopy, light microscopy, and medical imaging a. Interactive SimpleITK use in ChimeraX (Tom) a. Allow loading, visualizing, creating, measuring and saving segmentations. (Tom) a. Support new EMDB-SFF segmentation file format from the EM Databank (Tom). #3639 in progress a. NOTE: some example data sets would be useful - AI Detected Lesions in lungs. Phil will get some data to TomG. Could also look at some data sets from SimpleITK. Bryan Hansen and Beth Fisher could also get some data sets 3. Medical imaging a. Metadata browser for DICOM files (Tom) a. **Support radiologist collaborator needs by adapting ChimeraX to better suit standard workflows and to provide critical missing features identified by our collaborators** (Tom) i. Need to get a collaborator i. Les Folio / Ron Summers i. New NIAID section focused on lung imaging i. Roberto Rodriguez Rubio, MD at UCSF director of [https://skullbaselab.ucsf.edu Skull Base lab], interested in VR. Emphasis on dissections, no medical imaging. 4. Improve multi-person VR beyond work accomplished in 2019 SOW a. **Localizable connection server solution - deliver a rendezvous server that can easily be deployed by institutions or enterprises. (Conrad/Greg)** i. Fix cxconference TLS security #3629 i. ~~Get TLS certificate for plato cxconference server (Greg) i. Make cxconference work with VR #2892, #2893, #3498, #3512 i. **Greg to help containerize cxconference** 5. Human Biomolecular Atlas Program (HuBMAP) multiscale visualization a. Engage with the HuBMAP group to evaluate the potential for ChimeraX extensions to support exploration and analysis of HuBMAP data, particularly as those extensions align with NIAID areas of interest. This will include determining the programmatic interfaces to access the HuBMAP data and initial efforts to scope the task of supporting the various HuBMAP data formats. i. Discuss needs with Meghan !McCarthy and Darrell Hurt 6. Outreach a. Workshops, Training and presentations a. Instructional material and tools documentation. i. Detailed instructions for all features shall be provided in a user manual i. Written user guides and tutorials shall be available as an HTML page 7. Administration a. A project schedule, implementation plan, and documentation plan will be provided a. Monthly status reports detailing progress on each subtask will be delivered Additional Requests from Users 1. Adding Coulombic coloring (Eric) #3596 (Elaine: this is one of the essential missing features mentioned in 1b above) a. 90% cases covered 1. Colada export for preparing models for PathogenAR cellphone app (Tom) #485 1. ~~Add support for SDF V3000 (Eric) = Meeting Notes = Zoom meeting URL [https://nih.zoomgov.com/j/1600907987 https://nih.zoomgov.com/j/1600907987] == 9/24/2020 == Darrell Hurt, Phil Cruz, Meghan !McCarthy, Scooter Moris, Greg Couch, Tom Goddard, Elaine Meng, Eric Pettersen 1. NIH 3D pipeline status a. they're working on the architecture, backend, using GLTF (.glb) rather than X3D a. Darrell: Philip will use ChimeraX as executable rather than reaching into python a. Scooter: how about REST interface approach with Json; are they interested? a. Darrell: makes sense, but need Philip to weigh in 2. VR meeting a. TomG, Phil, Victor tried 3-way meeting to work on firewall issues. a. Direct connection to TomG's home computer worked. a. AWS firewall mis-configured, test failed, will try again. a. Found several bugs in multiuser VR, created tickets. #3735, #3736, #3737, #3738, #3739, #3740, #3755. a. Discussed naming meetings using a rendezvous service, simplifying AWS setup, providing free AWS service hosted by NIAID or UCSF. 3. V3000 SDF support from Eric a. Phil is happy, allows them to jettison OpenBabel a. Elaine put this in Change Log dated Sept 15 4. macOS Big Sur a. TomG mentions ChimeraX fails to on macOS Big Sur beta, patched in daily build a. Phil says they aren't even at Catalina yet 5. VR hand tracking a. Darrell asks about VR hand-tracking, shows video of putting on gloves, PPE a. TomG has not looked at hand-tracking since the Leap device has poor tracking == 10/08/2020 == Darrell, Meghan, Phil, Philip, Kristen, Victor; Scooter, Greg, Elaine, Eric, TomG - ChimeraX REST interface and Json output - Eric demo with GUI but can be done with script in nogui mode - "remotecontrol" to start REST, put URL shown in the ChimeraX Log into web browser; the resulting page allows entering commands and getting json replies, if any - currently Json output is implemented for "open" and "info" commands - would be useful for "info chain" to report polymer type in addition to whether there are any polymers - maybe we can provide a prototype python script to start rest, open structure, get information on chains and their types - Eric will improve user-error reporting in json - VR experiment 1 wk ago with 4-way: Phil, Meghan, Victor, TomG via AWS - found more bugs, including "ghosts" (now fixed) - TomG recently added (Sep 30) features: new input model type [http://rbvi.ucsf.edu/chimerax/docs/user/commands/open.html#miscellaneous photo] (2D image, e.g. for showing a paper figure in VR) and new [http://rbvi.ucsf.edu/chimerax/docs/user/commands/ui.html#functions move picked model] mouse mode to move models w/o having to select them first - TomG plans to add remembering the face image, name, and hand-cone color previously specified for VR meeting - worked pretty well on cheapest AWS tier - perhaps NIAID could provide the hub - Greg wonders about security; TomG mentions ssh tunneling, Scooter mentions generated password == 10/22/2020 == Darrell, Meghan, Phil, Philip, Kristen, Victor; Greg, Elaine, Eric, TomG - Scooter on vacation for a month, sailing home from Mexico, returns Nov 22 (Elaine: this is approximate, weather-dependent) NIH 3D pipeline: - Eric working on converting workflow to ChimeraX - Got 3 scripts from Phil Cruz - TomG joined github repository for scripts set up by Philip; it seems that 2-factor authentication will not be a problem for our day-to-day work - Eric: only few issues with the 2 shorter scripts - ChimeraX does not write VRML; not absolute requirement, can convert glb to vrml in separate step - ChimeraX "graphics quality" can be used to adjust numbers of triangles for STL output - no incremental radius adjustment a la Chimera vdwdefine plus/minus; Eric will supply python to do this - no combine, why was it used? Phil: to handle biological assemblies that were multiple models. Eric: now the fetch gets the assemblies as single models - Philip asks about taking all the file reading and branching out of the ChimeraX scripts and instead have several separate ChimeraX scripts that are called; however, parsing with ChimeraX has several advantages - Phil: actually may want to combine small-molecule and macromolecule scripts into one to reduce user error; distinction is presence of "standard residues" (biopolymer chains) - Darrell: how about also combining with volume script, have ChimeraX identify if upload is map? Eric: should be doable, at least if filename has standard suffix - Darrell: will also need to distinguish which database goes with an identifier for fetch purposes - Tom: maybe run ChimeraX once to assess content, send feedback/questions to user, then run ChimeraX again for the processing - Phil: if REST, is a hybrid approach possible? Could just do via REST without having to run ChimeraX twice - Eric has improved error reporting in JSON Topics not covered: - VR meetings: firewalls, slow networks, 3 or 4 participants - Wrote documentation for setting up AWS server added to meeting command web page - David Liou has set up NIAID AWS server, will test tomorrow - Working on improved handling of low-bandwidth connections - Adding meeting command proxy options for simpler use of AWS == 11/5/2020 == Darrell, Phil, Philip, Kristen; Greg, Elaine, Eric, TomG, TomF **Pre-meeting agenda** NIH 3D pipeline: - Eric transcribing print exchange scripts to ChimeraX - Improved performance with surfaces on large molecular complexes - fixed struts command making too many struts when used in script - Studying how to handle level of detail for different use cases. - Tested ChimeraX glTF of RNA on social VR platform Spatial - colors shown in Oculus Quest, but not in web browser. - Is there an NIH 3D proposal the ChimeraX team can read? - Is there a deadline for an initial pipeline prototype. COVID PCR cellphone module: - Kristen working on sars-cov-2 rna models, trying ChimeraX rna command. VR meetings: - Tested NIAID AWS meeting proxy with Phil and Victor with Phil hosting, all worked. - Added name server: - start meeting "meeting start id covid-pcr" - join meeting "meeting id covid-pcr" - Set up chimeraxmeeting.net domain for UCSF AWS meeting proxy and name server. - Tried two simultaneous meetings on one AWS proxy server, worked fine. - Made non-VR meeting participants see synchronized view direction. - Improved session file compression using lz4 (4x smaller) to speed up joining meeting especially for low bandwidth connections. ** Actual discussion ** 3D Pipeline: Eric has translated the Chimera scripts into a single combined ChimeraX script that figures out processing path (small-mol, macromol, or map) from input file. Will get it to them via github. Much discussion of control process, Phil notes that it is not always possible to discern whether one wants to treat an atomic structure as small or macro, so it will be necessary to allow user to specify which path to take. Philip: why not always make all possible outputs for a given input? Don't worry about comp time or output size. Phil: can present the user with gallery of outputs when they return to the website. Current process is not interactive, so not a problem if it takes several minutes. TomG: hybrid approach, can ask user questions about what they want but also provide multiple alternatives. What is their goal for revamping pipeline? First goal is to reproduce the Chimera outputs with similar from ChimeraX, except GLTF instead of X3D. Darrell: re triangles, original goal was try to get a model that looked nice in graphics and was also suitable for 3D printing. Found that postprocessing decimation was better at maintaining appearance than decreasing triangles in Chimera; TomG: ChimeraX probably same, as we have not implemented fancy decimation or mesh repair. Functionality is largely there, but implementations/parameters differ and will require some experimentation. E.g. ChimeraX does have a ''sym'' command with option to show surfaces, but the surfaces are calculated differently than in Chimera VR meetings: - TomG was able to run multiple meetings using same AWS virtual machine as proxy - TomG added default meeting-name server chimeraxmeeting.net, but one can choose not to name the meeting, or use diff name server (will be saved in Prefs) - Phil and Victor will test with low bandwidth; new session-compression will help == 11/19/2020 == **Pre-meeting agenda** Darrell, Phil, Philip, Kristen, Meghan; Greg, Elaine, Eric, TomG, TomF Eric cannot attend today. 3D Pipeline: - Eric modified the ChimeraX pipeline script to allow specifying which branch to take (small mol, macromol, or map), or if not specified then chosen automatically. Regardless, the script reports what branch is used. He put the script on your github a couple of weeks ago. Feedback? - Eric is working on porting addcharge to ChimeraX for a more complete implementation of coloring by Coulombic ESP - Are there specific improvements to glTF output needed in ChimeraX? VR Meetings: - Phil, Victor and Meghan tried having two simultaneous two person meetings (one started by Phil, one by Tom) on the NIAID AWS server, last Friday. Worked with not noticeable slow down. - New VR meeting user interface panel so no knowledge of the meeting command syntax is needed. Menu Tools / General / Meeting. Elaine has documented it. - Meeting commands can now define multiple proxy servers. Segmentation, Medical Imaging, HuBMAP: - Our NIH 3D and VR meeting contract goals have made good progress. Which one of the 3 other areas, segmentation, medical imaging and HuBMAP would be best to get started? Are there BCBB projects we could assist on in these 3 areas? ** Discussion ** Darrell will be on a long road trip to Idaho, Colorado, Texas(?) in December for son's wedding and visit parents. Did not get exact dates. 3D Pipeline: - Phil has tried the script, seems to work well in a few tests, needs to try with more data including edge cases and wider range of sizes - The script looks for a recommended contour level for maps from EMDB, but some maps do not have this annotation - NIH 3D Print Exchange will need Chimera 1.15 because of changes in RCSB PDB fetch - Add new fetches? - Crystallography Open Database provides CIF, but ChimeraX does not read small-molecule CIF - ZINC provides formats ChimeraX reads (SDF, MOL2), we will reach out to Shoichet and/or Irwin VR Meetings: - Meghan: we will try a VR meeting with Uganda - Victor: ...or with our own low-bandwidth test equipment - the Meeting GUI is easier than using command, remembers multiple proxy servers - TomG will investigate lowering the bandwidth requirement by using !MessagePack library - TomG wants to make a science-focused video also to publicize ChimeraX meeting capabilities Segmentation, Medical Imaging, HuBMAP: - re Hubmap, the contract was to investigate it rather than to implement specific visualization - Kristen: may be too early to work with Hubmap, seems in flux - Darrell: would still like to prioritize Hubmap - Darrell: then secondarily, medical imaging; make use of ITK somehow? Would be strategic move to incorporate ITK. NIH has made investments in Hubmap and ITK, so using them may help subsequent round of funding. - TomG: maybe work to make ChimeraX show DICOM simple ITK segmentations - They will invite simple ITK developer(s) to our next meeting, Liv and Brad. == 12/17/2020 == VR meetings - VR session with Uganda worked very well Cytoscape for HuBMAP data - Let's arrange for Scooter to demo scNetViz to the NIAID folks; see also [https://science.sciencemag.org/content/370/6522/eaaz4910 recent Science paper] in which a Cytoscape app is used to map genetic interactions onto structures in ChimeraX Next contract - We are drafting a task list for renewing the contract next year. HuBMAP visualization - Discussion of !HubMap and ontologies. - !HubMap data has issues revealed in ChimeraX, like different brightnesses and z-planes for different tiles within the intestine data. - Scooter knows Nils Gehlenborg (Harvard), maybe we could set up a meeting to discuss how ChimeraX can contribute to viewing !HubMap data using capabilities beyond those in the portal. TomG would like more time to think about this (what exactly are the "beyond" capabilities: custom,in-depth analyses?) before we schedule a meeting. HuBMAP anatomical models - Kristen Browne talked about making anatomical organ models with Katy Borner for HuBMAP reference frame for positioning deposited samples. - Katy has a person working on a VR placement tool. - BCBB will have all the anatomical models in NIH 3D. !UniProt features in ChimeraX - Eric has implemented getting sequence features from !UniProt into ChimeraX, available in next daily build Next meeting 1/14. Darrell returns January 11. == 1/14/2021 == Christopher Whalen (infrastructure, VR & other), Phil, Philip, Kristen, Victor; Scooter, Greg, Elaine, Eric, TomG Scooter: we need to think about getting the next contract together soon. We will send a document with some possibilities. VR: Good performance in multisite meetings, even cross-country Medical imaging: Got some helpful input from Gabriel Massano, Biomodelos 3D, Argentina 3D Pipeline status? Philip: has worked with VTK, but not yet workflow-ized the ChimeraX stuff Phil plans to try Eric's script with edge cases, "normal" cases have worked well