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

У меня есть такая задача "Найти сессии, в которых между

каждыми соседними событиями auto_play должно быть одно из событий [auto_pause, rebuffer]."
Я пыталась решать её через массивы
groupArray(event_name) AS event_names,
arrayReverseSplit(name, splitter -> splitter, event_names, arrayMap(x -> x = 'auto_play', event_names)) AS name_intervals,
arrayFilter(name -> name[-1] = 'auto_play', name_intervals) AS auto_play_intervals,
arrayFilter(name -> hasAny(name, ['rebuffer', 'auto_pause']), auto_play_intervals) AS valid_name_intervals,
length(auto_play_intervals) AS cnt_intervals,
length(valid_name_intervals) AS cnt_valid_intervals

сравнивая потом, что cnt_intervals = cnt_valid_intervals. Этот метод не проходил в ограничение памяти (20 GiB).
Пыталась использовать sequenceCount
sequenceCount('(?1).*(?2).*(?3)')(device_timestamp,
event_name = 'auto_play',
event_name IN ('rebuffer',
'auto_pause'), event_name = 'auto_play')
Это выдавало ошибку Pattern application proves too difficult, exceeding max iterations (1000000).
Через windowFunnel ничего внятного не получилось.
Помогите пожалуйста)

8 ответов

10 просмотров

а если set max_threads=1

А если без .* в sequenceCount?

т.е. нужно узнать, есть ли хотя бы одна цепочка (без других событий) auto_play, auto_pause|rebuffer, auto_play в пределах сессии?

Надя-Смирнова Автор вопроса
Aleksei Kh
т.е. нужно узнать, есть ли хотя бы одна цепочка (б...

Нет, между каждыми двумя событиями auto_play должно быть auto_pause|rebuffer, и при этом могут быть и другие события

Надя Смирнова
Нет, между каждыми двумя событиями auto_play должн...

ну их можно предварительно отфильтровать я думаю

Aleksei Kh
ну их можно предварительно отфильтровать я думаю

sequenceCount игнорит те, что не в кондишнах

primorial
sequenceCount игнорит те, что не в кондишнах

Чуть дополню, что можно это дело обойти https://kb.altinity.com/altinity-kb-functions/altinity-kb-sequencematch

Надя-Смирнова Автор вопроса

всем спасибо за идеи, в итоге я оставила решение с массивами, предварительно выбрав сессии только с этими событиями :D

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

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

#include <stdio.h> #include <stdlib.h> #include <time.h> void mass_first_generate(int mass[5][7]) {     for (int N = 0; N < 5; N++) {         for (int A = 0; A < 7; A++) {   ...
Чувак
6
https://www.linkedin.com/posts/ugama-benedicta-kelechi-codergirl-103041300_mobiledevelopment-fluttertraining-handsonlearning-activity-7263445699227254784-IdHB?utm_source=share...
CoderGirl
16
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Ну вот просто даже давайте вот как. Какой нибудь конкретный кейс, можете в пример привести, где бч работает и приносит прикладную пользу, а не просто что бы было? Не крипту.
Alexander Andreev
22
объясните пожалуйста, почему функция не работает должным образом? вроде должно брать активное окно сравнивать его размер с размером экрана, и если есть совпадение = true прове...
JF
12
Гляньте, че бывает: Сегодня по одному проекту одной вебстудии делал проект небольшой, на их хостинге. На Modx revo. В определенный момент , работая в админке, вдруг перестал р...
Artem
7
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
12
> Копаем глубже > Следующий момент был, когда я спросил его, знает ли он JavaScript. Он ответил, что его учили работать с C#. Я тоже в университете писал на C#, но даже там мн...
Oleg Volkov
4
И никого не интересует какие пакеты кто использует. ((% Заходишь на сайт симфони и видишь поддержку Украины - по законам РФ это ж экстремизм. Только никто не отказывается от с...
Am Ambrion
11
Карта сайта