mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 19:32:55 +08:00
Account for legacyAccScore in score conversion
This commit is contained in:
parent
27f9dfccc4
commit
71e5654b64
@ -74,6 +74,7 @@ namespace osu.Game.Rulesets.Catch.Difficulty
|
|||||||
simulateHit(obj, ref attributes);
|
simulateHit(obj, ref attributes);
|
||||||
|
|
||||||
attributes.BonusScoreRatio = legacyBonusScore == 0 ? 0 : (double)standardisedBonusScore / legacyBonusScore;
|
attributes.BonusScoreRatio = legacyBonusScore == 0 ? 0 : (double)standardisedBonusScore / legacyBonusScore;
|
||||||
|
attributes.BonusScore = legacyBonusScore;
|
||||||
|
|
||||||
return attributes;
|
return attributes;
|
||||||
}
|
}
|
||||||
|
@ -75,6 +75,7 @@ namespace osu.Game.Rulesets.Taiko.Difficulty
|
|||||||
simulateHit(obj, ref attributes);
|
simulateHit(obj, ref attributes);
|
||||||
|
|
||||||
attributes.BonusScoreRatio = legacyBonusScore == 0 ? 0 : (double)standardisedBonusScore / legacyBonusScore;
|
attributes.BonusScoreRatio = legacyBonusScore == 0 ? 0 : (double)standardisedBonusScore / legacyBonusScore;
|
||||||
|
attributes.BonusScore = legacyBonusScore;
|
||||||
|
|
||||||
return attributes;
|
return attributes;
|
||||||
}
|
}
|
||||||
|
@ -250,15 +250,14 @@ namespace osu.Game.Database
|
|||||||
long maximumLegacyComboScore = (long)Math.Round(attributes.ComboScore * legacyModMultiplier);
|
long maximumLegacyComboScore = (long)Math.Round(attributes.ComboScore * legacyModMultiplier);
|
||||||
double maximumLegacyBonusRatio = attributes.BonusScoreRatio;
|
double maximumLegacyBonusRatio = attributes.BonusScoreRatio;
|
||||||
long maximumLegacyBonusScore = attributes.BonusScore;
|
long maximumLegacyBonusScore = attributes.BonusScore;
|
||||||
int maximumLegacyCombo = attributes.MaxCombo;
|
|
||||||
|
|
||||||
|
double legacyAccScore = maximumLegacyAccuracyScore * score.Accuracy;
|
||||||
|
// We can not separate the ComboScore from the BonusScore, so we keep the bonus in the ratio.
|
||||||
|
double comboProportion =
|
||||||
|
((double)score.LegacyTotalScore - legacyAccScore) / (maximumLegacyComboScore + maximumLegacyBonusScore);
|
||||||
|
|
||||||
|
// We assume the bonus proportion only makes up the rest of the score that exceeds maximumLegacyBaseScore.
|
||||||
long maximumLegacyBaseScore = maximumLegacyAccuracyScore + maximumLegacyComboScore;
|
long maximumLegacyBaseScore = maximumLegacyAccuracyScore + maximumLegacyComboScore;
|
||||||
long maximumLegacyTotalScore = maximumLegacyBaseScore + maximumLegacyBonusScore;
|
|
||||||
|
|
||||||
// The combo proportion is calculated as a proportion of maximumLegacyTotalScore.
|
|
||||||
double comboProportion = (double)score.LegacyTotalScore / maximumLegacyTotalScore;
|
|
||||||
|
|
||||||
// The bonus proportion makes up the rest of the score that exceeds maximumLegacyBaseScore.
|
|
||||||
double bonusProportion = Math.Max(0, ((long)score.LegacyTotalScore - maximumLegacyBaseScore) * maximumLegacyBonusRatio);
|
double bonusProportion = Math.Max(0, ((long)score.LegacyTotalScore - maximumLegacyBaseScore) * maximumLegacyBonusRatio);
|
||||||
|
|
||||||
double modMultiplier = score.Mods.Select(m => m.ScoreMultiplier).Aggregate(1.0, (c, n) => c * n);
|
double modMultiplier = score.Mods.Select(m => m.ScoreMultiplier).Aggregate(1.0, (c, n) => c * n);
|
||||||
@ -288,6 +287,7 @@ namespace osu.Game.Database
|
|||||||
// this can be roughly represented by summing / integrating f(combo) = combo.
|
// this can be roughly represented by summing / integrating f(combo) = combo.
|
||||||
// All mod- and beatmap-dependent multipliers and constants are not included here,
|
// All mod- and beatmap-dependent multipliers and constants are not included here,
|
||||||
// as we will only be using the magnitude of this to compute ratios.
|
// as we will only be using the magnitude of this to compute ratios.
|
||||||
|
int maximumLegacyCombo = attributes.MaxCombo;
|
||||||
double maximumAchievableComboPortionInScoreV1 = Math.Pow(maximumLegacyCombo, 2);
|
double maximumAchievableComboPortionInScoreV1 = Math.Pow(maximumLegacyCombo, 2);
|
||||||
// Similarly, estimate the maximum magnitude of the combo portion in standardised score.
|
// Similarly, estimate the maximum magnitude of the combo portion in standardised score.
|
||||||
// Roughly corresponds to integrating f(combo) = combo ^ COMBO_EXPONENT (omitting constants)
|
// Roughly corresponds to integrating f(combo) = combo ^ COMBO_EXPONENT (omitting constants)
|
||||||
|
Loading…
Reference in New Issue
Block a user