From 3fffdfec62b579e7dd372be7e8a86f534155e2d9 Mon Sep 17 00:00:00 2001 From: Mily Date: Thu, 30 May 2024 15:07:34 +1000 Subject: [PATCH] Update polarity.py to return polarity_wordcloud object This is for use of the Juxtorpus Visualisation --- juxtorpus/features/polarity.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/juxtorpus/features/polarity.py b/juxtorpus/features/polarity.py index 12e37ac..b899206 100644 --- a/juxtorpus/features/polarity.py +++ b/juxtorpus/features/polarity.py @@ -116,7 +116,7 @@ def _selected_dtms(self, tokeniser_func: Optional, **kwargs) -> Generator[DTM, N return (corpus.dtm for corpus in self._jux().corpora) def wordcloud(self, dtm_names: tuple[str, str] | str, metric: str, top: int = 50, colours=('blue', 'red'), - stopwords: list[str] = None, **kwargs): + stopwords: list[str] = None, return_wc: bool = False, **kwargs): """ Generate a wordcloud using one of the 3 modes tf, tfidf, log_likelihood. """ polarity_wordcloud_func = self.metrics.get(metric, None) if polarity_wordcloud_func is None: @@ -126,8 +126,10 @@ def wordcloud(self, dtm_names: tuple[str, str] | str, metric: str, top: int = 50 height, width = 24, 24 pwc, add_legend = polarity_wordcloud_func(dtm_names, top, colours, stopwords, **kwargs) pwc._build(resolution_scale=int(height * width * 0.005)) - fig, ax = plt.subplots(figsize=(height / 2, width / 2)) + if return_wc: + return pwc + fig, ax = plt.subplots(figsize=(height / 2, width / 2)) names = self._jux().corpus_0.name, self._jux().corpus_1.name legend_elements = [Patch(facecolor=colours[0], label=names[0]), Patch(facecolor=colours[1], label=names[1])] legend_elements.extend(add_legend)