TGTGInsightтелеграм анализLIVE / telegram public index
← Такты, стеки, два колеса

TGINSIGHT SIMILAR POSTS

Намери подобно съдържание

Изходен канал @clockstackwheels · Post #1084 · 9.04

В общем, была задача на оптимизацию плана работ: есть набор заказов, и в каждом N тасков. Таски могут зависеть друг от друга или нет, имеют длительность и тип. Ещё есть M работников, каждый из которых может выполнять таски только определённых типов, причём, у каждого своя скорость. Если все таски в заказе выполнены, фирма получает сколько-то денег. У заказа есть дедлайн, за просрочку штраф (за каждый день просрочки), который вычитается из цены заказа. И ещё фирма тратит деньги за каждый день своей работы независимо от того, как загружены её сотрудники (то есть просто платит зарплаты по сути). Ещё важен учёт праздников и выходных. Нужно заработать на определённом наборе заказов и работников как можно больше денег. Полный текст задачи и код программы проверки есть в репозитории. Эта задача является изменённым заказом, который мы с напарником решали в реальной жизни: оптимизация работы печатных станков для типографии. Правда, тогда и мы справились так себе, и заказчик в итоге сначала захотел всё вручную сам делать, а потом и вовсе похоронил проект при смене директора. !!! Не читайте дальше, если хотите сначала попробовать решить самостоятельно, потому что я сейчас опишу эффективные подходы и результаты. ________________________________________ Так вот. Мы с другим экспертом Андреем сразу сели и написали разные варианты, чтобы задать шкалу, по которой будем оценивать решения команд. За пару часов я собрал примитивный жадный алгоритм, который сортировал заказы по прибыльности и укладывал в сетку кое-как, это дало нам нижнюю оценку. Мой алгоритм заработал ~75 млн виртуальных рублей, мы решили для оценки поставить нижней границей 40 млн. То есть всё, что ещё ниже, оценивалось в ноль баллов за качество оптимизации. Затем Андрей закрылся дома на три дня и вышел на свет со сложным жадным алгоритмом, который очень хитро сортировал заказы и очень хитро укладывал их в сетку, попутно выбирая разные способы этой укладки в зависимости от конкретного заказа. Это позволило заработать ~275 млн рублей. Мы сделали верхней границей для оценки 280 млн. К сожалению, в итоге только две команды из десяти прошли нижнюю границу, заработав, соответственно, ~91 и ~105 млн. К верхней границе не приблизился никто. И у четырёх команд алгоритм вообще не смог уложить без нарушений задачи в сетку (то есть, например, произвольно менял длительности, накладывал задачи друг на друга, давал одному работнику две задачи в один момент и так далее). Важной ошибкой команд, на мой взгляд, являлся тот факт, что никто не воспользовался возможностью запустить алгоритм на несколько минут и дать ему поработать. По условиям задания, можно было тянуть до 5 минут на одну оптимизацию, но по факту решения команд отрабатывали за единицы и десятки секунд. На самом конкурсе, пока команды работали, я решил попробовать сделать быстрое (по времени написания) но эффективное решение. Сначала попробовал жадную сортировку + доведение до лучшего варианта методом имитации отжига. В качестве нового состояния я просто менял местами заказы целиком. Этот вариант работал пару минут и дал мне около ~200 млн дохода. К слову, команда-лидер использовала такой же подход, просто не докрутила число итераций и температуру. Ну и потом я взял готовую либу по реализации классической генетики с особями и скрещиванием. Особью был массив с приоритетами заказов (которые конечно же нужно было аккуратно уложить чистым алгоритмом). Тип скрещивания: scattered. Всего 15 поколений по 20 особей, и это за минуту-полторы давало ~230-240 млн. Считаю, что для конкурса это самый лучший выбор: пишется одним человеком за день и даёт почти максимум, при этом легко настраивается на нужную длительность работы, легко параллелится. Ну а потом уже дома я посидел и накодил свой вариант сложного жадного с плавающим окном перебора отсортированных заказов и плавающей же укладкой по работникам. Такая штука за две минуты зарабатывает ~281 млн. Но за три дня в условиях стресса я бы такое не сделал, скорее всего. #dev

Hashtags

Резултати

Намерени 11 подобни публикации

Търсене: #debug

当前筛选 #debug清除筛选
Harukaの异想世界

@haruka_fantasy_world · Post #349 · 06.02.2026 г., 04:21

嗯, podman的kube兼容的实现也非常草台班子 起因是把k8s带HTTP livenessProbe的pod移植到podman上运行, 发现healthcheck始终失败, 翻源码发现这部分实现非常难评, 是进入容器调用curl localhost实现的, 并不是像kubelet那样从容器外部访问 也就是说, 如果容器是精简过或者做了安全加固, 没有自带curl来做http get, 那livenessProbe无论如何都不会成功 https://github.com/containers/podman/blob/be85287fcf4590961614ee37be65eeb315e5d9ff/pkg/specgen/generate/kube/kube.go#L689 #Debug

Hashtags

Harukaの异想世界

@haruka_fantasy_world · Post #322 · 11.12.2025 г., 19:24

被CMSIS-DSP的FFT创飞 (其实是没仔细读文档 arm官方文档明确指出了 arm_rfft_fast_f32 会原地修改输入缓冲区, 然而咱用库之前没仔细读文档 Due to the use of complex transform internally, the source buffer is modified by the rfft. 看到函数参数有输入和输出指针, 然后就想当然认为函数内部一定不会覆盖输入缓冲区, 再加上输入循环缓冲用的是zero-copy, 调用FFT也是直接传入了缓冲区指针, 所以相当于算了一次FFT后直接污染了整个缓冲区 #Debug

Hashtags

Harukaの异想世界

@haruka_fantasy_world · Post #171 · 07.10.2024 г., 09:41

TL;DR 容器内设置了错误的dns导致tailscale用了自带的dns解析control-plane的ip, 用一种奇怪的方式避开了防火墙的阻断 #Debug

Hashtags

Arcadia

@ningxueye · Post #33 · 19.03.2024 г., 09:40

aiokafka是根据获取到的metadata内的hostname和port去连接集群的,而我部署服务的环境无法解析集群内的hostname…… 吃了不熟悉Kafka的亏。 #debug

Hashtags

Harukaの异想世界

@haruka_fantasy_world · Post #272 · 21.07.2025 г., 15:43

最近在研究SDN, 结果闹出了在内网ARP查询外网IP这种抽象事 bro先是实现了带Learning的Bridge, 然后手搓了ARP Proxy, 但是没判断IP范围, 代码认为世界是个巨大的交换机, 所有IP都在LAN, 都能用ARP查出来对应的MAC ( 然后手机疯狂发送TCP SYN, 网桥也在内网里疯狂用ARP查询外网IP 回应想必是没有的, 然后手机就认为上不了网摆了, 绷 #日常#Debug

Ship Overboard

@Ship_Overboard · Post #833 · 30.08.2023 г., 04:32

#debug#洋屁 playing Valheim with friends started a Linux Dedicated Server w/ Azure Playfab Crossplay Support. can't connect server using IP and Playfab API always connecting > Unable to preload the following plugins: libparty.so checking libparty.so using > ldd libparty.so IT NEEDS libpulse-dev ??????? Why? Audio lib requested SRSLY? sudo apt install libpulse-dev all works...

djangoproject

@djangoproject · Post #323 · 29.04.2017 г., 08:15

https://pypi.python.org/pypi/django-debug-toolbar A configurable set of panels that display various #debug information about the current #request/#response. The #Django_Debug_Toolbar is a configurable set of panels that display various debug information about the current request/response and when clicked, display more details about the panel’s content. Here’s a screenshot of the toolbar in action:

GitHub Trends

@githubtrending · Post #15488 · 13.02.2026 г., 12:30

#swift#analysis#analytics#cocoapods#crashlytics#debug#debugger#debugging#hacktoberfest#layout_debugger#leak_detection#log#logs_analysis#networking#performance_analysis#sandbox#swift#swift6#ui#uikit#view DebugSwift is a comprehensive toolkit that simplifies debugging for Swift iOS apps by providing real-time monitoring of network requests, performance metrics (CPU, memory, FPS), crash reports, and app resources like keychain and user defaults. It includes interface tools for visualizing layouts with grid overlays and touch indicators, plus memory leak detection and console logging. The main benefit is that you can quickly identify and fix issues during development without leaving your app—just shake your device to toggle the debug panel, making troubleshooting faster and more efficient. https://github.com/DebugSwift/DebugSwift