数学建模社区-数学中国

标题: 市场营销问题 (二):产品属性的效用函数 [打印本页]

作者: 浅夏110    时间: 2020-6-15 11:42
标题: 市场营销问题 (二):产品属性的效用函数
一般来讲,每种产品(如某种品牌的小汽车)都有不同方面的属性,例如价格、安 全性、外观、保质期等。在设计和销售新产品之前,了解顾客对每种属性的各个选项的 偏好程度非常重要。偏好程度可以用效用函数来表示,即某种属性的不同选项对顾客的 价值(效用)。不幸的是,让顾客直接精确地给出每个属性的效用函数一般是困难的, 例如对于价格,一般的顾客当然会说越便宜越好,但很难确定10万元的价格和15万元 的价格的效用具体是多少。但是,对于具体的产品,产品的各个属性的具体选项配置都 已经确定下来了,所以如果我们把一些具体的产品让顾客进行评估打分,顾客通常能比 较容易地给出具体产品的效用。那么,从这些具体产品的效用信息中,我们能否反过来 估计每个属性中各个选项的效用呢?这种方法通常称为联合分析(conjoint analysis)。下面通过一个例子来说明。* ~+ P# s9 g# P' J$ ~) [- l& f7 E

8 U" `* Z5 w+ g% L; A3 L/ ?8 o例11  对某种牌号的小汽车,假设只考虑两种属性:价格和安全气囊。价格分为 12.9万元、9.9万元、7.9万元;安全气囊的配置为两个、一个、没有。经过市场调查, 顾客对该产品的不同配置的偏好程度(效用)如表9所示(表中的值(权重)越大表示 顾客越喜欢)。那么,价格和安全气囊的效用函数如何? % t7 x# \3 R, N- W: b$ d
& Z& L: I3 r" |

