تابع آماری زنجیره مارکوف از روشهای احتمالی برای تخصیص اعتبار در نقاط تماس تبلیغاتی بر اساس سهم مدلسازی شده آنها در احتمال تبدیل کاربر استفاده میکند. خروجی این تابع آزمایشی ممکن است در تخصیص اعتبار به یک کانال تبلیغاتی، کمپین، یا نقطه تماس دیگر، بر اساس سهم مدلسازی شده آنها در رویدادهای تبدیل، مفید باشد.
چگونه کار می کند
تابع آماری زنجیره مارکوف از داده های تبلیغاتی شما برای ایجاد یک زنجیره مارکوف استفاده می کند، جایی که هر رأس در نمودار مرتب نشان دهنده یک نقطه تماس است و هر یال احتمال حرکت به آن نقطه تماس بعدی را مشروط به قرار گرفتن در آن نقطه تماس فعلی می دهد. فرض میکند که فقط نقطه تماس فعلی بر احتمال انتقال تأثیر میگذارد. سپس سهم هر نقطه تماس با حذف نقطه تماس از نمودار، و محاسبه احتمال تبدیل مدل شده اکنون که نقطه تماس حذف شده است، محاسبه می شود.
محدودیت های حریم خصوصی
نقاط تماس باید شامل 50 کاربر در حال تبدیل یا بیشتر و 50 کاربر غیر تبدیل کننده یا بیشتر باشد تا با فیلترهای حریم خصوصی حذف نشوند. علاوه بر این، کاربران پرت که مقدار نامتناسبی از اعتبار را به یک نقطه تماس میدهند ممکن است فیلتر شوند. بنابراین، خروجی مدل زنجیره مارکوف ممکن است برخی از نقاط تماس را که در جدول نقاط تماس ورودی هستند، از دست داده باشد.پیام های حریم خصوصی پس از هر بار تکرار مدل زنجیره مارکوف نشان داده می شود. این پیام ها شامل اطلاعات کاربران و نقاط لمسی است که فیلتر شده اند.
مروری بر محاسبه مقادیر زنجیره مارکوف
- جداول نقطه تماس و اعتبار را ایجاد کنید:
-
touchpoint_temp_table
. -
user_credit_temp_table
.
-
- تابع با ارزش جدول
ADH.TOUCHPOINT_ANALYSIS
را با استفاده از جداول temp در بالا به عنوان آرگومان فراخوانی کنید.
جداول نقطه تماس و اعتبار را ایجاد کنید
جدول نقطه تماس را ایجاد کنید
جدول نقطه تماس جایی است که رویدادهای کاربر مربوط به نقاط تماس در آن تعریف می شوند. دادههای نمونه ممکن است شامل موارد زیر باشد، اما به این موارد محدود نمیشود: campaign_id
، creative_id
، placement_id
، یا site_id
.
جدول باید شامل ستون های زیر باشد:
نام ستون | تایپ کنید |
---|---|
touchpoint | string نام نقطه تماس خودسرانه (نباید NULL یا حاوی کاما باشد.) |
user_id | string شناسه کاربری که از نقطه تماس بازدید می کند. (نباید NULL یا 0 باشد.) |
event_time | int زمانی که کاربر از نقطه تماس بازدید کرده است. (نباید NULL باشد.) |
کد نمونه برای ایجاد جدول:
CREATE TABLE touchpoint_temp_table
AS (
SELECT user_id, event.event_time, CAST(event.site_id AS STRING) AS touchpoint
FROM adh.cm_dt_impressions
WHERE
event.event_type IN ('VIEW')
AND user_id <> '0'
AND event.campaign_id IN UNNEST(@campaign_ids)
UNION ALL
SELECT
user_id, event.event_time, CAST(event.site_id AS STRING) AS touchpoint
FROM adh.cm_dt_clicks
WHERE
event.event_type IN ('CLICK')
AND user_id <> '0'
AND event.campaign_id IN UNNEST(@campaign_ids)
);
جدول اعتبار کاربر را ایجاد کنید
جدول اعتبار کاربر جایی است که رویدادهای تبدیل تعریف می شوند. رویدادهایی که به دنبال تبدیلها میآیند، رویدادهای غیر تبدیلی محسوب میشوند.
جدول باید شامل ستون های زیر باشد:
نام ستون | تایپ کنید |
---|---|
user_id | string شناسه کاربری که از نقطه تماس بازدید می کند. (نباید NULL یا 0 باشد.) |
event_time | int زمانی که رویداد مشارکت اتفاق افتاد. (نباید NULL باشد.) |
credit | integer اعتبار ارائه شده توسط کاربر. این می تواند هر اعتباری باشد که کسی دوست دارد تحلیل کند. مثلاً مقدار تبدیل، تعداد تبدیل و ... باید بین 1 تا 100 باشد. |
کد نمونه برای ایجاد جدول:
CREATE TABLE user_credit_temp_table AS (
SELECT
user_id,
MAX(event.event_time) AS event_time,
1 AS credit
FROM adh.cm_dt_activities_attributed
WHERE user_id <> '0'
AND event.campaign_id IN UNNEST(@campaign_ids)
AND DATE(TIMESTAMP_MICROS(event.event_time)) BETWEEN @start_date AND @end_date
AND event.activity_id IN UNNEST (@activity_ids)
GROUP BY user_id
);
تابع با ارزش جدول
تابع جدول مقدار تابعی است که یک جدول را در نتیجه برمی گرداند. به این ترتیب، شما می توانید تابع با ارزش جدول را مانند یک جدول معمولی پرس و جو کنید.
نحو
ADH.TOUCHPOINT_ANALYSIS(TABLE touchpoints_tmp_table_name, TABLE credits_tmp_table_name, STRING model_name)
استدلال ها
نام | |
---|---|
touchpoints_tmp_table_name | نام جدول نقطه تماس موقت ایجاد شده توسط مشتری. جدول باید دارای طرحی باشد که شامل ستون های touchpoint ، user_id و event_time باشد. |
credits_tmp_table_name | نام جدول اعتبار موقت کاربر ایجاد شده توسط مشتری. جدول باید دارای طرحی باشد که شامل ستونهای user_id ، credit و conversion_time باشد. |
model | string باید MARKOV_CHAINS باشد. |
جدول خروجی
جدول خروجی شامل طرح زیر خواهد بود:
نام ستون | تایپ کنید |
---|---|
touchpoint | string نام نقطه تماس |
score | integer امتیاز زنجیره مارکوف برای این نقطه تماس محاسبه شده است. |
کد نمونه برای استفاده از تابع با ارزش جدول
SELECT *
FROM ADH.TOUCHPOINT_ANALYSIS(
TABLE tmp.touchpoint_temp_table,
TABLE tmp.user_credit_temp_table,
'MARKOV_CHAINS')