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

get_agent_x_list()$columns is empty for col_vals_expr() #477

Closed
mayeulk opened this issue May 3, 2023 · 2 comments · Fixed by #505
Closed

get_agent_x_list()$columns is empty for col_vals_expr() #477

mayeulk opened this issue May 3, 2023 · 2 comments · Fixed by #505

Comments

@mayeulk
Copy link
Contributor

mayeulk commented May 3, 2023

I notice that, for col_vals_expr(), the columns slot of the object returned by get_agent_x_list() is NA.
This is linked to https://github.com/rich-iannone/pointblank/issues/475, but as a slightly broader issue (such as "For failed rows, access columns used in validation, and only those").

In my code in issue https://github.com/rich-iannone/pointblank/issues/475, instead of
columns_to_display <- unique c((id_columns, get_agent_x_list(agent, i = c_step)$columns ))
I use the following workaround, with a hack involving all.vars(as.formula()):

c_agent_step <- get_agent_x_list(agent, i = c_rule)
if (c_agent_step$type == "col_vals_expr") {
   columns_to_display <- unique (c(id_columns,
                                   # get the variables from the expr-ession used in col_vals_expr()
                                   all.vars(as.formula( paste0("~", c_agent_step$values)))) )
 } else {
   columns_to_display <- unique (c(id_columns, c_agent_step$columns) )
 }

My use case here is a validation step involving:

  col_vals_expr(
    expr = expr( paste0("some_string", column1) == column2))

I would suggest adding something to fill in the columns slot in such cases (and maybe for specially(), too).

@rich-iannone
Copy link
Member

Thank you for raising this issue and digging into the details. This definitely should be fixed!

@rich-iannone rich-iannone added this to the v0.12.0 milestone Jul 21, 2023
@rich-iannone rich-iannone modified the milestones: v0.12.0, v0.13.0 Feb 20, 2024
@rich-iannone rich-iannone changed the title get_agent_x_list()$columns is empty for col_vals_expr() get_agent_x_list()$columns is empty for col_vals_expr() Feb 20, 2024
@yjunechoe yjunechoe linked a pull request Jun 9, 2024 that will close this issue
3 tasks
@yjunechoe
Copy link
Collaborator

Fixed in dev!

agent <- data.frame(x = 1, y = 2, z = 3) %>% 
  create_agent() %>% 
  col_vals_expr(expr(x + y == z)) %>% 
  interrogate()
  
get_agent_report(agent)

image

get_agent_report(agent, display_table = FALSE)$columns
#> [1] "x, y, z"

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants