我们在R中有以下代码(已经剥离到骨骼以进行调试)
tgtStart = 29593
for (i in tgtStart:tgtStart)
{
PricerData[i, 1] = 111
}
print(PricerData[29592,1])
Run Code Online (Sandbox Code Playgroud)
PricerData是一个超过29593的矩阵,预先填充了NA.
我不明白的是,PricerData [29592,1]将更改为111,此代码打印111,而不是我们预期的NA.
为了使它更精细,我今天结束的代码是:
tgtStart = 29593
for (i in tgtStart:tgtStart)
{
print(PricerData[i,1])
print(PricerData[i-1,1])
PricerData[i, 1] = 111
print(PricerData[i,1])
print(PricerData[i-1,1])
}
print(PricerData[29592,1])
Run Code Online (Sandbox Code Playgroud)
它将打印:
[1] NA
[1] NA
[1] 111
[1] NA
[1] 111
Run Code Online (Sandbox Code Playgroud)
一直如预期到最后,为什么我们开始之前的元素变化了?为什么不在循环中,只有在关闭for循环之后(哦,如果我们将29593更改为29596,所有都按预期工作,我不理解.).
另外,我不编码R,通常我正在做C++,我要理解R是一个基于它的向量,但请不要介意覆盖真正的基础知识.我们使用R版本2.4.1.5,x64
编辑:好的,很明显我从代码中删除了太多,所以对你来说问题就消失了,这里是完整的函数,作为参考,我不明白它给出的输出
LoadPricer <- function(instrument, colo, simDate, sliceSize, startTime, endTime, pricerName, pricerSettings, returnEmptyMatrixIfFileNotFound = FALSE)
{
fileName <- paste ( simulatorOutputBasePath, instrument, '\\', colo, '\\', format(simDate, '%Y%m%d'), '\\', sliceSize, '\\P#', pricerName, '#', pricerSettings, '.csv', sep='')
firstSliceRequest = GetSlicesSinceMidnight(startTime, sliceSize)
lastSliceRequest = GetSlicesSinceMidnight(endTime, sliceSize)
PricerData = as.matrix(matrix(NA, nrow=(lastSliceRequest - firstSliceRequest + 1), ncol = 1))
if (file.exists(fileName))
{
# Load entire file
AllData = as.data.frame(read.csv(fileName, header = TRUE, colClasses=c("customTimeFormat","numeric")))
if (dim(AllData)[1] > 0)
{
firstSliceData = GetSlicesSinceMidnight(as.POSIXlt(AllData[1,1]), sliceSize)
lastSliceData = GetSlicesSinceMidnight(as.POSIXlt(AllData[nrow(AllData),1]), sliceSize)
if ( firstSliceData <= lastSliceRequest & lastSliceData >= firstSliceRequest )
{
tgtStart = max(1, firstSliceData - firstSliceRequest + 1)
tgtEnd = min(lastSliceRequest - firstSliceRequest + 1, lastSliceData - firstSliceRequest + 1)
srcStart = max(1, firstSliceRequest - firstSliceData + 1)
srcEnd = min(lastSliceData - firstSliceData + 1, srcStart + tgtEnd - tgtStart)
#PricerData[as.integer(tgtStart):as.integer(tgtEnd),1] = AllData[as.integer(srcStart):as.integer(srcEnd),2]
for (i in tgtStart:tgtStart)
{
PricerData[i, 1] = 111# as.matrix(AllData[srcStart+i-tgtStart , 2])
}
}
}
}
else
{
if (returnEmptyMatrixIfFileNotFound) PricerData = matrix(NA, nrow=0, ncol=2)
print(paste('WARNING: Unable to load Pricer! File:', fileName))
}
return (PricerData)
}
Run Code Online (Sandbox Code Playgroud)
一个基于
> PricerData <- matrix(NA, 30000, ncol=1)
> tgtStart <- 29593
> for (i in tgtStart:tgtStart) PricerData[i, 1] <- 111
> print(PricerData[29592, 1])
[1] NA
> print(PricerData[29593, 1])
[1] 111
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6538 次 |
| 最近记录: |