-
Notifications
You must be signed in to change notification settings - Fork 31
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
color by feature metadata #130
Milestone
Comments
fedarko
added a commit
to fedarko/empress
that referenced
this issue
Apr 8, 2020
ElDeveloper
added a commit
that referenced
this issue
Apr 20, 2020
… ok (#154) * BUG/TST: Add back in data matching/checking code Closes #139, for real this time. Eventually we'll need to check that feature metadata matches up, but that is its own problem for later down the road. * STY: fix flake8 complaint * DOC: add all needed moving pix files & "make docs" Not sure why these files weren't here before, but this will make rerunning the tutorial easy. Also "make docs" is just a shorthand that saves extra typing when re-visualizing the moving pictures tree. We could integrate this into the travis build in the future if desired (of course this would be predicated on us getting QIIME 2 set up in the travis build, which would add on a few minutes to each build due to Q2 installation taking some time). * DOC: typo fix [ci skip] * BUG: Transpose feature tbl before matching it So apparently QIIME 2's transformers from biom table -> pd DataFrame produce DFs that are transposed from what biom.Table does -- QIIME 2 uses samples as the indices (rows) and features as the columns, while biom.Table does it the other way around. As you can imagine, this is pretty confusing! This commit should fix this problem from our end, but in the future we should really add logic to prevent having to do table-DF-transposition, since IIRC that can be super slow with massive DFs. (...We really oughta unit-test _plot.) * STY: rm extra blank line * TST: rename a prev matching test and add skeletons * TST: Add "no features shared" test for matching part of #139 fixes * TST: test a warning msg printed during matching * TST: Add sample dropping warning test think this pr should be good for now * DOC: add note to match_inputs() re #130 (TODO) * TST: Install and use QIIME 2 env in travis build * TST: Add actual Q2 integration test! Addresses @ElDeveloper's comment on #154. I'm keeping 'make docs' around since it could still be nifty (if you just wanna regenerate the empress-tree.qzv file without rerunning the tests, I guess). * TST: don't run 'make docs' on travis build Since the Q2 Artifact API test I just added does the same thing. * TST: Add rough Q2 visualization check #154 Addresses comment from @ElDeveloper * STY: Remove blank lines in match_inputs() Co-Authored-By: Yoshiki Vázquez Baeza <[email protected]> * STY: more blank line removals in docstring Co-Authored-By: Yoshiki Vázquez Baeza <[email protected]> * STY: rm blank lines in print_if_dropped docstring Co-Authored-By: Yoshiki Vázquez Baeza <[email protected]> * MNT: warn instead of printing re: sample dropping Tests haven't been updated yet -- will do so when --ignore-missing-samples option added in. (So this will currently break the tests.) This represents part of the work on addressing @ElDeveloper's comments on #154. * ENH: add UI skeleton for no-data sample/feat flags Per suggestion from @ElDeveloper in #154 * STY: make _plot inputs prettier * DOC: add ref to emperor --ignore-missing-samples * DOC: Remove 'standalone' instructions in README Just for now. When we resolve #140, we should add these instructions back in (likely we'll also have to adjust these when we get to the 'initial release' of Empress on PyPI / conda-forge / etc.) * DOC: switch feature/sample flag order, imprv docs * ENH: Add @ElDeveloper's suggested filtering flags This entailed substantial restructuring of match_inputs(). I also completely deleted warn_if_dropped(), because it was honestly easier to replace it with custom error messages for each of its 3 usages. (Also, that thing was like 50 lines of docstring / infrastructure for 8 lines of code. It was gnarly. :P) This isn't done yet! I still need to test this new behavior thoroughly, and to update the tests for the old functionality accordingly. * MNT: Avoid redundant table DF transpositions #155 * BUG: don't display useless warning in most cases * TST: reduce tests to just one working one will add more back (with relevant changes to work with new behavior) soon * DOC: add TODO note re empty checking * TST: add back "simple" matching error tests * TST: add + beef up tests of matching warnings, etc * TST: add --p-ignore-missing-samples tests * TST: add another cornercase test * TST: test final "warning" in matching func for now also fixed a bug in prev test i just added in, and removed extraneous comment * TST: Add other check for extra s.m. sample warning I think I'm satisfied with the new matching behavior tests, at least for now * DOC: update example QZV :) * MNT: don't warn on dropped samples from s.metadata See new comment for justification. Addresses comment from @ElDeveloper. Co-authored-by: Yoshiki Vázquez Baeza <[email protected]>
fedarko
added a commit
to fedarko/empress
that referenced
this issue
May 25, 2020
Progress on biocore#130. Next up is testing this (... and un-breaking the tests in general, my bad).
fedarko
added a commit
to fedarko/empress
that referenced
this issue
May 25, 2020
All that was really needed was just unpacking a third return value (feature metadata). I added a few tests that this value was None, but we'll test this in more depth shortly.
fedarko
added a commit
to fedarko/empress
that referenced
this issue
May 25, 2020
fedarko
added a commit
to fedarko/empress
that referenced
this issue
May 25, 2020
fedarko
added a commit
to fedarko/empress
that referenced
this issue
May 25, 2020
fedarko
added a commit
to fedarko/empress
that referenced
this issue
May 26, 2020
fedarko
added a commit
to fedarko/empress
that referenced
this issue
May 27, 2020
Helps a lot for biocore#130
ElDeveloper
added a commit
that referenced
this issue
Jun 19, 2020
* ENH: Add initial stab at circular layout Needs further inspection and testing, and of course the JS needs to be modified to draw "vertical lines" as for the rect. layout (but now with curves, etc.) but this seems like a decent start * DOC: add details re circ layout alg and TODOs * ENH: draw circ layout arcs (not beziers yet), etc Lotta ugly hacky code in this commit. Will get things working then from there backtrack to make things pretty and well tested before the PR. This is looking actually pretty nice. Will probably need to fix the "shape" of the circular layout though LOL * MNT: don't generate arc info for root (circlayout) * BUG: still store pos data for root * MNT: on 2nd thought draw "arc" for c.layout root consistency will be useful, and we can adjust later as needed also improved js docs for # lines needed * DOC: document c0/c1 stuff for circ layout better * BUG: Actually draw tips for circ layout turns out that the reason things in this layout looked 'incomplete', off, etc. was that xc0 and yc0 info was only being stored for internal nodes, giving the dubious impression that penultimate nodes were tips. With this, remaining circular layout TODOs are 1) drawing fancy curved arcs for internal nodes 2) adjust the UI to get the thick line stuff to work properly with the circular layout 3) clean up code, esp messy portions (like maybe store xc0/xc1 info in the layoutToCoordSuffix object somehow, by making it interpret an array of two suffixes as start and endpoints) 3) add tests * MNT: Don't store root arc info; smooth arcs; docs Improved documentation on *why* attempting to draw an arc for the root is kinda useless. Hopefully shouldn't have to update that again ._. I split up the line segment for the circular layout into two, one connecting an internal node's endpoint with its arc start and another connecting the node endpoint with its arc endpoint. This makes the layout look A LOT better; it's still essentially an approximation, though. What we need to do is hijack the WebGL code to draw bezier curves (starting and ending at the arc start/endpoints, and passing through the internal node endpoint) instead. Uh, hopefully that isn't too difficult? LOL I guess we'll see. * DOC: improve circ layout coordinate docs Addressing some ambiguities, and fixing an error w prev commit docs * DOC: add note re: internal node arcs + cornercases * BUG/MNT: Proper thick lines in c.layout; code chgs I moved the general "corner-computing" code from within Empress.thickenSameSampleLines() to its own function within VectorOps. This allows a lot more code reuse, but I think we could make the code even more compact by allowing _addTriangleCoords() to accept {tL: ..., ...} objects directly. * MNT: Make _addTriangleCoords accept corners obj ... Instead of accepting individual corner coordinates. This makes life a bit easier, or at least makes the code a bit cleaner (since now we can funnel the output from VectorOps.computeBoxCorners() straight into Empress._addTriangleCoords()). Of course it's worth noting that making the circular layout draw the arcs with curved lines/beziers (and not just as the disjointed line segments) will probably mean we'll have to abandon this particular function for that particular use case. for now, tho, this looks pretty nice * for reference, update qzv * ENH: Match up feature metadata w/ tree nodes Progress on #130. Next up is testing this (... and un-breaking the tests in general, my bad). * TST: Un-break rect layout tests The tests were broken due to me renaming lowestchildyr, etc. to lowest_child_yr. Fixed. * TST: Un-break matching tests due to #130 work All that was really needed was just unpacking a third return value (feature metadata). I added a few tests that this value was None, but we'll test this in more depth shortly. * STY: clean JS line-thickening code Some repeated declarations ("var corners", "var x1", etc.) were making jshint angry, so I addressed them (for corners, by declaring it up front at the start of the function in question; for the x1/y1/ etc. stuff, by not even assigning them explicitly to variables and just by passing them directly to the function I was calling). * STY: Minor flake8 fixes The build should be working now 💯 * TST: Add fm for testing; don't name internal nodes the "don't bother naming internal nodes" change comes from the fact that now that step is done after matching, anyway, so there's no point in keeping this line in the tests * TST: add basic feature metadata matching test #130 * TST: test feature metadata mismatch error :) #130 * TST: test partial feature dropping in fm matching done with this part, gonna move on to taxonomy handling / etc. next * ENH: Add taxonomy-splitting func signature/docs (still need to accidentally implement it lol 💯) * ENH: Draft taxonomy splitting code skeleton the actual meat of this function isn't done yet, but this should at least handle most (but not all, Error condition number 3 is still unimplemented) of the funky corner cases. * STY: flake8 line spacing * ENH: validate ; ct. and do tax splitting #130 * TST: add basic tax splitting infrastructure tests * MNT: tax splitting->new module; allow uneven ; cts Lots of (untested) changes here. Need to test this stuff... * BUG/TST: Fix "Level" col bug, and add tests for it tldr code was lowercasing all col names and checking to see if any started with "Level", which obvs wouldn't be the case since "Level" would get turned to "level". Fixed problem. * MNT: Put Level cols at start of fm * TST: add partial tax splitting "good" case test at least we know it works know lol * TST: Finish "good" tax-splitting test * TST: test funky tax splitting corner case * TST/MNT: warn on no-; case and add test * ENH: add UI skeleton for f. metadata coloring #130 * ENH/DOC: add fancy notes for coloring tabs :D:D:D * ENH: Chuck feat. md over to JS; populate selectors So, now we have access to feature metadata in the Empress JS object, and the selectors in the feature metadata coloring tab have the f.m. fields populated there. * MNT: Make feat. md. data transfer simpler has advantage of preserving column order ;) * DOC: Add inline docs to layout + anim. panels * DOC: update QZV for reference * ENH: Add initial, hacky f.m. coloring prototype! :D:D:D:D * STY: fix prettier issues * BUG: Make code work, and fix UI, if no f.m. passed UI could use some extra work -- maybe set the initial "hidden" on the fm button directly from jinja2, if possible. but this at least works? * BUG: remove ref to missing UI ele in JS this makes unchecking the feature metadata checkbox work properly -- what was happening was the fHideChk thing was getting referenced, which (silently from the user perspective ...) crashed the "close" function, which prevented the tree from being reset and redrawn. js, amirite * STY: fix flake8 spacing pbm * DOC: Describe use of f.m. in CLI docs * ENH: color internal nodes with uniform child f.md * Update qzv * circular layout * Add QZV including BOTH circ layout AND fm coloring :D :D :D :D :D :D * Show feature metadata for tips in select-node menu Helps a lot for #130 * ENH: improve node hover menu UI * Consistent table styling, better frozen header col satisfied for now * Show a table of feature metadata in the node hover menu; improve the existing styling in the menu (#166) * Show feature metadata for tips in select-node menu Helps a lot for #130 * ENH: improve node hover menu UI * Consistent table styling, better frozen header col satisfied for now * STY: prettier fixes * TST: add docstrings for f.m. matching tests * ENH: fix minor grammar issue in node menu * MNT: Clean code for name_internal_nodes() - unlabled -> unlabeled - use str.format() rather than % for formatting node names (seems to be preferred in modern python code) * BUG: fix one last "unlabled" * TST / BUG: Explicitly disallow nonunique tip names I thought we were already checking for this, but turns out we weren't. * ENH/TST: warn when internal nodes share name Per advice from @ElDeveloper worth noting that the current check is bugged: it doesn't check the root node's name. We should fix that. * BUG/TST: Also consider root node name for warnings * TST/BUG: raise error if tip name in int node names Another annoying corner case it's good to detect and handle. Note that we purposefully ignore "None"-named nodes, since those will be replaced with unique IDs later. * MNT: Rename name_internal_nodes() more accurately Because: 1) it wasn't just renaming internal nodes 2) it also assigns missing branch lengths (although this is NOT tested as far as I can tell) * MNT: fill_missing_node_data -> _node_names SO: turns out that the validation code i added a while back re: nodes with missing branch lengths was unnecessary, since name_internal_nodes() already handled that. Well, at this point the simplest thing to do is just remove that functionality from name_internal_nodes() (now named fill_missing_node_names()), since the validation should already preclude missing branch lengths. (If this is annoying, we can set things so that missing branch lengths are replaced with 0 or 1 or something, but I personally don't think that's a great idea.) * STY: add extra blank line for flake8 * BUG: Handle EmpressNode* corner case should be a temporary solution, but I don't anticipate this being a problem for the majority of use cases. * MNT: explicitly ignore None-named tips in matching I don't believe this was doing anything before, but it could have ostensibly been a problem if there was a feature named None (like, the object None) in the table. (And I don't *think* that will ever happen since we're getting these tables from QIIME 2, which uses biom-format, which treats IDs as strings.) * TST: test corner-case feature metadata matching Some funky things re: 1) root of the tree being allowed to have fm and 2) duplicate internal nodes being allowed to have fm * STY: minor fixes to _plot.py - Use a safer variable name than "file", which is a reserved keyword in some versions of python: https://stackoverflow.com/a/24942363/10730311 (I doubt that this would cause problems since I'm pretty sure Empress only supports python 3, but we might as well be safe.) - Use more reasonable-looking indentation for a jinja2 call * fix typo in biom table js * MNT: remove logging stmt I left in accidentally * ENH: Add UI skeleton for two fm coloring options * fix a grammar issue * MNT: Refactor to store fmd as tip/int node md This will make implementing the different JS "coloring methods" a lot easier. Need to update the tests. * TST: Verify that taxonomy whtspcs handled right I think this addresses #129, at least to the extent that we can handle this without messing with QIIME 2. But I'm not closing it until I can verify (if poss.) that the original error is rectified. * TST: test specific SILVA annotation from #129 * fix typos * TST: start fixing old match tests re: t/i fm split * TST: fix more matching tests; imprv matching docs ... since i forgot about the 'moving tax splitting to match_inputs()' change i made earlier today :P * TST: Finish un-breaking old matching tests Still need to, like, add on new tests that explicitly verify that the splitting stuff works, but these changes essentially do that already * DOC: bump min q2 version to 2019.10 see #129 * TST: add clarifying comment re: #129 test * Finish up merging stuff * add back index.html gen stuff i accidentally deleted during merging but we need this ._. * temporarily rm circ layout (it'll be added back when #180 is merged in) * MNT: Abstract pretty sample table generation ... And use the new function for both leaf *and* internal node selection menus. The new function is a static method, so it should be pretty simple to test (knock on wood). Need to actually test this though!!!! This addresses one of the TODOs on #169. * Remove #tree-container CSS block: close #168 This was getting on my nerves, so I just knocked it out now ._. * DOC/MNT: clear tableEle HTML in s.tbl.gen; docs * TST: Test tip/int node md cols, and details Crucially, this includes the "just internal nodes" case :) * TST: Un-break core tests ... By adding the tip/int metadata stuff to DICT_A. We should definitely add tests that make sure that this info is properly transmitted at some point, tho. * TST: test feature metadata and _to_dict() * BUG: be consistent w/ "EmpressNode" btwn python/js We might just wanna not special-case this altogether tbh * STY: fix js/py style issues - unbreak travis :D * BUG: enable selecting the root node #169 * update qzv * Fix typo * ENH: Show int node fmd, simplify fm table code Also fixed a few typos ("uniqe" -> "unique") and bolded the warning about duplicate node IDs. The code for this is p messy (although it does demonstrably work :D) so I gotta fix this... * MNT: Abstract fmd table gen code to sep func ... so we can use it for both internal nodes and tips. TODO, need to add docs + tests for this ... * DOC: Add docs for makeFeatureMetadataTable() * DOC: make plugin setup fm usage desc more faithful * BUG: Remove cursor: pointer on text/number inputs I think this should make it clearer to the user that you can type into these fields... * ENH: Add int. node coloring method; refactoring F. metadata coloring method is now configurable!!! only took me forever ._. * STY: js style fixes * STY: fix variable re-defining pbm * ENH: On changing fm method, change checkbox desc. The wording could probably use some work, but this does the job. * MNT: tidy up side panel code a bit * BUG: Use linethickening for fm; readd desc updates (The reason I held off on the line-thickening stuff is it's all "thicken same sample lines" and stuff, but at this point we're hijacking all of the sample coloring stuff to color by whatever.) * DOC: update fm TODO comment * MNT: Abstract out a LOT of side-panel-handler code ... into shared functions between the feature / sample coloring code. This should have the side effect of making testing easier. I think? In any case, the documentation seems a bit nicer :) * DOC: update _updateColoring re funky method param at least justifies why it's kinda wack * BUG: prevent sample/ftr opts simultaneously shown getting that commit title down to 50 characters was a struggle, but you get the idea. This involved adding back some functions to side panel handler, but these are a lot more clear and concise so I don't mind them as much. or maybe i'm just biased because i wrote them lol * ENH: clean node selection menu; improve descs #169 Another thing ticked off for #169. Something i thought of just now - would be good to say "Name" instead of "ID" for nodes maybe? skbio treenode treats these as Names not IDs, and according to wikipedia (https://en.wikipedia.org/wiki/Newick_format) newick seems to mostly consider these as "names" also. * STY: fix JS style; redo qzv * MNT: Rename _validate_data: makes behavior clearer Addresses a comment from @kwcantrell * DOC: Clean up _to_dict fm usage Things should be a lot clearer now. Addresses points brought up in @kwcantrell's review * Clarify more comments in _to_dict * BUG: Reset fm coloring "update" btn in selcallback Addresses a comment from @ElDeveloper * STY: Rename Empress ctx var name for closure This is somewhat more consistent. Addresses an @ElDeveloper comment. * STY: minor prettier thing * MNT: Rename hover-* stuff to menu-* Addresses comment from @kwcantrell * Update empress/support_files/js/vector-ops.js Co-authored-by: Yoshiki Vázquez Baeza <[email protected]> * Only use {{ feature_metadata_columns }} once addresses @ElDeveloper comment * Add + update copyright headers to all python files * Update empress/taxonomy_utils.py Co-authored-by: Yoshiki Vázquez Baeza <[email protected]> * Simplify max ; ct computation Co-authored-by: Yoshiki Vázquez Baeza <[email protected]> * Avoid unnecessary set() conversions Addresses suggestion from @ElDeveloper * Use @ElDeveloper suggestion for tax splitting code * Update qzv * Revert "Use @ElDeveloper suggestion for tax splitting code" This reverts commit ce8e26c. * ... update qzv from old logic * unbreak circ layout js test * Un-break python test Thanks @esayyari for debugging this! Co-authored-by: kcantrel <[email protected]> Co-authored-by: Yoshiki Vázquez Baeza <[email protected]>
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Currently is not possible to highlight via the GUI via feature metadata and this will be great.
The text was updated successfully, but these errors were encountered: