chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于Python語言的RFM模型講解

數(shù)據(jù)分析與開發(fā) ? 來源:CDA數(shù)據(jù)分析師 ? 作者:CDA數(shù)據(jù)分析師 ? 2022-03-15 15:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

背景

RFM(Recency Frequency Monetary)模型是衡量客戶價(jià)值和客戶創(chuàng)利能力的重要工具和手段。在眾多的客戶關(guān)系管理(CRM)的分析模式中,RFM模型是被廣泛提到的。

RFM模型是屬于業(yè)務(wù)分析方法與模型中的部分。它的本質(zhì)是用戶分類。本文將用現(xiàn)代最流行的編程語言---Python語言來實(shí)踐課堂上講解的RFM模型,將用戶進(jìn)行分類。

本文采用Anaconda進(jìn)行Python編譯,主要涉及的Python模塊:

  • pandas

  • matplotlib

  • seaborn

  • datetime

本章分為三部分講解:

1.RFM模型原理與步驟

2.Python分布實(shí)現(xiàn)RFM

3.總結(jié)

RFM模型原理與步驟

RFM模型的思路是:該模型是根據(jù)用戶歷史行為數(shù)據(jù),結(jié)合業(yè)務(wù)理解選擇劃分維度,實(shí)現(xiàn)用戶分類,助力用戶精準(zhǔn)營銷。此外,還學(xué)習(xí)了構(gòu)建RFM模型的步驟:

  • 獲取R、F、M三個(gè)維度下的原始數(shù)據(jù)

  • 定義R、F、M的評(píng)估模型與判斷閾值

  • 進(jìn)行數(shù)據(jù)處理,獲取R、F、M的值

  • 參照評(píng)估模型與閾值,對(duì)用戶進(jìn)行分層

  • 針對(duì)不同層級(jí)用戶制定運(yùn)營策略

上面步驟可以知道,我們需要有RFM三個(gè)維度,根據(jù)我們?cè)跇I(yè)務(wù)分析方法課程中學(xué)到的,業(yè)務(wù)分析模型離不開指標(biāo),而指標(biāo)是對(duì)度量的匯總。因此,在找出RFM三個(gè)維度后,需要對(duì)每個(gè)維度下度量實(shí)現(xiàn)不同匯總規(guī)則。下面講述對(duì)R、F、M三個(gè)維度下的度量如何進(jìn)行匯總。

1.R代表最近一次消費(fèi),是計(jì)算最近一次消費(fèi)時(shí)間點(diǎn)和當(dāng)前時(shí)間點(diǎn)的時(shí)間差。因此,這里需要用到多維數(shù)據(jù)透視分析中的基本透視規(guī)則---最小值MIN求出最小的時(shí)間差。

2.F代表消費(fèi)頻次,是在指定區(qū)間內(nèi)統(tǒng)計(jì)用戶的購買次數(shù)。因此,這里需要用到多維數(shù)據(jù)透視分析中的基本透視規(guī)則---技術(shù)類COUNT(技術(shù)類不去重指標(biāo))統(tǒng)計(jì)用戶的購買次數(shù)。

3.M代表消費(fèi)金額,是指在指定區(qū)間內(nèi)統(tǒng)計(jì)用戶的消費(fèi)總金額,因此,這里需要用到求和類指標(biāo),也即基本透視規(guī)則中的合計(jì)規(guī)則---SUM。

在對(duì)得到RFM模型中的指標(biāo)值后最重要的一步就是分層,根據(jù)我們?cè)谡n堂上學(xué)到的內(nèi)容,大部分的用戶分層是根據(jù)經(jīng)驗(yàn)來分層的,本文在追求數(shù)據(jù)的客觀性下采取統(tǒng)計(jì)學(xué)中的等距分箱方法來進(jìn)行分層,對(duì)R、F、M三個(gè)維度分成兩類。

綜上,我們大致了解了如何構(gòu)建RFM模型,下面以Python實(shí)現(xiàn)RFM模型,并對(duì)每一步進(jìn)行詳細(xì)的講解。

03 Python實(shí)現(xiàn)RFM模型

數(shù)據(jù)準(zhǔn)備

本文所需的數(shù)據(jù)是一家公司對(duì)2021年10月底至今的客戶購買行為數(shù)據(jù),(前十二行)如圖下:

abd337c8-91e2-11ec-952b-dac502259ad0.png

其中,uid代表客戶的id,是存在重復(fù)情況的。prince維度代表客戶每發(fā)生一次交易行為所花費(fèi)的金額。time為客戶發(fā)生交易行為的時(shí)間。

數(shù)據(jù)讀取與理解

在得到一份數(shù)據(jù)之后,我們第一步就是要理解數(shù)據(jù)的業(yè)務(wù)意義,以及對(duì)數(shù)據(jù)表的EDA(探索性分析),這里通過如下代碼,發(fā)現(xiàn)以下特征:

abeab51a-91e2-11ec-952b-dac502259ad0.png

具體代碼(包含Python導(dǎo)入包部分)如下:

#導(dǎo)入相關(guān)包
importpandasaspd
importtime
importnumpyasnp
importseabornassns
importmatplotlib.pyplotasplt
plt.rcParams['font.sans-serif']=["SimHei"]
plt.rcParams["axes.unicode_minus"]=Falsesns.set(style="darkgrid")

#數(shù)據(jù)讀取與查看
data=pd.read_excel('data.xlsx')
data.head()
data.isnull().sum()#查看缺失值
data.duplicated().sum()#重復(fù)值,但是不刪
data.dtypes#查看數(shù)據(jù)類型
data.describe()

#創(chuàng)建dataframe,存放RFM各值
data_rfm=pd.DataFrame()

接下來進(jìn)行R、F、M指標(biāo)值構(gòu)建。

時(shí)間維度處理

從上文可以知道time維度,即每筆交易行為發(fā)生的時(shí)間是字符串object的格式,而在Python中我們對(duì)時(shí)間作差需要的是datetime格式,因此利用pandas庫中的pd.to_datetime函數(shù)將時(shí)間格式進(jìn)行轉(zhuǎn)換,代碼如下:

data['time']=pd.to_datetime(data['time'])

得到的前五行數(shù)據(jù)如圖下,可以看到數(shù)據(jù)類型變成了datetime64[ns]

abffd4f4-91e2-11ec-952b-dac502259ad0.png

統(tǒng)計(jì)每筆訂單產(chǎn)生時(shí)間與當(dāng)前時(shí)間的差(這里的當(dāng)前時(shí)間是2021年12月11日),得到的差是timedelta64[ns]類型

ac1717fe-91e2-11ec-952b-dac502259ad0.png

可以看到時(shí)間差中包含了day、時(shí)、分、秒4個(gè)維度,但是這里我們僅需要day維度,因此我們用astype()函數(shù)將類型轉(zhuǎn)為僅含有day維度的timedelta64[D]類型。具體代碼如下:

#統(tǒng)計(jì)沒條數(shù)據(jù)與當(dāng)前日期的時(shí)間差
##計(jì)算相差天數(shù)
data['R']=(pd.datetime.now()-data['time'])
##將時(shí)間差timedelta格式轉(zhuǎn)化為需要的日格式
data['R']=data['R'].astype('timedelta64[D]').astype('int')

tips:這里可能會(huì)報(bào)警告:FutureWarning: The pandas.datetime class is deprecated and will be removed from pandas in a future version. Import from datetime module instead.讀者無需理會(huì),這是由于我們所用的pd.datetime.now()是一個(gè)比較舊的函數(shù),以后將會(huì)廢棄。

統(tǒng)計(jì)R值

在上面我們已經(jīng)創(chuàng)建了名為data_rfm的表結(jié)構(gòu)的數(shù)據(jù)框,因此,將下面統(tǒng)計(jì)的R值放入其中。R值得統(tǒng)計(jì)是找客戶最近發(fā)生交易行為日期與當(dāng)前日期的差。換一種思路就是找所有時(shí)間差中的最小值。

因此利用pandas中的groupby函數(shù)對(duì)每個(gè)用戶以上一步統(tǒng)計(jì)的R值作為分組依據(jù)進(jìn)行分組,并求出最小值。具體代碼如下:

data_rfm=pd.merge(data_rfm,data.groupby('uid')['R'].min(),
left_on='user_id',right_on='uid')

統(tǒng)計(jì)F值

F值得統(tǒng)計(jì)就是統(tǒng)計(jì)指定區(qū)間內(nèi)的消費(fèi)頻次,而指定區(qū)間一般為人為設(shè)定,這里我們?nèi)∪繑?shù)據(jù),即2021年10月底至今作為指定區(qū)間。

本文利用value_counts()函數(shù)對(duì)uid進(jìn)行統(tǒng)計(jì)即為每個(gè)用戶得消費(fèi)頻次,同時(shí)將結(jié)果合并到data_rfm數(shù)據(jù)框中。

#統(tǒng)計(jì)指定區(qū)間內(nèi)的消費(fèi)頻次
data_rfm['user_id']=data['uid'].value_counts().index
data_rfm['F']=data['uid'].value_counts().values

統(tǒng)計(jì)M值

本文以uid作為分組依據(jù)對(duì)price字段進(jìn)行求和,得到求和類指標(biāo)M值。此外,將結(jié)果合并到data_rfm數(shù)據(jù)框中。

data_rfm=pd.merge(data_rfm,data.groupby('uid')['price'].sum(),
left_on='user_id',right_on='uid')
data_rfm.rename(columns={'price':'M'},inplace=True)

上述代碼中出現(xiàn)了pandas庫中得合并語法merge(),merge()函數(shù)采取的是橫向合并,不同于MYSQL,不需要指定左表還是右表為主表,只需要提供左表與右表的公共字段在各表中的名稱即可。

由于data_rfm數(shù)據(jù)表中的user_id是去重的,因此將其作為主鍵。而data.groupby('uid')['price'].sum()得到的表格也是去重的,因此我們可以采取多維數(shù)據(jù)模型中的連接對(duì)應(yīng)關(guān)系---一對(duì)一對(duì)兩表進(jìn)行合并。公共字段為:左表的uid,右表的user_id

最終表格結(jié)果如下,展現(xiàn)前18行:

ac2cd22e-91e2-11ec-952b-dac502259ad0.png

數(shù)據(jù)分箱

在得到R、F、M三個(gè)指標(biāo)值后,我們需要對(duì)這三個(gè)指標(biāo)進(jìn)行分類,并將每個(gè)用戶進(jìn)行分層。

本文不采取人為主觀性的經(jīng)驗(yàn)法則劃分,而是采取等距分箱的方式劃分,等距分箱的原理較簡單,這里寫出步驟:

  • 從最小值到最大值之間,均分為$N$等份(這里$N$取為2)。

  • 如果 $A$,$B$ 為最小最大值, 則每個(gè)區(qū)間的長度為 $W=(B?A)/N$ ,.

  • 則區(qū)間邊界值為$A+W$,$A+2W$,….$A+(N?1)W$ 。這里只考慮邊界,采用左閉右開的方式,即每個(gè)等份的實(shí)例數(shù)量不等。

在Python中可以利用pandas庫中的cut()函數(shù)輕松實(shí)現(xiàn)上述等距分箱,同時(shí)將結(jié)果R_label,F_labelM_label合并到data_rfm數(shù)據(jù)框中具體代碼如下:

#分箱客觀左閉右開
cut_R=pd.cut(data_rfm['R'],bins=2,right=False,labels=range(1,3)).astype('int')
data_rfm['R_label']=cut_R

cut_F=pd.cut(data_rfm['F'],bins=2,right=False,labels=range(1,3)).astype('int')
data_rfm['F_label']=cut_F

cut_M=pd.cut(data_rfm['M'],bins=2,right=False,labels=range(1,3)).astype('int')
data_rfm['M_label']=cut_M

