Aller au contenu

Utilisateur:MathieuLVQ/Modélisation des Réseaux (M1, 2018)/Activité F

Une page de Wikiversité, la communauté pédagogique libre.

pour chacun des autres participants q, calculer la similarité s(p, q):

  • la similarité s(p, q) est le nombre de voisins communs entre p et q - c'est-à-dire, le nombre de voisins de p qui sont aussi voisins de q.

Je commence par créer un tableau pour les participants et nombre de voisins en commun avec moi.

Puis, je suis l'astuce de rechercher dans le document du réseau du week-end les activités dont je suis voisin. Comme ça, je vois tout de suite qui sont les voisins communs d'une activité. Il suffit alors d'ajouter 1 à la similarité de ces voisins, et continuer la recherche pour trouver la prochaine activité lié à moi.

Pour finir, les participants n'apparaissant jamais dans ces recherches n'ont pas de voisins en commun avec moi. Ses similarités sont alors 0, et j'ai pas besoin de les lister dans mon tableau.

Voisins en commun avec MathieuLVQ
Nom du participant Voisins en commun
Tom Flamand 1 + 1
Chapch14 1
Florentine_Cuenot 1
Juliamthrn 1 + 1
Mehdijibril 1
Pmrslt 1 + 1
Solstag 1
T.SerSo 1
Tanguyngo 1
Marguerite Parmentier 1
Arnaud_ldl 1
FionaArn 1
Alice.gabay 1

Je vois à partir du tableau que j'ai la plus haute similarité avec Pmrslt, Tom Flamand et Juliamthrn. J'étudierai, après tirage au sort, la chouette personne qu'est Pmrslt.

pour chaque activité a, calculer le score r(p, a):

  • pour expédier le travail, on va considérer uniquement les activités liées aux deux participants à plus haute similarité de p, tirant au sort en cas d'égalité.
  • le score r(p, a) est la somme, pour chacun des voisins q de a, de la similarité s(p, q) qu'on vient de calculer.
  • on ne veut pas recommander des activités déjà faites, donc pas besoin de calculer le score pour les activités déjà liées au participant p.

Je vois dans le tableau précédent que, pou moi, les participants à plus haute similarité sont 'Tom Flamand' et 'Florentine_Cuenot'. Je tire au sort entre eux et reste avec la deuxième option.

Alors je crée un deuxième tableau avec les activités de 'Florentine_Cuenot', qui je trouve déjà regroupés dans le document du réseau du week-end en cherchant pour les URIs des deux participants.

Je crée deux colonnes, une pour le score et une pour lister les voisins, ce qui va faciliter le calcul. Je copie et colle les voisins de chaque activité comme trouvés dans le document du réseau du week-end.

Je mets -1 pour le score des activités dont je suis déjà voisin.

Je calcule le score pour les autres activités, en sommant la similarité des voisins listés dans la dernière colonne. J'ouvre une nouvelle fenêtre pour consulter plus facilement le tableau similarités.

Calcul du score
Activité Voisins de l'activité Somme Score
<https://www.wikidata.org/wiki/Q464980> <https://fr.wikiversity.org/wiki/Utilisateur:Agathe Ch.>

<https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt>

0 + 2 2
<https://www.wikidata.org/wiki/Q17297777> <https://fr.wikiversity.org/wiki/Utilisateur:Alice.gabay>

<https://fr.wikiversity.org/wiki/Utilisateur:Chapch14>

<https://fr.wikiversity.org/wiki/Utilisateur:Florentine_Cuenot>

<https://fr.wikiversity.org/wiki/Utilisateur:Juliamthrn>

<https://fr.wikiversity.org/wiki/Utilisateur:Marguerite Parmentier>

<https://fr.wikiversity.org/wiki/Utilisateur:MathieuLVQ>

<https://fr.wikiversity.org/wiki/Utilisateur:Mehdijibril>

<https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt>

<https://fr.wikiversity.org/wiki/Utilisateur:Solstag>

