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

Резултати

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

Търсене: #webgl

当前筛选 #webgl清除筛选

Максим Эзьер написал большое руководство по работе с WebGL — "WebGL guide". В руководстве с азов объясняется создание интерактивной трёхмерной сцены без использования сторонних библиотек. Используется только чистый JS и WebGL. В самом начале есть раздел про математику, которая необходима для работы с графикой. Затем объясняется процесс создания простых двумерных и трёхмерных сцен с подробным объяснением примеров исходного кода. Есть пример текстурирования объектов и работы с источниками света. В конце статьи есть список наиболее распространённых ошибок. Про них полезно знать при отладке кода. В общем, если хотели потыкать WebGL, рекомендую заглянуть в это руководство. #webgl#tutorial https://xem.github.io/articles/webgl-guide.html

✈️ Y8 | 一个还在持续更新的在线网页游戏平台,连 Flash 存档都给你留着了 🏷 检索标签:#Y8#游戏#网页游戏#Flash游戏#WebGL#游戏 ⭐️ 详情介绍:Y8 是个做了很多年的在线游戏平台,它把 老 Flash 存档 和现在还能跑的 HTML5 / WebGL 游戏 都放在了一起。你点进去就能玩,不用下载、不用装客户端 它库里收了 10 万+ 游戏,里面不只是常见小游戏,也有 多人联机、换装互动、独立作品 和一些能直接在浏览器里跑起来的 3D 内容 🔎Y8游戏网站 😌频道 |🙂群聊 |😋中文包 |☺️搜索

纯情男高

@hanzichen · Post #1390 · 22.11.2025 г., 14:00

VolumeShader毒蘑菇显卡测试 | 基于 WebGL 的 GPU 性能测试平台 一款基于浏览器的GPU性能测试工具,通过实时3D体积渲染精确测量您的显卡性能。提供详细的FPS、帧时间和GPU使用率数据,无需下载安装即可获得专业级基准测试结果。一个在浏览器中运行的 GPU 基准测试工具,使用 3D 体积渲染(volume rendering)技术来评估设备显卡性能。它通过 WebGL 实现实时体积着色器 (shader) 效果,并提供多个测试场景(如分形 Mandelbulb、Julia 集)和不同难度等级(从低强度到 “地狱级”)来施加 GPU 压力。测试过程中会实时显示 FPS(帧率)、帧时间等性能指标,无需安装任何软件。 点击访问 #GPU性能测试#WebGL#体积渲染#在线基准测试#VolumeShader

GitHub Trends

@githubtrending · Post #14888 · 30.06.2025 г., 12:30

#typescript#data_visualization#geospatial_analysis#javascript#maps#python#visualization#webgl deck.gl is a powerful tool that helps you create fast, interactive, and visually impressive maps and data visualizations using WebGL technology. It lets you turn large sets of data into layers like icons, polygons, and text, which you can view in different ways such as maps or 3D scenes. It works well with popular map providers like Google Maps and Mapbox, and supports easy interaction like clicking and filtering. You can use it simply by adding a script or installing it via npm or Python. This makes it easier for you to build custom, high-performance visualizations quickly and with less coding effort. https://github.com/visgl/deck.gl

GitHub Trends

@githubtrending · Post #14898 · 02.07.2025 г., 13:30

#javascript#3d#augmented_reality#canvas#html5#javascript#svg#virtual_reality#webaudio#webgl#webgl2#webgpu#webxr Three.js is a powerful and easy-to-use JavaScript library that helps you create 3D graphics and animations on the web with much less code than using WebGL directly. It handles complex tasks like rendering and math calculations, so you can focus on designing your 3D scenes. It supports WebGL and WebGPU, with additional options like SVG and CSS3D. Three.js has excellent documentation, many examples, and a large, active community that provides support and updates. This makes it ideal for quickly building interactive 3D content that works across browsers, improving your web projects with engaging visuals and smooth performance[1][3][5]. https://github.com/mrdoob/three.js

GitHub Trends

@githubtrending · Post #15296 · 12.11.2025 г., 13:30

#javascript#3d_gaussian_splatting#game_development#game_engine#gamedev#gaussian_splatting#gltf#hacktoberfest#javascript#nodejs#playcanvas#typescript#virtual_reality#webgl#webgl2#webgpu#webxr PlayCanvas is an open-source game engine that lets you create 3D and 2D games or apps that run in any browser, using WebGL and WebGPU for fast, high-quality graphics. It supports advanced features like animation, physics, sound, and asset streaming, and you can write code in JavaScript or TypeScript. The engine is free, easy to set up, and works well for both simple projects and complex games, making it simple to build and share interactive content online. https://github.com/playcanvas/engine