: m, D% L4 r% A" H: T7 Q' I4 v3 m
( O, ]- C8 B5 f; }" O7 t, w (1)模型建立 . a7 q2 W' `6 a: e
# G7 [* k$ y/ J% H; Z* D7 J
记价格选项分别为H(高),M(中),L(低),对应的效用为   (  j= H,M,L);安全气囊选项分别为0,1,2,对应的效用为  ( i=0,1,2)。我们的目的实际上就是要求出 。 假设价格和安全气囊的效用是线性可加的,即当价格选项为 j 、安全气囊选项为i时,具体产品的效用  应该可以用价格的和安全气囊的效用之和来估计 ! L8 t+ v  G. _! y* O% I2 ~% M
                                                        (1) $ Y" N0 n$ G% K# i1 P3 w0 X8 @
                 那么,如何比较不同的估计的好坏呢?一种简单的想法是针对6个待定参数   。表中给出了9组数据,因此可以用小二乘法确定 。也就是说,此时的目标为 ( d! B5 ~$ ?+ J, s8 t% G

* C3 [! g+ p* {: A) k  c                                                      ( 2 )& c1 w/ I; y9 ?, T: |; @+ a- k
% w( v! L( t0 ~0 _# g) v! Q) j
                其中  是表中的数据(安全气囊选项为i、价格选项为 j 时具体产品的效用)。, k$ C: R% ]0 [' c* x8 `5 w3 A* x# f
( B! \$ ^- Y. I  B" T
因为做效用分析的主要目的是将来用于把不同配置的具体产品的优劣次序排出来,所以另一种方法是希望 保持同样的顺序:即对任意的  和 ,当 时,也尽量有 (这里“+1”表示 严格小于   ,且至少相差1)。于是,可以考虑如下目标函数  6 ^& p2 j( I$ H! j9 p1 h/ G

1 z6 _2 v9 B9 s) r; i: R! M                                      (3) / Y* N( ?4 q9 b2 z  x- D
            式中的求和只是对满足 的  和   求和。在LINGO中由于所0 r0 v- ?; f3 R% o& e
有的变量默认的都为非负变量,程序中式(3 )可以改写为  
# E3 ^* Q2 h8 h9 x& o" ~, A  d. r/ _  D  h" R- j
              ; a' |+ Q; ~& U0 P% a/ u4 W
7 h- m1 e0 Q6 D9 S+ t# i' i# M
  (2)模型求解  
: [5 `2 f4 @& |6 n' }4 M/ Q" z. {  H( @5 ~
LINGO程序如下:
4 a' U, N! F8 ?% n& ]
3 N2 h7 Z8 P7 sMODEL: & H4 Z; u7 X  r3 z1 a- o) i8 h' D
TITLE 产品属性的效用函数; $ I6 y+ T( S3 n" B- v- J
SETS:     
1 S) [8 n5 T  E' V6 E    PRICE/H,M,L/;   ! k+ Y0 x5 [: h) ^1 B; {- {
    SAFETY/2,1,0/;     / k2 j- O( x. ?) C7 Q- b* ~: p" k
    M(safety,PRICE):CI;     
3 e) p# }3 K- ?4 t    MM(M,M)|CI(&1,&2)+1 #LE# CI(&3,&4):ERROR; 1 _8 Y8 m  A( k4 t. x! ]! g1 @4 Y
ENDSETS
1 X9 [5 t9 [- ]$ |! j& a; y  qDATA:    5 `0 \- @: i+ n- h( H( z( B
    CI=7  8  9  3  4  6  1  2  5;
% N5 ]" H" r" ~- nENDDATA
1 D0 U0 @) f9 u  q# E@FOR(MM(i,j,k,l):ERROR(i,j,k,l)>1+P(j)+Q(i)-(P(l)+Q(k))); . H# b. m& [% a4 K9 I5 y6 q- J
[obj] MIN = @SUM(mm: ERROR);
; p6 v- q1 g8 l' @END
, @0 M$ v! F; r& U            求解这个模型,得到
2 G1 Z; s: \. D( b' m0 e7 z' o- ^3 Q: i$ t) G
              5 p" k6 W' S5 ]) w
, v; L+ e; A, w2 \+ m8 K1 E
              此时模型的最优值(误差和)为0,所以说明在这个效用函数下,虽然得到的产品 权重(效用)与问题中给出的数据不完全相同,但产品的相对偏好顺序是完全一致的。
3 {: q  b  I: H2 j# p3 R9 Z
* g7 h4 y2 }  a% l/ ^+ u  D (3)模型的讨论 3 ]2 {2 z# k! y& L  K
4 I5 H- C5 f( {) H; o& l
下面我们看看用小二乘法确定  和  的结果是否与此相同。此时的模型实际上就是一个简单的二次规划模型。LINGO程序为
& n6 m3 o) ]% N5 {! n
( X- y/ x; f$ y" c+ tMODEL: * p1 X1 P$ y7 J; f$ b2 c+ b1 R
TITLE 小二乘法计算产品属性的效用函数;
* u7 V9 z! S+ WSETS:     4 ~* z+ f6 c5 I% `. F3 p
    PRICE/H,M,L/;         5 _% r+ E  b: g; {9 D9 p+ }
    SAFETY/2,1,0/;     
$ |+ F2 X& p. F( V1 k    M(safety,PRICE):CI,ERROR,sort;
5 n* I+ m2 F" N8 fENDSETS # p- l% y. {% y/ S! m) M
DATA:     - l5 M: C  B1 I& W& R& P8 r; s
    CI =7  8  9  3  4  6  1  2  5; 8 [& g) a5 b, R2 _  t7 W% G7 E
ENDDATA
3 A* N8 W( R, J- a/ f  _9 L$ q8 J@FOR(M(i,j):sort(i,j)=p(j)+q(i);ERROR(i,j)= sort(i,j)-CI(i,j) );
( F+ z- u3 [; L( L# ?/ A  @5 {MIN=@SUM(Msqr(ERROR)); 4 u% w5 h) [% \! o+ v. a" P3 _
@FOR(M(i,j): @FREE(ERROR) );
& |4 F7 T9 \, Q8 }3 w- i!@FOR(pricegin(P));
: s6 q* _1 P% X!@FOR(safetygin(Q)); 2 B! F, G2 n! r' {
END
6 w7 Y5 w; q1 \6 Y- v* e( s4 m上面模型中的sort变量表示的就是按照这里新计算的效用函数得到的不同配置下 的产品的效用。 通过运行LINGO程序,可以看到,此时的效用函数的结果与前面得到的结果不同, 但仔细察看SORT的结果可以发现,不同配置产品之间的相对顺序仍然是保持的。 不过,小二乘法得到的产品的效用是一些带有小数的数,实际中使用不太方便。 如果希望得到整数解,只需要在模型中“END”语句前增加下面两行语句: @FOR(pricegin(P)); @FOR(safetygin(Q)); 求解结果中,SORT(1,M)=SORT(0,L)=4,这两个配置没能分辨出来。
8 C) ]8 l+ A' N( s/ ~2 |; h2 X$ j( @
综合这些讨论,结论还是我们在基本模型中给出的结果比较令人满意。请读者思考 一下:基本模型中并没有要求决策变量取整数,为什么正好是整数?这是偶然的,还是 必然的? + Y! i: @) k2 W$ b; _5 w
————————————————3 v8 }' _1 ]% I$ m' j# v1 ]
版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
% K. E" r: q5 s6 E) n/ O原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89413066
' G/ l* n" n. e" l6 ^) j5 L4 a9 f% T( Y& \" w1 w4 d

6 a/ H0 K# a" X




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5