Use new function plotMDSUsingSEs() in vignette.
Remove Author and Maintainer fields from DESCRIPTION again.
New function plotMDSUsingSEs().
Add Mengbo Li as joint maintainer. Add Author and Maintainer fields to DESCRIPTION.
New argument 'chunk' for dpcQuant() and dpcImpute().
dpcImpute() now passes the 'verbose' argument to peptides2Proteins().
Add more background information to the vignette, including references for DIA-NN, Spectronaut and MaxQuant. Add mention of voomaLmFitWithImputation().
Bug fix to starting values in peptides2Proteins() for single-peptide proteins.
expTiltByColumns() is now more robust for datasets with very few rows, especially when the column variance is exactly zero by chance. It originally assumed that the number of rows would always be large. This also improves the robustness of imputeByExpTilt().
peptides2Proteins() now runs imputeByExpTilt() on the whole dataset in order to get starting values for each protein. This improves speed slightly and makes the starting values more robust for large datasets with many NAs.
readDIANN() now supports DIA-NN output in either tsv or Parquet formats.
New functions dpcImpute() and dpcImputeHyperparam() to facilitate imputation and differential expression analysis at the peptide level. This may be needed for phosphoproteomics and analogous applications.
Package title changed to "Quantification and Differential Analysis of Proteomics Data", and package description expanded.
New function plotProtein(), to plot the quantifications for a given protein with error bars.
Cleanup annotation output from dpcQuant() to remove peptide-level annotation columns
dpc() now outputs 'n.detected' for each peptide.
dpc() now checks for peptides that are entirely missing.
plotDPC() now accepts input from either dpc() or dpcCN(). It now estimates jittering amount automatically.
Add readDIANN() code to vignette.
Add peptide filtering to vignette.
New function voomaLmFitWithImputation(), which is the same as limma::voomaLmFit() except that it allows for loss of degrees of freedom when all the values for a particular protein in a particular group are imputed and identical. dpcDE() now calls thew new function instead of limma::voomaLmFit(), making the differential expression analysis more robust to high rates of missing values.
Fix dpcQuant() 'genes' output when the input 'y' is a plain matrix instead of an 'EList' object.
New argument 'dpc.slope' for dpcQuant(), to allow the use of a preset DPC slope.
estimateDPCIntercept() now allows 'dpc.slope=0', corresponding to the case that missing values are uninformative.
Initial public release of the limpa package ("Linear Models for Proteomics Data") at https://github.com/SmythLab/limpa with the following exported functions: completeMomentsON, dpc, dpcCN, dpcDE, dpcQuant, dpcQuant.default, dpcQuant.EList, dpcQuantHyperparam, dztbinom, estimateDPCIntercept, expTiltByColumns, expTiltByRows, filterCompoundProteins, filterCompoundProteins.default, filterCompoundProteins.EList, filterCompoundProteins.EListRaw, filterNonProteotypicPeptides, filterNonProteotypicPeptides.default, filterNonProteotypicPeptides.EList, filterNonProteotypicPeptides.EListRaw, filterSingletonPeptides, filterSingletonPeptides.default, filterSingletonPeptides.EList, filterSingletonPeptides.EListRaw, fitZTLogit, imputeByExpTilt, imputeByExpTilt.default, imputeByExpTilt.EList, imputeByExpTilt.EListRaw, observedMomentsCN, peptides2ProteinBFGS, peptides2ProteinNewton, peptides2Proteins, peptides2ProteinWithoutNAs, plotDPC, proteinResVarFromCompletePeptideData, pztbinom, readDIANN, readSpectronaut, removeNARows, removeNARows.default, removeNARows.EList, simCompleteDataCN, simCompleteDataON, simProteinDataSet.