Skip to content

Commit

Permalink
Merge pull request #4393 from AndrejaKovacic/annotate_data
Browse files Browse the repository at this point in the history
[FIX] DataProjectionWidget: attribute Selected
  • Loading branch information
janezd authored Feb 7, 2020
2 parents b8afe13 + 322a2a1 commit a011110
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 5 deletions.
13 changes: 11 additions & 2 deletions Orange/widgets/visualize/tests/test_owprojectionwidget.py
Original file line number Diff line number Diff line change
Expand Up @@ -126,9 +126,9 @@ def get_embedding(self):
return None

x_data[x_data == np.inf] = np.nan
x_data = np.nanmean(x_data[self.valid_data], 1)
x_data_ = np.ones(len(x_data))
y_data = np.ones(len(x_data))
return np.vstack((x_data, y_data)).T
return np.vstack((x_data_, y_data)).T


class TestOWDataProjectionWidget(WidgetTest, ProjectionWidgetTestMixin,
Expand All @@ -145,6 +145,15 @@ def setUpClass(cls):
def setUp(self):
self.widget = self.create_widget(TestableDataProjectionWidget)

def test_annotation_with_nans(self):
data = Table.from_table_rows(self.data, [0, 1, 2])
data.X[1, :] = np.nan
self.send_signal(self.widget.Inputs.data, data)
points = self.widget.graph.scatterplot_item.points()
self.widget.graph.select_by_click(None, [points[1]])
annotated = self.get_output(self.widget.Outputs.annotated_data)
np.testing.assert_equal(annotated.get_column_view('Selected')[0], np.array([0, 0, 1]))

def test_saved_selection(self):
self.send_signal(self.widget.Inputs.data, self.data)
self.widget.graph.select_by_indices(list(range(0, len(self.data), 10)))
Expand Down
6 changes: 3 additions & 3 deletions Orange/widgets/visualize/utils/widget.py
Original file line number Diff line number Diff line change
Expand Up @@ -573,7 +573,7 @@ def send_data(self):
self.output_changed.emit(selected)
self.Outputs.selected_data.send(selected)
self.Outputs.annotated_data.send(
self._get_annotated_data(data, graph.get_selection(), group_sel,
self._get_annotated_data(data, group_sel,
graph.selection))

def _get_projection_data(self):
Expand All @@ -597,11 +597,11 @@ def _get_selected_data(data, selection, group_sel):
if len(selection) else None

@staticmethod
def _get_annotated_data(data, selection, group_sel, graph_sel):
def _get_annotated_data(data, group_sel, graph_sel):
if graph_sel is not None and np.max(graph_sel) > 1:
return create_groups_table(data, group_sel)
else:
return create_annotated_table(data, selection)
return create_annotated_table(data, np.nonzero(group_sel)[0])

# Report
def send_report(self):
Expand Down

0 comments on commit a011110

Please sign in to comment.