From 60c440ebf64371a6ed7b36282c0f693127217abc Mon Sep 17 00:00:00 2001 From: Dan Balasescu Date: Mon, 11 Nov 2024 15:35:16 +0900 Subject: [PATCH 1/4] Rename `ProcessableBeatmap` -> `ProcessableItem` There was already a case of `beatmap.Beatmap.Beatmap` with the existing name, which is nothing short of silly. --- .../ServerDifficultyCalculator.cs | 50 +++++++++---------- 1 file changed, 25 insertions(+), 25 deletions(-) diff --git a/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs b/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs index 15e28ce..d4d24a5 100644 --- a/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs +++ b/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs @@ -67,7 +67,7 @@ public void Process(WorkingBeatmap beatmap, ProcessingMode mode) public void ProcessLegacyAttributes(WorkingBeatmap beatmap) => run(beatmap, processLegacyAttributes); - private void run(WorkingBeatmap beatmap, Action callback) + private void run(WorkingBeatmap beatmap, Action callback) { try { @@ -89,10 +89,10 @@ private void run(WorkingBeatmap beatmap, Action r.RulesetInfo.OnlineID == beatmap.BeatmapInfo.Ruleset.OnlineID)) - callback(new ProcessableBeatmap(beatmap, beatmap.BeatmapInfo.Ruleset.CreateInstance(), ranked), conn); + callback(new ProcessableItem(beatmap, beatmap.BeatmapInfo.Ruleset.CreateInstance(), ranked), conn); } } catch (Exception e) @@ -101,14 +101,14 @@ private void run(WorkingBeatmap beatmap, Action(); @@ -130,8 +130,8 @@ private void processDifficulty(ProcessableBeatmap beatmap, MySqlConnection conn) { parameters.Add(new { - BeatmapId = beatmap.BeatmapID, - Mode = beatmap.RulesetID, + BeatmapId = item.BeatmapID, + Mode = item.RulesetID, Mods = (int)legacyMods, Attribute = mapping.attributeId, Value = Convert.ToSingle(mapping.value) @@ -145,19 +145,19 @@ private void processDifficulty(ProcessableBeatmap beatmap, MySqlConnection conn) parameters.ToArray()); } - if (legacyMods == LegacyMods.None && beatmap.Ruleset.RulesetInfo.Equals(beatmap.Beatmap.BeatmapInfo.Ruleset)) + if (legacyMods == LegacyMods.None && item.Ruleset.RulesetInfo.Equals(item.Beatmap.BeatmapInfo.Ruleset)) { - double beatLength = beatmap.Beatmap.Beatmap.GetMostCommonBeatLength(); + double beatLength = item.Beatmap.Beatmap.GetMostCommonBeatLength(); double bpm = beatLength > 0 ? 60000 / beatLength : 0; object param = new { - BeatmapId = beatmap.BeatmapID, + BeatmapId = item.BeatmapID, Diff = attribute.StarRating, - AR = beatmap.Beatmap.BeatmapInfo.Difficulty.ApproachRate, - OD = beatmap.Beatmap.BeatmapInfo.Difficulty.OverallDifficulty, - HP = beatmap.Beatmap.BeatmapInfo.Difficulty.DrainRate, - CS = beatmap.Beatmap.BeatmapInfo.Difficulty.CircleSize, + AR = item.Beatmap.BeatmapInfo.Difficulty.ApproachRate, + OD = item.Beatmap.BeatmapInfo.Difficulty.OverallDifficulty, + HP = item.Beatmap.BeatmapInfo.Difficulty.DrainRate, + CS = item.Beatmap.BeatmapInfo.Difficulty.CircleSize, BPM = Math.Round(bpm, 2), MaxCombo = attribute.MaxCombo, }; @@ -181,13 +181,13 @@ private void processDifficulty(ProcessableBeatmap beatmap, MySqlConnection conn) } } - private void processLegacyAttributes(ProcessableBeatmap beatmap, MySqlConnection conn) + private void processLegacyAttributes(ProcessableItem item, MySqlConnection conn) { - Mod? classicMod = beatmap.Ruleset.CreateMod(); + Mod? classicMod = item.Ruleset.CreateMod(); Mod[] mods = classicMod != null ? new[] { classicMod } : Array.Empty(); - ILegacyScoreSimulator simulator = ((ILegacyRuleset)beatmap.Ruleset).CreateLegacyScoreSimulator(); - LegacyScoreAttributes attributes = simulator.Simulate(beatmap.Beatmap, beatmap.Beatmap.GetPlayableBeatmap(beatmap.Ruleset.RulesetInfo, mods)); + ILegacyScoreSimulator simulator = ((ILegacyRuleset)item.Ruleset).CreateLegacyScoreSimulator(); + LegacyScoreAttributes attributes = simulator.Simulate(item.Beatmap, item.Beatmap.GetPlayableBeatmap(item.Ruleset.RulesetInfo, mods)); if (dryRun) return; @@ -198,8 +198,8 @@ private void processLegacyAttributes(ProcessableBeatmap beatmap, MySqlConnection + "ON DUPLICATE KEY UPDATE `legacy_accuracy_score` = @AccuracyScore, `legacy_combo_score` = @ComboScore, `legacy_bonus_score_ratio` = @BonusScoreRatio, `legacy_bonus_score` = @BonusScore, `max_combo` = @MaxCombo", new { - BeatmapId = beatmap.BeatmapID, - Mode = beatmap.RulesetID, + BeatmapId = item.BeatmapID, + Mode = item.RulesetID, AccuracyScore = attributes.AccuracyScore, ComboScore = attributes.ComboScore, BonusScoreRatio = attributes.BonusScoreRatio, @@ -231,7 +231,7 @@ private static List getRulesets() return rulesetsToProcess; } - private readonly record struct ProcessableBeatmap(WorkingBeatmap Beatmap, Ruleset Ruleset, bool Ranked) + private readonly record struct ProcessableItem(WorkingBeatmap Beatmap, Ruleset Ruleset, bool Ranked) { public int BeatmapID => Beatmap.BeatmapInfo.OnlineID; public int RulesetID => Ruleset.RulesetInfo.OnlineID; From 4529f67c80afed2167b05e55224b0d62968ce5c4 Mon Sep 17 00:00:00 2001 From: Dan Balasescu Date: Mon, 11 Nov 2024 15:36:17 +0900 Subject: [PATCH 2/4] Rename `Beatmap` -> `WorkingBeatmap` --- .../ServerDifficultyCalculator.cs | 20 +++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs b/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs index d4d24a5..7b4dfaf 100644 --- a/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs +++ b/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs @@ -103,7 +103,7 @@ private void run(WorkingBeatmap beatmap, Action 0 ? 60000 / beatLength : 0; object param = new { BeatmapId = item.BeatmapID, Diff = attribute.StarRating, - AR = item.Beatmap.BeatmapInfo.Difficulty.ApproachRate, - OD = item.Beatmap.BeatmapInfo.Difficulty.OverallDifficulty, - HP = item.Beatmap.BeatmapInfo.Difficulty.DrainRate, - CS = item.Beatmap.BeatmapInfo.Difficulty.CircleSize, + AR = item.WorkingBeatmap.BeatmapInfo.Difficulty.ApproachRate, + OD = item.WorkingBeatmap.BeatmapInfo.Difficulty.OverallDifficulty, + HP = item.WorkingBeatmap.BeatmapInfo.Difficulty.DrainRate, + CS = item.WorkingBeatmap.BeatmapInfo.Difficulty.CircleSize, BPM = Math.Round(bpm, 2), MaxCombo = attribute.MaxCombo, }; @@ -187,7 +187,7 @@ private void processLegacyAttributes(ProcessableItem item, MySqlConnection conn) Mod[] mods = classicMod != null ? new[] { classicMod } : Array.Empty(); ILegacyScoreSimulator simulator = ((ILegacyRuleset)item.Ruleset).CreateLegacyScoreSimulator(); - LegacyScoreAttributes attributes = simulator.Simulate(item.Beatmap, item.Beatmap.GetPlayableBeatmap(item.Ruleset.RulesetInfo, mods)); + LegacyScoreAttributes attributes = simulator.Simulate(item.WorkingBeatmap, item.WorkingBeatmap.GetPlayableBeatmap(item.Ruleset.RulesetInfo, mods)); if (dryRun) return; @@ -231,9 +231,9 @@ private static List getRulesets() return rulesetsToProcess; } - private readonly record struct ProcessableItem(WorkingBeatmap Beatmap, Ruleset Ruleset, bool Ranked) + private readonly record struct ProcessableItem(WorkingBeatmap WorkingBeatmap, Ruleset Ruleset, bool Ranked) { - public int BeatmapID => Beatmap.BeatmapInfo.OnlineID; + public int BeatmapID => WorkingBeatmap.BeatmapInfo.OnlineID; public int RulesetID => Ruleset.RulesetInfo.OnlineID; } } From 451f0bc7290c6c06980b3b82e1c5512429fd72e9 Mon Sep 17 00:00:00 2001 From: Dan Balasescu Date: Mon, 11 Nov 2024 15:58:48 +0900 Subject: [PATCH 3/4] Update hitobject counts when writing to `osu_beatmaps` --- .../ServerDifficultyCalculator.cs | 27 ++++++++++++++++--- 1 file changed, 23 insertions(+), 4 deletions(-) diff --git a/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs b/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs index 7b4dfaf..bd80faa 100644 --- a/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs +++ b/osu.Server.DifficultyCalculator/ServerDifficultyCalculator.cs @@ -12,6 +12,7 @@ using osu.Game.Beatmaps.Legacy; using osu.Game.Rulesets; using osu.Game.Rulesets.Mods; +using osu.Game.Rulesets.Objects.Legacy; using osu.Game.Rulesets.Scoring.Legacy; using osu.Server.DifficultyCalculator.Commands; @@ -150,6 +151,20 @@ private void processDifficulty(ProcessableItem item, MySqlConnection conn) double beatLength = item.WorkingBeatmap.Beatmap.GetMostCommonBeatLength(); double bpm = beatLength > 0 ? 60000 / beatLength : 0; + int countCircle = 0; + int countSlider = 0; + int countSpinner = 0; + + foreach (var obj in item.WorkingBeatmap.Beatmap.HitObjects.OfType()) + { + if ((obj.LegacyType & LegacyHitObjectType.Circle) > 0) + countCircle++; + if ((obj.LegacyType & LegacyHitObjectType.Slider) > 0) + countSlider++; + if ((obj.LegacyType & LegacyHitObjectType.Spinner) > 0) + countSpinner++; + } + object param = new { BeatmapId = item.BeatmapID, @@ -160,20 +175,24 @@ private void processDifficulty(ProcessableItem item, MySqlConnection conn) CS = item.WorkingBeatmap.BeatmapInfo.Difficulty.CircleSize, BPM = Math.Round(bpm, 2), MaxCombo = attribute.MaxCombo, + CountCircle = countCircle, + CountSlider = countSlider, + CountSpinner = countSpinner, + CountTotal = countCircle + countSlider + countSpinner }; if (AppSettings.INSERT_BEATMAPS) { conn.Execute( - "INSERT INTO `osu_beatmaps` (`beatmap_id`, `difficultyrating`, `diff_approach`, `diff_overall`, `diff_drain`, `diff_size`, `bpm`, `max_combo`) " - + "VALUES (@BeatmapId, @Diff, @AR, @OD, @HP, @CS, @BPM, @MaxCombo) " - + "ON DUPLICATE KEY UPDATE `difficultyrating` = @Diff, `diff_approach` = @AR, `diff_overall` = @OD, `diff_drain` = @HP, `diff_size` = @CS, `bpm` = @BPM, `max_combo` = @MaxCombo", + "INSERT INTO `osu_beatmaps` (`beatmap_id`, `difficultyrating`, `diff_approach`, `diff_overall`, `diff_drain`, `diff_size`, `bpm`, `max_combo`, `countNormal`, `countSlider`, `countSpinner`, `countTotal`) " + + "VALUES (@BeatmapId, @Diff, @AR, @OD, @HP, @CS, @BPM, @MaxCombo, @CountCircle, @CountSlider, @CountSpinner, @CountTotal) " + + "ON DUPLICATE KEY UPDATE `difficultyrating` = @Diff, `diff_approach` = @AR, `diff_overall` = @OD, `diff_drain` = @HP, `diff_size` = @CS, `bpm` = @BPM, `max_combo` = @MaxCombo, `countNormal` = @CountCircle, `countSlider` = @CountSlider, `countSpinner` = @CountSpinner, `countTotal` = @CountTotal", param); } else { conn.Execute( - "UPDATE `osu_beatmaps` SET `difficultyrating` = @Diff, `diff_approach` = @AR, `diff_overall` = @OD, `diff_drain` = @HP, `diff_size` = @CS, `bpm` = @BPM , `max_combo` = @MaxCombo " + "UPDATE `osu_beatmaps` SET `difficultyrating` = @Diff, `diff_approach` = @AR, `diff_overall` = @OD, `diff_drain` = @HP, `diff_size` = @CS, `bpm` = @BPM , `max_combo` = @MaxCombo, `countNormal` = @CountCircle, `countSlider` = @CountSlider, `countSpinner` = @CountSpinner, `countTotal` = @CountTotal " + "WHERE `beatmap_id` = @BeatmapId", param); } From f4036d80ffd1f2e1e845c3cb54f0e0b57bfcd4ba Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Fri, 15 Nov 2024 19:26:24 +0900 Subject: [PATCH 4/4] Update packages everywhere --- .../osu.Server.DifficultyCalculator.csproj | 18 +++++++++--------- .../osu.Server.Queues.BeatmapProcessor.csproj | 2 +- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/osu.Server.DifficultyCalculator/osu.Server.DifficultyCalculator.csproj b/osu.Server.DifficultyCalculator/osu.Server.DifficultyCalculator.csproj index f644314..ff0328f 100644 --- a/osu.Server.DifficultyCalculator/osu.Server.DifficultyCalculator.csproj +++ b/osu.Server.DifficultyCalculator/osu.Server.DifficultyCalculator.csproj @@ -13,15 +13,15 @@ - - - - - - - - - + + + + + + + + + diff --git a/osu.Server.Queues.BeatmapProcessor/osu.Server.Queues.BeatmapProcessor.csproj b/osu.Server.Queues.BeatmapProcessor/osu.Server.Queues.BeatmapProcessor.csproj index 586e4fd..8ea87f3 100644 --- a/osu.Server.Queues.BeatmapProcessor/osu.Server.Queues.BeatmapProcessor.csproj +++ b/osu.Server.Queues.BeatmapProcessor/osu.Server.Queues.BeatmapProcessor.csproj @@ -11,7 +11,7 @@ - +