Both of the lsmeans statements you show generate lists of lsmobjs, and each element of those lists is handled separately. If you want to incorporate an overall adjustment for two or more lists combined, it is technical and it takes a bit of work.
First, save the list:
lsmlist = lsmeans(warp.lm, list(pairwise ~ wool|tension,
pairwise ~ tension|wool))
This creates a list of 4 lsmobjs (originally two lists of two)
> names(lsmlist)
[1] "lsmeans of wool | tension"
[2] "pairwise differences of contrast, tension | tension"
[3] "lsmeans of tension | wool"
[4] "pairwise differences of contrast, wool | wool"
The user wants to combine the three comparisons in lsmlist[[2]] with the six in lsmlist[[4]] and have an overall multiplicity adjustment for those 9 comparisons.
To start, create a new lsmobj from one of the results, and fix it up.
mydiffs = lsmlist[[4]]
First, bind together the linear functions for the two sets of comparisons:
mydiffs@linfct = rbind(lsmlist[[2]]@linfct, lsmlist[[4]]@linfct)
We also need to define the grid slot, which defines the factors associated with each linear function. To make it simple, I just define a factor named contrast with 9 levels for the 9 contrasts (something fancier could be done here).
mydiffs@grid = data.frame(contrast = 1:9)
Finally, fix up the auxiliary info that does the bookkeeping. We now use our new contrast factor as the only variable, with no "by" variables. For the combined family of 9 contrasts, the Tukey adjustment makes no sense so we use the multivariate $t$ ("mvt") method:
mydiffs = update(mydiffs, pri.vars = "contrast", by.vars = NULL,
adjust="mvt")
Now, we can look at the resulting summary:
> mydiffs
contrast estimate SE df t.ratio p.value
1 16.3333333 5.157299 48 3.167 0.0205
2 -4.7777778 5.157299 48 -0.926 0.9119
3 5.7777778 5.157299 48 1.120 0.8258
4 20.5555556 5.157299 48 3.986 0.0019
5 20.0000000 5.157299 48 3.878 0.0026
6 -0.5555556 5.157299 48 -0.108 1.0000
7 -0.5555556 5.157299 48 -0.108 1.0000
8 9.4444444 5.157299 48 1.831 0.3796
9 10.0000000 5.157299 48 1.939 0.3190
P value adjustment: mvt method for 9 tests
I could consider adding a feature for combining pieces of lsm.list objects, but it is not straightforward -- primarily because of complications in obtaining meaningful labels for the results (the grid part). It is also a problem that different users expect different defaults.
pairsto get the contrasts you want. Read the vignette "using-lsmeans" for a lt of examples and discussion. – Russ Lenth Aug 07 '15 at 13:31tension = M: A - B -4.777778 5.157299 48 -0.926 0.3589
tension = H: A - B 5.777778 5.157299 48 1.120 0.2682
Should the p-values not be higher after the first command than the second? There are more comparisons to be made after the first command.
I tried the "pairs" route but the results are the same as "pairwise".
– Sam Aug 07 '15 at 14:54lsmeanspackage & I'd be grateful if you'd edit it further to explain what statistical analysis you're trying to carry out, & why the results are unexpected. – Scortchi - Reinstate Monica Aug 10 '15 at 08:56lsmeans. – Scortchi - Reinstate Monica Aug 10 '15 at 09:00