π
<-

Module TI-Python disponible à l'unité chez Jarrety : 13,50€

:32ti73: :32ti73e: :32ti73e2: :32ti76f: :32ti80: :32ti81: :32ti82: :32ti85: :32ti86: :32ti82s: :32ti82sf: :32ti82sfn: :32ti83: :32ti83p: :32ti83pb: :32ti83pr: :32ti83pfr: :32ti83pse: :32ti84p: :32ti84pse: :32ti84ppse: :32ti84pfr: :32ti84pcse: :32ti83pfrusb: :32ti82p: :32ti82a: :32ti84pce: :32ti83pce:

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby Lionel Debroux » 07 Feb 2019, 18:43

Argh. C'est à ce point-là, la différence de performances ?
Je n'ai pas touché au code d'init et à la fréquence CPU, donc je suppose que ce n'est pas parce que la board est mal réglée que les performances semblent si horribles.
Membre de la TI-Chess Team.
Co-mainteneur de GCC4TI (documentation en ligne de GCC4TI), TIEmu et TILP.
User avatar
Lionel DebrouxSuper Modo
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 11.3%
 
Posts: 6865
Joined: 23 Dec 2009, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Class: -
GitHub: debrouxl

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby critor » 07 Feb 2019, 19:06

Je note que sys.maxsize a été réduit.
Or, comme il n'y a pas d'entiers longs, cela réduit donc encore davantage l'intervalle des entiers supportés.

sys.maxsize==2147483647 sur NumWorks, Graph 90+E et Graph 35/75+E.
sys.maxsize==1073741823 sur le module externe TI-Python avec son firmware d'origine
sys.maxsize==536870911 sur le module externe TI-Python avec le dernier firmware de Lionel
Image
User avatar
critorAdmin
Niveau 19: CU (Créateur Universel)
Niveau 19: CU (Créateur Universel)
Level up: 48%
 
Posts: 41984
Images: 15890
Joined: 25 Oct 2008, 00:00
Location: Montpellier
Gender: Male
Calculator(s):
MyCalcs profile
YouTube: critor3000
Twitter: critor2000
GitHub: critor

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby Lionel Debroux » 07 Feb 2019, 19:12

OK, alors je vais essayer d'utiliser MICROPY_OBJ_REPR_A plutôt que MICROPY_OBJ_REPR_B, parce que cette représentation laisse un bit de plus pour les entiers, comme MICROPY_OBJ_REPR_C :)

