wiki:NIAID2024

Version 20 (modified by Elaine Meng, 15 months ago) ( diff )

--

NIAID-UCSF 2024 Contract Statement of Work -- March 1 - September 30, 2024

This SOW is split into two parts. Part 1 is intended to be accomplished in the first 6 months of the contract. If specific items are completed, items from part 2 will be brought forward. Should NIAID extend the contract to 1 year, those items in part 2 not completed during the first 6 months will be worked on.

Part 1

  1. General ChimeraX improvements to support NIAID-specific requirements to assist NIAID personnel to transition away from the unsupported legacy Chimera program, e.g.:
    1. Investigate and improve ChimeraX usability for very wide displays and touch screens i.Specific focus on the BioViz lab wall display
    2. Worms depiction
    3. More GUIs (notably, copy/combine, 2D labels)
    4. Support for showing the thermal ellipsoids
  2. Support the NIH 3D pipeline development, including any changes to ChimeraX to support ongoing development
    1. Continuing support for NIH3D as needed
      1. Updating workflows
      2. Quick submits for AlphaFold database entries
      3. Improve GLTF output to include structure hierarchy
    2. Investigate adding support for ChimeraX sessions in NIH3D
      1. Both uploading and downloading
      2. Need to check on any possible security issues
  3. Extend virtual reality support
    1. Implement use of pass-through video with the Quest 2/3/Pro for multi-person sessions in ChimeraX VR
    2. Improve molecular viewer for standalone headsets such as Quest 2/3.
    3. Add “disable/enable buttons” commands to support better support for handing off the controls to another user to prevent the scene from getting inadvertently changed.
  4. Explore pedagogical benefits of ChimeraX in VR vs. flat screen
    1. Provide support to the University of Indiana (Andi), UCSF, and NIAID to conduct a task analysis comparing VR vs. flat screen for understanding biological macromolecules as needed
  5. Medical Images
    1. Improve presets for medical images
    2. Move medical imaging functionality to toolshed
    3. Explore re-skinning the UI when switching to medical imaging
    4. Support for automated segmentation
      1. Investigate adding Total segmentator
  6. Outreach
    1. Instructional material and tools documentation.
      1. Detailed instructions for all features shall be provided in a user manual.
      2. Written user guides and tutorials shall be available as HTML pages.
      3. Improve documentation for multi-person VR
    2. Attendance at meetings or workshops as required by NIAID
  7. Administration Submit monthly written reports of accomplishments

Part 2

  1. General ChimeraX improvements to support NIAID-specific requirements to assist NIAID personnel to transition away from the unsupported legacy Chimera program, e.g.:
    1. Energy minimization
    2. Support for MD analysis
    3. Improve the altloc explorer
    4. Rewrite ViewDockX
    5. Read VRML/X3D
  2. Support the NIH 3D pipeline development, including any changes to ChimeraX to support ongoing development
    1. Continuing support for NIH3D as needed
      1. Adding support for total segmentator
    2. Investigate adding support for ChimeraX sessions in NIH3D
      1. Both uploading and downloading
      2. Need to check on any possible security issues
  3. Extend virtual reality support
    1. Improve user experience in ChimeraX VR, e.g.
      1. Implement a VR ergonomic toolbar and Model panel user interface.
      2. Add support for a voice interface in VR mode
  4. Explore pedagogical benefits of ChimeraX in VR vs. flat screen
    1. Collaborate with the University of Indiana (Andi), UCSF, and NIAID to conduct a task analysis comparing VR vs. flat screen for understanding biological macromolecules
  5. Medical Images
    1. Implement new rendering and lighting modes for medical imagings
    2. Continue improvements to the DICOM reader by including more data types such as segmentations, and making it more robust by testing against the NCI TCIA repository.
    3. Improve VR experience for medical images
      1. Easier manipulation of windowing and leveling, especially for complex curves
      2. Particularly support for fine-grained changes
      3. Improve segmentation tool by adding commands to support multi-person VR
      4. Investigate adding support for 2D views in VR
    4. General usability improvements for using ChimeraX with medical images driven by TCIA data
    5. Support for automated segmentation
      1. Add support for ML-based tumor segmentation tool
  6. Outreach Instructional material and tools documentation.
    1. Detailed instructions for all features shall be provided in a user manual.
    2. Written user guides and tutorials shall be available as HTML pages.
    3. Create videos demonstrating new capabilities.
    4. Present webinar and workshop tutorials to train users on existing and new capabilities.
    5. Create video tutorials for how to use multi-person VR.
    6. Do outreach using VR in particular (live presentations)
    7. Improve documentation for multi-person VR
    8. Attendance at meetings or workshops as required by NIAID
  7. Administration
    1. Submit monthly written reports of accomplishments

Meeting Minutes

8/1/24

Elaine, Eric, Zach, Piet, Scooter, Tom G; Phil, Darrell, Mike Bopf (first part), Kristen

Re NIH3D pipeline:

Phil: what was the high-confidence cutoff for AlphaFold? Eric: 50, could easily be changed. Phil: could the printable output only show the single biggest piece? Eric: doable. Phil: another separate rule, is that if high confidence is <17 residues total, do not create output (visible or printable). Elaine: for the biggest piece, what about separate domains that are are not contiguous covalently but that are in contact? Scooter: let's start with just the covalent connectivity because it's simpler. Eric: could do some kind of distance-based contact test, NxN where N is the number of contiguous pieces. Phil: can we use the "PAE domains"? TomG: probably too complicated. Could just do NxN contacts where N is the number of residues and then take biggest connected/contacting piece. Elaine: get a contact RIN and then use the largest connected component.

Kristen: Eric's previous fix for the virus chain-names issue looks good.

Phil: question about contacts command, can we list only residue-residue contacts? Elaine: no, is atom-atom; you can use contacts to select atoms and then list selected residues, but it would lose the residue pairing information. Eric: can add an option to the command. Phil: sounds good.

Phil: plans to incorporate AlphaFold3? TomG: their website only allows limited calculations and there is no API for programmatic access. However, can upload a json to set up a run on their server. So one potential thing ChimeraX could do is generate that json file, but it may be difficult especially for ligands, and not worth it with the current restrictions on what calculations can be done. So I'm inclined to wait and hope that a less restrictive version becomes available. Phil: I miss the interactive PAE. TomG: currently (v1.8+) you can download the results and then open the AlphaFold3 PAE data and structure in ChimeraX. Phil: OK, then I'm satisfied!

Scooter: re Schol-AR, we met with Tyler and got feedback. Next step is to put a "beta" bundle in the Toolshed and get some more testing. Elaine: yes please use, you (Kristen and Phil) are more qualified than I to test this feature.

Scooter: we have the raytracing lighting for volumes now, take a look. Elaine: see the Medical Image tab of the toolbar, icon looks like a 3D pac-man.

Greg: I've added dark mode support. Elaine: the User Guide pages also support this.

Darrell: did 2nd-half-of-year funding go through yet? Scooter: still in progress, on my to-do list. Want to get it done without a gap, so it's urgent (possibly later today). Have been busy with hardware upgrades. Darrell: saw on "X" the new chimeraX raycasting and worms representation, look good. Unfortunately, our budget going forward will be flat, need to keep spending no higher next year than this year, may need to reduce hours in the next contract.

Scooter: green light from UCSF for setting up endowment for Tom Ferrin's position. Position will be open soon, we want to inform relevant parties and start getting interest.

Darrell: we would like to visit you, should start planning soon. Would like to bring Neta Filip-Granite (cryoEM expert). Scooter: maybe Jan/Feb. Kristen: hopefully I won't be snowed in. Scooter: maybe we can do some kind of seminar concurrently.

7/18/24

Elaine, Eric, Zach, Piet; Phil, Bhinnata, Andi, Kristen, Meghan, Mike Bopf

Phil: any questions from Eric about the NIH3D issues/requests? Eric: not really, but haven't had time to address the issue with struts being calculated for hidden (low-pLDDT) parts of alphafold models. Have a plan to fix it. Haven't had a chance to work on the other issues: missing outputs #15611, #15612 atom coloring showing on surfaces. Elaine: maybe the latter is atoms shown in sphere style protruding through the molecular surface.

We have some progress to report: Zach and med imaging, Piet and Schol-AR.

Piet: after getting your API key, you can see your projects via the ChimeraX tool, and update them directly. Kristen: I had issues with GLB vertex coloring. Piet: they support GLB currently but there are some issues with coloring.