<https://fr.wikiversity.org/wiki/Utilisateur:T.SerSo>

<https://fr.wikiversity.org/wiki/Utilisateur:Tanguyngo>

<https://fr.wikiversity.org/wiki/Utilisateur:Tom Flamand>

<https://fr.wikiversity.org/wiki/Utilisateur:Utilisateur:FionaArn>

Déjà voisin -1
<https://www.wikidata.org/wiki/Q44> <https://fr.wikiversity.org/wiki/Utilisateur:Arnaud_ldl>

<https://fr.wikiversity.org/wiki/Utilisateur:Juliamthrn>

<https://fr.wikiversity.org/wiki/Utilisateur:MathieuLVQ>

<https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt>

Déjà voisin -1
<https://www.wikidata.org/wiki/Q105674> <https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt> 2 2
<https://www.wikidata.org/wiki/Q11424> <https://fr.wikiversity.org/wiki/User:Leavigouroux>

<https://fr.wikiversity.org/wiki/Utilisateur:Alice.gabay>

<https://fr.wikiversity.org/wiki/Utilisateur:Juliamthrn>

<https://fr.wikiversity.org/wiki/Utilisateur:Juliettebenhadria>

<https://fr.wikiversity.org/wiki/Utilisateur:Levyemma>

<https://fr.wikiversity.org/wiki/Utilisateur:LénaWeiss>

<https://fr.wikiversity.org/wiki/Utilisateur:Marguerite Parmentier>

<https://fr.wikiversity.org/wiki/Utilisateur:Mehdijibril>

<https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt>

<https://fr.wikiversity.org/wiki/Utilisateur:T.SerSo>

<https://fr.wikiversity.org/wiki/Utilisateur:Tom Flamand>

0+1+2+0+1+1+2+1+2 7
<https://www.wikidata.org/wiki/Q182832> <https://fr.wikiversity.org/wiki/Utilisateur:Alexandre Husltin>

<https://fr.wikiversity.org/wiki/Utilisateur:Arnaud_ldl>

<https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt>

0+1+2 3
<https://www.wikidata.org/wiki/Q177> <https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt> 2 2
<https://www.wikidata.org/wiki/Q6663> <https://fr.wikiversity.org/wiki/Utilisateur:Alice.gabay>

<https://fr.wikiversity.org/wiki/Utilisateur:Florentine_Cuenot>

<https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt>

1+1+2 4
<https://www.wikidata.org/wiki/Q830036> <https://fr.wikiversity.org/wiki/Utilisateur:Alice.gabay>

<https://fr.wikiversity.org/wiki/Utilisateur:Auriane78>

<https://fr.wikiversity.org/wiki/Utilisateur:Florentine_Cuenot>

<https://fr.wikiversity.org/wiki/Utilisateur:Julie Roland-Billecart>

<https://fr.wikiversity.org/wiki/Utilisateur:Levyemma>

<https://fr.wikiversity.org/wiki/Utilisateur:Manel411195>

<https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt>

1+0+1+2 4
<https://www.wikidata.org/wiki/Q8486> <https://fr.wikiversity.org/wiki/Utilisateur:Juliamthrn>

<https://fr.wikiversity.org/wiki/Utilisateur:Pmrslt>

2+2 4

choisir l'activité à recommander:

  1. exclure les activités déjà liées au participant p.
  2. trouver les activités avec le plus haut score r(p, a).
    • si il n'y a qu'une seule activité avec le plus haut score:
      • recommander cette activité.
    • s'il y a plusieurs activités avec le plus haut score:
      • parmi ces activités à plus haut score, trouver celles avec le plus haut nombre de voisins.
        • si il n'y a qu'une seule activité trouvée:
          • recommander cette activité.
        • s'il y a plusieurs activités trouvées:
          • recommander une parmi elles, au hasard.

L'activité qui m'est proposé par le système de recommandation est alors https://www.wikidata.org/wiki/Q11424

car elle s'élève à 7 !