由于利用cut()函數(shù)得到的是區(qū)間形式的值,因此需要賦予label值進(jìn)行虛擬變量引用。label值使用1和2,對(duì)應(yīng)的區(qū)間為從小到大。具體代表意思如下表:

ac4e7226-91e2-11ec-952b-dac502259ad0.jpg

得到最終的表格形式如下:

ac628266-91e2-11ec-952b-dac502259ad0.png

用戶分類

在得到每個(gè)用戶的R、F、M三個(gè)維度的label值后,最后就是需要對(duì)用戶進(jìn)行分類,分類的原則如圖下:

ac8f2e7e-91e2-11ec-952b-dac502259ad0.png

利用pandas庫中的·terrows()函數(shù)循環(huán)遍歷每個(gè)用戶行為記錄,將符合上述條件的劃分對(duì)應(yīng)的類,具體代碼如下:

fori,jindata_rfm.iterrows():
ifj['R_label']==2andj['F_label']==2andj['M_label']==2:
data_rfm.loc[i,'用戶類別']='重要價(jià)值用戶'
ifj['R_label']==2andj['F_label']==1andj['M_label']==2:
data_rfm.loc[i,'用戶類別']='重要發(fā)展用戶'
ifj['R_label']==1andj['F_label']==2andj['M_label']==2:
data_rfm.loc[i,'用戶類別']='重要保持用戶'
ifj['R_label']==1andj['F_label']==1andj['M_label']==2:
data_rfm.loc[i,'用戶類別']='重要挽留用戶'
ifj['R_label']==2andj['F_label']==2andj['M_label']==1:
data_rfm.loc[i,'用戶類別']='一般價(jià)值用戶'
ifj['R_label']==2andj['F_label']==1andj['M_label']==1:
data_rfm.loc[i,'用戶類別']='一般發(fā)展用戶'
ifj['R_label']==1andj['F_label']==2andj['M_label']==1:
data_rfm.loc[i,'用戶類別']='一般保持用戶'
ifj['R_label']==1andj['F_label']==1andj['M_label']==1:
data_rfm.loc[i,'用戶類別']='一般挽留用戶'

條形圖可視化用戶類別

利用seaborn畫圖庫對(duì)已劃分類別的用戶進(jìn)行技術(shù)統(tǒng)計(jì)與可視化,得到如下圖表

acabd60a-91e2-11ec-952b-dac502259ad0.png

可以看出,大部分的用戶屬于一般發(fā)展用戶與一般挽留用戶。而對(duì)于一般發(fā)展用戶而言采取的策略為挖掘需求,后者則是放棄治療。因此,可以看出該公司在10月底至今的時(shí)間段內(nèi),用戶流失較多,但是可發(fā)展的用戶同樣是非常多的,想要提高收入,對(duì)一般發(fā)展用戶入手是成本少,效率高的選擇。

總結(jié)

RFM模型同時(shí)還利用了多維數(shù)據(jù)透視分析和業(yè)務(wù)分析方法兩個(gè)模塊的內(nèi)容。所以說實(shí)踐是檢驗(yàn)和鞏固學(xué)到的東西的最好方法。

例如一級(jí)的??碱}上,我們常碰到一個(gè)模擬題,包含RFM模型劃分規(guī)則和一張帕累托圖,問題是在公司有限成本下提高公司收入,需要針對(duì)哪種用戶營銷最好,答案是一般發(fā)展用戶。相信大家一開始都很疑惑為什么選這個(gè),這時(shí)候如果像本文一樣對(duì)一份數(shù)據(jù)進(jìn)行實(shí)踐,這樣你就會(huì)更加理解為什么是這個(gè)答案。

審核編輯:郭婷


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • python
    +關(guān)注

    關(guān)注

    58

    文章

    4888

    瀏覽量

    90320

原文標(biāo)題:基于客觀事實(shí)的 RFM 模型(Python 代碼)

