Optimize GC for frame calculation.
This commit is contained in:
@@ -10,6 +10,7 @@ namespace Cryville.Crtr {
|
||||
|
||||
SquareMatrix matFrame;
|
||||
ContainerState[] tracks;
|
||||
public int TrackCount { get { return tracks.Length; } }
|
||||
|
||||
public GroupHandler(Chart.Group tg, ChartHandler ch) : base() {
|
||||
this.ch = ch;
|
||||
@@ -25,14 +26,17 @@ namespace Cryville.Crtr {
|
||||
select c.Value
|
||||
).ToArray();
|
||||
matFrame = SquareMatrix.WithPolynomialCoefficients(tracks.Length);
|
||||
frame = new ColumnVector<Vector3>(tracks.Length);
|
||||
frame1 = new ColumnVector<Vector3>(tracks.Length);
|
||||
frame2 = new ColumnVector<Vector3>(tracks.Length);
|
||||
}
|
||||
|
||||
ColumnVector<Vector3> frame;
|
||||
ColumnVector<Vector3> frame1;
|
||||
ColumnVector<Vector3> frame2;
|
||||
public ColumnVector<Vector3> GetCurrentFrame(Func<ContainerState, Vector3> func) {
|
||||
for (int i = 0; i < tracks.Length; i++)
|
||||
frame[i] = func(tracks[i]);
|
||||
return matFrame.Eliminate(frame, Vector3Operator.Instance);
|
||||
frame1[i] = func(tracks[i]);
|
||||
matFrame.Eliminate(frame1, frame2, Vector3Operator.Instance);
|
||||
return frame2;
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -50,6 +50,7 @@ namespace Cryville.Crtr {
|
||||
|
||||
public override void PreInit() {
|
||||
base.PreInit();
|
||||
coeffs = new ColumnVector<float>(gh.TrackCount);
|
||||
foreach (var j in Event.judges) {
|
||||
judges.Add(j, new JudgeState(this, j.Id.Key));
|
||||
}
|
||||
@@ -132,6 +133,7 @@ namespace Cryville.Crtr {
|
||||
}
|
||||
|
||||
readonly List<Vector3> ctrl = new List<Vector3>(2);
|
||||
ColumnVector<float> coeffs;
|
||||
Vector3 GetFrame(ContainerState state, float track, Func<ContainerState, Vector3> func) {
|
||||
// TODO
|
||||
int id = Mathf.FloorToInt(track);
|
||||
@@ -160,12 +162,8 @@ namespace Cryville.Crtr {
|
||||
}
|
||||
if (ctrl.Count == 0) {
|
||||
var frame = gh.GetCurrentFrame(func);
|
||||
return frame.Dot(
|
||||
ColumnVector<float>.WithPolynomialCoefficients(
|
||||
frame.Size, track
|
||||
),
|
||||
Vector3Operator.Instance
|
||||
);
|
||||
ColumnVector<float>.FillWithPolynomialCoefficients(coeffs, track);
|
||||
return frame.Dot(coeffs, Vector3Operator.Instance);
|
||||
}
|
||||
else if (ctrl.Count == 1) {
|
||||
return nt * (nt * p1 + t * (ctrl[0] + p1)) + t * t * p2;
|
||||
|
Reference in New Issue
Block a user