Squeak.ru - шаблоны программирования

Использование Excel для распределения значений на основе их ранга, оставаясь при этом в рамках ограничений

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

Upper Limit     Allocation  Prod    Ranking
12               [to calc]   28%      1
15                           18%      2 
5                            17%      3
4                             8%      4
2                             6%      5
3                            .2%      6
4                            .2%      6 

Как и в другом вопросе, у меня есть ограничение, которое мне нужно выделить так много. В этом примере мы будем использовать 38 в качестве суммы, которая должна быть выделена.

Я использовал формулу из другого ответа:

 =MIN(A2,$E$1-SUMIF($D$2:$D$8,"<"&D2,$B$2:$B$8))

Где E1 содержит общую сумму, подлежащую распределению.

У меня есть две проблемы с этой формулой: 1) Проблема, с которой я сталкиваюсь, заключается в том, что мне требуется минимальное значение как минимум 1 человека в каждом из этих разделов.

Я попытался использовать функцию max, чтобы просто установить это значение, однако это приводит к тому, что выделенные ресурсы превышают общую сумму. Какое уравнение мне нужно использовать, чтобы оно учитывало общую сумму, доступную для распределения, минимальные требования для каждого фонда и максимальный лимит для каждого фонда.

2) Он возвращает только твердые целые числа, есть ли способ получить более точные результаты, возможно, изменив его на% распределения?

UL  Alloc   Rank    Capacity    Lower Limit
2   1        15      93          1
3   1        15     
4   1        15     
6   6        8      
1   1        15     
2   1        15     
4   4        9      
2   2        7      
4   4        4      
15  15       2      
12  12      10      
12  12      1       
1   1       11      
13  13      5       
6   6       6       
5   1       15      
5   5       3       
1   1       14      
2   2       13      
3   3       12      
3   1       15      

Ссылка: Использование Функция Excel Rank() для расчета распределения на основе ранжирования и ограничений

17.01.2017

  • Набор данных изменен по сравнению с исходным 18.01.2017

Ответы:


1
  1. Просто вычтите 100 со всех сторон и добавьте их отдельно:

    =MIN(A2-100,($E$1-100*COUNTA($A$2:$A$8))-(SUMIF($D$2:$D$8,"<"&D2,$B$2:$B$8)-COUNTIF($D$2:$D$8,"<"&D2)*100))+100

  2. То, что возвращается, зависит от ваших записей в столбце A и в E1. Вы можете изменить столбец A на основе процентного распределения, и формула вернет соответствующие значения.

Изменить:

Если вы установите нижний порог в F2, ваше ограничение в E2, используя эту формулу

=MIN(A2-$F$2,($E$2-$F$2*COUNTA($A$2:$A$8))-(SUMIF($D$2:$D$8,"<"&D2,$B$2:$B$8)-COUNTIF($D$2:$D$8,"<"&D2)*$F$2))+$F$2

результат выглядит так:

введите здесь описание изображения

17.01.2017
  • Спасибо за ваш ответ. К сожалению, эта формула не дает мне правильного ответа, если мое более низкое требование состоит в том, чтобы перейти на более сложное число для использования, такое как 1. Я скорректировал набор данных, чтобы сделать его более похожим на мой собственный, чтобы посмотреть, поможет ли это мне передать проблема лучше. 18.01.2017
  • Для справки, при замене 100 на 1 это привело к нескольким отрицательным числам. 18.01.2017
  • Ты заменил все 100? Попробуйте эту формулу и введите Нижнее требование в F1: =MIN(A2-$F$1,($E$1-$F$1*COUNTA($A$2:$A$8))-(SUMIF($D$2:$D$8,"<"&D2,$B$2:$B$8)-COUNTIF($D$2:$D$8,"<"&D2)*$F$1))+$F$1 18.01.2017
  • Привет @LukasV, Спасибо, это сработало отлично. Единственная проблема, с которой я столкнулся сейчас, заключается в том, что когда я приближаюсь к максимальной емкости, формула становится неправильной из-за того, что для их множественных качественных рангов я добавил дополнительный набор данных к исходному вопросу, чтобы проиллюстрировать это. При емкости 93 формула верна, однако где-то между 94-106 (моя абсолютная максимальная емкость) формула неверна. Есть ли способ принять это во внимание? 19.01.2017
  • Это сложно. Единственное, о чем я могу думать, это о том, что вы корректируете свой рейтинг, избегая двойных записей. Вы можете использовать этот форум =RANK(C2,$C$2:$C$22,1)+COUNTIF($C$2:C2,C2)-1, однако имейте в виду, что с этой формулой преимущество всегда получает первый номер. 19.01.2017
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...