Skip to content
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

Specify edge text location #84

Open
dan-knight opened this issue Aug 17, 2023 · 4 comments
Open

Specify edge text location #84

dan-knight opened this issue Aug 17, 2023 · 4 comments
Assignees
Labels
enhancement New feature or request future Planned future features

Comments

@dan-knight
Copy link
Collaborator

Suggested by @WuSelina, there is a need to specify precise locations of text along an edge. Broadly, this has two requirements:

  • Specify if text should be placed relative to node or the edge
  • Control over that relative location (X, Y, or both)

Screenshot 2023-08-17 at 1 22 13 PM

@dan-knight dan-knight added the enhancement New feature or request label Aug 17, 2023
@dan-knight
Copy link
Collaborator Author

Edges and nodes can both be referenced by the same ID. Just like with the length columns in the tree input data.frame, the specified edge would correspond to the edge leading from the parent to the specified node.

This should probably be handled with extra, optional columns in the text input data.frame. Tentatively:

node.id location x y

The x and y values are a bit tricky.

  • I'm thinking that y should be a percentage of the total branch length. This is due to the fact that a branch could have multiple edges, and therefore multiple scales. An objective value would not be practical. (Which scale applies to the value?) - For x, perhaps this should work the same as the tree padding parameters, corresponding to a percentage of the default padding.

These seem intuitive for each argument separately, but I'm hesitant to design this in a way that x and y aren't conceptualized the same way. Maybe this can be solved with better, more informative column names.

@dan-knight dan-knight self-assigned this Aug 17, 2023
@WuSelina
Copy link

  • I'm thinking that y should be a percentage of the total branch length. This is due to the fact that a branch could have multiple edges, and therefore multiple scales. An objective value would not be practical. (Which scale applies to the value?)

I think y being a percentage of the total branch length makes sense. I guess a better column name could be similar to label.y just in case y is ambiguous.

I'm not sure what you mean by an "objective value". I believe you are correct and thoughtful that it would not be practical if the scales are not clear, but I am having a hard time following along.

@WuSelina
Copy link

For x, perhaps this should work the same as the tree padding parameters, corresponding to a percentage of the default padding.

I'm not sure if others such as @whelena will use these labels in a different way when there are multiple samples, but I think it makes sense to set x (or label.x as I'll call it for now) as corresponding to padding, but I think I understand your concern.

These seem intuitive for each argument separately, but I'm hesitant to design this in a way that x and y aren't conceptualized the same way. Maybe this can be solved with better, more informative column names.

For my single-sample cases so far, I think of the label.y as "the point in time at which an event occurs," so I believe setting it as percentage of branch length would work well. For label.x, though, I think of it as asking "Which clone does this event stem from/occur to?" so I am asking which branch/node I want the event label to be closest to. We could probably talk more about this in person!

@whelena
Copy link
Collaborator

whelena commented Aug 21, 2023

I'm not sure if others such as @whelena will use these labels in a different way when there are multiple samples, but I think it makes sense to set x (or label.x as I'll call it for now) as corresponding to padding, but I think I understand your concern.

For labelling I don't envision doing it this granularly. For some of my samples, placing the labels are simply impossible with the current setup due to lack of space.

I'm thinking that y should be a percentage of the total branch length. This is due to the fact that a branch could have multiple edges, and therefore multiple scales. An objective value would not be practical. (Which scale applies to the value?) - For x, perhaps this should work the same as the tree padding parameters, corresponding to a percentage of the default padding

I think a percentage would be equally confusing since the actual branch lengths are determined within CEV. I think we should simplify the problem for now and default to the scale used in the first edge, length1, for y. In @WuSelina case, both length1 and y should be the number of SNV between events.

As for the x value, is there a reason why the default wouldn't work? Is it mostly to control the distance between the edges and the labels?

@dan-knight dan-knight added the future Planned future features label Oct 28, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request future Planned future features
Projects
None yet
Development

No branches or pull requests

3 participants