Congrès Français de Génie des Procédés SFGP – du 15 au 17 octobre 2024

Participez au 19ᵉ congrès français de génie des procédés : innovations, réseautage et découvertes en Normandie !

Du 15 au 17 octobre 2024, plongez dans l’univers captivant du génie des procédés au Centre International de Deauville. Cet événement majeur vous offre une opportunité rare de découvrir les dernières avancées scientifiques et technologiques, de rencontrer des leaders du secteur, et de débattre des défis cruciaux de notre époque. En plus des sessions enrichissantes, vous aurez l’occasion de visiter des sites industriels emblématiques et de profiter des trésors touristiques de la Normandie. Ne manquez pas cette chance unique de vous connecter, d’apprendre et de vous inspirer. Réservez dès aujourd’hui pour un congrès inoubliable !

Du 15 au 17 octobre 2024

Au Centre International de Deauville

Probayes intervient en compagnie d'Orano

Au sein de son usine, Orano se doit d’effectuer des mesures laboratoires, c’est pourquoi Probayes a proposé son expertise en modélisation . Ces mesures sont coûteuses en temps et ne sont pas continues. Dans le but de consolider les résultats laboratoires, mais aussi d’avoir une mesure continue du relevé cible, nous avons proposé à Orano une solution mêlant l’information chimique (équation de réaction) et une modélisation probabiliste. A l’aide d’autres mesures capteurs et en propageant des incertitudes sur les relevés laboratoires avec un modèle bayesien, nous avons proposé une solution pertinente et efficace, permettant d’avoir une confiance notable dans les résultats du modèle.
Ce projet sera présenté à la société française de la génie des procédés 2024 à Deauville, en compagnie d’Orano. Cette réussite mutuelle donnera également naissance à un document détaillant la méthode. 
Vous pouvez nous retrouver du 15 au 17 octobre au salon a Deauville!

Programme en cours d’élaboration…

Elise Dard

Chef de projet Organisation et Planification Opérationnelle du Réseau La Poste

Leslie Leroux

Responsable d'équipe Recherche Opérationnelle et Optimisation Combinatoire

Logo Probayes

Un évènement organisé par :

Webinaire Minasmart/NumIAA – 27 septembre 2024

L'intelligence artificielle au service de
l'optimisation des processus de R&D !

Vous travaillez dans la Recherche et Développement à l’ère de la révolution numérique et des avancées de l’Intelligence Artificielle ?

Face aux défis des secteurs agroalimentaire, cosmétique et des compléments alimentaires, Innov’Alliance, en partenariat avec Vegepolys Valley, organise cet événement gratuit et ouvert à tous. Il comprend un webinaire de présentation et un atelier d’émergence (discussion interactive) centré sur l’optimisation des processus de R&D grâce à l’Intelligence Artificielle.

Conférence

Inscrivez-vous !

L’IA au service de la performance de votre entreprise 
Alexis Mignon, Directeur Scientifique Probayes

Explorons ensemble le déroulement d’un projet d’Intelligence Artificielle.

Quels sont les éléments importants ?
Qu’est-ce qu’une donné de qualité ?

Découvrons quelques cas d’usage possibles sur les secteurs de l’agroalimentaire ou de la chimie :

  • Comment trouver la bonne formule chimique ?
  • Aider à la formulation chimique de médicament
  • Aider à la compréhension de facteurs impactants
  • Optimiser le procédé de production

27 septembre

10h – 11h10

Webinaire en ligne

Elise Dard

Chef de projet Organisation et Planification Opérationnelle du Réseau La Poste

Alexis MIGNON
Directeur Scientifique expert en Machine Learning.

Logo Probayes

Un évènement organisé par :

Supply Chain Event – 12 et 13 novembre 2024

IA & Optimisation
le nouveau tandem pour supply chain
et la logistique du futur !

Plus qu’un événement, Supply Chain Event est activateur de transformation numérique présentant des technologies, outils et méthodes pour optimiser la chaîne d’approvisionnement des entreprises de l’industrie et de la grande distribution.

 

Retrouvez-nous !

  • Stand B27
  • 12 & 13 novembre 2024
  • Paris Porte de Versailles –  Pavillon 5.2 & 5.3

Conférence en prévision

Comment faciliter la planification des agents en couvrant au mieux les tâches à accomplir et en respectant de multiples impératifs ?

Le module de Recherche Opérationnelle développé propose des plannings de chargés de clientèle au manager du bureau de poste, afin de satisfaire le flux client et la qualité de vie au travail.

Il est intégré dans l’outil de planification du métier et prend en compte le multi-sites, multi-activités, les impératifs réglementaires, métiers et RH.

 

Mardi 14 novembre 

15h00 – 15h45

Salle / Atelier 3

Elise Dard

Chef de projet Organisation et Planification Opérationnelle du Réseau La Poste

Leslie Leroux

Responsable d'équipe Recherche Opérationnelle et Optimisation Combinatoire

Logo Probayes

Un évènement organisé par :

Big Data & AI Paris – 15 et 16 octobre 2024

Plongez au cœur de l'Intelligence Artificielle !

Le salon « IA Paris & Big Data 2024 » est le fruit du regroupement entre deux événements phares de la tech française et européenne : Big Data Paris, rendez-vous clé de la scène big data depuis dix ans, et AI Paris, événement dédié aux avancées de l’intelligence artificielle devenu incontournable en cinq éditions. Rapprochés pour la première fois en 2020, ces deux événements sont désormais regroupés en une seule et unique manifestation, tant le développement des marchés du big data et de l’IA sont corrélés. Big Data & AI Paris devient l’événement français de référence de tout l’écosystème big data et IA.  

15 et 16 octobre 2024

Stand C14

Porte de Versailles, Paris

Conférence en prévision

TotalEnergies développe des services de monitoring prédictif pour ses clients. L’objectif est de connaître, en temps réel, la santé de leurs équipements : moteur de cogénération ou de bateaux, machines industrielles, éoliennes, etc.

A partir des données des huiles, issues des capteurs, on va déduire la santé des machines, en estimant l’état de vieillissement de ces huiles, et en détectant la présence de contaminants par exemple. Un apprentissage multi-niveaux mené par Probayes permet de convertir les données brutes fournies par les capteurs en des informations interprétables afin d’en déduire des actions de maintenance prédictive.

Lundi 25 septembre 

16h30 – 17h00

Salle de conférence 3

Laurent Grosset – Project Leader – TotalEnergies

Ingénieur de formation, Laurent utilise la science et la technologie pour résoudre des problèmes et développer de nouveaux produits et services.

Il est reconnu pour cette combinaison unique d’une forte expertise en statistiques et en science des données et d’une très bonne compréhension de la mécanique, de la chimie, de la chimie analytique, des processus de fabrication, de la simulation et des capteurs.

Passionné par le domaine effervescent du Machine Learning et de l’IA, Laurent est toujours curieux d’améliorer sa connaissance des nouvelles techniques et aime choisir la bonne technique afin de fournir les meilleures solutions aux clients.

Logo Probayes

Alexis Mignon – Directeur Scientifique – Probayes

Alexis est docteur en informatique spécialisé en Vision par Ordinateur et Apprentissage Automatique. Il travaille depuis 2013 chez Probayes en tant qu’ingénieur R&D et chef de projets sur des sujets d’Apprentissage Automatique.

Alexis est aujourd’hui Directeur Scientifique expert en Machine Learning.

Logo Probayes

Julien Albaranes – Directeur du Développement – Probayes

