From: Rudolf Polzer Date: Sat, 12 Nov 2011 21:44:39 +0000 (+0100) Subject: failed attempt to counter prediction error X-Git-Tag: xonotic-v0.6.0~74^2~100^2~96 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=16a7f29d7a76635794152e68d4e0c11a7abe016f;p=xonotic%2Fxonotic-data.pk3dir.git failed attempt to counter prediction error --- diff --git a/qcsrc/common/csqcmodel.qc b/qcsrc/common/csqcmodel.qc index 543075ce9b..7085d82cd0 100644 --- a/qcsrc/common/csqcmodel.qc +++ b/qcsrc/common/csqcmodel.qc @@ -89,6 +89,23 @@ vector player_org, player_vel; float player_sequence, player_pmflags; float pmoveframe; .float pmove_flags; +vector prediction_error; +float prediction_errortime; +float autocvar_cl_predictionerrorcompensation = 20; + +vector GetPredictionError() +{ + if(time < prediction_errortime) + return prediction_error * (prediction_errortime - time) * autocvar_cl_predictionerrorcompensation; + return '0 0 0'; +} + +void SetPredictionError(vector v) +{ + prediction_error = (prediction_errortime - time) * autocvar_cl_predictionerrorcompensation * prediction_error + v; + prediction_errortime = time + 1.0 / autocvar_cl_predictionerrorcompensation; +} + void Unpredict() { self.origin = player_org; @@ -122,16 +139,13 @@ void PredictTo(float endframe) } */ - print("Starting at ", vtos(self.origin), "\n"); while(pmoveframe < endframe) { - print("Running frame ", ftos(pmoveframe), " -> "); if (!getinputstate(pmoveframe)) { break; } runstandardplayerphysics(self); - print(vtos(self.origin), "\n"); pmoveframe++; } @@ -151,11 +165,10 @@ void CSQCModel_SetCamera() entity oldself; oldself = self; self = csqcmodel_me; - print("PREDICTED step forward\n"); PredictTo(clientcommandframe); self = oldself; - org = csqcmodel_me.origin + csqcmodel_me.view_ofs; + org = csqcmodel_me.origin + csqcmodel_me.view_ofs + GetPredictionError(); ang = R_SetView3fv(VF_ANGLES); // simulate missing engine features @@ -201,10 +214,9 @@ void CSQCModel_Read() vector o, v; o = self.origin; v = self.velocity; - print("REAL step forward\n"); PredictTo(servercommandframe + 1); float d; - d = (o - self.origin) * normalize(self.velocity); + SetPredictionError(o - self.origin); player_pmflags = self.pmove_flags; player_org = o; player_vel = self.velocity;