Zach: I've been implementing raycasting for medical images, which gives a higher-quality appearance more like other medical image viewers. Eric: is there a way to get rid of the moire pattern? Elaine: does rendering mode XYZ slices vs. perpendicular slices (icons) affect that? Zach, no they aren't applicable to raycasting. Zach: there are a few different approaches for getting rid of the moire pattern, just haven't tried them yet. This raycasting is faster than 3D Slicers. Phil, Kristen: should show this to Dave Chen.

Zach: have you had a chance to try the Segmentations tool lately? I made several improvements to UI. Phil: not yet, but you've inspired me to do it soon. Have been busy helping with several specific research projects lately.

6/20/24

Elaine, Eric, Zach, TomG, Scooter; Phil, Kristen, Meghan, Bhinnata, Mike Bopf

Phil: to get coordinates of a point, I found it useful to add a helium atom, and then move it VR. Used "measure center" to report its coordinates. TomG: is there a more convenient approach? Elaine: maybe a setting for balloon help to show coordinates instead of spec, or an entry in the context menu, or a "log coordinates" mouse mode. TomG: similar features are the spheres in Local EM Fitting and Map Eraser. Phil: VR makes placement easier.

Kristen: we filed tickets for more alphafold presets and something about coloring by chain instead of by polymer. Eric: the latter was for something like a virus assembly, if from pdbe_bio you get different chain IDs than if you use "sym" to generate the assembly. Discussion of what coloring they actually want. Unfortunately with color bypolymer, similar sequences don't necessarily give similar colors. Discussion of which presets will be needed for the alphafold models.

Discussion of VR w/ and w/o cable, w/ and w/o passthrough video.

Meghan: how much do you engage with other VR users at UCSF? Is there a special interest group? TomG: no, we are not really connected, especially with very different applications (not molecular structure). Meghan: Adam Gazzaley? TomG: we know of him but haven't interacted re VR.

TomG: have been working on viewing different kinds of data in VR, like light-sheet microscopy. Phil: spatial omics? a "growth area" discussed in the world economic forum. Zach: somebody who attended our workshop at NIAID was doing spatial omics. Discussion of what exactly spatial omics includes. Phil: 3D detection in cells of "whatever"

Next meeting Jul 18 (Jul 4 is holiday)

6/6/24

Scooter, Eric, Elaine, Zach, Greg; Mike Bopf, Kristen, Bhinnata, Darrell, Meghan

Eric demoed some of the NIH3D alphafold presets he's been working on. Has separate sets of alphafold presets showing all residues vs. high-confidence (pLDDT) residues only. Removed some of the printable ones as per request. He also worked on the script to fetch from alphafold. Still working on the case where all residues are high confidence (to only put out one instead of two that are the same). Kristen: some of the "spaghetti" will not be printable, will need to work on our warning text for these alphafold models. Mike asked if this is the same script that produced outputs for the PDB models, Eric said yes.

Scooter: we're 3 months into this 6-month period. Should we go forward and start thinking about paperwork for the next 6 months? Darrell: I should know by next Monday. Scooter: let's think about another visit during that period. Darrell: will keep that in mind as well, and let you know if feasible. Maybe we could instead visit you, and avoid the UC surcharge. Kristen: I would definitely volunteer to come. Scooter: OK, so maybe we could host the next meeting. You could give an NIH 3D presentation.

Zach asks if Kristen had disseminated some DICOM info that he'd given her earlier, she said not yet. Scooter: by the way, we will be working with an intern on the Schol-AR project.

5/23/24

Elaine, Eric, Scooter, Zach; Phil, Kristen, Andi (briefly), Mike Bopf

Scooter is concerned that we haven't heard anything about the supposedly current contract. Meghan is away today and we didn't get any updates from her since the last meeting. Phil will send her email CC-ing Darrell and Scooter. Scooter: it's possible it's already come to UCSF but nobody has done anything with it.

Eric has implemented several of the alphafold presets requested in the previous meeting, including coloring by PAE domain. For printable ribbon, may need to use a longer max length with the "struts" command, say 20. Tried with ldlr_human. The disordered (low confidence) parts are so long, Phil is thinking we just shouldn't bother with the printable ribbon form of the alphafold-all structures (all = including low confidence). We can keep the printable surface one for these structures.

Phil and Eric discuss details of the File... Save dialog and why it looks different than the File... Open dialog.

Zach: I've made a lot of updates in the Segmentations tool and associated features. Works with segmentations read from file, can have multiple ones each associated with their original dataset. New segmentations command and mousemode/hand-controller mode toggle icons.

Zach demos the new stuff to general acclaim and Kristen wants to see how responsive segmentation is compared to slicer. Zach: it is more responsive, thanks to Tom G's graphics work. Phil recently demoed these features and will be doing more demos soon.

Mike: question for Eric, the bug you fixed, is that specific to the Mac? Eric: yes, that setting applies to Mac only. Mike: timeframe for these alphafold updates? Eric: a couple of weeks, need to do more on the presets and then update the script itself to use them.

Phil won't be here next time, will be in Croatia.

5/9/24

Elaine, Eric, Zach, Scooter; Phil, Meghan, Mike Bopf, Bhinnata, Andi Bueckle, Kristen Browne

Discussion of preparations for their poster presentation next week. Wanted to use VR along with the poster, but had an issue trying to set up their own wifi for "vr meeting" and alignment of two sessions. Phil ended up using his phone as a hotspot.

Phil: we had internal discussions on what we need for alphafold presets for NIH3D. Shows a table summarizing the names, display styles, coloring, with and without high confidence (probably pLDDT >= 50 although that may change). Also shares the table as Word and PDF docs, Elaine downloaded and emailed to Eric.

Eric demonstrates the first two alphafold presets that he'd already worked up, ribbons colored by pLDDT for viz and for printing.

Phil: these alphafold presets are only for quick-submit, i.e. user just specifies uniprot ID and we do the fetch. Eric: better to give us (the script) the uniprot ID than the structure, so that the fetch can also get the corresponding PAE, etc. Elaine: use "alphafold fetch" with "pae true" and then another command "alphafold pae" with "colorDomains true". Phil: Mike, we will be getting the additional PAE file (JSON) and it needs to be accessible to ChimeraX.

Scooter: we haven't gotten an official confirmation of the contract. We were given the nod to work "at risk" but that was a while ago. Meghan: I will touch base with Nada and see what information I can get on status. Scooter: or maybe UCSF has just failed to notify us.

Some discussion of NIAID contract and funding opportunities for Andi.

4/25/24

TomG, Eric, Zach, Scooter, Eric; Phil, Meghan, Andi Bueckle, Mike Bopf, Bhinnata

Phil: our "take your child to work day" activity was starting a ChimeraX VR meeting, and there was already a meeting name that suggested others had the same idea! Went well, kids enjoyed it. Meghan: we're tired from doing demos today. Andi: I have a VR demo (Apple Vision Pro) if we have time.

Phil: latest on working with passthrough? TomG: haven't changed it in a few weeks. Scooter tried it recently and found that a developer account is needed to change a necessary setting for passthrough. TomG: related to security.

Scooter: I made a long list of requests to TomG and Zach, can share with NIAID folks. I would bring up a menu to the right of where I was viewing the scene. Most importantly, I wanted multiple panels to stick together so they didn't have to be moved individually. Also I kept bumping my hand on the physical screen trying to select with the cone. It would be nice to have an interface for selecting from a distance, like a laser pointer. Resizing panels was confusing.

Phil: during one session on one machine, I would always get the checkbox below the one I was clicking on. Not very reproducible. It was the "show/hide" checkbox in the Model Panel. Meghan: maybe low battery on controller? TomG: there is a conversion between VR space location and desktop screen location, and maybe it was off by a certain vertical amount.

TomG: we recently added a button lockout so that you can hand over controls without messing everything up. Need a new daily build. Phil: now we can easily push the new version to multiple machines.

3D Workflow. Mike: how many visualization output file are we going to get for alphafold structures? Phil: that ball's in my court, to decide on which representations and their filenames. Will let Eric know to work on new presets. Phil: and then the script needs to take the outputs from the presets and write out the additional files.

Over to Andi for demo: sharing screen from Vision Pro, shows augmented reality of organs in shiny clear bubbles floating around his office. There are interaction panels, toggle switch to explode the organ with labels on all of its bits, and toggle back to put it back together. left/right on the other interaction panel chooses a different organ to focus on.

