我想找出一种方法来增加向量元素的数量,以便在绘制这些向量的值时去除可见的角效应。举例来说,假设我有包含每10个元素的两个向量:在R中增加向量分辨率
a = c(4,2,10,5,3,4,8,9,6,2)
b = seq(0,4.5, by=0.5)
他们受到数据平滑,但我想,以增加他们的“分辨率”比10(长度),以获得更多的预测点。所以,换句话说,采用向量a,并在保持其一致性的同时加倍(例如)其元素的数量。将所得的载体应是这样的:
a = c(4,3,2,6,10,7,5,4,3,4,6,8,8.5,9,7.5,6,4,2,2)
。当然,在这种特殊情况下,我很容易计算的元件的平均成对。但我想有一个任意长度的广义方法。我曾尝试用:
seq(a[1],a[10], length.out=20)
但当然,因为只有向量的第一个和最后一个元素都采取了在考虑这个没有做这项工作。它适用于第二个矢量b虽然(其中包含横坐标值)。 任何帮助,将不胜感激。谢谢。 Marius。
您认为“保持其一致性”意思不是很清楚吗?只要符合最小值和最大值就可以了。 – Hansi 2012-04-10 12:15:19
你可能喜欢'splinefun'或'approxfun' – 2012-04-10 12:28:35
不,要得到任意两个连续的向量元素* a *并且在它们之间再加上2或3或者任何均匀分布的元素,但要尊重向量。例如,如果最初a [5] = 4和a [6] = 7和a [7] = 5,我在a [5]和a [6]之间以及a [6]和a [ 7]该矢量片应该是a1 [5] = 4; a1 [6] = 5,a1 [7] = 6,a1 [8] = 7,a1 [9] = 6.34,a1 [10] = 5.68,a1 [11] = 5,初始a [5] = a1 [5],a [6] = a1 [8]和a [7] = a1 [11] – Marius 2012-04-10 12:32:00