本文介绍了有条件地将向量中的第 n 个元素分配为 H,其余为 L的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个随机抽样数字的向量.例如,

I have a vector of randomly sampled numbers. For example,

vec1 <- sample(1:574)

我想将这个采样向量中的前 25% 的值指定为 H,其余元素指定为 L.我曾尝试使用 ifelse,但这会将值 1 到 143 指定为 H,并且值大于 143作为 L.但我希望前 143 个值具有 H,其余为 L.对于下面的元素,我希望前 143 个元素(即前 4 行到 44 行)将是 H,所有其余部分都是 L.这意味着第一个元素值 393 将得到 H,第二个元素 518 也将得到 H.

I would like to assign first 25 percent value in this sampled vector as H and rest elements as L. I have tried using ifelse but that gives values 1 to 143 as H and values greater that 143 as L. But I want first 143 values to have H and rests as L. For elements below, I want first 143th elements (i.e.first 4 rows upto 44) will be H and all rests will be L.That means the first element which values 393 will get H, the second element 518 will aso get H.

> vec1
  [1] 393 518 179 358  78 185 168 386 321 114 163  18 217 302 191 167 465 427 342 422 406 144 183 438 546
 [26] 500 336 123  99 208 130   9 477 197  95  75 122 320 101 175 117 388 414 475 353 499  66 558 298 277
 [51]  35 522 293 343 165 194 563 482 219 274 104 164 484  11 333  67 180  57 221 470 211 447  63 212 148
 [76] 267 426 118  10  84 459 463  51  91 432 569 303 442 390 446 218  34 338 464 201 232 398 385 365 510
[101] 412 400  38 295 514 220 430 372  15 308 366 268 557 110 467 474  32 364 515  41 418 419 300 542 523
[126] 317 307 554 458 263  47 128 445 360 528  72 431 171 368  44 160 433 202 502  62 550 417  89 337 503
[151] 233 401 115  42 113 257 340 555 323  76 196 533  69 261  86 292  77 273 297 454 479 508   7  50 357
[176] 296 473 476 516 551  83 309 215 213 488 556 262 278 289 265 370 151 310   4 423 126 506  55 564 424
[201]  40  60 493 544  30 312  65 490 529 214 456 319  98 198 391 376 112 284 572 304 247 560 249 486 345
[226] 527 250 382 346 428  49 331 169 166 565 159 384 324 371 548 222 325 107 209 453 504 269 538 305   6
[251] 125  82 238 481 487 339 129 237 108 139 141 441 471 562 178 517 146 468 480 182 352 460  28 543 363
[276]  96   8 252 301 526 281 119  16  13 157 280 530 143 524 276 256 316 254 205 200 332 425 440 573   2
[301] 149 539 206 497  31 315 228   1 199 552  21 436 498 109  26 158 111  90 330 313 491  54 204 103 520
[326]  61 466 253 329  64 241 124  37  19 351 505 405 513 246 429 258 547 176 496 381 451 186 172 350 354
[351] 347 469 416 449  68 525 404 549 413 134 367 216 373 136 306 568 121 190 355 156 361 566 181 411 236
[376] 161  43 311 138 359  81 439 155 374 570 223 344   3 264  36  27  71 348 452 288 174 407  52 396 255
[401] 187 455 369 224 314 127 379  12  94 328 341 271  48 327 402 443 478 450  87  17 380 287 279  39  85
[426] 509  45 483 457 521 231 349 152 105  73 494 251 207 420 135 120 435  33  22 286 153 535 421 285 235
[451]  80  93 395 540 489 154 322  46  59 392 326 195 409  25 177 100 545  24 170 472 142 437  74 270 495
[476]  56 410  20 188 394 561 415  58 229  79 227 531 203 242 162 574 272 541   5 283 448  88 137 239 507
[501] 356 383 243 290 536 444 387 234  14 461 282  29 534 132 192 275 133 230 259 375 537 532  70 184 512
[526] 260  92 106 131 434 225 102 362 147 408 173 248 334 226 403 511 294 299 378 389 399 189 492 519 240
[551] 116 266 501  23 193 145 567 140  97 335  53 210 291 553 571 377 485 150 318 244 245 397 559 462
>

推荐答案

我想你的意思是这样的:

I think you mean this:

vec1 <- sample(1:574)
L = vec1[1:143]
H = vec1[144:length(vec1)]

无论如何,您都可以做到这一点:

Anyway by percentage you can do this:

vec1 <- sample(1:574)
num_to_25 <- floor(0.25*length(vec1))
L = vec1[1:num_to_25]
H = vec1[(num_to_25+1):length(vec1)]

你可以使用的功能:

assigner = function (input_vactor,percentage_of_L=25){
   num_to_25 <- floor(percentage_of_L*0.01*length(input_vactor))
   L = input_vactor[1:num_to_25]
   H = input_vactor[(num_to_25+1):length(input_vactor)]
   return (list(L=L,H=H))
}

并像这样使用它:

vec1 <- sample(1:574)
h = assigner(vec1)$H
l = assigner(vec1)$L

Edit for Edit:对于您已编辑的问题,将第二个函数更改为:

Edit for For your edited question change second function to this:

sensitivity.rand <- function(vector, threshold){
  num_to_thres <- floor(threshold*0.01*length(vector))
  l = length (vector)
  score = c(rep("L",num_to_thres),rep("H",l-num_to_thres))
  return(score)
}

这篇关于有条件地将向量中的第 n 个元素分配为 H,其余为 L的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

05-17 18:42