mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 18:03:11 +08:00
Resolve errors + auto-format
This commit is contained in:
parent
d613888803
commit
779af48802
@ -1,15 +1,12 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using osu.Game.Rulesets.Difficulty.Preprocessing;
|
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Taiko.Difficulty.Preprocessing
|
namespace osu.Game.Rulesets.Taiko.Difficulty.Preprocessing
|
||||||
{
|
{
|
||||||
public class StaminaCheeseDetector
|
public class StaminaCheeseDetector
|
||||||
{
|
{
|
||||||
|
|
||||||
private const int roll_min_repetitions = 12;
|
private const int roll_min_repetitions = 12;
|
||||||
private const int tl_min_repetitions = 16;
|
private const int tl_min_repetitions = 16;
|
||||||
|
|
||||||
@ -39,6 +36,7 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Preprocessing
|
|||||||
if (history.Count > 2 * patternLength) history.RemoveAt(0);
|
if (history.Count > 2 * patternLength) history.RemoveAt(0);
|
||||||
|
|
||||||
bool isRepeat = true;
|
bool isRepeat = true;
|
||||||
|
|
||||||
for (int j = 0; j < patternLength; j++)
|
for (int j = 0; j < patternLength; j++)
|
||||||
{
|
{
|
||||||
if (history[j].IsKat != history[j + patternLength].IsKat)
|
if (history[j].IsKat != history[j + patternLength].IsKat)
|
||||||
@ -62,13 +60,13 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Preprocessing
|
|||||||
(hitObjects[i]).StaminaCheese = true;
|
(hitObjects[i]).StaminaCheese = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void findTLTap(int parity, bool kat)
|
private void findTLTap(int parity, bool kat)
|
||||||
{
|
{
|
||||||
int tl_length = -2;
|
int tl_length = -2;
|
||||||
|
|
||||||
for (int i = parity; i < hitObjects.Count; i += 2)
|
for (int i = parity; i < hitObjects.Count; i += 2)
|
||||||
{
|
{
|
||||||
if (kat == hitObjects[i].IsKat)
|
if (kat == hitObjects[i].IsKat)
|
||||||
@ -90,6 +88,5 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Preprocessing
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Game.Rulesets.Difficulty.Preprocessing;
|
using osu.Game.Rulesets.Difficulty.Preprocessing;
|
||||||
using osu.Game.Rulesets.Objects;
|
using osu.Game.Rulesets.Objects;
|
||||||
using osu.Game.Rulesets.Taiko.Objects;
|
using osu.Game.Rulesets.Taiko.Objects;
|
||||||
@ -27,12 +26,15 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Preprocessing
|
|||||||
public TaikoDifficultyHitObject(HitObject hitObject, HitObject lastObject, HitObject lastLastObject, double clockRate)
|
public TaikoDifficultyHitObject(HitObject hitObject, HitObject lastObject, HitObject lastLastObject, double clockRate)
|
||||||
: base(hitObject, lastObject, clockRate)
|
: base(hitObject, lastObject, clockRate)
|
||||||
{
|
{
|
||||||
|
var lastHit = lastObject as Hit;
|
||||||
|
var currentHit = hitObject as Hit;
|
||||||
|
|
||||||
NoteLength = DeltaTime;
|
NoteLength = DeltaTime;
|
||||||
double prevLength = (lastObject.StartTime - lastLastObject.StartTime) / clockRate;
|
double prevLength = (lastObject.StartTime - lastLastObject.StartTime) / clockRate;
|
||||||
Rhythm = TaikoDifficultyHitObjectRhythm.GetClosest(NoteLength / prevLength);
|
Rhythm = TaikoDifficultyHitObjectRhythm.GetClosest(NoteLength / prevLength);
|
||||||
RhythmID = Rhythm.ID;
|
RhythmID = Rhythm.ID;
|
||||||
HasTypeChange = lastObject is RimHit != hitObject is RimHit;
|
HasTypeChange = lastHit?.Type != currentHit?.Type;
|
||||||
IsKat = lastObject is RimHit;
|
IsKat = lastHit?.Type == HitType.Rim;
|
||||||
HasTimingChange = !TaikoDifficultyHitObjectRhythm.IsRepeat(RhythmID);
|
HasTimingChange = !TaikoDifficultyHitObjectRhythm.IsRepeat(RhythmID);
|
||||||
|
|
||||||
n = counter;
|
n = counter;
|
||||||
@ -40,7 +42,5 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Preprocessing
|
|||||||
}
|
}
|
||||||
|
|
||||||
public const int CONST_RHYTHM_ID = 0;
|
public const int CONST_RHYTHM_ID = 0;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,8 +17,10 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
private ColourSwitch lastColourSwitch = ColourSwitch.None;
|
private ColourSwitch lastColourSwitch = ColourSwitch.None;
|
||||||
private int sameColourCount = 1;
|
private int sameColourCount = 1;
|
||||||
|
|
||||||
private int[] previousDonLengths = {0, 0}, previousKatLengths = {0, 0};
|
private int[] previousDonLengths = { 0, 0 }, previousKatLengths = { 0, 0 };
|
||||||
|
|
||||||
private int sameTypeCount = 1;
|
private int sameTypeCount = 1;
|
||||||
|
|
||||||
// TODO: make this smarter (dont initialise with "Don")
|
// TODO: make this smarter (dont initialise with "Don")
|
||||||
private bool previousIsKat = false;
|
private bool previousIsKat = false;
|
||||||
|
|
||||||
@ -29,11 +31,10 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
|
|
||||||
protected double StrainValueOfNew(DifficultyHitObject current)
|
protected double StrainValueOfNew(DifficultyHitObject current)
|
||||||
{
|
{
|
||||||
|
|
||||||
double returnVal = 0.0;
|
double returnVal = 0.0;
|
||||||
double returnMultiplier = 1.0;
|
double returnMultiplier = 1.0;
|
||||||
|
|
||||||
if (previousIsKat != ((TaikoDifficultyHitObject) current).IsKat)
|
if (previousIsKat != ((TaikoDifficultyHitObject)current).IsKat)
|
||||||
{
|
{
|
||||||
returnVal = 1.5 - (1.75 / (sameTypeCount + 0.65));
|
returnVal = 1.5 - (1.75 / (sameTypeCount + 0.65));
|
||||||
|
|
||||||
@ -78,10 +79,8 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
previousDonLengths[0] = sameTypeCount;
|
previousDonLengths[0] = sameTypeCount;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sameTypeCount = 1;
|
sameTypeCount = 1;
|
||||||
previousIsKat = ((TaikoDifficultyHitObject) current).IsKat;
|
previousIsKat = ((TaikoDifficultyHitObject)current).IsKat;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
@ -94,7 +93,6 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
|
|
||||||
protected double StrainValueOfOld(DifficultyHitObject current)
|
protected double StrainValueOfOld(DifficultyHitObject current)
|
||||||
{
|
{
|
||||||
|
|
||||||
double addition = 0;
|
double addition = 0;
|
||||||
|
|
||||||
// We get an extra addition if we are not a slider or spinner
|
// We get an extra addition if we are not a slider or spinner
|
||||||
@ -112,10 +110,9 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
return addition;
|
return addition;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private bool hasColourChange(DifficultyHitObject current)
|
private bool hasColourChange(DifficultyHitObject current)
|
||||||
{
|
{
|
||||||
var taikoCurrent = (TaikoDifficultyHitObject) current;
|
var taikoCurrent = (TaikoDifficultyHitObject)current;
|
||||||
|
|
||||||
if (!taikoCurrent.HasTypeChange)
|
if (!taikoCurrent.HasTypeChange)
|
||||||
{
|
{
|
||||||
@ -139,6 +136,5 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
Even,
|
Even,
|
||||||
Odd
|
Odd
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,6 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
{
|
{
|
||||||
public class Rhythm : Skill
|
public class Rhythm : Skill
|
||||||
{
|
{
|
||||||
|
|
||||||
protected override double SkillMultiplier => 1;
|
protected override double SkillMultiplier => 1;
|
||||||
protected override double StrainDecayBase => 0;
|
protected override double StrainDecayBase => 0;
|
||||||
private const double strain_decay = 0.96;
|
private const double strain_decay = 0.96;
|
||||||
@ -64,8 +63,9 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
{
|
{
|
||||||
currentStrain *= strain_decay;
|
currentStrain *= strain_decay;
|
||||||
|
|
||||||
TaikoDifficultyHitObject currentHO = (TaikoDifficultyHitObject) dho;
|
TaikoDifficultyHitObject currentHO = (TaikoDifficultyHitObject)dho;
|
||||||
rhythmLength += 1;
|
rhythmLength += 1;
|
||||||
|
|
||||||
if (!currentHO.HasTimingChange)
|
if (!currentHO.HasTimingChange)
|
||||||
{
|
{
|
||||||
return 0.0;
|
return 0.0;
|
||||||
@ -77,6 +77,7 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
|
|
||||||
ratioObjectHistory.Add(currentHO);
|
ratioObjectHistory.Add(currentHO);
|
||||||
ratioHistoryLength += 1;
|
ratioHistoryLength += 1;
|
||||||
|
|
||||||
if (ratioHistoryLength > ratio_history_max_length)
|
if (ratioHistoryLength > ratio_history_max_length)
|
||||||
{
|
{
|
||||||
ratioObjectHistory.RemoveAt(0);
|
ratioObjectHistory.RemoveAt(0);
|
||||||
@ -88,6 +89,7 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
for (int start = ratioHistoryLength - l - 1; start >= 0; start--)
|
for (int start = ratioHistoryLength - l - 1; start >= 0; start--)
|
||||||
{
|
{
|
||||||
bool samePattern = true;
|
bool samePattern = true;
|
||||||
|
|
||||||
for (int i = 0; i < l; i++)
|
for (int i = 0; i < l; i++)
|
||||||
{
|
{
|
||||||
if (ratioObjectHistory[start + i].RhythmID != ratioObjectHistory[ratioHistoryLength - l + i].RhythmID)
|
if (ratioObjectHistory[start + i].RhythmID != ratioObjectHistory[ratioHistoryLength - l + i].RhythmID)
|
||||||
@ -105,7 +107,6 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (currentHO.Rhythm.IsSpeedup())
|
if (currentHO.Rhythm.IsSpeedup())
|
||||||
{
|
{
|
||||||
objectDifficulty *= 1;
|
objectDifficulty *= 1;
|
||||||
@ -126,8 +127,6 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
|
|
||||||
currentStrain += objectDifficulty;
|
currentStrain += objectDifficulty;
|
||||||
return currentStrain;
|
return currentStrain;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,24 +1,20 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using osu.Game.Rulesets.Difficulty.Preprocessing;
|
using osu.Game.Rulesets.Difficulty.Preprocessing;
|
||||||
using osu.Game.Rulesets.Difficulty.Skills;
|
using osu.Game.Rulesets.Difficulty.Skills;
|
||||||
using osu.Game.Rulesets.Objects;
|
|
||||||
using osu.Game.Rulesets.Taiko.Difficulty.Preprocessing;
|
using osu.Game.Rulesets.Taiko.Difficulty.Preprocessing;
|
||||||
using osu.Game.Rulesets.Taiko.Objects;
|
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
||||||
{
|
{
|
||||||
public class Stamina : Skill
|
public class Stamina : Skill
|
||||||
{
|
{
|
||||||
|
|
||||||
private int hand;
|
private int hand;
|
||||||
private int noteNumber = 0;
|
private int noteNumber = 0;
|
||||||
|
|
||||||
protected override double SkillMultiplier => 1;
|
protected override double SkillMultiplier => 1;
|
||||||
|
|
||||||
protected override double StrainDecayBase => 0.4;
|
protected override double StrainDecayBase => 0.4;
|
||||||
// i only add strain every second note so its kind of like using 0.16
|
// i only add strain every second note so its kind of like using 0.16
|
||||||
|
|
||||||
@ -51,7 +47,7 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
{
|
{
|
||||||
noteNumber += 1;
|
noteNumber += 1;
|
||||||
|
|
||||||
TaikoDifficultyHitObject currentHO = (TaikoDifficultyHitObject) current;
|
TaikoDifficultyHitObject currentHO = (TaikoDifficultyHitObject)current;
|
||||||
|
|
||||||
if (noteNumber % 2 == hand)
|
if (noteNumber % 2 == hand)
|
||||||
{
|
{
|
||||||
@ -87,17 +83,18 @@ namespace osu.Game.Rulesets.Taiko.Difficulty.Skills
|
|||||||
if (d < minimum)
|
if (d < minimum)
|
||||||
minimum = d;
|
minimum = d;
|
||||||
}
|
}
|
||||||
|
|
||||||
return minimum;
|
return minimum;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Stamina(bool rightHand)
|
public Stamina(bool rightHand)
|
||||||
{
|
{
|
||||||
hand = 0;
|
hand = 0;
|
||||||
|
|
||||||
if (rightHand)
|
if (rightHand)
|
||||||
{
|
{
|
||||||
hand = 1;
|
hand = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,6 @@ namespace osu.Game.Rulesets.Taiko.Difficulty
|
|||||||
{
|
{
|
||||||
public class TaikoDifficultyCalculator : DifficultyCalculator
|
public class TaikoDifficultyCalculator : DifficultyCalculator
|
||||||
{
|
{
|
||||||
|
|
||||||
private const double rhythmSkillMultiplier = 0.15;
|
private const double rhythmSkillMultiplier = 0.15;
|
||||||
private const double colourSkillMultiplier = 0.01;
|
private const double colourSkillMultiplier = 0.01;
|
||||||
private const double staminaSkillMultiplier = 0.02;
|
private const double staminaSkillMultiplier = 0.02;
|
||||||
@ -56,14 +55,13 @@ namespace osu.Game.Rulesets.Taiko.Difficulty
|
|||||||
|
|
||||||
private double combinedDifficulty(Skill colour, Skill rhythm, Skill stamina1, Skill stamina2)
|
private double combinedDifficulty(Skill colour, Skill rhythm, Skill stamina1, Skill stamina2)
|
||||||
{
|
{
|
||||||
|
|
||||||
double staminaRating = (stamina1.DifficultyValue() + stamina2.DifficultyValue()) * staminaSkillMultiplier;
|
double staminaRating = (stamina1.DifficultyValue() + stamina2.DifficultyValue()) * staminaSkillMultiplier;
|
||||||
double readingPenalty = this.readingPenalty(staminaRating);
|
double readingPenalty = this.readingPenalty(staminaRating);
|
||||||
|
|
||||||
|
|
||||||
double difficulty = 0;
|
double difficulty = 0;
|
||||||
double weight = 1;
|
double weight = 1;
|
||||||
List<double> peaks = new List<double>();
|
List<double> peaks = new List<double>();
|
||||||
|
|
||||||
for (int i = 0; i < colour.StrainPeaks.Count; i++)
|
for (int i = 0; i < colour.StrainPeaks.Count; i++)
|
||||||
{
|
{
|
||||||
double colourPeak = colour.StrainPeaks[i] * colourSkillMultiplier * readingPenalty;
|
double colourPeak = colour.StrainPeaks[i] * colourSkillMultiplier * readingPenalty;
|
||||||
@ -71,6 +69,7 @@ namespace osu.Game.Rulesets.Taiko.Difficulty
|
|||||||
double staminaPeak = (stamina1.StrainPeaks[i] + stamina2.StrainPeaks[i]) * staminaSkillMultiplier;
|
double staminaPeak = (stamina1.StrainPeaks[i] + stamina2.StrainPeaks[i]) * staminaSkillMultiplier;
|
||||||
peaks.Add(norm(2, colourPeak, rhythmPeak, staminaPeak));
|
peaks.Add(norm(2, colourPeak, rhythmPeak, staminaPeak));
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach (double strain in peaks.OrderByDescending(d => d))
|
foreach (double strain in peaks.OrderByDescending(d => d))
|
||||||
{
|
{
|
||||||
difficulty += strain * weight;
|
difficulty += strain * weight;
|
||||||
@ -113,16 +112,17 @@ namespace osu.Game.Rulesets.Taiko.Difficulty
|
|||||||
MaxCombo = beatmap.HitObjects.Count(h => h is Hit),
|
MaxCombo = beatmap.HitObjects.Count(h => h is Hit),
|
||||||
Skills = skills
|
Skills = skills
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override IEnumerable<DifficultyHitObject> CreateDifficultyHitObjects(IBeatmap beatmap, double clockRate)
|
protected override IEnumerable<DifficultyHitObject> CreateDifficultyHitObjects(IBeatmap beatmap, double clockRate)
|
||||||
{
|
{
|
||||||
List<TaikoDifficultyHitObject> taikoDifficultyHitObjects = new List<TaikoDifficultyHitObject>();
|
List<TaikoDifficultyHitObject> taikoDifficultyHitObjects = new List<TaikoDifficultyHitObject>();
|
||||||
|
|
||||||
for (int i = 2; i < beatmap.HitObjects.Count; i++)
|
for (int i = 2; i < beatmap.HitObjects.Count; i++)
|
||||||
{
|
{
|
||||||
taikoDifficultyHitObjects.Add(new TaikoDifficultyHitObject(beatmap.HitObjects[i], beatmap.HitObjects[i - 1], beatmap.HitObjects[i - 2], clockRate));
|
taikoDifficultyHitObjects.Add(new TaikoDifficultyHitObject(beatmap.HitObjects[i], beatmap.HitObjects[i - 1], beatmap.HitObjects[i - 2], clockRate));
|
||||||
}
|
}
|
||||||
|
|
||||||
new StaminaCheeseDetector().FindCheese(taikoDifficultyHitObjects);
|
new StaminaCheeseDetector().FindCheese(taikoDifficultyHitObjects);
|
||||||
for (int i = 0; i < taikoDifficultyHitObjects.Count; i++)
|
for (int i = 0; i < taikoDifficultyHitObjects.Count; i++)
|
||||||
yield return taikoDifficultyHitObjects[i];
|
yield return taikoDifficultyHitObjects[i];
|
||||||
@ -148,6 +148,5 @@ namespace osu.Game.Rulesets.Taiko.Difficulty
|
|||||||
protected override DifficultyAttributes VirtualCalculate(IBeatmap beatmap, Mod[] mods, double clockRate)
|
protected override DifficultyAttributes VirtualCalculate(IBeatmap beatmap, Mod[] mods, double clockRate)
|
||||||
=> taikoCalculate(beatmap, mods, clockRate);
|
=> taikoCalculate(beatmap, mods, clockRate);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user