Skip to content

Commit

Permalink
Document the kind of indices returned by findmin/findmax/argmin
Browse files Browse the repository at this point in the history
…/`argmax` (#46705)

This is the sentence used for `find*` functions, introduced by #25577.

Also change "the domain of `f`" to "`domain`" as the domain of `f` can
be a superset of the passed `domain`.

(Spotted at JuliaData/DataFrames.jl#3139.)

---------

Co-authored-by: Jameson Nash <[email protected]>
Co-authored-by: Lilith Orion Hafner <[email protected]>
  • Loading branch information
3 people authored Oct 31, 2023
1 parent 96147bb commit 85ed34c
Showing 1 changed file with 19 additions and 3 deletions.
22 changes: 19 additions & 3 deletions base/reduce.jl
Original file line number Diff line number Diff line change
Expand Up @@ -877,11 +877,12 @@ end
"""
findmax(f, domain) -> (f(x), index)
Return a pair of a value in the codomain (outputs of `f`) and the index of
Return a pair of a value in the codomain (outputs of `f`) and the index or key of
the corresponding value in the `domain` (inputs to `f`) such that `f(x)` is maximised.
If there are multiple maximal points, then the first one will be returned.
`domain` must be a non-empty iterable.
`domain` must be a non-empty iterable supporting [`keys`](@ref). Indices
are of the same type as those returned by [`keys(domain)`](@ref).
Values are compared with `isless`.
Expand Down Expand Up @@ -915,6 +916,9 @@ Return the maximal element of the collection `itr` and its index or key.
If there are multiple maximal elements, then the first one will be returned.
Values are compared with `isless`.
Indices are of the same type as those returned by [`keys(itr)`](@ref)
and [`pairs(itr)`](@ref).
See also: [`findmin`](@ref), [`argmax`](@ref), [`maximum`](@ref).
# Examples
Expand All @@ -936,12 +940,15 @@ _findmax(a, ::Colon) = findmax(identity, a)
"""
findmin(f, domain) -> (f(x), index)
Return a pair of a value in the codomain (outputs of `f`) and the index of
Return a pair of a value in the codomain (outputs of `f`) and the index or key of
the corresponding value in the `domain` (inputs to `f`) such that `f(x)` is minimised.
If there are multiple minimal points, then the first one will be returned.
`domain` must be a non-empty iterable.
Indices are of the same type as those returned by [`keys(domain)`](@ref)
and [`pairs(domain)`](@ref).
`NaN` is treated as less than all other values except `missing`.
!!! compat "Julia 1.7"
Expand Down Expand Up @@ -975,6 +982,9 @@ Return the minimal element of the collection `itr` and its index or key.
If there are multiple minimal elements, then the first one will be returned.
`NaN` is treated as less than all other values except `missing`.
Indices are of the same type as those returned by [`keys(itr)`](@ref)
and [`pairs(itr)`](@ref).
See also: [`findmax`](@ref), [`argmin`](@ref), [`minimum`](@ref).
# Examples
Expand Down Expand Up @@ -1027,6 +1037,9 @@ If there are multiple maximal elements, then the first one will be returned.
The collection must not be empty.
Indices are of the same type as those returned by [`keys(itr)`](@ref)
and [`pairs(itr)`](@ref).
Values are compared with `isless`.
See also: [`argmin`](@ref), [`findmax`](@ref).
Expand Down Expand Up @@ -1082,6 +1095,9 @@ If there are multiple minimal elements, then the first one will be returned.
The collection must not be empty.
Indices are of the same type as those returned by [`keys(itr)`](@ref)
and [`pairs(itr)`](@ref).
`NaN` is treated as less than all other values except `missing`.
See also: [`argmax`](@ref), [`findmin`](@ref).
Expand Down

0 comments on commit 85ed34c

Please sign in to comment.