Julien a rejoint Probayes en 2020 en tant que Directeur du Développement. Ingénieur de formation puis consultant en aide à la décision, il évolue dans l’Intelligence Artificielle et la Data-Science depuis plus de 15 ans.

Optimnet

Optimnet est un outil d’aide à la décision sur mesure, qui s’adapte à vos besoins pour optimiser votre réseau logistique.

FraudIA™

Solution de détection de fraude à la carte bancaire

Projet Eye Tracking

Projet permettant d’interagir grâce au suivi oculaire

Achema du 10 au 14 juin 2024

🚀 🏭𝗧𝗿𝗮𝗻𝘀𝗳𝗼𝗿𝗺𝗲𝗿 𝗹’𝘂𝘀𝗶𝗻𝗲 𝗽𝗼𝘂𝗿 𝘂𝗻𝗲 𝗽𝗲𝗿𝗳𝗼𝗿𝗺𝗮𝗻𝗰𝗲 𝗱𝘂𝗿𝗮𝗯𝗹𝗲 !

Venez découvrir le stand de L’Usine Augmentée (Hall 11.0, Stand E65) sur ACHEMA 2024, du 10 au 14 juin, au cœur du Hub Digital !

🔎 Le Hub Digital, c’est un concentré d’innovations technologiques. Situé dans le Hall 11.0, vous y retrouverez toutes les solutions d’avenirs qui feront progresser l’industries des procédés :
🔹 Plateformes numériques
🔹
Cloud et infrastructure
🔹 Logiciels
🔹
Conseil
🔹
 Outils technologiques

Probayes s’associe à son écosystème de partenaires, Courbon, Inevo, et Optimistik, pour présenter une solution unique vers le digital et la numérisation des procédés.

🚀 🏭 𝗧𝗿𝗮𝗻𝘀𝗳𝗼𝗿𝗺𝗶𝗻𝗴 𝘁𝗵𝗲 𝗽𝗹𝗮𝗻𝘁 𝗳𝗼𝗿 𝗮 𝘀𝘂𝘀𝘁𝗮𝗶𝗻𝗮𝗯𝗹𝗲 𝗽𝗲𝗿𝗳𝗼𝗿𝗺𝗮𝗻𝗰𝗲!

Come and visit the “The Augmented Plant” stand (Hall 11.0, Booth E65) at ACHEMA 2024, from June 10 to 14, in the heart of the Digital Hub!

🔎 The Digital Hub is a concentration of technological innovations where you can discover all the future solutions that will drive the process industry forward:
🔹 Artificial Intelligence
🔹 Digital platforms
🔹 Cloud and infrastructure
🔹 Software
🔹 Consulting
🔹 Technology tools

Probayes joins its ecosystem of partners, Courbon, Inevo and Optimistik to present solutions covering the entire value chain of the sustainable industry of the future.

Rendez-nous
visite au :

Hall 11.0 Stand E65

▶️ Salon Achema 10 – 14 juin 2024, Francfort-sur-le-Main, Allemagne

Au programme

Mardi 11/06 :

10h00/10h30 : INEVO – Jumeau Numérique

11h00/11h30 : Courbon – digitalizing industry: adapt the solution to your environment and gain agility 

14h00/14h30 : Optimistik – Data-driven plant operations

15h/15h30 : Probayes – AI for Industry

Mercredi 12/06 :

10h00/10h30 : Optimistik – Data-driven plant operations

11h00/11h30 : Probayes – AI for Industry

14h00/14h30 : INEVO – Jumeau Numérique 

Jeudi 13/06 :

10h00/10h30 : Courbon – digitalizing industry: adapt the solution to your environment and gain agility 

11h00/11h30 : INEVO – Jumeau Numérique

14h00/14h30 : Probayes – AI for Industry

15h/15h30 : Optimistik – Data-driven plant operations

📍 Le rendez-vous est donné, nous vous attendons du 10 au 14 juin, sur le stand E65, hall 11.0 !

Optimnet

Optimnet est un outil d’aide à la décision sur mesure, qui s’adapte à vos besoins pour optimiser votre réseau logistique.

FraudIA™

Solution de détection de fraude à la carte bancaire

Projet Eye Tracking

Projet permettant d’interagir grâce au suivi oculaire

VivaTech du 22 au 25 mai 2024

𝙋𝙡𝙤𝙣𝙜𝙚𝙯 𝙖𝙪 𝙘œ𝙪𝙧 𝙙𝙚 𝙡𝙖 𝙏𝙚𝙘𝙝 𝙚𝙩 𝙫𝙚𝙣𝙚𝙯 𝙙é𝙘𝙤𝙪𝙫𝙧𝙞𝙧 𝙦𝙪𝙚𝙡𝙦𝙪𝙚𝙨-𝙪𝙣𝙨 𝙙𝙚 𝙣𝙤𝙨 𝙥𝙧𝙤𝙟𝙚𝙩𝙨 𝙙’𝙄𝙣𝙩𝙚𝙡𝙡𝙞𝙜𝙚𝙣𝙘𝙚 𝘼𝙧𝙩𝙞𝙛𝙞𝙘𝙞𝙚𝙡𝙡𝙚 𝙚𝙩 𝙙’𝙄𝘼 𝙂𝙚́𝙣𝙚́𝙧𝙖𝙩𝙞𝙫𝙚 𝙨𝙪𝙧 𝙑𝙞𝙫𝙖𝙩𝙚𝙘𝙝 !

Probayes sera présent sur Vivatech et vous présentera plusieurs démos  :

– La Poste GPT

– détection de mauvaises postures en temps réel et grâce à l’Intelligence Artificielle 

– son avatar doté d’Intelligence Artificielle Générative

Mais comment discuter avec mon Avatar ?
C’est simple, à partir d’une photo prise sur place, vous choisissez le style dans lequel votre avatar apparaîtra.
Et hop, en quelques secondes, vous voilà sous les traits d’un dessin animé.
À présent, c’est à vous de jouer en posant vos questions.
Et grâce à l’IA Générative, la magie opère et votre double vous répond sous forme de vidéo.

▶️ Rencontrons-nous, du 22 au 25 mai 2024 à VivaTech

Retrouvez-nous sur le stand de La Poste Groupe

Optimnet

Optimnet est un outil d’aide à la décision sur mesure, qui s’adapte à vos besoins pour optimiser votre réseau logistique.

FraudIA™

Solution de détection de fraude à la carte bancaire

Projet Eye Tracking

Projet permettant d’interagir grâce au suivi oculaire

Les filtres de Kalman

Les filtres de Kalman

Les filtres de Kalman permettent d’estimer l’état d’un système dynamique pour lequel on connait :

  • les règles / lois d’évolution
  • les actions qui lui sont appliquées
  • une série d’observations / mesures potentiellement incomplètes ou bruitées.

Dans sa version la plus simple, l’ensemble des transformations du système ainsi que les observations réalisées peuvent être modélisées sous forme de transformations linéaires appliquées à l’état du système.

Supposons un système dynamique dont l’état à l’instant t est \boldsymbol x_t.

À tout moment, l’estimation de l’état \hat {\boldsymbol x}_t est connue avec une certaine incertitude représentée par une matrice de covariance P_t.

    \[\boldsymbol x_t \sim \mathcal N(\hat{\boldsymbol x}_t, P_t)\]

 

Les gaussiennes multivariées

Ce sont des distributions bien connues avec de nombreuses propriétés mathématiques pratiques:

  • marginalisation
  • conditionnement
  • etc.

