There is a newer version of the record available.

Published October 25, 2016 | Version v2.0.0
Software Open

PascalKieslich/mousetrap: mousetrap v2.0.0

  • 1. University of Mannheim

Description

General changes to all existing functions

  • Renamed show_progress argument to verbose (+ set default to FALSE).
  • Introduced dimensions argument to explicitly specify the names of the columns in the trajectory array that contain the mouse positions. In most cases, the default is c("xpos","ypos") as the x- and y-positions should be used. Note that in some functions (as specified in the documentation) the order of the labels matters, the first value will be taken as the label of the x-positions, the second as the label of the y-positions.
  • Introduced timestamps argument to explicitly specify the dimension in the trajectory array containing the timestamps.
  • Perform merging of trial and trajectory data (e.g., in mt_subset and mt_reshape) based on the rownames. Therefore, the mt_id column in data.frames is not needed anymore - but is kept for the convenience of the user. The column is called "mt_id" in import and measures functions. mt_reshape allows the user to specify the label of the mt_id column explicitly.
  • As a consequence of the previous changes: Removal of the internal variables mt_variable_labels and mt_id.
  • Removed "calculate" from all mt_calculate functions: mt_calculate_measures, mt_calculate_derivatives, mt_calculate_deviations are now called mt_measures, mt_derivatives, mt_deviations.
  • Introduction of internal utils function create_results (that simplifies including the newly created trajectories or measures in the existing mousetrap data object).
  • Performance improvement of reshaping, aggregation, and visualization functions through internal changes in mt_reshape: base::merge and reshape2 functions are replaced with functions from the tidyr and dplyr packages (and custom functions). Package dependencies were adjusted accordingly. As the dplyr functions may introduce additional classes for the reshaped data (such as grouped_df and tbl_df), a new argument (convert_df) is introduced that converts the reshaped data to "pure" data.frames by default (thereby dropping additional classes).

Changes in specific functions

  • mt_import_mousetrap, mt_import_long, mt_import_wide: Allow specifying several variables for the trial identifier in mt_id_label. A a new ID variable will be created by combining the values of each variable.
  • mt_import_mousetrap: Make import more robust against variables with empty logs (warning message is returned in the end) (closes #5, thanks to @sbrockhaus).
  • mt_import_long, mt_import_wide: Import any number of additional variables using add_labels (closes #4).
  • mt_import_long: Timestamps are no longer used for ordering if mt_seq_label is not provided. Instead, data will be imported in the order in which they were stored in raw_data.
  • mt_import_long: Improved speed by relying on functions from the tidyr and dplyr packages.
  • mt_space_normalize, mt_align_start: Introduction of dimensions argument and the corresponding arguments start and end (deprecate xpos_start/xpos_end/ypos_start/ypos_end). This also fixes the internal bug that in mt_align_start xpos_start was passed on as ypos_start to mt_space_normalize (instead of ypos_start).
  • mt_derivatives: Rename dimension argument to dimensions, enable function to work with an arbitrary number of dimensions.
  • mt_deviations: Vectorized function point_to_line for time speed up (closes #2, thanks to @sbrockhaus).
  • mt_measures: Allow for flexible dimension labels and rename all measures columns relating only to x- or y-positions depending on the values in dimensions (e.g., x_max becomes xpos_max, x_flips becomes xpos_flips). Change column label xy_dist to total_dist.
  • mt_measures: Simplify AUC calculation using the actual x- and y-positions . New AUC values correlate to 1.00 with old values in mt_example, but in some cases extremely small differences are possible (maximum difference of 2.328e-10 in mt_example).
  • mt_reshape, mt_aggregate, mt_aggregate_per_subject: Replace aggregation_function argument with .funs, which is passed on to the aggregation function(summarize_at). .funs also allows for specifying several aggregation functions.
  • mt_plot_per_trajectory: New arguments xlim and ylim for specifying the axes limits explicitly and axes_exact for plotting exact axes.
  • mt_plot_per_trajectory: New arguments rect, color, and fill for plotting rectangles (usually representing the response buttons).
  • mt_plot (and related functions): New argument points allows for plotting points.

New functions

  • mt_add_variables: add new variables to trajectory array.
  • mt_export_long: export mouse-tracking data in long format (wrapper for mt_reshape).
  • mt_export_wide: export mouse-tracking data in wide format (wrapper for mt_reshape).

Bugs fixed

  • mt_align_start: Fixed bug that xpos_start (instead of ypos_start) was passed on as ypos_start to mt_space_normalize.
  • mt_average: Fixed bug that if intervals were specified explicitly using intervals, the wrong interval size was used when averaging (the default size of 100 was used).

Files

PascalKieslich/mousetrap-v2.0.0.zip

Files (182.3 kB)

Name Size Download all
md5:84e1876c8d7541a69760d2740dd5d657
182.3 kB Preview Download

Additional details