Statistics variables and commands
|
12-12-2023, 04:58 PM
Post: #3
|
|||
|
|||
RE: Statistics variables and commands
I'm guessing Carlos may have intended this to apply to a 50g, since that is in his hand in his avatar. Hopefully he will clarify. I'll assume that is indeed the case until we hear otherwise.
There's a built-in MEAN command, but that operates on a matrix that must be stored in the special global variable ΣDAT. Since Carlos mentioned that his data is already in list form, it's easy enough to do this manually with no dependence on the built-in statistical variables. The following assumes that the input is always a list of numeric values, with at least one element in the list. An empty list is undefined, and will cause errors for the calculations of mean and median. Here's one way to find the arithmetic mean: Code: \<< The only extra consideration needed with the above is that ΣLIST throws an error when given a list with only 1 element. I worked around this by adding a 0 element, which insures that there will be at least 2 elements in the list (we already ruled out an empty list as invalid). Calculating the median is a bit more interesting, only in that the final result depends on whether the element count is even or odd. Here's one way to compute the median: Code: \<< Perhaps the most important concept in the above approach is in determining the list size/2. That intermediate result can then be used in multiple ways. Namely:
Determining the mode of a list of numbers is definitely more complex than the mean or median. While it can certainly be done with standard RPL commands, I'm inclined to make use of some specific functions from the ListExt library that make short work of this: Code: \<< The result of this program is always a list, since there can be more than one value that meets the criteria. The list elements are the mode values for the given input. I'm reasonably certain that there's no more than 1-2 people that could make sense of the above (including myself ). Using the following input list as an example, here's an explanation of the steps: Given { 5 1 3 1 5 1 3 1 3 3 4 2 } as input SORT sorts the given list of numbers in increasing order { 1 1 1 1 2 3 3 3 3 4 5 5 } LRPCT (List RePeat CounT) converts the sorted list to a list containing 2 sublists: the unique list elements, and a corresponding list containing the counts of each element encountered. { { 1 2 3 4 5 } { 4. 1. 4. 1. 2. } } EVAL simply explodes the above list of sublists into two separate lists to be left on the stack. { 1 2 3 4 5 } { 4. 1. 4. 1. 2. } KSORT (Key SORT) sorts both lists on the stack using the list of elements in stack level 1 as the keys. { 2 4 5 1 3 } { 1. 1. 2. 4. 4. } DUP REV HEAD obtains the final element from the stack level 1 list (which in this case is the highest count). { 2 4 5 1 3 } { 1. 1. 2. 4. 4. } 4. MPOS results in a list showing the position of each stack level 1 item in the list in stack level 2. So this gives us the positions of all elements with the (same) highest count. { 2 4 5 1 3 } { 4. 5. } LPICK simply extracts the elements in the stack level 2 list that are in the positions indicated in the stack level 1 list. { 1 3 } So the mode of the given input list is a list containing the elements 1 and 3, since both of those appear the maximum count of times. |
|||
« Next Oldest | Next Newest »
|
Messages In This Thread |
Statistics variables and commands - CMarangon - 12-11-2023, 08:39 PM
RE: Statistics variables and commands - StephenG1CMZ - 12-11-2023, 10:55 PM
RE: Statistics variables and commands - DavidM - 12-12-2023 04:58 PM
RE: Statistics variables and commands - DavidM - 12-12-2023, 05:36 PM
|
User(s) browsing this thread: 2 Guest(s)