Распределите денежную сумму по строкам, пока она не истощится - PullRequest
0 голосов
/ 30 мая 2018

Для определенного фрейма данных, который у меня есть, необходимо распределить определенное количество (POT) по фрейму данных.Когда эта сумма исчерпана, она должна вернуть оставшийся кадр данных без присвоения значения.Введите DF:

Accepted    Jackpot Commision   Rank
NO          2760.33 279.85      1
NO          2760.33 279.85      1
NO          2760.33 279.85      1
NO          2760.33 279.85      1
NO          2760.33 206.38      2
NO          2760.33 206.38      2
NO          2760.33 206.38      2

, как вы можете видеть, DF имеет 4 столбца, но в действительности он намного больше, но это столбцы, которые имеют значение.Я хочу изменить «Принято» на «Да» при истощении джекпота с комиссией, основанной на столбце «Ранг».

Таким образом, джекпот - комиссия (2760,33 - 279,85 = 2480,48) превращается в «Да» для всех рядов, имеющих ранг 1. Джекпот теперь: 2480.48.Так что это то, что мы можем использовать для ранга 2 и так далее.До тех пор, пока мы не достигнем 0 и просто все принятые останутся на NO.

Accepted    Jackpot Commision   Rank
YES         2760.33 279.85      1
YES         2760.33 279.85      1
YES         2760.33 279.85      1
YES         2760.33 279.85      1
NO          2480.48 206.38      2
NO          2480.48 206.38      2
NO          2480.48 206.38      2

Я пробовал много вещей, таких как By, (s)apply, for, aggregate и даже больше, но мне не удалось получить правильный ответ.Любая помощь приветствуется.

Полный кадр данных теста:

dput(tst_df)
structure(list(Accepted = structure(c(1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L), .Label = c("NO", "YES"), class = "factor"), 
    Jackpot = c(2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 2760.33, 
    2760.33, 2760.33, 2760.33, 2760.33, 2760.33), Commision = c(12.71, 
    12.71, 12.71, 27.52, 27.52, 27.52, 27.52, 27.52, 16.94, 16.94, 
    16.94, 31.51, 31.51, 31.51, 31.51, 31.51, 3.72, 3.72, 16.68, 
    16.68, 16.68, 14.46, 14.46, 132.13, 132.13, 132.13, 132.13, 
    132.13, 132.13, 132.13, 132.13, 132.13, 132.13, 132.13, 132.13, 
    132.13, 132.13, 132.13, 132.13, 132.13, 132.13, 132.13, 132.13, 
    132.13, 132.13, 132.13, 132.13, 12.19, 12.19, 6.82, 6.82, 
    55.31, 55.31, 55.31, 55.31, 55.31, 55.31, 55.31, 13.01, 13.01, 
    155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 
    155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 
    155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 155.8, 
    155.8, 155.8, 155.8, 279.85, 279.85, 279.85, 279.85, 279.85, 
    279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 
    279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 
    279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 
    279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 279.85, 
    279.85, 279.85, 279.85, 279.85, 279.85, 1.86, 6.2, 6.2, 36.96, 
    36.96, 36.96, 36.96, 36.96, 36.96, 36.96, 36.96, 36.96, 9.3, 
    6.45, 8.26, 10.16, 10.16, 10.16, 10.16, 6.61, 5.78, 6.2, 
    18.59, 18.59, 18.59, 84.24, 84.24, 84.24, 84.24, 84.24, 84.24, 
    84.24, 84.24, 84.24, 84.24, 84.24, 31.19, 31.19, 31.19, 31.19, 
    31.19, 31.19, 167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 
    167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 
    167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 
    167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 167.78, 1.24, 
    3.81, 3.81, 4.13, 17.67, 17.67, 17.67, 17.67, 106.72, 106.72, 
    106.72, 106.72, 106.72, 106.72, 106.72, 106.72, 106.72, 106.72, 
    106.72, 106.72, 106.72, 106.72, 106.72, 106.72, 106.72, 9.3, 
    55.43, 55.43, 55.43, 55.43, 55.43, 55.43, 55.43, 2.23, 24.79, 
    24.79, 24.79, 24.79, 260.22, 260.22, 260.22, 260.22, 260.22, 
    260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 
    260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 
    260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 260.22, 
    260.22, 260.22, 3.51, 3.51, 3.51, 7.44, 4.29, 4.29, 6.61, 
    27.58, 27.58, 27.58, 27.58, 27.58, 27.58, 27.58, 115.08, 
    115.08, 115.08, 115.08, 115.08, 115.08, 115.08, 115.08, 115.08, 
    115.08, 115.08, 115.08, 115.08, 115.08, 115.08, 115.08, 206.38, 
    206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 
    206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 
    206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 
    206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 206.38, 
    206.38, 206.38, 206.38, 69.1, 69.1, 69.1, 69.1, 69.1, 69.1, 
    69.1, 69.1, 69.1, 69.1, 69.1, 69.1, 69.1, 4.63, 0, 6.69, 
    6.69, 6.69, 6.69, 66.85, 66.85, 66.85, 66.85, 66.85, 66.85, 
    66.85, 66.85, 66.85, 11.98), Rank = c(15L, 15L, 15L, 18L, 
    18L, 18L, 18L, 18L, 37L, 37L, 37L, 25L, 25L, 25L, 25L, 25L, 
    33L, 33L, 20L, 20L, 20L, 23L, 23L, 4L, 4L, 4L, 4L, 4L, 4L, 
    4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 
    4L, 4L, 4L, 38L, 38L, 58L, 58L, 10L, 10L, 10L, 10L, 10L, 
    10L, 10L, 70L, 70L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 
    3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 
    3L, 3L, 3L, 3L, 3L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
    1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
    1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
    1L, 1L, 22L, 47L, 47L, 16L, 16L, 16L, 16L, 16L, 16L, 16L, 
    16L, 16L, 85L, 53L, 60L, 35L, 35L, 35L, 35L, 34L, 48L, 54L, 
    41L, 41L, 41L, 11L, 11L, 11L, 11L, 11L, 11L, 11L, 11L, 11L, 
    11L, 11L, 17L, 17L, 17L, 17L, 17L, 17L, 8L, 8L, 8L, 8L, 8L, 
    8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 
    8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 8L, 42L, 31L, 31L, 32L, 21L, 
    21L, 21L, 21L, 7L, 7L, 7L, 7L, 7L, 7L, 7L, 7L, 7L, 7L, 7L, 
    7L, 7L, 7L, 7L, 7L, 7L, 13L, 12L, 12L, 12L, 12L, 12L, 12L, 
    12L, 30L, 43L, 43L, 43L, 43L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 
    5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 
    5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 5L, 66L, 66L, 66L, 79L, 45L, 
    45L, 46L, 28L, 28L, 28L, 28L, 28L, 28L, 28L, 6L, 6L, 6L, 
    6L, 6L, 6L, 6L, 6L, 6L, 6L, 6L, 6L, 6L, 6L, 6L, 6L, 2L, 2L, 
    2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 2L, 2L, 9L, 9L, 9L, 9L, 9L, 9L, 9L, 9L, 9L, 9L, 9L, 
    9L, 9L, 104L, 26L, 29L, 29L, 29L, 29L, 14L, 14L, 14L, 14L, 
    14L, 14L, 14L, 14L, 14L, 57L)), .Names = c("Accepted", "Jackpot", 
"Commision", "Rank"), row.names = c(NA, -367L), class = "data.frame")

1 Ответ

0 голосов
/ 30 мая 2018

В этом наборе данных оказывается, что «Джекпот» не исчерпан, поэтому решение тривиально.То есть

library(dplyr)
tst_df %>%
  distinct() %>%
  arrange(Rank) %>%
  mutate(cumsum = cumsum(Commision), remaining = Jackpot - cumsum) 
#    Accepted Jackpot Commision Rank  cumsum remaining
# 1        NO 2760.33    279.85    1  279.85   2480.48
# 2        NO 2760.33    206.38    2  486.23   2274.10
# 3        NO 2760.33    155.80    3  642.03   2118.30
# 4        NO 2760.33    132.13    4  774.16   1986.17
# <snip>
# 48       NO 2760.33     13.01   70 2172.54    587.79
# 49       NO 2760.33      7.44   79 2179.98    580.35
# 50       NO 2760.33      9.30   85 2189.28    571.05
# 51       NO 2760.33      4.63  104 2193.91    566.42

Предположим, мы установили для джекпота меньшее число.Решение состоит в том, чтобы выяснить Rank, при котором сумма истощается, а затем присоединить сводную таблицу к исходному набору данных:

new_df <- mutate(tst_df, Jackpot = 1000)
accepted <- new_df %>%
  distinct() %>%
  arrange(Rank) %>%
  mutate(cumsum = cumsum(Commision),
         remaining = Jackpot - cumsum,
         Accepted = if_else(remaining > 0, "YES", "NO")) 
head(accepted)
#   Accepted Jackpot Commision Rank  cumsum remaining
# 1      YES    1000    279.85    1  279.85    720.15
# 2      YES    1000    206.38    2  486.23    513.77
# 3      YES    1000    155.80    3  642.03    357.97
# 4      YES    1000    132.13    4  774.16    225.84
# 5       NO    1000    260.22    5 1034.38    -34.38
# 6       NO    1000    115.08    6 1149.46   -149.46

Так что здесь все Rank из 4 или ниже имеют Accepted равно "ДА".Наконец

out <- left_join(select(accepted, Accepted, Rank), select(tst_df, -Accepted))
...