EDIT: le .uf2 en pièce jointe (dans un tarball car l'extension .uf2 est interdite). Le seul changement depuis le diff précédent est donc -MICROPY_OBJ_REPR_B +MICROPY_OBJ_REPR_A dans ports/atmel-samd/mpconfig.h . La taille diminue très légèrement.

Je suis en train d'organiser un peu mon travail en local, pour une diffusion ultérieure sur Github et aussi au moins une PR à CircuitPython, puisque j'ai vu une paire d'optimisations mineures au passage :)

EDIT2: la PR est donc https://github.com/adafruit/circuitpython/pull/1527 .
You do not have the required permissions to view the files attached to this post.
Membre de la TI-Chess Team.
Co-mainteneur de GCC4TI (documentation en ligne de GCC4TI), TIEmu et TILP.
User avatar
Lionel DebrouxSuper Modo
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 11.3%
 
Posts: 6865
Joined: 23 Dec 2009, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Class: -
GitHub: debrouxl

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby critor » 07 Feb 2019, 20:12

Voilà, mis à jour le script de test de performances avec des entiers courts :
Code: Select all
try:
  from time import *
except:
  pass

def hastime():
  try:
    monotonic()
    return True
  except:
    return False

def genseed(ndigits):
  nmax,s,k=5*10**(ndigits-1),0,1
  while s<nmax:
    s+=k
    k*=2
  return s

def genarr(ndigits):
  sd,arr=genseed(ndigits),[]
  for k in range(1,ndigits):
    for j in range(ndigits):
      t=sd%10**k
      arr.extend([t,-t,10**k-t,t-10**k])
      sd=sd//10+(sd%10)*10**(ndigits-1)
  arr.extend([sd,-sd])
  return arr

def sortarr(arr,sdiff):
  segs=[0,len(arr)-1]
  while len(segs):
    iref=segs[0]
    for k in range(segs[0],segs[1]+1):
      if sdiff*(arr[k]-arr[iref])>0:
        t=arr[iref]
        arr[iref]=arr[k]
        arr[k]=arr[iref+1]
        arr[iref+1]=t
        iref+=1
    if iref>=segs[0]+2:
      segs.extend([segs[0],iref-1])
    if iref<=segs[1]-2:
      segs.extend([iref+1,segs[1]])
    segs.pop(0)
    segs.pop(0)
  return arr

def test(l,n):
  timed=hastime()
  start,stop,sdiff,arr=0 or timed and monotonic(),1,-1,[]
  arr.extend(genarr(l))
  for k in range(n):
    arr.extend(sortarr(arr,sdiff))
    sdiff=-sdiff
  stop=timed and monotonic() or 1
  return stop-start,len(arr),arr[0],arr[len(arr)//2-1],arr[len(arr)//2],arr[len(arr)-1]


Ligne d'appel : test(9,2)

  1. TI-Nspire :1.41s
  2. TI-Nspire CX CR3- : 1.56s
  3. TI-Nspire CX CR4+ : 2.40s
  4. NumWorks : 3.74s
  5. Graph 90+E : 4.75s
  6. HP Prime G2 : 8.81s
  7. Graph 75+E + CasioPython : 9.78s
  8. HP Prime G1 : 20.73s
  9. module externe TI-Python (firmware d'origine) : 23.20s
  10. Graph 90+E + KhiCAS : 60.71s
Image
User avatar
critorAdmin
Niveau 19: CU (Créateur Universel)
Niveau 19: CU (Créateur Universel)
Level up: 48%
 
Posts: 41984
Images: 15890
Joined: 25 Oct 2008, 00:00
Location: Montpellier
Gender: Male
Calculator(s):
MyCalcs profile
YouTube: critor3000
Twitter: critor2000
GitHub: critor

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby parisse » 07 Feb 2019, 21:44

Adriweb: il y a un support partiel du short if, mais pas comme ca dans des expressions avec parentheses, ca aurait trop d'effets de bord d'essayer de gerer ca au niveau du lexer/parser. Je ne compte pas retravailler la-dessus, sinon c'est sans fin, d'autant plus que chaque nouvelle version de Python introduit probablement de nouvelles possibilites.

critor: bien joue pour le dernier script. Par contre je n'ai aucune idee de ce qu'il peut bien faire.

De maniere generale, je pense qu'il serait plus significatif de comparer des programmes faisant la meme chose mais tirant parti des particularites de chaque implementation. Evidemment, c'est plus systematique d'avoir un meme programme pour tous, mais d'un autre cote ca ne represente pas un usage normal de creer une fonction signe maison quand on en a une native sous la main. La force de KhiCAS/Xcas c'est de proposer beaucoup de fonctions mathematiques natives, sa faiblesse c'est qu'un evaluateur symbolique (autorisant l'evaluation d'une variable libre) est significativement plus lent qu'un evaluateur non symbolique. Il est assez clair que tous les benchmarks systematiques vont classer les implementations a base de Xcas en queue de classement, alors que pour un etudiant voulant programmer en relation avec les maths, l'environnement est bien plus riche et sera plus rapide lorsqu'on peut utiliser une fonction native specifique.
User avatar
parisseVIP++
Niveau 12: CP (Calculatrice sur Pattes)
Niveau 12: CP (Calculatrice sur Pattes)
Level up: 86.1%
 
Posts: 3663
Joined: 13 Dec 2013, 16:35
Gender: Not specified
Calculator(s):
MyCalcs profile

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby critor » 07 Feb 2019, 22:28

parisse wrote:critor: bien joue pour le dernier script. Par contre je n'ai aucune idee de ce qu'il peut bien faire.


Rien de bien intéressant, à part occuper suffisamment de temps processeur pour pouvoir faire un classement.

Il génère une liste puis la trie alternativement par ordre croissant et décroissant, et concatène le résultat à chaque fois.

Je n'ai volontairement pas utilisé la fonction sort() de Python, car le fonctionnement interne peut différer d'une plateforme à une autre selon les optimisations autorisées à la compilation.

Donc pour un QCC 2019, nous avons maintenant 2 tests de performances Python :
  • un avec uniquement des entiers courts
  • un avec uniquement des flottants
Image
User avatar
critorAdmin
Niveau 19: CU (Créateur Universel)
Niveau 19: CU (Créateur Universel)
Level up: 48%
 
Posts: 41984
Images: 15890
Joined: 25 Oct 2008, 00:00
Location: Montpellier
Gender: Male
Calculator(s):
MyCalcs profile
YouTube: critor3000
Twitter: critor2000
GitHub: critor

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby Adriweb » 08 Feb 2019, 05:21

critor wrote:Voilà, mis à jour le script de test de performances avec des entiers courts


Voici une amélioration qui est globale aux scripts de tests:

plutot que d'incorporer directement le benchmark a l'interieur de la fonction, on cree une fonction a part, comme ca on a juste a implémenter la fonction à tester normalement
beaucoup plus naturel, réutilisable, et propre :)

Pour ton exemple ci-dessus, le coeur de la fonction test est la meme, mais j'ai une autre fonction timefunc qui prend la fonction à benchmarker en parametre, ainsi que ses arguments.
Code: Select all
def test(l, n):
    sdiff, arr = -1, []
    arr.extend(genarr(l))
    for k in range(n):
        arr.extend(sortarr(arr, sdiff))
        sdiff = -sdiff
    return len(arr), arr[0], arr[len(arr) // 2 - 1], arr[len(arr) // 2], arr[len(arr) - 1]


def timefunc(func, *args):
    timed = hastime()
    start, stop = 0 or timed and monotonic(), 1
    retvals = (func(*args))
    stop = timed and monotonic() or 1
    return stop - start, retvals


print(timefunc(test, 9, 2))


Et puis, bonus visuellement, puisque dans le print ca cloisonne un peu mieux le temps de la retval de la fonction. par exemple :
Code: Select all
/usr/bin/python3 test.py
(0.020823007998842513, (1160, 536870911, -536870911, 536870911, -536870911))


Edit: Maintenant, il faudrait probablement voir comment avoir quelque chose de compatible avec la syntaxe giac... (je suppose qu'il y aurait moyen, quitte a faire un if(giac) dans la fonction timefunc).

MyCalcs: Help the community's calculator documentations by filling out your calculators info!
MyCalcs: Aidez la communauté à documenter les calculatrices en donnant des infos sur vos calculatrices !
Inspired-Lua.org: All about TI-Nspire Lua programming (tutorials, wiki/docs...)
My calculator programs
Mes programmes pour calculatrices
User avatar
AdriwebAdmin
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 78.9%
 
Posts: 14744
Images: 1119
Joined: 01 Jun 2007, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Twitter: adriweb
GitHub: adriweb

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby parisse » 08 Feb 2019, 08:59

Plutot que d'essayer a tout prix de faire une fonction timefunc qui marche aussi pour giac, il me semble beaucoup plus simple de juste faire time(test(9,2)).
User avatar
parisseVIP++
Niveau 12: CP (Calculatrice sur Pattes)
Niveau 12: CP (Calculatrice sur Pattes)
Level up: 86.1%
 
Posts: 3663
Joined: 13 Dec 2013, 16:35
Gender: Not specified
Calculator(s):
MyCalcs profile

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby Adriweb » 08 Feb 2019, 09:04

parisse wrote:Plutot que d'essayer a tout prix de faire une fonction timefunc qui marche aussi pour giac, il me semble beaucoup plus simple de juste faire time(test(9,2)).

?
test(9,2) sera évalué avant que la fonction time soit appelée avec le résultat de la fonction test, donc je ne vois pas comment la fonction time pourrait mesurer quoi que ce soit.
(sauf si "time" est quelque chose de particulier en giac, auquel cas, pourquoi pas...)


Edit: oui ok, c'est bien le cas, c'est specifique a giac. Donc encore plus simple. Dispo sur KhiCAS etc. ?

(PS: Je n'ai pas trouvé de moyen de déclarer une fonction variadique en giac, voir de passer une fonction en parametre a une autre fonction - est-ce possible ? Meme si ce n'est plus d'actualité)

MyCalcs: Help the community's calculator documentations by filling out your calculators info!
MyCalcs: Aidez la communauté à documenter les calculatrices en donnant des infos sur vos calculatrices !
Inspired-Lua.org: All about TI-Nspire Lua programming (tutorials, wiki/docs...)
My calculator programs
Mes programmes pour calculatrices
User avatar
AdriwebAdmin
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 78.9%
 
Posts: 14744
Images: 1119
Joined: 01 Jun 2007, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Twitter: adriweb
GitHub: adriweb

Re: Module TI-Python disponible à l'unité chez Jarrety : 13,

Unread postby samourai3745 » 08 Feb 2019, 11:12

Salut à tous,

J'essaye d'executer le script avec Khicas, mais j'obtiens system error address target DF1ED41F, pc=000000000
Khicas version de janvier. Bizarre





Adriweb wrote:
critor wrote:Voilà, mis à jour le script de test de performances avec des entiers courts


Voici une amélioration qui est globale aux scripts de tests:

plutot que d'incorporer directement le benchmark a l'interieur de la fonction, on cree une fonction a part, comme ca on a juste a implémenter la fonction à tester normalement
beaucoup plus naturel, réutilisable, et propre :)

Pour ton exemple ci-dessus, le coeur de la fonction test est la meme, mais j'ai une autre fonction timefunc qui prend la fonction à benchmarker en parametre, ainsi que ses arguments.
Code: Select all
def test(l, n):
    sdiff, arr = -1, []
    arr.extend(genarr(l))
    for k in range(n):
        arr.extend(sortarr(arr, sdiff))
        sdiff = -sdiff
    return len(arr), arr[0], arr[len(arr) // 2 - 1], arr[len(arr) // 2], arr[len(arr) - 1]


def timefunc(func, *args):
    timed = hastime()
    start, stop = 0 or timed and monotonic(), 1
    retvals = (func(*args))
    stop = timed and monotonic() or 1
    return stop - start, retvals


print(timefunc(test, 9, 2))


Et puis, bonus visuellement, puisque dans le print ca cloisonne un peu mieux le temps de la retval de la fonction. par exemple :
Code: Select all
/usr/bin/python3 test.py
(0.020823007998842513, (1160, 536870911, -536870911, 536870911, -536870911))


Edit: Maintenant, il faudrait probablement voir comment avoir quelque chose de compatible avec la syntaxe giac... (je suppose qu'il y aurait moyen, quitte a faire un if(giac) dans la fonction timefunc).
User avatar
samourai3745Programmeur
Niveau 9: IC (Compteur Infatigable)
Niveau 9: IC (Compteur Infatigable)
Level up: 82%
 
Posts: 75
Images: 0
Joined: 19 Jul 2015, 17:23
Location: Tours
Gender: Male
Calculator(s):
MyCalcs profile
Class: BTS Informatique de Gestion, BTS Formateur d'adultes

PreviousNext

Return to News TI-z80 (TI-73, 76, 80, 81, 82, 83, 84, 85, 86)

Who is online

Users browsing this forum: ClaudeBot [spider] and 6 guests

-
Search
-
Social TI-Planet
-
Featured topics
Comparaisons des meilleurs prix pour acheter sa calculatrice !
"1 calculatrice pour tous", le programme solidaire de Texas Instruments. Reçois gratuitement et sans aucune obligation d'achat, 5 calculatrices couleur programmables en Python à donner aux élèves les plus nécessiteux de ton lycée. Tu peux recevoir au choix 5 TI-82 Advanced Edition Python ou bien 5 TI-83 Premium CE Edition Python.
Enseignant(e), reçois gratuitement 1 exemplaire de test de la TI-82 Advanced Edition Python. À demander d'ici le 31 décembre 2024.
Aidez la communauté à documenter les révisions matérielles en listant vos calculatrices graphiques !
1234
-
Donations / Premium
For more contests, prizes, reviews, helping us pay the server and domains...
Donate
Discover the the advantages of a donor account !
JoinRejoignez the donors and/or premium!les donateurs et/ou premium !


Partner and ad
Notre partenaire Jarrety Calculatrices à acheter chez Calcuso
-
Stats.
829 utilisateurs:
>782 invités
>41 membres
>6 robots
Record simultané (sur 6 mois):
6892 utilisateurs (le 07/06/2017)
-
Other interesting websites
Texas Instruments Education
Global | France
 (English / Français)
Banque de programmes TI
ticalc.org
 (English)
La communauté TI-82
tout82.free.fr
 (Français)