【发布时间】:2022-01-18 23:42:48
【问题描述】:
我正在尝试绘制一条线,其中包含等于给定值 (z) 的 x 和 y 的所有乘积。
现在我可以制作所有x 和y 配对的矩阵,然后希望在group_id 中获得足够的条目以便能够绘制线。这并不优雅,并且比我想要设置值 z 来绘制更近似。
有没有比我下面列出的更聪明的方法来做到这一点?我宁愿只提供x 和y 的向量,并能够在x*y = z 处绘制一条线,我提供z 的值。这更像是一个“求解器”类型的问题吗?
library(tidyverse)
# Create a data.frame with each combination of values of A and B
df <- expand.grid(A = seq(0, 1, 0.001), B = seq(0, 100, .1))
# possible products of A and B
df$AB <- with(df, A*B)
# make a for each unique AB
df$group_id <- df %>% group_indices(AB)
# how many entries in the group, need enough to plot
df1 <- df %>%
group_by(group_id) %>%
mutate(nID = n()) %>%
ungroup()
df2 <- df1 %>% filter(AB > 0)
# an example to plot more than one line
#df3 <- df2 %>% filter(nID > 40)
# an example to plot just one line
df3 <- df2 %>%
filter(AB == 8.316)
# plot isocline
df3 %>% #group_by(group_id) %>%
ggplot(., aes(x = A, y = B, color = factor(AB))) + geom_line()
###
【问题讨论】:
-
我不保证感兴趣的
z将使用上面或下面包含在内,在使用扩展网格时无需进行大量预检查。我希望能够选择任何z(前提是它包含在x*y的范围内 -
可能是我,但我不明白这个......在范围内 - 如该范围内的 any 值,或仅 x*y 实际采用的那些值?您在寻找什么?
-
让我按照我现在的理解来表述这个问题:给你一个值 z。并且您想知道新向量 x*y 的值是否包含足够的 z 以绘制一条线?您将多少分定义为“足够”的分界线? (你已经可以通过两点画一条线了)
-
另外,x 和 y 是否总是要排序的? (例如只增加)?它们是否只有独特的价值?虽然我现在不知道如何,但这些信息可能与有效的解决方案相关。