Pour ce type de formule, vous pouvez par exemple utiliser le « Matrix CookBook »

 

%matplotlib inline
import numpy as np
from scipy.linalg import eigh
from scipy.stats import multivariate_normal
import matplotlib.pyplot as plt
from matplotlib.patches import Ellipse
from sklearn.datasets import make_spd_matrix

plt.ion()
def compute_ellipse(cov):
w, u = eigh(cov)
std = np.sqrt(w)
angle = np.arctan2(u[1, 0], u[0, 0])
return 3 * std[0], 3 * std[1], angle * 180. / np.pi

def plot_gaussian(mu, cov):
"""Plot the mean and covariance of a 2D Gaussian distribution.

Parameters
----------
mu : array_like, shape (2,)
Mean vector of the distribution.
cov: array_like, shape (2, 2)
Covariance matrix of the distribution.
"""

# Plot the mean vector.
sc = plt.scatter(mu[0], mu[1], label='Mean')
width, height, angle = compute_ellipse(cov[:2, :2])
# Plot the covariance matrix as an ellipse.
ellipse = Ellipse(xy=mu, width=width, height=height, angle=angle,
alpha=0.2, label='Covariance')
plt.gca().add_artist(ellipse)
return sc, ellipse

C = make_spd_matrix(2, random_state=1)
mu = np.array([1, 2])

X = multivariate_normal(mu, C).rvs(1000)

plt.scatter(*X.T, s=1)
plot_gaussian(mu, C);

png

Distribution jointe

Décomposons notre état \boldsymbol x distribuée selon une loi Gaussienne, en deux sous-parties, la distribution jointe des deux sous partie est :

    \[\boldsymbol x = \pmatrix{ \boldsymbol x_1 \ \boldsymbol x_2 } \sim \mathcal N\left( \pmatrix{ \boldsymbol \mu_1 \ \boldsymbol \mu_2 }, \pmatrix{ \Sigma_{11} & \Sigma_{12} \ \Sigma_{21} & \Sigma_{22} } \right)\]

Avec \Sigma_{21} = \Sigma_{12}^T.

Marginalisation

    \[\boldsymbol x_1 \sim \mathcal N\left( \boldsymbol \mu_1, \Sigma_{11} \right)\]

Conditionnement

Si on connait la valeur de \boldsymbol x_2 alors:

    \[\boldsymbol x_{1|2} \sim \mathcal N\left( \boldsymbol \mu_1 + \Sigma_{12}\Sigma_{22}^{-1}(\boldsymbol x_2 - \boldsymbol \mu_2), \Sigma_{11} - \Sigma_{12}\Sigma_{22}^{-1}\Sigma_{21} \right)\]

Combinaison linéaire

Si on a deux variable aléatoires indépendantes :

    \[\boldsymbol x_1 \sim \mathcal N\left( \boldsymbol \mu_1, \Sigma_{11} \right)\]

    \[\boldsymbol x_2 \sim \mathcal N\left( \boldsymbol \mu_2, \Sigma_{22} \right)\]

Alors la combinaison linéaire des deux est distribuée comme:

    \[A\boldsymbol x_1 + B \boldsymbol x_2 + \boldsymbol c \sim \mathcal N\left( A\boldsymbol \mu_1 + B \boldsymbol \mu_2 + \boldsymbol c, A\Sigma_{11}A^T + B\Sigma_{22}B^T \right)\]

Propagation de la dynamique du système

Les filtres de Kalman modélisent le système en temps discret et l’évolution entre deux pas de temps est donnée par la loi linéaire :

    \[\boldsymbol x_{k + 1|k} = F_k \boldsymbol x_{k|k} + G_k \boldsymbol u_k + \boldsymbol w_k\]

avec :
* \boldsymbol x_{k|k}: L’estimtation de l’état au pas k après avoir pris en compte les éventuelles observations
* \boldsymbol x_{k + 1|k} : L’estimation de l’état au pas k+1 par propagation de la dynamique du système depuis l’estimation au pas précédent.
* F_k : matrice de transition qui représente l’évolution « naturelle » du système (pas nécessairement constante)
* \boldsymbol u_k : une commande (ou contrôle) appliquée au système
* G_k : l’effet de la commande sur le système (pas nécessairement constante)
* \boldsymbol w_k : le bruit du processus, c’est-à-dire ce qu’on ne modélise pas bien.

    \[\boldsymbol w_k \sim \mathcal N(\boldsymbol 0, Q_k)\]

Exemple

Point mobile dans le plan

Appliquons cela à un objet ponctuel en mouvement sans frottement dans un plan.

L’état de l’objet à un instant t est encodé par sa position \boldsymbol x_t et sa vitesse \dot{\boldsymbol x}_t:

 

Le contrôle sur l’objet se fait par l’intermédiaire de l’équivalent d’une poussée :

    \[\boldsymbol a_t = \frac{1}{m} \boldsymbol f_t\]

On peut donc appliquer les équations du mouvement de Newton pour modéliser l’évolution du mobile entre deux instants proches. Si on considère que l’accélération est constante entre t est t + \Delta t, la vitesse va être données par:

    \[\dot{\boldsymbol x}_{t + \Delta_t} = \boldsymbol a_t \Delta t + \dot{\boldsymbol x}_t\]

Soit la vitesse initiale à laquelle on ajoute la variation de vitesse due à la poussée.

Et le déplacement peut se calculer par:

    \[\boldsymbol x_{t + \Delta_t} = \frac{1}{2}\boldsymbol a_t (\Delta t)^2 + \dot{\boldsymbol x}_t \Delta t + \boldsymbol x_t\]

Où l’on retrouve la position à l’instant précédent, plus la variation de poistion due à la vitesse initiale, plus la variation de position liée à la poussée.

Mise en équation de la propagation du filtre de Kalman

Pour se caler dans le formalisme des filtre de Kalman, je suppose que l’état du système, au pas de temps k, est donné par sa position et sa vitesse :

    \[\boldsymbol x_{k|k} = \left(\begin{array}{c} x_k \ y_k \ \dot x_k \ \dot y_k \end{array}\right)\]

On peut ensuite séparer dans les équations de mouvement. Les parties qui dépendent de l’état précédent (position \boldsymbol x et vitesse \boldsymbol{\dot x}) et les parties qui dépendent du contrôle \boldsymbol u_k = \boldsymbol a_k (ici l’accélération) et on peut ainsi construire les différents termes de l’étape de propagation:

    \[F_k = \left(\begin{array}{cc} 1 & 0 & \Delta t & 0 \ 0 & 1 & 0 & \Delta t \ 0 & 0 & 1 & 0 \ 0 & 0 & 0 & 1 \end{array}\right)\]

Le contrôle corresond ici à la poussée:

    \[\boldsymbol u_k = \boldsymbol a_k = \pmatrix{a_{xk} \ a_{yk}}= \frac{1}{m} \left(\begin{array}{c}f_{xk} \ f_{yk}\end{array}\right)\]

Et l’évolution due au contrôle est donnée par:

    \[G_k = \left(\begin{array}{c} \frac{1}{2} \Delta_t^2 & 0\ 0 & \frac{1}{2}\Delta_t^2\ \Delta t & 0 \ 0 & \Delta t \end{array}\right)\]

Simulons un tel systeme:

delta_t = 0.1
t = np.arange(0, 10., delta_t)

# L'accélération est modifée à 3 reprises pendant 10 pas de temps dans des directions différentes
acceleration = np.zeros((len(t), 2))
acceleration[10: 20] = (0, 0.4)
acceleration[30: 40] = (0, -0.6)
acceleration[50: 60] = (0.1, 0.3)

# Matrice d'évolution de l'état
F = np.identity(4)
F[0, 2] = delta_t
F[1, 3] = delta_t

# Matrice donnant l'effet du contrôle sur système
G = np.zeros((4, 2))
G[0, 0] = G[1, 1] = 0.5 * delta_t**2
G[2, 0] = G[3, 1] = delta_t

# Estimation du bruit lié au processus d'évolution
Q = np.diag([0.001, 0.001, 0.002, 0.002]) ** 2

# Etat initial
state_actual = np.zeros((len(t), 4))
state_actual[0] = (0, 0, 0.1, 0)

state_mean = np.zeros((len(t), 4))
state_mean[0] = (0, 0, 0.1, 0)

# Evolution dans le temps
np.random.seed(0)
for i in range(1, len(t)):
state_actual[i] = multivariate_normal(F @ state_actual[i - 1] + G @ acceleration[i], Q).rvs()
state_mean[i] = F @ state_mean[i - 1] + G @ acceleration[i]
from itertools import chain
from IPython.display import HTML
from matplotlib.animation import FuncAnimation

class AnimResult:
def __init__(self, state_actual, acceleration, state_mean, covariance=None, observations=None):
self.state_actual = state_actual
self.acceleration = acceleration
self.state_mean = state_mean
self.covariance = covariance
self.observations = observations

def plot_init(self):
plt.plot(*state_mean.T[:2], "--", color="tab:blue", label="Trajectoire estimée")
plt.plot(*state_actual.T[:2], "-", color="tab:orange", label="Trajectoire simulée")
if self.observations is not None:
self.plot_observations()

def plot_acceleration(self):
if self.acceleration is None:
self.accel_arrow = None
else:
self.accel_arrow = plt.arrow(
*chain(self.state_mean[0, :2],
0.5 * self.acceleration[0]),
width=0.01,
visible=np.any(self.acceleration[i] != 0)
)

def plot_estimate(self):
self.actual_scatter = plt.scatter(*self.state_actual[[0], :2].T, color="tab:orange", label="Position simulée")

if self.covariance is None:
self.mean_scatter = plt.scatter(*self.state_mean[[0], :2].T, color="tab:blue", label="Position estimée")
self.cov_ellipse = None
else:
self.mean_scatter, self.cov_ellipse = plot_gaussian(self.state_mean[0, :2], self.covariance[0, :2, :2])

def update(self, i):
self.actual_scatter.set_offsets(*self.state_actual[[i], :2])

self.mean_scatter.set_offsets(*self.state_mean[[i], :2])

if self.cov_ellipse is not None:
width, height, angle = compute_ellipse(self.covariance[i, :2, :2])
self.cov_ellipse.set_center(self.state_mean[i, :2])
self.cov_ellipse.set_width(width)
self.cov_ellipse.set_height(height)
self.cov_ellipse.set_angle(angle)

if self.acceleration is not None:

self.accel_arrow.set_data(
x=self.state_mean[i, 0],
y=self.state_mean[i, 1],
dx=0.5 * self.acceleration[i, 0],
dy=0.5 * self.acceleration[i, 1]
)
self.accel_arrow.set_visible(np.any(self.acceleration[i] != 0))

if self.observations is not None:
self.update_observations(i)

def plot_observations(self, i):
pass

def update_observations(self, i):
pass

def animate(self):
self.plot_init()
self.plot_estimate()
plt.legend()
self.plot_acceleration()

ani = FuncAnimation(
plt.gcf(), self.update, frames=np.arange(len(t)), interval=100
)
return HTML(ani.to_html5_video())
plt.ioff()
plt.figure()
plt.gca().set_aspect("equal")
AnimResult(state_actual=state_actual, acceleration=acceleration, state_mean=state_mean).animate()

 

 

Propagation de l’incertitude

Puisque nous n’avons que des lois normales et des transformations linéaires, l’erreur peut également être propagée avec, en notant P_{k|k} est l’estimation de la covariance de l’état \boldsymbol x_{k|k}:

    \[P_{k + 1 | k} = F_kP_{k|k}F_k^T + Q_k\]

Puisque:

    \[\operatorname{Cov}(\boldsymbol x_{k + 1|k}) = \mathbb E[\boldsymbol x_{k + 1|k}\boldsymbol x_{k + 1|k}^T] = \mathbb E(F_k \boldsymbol x_{k|k} \boldsymbol x_{k|k}^T F_k^T + \boldsymbol w_k \boldsymbol w_k^T)\]

# Etat initial
state_actual = np.zeros((len(t), 4))
state_actual[0] = (0, 0, 0.1, 0)

state_mean = np.zeros((len(t), 4))
state_mean[0] = (0, 0, 0.1, 0)

state_cov = np.zeros((len(t), 4, 4))
state_cov[0] = Q * 5 ** 2

# Evolution dans le temps
np.random.seed(0)
for i in range(1, len(t)):
state_actual[i] = multivariate_normal(F @ state_actual[i - 1] + G @ acceleration[i], Q).rvs()
state_mean[i] = F @ state_mean[i - 1] + G @ acceleration[i]
state_cov[i] = F @ state_cov[i - 1] @ F.T + Q

plt.ioff()
plt.figure()
plt.gca().set_aspect("equal")
AnimResult(state_actual=state_actual, acceleration=acceleration, state_mean=state_mean, covariance=state_cov).animate()

 

 

On voit donc ici le mouvement estimé du système connaissant uniquement l’état initial et les contrôles appliqués sur le système. L’incertitude sur l’état (ici, on ne visualise que l’incertitude sur la position) augmente continuellement au cours du temps.

Pour la diminuer, on peut avoir recours à des observations.

Observations

Théorie

Par ailleurs, une observation se modélise par:

    \[\boldsymbol z_k = H_k \boldsymbol x_{k | k - 1} + \boldsymbol v_k\]

avec:

  • \boldsymbol z_k: la mesure issue de l’observation
  • H_t : la matrice modélisation le processus d’observation
  • \boldsymbol v_k: le bruit d’observation.

    \[\boldsymbol v_t \sim \mathcal N(\boldsymbol 0, R_t)\]

Pour calculer l’information gagnée après une observation, on part de la distribution jointe de l’état courant et du résultat de l’observation:

    \[\left(\begin{array}{c} \boldsymbol x_{k + 1 | k} \ \boldsymbol z_k \end{array}\right) = \mathcal N \left( \left(\begin{array}{cc} \hat{\boldsymbol x}<em>{k+1|k} \ H_k \hat{\boldsymbol x}</em>{k + 1|k} \end{array}\right), \left(\begin{array}{cc} P_{k+ 1|k} & P_{k + 1 | k} H_k^T \ H_k P_{k + 1 | k} & H_k P_{k + 1 | k}H_k^T + R_k \end{array}\right) \right)\]

On peut ensuite appliquer les formules associées aux gaussiennes multivariées:

    \[\mathcal N\left( \left(\begin{array}{c}\boldsymbol \mu_1 \ \boldsymbol \mu_2\end{array}\right), \left(\begin{array}{cc}\Sigma_{11} & \Sigma_{12} \ \Sigma_{21} & \Sigma_{22}\end{array}\right) \right)\]

    \[\boldsymbol \mu_{1 | \boldsymbol x_2} = \boldsymbol \mu_1 + \Sigma_{12}\Sigma_{22}^{-1}(\boldsymbol x_2 - \boldsymbol \mu_2)\]

    \[\Sigma_{11 | \boldsymbol x_2} = \Sigma_{11} - \Sigma_{12}\Sigma_{22}^{-1}\Sigma_{21}\]

Soit ici, en supposant qu’on a observé \boldsymbol o_k:

    \[\hat{\boldsymbol x}<em>{k + 1|k + 1} = \mathbb E[\hat{\boldsymbol x}</em>{k + 1|k}|\boldsymbol z_k] = \hat{\boldsymbol x}<em>{k + 1|k} + P</em>{k+1|k} H_k^T(H_k P_{k + 1|k} H_k^T + R_k)^{-1}(\boldsymbol o_k - H_k \hat{\boldsymbol x}_{k + 1|k})\]

    \[P_{k + 1 | k + 1} = P_{k+1|k} - P_{k+1|k} H_k^T(H_k P_{k + 1|k} H_k^T + R_k)^{-1} H_k P_{k + 1|k}\]

Simulons ici une observation correspondant à la mesure de la position et de la vitesse selon l’axe x uniquement:

    \[H_k = \left(\begin{array}{cc} 1 & 0 & 0 & 0 \ 0 & 0 & 1 & 0 \end{array}\right)\]

cela donne:

from scipy.stats import multivariate_normal

# Etat initial
state_actual = np.zeros((len(t), 4))
state_actual[0] = (0, 0, 0.1, 0)

state_mean = np.zeros((len(t), 4))
state_mean[0] = (0, 0, 0.1, 0)

state_cov = np.zeros((len(t), 4, 4))
state_cov[0] = Q * 5 ** 2

# Transformation leading to the observation
H = np.array([
[1, 0, 0, 0],
[0, 0, 1, 0]
])

# Observation noise
R = (0.01 ** 2, 0.1 ** 2) * np.identity(2)

observation_times = [40, 60]
observation_results = {}

# Evolution dans le temps
np.random.seed(0)
for i in range(1, len(t)):
state_actual[i] = multivariate_normal(F @ state_actual[i - 1] + G @ acceleration[i], Q).rvs()
state_mean[i] = F @ state_mean[i - 1] + G @ acceleration[i]
state_cov[i] = F @ state_cov[i - 1] @ F.T + Q

if i in observation_times:
# Observation process
observation_results[i] = obs_i = multivariate_normal(H @ state_actual[i], R).rvs()

# update the estimates
z_i = H @ state_mean[i]
cov_state_obs = state_cov[i] @ H.T
cov_obs_obs = H @ state_cov[i] @ H.T + R

state_mean[i] += cov_state_obs @ np.linalg.solve(cov_obs_obs, obs_i - z_i)
state_cov[i] -= cov_state_obs @ np.linalg.solve(cov_obs_obs, cov_state_obs.T)

class AnimLinearObs(AnimResult):
def plot_observations(self):
ymin, ymax = plt.ylim()
dx = 3 * np.sqrt(R.flatten())[0]
self.observation_lines = {}
self.observation_fill = {}

for i, obs_i in self.observations.items():
xi = obs_i[0]
self.observation_lines[i] = plt.vlines(xi, ymin, ymax, color="tab:green", linestyle="--", alpha=0.1)
self.observation_fill[i] = plt.fill_between([xi - dx, xi + dx], [ymin, ymin], [ymax, ymax], color="lightgreen", alpha=0.1)
plt.ylim(ymin, ymax)

def update_observations(self, i):
for iobs, line in self.observation_lines.items():
line.set_alpha(0.8 if i == iobs else 0.1)
self.observation_fill[iobs].set_alpha(0.8 if i == iobs else 0.1)

plt.ioff()
plt.figure()
plt.gca().set_aspect("equal")
AnimLinearObs(state_actual, acceleration, state_mean, state_cov, observation_results).animate()

 

 

On peut voir la contraction de l’incertitude selon x liée à l’observation.

Extended Kalman Filters

Si les lois d’évolution et d’observation ne sont plus linéaires, il est tout de même possible d’appliquer le filtre de Kalman en le linéarisant localement:

    \[\boldsymbol x_{k + 1} = \boldsymbol f(\boldsymbol x_k, \boldsymbol u_k) + \boldsymbol w_k\]

    \[\boldsymbol z_k = \boldsymbol h(\boldsymbol x_k) + \boldsymbol v_k\]

Il suffit alors de remplacer les formules de mise à jour des covariances en utilisant la jacobienne des fonctions \boldsymbol f(.) et \boldsymbol h(.):

    \[F = \operatorname{J}(\boldsymbol f) = \left( \begin{array}{cc} \frac{\partial f_{1}}{\partial x_{1}} & \dots & \frac{\partial f_{1}}{\partial x_{D}} \ \vdots & \ddots & \vdots \ \frac{\partial f_{d}}{\partial x_{1}} & \dots & \frac{\partial f_{1}}{\partial x_{D}} \ \end{array} \right)\]

    \[H = \operatorname{J}(\boldsymbol h)\]

Ici, on simule une observation, où l’on peut mesurer la distance et l’angle d’observation depuis l’origine du repère:

    \[\left( \begin{array}{c} r \ \theta \end{array} <h1>\right)</h1> \left( \begin{array}{c} \sqrt{x^2 + y^2} \ \arctan(\frac{y}{x}) \end{array} \right)\]

La loi de mouvement reste inchangée, donc la jacobienne est identique à la matrice F donnée plus tôt:

import jax
import jax.numpy as jnp

def movement(state, control):
return F @ state + G @ control

def observation(state):
x, y = state[:2]
r = jnp.sqrt(x ** 2 + y ** 2)
angle = jnp.arctan2(y, x)
return jnp.array([r, angle * 180 / np.pi])

R = (np.identity(2) * (0.025, 0.5)) ** 2

# Etat initial
state_actual = np.zeros((len(t), 4))
state_actual[0] = (0, 0, 0.1, 0)

state_mean = np.zeros((len(t), 4))
state_mean[0] = (0, 0, 0.1, 0)

state_cov = np.zeros((len(t), 4, 4))
state_cov[0] = Q * 5 ** 2

observation_results = {}

# Evolution dans le temps
np.random.seed(0)
for i in range(1, len(t)):
state_actual[i] = multivariate_normal(movement(state_actual[i - 1], acceleration[i]), Q).rvs()
state_mean[i] = movement(state_mean[i - 1], acceleration[i])
F_i = jax.jacobian(movement)(state_mean[i - 1], acceleration[i])

state_cov[i] = F_i @ state_cov[i - 1] @ F_i.T + Q

if i in observation_times:
# Observation process
observation_results[i] = obs_i = multivariate_normal(observation(state_actual[i]), R).rvs()

# update the estimates
z_i = observation(state_mean[i])
H_i = jax.jacobian(observation)(state_mean[i])
cov_state_obs = state_cov[i] @ H_i.T
cov_obs_obs = H_i @ state_cov[i] @ H_i.T + R

state_mean[i] += cov_state_obs @ np.linalg.solve(cov_obs_obs, obs_i - z_i)
state_cov[i] -= cov_state_obs @ np.linalg.solve(cov_obs_obs, cov_state_obs.T)

def draw_polar_section(r, angle, dr, dangle, circle_grid=10):
x0 = r * np.cos(angle / 180. * np.pi)
y0 = r * np.sin(angle / 180. * np.pi)

