توپ و جعبه

از ویکی‌پدیا، دانشنامهٔ آزاد

مسئله توپ-و-جعبه یک مسئله کلاسیک در نظریه احتمال است که کاربردهای بسیاری در علوم کامپیوتر دارد. این مسئله شامل m توپ و n جعبه (یا "سطل") است. هر بار یک توپ در یک جعبه قرار داده می‌شود. پس از آنکه همه توپ‌ها در جعبه‌ها قرار گرفت، تعداد هر جعبه را بار (load) آن جعبه می‌نامیم. در این مسئله یافتن مقدار یا یک کران برای بیشینه (ماکزیمم) بار حائز اهمیت است.

بدیهی است که می‌توان با قرار دادن توپ در جعبه با کمترین بار به بار m/n رسید. در انتخاب جعبه‌ها مسئله وقتی در حوزه احتمالات قرار می‌گیرد که جعبه‌ها کاملاً (تخصیص تصادفی کامل) یا بعضاً (تخصیص تصادفی جزئی) به صورت تصادفی انتخاب شوند.

تخصیص تصادفی کامل[ویرایش]

زمانی که برای هر توپ، جعبه به‌طور تصادفی و مستقل از دیگر انتخاب‌ها، انتخاب می‌شود، بیشینه بار ممکن است به بزرگی . هرچند می‌توان یک کران محدود برای «حداکثر بار» که با احتمال بالا صادق است، به‌دست آورد. یک «احتمال بالا» یک احتمال یعنی زمانی که n به سمت بینهایت میل می‌کند، احتمال به میل خواهد کرد.

برای مورد با احتمال بالا حداکثر بار:[۱][۲]

.

Gonnet[۳] یک کران محدود برای امید ریاضی بیشینه بار به‌دست آورد که برای برابر . معکوس تابع گاماست و برابراست با

بیشینه بار همچنین می‌تواند برای محاسبه شود. به عنوان مثال برای مقدار بیشینه بار با احتمال بالا برابر است با و برای با احتمال بالا برابر است با .[۴]

تخصیص تصادفی جزئی[ویرایش]

به‌جای انتخاب تصادفی جعبه برای هر توپ، می‌توان دو جعبه یا بیشتر به صورت تصادفی انتخاب کرد و توپ را در جعبه با بار کمتر قرار داد. تخصیص تصادفی جزئی، بین حالت تخصیص قطعی که در آن جعبهٔ با بار کمتر انتخاب می‌شود و حالت کاملاً تصادفی قرار دارد که در آن جعبه به صورت کاملاً تصادفی بدون توجه به بار جاری آن انتخاب می‌شود.

در این حالت اگر m توپ و n جعبه داشته باشیم (که m=n) و برای هر توپ جعبه به صورت تصادفی در هر مرحله انتخاب شود و سپس توپ در جعبه با بار کمتر از بین d جعبه قرار داده شود، آنگاه با احتمال بالا بیشینه بار برابر است با:

[۵]

که به صورت نمایی کمتر از تخصیص تصادفی کلی است.

می‌توان برای (که ) نیز این نتیجه را تعمیم داد، که با احتمال بالا بیشینه بار برابر است با:[۶]

توجه شود که برای را به‌دست می‌دهد. بهبود بین این دو فرایند به ویژه برای .

جریان بی‌نهایت از توپ‌ها[ویرایش]

به جای قرار دادن m توپ، می‌توان حالتی را در نظر گرفت که در آن در یک فرایند نامحدود، یک توپ قرار داده شود و یک توپ برداشته شود به نحوی که تعداد توپ‌ها همواره ثابت بماند. برای m=n، پس از یک زمان طولانی، با احتمالاً بالا بار بیشینه شبیه نسخه نامتناهی مسئله، هم برای تخصیص تصادفی کلی و هم برای تخصیص تصادفی جزئی می‌شود.[۵]

کاربردها[ویرایش]

تخصیص پویای منابع: تعداد n دستگاه کامپیوتر یکسان را در نظر بگیرید. n کاربر هم وجود دارند. کاربران با یکدیگر هماهنگ نیستند و هر کاربر کامپیوتری را که می‌خواهد انتخاب می‌کند. هر کاربر منطقا کامپیوتر با بار کمینه را انتخاب خواهد کرد، که البته لازمه آن این است که بار روی هر کامپیوتر محاسبه شود و این خود ممکن است زمان طولانی ای نیاز داشته باشد. راه دیگر این است که هر کاربر کامپیوتری را به صورت تصادفی انتخاب کند، که در این حالت با احتمال بالا بار بیشینه

درهم سازی (Hashing): یک جدول درهم سازی را در نظر بگیرید که در آن همه کلیدهایی که به یک محل نگاشت شده‌اند در یک لیست پیوندی ذخیره می‌شوند. بازدهی دسترسی به کلید به طول لیست بستگی دارد. اگر از یک تابع درهم سازی استفاده کنیم که که مکان‌ها را با احتمال یکنوا انتخاب می‌کند، با احتمال بالا طولانی‌ترین زنجیره (لیست) کلید دارد. یک بهبود برای این وضعیت استفاده از دو تابع درهم سازی و قرار دادن کلید در لیست کوتاه‌تر است. در این حالت با احتمال بالا طولانی‌ترین زنجیره فقط عنصر دارد.[۷]

Proportional division.[۸]

منابع[ویرایش]

  1. Kolchin, Valentin F. (1978). Random allocations. Washington: Winston [usw.] ISBN 978-0-470-99394-1.
  2. Kotz, Samuel; Johnson, Norman Lloyd (1977). Urn models and their applications. New York, NY: John Wiley & Sons. ISBN 978-0-471-44630-9.
  3. Gonnet, Gaston H. (1981). "Expected Length of the Longest Probe Sequence in Hash Code Searching". Journal of the Association for Computing Machinery. 28 (2): 289–304. doi:10.1145/322248.322254.
  4. Raab, Martin (1998). ""Balls into Bins" — A Simple and Tight Analysis". Lecture Notes in Computer Science: 159–170. doi:10.1007/3-540-49543-6_13.
  5. ۵٫۰ ۵٫۱ Azar, Yossi; Broder, Andrei Z.; Karlin, Anna R.; Upfal, Eli (1999). "Balanced Allocations". SIAM Journal on Computing. 29 (1): 180–200. doi:10.1137/s0097539795288490.
  6. Berenbrink, Petra; Czumaj, Artur; Steger, Angelika; Vöcking, Berthold (2006). "Balanced Allocations: The Heavily Loaded Case". SIAM Journal on Computing. 35 (6): 180–200. doi:10.1137/S009753970444435X.
  7. Karp, R. M. (1996). "Efficient PRAM simulation on a distributed memory machine". Algorithmica. 16 (4–5): 517–542. doi:10.1007/bf01940878.
  8. Jeff Edmonds and Kirk Pruhs (2006). "Balanced Allocations of Cake". 2006 47th Annual IEEE Symposium on Foundations of Computer Science (FOCS'06): 623. doi:10.1109/focs.2006.17. ISBN 0-7695-2720-5.