Let's see how the game use this : when a drop occurs, the game follows the TC until getting a base object. For exemple a "skull cap". Then it test if the item become unique/set/rare/.../Low quality.
For this it uses the proper line of ItemRatio.txt, the MF bonus of the character who made the drop (character + minion if a minion killed the monster), and the maximum values of unique/set/magic/rare crossed while following TreasureClassEx.txt (the maximum value, not the first seen, not the last non null, not the sum, ... Heavily tested by Paul).
The game decides the quality of item (unique/.../lowquality) by first testing if it is unique, if not it tests if it is rare, if not ..., and if all fail the item of "low quality".
The order is :
Unique > Set > Rare > Magic > Hi quality > Normal > Low quality
the unique test :
The base probability of being unique is probability = 1 / Unique, Unique taken from ItemRatio.
Then this base chance is decreased by (MonsterLvl - QualityLvl) / UniqueDivisor , where QualityLvl is the level read in armor/misc/weapons.
Now this value is multiplied by 128 (some extra precision).
And comes the effect of EMF (MF with diminushing return) : chance = chance * 100 / (100 + EMF) .
Chance is compared with UniqueMin from ItemRatio.txt (so note that XXXmin is in essence 128 time bigger than XXX).
And finally the TC bonus is applied : chance = chance - (chance * unique_factor) / 1024 , where unique_factor is the maximum value of "unique" seems in TreasureClassEx.txt.
Now the games picks a random number between 0 and chance-1. If this random number is less or equal than 127, the objet is unique.
Same procedure is used (but with different diminushing return) for set/rare/magic tests.
And also for Hi quality/normal, but without MF, without XXXmin, and without XXX_factor.
A notes on XXXDivisor :
Well mishy23 explained it very well so I'll just be lazy and quote him :
Just to expand on RareDiv,
When it comes to determining what rarity(magic/rare/unique) item is,
the difference in itemlevel (qlvl) and monsterlevel (mlvl) make a large difference in overall determination.
Thats why its easier to get magic items and higher on lower level items, then it is on higher level objects.
This is why you usually see white items first when new itemtypes become available, and magic versions dont drop with much regularity until after your fighting higher level monsters.
As Ulmo said (MonsterLvl - Qlvl) / UniqueDivisor is the formula,
so the if a very high level monster drops a very low level base item,
well this raisies chance item can be magic, rare, etc...
while if a medium level monster drops a medium level base item, well that difference is very small and the chance to get magic, rare, etc...is not modified very much at all.
RareDiv, makes this level difference between monster and item its dropping matter less the higher the div is.
Div does not in itself divide the overall chance for dropping magic, rare, unique, just the modification of this chance by the monsterlvl-itemlvl curve.
Also, you can think of XXXmin as a way to counter too high values of MF.
Effective MF formulae :
For magic, it is just EMF = MF
For Rare/Set/Unique, Diminushing return is only used if MF > 10. In this case, EMF = MF*X/(MF+X) , i.e. going slower and slower from 0 to X. With X = 250 for uniques, X = 500 for Sets, and X = 600 for Rares.
Exemple :
A ring (qlvl = 1) dropped by Andarielle in hell (Mlvl = 78) with +300% MF (I use here the QuestDrop).
So base chance is 400, then becomes 400 - (78 - 1)/1 = 323
extra-precision : chance = 323*128 = 41344
MF : chance = 41344 * 100 / (100 + 136) = 17518
UniqueMin is lower than chance and is ignored.
for Andarielle questdrop in hell (TC = "Andarielq (H)"), Unique_factor = 995
So chance = 17518 - (17518 * 995) / 1024 = 496
This means 128/496 = 25.81% chances of being unique.