- Added latest reference to the DESCRIPTION and README
- Added function
filter_func
as a parameter to themodel_in_situ()
function, which allows user to filter out outliers within each velocity bracket - Fixed the NA result in
model_in_situ()
function when using CV resulting in smaller number of observations in the velocity bracket thann_observations
parameter - In the
model_in_situ()
function, whenvelocity_threshold
is not provided (i.e.,NULL
), the finding of the peak acceleration and thus velocity threshold is applied afterfilter_func
. This is to avoid outliers to specifyvelocity_threshold
. The samevelocity_threshold
is used to train and test data sets when performing cross-validation.
- Fixed error in
predict_work_till_distance()
function - Added
model_timing_gates_FD_fixed()
andmodel_time_distance_FD_fixed()
which allow user to set the fixedFD
parameter. This was before done using additional parameter inmodel_timing_gates_FD()
andmodel_time_distance_FD()
functions, but now these functions only provide estimatedFD
. This is done to allow confidence intervals estimation, which was impossible to do since fixedFD
was also estimated, but it was constrained by the optimization function to user-provided value.
- For
model_in_situ()
function, the filtering parameters (velocity_threshold
,velocity_step
, andn_observations
) are returned in thecorrections
element of the returned object. These are also returned in theCV
element of the returned object for every cross-validation fold velocity_threshold
parameter in themodel_in_situ()
function is now by defaultNULL
, in which case the velocity of the observation with the fastest acceleration is taken as the cutoff value- Updated the in-situ examples in the README file
- Cleaned the
theme_bw()
from README and set defaultggplot
theme withggdist::ggdist()
- Fixed the error in README example for plotting the in-situ velocity-acceleration profile
- Fixed error in the
find_optimal_FV_scalar()
function and all upper-level calling functions which happens whenresistance
parameter is below zero - Added new publication in README and DESCRIPTION
- Rebuilt
split_times
since it hasAsIs
object, causing issues withggplot2
plotting in the README file
- Fixed the error in
model_radar_gun()
andmodel_laser_gun()
examples that happened onr-release-macos-arm64
andr-oldrel-macos-arm64
due to the perfect model fit causing "singular gradient matrix at initial parameter estimates". This is sorted by adding simple noise to the simulated data - Modified
model_in_situ()
function to now useminpack.lm::nlsLM()
instead ofstats::lm()
function, which now estimatesMSS
andMAC
parameters, and it is thus easier to read the code, and estimate the confidence intervals - Updated the DESCRIPTION file with better package description
- Fixed the sign error in the
get_air_resistance()
function where both head wind and tail wind returned the same resistance. - Fixed the error in
make_FV_profile()
function when estimating force-velocity profile with wind conditions. - Fixed the error in
convert_FV()
function when converting force-velocity profile back to acceleration-velocity profile with wind conditions.
- Renamed the
make_FV_profile()
function tocreate_FVP()
. - Renamed the
convert_FV()
function toconvert_FVP()
. - Renamed the output of
predict_kinematics()
functionrelative_power
topower_relative
to be in alignment with other variables. - Added
work
,average_power
, andaverage_power_relative
to the output ofpredict_kinematics()
function, and removednet_horizontal_force
from the output to avoid confusion whether the inertia is included or not. - Updated internal
shorts_model_fit()
function to return model fit metrics in both absolute and percentage forms. - Added internal
model_sprint()
wrapper function and updated internalnew_shorts_model()
constructor which provide changes in the model output format ("shorts_model"
class). This will create BREAK CHANGE from the previous versions of the{shorts}
package.
- Added
predict_work_till_time()
andpredict_work_till_distance()
to calculate horizontal work performance. - Rewritten
model_radar_gun()
and added aliasmodel_laser_gun()
function. - Rewritten
model_timing_gates()
,model_timing_gates_TC()
,model_timing_gates_FD()
, andmodel_timing_gaes_FD_TC()
, functions. Now theTC
parameter has positive sign. - Rewritten
model_tether()
andmodel_tether_DC()
functions. Changed the sign of theDC
parameter. - Rewritten
model_
family of functions to includepredict_
function in the model definition. NowMSS
andMAC
are estimated, rather thanMSS
andTAU
. This improves readability of the model definition. Also movedMAC
in the output afterMSS
parameter. - Removed
model_timing_gates_FD_TC()
function. - Added
model_timing_gates_DC()
andmodel_timing_gates_TC_DC()
functions. - Added
model_in_situ()
function which performs embedded (i.e., in-situ) analysis of the session monitoring data using GPS or LPS systems which provide instantaneous acceleration and velocity. - Added
model_time_distance()
,model_time_distance_TC()
,model_time_distance_DC()
,model_time_distance_TC_DC()
, andmodel_time_distance_FD()
functions. These are exactly the same asmodel_timing_gates
family of functions, but with reverse predictor and outcome variables. - Added
create_sprint_trace()
function for quickly creating sprint traces with time- and distance-shifts, as well as flying starts. Useful for creating examples for issues in modeling sprint traces. - Updated S3 print and plot methods for the
"shorts_model"
class. The plot method now plots four different types of plots, depending on thetype
argument: "model" (default), "kinematics-time", "kinematics-distance", or "residuals". - Added
confint
S3 method to provide confidence intervals of the parameters. - Changed
coef
S3 method to return all model parameters, not only sprint parameters.
- Updated examples for the
model_
family of functions. - Added
LPS_session
dataset. This dataset represents a sample data provided by Local Positioning System (LPS) on a single individual performing a single basketball practice session (aprox. 90min). Sampling frequency is 20Hz. - Added
dynaspeed
dataset. - Added
laser_gun_data
dataset. - Updated README to cover changes.
- Removed Jason Vescovi from the authorship in the DESCRIPTION file and CITATION. Jason is still referenced in the dataset he provided
- Added
inertia
(mass; in kg) andresistance
(force; in Newtons) topredict_force_
,predict_power_
,predict_relative_power_
, as well aspredict_kinematics()
functions. This increases the ability of the {shorts} package to deal with external resistance, like weight vest, sled, and tether devices. - Modified
predict_kinematics()
function to includeinertia
(mass; in kg) andresistance
(force; in Newtons) parameters, as well as to allow the user to either provide theshorts_model
object, or provideMSS
andMAC
parameters. Additional parameteradd_inertia_to_vertical
to allow user to decided whether inertia should be added tobodymass
when calculating vertical force. - Added
predict_force_at_velocity()
function - Modified
find_max_power_
andfind_power_critial_
function to add support for theinertia
(mass; in kg) andresistance
(force; in Newtons) parameters - Simplified
make_FV_profile()
function and added support for theinertia
(mass; in kg) andresistance
(force; in Newtons) parameters. Removed the S3 print and plot methods, as well as the class type involving this function - Made internal
convert_FV()
function available for the users and added support for theinertia
(mass; in kg) andresistance
(force; in Newtons) parameters - Updated
predict_time_at_distance_FV()
function to use simplerconvert_FV()
function - Renamed
find_max_power
functions tofind_peak_power
to avoid confusion betweenPmax
andPpeak
- Implemented
inertia
(mass; in kg) andresistance
(force; in Newtons) tooptimal_FV()
function - Implemented
inertia
(mass; in kg) andresistance
(force; in Newtons) toprobe_FV()
function - I added the
model_tether_DC()
function with an additionaldistance correction
(DC) parameter estimate. DC parameter serves as an intercept when distance doesn't start at zero
- Removed "Suggest" from the package DESCRIPTION file
- Added
use_observed_MSS
parameter tomodel_radar_gun()
andmodel_tether()
functions. This allows user to estimateMSS
parameter from the observed data - Add
FD
parameter tomodel_timing_gates_FD()
andmodel_timing_gates_FD_TC()
functions, which allow user to provide fixedFD
parameter value. - Updated README.Rmd file with the example on how to use these feature. Also added a reference to a published article that was previously available only as pre-print.
- Changed generic
predict()
function not to return fitted values, but to use generic predict method on the object. This allows user to usenewdata
parameter. Addedfitted()
method to return fitted values instead
- Moved optimal profile functions to "optional-functions.R" file, with accompanying documentation name
- Renamed the
FV_slope_perc
toprofile_imb
in the output of theoptimal_
functions - The functions
find_optimal_FV()
andfind_optimal_FV_peak()
are now wrapped inside theoptimal_FV
, but the method is selected usingmethod
parameter ("max" forfind_optimal_FV()
and "peak" forfind_optimal_FV_peak()
). Please refer to examples - Probing analysis is now removed from
optimal_
functions and moved toprobe_FV()
andprobe_MSS_MAC()
functions. Please refer to examples - Finding for the distance where the profile is optimal is now done using the
find_optimal_distance()
function that can take other optimal and probe functions as parameter. Please refer to examples - Removed a bug in
find_optimal_FV_peak()
(now implemented infind_optimal_FV()
function usingmethod="peak"
parameter) where information needed to calculate air resistance was not forwarded
- Expanded the results output of the
find_optimal_MSS_MAC()
andfind_optimal_FV()
functions. Some of the columns are renamed to better clarity - Added internal function
convert_FV()
to convert from FV profile to sprint profile. This is used to calculate Peak Power (Ppeak
) metric and its location - Added
min_func
parameter tofind_optimal_MSS_MAC_distance()
andfind_optimal_FV_distance()
. This allows to optimize by using any other metric - Added
find_optimal_FV_peak()
function, which optimize the profile while keeping the Peak Power the same. Accompanyingfind_optimal_FV_peak_distance()
is also added - Added extra reference to DESCRIPTION
- Added mean acceleration over distance to
format_splits()
- Added
model_tether()
function for modeling data output from tether devices, which involve velocity at distance - Change the
Pmax_relative
toPmax_rel
in the output of themake_FV_profile()
function - Added analytically/polynomially estimated
F0_poly
,F0_poly_rel
,V0_poly
,Pmax_poly
,Pmax_poly_rel
, andFV_slope_poly
to the output of themake_FV_profile()
function using the method outlined in Pierre Samozino and Nicolas Peyror, et al (2021) <doi: 10.1111/sms.14097> - Added
predict_time_at_distance_FV()
which uses FV profile'sF0
andV0
to predict time at distance. For more info see Pierre Samozino and Nicolas Peyror, et al (2021) <doi: 10.1111/sms.14097> - Added optimization functions:
find_optimal_MSS_MAC()
,find_optimal_MSS_MAC_distance()
,find_optimal_FV()
,find_optimal_FV_distance()
. For more info on the FV optimization see Pierre Samozino and Nicolas Peyror, et al (2021) <doi: 10.1111/sms.14097> - Removed DOI from citation info
This is NEW version of the {shorts} package INCOMPATIBLE with the previous due to drastic changes in functions. Here are the changes utilized:
- Removed the mixed-effects function due to their small usage in practice.
- In
predict_
functions,time_correction
anddistance_correction
are no longer used, since due to novel models of estimation, it is hard to neatly implement them into functions. Now thepredict_
functions predict on a scale where sprint starts att=0
andd=0
, rather than on the original (data) scale. This will also remove the confusion for the user. - In
predict_
functions, the user now usesMSS
andMAC
parameters - Changed the non-linear regression estimation function from
stats::nls()
tominpack.lm::nlsLM()
inmodel_
functions. This is done to avoid "singular gradient" error and inability of thestats::nls()
to estimate when there are zero residuals. Please make note that now when you use...
inmodel_
function, it will be forwarded tominpack.lm::nlsLM()
. If you have been usingcontrol = stats::nls.control(warnOnly = TRUE)
to avoidstats::nls()
to throw error when fitting when there are zero residuals, now you can remove it. If needed usecontrol = minpack.lm::nls.lm.control()
instead. - Added
create_timing_gates_splits()
function to generate timing gates splits - For modeling timing gates, the following functions are now available:
model_timing_gates()
,model_timing_gates_TC()
,model_timing_gates_FD()
, andmodel_timing_gates_FD_TC()
. All other functions have been removed - For modeling radar gun data, there is now only one function
model_radar_gun()
which also estimates time correction (TC
) parameter. - Function
model_radar_gun()
feature n-folds cross-validation, as opposed tomodel_timing_gates()
family of functions, which features leave-one-out cross-validation (LOOCV) due to small number of observations. Using theCV
parameter, set n-fold cross-validations for themodel_radar_gun()
function. - Renamed the element
LOOCV
in theshorts_model
object toCV
to reflect above changes inmodel_radar_gun()
function - Removed vignettes. I am working on a better pre-print as well as one peer-reviewed simulation paper and will reference those instead
- Updated documentation regarding the below mentioned potential issues
- IMPORTANT: For the
model_using_splits_with_distance_correction()
function thepredict_XXX_at_distance()
family of functions doesn't work correctly ifdistance_correction
is used as parameter (i.e., different than zero). This is because the model definition is completely different, and predicting on the same distance scale is not possible. Please refer to Jovanović, M., Vescovi, J.D. (2020) for more information. - Jovanović, M., Vescovi, J.D. (2020). shorts: An R Package for Modeling Short Sprints. Preprint available at SportRxiv. https://doi.org/10.31236/osf.io/4jw62
- Fixed wrong error message from the
plot.shorts_fv_profile()
function - Minor model print aesthetic changes
- Fixed calculation of the residuals, which is now correctly calculated using observed - predicted. This calculation is implemented in the
residuals()
S3 method, as well as with internal functionshorts_model_fit()
that provides model fit estimates (i.e. RMSE, MAE, MAPE) - Fixed calculation of the residuals in the vignette
- Added
model_using_splits_with_distance_correction()
function that implements novel model definition to estimate flying start distance - Added
mixed_model_using_splits_with_distance_correction()
function that implements novel model definition to estimate flying start distance
- Added
ggplot2
andtidyr
package dependency and implemented it in S3 plotting functions get_FV_profile
now return a object classshorts_fv_profile
- Added S3 print and plot methods for
shorts_fv_profile
object - Renamed column
force
andrelative_force
tohorizontal_force
andrelative_horizontal_force
in theshorts_fv_profile
object and data frame returned by thepredict_kinematics
- Added
acceleration
,bodymass
,net_horizontal_force
,air_resistance
, andvertical_force
,resultant_force_relative
,power
, andforce_angle
in theshorts_fv_profile
object and data frame returned by thepredict_kinematics
- Improved examples and README.Rmd
- Added S3 plot method for
shorts_model
andshorts_mixed_model
objects
-
Added sample radar gun data from Jean-Benoît Morin Microsoft Excel spreadsheet, freely available at his website (accessed October 27, 2020)). For more information
?jb_morin
-
Added
get_FV_profile
for generating Force-Velocity profile summary using Pierre Samozino and Jean-Benoît Morin method (for more DOI:10.1111/sms.12490)
- Added
get_air_resistance
function to estimate air resistance in newtons - Added
predict_air_resistance_at_time
andpredict_air_resistance_at_time
functions - Added
predict_force_at_time
andpredict_force_at_distance
functions - Added
predict_power_at_time
andpredict_power_at_distance
functions - Now power calculations in
predict_relative_power_at_distance
andpredict_relative_power_at_time
use air resistance to do the calculations. The default bodymass is 75kg. To replicate earlier function behavior, usepredict_velocity_at_
multiplied bypredict_acceleration_at_
to get relative power without air resistance - Function
predict_kinematics
now uses aforementioned changes inpredict_relative_power_
functions, and added force and air resistance in the output - Functions
find_max_power_distance
andfind_power_critical_distance
now uses aforementioned changes and returns absolute power, rather than relative, and air resistance is used in the power calculations - Added
find_max_power_time
,find_velocity_critical_time
,find_acceleration_critical_time
, andfind_power_critical_time
functions - Added
model_using_radar_with_time_correction
where time_correction parameter is estimated - Added
mixed_model_using_radar_with_time_correction
where time_correction parameter is estimated
- Added James Vescovi contributed dataset (
data("vescovi")
). For more info see?vescovi
- Used constructor functions for all modeling functions
- Added modular short_model_fit function with three extra estimators: MAE, MAPE, and MaxAbsErr. This function is hidden from the user, but allows easier extension and modularity as well avoidance of code repetition
- Added
time_correction
anddistance_correction
to all model parameters output to align them - Added S3
predict_kinematics
function that predicts 0-6s distance (100Hz), velocity, acceleration, and relative power - Added S3
print
,coef
,summary
,predict
, andresiduals
methods - Added LOOCV option to modeling functions which provided cross-validated predictions and estimated model parameters
- Added
random
parameter tomixed_
family of functions to allow higher flexibility in model definitions, but removedcorrections_as_random_effects
parameter. The default behavious is to use all parameters as random effects. - Added
...
tomodel_using_radar
andmixed_model_using_radar
to be forwarded tonlme::nlme
- Expanded the Readme.md file
- Expanded the
sprint-corrections
vignette by adding a short simulation study
- Corrected the error in vignette that showed on Solaris system. Increased the random noise to allow nls to fit
- Renamed
time_delay
totime_correction
inshorts::model_using_instant_velocity
andshorts::mixed_model_using_instant_velocity
functions to be more consistent across functions. Also, this correction is added to time, so use negative numbers instead time_correction
inshorts::mixed_model_using_instant_velocity
andshorts::mixed_model_using_split_times
is now numeric vector, not column name- Implemented
time_correction
inshorts::model_using_split_times
andshorts::mixed_model_using_split_times
- Implemented
time_correction
inshorts:predict_
family of functions - Implemented
distance_correction
inshorts:predict_
family of functions - Implemented estimation of
time_correction
inshorts::model_using_split_times_with_time_correction
andshorts::mixed_model_using_split_times_with_time_correction
- Implemented estimation of
distance_correction
inshorts::model_using_split_times_with_corrections
andshorts::mixed_model_using_split_times_with_corrections
- Fixed error in calculating PMAX in
shorts::mixed_model_
functions - Removed
maxAbsErr
from model_fit element - Wrote "sprint-corrections" vignette explaining the idea behind sprint time and distance corrections
- Implemented
find_
family of functions for finding max power and critical distance when velocity or acceleration reaches certain threshold - Implemented
...
to all modeling functions so that extra parameters can be forwarded to the optimization engine - Data
split_times
recreated using distance shift behind the first timing gate. Needed to demo mixed models with corrections - Renamed
_model_using_instant_velocity
to_model_using_radar
- Renamed
_model_using_split_times_
to_model_using_splits_
- Initial version with all core functionalities
- This package was submitted to CRAN on 2020-04-17. (commit b59402c9c5)