aboutsummaryrefslogtreecommitdiffstats
path: root/ydb/library/yql/dq/opt/dq_opt.h
blob: edcc7a5dafbb01129a41f7065f7ed96ca56b6f13 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#pragma once

#include <ydb/library/yql/ast/yql_expr.h>
#include <ydb/library/yql/dq/expr_nodes/dq_expr_nodes.h>
#include <ydb/library/yql/dq/proto/dq_tasks.pb.h>

#include <util/generic/guid.h>

namespace NYql::NDq {

struct TDqStageSettings {
    static constexpr TStringBuf LogicalIdSettingName = "_logical_id";
    static constexpr TStringBuf IdSettingName = "_id";
    static constexpr TStringBuf SinglePartitionSettingName = "_single_partition";
    static constexpr TStringBuf IsExternalSetting = "is_external_function";
    static constexpr TStringBuf TransformNameSetting = "transform_name";
    static constexpr TStringBuf TransformTypeSetting = "transform_type";
    static constexpr TStringBuf TransformConcurrencySetting = "concurrency";

    ui64 LogicalId = 0;
    TString Id;
    bool SinglePartition = false;

    bool IsExternalFunction = false;
    NDqProto::ETransformType TransformType = NDqProto::TRANSFORM_YANDEX_CLOUD;
    TString TransformName;
    ui32 TransformConcurrency = 0;

    static TDqStageSettings Parse(const NNodes::TDqStageBase& node);

    static TDqStageSettings New(const NNodes::TDqStageBase& node);

    static TDqStageSettings New() {
        TDqStageSettings s;
        s.Id = CreateGuidAsString();
        return s;
    }
    NNodes::TCoNameValueTupleList BuildNode(TExprContext& ctx, TPositionHandle pos) const;

    ui32 MaxTransformConcurrency() const;
};

NNodes::TCoAtom BuildAtom(TStringBuf value, TPositionHandle pos, TExprContext& ctx);
NNodes::TCoAtomList BuildAtomList(TStringBuf value, TPositionHandle pos, TExprContext& ctx);
NNodes::TCoLambda BuildIdentityLambda(TPositionHandle pos, TExprContext& ctx);

bool EnsureDqUnion(const NNodes::TExprBase& node, TExprContext& ctx);

const TNodeSet& GetConsumers(const NNodes::TExprBase& node, const TParentsMap& parentsMap);
const TNodeMultiSet& GetConsumers(const NNodes::TExprBase& node, const TParentsMultiMap& parentsMap);

ui32 GetConsumersCount(const NNodes::TExprBase& node, const TParentsMap& parentsMap);
bool IsSingleConsumer(const NNodes::TExprBase& node, const TParentsMap& parentsMap);

bool IsSingleConsumerConnection(const NNodes::TDqConnection& node, const TParentsMap& parentsMap, bool allowStageMultiUsage = true);

ui32 GetStageOutputsCount(const NNodes::TDqStageBase& stage, bool includingSinks); 

TVector<NNodes::TDqConnection> FindDqConnections(const NNodes::TExprBase& node);
bool IsDqPureExpr(const NNodes::TExprBase& node, bool isPrecomputePure = true);
bool IsDqDependsOnStage(const NNodes::TExprBase& node, const NNodes::TDqStageBase& stage);

bool CanPushDqExpr(const NNodes::TExprBase& expr, const NNodes::TDqStageBase& stage);
bool CanPushDqExpr(const NNodes::TExprBase& expr, const NNodes::TDqConnection& connection);

} // namespace NYql::NDq