170 похожих чатов

Можно как-то оптимизировать это? IEnumerable<IEnumerable<TimeSeries>> timeSeriesGroups = replacedTimeSeries .Select((s, i) => Tuple.Create(i,

s))
.GroupBy(t => t.Item2.Dimensions, new TimeSeriesDimensionsComparer(false))
.Select(gr => Tuple.Create(SelectIndexes(gr), gr.Select(t => t.Item2).Distinct(new TimeSeriesKeyComparer())))
.Select(t => t.Item1.Select(e => Tuple.Create(e, t.Item2)))
.SelectMany(e => e.Select(r => r))
.OrderBy(e => e.Item1)
.Select(e => e.Item2);

21 ответов

23 просмотра
Ilya-Khudaev Автор вопроса
Ilya-Khudaev Автор вопроса
Пользователь 6196d
Жепа

но может есть идеи как оптимизировать это ?

Как-то мало что понятно. Что за коллекция replacedTimeSeries? Что вообще надо сделать и что получить?

Ilya-Khudaev Автор вопроса
Roman
Как-то мало что понятно. Что за коллекция replaced...

replacedTimeSeries - это IEnumerable<TimeSeries> тут много выборок и групировок чтобы отделить лишнее, отсортировать, дубли убрать и прочее

Блин, бы эту херню сначала распилил в отдельные переменные, чтобы формализовать для чего я каждый linq сделал. И переменные именно так и назвать. Потому что то, что я вижу сейчас - для меня непознаваемо.

Ilya-Khudaev Автор вопроса
Ilya Khudaev
не поверишь, для меня тоже ))

Тогда распили и попробуй понять, зачем чувак каждый шаг делал когда-то 🌚

Ilya-Khudaev Автор вопроса
Roman
Тогда распили и попробуй понять, зачем чувак кажды...

загадок стало только больше, если честно ))

Ilya-Khudaev Автор вопроса
Roman
Ты разобрался зачем там кортежи?)

только одну причину вижу использования кортежей. для сортировки в самом конце по индексу списка

Я так понял, это какая-то свёртка, которая в итоге даст вместо самого объекта массив объектов с тем же параметром dimensions?

Roman
Я так понял, это какая-то свёртка, которая в итоге...

Ну и что бы не сделать для каждого условия группы Dimensions, new TimeSeriesDimensionsComparer(false) запись в словаре, где value - IEnumerable, потом раз пройти по исходному массиву и заполнить эти группы в словаре, потом пройтись ещё раз и собрать в нужном порядке?

Roman
Ну и что бы не сделать для каждого условия группы ...

Еще лучше сделать это прямо в БД, если ms sql. ROW_NUMBER и PARTITION как раз для этого.

а не олап ли это....

Не до конца понятны условия группировки особенно вторая часть запроса, но в целом операция называется партицирование или вычисление кубов данных. В качестве оптимизации можешь её сделать в БД, если она позволяет.

нельзя

Ilya-Khudaev Автор вопроса

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта