MacMusic.org  |  PcMusic.org  |  440Software  |  440Forums.com  |  440Tv  |  Zicos.com  |  AudioLexic.org
Loading... visitors connected
Welcome Guest
> Performances Du Coremidi, Avec Logic, Reason 2, Live, PT6, etc...
deleted
post Tue 5 Nov 2002, 21:32
Post #1


SuperHero
********

Group: Banned
Posts: 1,879
Joined: 24-Feb 02
Member No.: 3,562




Est-ce que les utilisateurs de Logic, Reason 2, Live, PT6, etc. peuvent me dire comment se comprte le coreMIDI avec bcp d'infos et de controleurs qui circulent, ceci avec de grosses interfaces multi i/o? Et avec moults pistes audio en plus?

Est-ce que ça suit?

Y'a t'il des pbs de timing? Le MTS est il au point?

Et comment se comporte le multi-tache d'os X si y'a d'autres applis qui tournent derrière (sampler virtuel, instru)?

Bye.
Go to the top of the page
 
+Quote Post
 
Start new topic
Replies
BusError
post Wed 6 Nov 2002, 00:39
Post #2


Advanced Member
*****

Group: Members
Posts: 351
Joined: 12-Aug 02
From: London - UK
Member No.: 6,795




Tss Tss, c'est limite dévelopment ca hein! :-)

Le MIDI et audio OSX tourned en "temps reel" c'est a dire que leur priorite n'est pas relative a leur utilisation du CPU.

J'essssplique:
Une appli normale est géré en multitache de la facon suivante: Le system lui done une 'trance de temps' (time slice). Le programme tourne dans cette tranche et il peut se passer deux chose:
1) Le programme rends la main au systeme avant que sa tranche soit finie, auquel cas sa propre priorite augmente un peu ("bon ptit gars!")
2) Le programme utilise toute sa trance, auquel cas sa priorite descents un peu ("Tss Tss, laisse en aux autres!")

Donc, on peu en deduire deux choses:
1) Meme si une appli gourmande fait PLEIN de trucs, vous pourrez toujours travailler sur la machine, parce que la tache qui monopolise le CPU aura son 'time slice' que quand les autres plus 'sage' ont fini.
2) Il n'y a pas moyen de predire le temps necessaire a une action, puisque le delay que le systeme utilise pour donne du temps est variable.

Ca, c'est une application normale.

Une appli audio/MIDI utilise un autre type de distribution de temps (scheduling). C'est du "round robin" ou encore appellé innexactement 'temps reel'

Dans ce shema, un programme recoit toujours une tranche de temps a intervale regulier, apres toutes les autres taches qui sont elles aussi en 'round robin'
Donc, les consequences:
+ Il faut limiter a mort le temps qui y est passe
+ Ces taches peuvent mettre la machine a genoux, puisque elles ont une priorite bien plus grande que les autres
+ Meme si on ne peut pas *guarantir* une notion de timing de l'ordre de la microseconde, on s'en approche quand meme pas mal.

Voila, apres tout ca, il suffit juste de dire que l'audio et le MIDI dans OSX tourne dans des 'taches' round robin. Donc la charge de la machine (hors autre taches du meme genre) a beaucoup moins d'impact que sur les autres.

D'apres mes tests, avec des examples un peu chargés, j'arrive a avoir une latence MIDI inferieure a 2 dixieme de millisecondes (0.0002s) ce qui est monstrueusement precis.
Et ca c'est sans algorythme tordu de prediction/correction de latence potentielle, je fais juste une correction de 'drift' (derive) un peu a la louche.

je sais que le systeme audio peu arriver a une latence bien meilleure encore, dans des cas 'ideaux', il y a aussi des problemes avec ca, qu'il faudra que j'explique un de ces 4 :-)


--------------------
Go to the top of the page
 
+Quote Post

Posts in this topic


Reply to this topicStart new topic
1 User(s) are reading this topic (1 Guests and 0 Anonymous Users)
0 Members:

 

Lo-Fi Version - Thu 12 Dec 2024, 20:50
- © MacMusic 1997-2008