« Réunion du 09-07-2024 » : différence entre les versions

De OSWiki
Aller à la navigation Aller à la recherche
Ligne 29 : Ligne 29 :
= Bugs =
= Bugs =
= Tests =
= Tests =
= Projets en cours / Infos=
= Divers=
==Réflexions sur la vitesse des NPC ==
==Réflexions sur la vitesse des NPC ==
=== Le problème ===
=== Le problème ===
Ligne 48 : Ligne 48 :
* '''Ajuster la vitesse''' de déplacement des NPC, y compris l'injection de vitesse.
* '''Ajuster la vitesse''' de déplacement des NPC, y compris l'injection de vitesse.
* '''Tests supplémentaires''' : réseau, moteur physique.
* '''Tests supplémentaires''' : réseau, moteur physique.
== Problème de précision des grandes régions==
* [[Réunion_du_30-04-2024#Problème_de_précision_des_grandes_régions | On en avait parlé à la réunion du 30-04-2024 ]]


= Viewers=
= Viewers=
= Source=
= Source=
http://opensimulator.org/wiki/Chat_log_from_the_meeting_on_2024-07-09
http://opensimulator.org/wiki/Chat_log_from_the_meeting_on_2024-07-09

Version du 12 juillet 2024 à 11:34

Changements du code de la semaine

Permissions

  • Commit c8b135: Correction de la vérification de l'autorisation de modifier un objet partagé dans un groupe .

Ajout de llGetNotecardLineSync

string llGetNotecardLineSync( string nom, integer ligne );

Cette fonction renvoie la chaîne de caractères contenant le texte de la ligne <ligne> demandée dans une notecard <nom>. Elle récupère <ligne> de la notecard dans le cache des notecards de la région immédiatement sans déclencher d'événement de type "dataserver".

Limitation des mises à jours des agents

  • Commit b06ecf : Maintenant, les agents envoient des demandes de non-actualisation aux viewers pour en ignorer certaines.
  • Le code de gestion des périphériques (souris et clavier) du viewer semble être inefficace. Cela peut entraîner des problèmes de réactivité ou de fluidité dans l'interaction avec le monde virtuel. Pour pallier à ces problèmes, augmenter les mises à jour des agents peut être une solution pour améliorer la synchronisation et la réponse aux actions des utilisateurs, même si cela peut entraîner d'autres défis en termes de charge de traitement et de bande passante.
  • Les viewers peuvent envoyer davantage de demandes de mises à jour lorsque le GPU est capable de traiter un plus grand nombre d'images par seconde et qu'il a un taux de rafraîchissement élevé. S'il fait 400fps (frame par seconde), il envoie environ 300 mises à jour par seconde. Cela peut entraîner des pertes de paquets de données. En réponse à cela, Linden Lab a réduit le nombre de mises à jour à 10 par seconde, ce qui a affecté négativement l'expérience des utilisateurs en termes de fluidité, entraînant des plaintes. Les scripts de véhicules de Second Life demande 45 mises à jour par seconde. Actuellement, les serveurs de Second Life ignorent tous les événements plus rapides que 45 mises à jour par seconde.
  • Firestorm permet 125 mises à jour par seconde. Peut-être pour les combats ? Ubit Umarov a ajouté du code pour ignorer ce qui va au delà de 45 mises à jour par secondes . OpenSim n'envoie que 10 mises à jour de mouvement par seconde avec les réglages par défaut ce qui est correct pour une région sociale.
  • 125 mises à jour c'est une mise à jour toutes les 8ms, qui doit être traitée et transformée en données pour la frame suivante, ce pour quoi on ne dispose que de 16ms de manière réaliste. De plus avec le viewer Firestorm PBR actuel la plupart des utilisateurs n'ont même pas 25 fps.
  • Informations complémentaires en anglais : [1][2]

Avertissement

Attention : Ce résumé existe pour orienter vos recherches. Des erreurs d'interprétation ne sont pas à exclure. Pour plus de précisions, veuillez vous référer aux sources ou vous adresser directement aux développeurs d'OpenSimulator en assistant aux réunions du mardi ou sur le canal IRC. Je ne fais pas partie des développeurs, ne vous adressez pas à moi pour les joindre. Merci.😉


Noyau

Scripts

Base de données

Modules

Génération niveaux de zoom de maptile en parallèle

Serveur d'argent NSL/DTL avec le support de BTCPay

Bugs

Tests

Divers

Réflexions sur la vitesse des NPC

Le problème

  • Vincent.Sylvester a remarqué que les NPC semblent se déplacer plus lentement que les avatars normaux ce qui est ennuyeux quand on essaie de les suivre. Leur mouvements sont contrôlés par du code. Il a fait des tests asynchrones pour isoler le NPC des autres éléments du simulateur et des tests simfps (simulated frames per second) pour évaluer les performances du simulateur. Cela n'a rien donné.
  • Les NPC et les avatars utilisent le même code de déplacement "moveto".
NDLR  : Je n'ai pas vraiment compris si les NPC et les avatars utilisaient vraiment le même mode de déplacement. Ubit Umarov ajoute plus loin : "Je ne suis pas sûr qu'il y ait une comparaison, puisque la mécanique de mouvement est différente."


Causes envisagées

  • Est-ce que les animations de marche sont identiques ? : ce sont des animations côté viewer, les animations ne devraient pas avoir d'incidence.
  • Le NPC porte t-il un AO[3] (animations overriders) scripté  ? Les AO et les scripts côté serveur peuvent avoir un impact sur les animations mais pas sur la vitesse.
  • Le réseau : il faudrait faire des tests locaux et des tests avec des machines plus éloignées.
  • Est-ce que les NPC sont trop lents ou les avatars trop rapides ?
  • Cela peut aussi dépendre du moteur physique : à tester.

Solutions envisagées

  • Ajuster la vitesse de déplacement des NPC, y compris l'injection de vitesse.
  • Tests supplémentaires : réseau, moteur physique.

Problème de précision des grandes régions

Viewers

Source

http://opensimulator.org/wiki/Chat_log_from_the_meeting_on_2024-07-09