IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Java Discussion :

Calcul de haute performance


Sujet :

Java

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Doctorante
    Inscrit en
    Juillet 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Doctorante

    Informations forums :
    Inscription : Juillet 2011
    Messages : 10
    Points : 5
    Points
    5
    Par défaut Calcul de haute performance
    Bonjour,
    j'ai développé une application en java (eclipse) pour parser des fichiers XML (environs 400), les stocker dans une base de donnée objet (neodatis) et ensuite calculer la similarité entre ces fichiers. Mais lors de l’exécution mon pc est très vite à laboure.
    Certains me conseillent de passer au cloud computing( windows azure, Amazon EC2, Google app engine etc).
    Qu'en pensez vous? je réfléchis également au supercalculateur!!!
    Merci.

    Nass

  2. #2
    Membre éprouvé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2010
    Messages
    394
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Distribution

    Informations forums :
    Inscription : Avril 2010
    Messages : 394
    Points : 1 212
    Points
    1 212
    Par défaut
    Bonjour,

    La première chose à faire serait d'optimiser les algorithmes utilisés dans le programme. C'est-à-dire repérer les points clés de l'application (ceux qui sont susceptibles d'être chronophages), et s'assurer qu'il n'y a pas moyen "de le faire mieux".

    Sinon, passer au Cloud ou bien à des ordinateurs plus puissants ne serait que déplacer le problème, et non pas le résoudre.

    Mako.

  3. #3
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,

    Citation Envoyé par Mako 5013 Voir le message
    La première chose à faire serait d'optimiser les algorithmes utilisés dans le programme.
    +1000 !

    a++

  4. #4
    Futur Membre du Club
    Femme Profil pro
    Doctorante
    Inscrit en
    Juillet 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Doctorante

    Informations forums :
    Inscription : Juillet 2011
    Messages : 10
    Points : 5
    Points
    5
    Par défaut
    Bonjour, merci pour vos réponses..mais comment dois-je faire pour optimiser mes algorithmes?
    Merci

  5. #5
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Comme l'a dit Mako, il faut analyser les différentes parties de ton programme afin de déterminer les parties sensibles qui demande beaucoup de temps...


    a++

  6. #6
    Futur Membre du Club
    Femme Profil pro
    Doctorante
    Inscrit en
    Juillet 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Doctorante

    Informations forums :
    Inscription : Juillet 2011
    Messages : 10
    Points : 5
    Points
    5
    Par défaut
    Les parties sensibles sont celles ou je calcule la similarité car ces fichiers sont structurés sous formes d'arbres avec parfois 50 chemins!!
    Que dois je faire?
    Merci bcp

  7. #7
    Membre éprouvé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2010
    Messages
    394
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Distribution

    Informations forums :
    Inscription : Avril 2010
    Messages : 394
    Points : 1 212
    Points
    1 212
    Par défaut
    Bonjour,

    Poster la partie de code correspondant à ces traitements (en simplifiant si cela est trop volumineux), afin que l'on puisse voir comment cela est traité, et s'il est possible d'optimiser le tout.

    Mako.

  8. #8
    Nouveau membre du Club
    Inscrit en
    Octobre 2006
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 28
    Points : 31
    Points
    31
    Par défaut
    Bonjour,
    Je crois pas que du cloud computing pour l'ordre de 400 fichiers serait une bonne idée !
    Je te propose 3 solutions :
    1- Chercher à optimiser tes algorithmes(purement théorique) avant de les implémenter (méthodes de parcours de l'arbre de recherche : en largeur, en profondeur..., combinaisons de méthodes..etc).
    2-Utiliser le multithreading qui est parfaitement adapté à ce type d'opérations(Le profodeur d'u noeud serait un bon indice pour lancer un nouveau thread).
    3- Une combianaison de 1/ et 2/ .

    Bon chance !

  9. #9
    Membre chevronné
    Avatar de CheryBen
    Inscrit en
    Mai 2005
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mai 2005
    Messages : 1 599
    Points : 2 197
    Points
    2 197
    Par défaut
    Il faut bien faire attention à la lecture des fichiers xml, éviter les conversions inutiles xml vers String ou inversement, essayer d'optimiser les xpath (éviter les //monElement).

    Comment compares-tu les documents?
    S'il s'agit simplement de savoir si des documents sont identiques, peut-être que tu devrais t'orienter vers la librairie XmlUnit qui propose la classe XMLAssert. Si tu dois extraire précisément les différences, je ne suis pas sûr que cette librairie soit adaptée, à ma connaissance la comparaison s'arrête à la 1ère différence trouvée.

  10. #10
    Futur Membre du Club
    Femme Profil pro
    Doctorante
    Inscrit en
    Juillet 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Doctorante

    Informations forums :
    Inscription : Juillet 2011
    Messages : 10
    Points : 5
    Points
    5
    Par défaut
    Bonjour,
    merci pour vos réponses.
    Vous avez mentionné le le multithreading!!pourriez vous m'éclairer sur ce point?
    Actuellement j'essaye de voir ce que le Grid computing pourrait m'offrir.
    Merci

  11. #11
    Membre émérite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Septembre 2008
    Messages
    1 190
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 1 190
    Points : 2 657
    Points
    2 657
    Par défaut
    Tu peux utiliser un outil d'analyse de code, qui te permettra de voir quel méthode te prend le plus de temps.

    Le multithreading c'est de diviser les tâches en plusieurs parties concurrentes, chaque partie étant traitée par un Thread. Sachant que les Thread doivent être lancés en concurrence (s'exécuter en parallèle).

    Sinon une autre solution est d'ajouter des heuristiques a ton algo. C'est à dire essayer de prévoir quels branches ne mène a rien, ou lesquels sont plus intéressante à explorer en premier, etc...

Discussions similaires

  1. Réponses: 0
    Dernier message: 27/10/2010, 14h17
  2. Réponses: 0
    Dernier message: 09/07/2009, 17h19
  3. Réponses: 0
    Dernier message: 22/05/2009, 18h31
  4. Réponses: 2
    Dernier message: 13/08/2008, 09h56
  5. totaux calculé en haut de section
    Par pdelorme dans le forum SAP Crystal Reports
    Réponses: 5
    Dernier message: 29/01/2008, 15h20

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo