0

这是我在 StackOverflow 中的第一个问题,所以我希望能做对......

我试图用两个预测变量拟合一个黄土模型,其中一个是局部加权的,另一个是参数的。拟合模型后,我想在参数预测器上获得回归线的斜率,以非参数预测器的某个值为条件。当用回归线中的任何两个值计算这个斜率时,我应该得到一个与斜率相对应的常数值。但是,如果我用每两个连续值计算斜率,我会得到一条类似于抛物线的曲线。在这里,您有一些用于展示此问题的代码:

## DATA

criterion <- c(
  -1.8914741214789, -0.864604956700496, 2.43013372852099, -1.32227168040904, 
  0.861585875211724, -1.25506145955845, 1.1201893940246, -1.18560159611826, 
  1.24871681364416, -1.24362634687504, -2.22058652097061, -0.67920682239687, 
  -1.14096010679208, 0.228758533000768, -1.3607742780652, 0.473165865126464, 
  0.0438948075908679, -1.14355404117161, 2.60406860120487, 0.539583593348819, 
  -0.599388766026817, -1.14918693916554, -0.17334788506616, -0.836478866743926, 
  2.88908329995278, -0.401016464464891, -0.292311619619775, 1.12804091879547, 
  3.6733647991105, -3.31190363769332, -0.672558641084861, 0.498844902537884, 
  -0.037062115762172, -1.02017987978252, -0.854805324374525, 1.34168735130207, 
  -0.242996720017973, 1.14871933640721, -0.736312690622741, -2.51965992948912, 
  -3.16327863554555, -0.269020543067839, 0.552150179356176, 0.320523449469915, 
  1.14736382025547, 0.891590469554733, -0.717678520852477, 3.15631635301073, 
  -0.225648864790169, -1.35189421566795, -0.558073572773821, -1.33356547103824, 
  -2.01215450549957, 1.63719762873429, -2.0218275161466, 0.513289109719022, 
  -1.30263029019454, 1.85949704911488, -1.22544429584118, 0.336732253617053, 
  -2.45126282746359, -4.94155955259729, 0.743231639698684, 1.04320562270113, 
  3.99232225357353, -1.07752259470057, -0.353671379249384, -0.748973055922694, 
  0.467443998802691, 0.966013090920868, 1.32739645813748, 1.07159468103619, 
  -1.8542024758483, 0.360922743179635, -4.99642432601298, 0.596072047320551, 
  -1.48256500350222, -0.251689130094422, -0.104867519535428, -3.23675187957067, 
  1.15657910171856, -0.640772355492231, 2.21198640279181, -0.229386564567888, 
  -2.8014148535931, 0.325261825780768, 1.65431768179619, -0.701353356393564, 
  1.56301740126489, -2.91989037858617, 0.560634128846807, -3.40972988669857, 
  0.519955616184439, -0.673752119923202, -0.126511467211613, -1.49156456253545, 
  2.68041989003066, -3.18246878051744, -1.05338046600476, -0.122679130411665, 
  0.619202563903638, -2.80132012240656, -1.50106228060585, -1.78428153598023, 
  -0.17959372353835, -3.7657930817963, 1.74830598714522, 0.199267717912346, 
  -0.187088254090319, -0.431926901631399, -2.50168001668916, -0.715294537723936, 
  4.8050892573889, 3.48017935641437, -2.29413209640673, 1.88045620792631, 
  -0.125724128270772, -0.514660621563394, 1.28920199656138, -0.888250921411933, 
  -1.53336797414911, 0.566890809767711, 2.18492239723917, 1.45986142278563, 
  2.29475550546227, -2.91360806155925, -1.28474245565384, -1.15236199251384, 
  -2.68344935749574, -1.0406761060411, 0.236606541573282, -1.0577344636865
)


lw.predictor <- c(
  3.97543828892376, 3.74367045733871, 2.8031293667213, 3.12721154621725, 
  3.57809163186571, 3.85490258924953, 3.04509486547235, 3.06527167000886, 
  3.42172751371031, 3.48342454710053, 3.03382754767655, 3.29840143930276, 
  3.42532870135535, 3.3466401061363, 4.19719410513314, 4.27624851591474, 
  3.90521253346176, 3.66434131328865, 3.78008480009251, 3.26961939052607, 
  3.37557706887951, 3.07887188021758, 3.20615845753053, 3.25681582455448, 
  3.07575583761175, 3.4678563115072, 3.63412290863538, 2.7341072520575, 
  3.04486992771651, 4.0244118093156, 2.75978954925269, 2.94469571886678, 
  3.64916954335701, 3.23529338509991, 3.09993371559714, 3.92201374051927, 
  2.63693470862178, 3.19438720086359, 4.10395732841177, 4.14695795420843, 
  3.37963279191973, 2.75059146814963, 3.05430305033533, 4.07380539679535, 
  3.41070032578776, 3.52175236580135, 3.9922870844146, 2.83689005875791, 
  3.59280102122038, 3.744585131656, 4.07464596327428, 2.94632345777042, 
  3.79563556141373, 2.92157773101387, 3.60631105869347, 3.90380916892684, 
  3.4349134104059, 2.86428168814471, 2.80459505537921, 3.52738795051305, 
  3.90100092529829, 3.95557522270349, 2.88144750533953, 3.4177217437656, 
  2.72281079587565, 3.44307922077723, 3.58191805968554, 2.85374063580388, 
  3.61825659978916, 3.35154840518957, 2.78055872970075, 3.31559205647068, 
  3.72845408487401, 3.45439961676827, 3.47673283886995, 3.38348122582045, 
  2.88524826215121, 3.37314129436951, 4.17608980116535, 2.78621853030773, 
  4.23989532049638, 2.65428059546312, 2.75954135557898, 3.90836826127649, 
  3.70911502202012, 3.9502037401938, 2.72934334016319, 3.56908337873796, 
  3.53107535330031, 4.10445798400541, 3.37029733251965, 2.77784779211612, 
  4.00205426701893, 3.390559011573, 3.75061638769833, 3.67591196400612, 
  4.00034245109432, 4.19507212536165, 2.64290209936905, 2.84965751366817, 
  2.93584367468566, 3.5792399897338, 3.87103752330681, 4.11112756588916, 
  3.69820393282565, 3.47909608792875, 3.021611653787, 3.38833615773409, 
  3.53688974115618, 3.86802841711593, 3.04014239032067, 3.83441517392514, 
  2.78055872970075, 2.95676609717858, 3.46963343371941, 2.69652236718191, 
  4.21169279083643, 3.59508797308864, 2.90229007358549, 3.74055889165213, 
  4.22533130742836, 3.10942006661772, 2.81532012340698, 3.39540382330109, 
  3.11580153059886, 2.73435775434875, 3.80464748245529, 3.63431137604942, 
  4.09744323888573, 2.77908036429911, 3.30047734198123, 3.7238586557053
)


par.predictor <- c(
  94.3333333333333, 105.333333333333, 135.666666666667, 113.666666666667, 
  116.333333333333, 112.666666666667, 117.333333333333, 100.333333333333, 
  118, 118.333333333333, 119.666666666667, 109.666666666667, 116.333333333333, 
  107.666666666667, 110.666666666667, 97, 99.6666666666667, 108.666666666667, 
  118.333333333333, 119, 106.333333333333, 121.666666666667, 103, 
  132, 99, 121.666666666667, 99.6666666666667, 104.666666666667, 
  124.333333333333, 106.666666666667, 118.666666666667, 111, 125, 
  101.666666666667, 101, 103, 102, 108.333333333333, 119.333333333333, 
  131.333333333333, 105.666666666667, 118.666666666667, 124.333333333333, 
  111.333333333333, 108.333333333333, 126.666666666667, 111, 107.333333333333, 
  118.666666666667, 120.333333333333, 114, 117.666666666667, 118, 
  104.666666666667, 115.333333333333, 117.666666666667, 101.666666666667, 
  118, 103.333333333333, 120, 105, 106.666666666667, 104.333333333333, 
  112.333333333333, 109.333333333333, 103.333333333333, 114, 112, 
  122.333333333333, 115, 135.666666666667, 102.666666666667, 116, 
  115.333333333333, 118, 107, 104, 113.666666666667, 130, 128.333333333333, 
  110.333333333333, 127.666666666667, 129.333333333333, 107, 110.666666666667, 
  97.3333333333333, 120.333333333333, 90.6666666666667, 122.333333333333, 
  104, 93.6666666666667, 102.333333333333, 111.333333333333, 121.666666666667, 
  127.666666666667, 115, 103, 91.6666666666667, 150.666666666667, 
  127, 126.333333333333, 111.666666666667, 117.666666666667, 109, 
  103, 104, 103.666666666667, 109, 122.666666666667, 122, 116.333333333333, 
  117.333333333333, 102, 156, 105.666666666667, 106.333333333333, 
  124.333333333333, 105.333333333333, 121.333333333333, 92.6666666666667, 
  117.666666666667, 122.666666666667, 88.3333333333333, 119, 121.333333333333, 
  97, 107, 109.333333333333, 113.666666666667, 103.666666666667, 
  117, 112.666666666667
)

# Predictor variables are standardized prior to fitting the loess model
data <- data.frame(criterion = criterion, lw.predictor = scale(lw.predictor), par.predictor = scale(par.predictor))


## MODEL FIT

lwr.fit <- loess(
  criterion ~ lw.predictor * par.predictor, data,
  parametric = "par.predictor",
  span = .7,
  family = "gaussian", degree = 2, drop.square = "par.predictor",
  normalize = FALSE
)


## PREDICTION ON GRID

# Statistics to standardize axes (based on the sample)
par.mean <- mean(par.predictor)
par.sd <- sd(par.predictor)
lw.mean <- mean(lw.predictor)
lw.sd <- sd(lw.predictor)

# Axes
pred.lw.axis <- (sqrt(seq(7, 18.25, by = 1/12)) - lw.mean) / lw.sd
pred.par.axis <- (89:156 - par.mean) / par.sd


# Grid generation
std.prediction.values <- expand.grid(
  lw.predictor = pred.lw.axis,
  par.predictor = pred.par.axis
)

# Prediction
lwr.prediction <- predict(lwr.fit, std.prediction.values, se = TRUE)


## GRAPHIC REPRESENTATION OF THE PARAMETRIC REGRESSION

# Slope computing
test.values <- lwr.prediction$fit[1, ]
slopes <- (test.values[-1] - test.values[-length(test.values)]) / (pred.par.axis[-1] - pred.par.axis[-length(pred.par.axis)])

plot(slopes, type = "l", ylab = "Slopes")

好吧,如果你运行这段代码,你会得到我所说的(接近)抛物线图。在我看来,这很奇怪。有人可能认为这是由于量化误差造成的,但我对此表示怀疑,因为它会在某种程度上是随机的,而且值要小得多。我可能弄错了,但我认为情节应该显示一条恒定的线。另一方面,我也尝试过更改黄土模型的参数,但问题似乎仍然存在。我希望有人可以帮助我,我在论坛中搜索过这个主题并没有找到任何类似的问题。

非常感谢你。

4

0 回答 0