eupolicy.social is one of the many independent Mastodon servers you can use to participate in the fediverse.
This Mastodon server is a friendly and respectful discussion space for people working in areas related to EU policy. When you request to create an account, please tell us something about you.

Server stats:

209
active users

#select

0 posts0 participants0 posts today
Cybersecurity & cyberwarfare<p><b>Inheritance in Python: la chiave per scrivere codice pulito e collaborativo nel Machine Learning</b></p><p>Molte persone che si avvicinano al <a href="https://www.redhotcyber.com/post/scopriamo-le-differenze-tra-un-algoritmo-di-machine-learning-e-deep-learning/" rel="nofollow noopener" target="_blank">machine learning</a> non hanno un forte background in ingegneria del software, e quando devono lavorare su un prodotto reale, il loro codice può risultare disordinato e difficile da gestire. Per questo motivo, raccomando sempre vivamente di imparare a usare le coding best practices, che ti permetteranno di lavorare senza problemi all’interno di un team e di migliorare il livello del progetto su cui stai lavorando. Oggi voglio parlare dell’inheritance di Python e mostrare alcuni semplici esempi di come utilizzarla nel campo del machine learning.</p><p>Nello sviluppo software e in altri ambiti dell’informatica, il technical debt (noto anche come design debt o code debt) rappresenta il costo implicito di future rielaborazioni dovuto a una soluzione che privilegia la rapidità rispetto a un design a lungo termine.</p><p>Se sei interessato a saperne di più sui design patterns, potresti trovare utili alcuni dei miei articoli precedenti.<br> </p><p><strong><strong>Python Inheritance</strong></strong></p><p><br>L’Inheritance non è solo un concetto di Python, ma un concetto generale nell’Object Oriented Programming. Quindi, in questo tutorial, dovremo lavorare con classei e oggetti, che rappresentano un paradigma di sviluppo non molto utilizzato in Python rispetto ad altri linguaggi come Java.</p><p>Nell’OOP, possiamo definire una classe generale che rappresenta qualcosa nel mondo, ad esempio una Persona, che definiamo semplicemente con un nome, un cognome e un’età nel seguente modo.</p><p>class Person:<br> def __init__(self, name, surname, age):<br> self.name = name<br> self.surname = surname<br> self.age = age</p><p> def __str__(self):<br> return f"Name: {self.name}, surname: {self.surname}, age: {self.age}"</p><p> def grow(self):<br> self.age +=1</p><p>In questa classe, abbiamo definito un semplice costruttore (init). Poi abbiamo definito il method str, che si occuperà di stampare l’oggetto nel modo che desideriamo. Infine, abbiamo il method grow() per rendere la persona di un anno più vecchia.</p><p>Ora possiamo instanziare un oggetto e utilizzare questa classe.</p><p>person = Person("Marcello", "Politi", 28)<br>person.grow()<br>print(person)</p><p># output wiil be<br># Name: Marcello, surname: Politi, age: 29</p><p>E se volessimo definire un particolare tipo di persona, ad esempio un operaio? Possiamo fare la stessa cosa di prima, ma aggiungiamo un’altra variabile di input per aggiungere il suo stipendio.</p><p>class Worker:<br> def __init__(self, name, surname, age, salary):<br> self.name = name<br> self.surname = surname<br> self.age = age<br> self.salary = salary</p><p> def __str__(self):<br> return f"Name: {self.name}, surname: {self.surname}, age: {self.age}, salary: {self.salary}"</p><p> def grow(self):<br> self.age +=1</p><p>Tutto qui. Ma è questo il modo migliore per implementarlo? Vedete che la maggior parte del codice del lavoratore è uguale a quello della persona, perché un lavoratore è una persona particolare e condivide molte cose in comune con una persona.</p><p>Quello che possiamo fare è dire a Python che il lavoratore deve ereditare tutto da Persona, e poi aggiungere manualmente tutte le cose di cui abbiamo bisogno, che una persona generica non ha.</p><p>class Worker(Person):<br> def __init__(self, name, surname, age, salary):<br> super().__init__(name, surname, age)<br> self.salary = salary</p><p> def __str__(self):<br> text = super().__str__()<br> return text + f",salary: {self.salary}"</p><p>Nella classe worker, il costruttore richiama il costruttore della classe person sfruttando la parola chiave super() e poi aggiunge anche la variabile salary.</p><p>La stessa cosa avviene quando si definisce il metodo <strong>str</strong>. Utilizziamo lo stesso testo restituito da Person usando la parola chiave super e aggiungiamo il salario quando stampiamo l’oggetto.<br> </p><p><strong>Ereditarietà nel Machine Learning</strong></p><p><br>Non ci sono regole su quando usare l’ereditarietà nell’machine learning . Non so a quale progetto stiate lavorando, né come sia il vostro codice. Voglio solo sottolineare il fatto che dovreste adottare un paradigma OOP nel vostro codice. Tuttavia, vediamo alcuni esempi di utilizzo dell’ereditarietà.<br> </p><p><strong>Definire un BaseModel</strong></p><p><br>Sviluppiamo una classe di base per il modello di ML, definita da alcune variabili standard. Questa classe avrà un metodo per caricare i dati, uno per addestrare, un altro per valutare e uno per preelaborare i dati. Tuttavia, ogni modello specifico preelaborerà i dati in modo diverso, quindi le sottoclassi che erediteranno il modello di base dovranno riscrivere il metodo di preelaborazione.<br>Attenzione, il modello BaseMLModel stesso eredita la classe ABC. Questo è un modo per dire a Python che questa classe è una classe astratta e non deve essere usata, ma è solo un modello per costruire sottoclassi.</p><p>Lo stesso vale per il metodo preprocess_train_data, che è contrassegnato come @abstactmethod. Ciò significa che le sottoclassi devono reimplementare questo metodo.</p><p>Guardate questo video per saperne di più su classi e metodi astratti:</p><p><a href="https://www.youtube.com/embed/UDmJGvM-OUw?start=1&amp;feature=oembed" rel="nofollow noopener" target="_blank">youtube.com/embed/UDmJGvM-OUw?…</a></p><p>from abc import ABC, abstractmethod<br>from sklearn.model_selection import train_test_split<br>from sklearn.metrics import accuracy_score<br>from sklearn.ensemble import RandomForestClassifier<br>from sklearn.linear_model import LogisticRegression<br>from sklearn.datasets import load_iris<br>import numpy as np</p><p>class BaseMLModel(ABC):<br> def __init__(self, test_size=0.2, random_state=42):<br> self.model = None # This will be set in subclasses<br> self.test_size = test_size<br> self.random_state = random_state<br> self.X_train = None<br> self.X_test = None<br> self.y_train = None<br> self.y_test = None</p><p> def load_data(self, X, y):<br> self.X_train, self.X_test, self.y_train, self.y_test = train_test_split(<br> X, y, test_size=self.test_size, random_state=self.random_state<br> )</p><p> @abstractmethod<br> def preprocess_train_data(self):<br> """Each model can define custom preprocessing for training data."""<br> pass</p><p> def train(self):<br> self.X_train, self.y_train = self.preprocess_train_data()<br> self.model.fit(self.X_train, self.y_train)</p><p> def evaluate(self):<br> predictions = self.model.predict(self.X_test)<br> return accuracy_score(self.y_test, predictions)</p><p>Vediamo ora come ereditare da questa classe. Per prima cosa, possiamo implementare un LogisticRegressionModel. Che avrà il suo algoritmo di preelaborazione.</p><p>class LogisticRegressionModel(BaseMLModel):<br> def __init__(self, **kwargs):<br> super().__init__()<br> self.model = LogisticRegression(**kwargs)</p><p> def preprocess_train_data(self):<br> <a href="https://poliverso.org/search?tag=Standardize" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>Standardize</span></a> features for Logistic Regression<br> mean = self.X_train.mean(axis=0)<br> std = self.X_train.std(axis=0)<br> X_train_scaled = (self.X_train - mean) / std<br> return X_train_scaled, self.y_train</p><p>Poi possiamo definire tutte le sottoclassi che vogliamo. Qui ne definisco una per una Random Forest.</p><p>class RandomForestModel(BaseMLModel):<br> def __init__(self, n_important_features=2, **kwargs):<br> super().__init__()<br> self.model = RandomForestClassifier(**kwargs)<br> self.n_important_features = n_important_features</p><p> def preprocess_train_data(self):<br> <a href="https://poliverso.org/search?tag=Select" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>Select</span></a> top `n_important_features` features based on variance<br> feature_variances = np.var(self.X_train, axis=0)<br> top_features_indices = np.argsort(feature_variances)[-self.n_important_features:]<br> X_train_selected = self.X_train[:, top_features_indices]<br> return X_train_selected, self.y_train</p><p>Ora usiamo tutto nella funzione main.</p><p>if __name__ == "__main__":<br> # Load dataset<br> data = load_iris()<br> X, y = data.data, data.target</p><p> # Logistic Regression<br> log_reg_model = LogisticRegressionModel(max_iter=200)<br> log_reg_model.load_data(X, y)<br> log_reg_model.train()<br> print(f"Logistic Regression Accuracy: {log_reg_model.evaluate()}")</p><p> # Random Forest<br> rf_model = RandomForestModel(n_estimators=100, n_important_features=3)<br> rf_model.load_data(X, y)<br> rf_model.train()<br> print(f"Random Forest Accuracy: {rf_model.evaluate()}")</p><p><strong>Conclusioni</strong></p><p><br>Uno dei principali vantaggi dell’ereditarietà di Python nei progetti ML è nella progettazione di codici modulari, mantenibili e scalabili. L’ereditarietà aiuta a evitare codice ridondante, scrivendo la logica comune in una classe base, come BaseMLModel, riducendo quindi la duplicazione del codice. L’inheritance rende anche facile incapsulare comportamenti comuni in una classe base, permettendo alle subclasses di definire dettagli specifici.</p><p>Il principale vantaggio, a mio avviso, è che una codebase ben organizzata e orientata agli oggetti consente a più sviluppatori all’interno di un team di lavorare indipendentemente su parti separate. Nel nostro esempio, un ingegnere capo potrebbe definire il modello base, e poi ogni sviluppatore potrebbe concentrarsi su un singolo algoritmo e scrivere la subclass.<br>Prima di immergerti in design patterns complessi, concentrati sull’utilizzo delle best practices nell’OOP. Farlo ti renderà un programmatore migliore rispetto a molti altri nel campo dell’AI!</p><p>L'articolo <a href="https://www.redhotcyber.com/post/inheritance-in-python-la-chiave-per-scrivere-codice-pulito/" rel="nofollow noopener" target="_blank">Inheritance in Python: la chiave per scrivere codice pulito e collaborativo nel Machine Learning</a> proviene da <a href="https://www.redhotcyber.com/feed" rel="nofollow noopener" target="_blank">il blog della sicurezza informatica</a>.</p>
Cybersecurity & cyberwarfare<p><b>Inheritance in Python: la chiave per scrivere codice pulito e collaborativo nel Machine Learnin</b></p><p>Molte persone che si avvicinano al <a href="https://www.redhotcyber.com/post/scopriamo-le-differenze-tra-un-algoritmo-di-machine-learning-e-deep-learning/" rel="nofollow noopener" target="_blank">machine learning</a> non hanno un forte background in ingegneria del software, e quando devono lavorare su un prodotto reale, il loro codice può risultare disordinato e difficile da gestire. Per questo motivo, raccomando sempre vivamente di imparare a usare le coding best practices, che ti permetteranno di lavorare senza problemi all’interno di un team e di migliorare il livello del progetto su cui stai lavorando. Oggi voglio parlare dell’inheritance di Python e mostrare alcuni semplici esempi di come utilizzarla nel campo del machine learning.</p><p>Nello sviluppo software e in altri ambiti dell’informatica, il technical debt (noto anche come design debt o code debt) rappresenta il costo implicito di future rielaborazioni dovuto a una soluzione che privilegia la rapidità rispetto a un design a lungo termine.</p><p>Se sei interessato a saperne di più sui design patterns, potresti trovare utili alcuni dei miei articoli precedenti.<br> </p><p><strong><strong>Python Inheritance</strong></strong></p><p><br>L’Inheritance non è solo un concetto di Python, ma un concetto generale nell’Object Oriented Programming. Quindi, in questo tutorial, dovremo lavorare con classei e oggetti, che rappresentano un paradigma di sviluppo non molto utilizzato in Python rispetto ad altri linguaggi come Java.</p><p>Nell’OOP, possiamo definire una classe generale che rappresenta qualcosa nel mondo, ad esempio una Persona, che definiamo semplicemente con un nome, un cognome e un’età nel seguente modo.</p><p>class Person:<br> def __init__(self, name, surname, age):<br> self.name = name<br> self.surname = surname<br> self.age = age</p><p> def __str__(self):<br> return f"Name: {self.name}, surname: {self.surname}, age: {self.age}"</p><p> def grow(self):<br> self.age +=1</p><p>In questa classe, abbiamo definito un semplice costruttore (init). Poi abbiamo definito il method str, che si occuperà di stampare l’oggetto nel modo che desideriamo. Infine, abbiamo il method grow() per rendere la persona di un anno più vecchia.</p><p>Ora possiamo instanziare un oggetto e utilizzare questa classe.</p><p>person = Person("Marcello", "Politi", 28)<br>person.grow()<br>print(person)</p><p># output wiil be<br># Name: Marcello, surname: Politi, age: 29</p><p>E se volessimo definire un particolare tipo di persona, ad esempio un operaio? Possiamo fare la stessa cosa di prima, ma aggiungiamo un’altra variabile di input per aggiungere il suo stipendio.</p><p>class Worker:<br> def __init__(self, name, surname, age, salary):<br> self.name = name<br> self.surname = surname<br> self.age = age<br> self.salary = salary</p><p> def __str__(self):<br> return f"Name: {self.name}, surname: {self.surname}, age: {self.age}, salary: {self.salary}"</p><p> def grow(self):<br> self.age +=1</p><p>Tutto qui. Ma è questo il modo migliore per implementarlo? Vedete che la maggior parte del codice del lavoratore è uguale a quello della persona, perché un lavoratore è una persona particolare e condivide molte cose in comune con una persona.</p><p>Quello che possiamo fare è dire a Python che il lavoratore deve ereditare tutto da Persona, e poi aggiungere manualmente tutte le cose di cui abbiamo bisogno, che una persona generica non ha.</p><p>class Worker(Person):<br> def __init__(self, name, surname, age, salary):<br> super().__init__(name, surname, age)<br> self.salary = salary</p><p> def __str__(self):<br> text = super().__str__()<br> return text + f",salary: {self.salary}"</p><p>Nella classe worker, il costruttore richiama il costruttore della classe person sfruttando la parola chiave super() e poi aggiunge anche la variabile salary.</p><p>La stessa cosa avviene quando si definisce il metodo <strong>str</strong>. Utilizziamo lo stesso testo restituito da Person usando la parola chiave super e aggiungiamo il salario quando stampiamo l’oggetto.<br> </p><p><strong>Ereditarietà nel Machine Learning</strong></p><p><br>Non ci sono regole su quando usare l’ereditarietà nell’machine learning . Non so a quale progetto stiate lavorando, né come sia il vostro codice. Voglio solo sottolineare il fatto che dovreste adottare un paradigma OOP nel vostro codice. Tuttavia, vediamo alcuni esempi di utilizzo dell’ereditarietà.<br> </p><p><strong>Definire un BaseModel</strong></p><p><br>Sviluppiamo una classe di base per il modello di ML, definita da alcune variabili standard. Questa classe avrà un metodo per caricare i dati, uno per addestrare, un altro per valutare e uno per preelaborare i dati. Tuttavia, ogni modello specifico preelaborerà i dati in modo diverso, quindi le sottoclassi che erediteranno il modello di base dovranno riscrivere il metodo di preelaborazione.<br>Attenzione, il modello BaseMLModel stesso eredita la classe ABC. Questo è un modo per dire a Python che questa classe è una classe astratta e non deve essere usata, ma è solo un modello per costruire sottoclassi.</p><p>Lo stesso vale per il metodo preprocess_train_data, che è contrassegnato come @abstactmethod. Ciò significa che le sottoclassi devono reimplementare questo metodo.</p><p>Guardate questo video per saperne di più su classi e metodi astratti:</p><p><a href="https://www.youtube.com/embed/UDmJGvM-OUw?start=1&amp;feature=oembed" rel="nofollow noopener" target="_blank">youtube.com/embed/UDmJGvM-OUw?…</a></p><p>from abc import ABC, abstractmethod<br>from sklearn.model_selection import train_test_split<br>from sklearn.metrics import accuracy_score<br>from sklearn.ensemble import RandomForestClassifier<br>from sklearn.linear_model import LogisticRegression<br>from sklearn.datasets import load_iris<br>import numpy as np</p><p>class BaseMLModel(ABC):<br> def __init__(self, test_size=0.2, random_state=42):<br> self.model = None # This will be set in subclasses<br> self.test_size = test_size<br> self.random_state = random_state<br> self.X_train = None<br> self.X_test = None<br> self.y_train = None<br> self.y_test = None</p><p> def load_data(self, X, y):<br> self.X_train, self.X_test, self.y_train, self.y_test = train_test_split(<br> X, y, test_size=self.test_size, random_state=self.random_state<br> )</p><p> @abstractmethod<br> def preprocess_train_data(self):<br> """Each model can define custom preprocessing for training data."""<br> pass</p><p> def train(self):<br> self.X_train, self.y_train = self.preprocess_train_data()<br> self.model.fit(self.X_train, self.y_train)</p><p> def evaluate(self):<br> predictions = self.model.predict(self.X_test)<br> return accuracy_score(self.y_test, predictions)</p><p>Vediamo ora come ereditare da questa classe. Per prima cosa, possiamo implementare un LogisticRegressionModel. Che avrà il suo algoritmo di preelaborazione.</p><p>class LogisticRegressionModel(BaseMLModel):<br> def __init__(self, **kwargs):<br> super().__init__()<br> self.model = LogisticRegression(**kwargs)</p><p> def preprocess_train_data(self):<br> <a href="https://poliverso.org/search?tag=Standardize" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>Standardize</span></a> features for Logistic Regression<br> mean = self.X_train.mean(axis=0)<br> std = self.X_train.std(axis=0)<br> X_train_scaled = (self.X_train - mean) / std<br> return X_train_scaled, self.y_train</p><p>Poi possiamo definire tutte le sottoclassi che vogliamo. Qui ne definisco una per una Random Forest.</p><p>class RandomForestModel(BaseMLModel):<br> def __init__(self, n_important_features=2, **kwargs):<br> super().__init__()<br> self.model = RandomForestClassifier(**kwargs)<br> self.n_important_features = n_important_features</p><p> def preprocess_train_data(self):<br> <a href="https://poliverso.org/search?tag=Select" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>Select</span></a> top `n_important_features` features based on variance<br> feature_variances = np.var(self.X_train, axis=0)<br> top_features_indices = np.argsort(feature_variances)[-self.n_important_features:]<br> X_train_selected = self.X_train[:, top_features_indices]<br> return X_train_selected, self.y_train</p><p>Ora usiamo tutto nella funzione main.</p><p>if __name__ == "__main__":<br> # Load dataset<br> data = load_iris()<br> X, y = data.data, data.target</p><p> # Logistic Regression<br> log_reg_model = LogisticRegressionModel(max_iter=200)<br> log_reg_model.load_data(X, y)<br> log_reg_model.train()<br> print(f"Logistic Regression Accuracy: {log_reg_model.evaluate()}")</p><p> # Random Forest<br> rf_model = RandomForestModel(n_estimators=100, n_important_features=3)<br> rf_model.load_data(X, y)<br> rf_model.train()<br> print(f"Random Forest Accuracy: {rf_model.evaluate()}")</p><p><strong>Conclusioni</strong></p><p><br>Uno dei principali vantaggi dell’ereditarietà di Python nei progetti ML è nella progettazione di codici modulari, mantenibili e scalabili. L’ereditarietà aiuta a evitare codice ridondante, scrivendo la logica comune in una classe base, come BaseMLModel, riducendo quindi la duplicazione del codice. L’inheritance rende anche facile incapsulare comportamenti comuni in una classe base, permettendo alle subclasses di definire dettagli specifici.</p><p>Il principale vantaggio, a mio avviso, è che una codebase ben organizzata e orientata agli oggetti consente a più sviluppatori all’interno di un team di lavorare indipendentemente su parti separate. Nel nostro esempio, un ingegnere capo potrebbe definire il modello base, e poi ogni sviluppatore potrebbe concentrarsi su un singolo algoritmo e scrivere la subclass.<br>Prima di immergerti in design patterns complessi, concentrati sull’utilizzo delle best practices nell’OOP. Farlo ti renderà un programmatore migliore rispetto a molti altri nel campo dell’AI!</p><p>L'articolo <a href="https://www.redhotcyber.com/post/inheritance-in-python-la-chiave-per-scrivere-codice-pulito-e-collaborativo-nel-machine-learnin/" rel="nofollow noopener" target="_blank">Inheritance in Python: la chiave per scrivere codice pulito e collaborativo nel Machine Learnin</a> proviene da <a href="https://www.redhotcyber.com/feed" rel="nofollow noopener" target="_blank">il blog della sicurezza informatica</a>.</p>
Felix Palmen :freebsd: :c64:<p>First change since <a href="https://mastodon.bsd.cafe/tags/swad" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>swad</span></a> 0.2 will actually be a (huge?) improvement to my <a href="https://mastodon.bsd.cafe/tags/poser" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>poser</span></a> lib. So far, it was hardwired to use the good old <a href="https://mastodon.bsd.cafe/tags/POSIX" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>POSIX</span></a> <a href="https://mastodon.bsd.cafe/tags/select" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>select</span></a> call. This is perfectly fine for handling around up to 100 (or at least less than 1000, YMMV) clients.</p><p>Some <a href="https://mastodon.bsd.cafe/tags/select" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>select</span></a> implementations offer defining the upper limit for checked file descriptors. Added support for that.</p><p>POSIX also specifies <a href="https://mastodon.bsd.cafe/tags/poll" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>poll</span></a>, which has very similar <a href="https://mastodon.bsd.cafe/tags/scalability" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>scalability</span></a> issues, but slightly different. Added support for this as well.</p><p>And then, I went on to add support for the <a href="https://mastodon.bsd.cafe/tags/Linux" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>Linux</span></a>-specific <a href="https://mastodon.bsd.cafe/tags/epoll" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>epoll</span></a> and <a href="https://mastodon.bsd.cafe/tags/BSD" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>BSD</span></a>-specific <a href="https://mastodon.bsd.cafe/tags/kqueue" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>kqueue</span></a> (<a href="https://mastodon.bsd.cafe/tags/FreeBSD" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>FreeBSD</span></a>, <a href="https://mastodon.bsd.cafe/tags/NetBSD" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>NetBSD</span></a>, <a href="https://mastodon.bsd.cafe/tags/OpenBSD" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>OpenBSD</span></a>, ...) which are both designed to *solve* any scalability issues 🥳 </p><p>A little thing that slightly annoyed me about kqueue was that there's no support for temporarily changing the signal mask, so I had to do the silly dance shown in the screenshot. OTOH, it offers changing event filters and getting events in a single call, which I might try to even further optimize ... 😎</p><p><a href="https://mastodon.bsd.cafe/tags/C" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>C</span></a> <a href="https://mastodon.bsd.cafe/tags/coding" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>coding</span></a></p>
Kevin Russell<p>Can we please get rid of "selected for deletion" in replies and edits.</p><p>Please, third time this week I had to open previous edits to copy text back into my post because "automatically selected for deletion" deleted the post I was trying to add a preposition to.</p><p><a href="https://mstdn.social/tags/Mastodon" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>Mastodon</span></a> <a href="https://mstdn.social/tags/select" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>select</span></a> <a href="https://mstdn.social/tags/coders" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>coders</span></a></p>
Europe Says<p><a href="https://www.europesays.com/1909382/" rel="nofollow noopener" translate="no" target="_blank"><span class="invisible">https://www.</span><span class="">europesays.com/1909382/</span><span class="invisible"></span></a> Kelsea Ballerini’s last minute show cancellation has fans demanding answers <a href="https://pubeurope.com/tags/america" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>america</span></a> <a href="https://pubeurope.com/tags/Entertainment" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>Entertainment</span></a> <a href="https://pubeurope.com/tags/episodic" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>episodic</span></a> <a href="https://pubeurope.com/tags/health" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>health</span></a> <a href="https://pubeurope.com/tags/nup_204841" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>nup_204841</span></a> <a href="https://pubeurope.com/tags/Season27" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>Season27</span></a> <a href="https://pubeurope.com/tags/select" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>select</span></a> <a href="https://pubeurope.com/tags/sports" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>sports</span></a> <a href="https://pubeurope.com/tags/UnitedStates" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>UnitedStates</span></a> <a href="https://pubeurope.com/tags/UnitedStatesOfAmerica" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>UnitedStatesOfAmerica</span></a> <a href="https://pubeurope.com/tags/US" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>US</span></a> <a href="https://pubeurope.com/tags/USA" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>USA</span></a></p>
🇪🇺EU at UN-NY<p>RT by <span class="h-card"><a href="https://respublicae.eu/@EUatUN" class="u-url mention" rel="nofollow noopener" target="_blank">@<span>EUatUN</span></a></span>: As political events, elections may trigger violence &amp; conflicts in societies.</p><p><a href="https://respublicae.eu/tags/EU" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>EU</span></a> and @UNDP developed an electoral violence early warning and early response system, implemented in several countries across the globe.</p><p><a href="https://respublicae.eu/tags/SELECT" class="mention hashtag" rel="nofollow noopener" target="_blank">#<span>SELECT</span></a><br>---<br><a href="https://nitter.privacydev.net/UNDPEU/status/1879472864136659370#m" rel="nofollow noopener" target="_blank"><span class="invisible">https://</span><span class="ellipsis">nitter.privacydev.net/UNDPEU/s</span><span class="invisible">tatus/1879472864136659370#m</span></a></p>