文章出處:【微信號(hào):DBDevs,微信公眾號(hào):數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    解讀大型語言模型的偏見

    在一項(xiàng)新的研究中,研究人員發(fā)現(xiàn)了LLM中某種偏見的根本原因,為更準(zhǔn)確、更可靠的AI系統(tǒng)鋪平了道路。研究表明,大型語言模型(LLM)往往傾向于過分強(qiáng)調(diào)文檔或?qū)υ掗_頭和結(jié)尾的信息,而相對(duì)忽略中間部分
    的頭像 發(fā)表于 04-15 14:44 ?729次閱讀
    解讀大型<b class='flag-5'>語言</b><b class='flag-5'>模型</b>的偏見

    使用PYTHON進(jìn)行的跨平臺(tái)仿真

    如何使用編程語言Python來調(diào)用和控制VirtualLab Fusion中的模擬。請(qǐng)查看下面鏈接的文檔,以找到關(guān)于如何設(shè)置和使用Python和VirtualLab Fusion之間的接口的詳細(xì)指南,以及一個(gè)
    發(fā)表于 04-02 08:21

    世界模型vs大語言模型,圖靈獎(jiǎng)得主#楊立昆 說“大模型是死路!”①#AI #大模型

    語言模型
    江蘇易安聯(lián)
    發(fā)布于 :2026年03月31日 10:17:40

    什么是大模型,智能體...?大模型100問,快速全面了解!

    一、概念篇1.什么是大模型?大模型是指參數(shù)規(guī)模巨大(通常達(dá)到數(shù)十億甚至萬億級(jí)別)、使用海量數(shù)據(jù)訓(xùn)練而成的人工智能模型。2.什么是大語言模型
    的頭像 發(fā)表于 02-02 16:36 ?1146次閱讀
    什么是大<b class='flag-5'>模型</b>,智能體...?大<b class='flag-5'>模型</b>100問,快速全面了解!

    講解C語言代碼的實(shí)現(xiàn)過程

    重點(diǎn)講解C語言代碼的實(shí)現(xiàn)過程,算法的C語言實(shí)現(xiàn)過程具有一般性,通過PID算法的C語言實(shí)現(xiàn),可以以此類推,設(shè)計(jì)其它算法的C語言實(shí)現(xiàn)。 第一步:
    發(fā)表于 01-21 07:58

    摩爾線程新一代大語言模型對(duì)齊框架URPO入選AAAI 2026

    近日,摩爾線程在人工智能前沿領(lǐng)域取得重要突破,其提出的新一代大語言模型對(duì)齊框架——URPO統(tǒng)一獎(jiǎng)勵(lì)與策略優(yōu)化,相關(guān)研究論文已被人工智能領(lǐng)域的國際頂級(jí)學(xué)術(shù)會(huì)議AAAI 2026收錄。這一成果標(biāo)志著摩爾線程在大模型基礎(chǔ)技術(shù)探索上邁出
    的頭像 發(fā)表于 11-17 16:03 ?610次閱讀
    摩爾線程新一代大<b class='flag-5'>語言</b><b class='flag-5'>模型</b>對(duì)齊框架URPO入選AAAI 2026

    一文了解Mojo編程語言

    Mojo 是一種由 Modular AI 公司開發(fā)的編程語言,旨在將 Python 的易用性與 C 語言的高性能相結(jié)合,特別適合人工智能(AI)、高性能計(jì)算(HPC)和系統(tǒng)級(jí)編程場景。以下是關(guān)于
    發(fā)表于 11-07 05:59

    NVIDIA ACE現(xiàn)已支持開源Qwen3-8B小語言模型

    為助力打造實(shí)時(shí)、動(dòng)態(tài)的 NPC 游戲角色,NVIDIA ACE 現(xiàn)已支持開源 Qwen3-8B 小語言模型(SLM),可實(shí)現(xiàn) PC 游戲中的本地部署。
    的頭像 發(fā)表于 10-29 16:59 ?1439次閱讀

    3萬字長文!深度解析大語言模型LLM原理

    我們正在參加全球電子成就獎(jiǎng)的評(píng)選,歡迎大家?guī)臀覀兺镀薄x謝支持本文轉(zhuǎn)自:騰訊技術(shù)工程作者:royceshao大語言模型LLM的精妙之處在于很好地利用數(shù)學(xué)解決了工業(yè)場景的問題,筆者基于過往工程經(jīng)驗(yàn)
    的頭像 發(fā)表于 09-02 13:34 ?3620次閱讀
    3萬字長文!深度解析大<b class='flag-5'>語言</b><b class='flag-5'>模型</b>LLM原理

    利用自壓縮實(shí)現(xiàn)大型語言模型高效縮減

    隨著語言模型規(guī)模日益龐大,設(shè)備端推理變得越來越緩慢且耗能巨大。一個(gè)直接且效果出人意料的解決方案是剪除那些對(duì)任務(wù)貢獻(xiàn)甚微的完整通道(channel)。我們?cè)缙诘难芯刻岢隽艘环N訓(xùn)練階段的方法——自壓
    的頭像 發(fā)表于 07-28 09:36 ?675次閱讀
    利用自壓縮實(shí)現(xiàn)大型<b class='flag-5'>語言</b><b class='flag-5'>模型</b>高效縮減

    C++ 與 Python:樹莓派上哪種語言更優(yōu)?

    Python是樹莓派上的首選編程語言,我們的大部分教程都使用它。然而,C++在物聯(lián)網(wǎng)項(xiàng)目中同樣廣受歡迎且功能強(qiáng)大。那么,在樹莓派項(xiàng)目中選擇哪種語言更合適呢?Python因其簡潔性、豐富
    的頭像 發(fā)表于 07-24 15:32 ?1120次閱讀
    C++ 與 <b class='flag-5'>Python</b>:樹莓派上哪種<b class='flag-5'>語言</b>更優(yōu)?

    【教程】使用NS1串口服務(wù)器對(duì)接智普清言免費(fèi)AI大語言模型

    AI大語言模型可以幫助我們解決各種問題,如翻譯、寫文案、創(chuàng)作詩歌、解決數(shù)學(xué)問題、情感陪伴等等。今天教大家如何使用NS1串口服務(wù)器模塊實(shí)現(xiàn)對(duì)接智普清言AI大語言模型,實(shí)現(xiàn)與大
    的頭像 發(fā)表于 06-12 19:33 ?928次閱讀
    【教程】使用NS1串口服務(wù)器對(duì)接智普清言免費(fèi)AI大<b class='flag-5'>語言</b><b class='flag-5'>模型</b>

    歐洲借助NVIDIA Nemotron優(yōu)化主權(quán)大語言模型

    NVIDIA 正攜手歐洲和中東的模型構(gòu)建商與云提供商,共同優(yōu)化主權(quán)大語言模型 (LLM),加速該地區(qū)各行業(yè)采用企業(yè)級(jí) AI。
    的頭像 發(fā)表于 06-12 15:42 ?1396次閱讀

    跟老齊學(xué)Python:從入門到精通

    礎(chǔ)的學(xué)習(xí)者介紹一門時(shí)下比較流行、并且用途比較廣泛的編程語言,所以,本書讀起來不晦澀,并且在其中穿插了很多貌似與Python 編程無關(guān),但與學(xué)習(xí)者未來程序員職業(yè)生涯有關(guān)的內(nèi)容。 獲取完整文檔資料可下載附件哦?。。。?如果內(nèi)容有幫助可以關(guān)注、點(diǎn)贊、評(píng)論支持一下哦~
    發(fā)表于 06-03 16:10

    瑞薩RZ/V2H平臺(tái)支持部署離線版DeepSeek -R1大語言模型

    瑞薩RZ/V2H平臺(tái)支持部署離線版DeepSeek -R1大語言模型
    的頭像 發(fā)表于 05-13 17:07 ?1875次閱讀
    瑞薩RZ/V2H平臺(tái)支持部署離線版DeepSeek -R1大<b class='flag-5'>語言</b><b class='flag-5'>模型</b>