Discussion of VR user interface improvements, like showing the command line in the headset (hard to see via passthrough). Meghan: cisco upgrade will be very expensive. Scooter: wifi 7 has been released. Meghan: but will the headsets support it, and will we be allowed to use it here? Scooter: I just mean that you may want to investigate other options before paying cisco big bucks for an upgrade. TomG: in my experience, passthrough requires cable connection for good performance. I don't think it is a hardware issue (lack of wifi bandwidth), but a Meta software problem with using airlink. The developer option is to allow passthrough with questlink (the cable), doesn't mention airlink. TomG: you do sharing with larger numbers of headsets than we do; wifi 7 may help in that case. Meghan: a cable is a nuisance with rolling chairs and might get damaged.

All the rest of the notes from today is text that Meghan sent thru the Zoom chat:

USB:

  • 192.6Mbps peak on Google Earth at defaults (200Mbps)
  • 188.2Mbps peak on ChimeraX at defaults (200Mbps)
  • 413.3Mbps peak on ChimeraX with max set to 500Mbps
  • 846.2Mbps peak on Medical Holodeck with max set to 960Mbps

Testing wired connection and pushing bitrates to the limit

Used Wireshark with USB-PCAP (requires special install file that gets moved into Wireshark program files) see https://desowin.org/usbpcap/tour.html

Next step: same testing wired/wireless focused on normal day-to-day use

Have a baseline to measure against

Torrey will investigate use of Cisco Meraki cloud-based WLC

4/11/24

TomG, Eric, Zach, Greg, Elaine, Scooter; Phil, Kristen, Meghan, Mike Bopf, Bhinnata

Zach: did you see the email I sent about a radiology conference later this year, are you going? Meghan: someone will go but we may not be hosting a booth. May be useful for you to attend just to learn, keep it in mind.

Scooter: we still don't have a contract finalized even though we were told it was fine to start the work. I'll email and ask for status.

Meghan: what's going on with workflows? Kristen: we need to figure out what we want re AlphaFold, still haven't gotten a list of specific requests. Quick submit is when the user enters an accession code (will be obtained using ChimeraX fetch) rather than uploading their own structure.

Scooter: we should talk about AlphaFold and GLTF. We would like to add a "publish to Schol-AR" feature in ChimeraX using REST interface. Developer Tyler Ard is a medical imaging guy and has given us some feedback about the ChimeraX tools. We would like to visit him at USC, give demos, discuss features, and try to engage his colleagues as well.

TomG: Meghan's powerpoint gltf example used an older ChimeraX. Newer ChimeraX (Oct 2023) gltf export has better treatment of color, so looks better in powerpoint. Discussion of whether the vrmls will then need correction since those converted from the older gltfs are fine. Meghan: let's test with newer ChimeraX. Phil: it looks good enough with newer ChimeraX that we don't need any special preset for gltf export for powerpoint.

Kristen: another possibility is color STL. Greg: recommend staying away from STL. Kristen, Meghan: or 3MF or USC (universal scene description). Kristen: there are various flavors, USC-Z etc.

TomG: should NIH3D put in lighting, or leave that to the end user's application? Kristen: probably better to leave it out so that you don't get stuck with both lighting from the exported file and the application, and no reasonable way to remove lights.

Discussion of lighting direction vs. camera direction. If there is a headlight you avoid dark sides of models, but that approach can overly wash out white or other light-colored models.

Phil: for AlphaFold, we probably want at least 2 colorings, by PAE domain and by pLDDT. Tom: pLDDT is well-known but PAE domain coloring is more specific to ChimeraX and may require more explanation or at least thought as to whether you really want to make it available. Parts of more than one chain can be assigned to the same PAE domain. Phil: for quick submit, it will be only one protein. My instinct is that we still want to include it for alphafold database entries, along with a good explanation. Phil: other issue is whether to hide low-pLDDT spaghetti. What is a reasonable cutoff? Tom: pLDDT 50. Tom: keep in mind that PAE values are in a separate file than the structure. ChimeraX alphafold fetch gets both files.

Current thinking is we need more presets: both with and without spaghetti, 2 alphafold coloring schemes, and all the existing color schemes of both ribbons and surfaces. Elaine: do you really need a combinatorially expanded set of presets, when some of these differences would just be a single command? Eric: how about a modifier preset? Then still simple but less duplicative. To get a specific view, you'd use preset A followed by modifier preset B.

Phil: do you need any more specifics? Eric: do you need missing-structure pseudobonds where the spaghetti is hidden or excised? What about surfaces? Will think about the implementation details. Tom: I have various doubts (a) that getting rid of the low pLDDT, can remove parts of helices, even buried cores, etc. and give weird results. (b) also, pLDDT coloring is useful for ribbons, probably not surfaces, have not seen it used for surfaces. Others: would simplify the preset situation to omit some of these options.

Eric: I'll work up some possibilities and put it in a bundle for further feedback.

3/28/24

Scooter, Eric, Zach, Elaine; Andi Bueckle, Phil, Kristen, Darrell, Meghan, Bhinnata

Some discussion of Andi's scary (almost-real-looking) avatar since he is Zooming using the Vision Pro. The varying amounts of transparency and the unrealistic mouth movements are the giveaway.

Phil: Kristen had an interesting idea to output files for Mesoscape. Scooter: I talked to some people at VIZBI... planning a collaboration for publishing data to Schol-AR; the developer (Tyler) happens to also be a radiologist and may be helpful in evaluating our medical image stuff. Discussed maybe having a ChimeraX REST interface to publish to Schol-AR. Kristen and Phil: we may be interested in adding a connection to Schol-AR from NIH3D.

Scooter: Eric has a present for you, especially Darrell. (Zoom technical difficulties, disconnected, reconnected.) Eric demonstrates worms, everybody is enthusiastic. Darrell: would be fun to try 3D printing. Might need struts. Kristen: is this in other programs? Elaine: yes, Pymol, Chimera, etc. Phil: re NIH3D I also wanted to discuss the quick-submit workflows for alphafold... we need to decide which are the standard outputs: pLDDT and PAE domain coloring, ribbons and surfaces, maybe hide low-pLDDT parts? Transparency? Elaine: pLDDT coloring shows low confidence as red, or it could be gray in combination with PAE domain coloring. In ChimeraX you can specify all residues with bfactor (pLDDT is in the bfactor field) greater than some value.

Scooter: this all ties into what metadata we want to have in the GLTF output. Groups of residues predefined, e.g. "high pLDDT" or by chain ID or domain, etc. Phil: Darrell, maybe you can help us decide on the standard set of outputs. Darrell: should be useful and include ones that are harder for some people to generate on their own, which used to be the case for ESP coloring. We'll have to put our heads together and decide on an edited set. Kristen: maybe we could offer checkbox choices of which outputs the user wants.

Phil: ChimeraX gltf outputs look washed out when embedded into Microsoft documents (Powerpoint and Word). Due to their oversaturated lighting model, which is unlikely to be addressed by Microsoft, so we have to try to work around it. I can generate ChimeraX gltf files that look better after embedding in such documents by using different settings in ChimeraX (I have my own preset for this, which uses "color modify" to lighten the colors) but that may require yet another set of output options. Kristen: I hacked Powerpoint to get around it but it's not trivial. See this in the forum for the Microsoft lighting: https://answers.microsoft.com/en-us/msoffice/forum/all/3d-model-lighting-inside-powerpoint/d0c0c316-8019-4c25-b0f6-86500e512f91 ... The suggested solution is what I've done in the past to fix the lighting.

Meghan posted another link in the chat https://answers.microsoft.com/en-us/msoffice/forum/all/powerpoint-uses-gltf-but-doesnt-support/002d1f4e-061d-4ab6-a692-ed217945724a

Meghan: are there ways to fix the gltf after it's output? Blender, but having to download Blender is another barrier. Kristen: maybe NIH3D could have a "optimize gltf for Microsoft documents" service that runs our own Blender. Phil, Darrell: it may be a useful utility. Darrell: does gltf outputs from ChimeraX include lights? Kristen: I just checked, and no, these gltf files do not include lights or camera.

Darrell: we might also look at providing U3D which can be embedded in PDFs. Greg: it hasn't been used much. Darrell: probably because it is rather difficult to generate. Meghan posted this link in the chat https://helpx.adobe.com/acrobat/using/adding-3d-models-pdfs-acrobat.html

Note: See TracWiki for help on using the wiki.