====== random_p() ====== ''int **random_p**(array //distribution//)'' Returns a number from the //distribution//. Each number can be assigned an individual probability in the process. * //distribution//\\ An array which specifies the possible numbers as keys, and their probability as a value. Therefore, each number is assigned a probability (number ''%%=>%%'' probability). The probability can be specified as a percentage (e.g. ''0.25''), or as a relative proportion (e.g. ''20''). **Note:** The distribution of the drawn values only converges once there have been many draws (n > 1000) of the distribution specified. If you are working with a lower number of cases, use [[:en:create:random_urns|randomization with urns]], and enter some numbers more often in the urn, if these should be drawn more often. **Note:** Use the function ''[[:en:create:functions:put|put()]]'' to save the drawn value in the data record. ===== Example 1 ===== In the first example, a number between 1 and 4 is drawn. Numbers 1 and 3 each have a 20% chance of being drawn, number 2 has a 50% chance, and number 4 has a 10% chance. All three random numbers in the first example have the same random distribution. // Define distribution $distribution = array( 1 => 20, 2 => 50, 3 => 20, 4 => 10 ); // Draw number between 1 and 4 $number = random_p($distribution); // Save the result of the random draw put('IV01_01', $number); // Show corresponding stimulus if ($number == 1) { text('stimulusA'); } elseif ($number == 2) { text('stimulusB'); } elseif ($number == 3) { text('stimulusC'); } else { text('stimulusD'); } The probabilities can also be listed as floating-point numbers (with a point as the decimal separator). The numbers can be written directly one after the other as well. // Probabilities as floating-point numbers $distribution = array(1=>0.2, 2=>0.5, 3=>0.2, 4=>0.1); The probabilities do __not__ have to add up to 1 or 100. // Probabilities as ratios $distribution = array(1=>4, 2=>10, 3=>4, 4=>2); And, of course, the distribution does __not__ have to be saved separately in a variable. // Draw number between 1 and 4 $number = random_p(array( 1 => 2, 2 => 5, 3 => 2, 4 => 1 )); ===== Example 2 ===== The second example demonstrates how a random selection can be made depending on the respondent's response. The example assumes that in question "PS19", how often 7 television stations were watched was requested, ranging from 1 (never), 2 (rarely), 3 (often) and 4 (almost daily). One of the television stations watched at least rarely should now be selected at random. However, preference should be given to television stations 2, 5 and 6. // Create a list in which all television stations watched appear $watched = getItems('PS19', 'min', 2); // If no station is watched, the survey is over if (count($watched) < 1) { goToPage('end'); } // Define probabilities for the various stations $pAll = array( 1 => 10, 2 => 20, 3 => 10, 4 => 10, 5 => 20, 6 => 30, 7 => 10 ); // A distribution must now be created for the stations watched $pWatched = array(); foreach ($watched as $station) { $pWatched[$station] = $pAll[$station]; } // Weighted random selection from the stations watched $focus = random_p($pWatched); // Store the subject matter put('PS20_01', $focus);