forked from echen/dirichlet-process
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathchinese_restaurant_process.rb
38 lines (34 loc) · 1.21 KB
/
chinese_restaurant_process.rb
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
# Generate table assignments for `num_customers` customers, according to
# a Chinese Restaurant Process with dispersion parameter `alpha`.
#
# Returns an array of integer table assignments.
#
# Examples
#
# chinese_restaurant_process(num_customers = 5, alpha = 1)
# => [1, 2, 3, 4, 3]
#
# chinese_restaurant_process(num_customers = 10, alpha = 3)
# => [1, 2, 1, 1, 3, 1, 2, 3, 4, 5]
#
def chinese_restaurant_process(num_customers, alpha)
return [] if num_customers <= 0
table_assignments = [1] # first customer sits at table 1
next_open_table = 2 # index of the next empty table
# Now generate table assignments for the rest of the customers.
1.upto(num_customers - 1) do |i|
if rand < alpha.to_f / (alpha + i)
# Customer sits at a new table.
table_assignments << next_open_table
next_open_table += 1
else
# Customer sits at an existing table.
# He chooses which table to sit at by giving equal weight to each
# customer already sitting at a table.
which_table = table_assignments[rand(table_assignments.size)]
table_assignments << which_table
end
end
table_assignments
end
puts chinese_restaurant_process(num_customers = 10, alpha = 3).join(", ")