rs = np.array([ r - dr, r + dr ] + [r + dr ] * circle_grid + [r - dr] + [r - dr] * circle_grid)
angles = np.array(
[angle - dangle, angle - dangle] +
[(angle - dangle) + (i + 1) / circle_grid * 2 * dangle for i in range(circle_grid)] +
[angle + dangle ] +
[(angle + dangle) - (i + 1) / circle_grid * 2 * dangle for i in range(circle_grid)]
)

polygon_xs = rs * np.cos(angles / 180. * np.pi)
polygon_ys = rs * np.sin(angles / 180. * np.pi)

return plt.scatter([x0], [y0], c="tab:green", alpha=0.1), plt.fill(polygon_xs, polygon_ys, alpha=0.1, color="lightgreen")

class AnimNonLinearObs(AnimResult):
def plot_observations(self):
dr, dangle = 3 * np.sqrt(R.diagonal())

self.observation_patches = {
i: draw_polar_section(*obs_i, dr, dangle) for i, obs_i in self.observations.items()
}

def update_observations(self, i):
for iobs, (obs_center, obs_poly) in self.observation_patches.items():
alpha = 0.8 if i == iobs else 0.1
obs_center.set_alpha(alpha)
for p in obs_poly: p.set_alpha(alpha)

plt.ioff()
plt.figure()
plt.gca().set_aspect("equal")
AnimNonLinearObs(state_actual, acceleration, state_mean, state_cov, observation_results).animate()

 

 

Filtres de Kalman sans parfum (Unscented Kalman Filter)

La transformation sans parfum

L’idée de cette transformation et d’estimer l’effet de transformations non-linéaires en utilisant des échantillons bien choisis appelés « points sigma ».

On fait passer ces points à travers les transformations d’évolution temporelle et d’observation et on estime ensuite, à partir de ces points, les paramètres de la distribution résultante.

L’idée est de construire un ensemble de paires de points qui pointent dans les directions principales de la distribution Gaussienne. Si on décompose la covariance en :

    \[\Sigma = LL^T\]

Alors, on construit les points sigma comme suit :

    \[\begin{array}{rcll} \boldsymbol{\mathcal X_0} & = & \boldsymbol \mu \ \boldsymbol{\mathcal X_i }& = & \boldsymbol \mu + \sqrt{(D + \lambda)L_i} & \ i = 1, \dots, L \ \boldsymbol{\mathcal X_i} & = & \boldsymbol \mu - \sqrt{(D + \lambda)L_{i - L}} & \ i = L+1, \dots, 2L \end{array}\]

à chaque point est associé un poids:

    \[\begin{array}{rcll} w_0 & = & \frac{\lambda}{D + \lambda} \ w_i & = & \frac{1}{2(D + \lambda)} \end{array}\]

\lambda est un paramètre d’échelle.

%matplotlib inline
import numpy as np
from scipy.linalg import eigh
from math import gcd

def sigma_points(mu, sigma, lambda_):
n_dims = len(mu)

w, u = eigh(sigma)
w = np.maximum(w, 0)
L = (u * np.sqrt(w)).T

X = np.vstack(
[ mu ] +
[ mu + np.sqrt(n_dims + lambda_) * L[i] for i in range(n_dims) ] +
[ mu - np.sqrt(n_dims + lambda_) * L[i] for i in range(n_dims) ]
)

w = np.hstack([lambda_ / (n_dims + lambda_)] + [0.5 / (n_dims + lambda_)] * (2 * n_dims))

return X, w

C = np.array([[1.0, 0.8], [0.8, 1]])
mu = np.array([1, 2])

X_sigma, w_sigma = sigma_points(mu, C, lambda_=1)

plt.ion()
plt.figure()
plot_gaussian(mu, C);
plt.scatter(*X_sigma.T, s=10);

png

Application to the Kalman Filter

On passe ces points à travers la transformation d’évolution temporelle et à travers la fonction d’observation et on estime ensuite les différentes quantité d’intérêt en intégrant les poids:

    \[\boldsymbol{\mathcal X}<em>{k, i} = f(\boldsymbol{\mathcal X}</em>{k - 1, i}, \boldsymbol u_k)\]

    \[\boldsymbol{\mathcal Z}<em>{k, i} = h(\boldsymbol{\mathcal X}</em>{k, i})\]

    \[\hat{\boldsymbol x}<em>{k|k-1} = \sum</em>{i=0}^{2L} w_i \boldsymbol{\mathcal X}_{k, i}\]

    \[P^{xx}<em>k = \sum</em>{i=0}^{2L} w_i (\boldsymbol{\mathcal X}<em>{k, i} - \hat{\boldsymbol x}_k)(\boldsymbol{\mathcal X}</em>{k, i} - \hat{\boldsymbol x}_k)^T\]

    \[\hat{\boldsymbol z}<em>k = \sum</em>{i=0}^{2L} w_i \boldsymbol{\mathcal Z}_{k, i}\]

    \[P^{zz}<em>k = \sum</em>{i=0}^{2L} w_i (\boldsymbol{\mathcal Z}<em>{k, i} - \hat{\boldsymbol z}_k)(\boldsymbol{\mathcal Z}</em>{k, i} - \hat{\boldsymbol z}_k)^T\]

    \[P^{xz}<em>k = \sum</em>{i=0}^{2L} w_i (\boldsymbol{\mathcal X}<em>{k, i} - \hat{\boldsymbol x}_k)(\boldsymbol{\mathcal Z}</em>{k, i} - \hat{\boldsymbol z}_k)^T\]

    \[\hat{\boldsymbol x}<em>{k|k} = \hat{\boldsymbol x}</em>{k|k-1} + P^{xz}_k{P^{zz}_k}^{-1}(\boldsymbol o_k - \hat{\boldsymbol z}_k)\]

    \[P^{x|z}_k = P^{xx}_k - P^{xz}_k{P^{zz}_k}^{-1}{P^{xz}_k}^T\]

# Apply on sigma points matrix instead of single vector
def movement(state, control):
return state @ F.T + G @ control

def observation(state):
x, y = state.T[:2]
r = np.sqrt(x ** 2 + y ** 2)
angle = np.arctan2(y, x)
return np.vstack([r, angle * 180 / np.pi]).T

# Etat initial
state_actual = np.zeros((len(t), 4))
state_actual[0] = (0, 0, 0.1, 0)

state_mean = np.zeros((len(t), 4))
state_mean[0] = (0, 0, 0.1, 0)

state_cov = np.zeros((len(t), 4, 4))
state_cov[0] = Q * 5 ** 2

observation_results = {}
lambda_ = 1e-1

# Evolution dans le temps
np.random.seed(0)
for i in range(1, len(t)):

state_actual[i] = multivariate_normal(movement(state_actual[[i - 1]], acceleration[i])[0], Q).rvs()

state_sigma, weight_sigma = sigma_points(state_mean[i - 1], state_cov[i - 1], lambda_)
state_sigma_tr = movement(state_sigma, acceleration[i])

state_mean[i] = np.einsum("ij, i -> j", state_sigma_tr, weight_sigma)
state_diff = state_sigma_tr - state_mean[i]
state_cov[i] = np.einsum("ij, ik, i -> jk", state_diff, state_diff, weight_sigma)

if i in observation_times:
# Observation process
observation_results[i] = obs_i = multivariate_normal(observation(state_actual[[i]])[0], R).rvs()

# update the estimates

z_sigma = observation(state_sigma_tr)
z_i = np.einsum("ij, i -> j", z_sigma, weight_sigma)

z_diff = z_sigma - z_i

cov_state_obs = np.einsum("ij, ik, i -> jk", state_diff, z_diff, weight_sigma)
cov_obs_obs = np.einsum("ij, ik, i -> jk", z_diff, z_diff, weight_sigma)

state_mean[i] += cov_state_obs @ np.linalg.solve(cov_obs_obs, obs_i - z_i)
state_cov[i] -= cov_state_obs @ np.linalg.solve(cov_obs_obs, cov_state_obs.T)

plt.ioff()
plt.figure()
plt.gca().set_aspect("equal")
AnimNonLinearObs(state_actual, acceleration, state_mean, state_cov, observation_results).animate()

 

Medi’Nov : 3 & 4 Avril 2024 au Centre de Congrès de Lyon

Le rendez-vous incontournable des medtech au cœur de l'écosystème santé !

La 12ème édition de Médi’Nov Connection aura lieu les 3 et 4 avril 2024 au sein du Centre de Congrès de Lyon, situé en plein cœur de la Cité Internationale.💡

▶️ Rencontrons-nous :

  • Centre de Congrès de Lyon
  • 3 et 4 avril 2024

Evaluation of the Impact of Mask Changes in Residual Apnea-Hypopnea Index Telemonitoring Data

Marie-Caroline Schaeffer, Data Scientist senior et chef de projets santé

Jeudi 4 avril

15h05 – 15h20

udd@orano

Le groupe Orano et ses partenaires lancent un projet de développement intitulé #udd@Orano (pour Usines De Demain sur les sites industriels d’Orano) en vue d’accélérer le déploiement de l’usine du futur au cœur des sites industriels du groupe.

Projet MONSOON

Projet visant à mettre en œuvre des techniques d’IA dans l’industrie de procédé – ici, l’aluminium (RIO TINTO – LIBERTY) et le plastique (GLNPlast, Portugal).

Projet ERAMET

Le groupe ERAMET est l’un des principaux producteurs mondiaux de métaux d’alliage. ERAMET produit dans son usine de Kvinesdal, en Norvège, des alliages de silicomanganèse.

PROJET DE QUALITÉ DE PRODUCTION

Projet visant à améliorer la fabrication de dispositifs médicaux

EasymAInt, solution de maintenance prédictive

À partir de capteurs plug&play, non intrusifs, EasymAInt permet de maitriser ses données, suivre ses équipements et réaliser de la maintenance prédictive

Chaine logistique

PROJET D'OPTIMISATION DE CHAÎNE LOGISTIQUE

Création d’un outil permettant de modifier les données d’entre et d’obtenir très rapidement, la résolution et la visualisation des résultats

Découvrez nos webinaires :

Améliorez votre performance industrielle grâce à l'Intelligence Artificielle

Le numérique est l’un des domaines clé de la performance industrielle. C’est donc un levier d’investissement primordial vers la vague « Industrie du Futur » ou « Industrie 4.0 ».

L'IA dans la boucle : Optimisez un procédé industriel

Retour d’expérience de Lynred sur le projet d’aide à la décision dans un procédé industriel, grâce à l’Intelligence Artificielle.

Retrouvez quelques photo. d'IA Paris & Big Data 2021 !

Probayes est très honoré d'avoir présenté à Mme Sophie Cluzelsecrétaire d'État aux personnes handicapées, Eye Tracking, solution d'interaction avec un système informatique, grâce au suivi oculaire !  

IMG_1353

▶️  Idéal pour utiliser sans contact, un écran et surtout une interface publique

▶️  Indispensable pour les personnes à mobilité réduite (alitées ou paralysées)

▶️  S’adapte à différents besoins sur les secteurs de la santé, de la finance, du loisir, etc.

En tant que filiale Le Groupe La Poste et tiers de confiance, Probayes
s’attache à développer des solutions respectant la souveraineté des
données

Equipe Probayes
Vos solutions d'IA

CCI Nord Isère, le 02/04 à Villefontaine

Comment appréhender le sujet de l'IA, Intelligence Artificielle en entreprise?

Profitez d’une journée originale avec les principaux acteurs en Région, pour vous projeter :

Rejoignez-nous le mardi 2 avril dès 13h30, pour une journée immersive dédiée, à la CCI Nord Isère, à Villefontaine, où vous découvrirez toutes les réponses à vos questions ! 💡

▶️ Rencontrons-nous :

  • à Villefontaine
  • Mardi 2 avril 2024
  • Dès 13h30

Industrialisation des solutions d'IA

Alexis Mignon – Directeur Scientifique – Probayes

Mardi 2 avril

14h45

udd@orano

Le groupe Orano et ses partenaires lancent un projet de développement intitulé #udd@Orano (pour Usines De Demain sur les sites industriels d’Orano) en vue d’accélérer le déploiement de l’usine du futur au cœur des sites industriels du groupe.

Projet MONSOON

Projet visant à mettre en œuvre des techniques d’IA dans l’industrie de procédé – ici, l’aluminium (RIO TINTO – LIBERTY) et le plastique (GLNPlast, Portugal).

Projet ERAMET

Le groupe ERAMET est l’un des principaux producteurs mondiaux de métaux d’alliage. ERAMET produit dans son usine de Kvinesdal, en Norvège, des alliages de silicomanganèse.

PROJET DE QUALITÉ DE PRODUCTION

Projet visant à améliorer la fabrication de dispositifs médicaux

EasymAInt, solution de maintenance prédictive

À partir de capteurs plug&play, non intrusifs, EasymAInt permet de maitriser ses données, suivre ses équipements et réaliser de la maintenance prédictive

Chaine logistique

PROJET D'OPTIMISATION DE CHAÎNE LOGISTIQUE

Création d’un outil permettant de modifier les données d’entre et d’obtenir très rapidement, la résolution et la visualisation des résultats

Découvrez nos webinaires :

Améliorez votre performance industrielle grâce à l'Intelligence Artificielle

Le numérique est l’un des domaines clé de la performance industrielle. C’est donc un levier d’investissement primordial vers la vague « Industrie du Futur » ou « Industrie 4.0 ».

L'IA dans la boucle : Optimisez un procédé industriel

Retour d’expérience de Lynred sur le projet d’aide à la décision dans un procédé industriel, grâce à l’Intelligence Artificielle.

Retrouvez quelques photo. d'IA Paris & Big Data 2021 !

Probayes est très honoré d'avoir présenté à Mme Sophie Cluzelsecrétaire d'État aux personnes handicapées, Eye Tracking, solution d'interaction avec un système informatique, grâce au suivi oculaire !  

IMG_1353

▶️  Idéal pour utiliser sans contact, un écran et surtout une interface publique

▶️  Indispensable pour les personnes à mobilité réduite (alitées ou paralysées)

▶️  S’adapte à différents besoins sur les secteurs de la santé, de la finance, du loisir, etc.

En tant que filiale Le Groupe La Poste et tiers de confiance, Probayes
s’attache à développer des solutions respectant la souveraineté des
données

Equipe Probayes
Vos solutions d'IA

Global Industrie du 25 au 28 mars 2024 à Paris Nord Villepinte

L'intelligence Artificielle au service de l'industrie du futur !

Le numérique et tout particulièrement l’Intelligence Artificielle permettent de créer des ruptures technologiques et d’usage.

Il s’agit là de leviers d’investissement primordiaux pour la performance industrielle et l’avancée vers la vague « Industrie du Futur » ou « Industrie 4.0 ».

Probayes accompagne ainsi de nombreux clients industriels dans leur transformation en développant des outils basés sur l’Intelligence Artificielle pour :

  • Améliorer la qualité des produits, par exemple par l’identification et l’analyse des facteurs influençant la non-qualité
  • Améliorer la performance industrielle, par exemple par la détection et l’anticipation des dérives du procédé
  • Optimiser le procédé, par exemple par la recommandation des meilleurs paramètres à appliquer durant le fonctionnement des équipements
  • Optimiser les ressources, par exemple le personnel, les machines et outils et les matières premières
  • Réaliser de la maintenance prédictive en anticipant les pannes éventuelles

Retrouvez-nous
Hall 5A - Stand 5W161

▶️ Rencontrons-nous :

  • Hall 5A – Village Smart – Stand 5W161 
  • du 25 au 28 mars 2024
  • Paris Nord Villepinte

Contrôle qualité automatisé par vision & amélioration du procédé de production

Benoît Hardier – Data Scientist et Chef de Projet – Probayes

Benoît est un ingénieur en mathématiques appliquées et data scientist chez Probayes depuis 2020. Son expertise se concentre sur l’application du deep learning dans des domaines tels que la vision par ordinateur (computer vision) et le traitement du langage naturel (NLP).

Mardi 26 mars

16h15 – 16h45

Conférence

Dans le cadre de sa collaboration avec la société ITEN, spécialisée dans l’élaboration et la fabrication de micro batteries, Probayes a développé un projet visant à automatiser le contrôle qualité des plaques d’électrodes, ainsi qu’à améliorer la compréhension de la chaîne des procédés de production.

Le projet a consisté à élaborer des méthodes hybrides de vision par ordinateur, combinant des techniques d’apprentissage profond avec des algorithmes classiques, afin de détecter avec précision les défauts sur les plaques d’électrodes. En utilisant des données d’images fournies par des caméras haute-résolution, l’équipe de Probayes, a entraîné des modèles de deep learning pour reconnaître et localiser différents types de défauts aux formes et aux origines variées.

Prédiction des caractéristiques de l'huile chez Total Energies

Alexis Mignon – Directeur Scientifique – Probayes

Alexis est docteur en informatique spécialisé en Vision par Ordinateur et Apprentissage Automatique. Il travaille depuis 2013 chez Probayes en tant qu’ingénieur R&D et chef de projets sur des sujets d’Apprentissage Automatique.

Alexis est aujourd’hui Directeur Scientifique expert en Machine Learning.

Mercredi 27 mars 

10h00 – 10h30

Conférence

TotalEnergies développe des services de monitoring prédictif pour ses clients. L’objectif est de connaître, en temps réel, la santé de leurs équipements : moteur de cogénération ou de bateaux, machines industrielles, éoliennes, etc.

A partir des données des huiles, issues des capteurs, on va déduire la santé des machines, en estimant l’état de vieillissement de ces huiles, et en détectant la présence de contaminants par exemple. Un apprentissage multi-niveaux mené par Probayes permet de convertir les données brutes fournies par les capteurs en des informations interprétables afin d’en déduire des actions de maintenance prédictive.

Et voici l'ensemble des conférences de nos partenaires

Mardi 26 Mars

🔹10:00 vrtice « Retex : 3 ans d’utilisation de Spherik chez EDF
Hydro pour préparer les interventions sur site »

🔹10:45 Optimistik « Donnée industrielle : démocratiser son utilisation
dans toute l’organisation, plutôt que de la limiter aux experts data »

🔹11:30 GROUPE SPC « Explorez les stratégies de valorisation de vos
données pour renforcer la résilience énergétique »

🔹14:00 Courbon Software « Digitalisation de l’industrie : adaptez la
solution à votre environnement et gagnez en agilité »

🔹14:45 QUATERNAIRE « Managez la performance de vos usines : engagez vos
collaborateurs en digitalisant vos rituels AIC »

🔹15:30 INEVO « Jumeau Numérique Process : comment & pourquoi ? »

🔹16:15 Probayes, « Contrôle qualité automatisé par vision & Amélioration du procédé de production »

Mercredi 27 Mars

🔹10:00 Probayes
Prédiction des caractéristiques de l’huile chez Total Energies

🔹10:45 Courbon Software
Digitalisation de l’industrie : adaptez la solution à votre environnement et gagnez en agilité

🔹11:30 QUATERNAIRE
Structurez et alignez la digitalisation des opérations aux enjeux de votre entreprise : diagnostic, schéma directeur et mise-en-œuvre

🔹14:00 INEVO
Jumeau Numérique Process : Comment & pourquoi ?

🔹14:45 GROUPE SPC
Exploitez la puissance de vos données industrielles pour gagner en efficacité et en productivité

🔹15:30 Optimistik
Maîtrisez vos procédés industriels par la data : améliorez vos KPI qualité, énergie et matières sur le terrain

🔹16:15 vrtice
Retex : 3 ans d’utilisation de Spherik chez EDF Hydro pour préparer les interventions sur site

udd@orano

Le groupe Orano et ses partenaires lancent un projet de développement intitulé #udd@Orano (pour Usines De Demain sur les sites industriels d’Orano) en vue d’accélérer le déploiement de l’usine du futur au cœur des sites industriels du groupe.

Projet MONSOON

Projet visant à mettre en œuvre des techniques d’IA dans l’industrie de procédé – ici, l’aluminium (RIO TINTO – LIBERTY) et le plastique (GLNPlast, Portugal).

Projet ERAMET

Le groupe ERAMET est l’un des principaux producteurs mondiaux de métaux d’alliage. ERAMET produit dans son usine de Kvinesdal, en Norvège, des alliages de silicomanganèse.

PROJET DE QUALITÉ DE PRODUCTION

Projet visant à améliorer la fabrication de dispositifs médicaux

EasymAInt, solution de maintenance prédictive

À partir de capteurs plug&play, non intrusifs, EasymAInt permet de maitriser ses données, suivre ses équipements et réaliser de la maintenance prédictive

Chaine logistique

PROJET D'OPTIMISATION DE CHAÎNE LOGISTIQUE

Création d’un outil permettant de modifier les données d’entre et d’obtenir très rapidement, la résolution et la visualisation des résultats

Découvrez nos webinaires :

Améliorez votre performance industrielle grâce à l'Intelligence Artificielle

Le numérique est l’un des domaines clé de la performance industrielle. C’est donc un levier d’investissement primordial vers la vague « Industrie du Futur » ou « Industrie 4.0 ».

L'IA dans la boucle : Optimisez un procédé industriel

Retour d’expérience de Lynred sur le projet d’aide à la décision dans un procédé industriel, grâce à l’Intelligence Artificielle.

Retrouvez quelques photo. d'IA Paris & Big Data 2021 !

Probayes est très honoré d'avoir présenté à Mme Sophie Cluzelsecrétaire d'État aux personnes handicapées, Eye Tracking, solution d'interaction avec un système informatique, grâce au suivi oculaire !  

IMG_1353

▶️  Idéal pour utiliser sans contact, un écran et surtout une interface publique

▶️  Indispensable pour les personnes à mobilité réduite (alitées ou paralysées)

▶️  S’adapte à différents besoins sur les secteurs de la santé, de la finance, du loisir, etc.

En tant que filiale Le Groupe La Poste et tiers de confiance, Probayes
s’attache à développer des solutions respectant la souveraineté des
données

Equipe Probayes
Vos solutions d'IA