WebSafe 3.7wikifunctions.org
|
|
🏠
Jump to content

Wikifunctions:Suggest a function

From Wikifunctions

Do you have an idea for a new function? Suggest it here! It may help to refer to our glossary.

You can create a function right away if you have the user-rights.

If a function requires a new type, consider proposing it.

Note that for now we only support a limited number of types as input and output types of functions. More types are coming in the next few months. For the full list, see WF:Type.

Once created, consider adding new Functions to the catalogue.

Proposed functions requiring only available types

String

String character discard functions

String character replacement functions

String search functions

String escaping and unescaping functions

String encoding and decoding functions

String presentation functions

String colour notation functions

String notation validation checks

String validation checks

  • check if string is a valid ISO 3166 country code
  • check if string is a valid EDTF date/time

String analysis functions

Monolingual text

String Wikitext operations

...

Natural number

Integer

Byte

See existing Byte functions in catalogue.

  • next byte without overflow: byte → byte
  • previous byte without overflow: byte → byte
  • next byte by Gray code: byte → byte
  • previous byte by Gray code: byte → byte
  • all bits set: byte → boolean
  • no bits set: byte → boolean
  • add bytes without overflow: byte, byte → byte
  • subtract bytes without overflow: byte, byte → byte
  • multiply bytes without overflow: byte, byte → byte
  • add bytes with overflow: byte, byte → byte
  • subtract bytes with overflow: byte, byte → byte
  • multiply bytes with overflow: byte, byte → byte
  • modulo bytes: byte, byte → byte
  • byte division: byte, byte → byte
  • right shift: byte → byte
  • left shift: byte → byte
  • right shift by n: byte, natural number → byte
  • left shift by n: byte, natural number → byte
  • right shift as ring: byte → byte
  • left shift as ring: byte → byte
  • right shift by n as ring: byte, natural number → byte
  • left shift by n as ring: byte, natural number → byte

Unicode code point

See existing code point functions in catalogue.

  • Codepoint to list of bytes for UTF-8
  • Codepoint to list of bytes for UTF-16
  • Codepoint to list of bytes for UTF-32

Object

List

Basic list/iterable functions

Complex list functions

CSV list operations

Functions with functions as arguments

  • test whether certain functions have specific properties of homogeneous relations for particular lists/sets

Gregorian calendar date

See catalogue of calendar date functions for existing functions.

  • Create a reading function for Dagbani that handles all the possible formats (both the English-linke and the traditional ones, both the Gregorian and the Hijra calendars). Dv103 (talk) 15:43, 31 May 2025 (UTC)[reply]
  • same day of the year: date, date → boolean
  • same day of the week: date, date → boolean
  • within a year: date, date → boolean
  • within a week: date, date → boolean
  • within n days: date, date → boolean
  • months between: date, date → natural number
  • weeks between: date, date → natural number
  • n days later: date, natural number → date
  • n days earlier: date, natural number → date
  • n weeks earlier: date, natural number → date
  • n months later: date, natural number → date
  • n months earlier: date, natural number → date
  • n years later: date, natural number → date
  • n years earlier: date, natural number → date
  • Julian day number to date: integer → date
  • how many leap days passed between two dates: date, date → natural number
  • how many weekdays between two dates: date, date, day of the week → natural number
  • within JavaScript's date implementation: date → boolean
  • next time a day of the month is on a specific weekday: date, natural number, day of the week → date
  • next Friday the 13th: date → date
  • nth weekday of the month: date, day of the week, natural number → date
  • nth working days after: date, list of wikidata item references (list of holidays), wikidata item reference (place) → date

Gregorian year

See catalogue of year functions for existing functions.

Morphological functions

morphology is the part of linguistics that studies how language parts are 'shaped' and change diachronically and when inflected. Hausa, Igbo, Malayalam, Bangla/Bengali and Dagbani are focus languages for Wikidata's lexicographic dataset, which is an important aspect of Abstract Wikipedia.

mul - Multiple languages

ase - American Sign Language

  • string: Stokoe to ase-Sgnw and vice-versa (consult @Slevinski: as to best approach)

bn - Bangla

bzs - Brazilian Sign Language

cy - Welsh

w:en:colloquial Welsh morphology

dag - Dagbani

de - German

  • tense * person * number for each verb
    • tenses: present, past, ...?
    • person: first, second, third
    • number: singular, plural
    • 22.5px Doing... third person singular present
    • second person singular preterite

en - English

eu - Basque

  • Basque language declension system in rather regular based on suffixes.
    • Here a few examples for Basque declension:
    • Before implementing all of them, we may propose an overall classification that eases both the implementation and the future usage of the functions. Here a first try based on bibliography from the Basque Language Academy:
      • Personal pronouns: they can be treated as exceptions (e.g. "zuek -> zuei", etc.) together with proper noun declension, or as a separate case.
      • Determiners: they can be treated as exceptions (e.g. "hau" -> "honek", etc) together with common noun declension, or as a separated case
      • Grammatical cases:
        • Absolutive ("Nor"): indefinite, singular and plural
        • Ergative ("Nork"): indefinite, singular and plural
        • Dative ("Nori"): indefinite, singular and plural
      • Place and Time: we must distinguish animate (AN) and inanimate (IN)
        • Inessive IN ("Non"): indefinite, singular and plural
        • Inessive AN ("Norengan"): indefinite, singular and plural - It could be a composition of "Noren" + "-gan"
        • Place and time ("Nongo"): indefinite, singular and plural
        • Allative IN ("Nora"): indefinite, singular and plural
        • Allative AN ("Norengana"): indefinite, singular and plural - It could be a composition of "Noren/Norengan" + "-gan/-a"
        • Finished Allative AN ("Noraino"): indefinite, singular and plural - It could be a composition of "Nora" + "-ino"
        • Finished Allative AN ("Norengainaino"): indefinite, singular and plural - It could be a composition of "Noregana" + "-ino"
        • Right way Allative IN ("Noratz"): indefinite, singular and plural - It could be a composition of "Nora" + "-ntz"
        • Right way Allative AN ("Norenganantz"): indefinite, singular and plural - It could be a composition of "Norengana" + "-ntz"
        • Ablative IN ("Nondik"): indefinite, singular and plural
        • Ablative AN ("Norengandik"): indefinite, singular and plural
      • Rest of the cases:
        • Partitive ("Zerik"): indefinite
        • Possessive ("Noren"): indefinite, singular and plural
        • Sociative ("Norekin"): indefinite, singular and plural
        • Instrumental ("Zerez"): indefinite, singular and plural
        • Motivative ("Zerengatik"): indefinite, singular and plural
        • Destinative ("Norentzat"): indefinite, singular and plural - It could be a composition of "Noren" + "-tzat"
      • Special case:
        • Prolative ("Nortzat"): indefinite
      • To take into consideration:
        • Together with animate and inanimate classification, we should also consider if the noun is a proper noun ("izen berezia"). We can identify that automatically (e.g. check if written in Title case, but this may not be always possible like in the beginning of sentences), but a dedicated function may be preferred (or a boolean to the generic function saying it is a proper noun).
        • The main distinction is between noun ending by vowel or consonant that can be easily computed

fr - French

ha - Hausa

A notated demo sentence ("Aishà taa jeefar dà kàren Indoo" ― "Aisha threw away Indo's dog") is available at http://intent.xigt.org

ig - Igbo

ldn - Láadan

section moved to WF:human languages/Z1882

ml - Malayalam

nl - Dutch

  • Cardinals
    • Cardinal to number
    • Number to cardinal
  • Verbs
  • Morphology
    • Diminutive to root word
      • Belgian diminutive to root word
    • Root word to diminutive
      • Belgian root word to diminutive (-ke)
    • Plural diminutive to root word
      • Belgian plural diminutive to root word
    • Root word to plural diminutive
      • Belgian root word to plural diminutive (-kes)

kcg - Tyap

  • Tyap has six determiners/definite articles which determine the pronoun, number (1-5), etc. forms used.
    • ka & wu (basically for singular nouns and adjectives with a few exceptions)
    • hu & ji (for singular and plural nouns and adjectives)
    • ba & na (mainly for plural nouns.
      • Determiners come after nouns.
      • When an adjective comes before a noun, the determiner used is that of the adjective. E.g., a̱sham (ka) - (the) beautiful, kyang (hu) - (the) thing = a̱sham kyang (ka) - (the) beautiful thing.
  • Tyap has a non-uniform noun class system used for noun pluralization and conversion from one part of speech to another. E.g., a̱bwom (song) and bwom (to sing), a̱fufwuo (ears) and fufwuo (ear).
  • Affixation: Prefixes exist but suffixes hardly are found.

vgt - Flemish Sign Language

Proposed functions requiring future types

Note these functions cannot be implemented properly until the needed types are requested and approved.

If one wishes to nevertheless attempt to define and implement them,

  • the functions and implementations should indicate prominently in their labels that their input/output types must be adjusted once support for the appropriate replacement types become available; and
  • the functions should not be used in the implementations of any other functions, as the later adjustment of input/output types to appropriate replacements will break those implementations.

String manipulation functions

String analysis functions

  • count distance between two letters in given alphabet (default to 26-charcater western alphabet. case insensitive. e.g. "a" & "A" ⇒ 0; "K" & "N" ⇒ 3)

String encoding and decoding functions

(would be better with types representing a stream of bytes)

  • BASE45 encode
  • BASE45 decode
  • Hexadecimal UTF-8 encode ("ABC ₤" ⇒ "41 42 43 20 E2 82 A4")
  • Hexadecimal UTF-8 decode ("41 42 43 20 E2 82 A4" ⇒ "ABC ₤")
  • Decimal UTF-8 encode ("ABC ₤" ⇒ "65 66 67 32 226 130 164")
  • Decimal UTF-8 decode ("65 66 67 32 226 130 164" ⇒ "ABC ₤")
  • Octal UTF-8 encode ("ABC ₤" ⇒ "101 102 103 40 342 202 244")
  • Octal UTF-8 decode ("101 102 103 40 342 202 244" ⇒ "ABC ₤")
  • Binary UTF-8 encode ("ABC ₤" ⇒ "01000001 01000010 01000011 00100000 11100010 10000010 10100100")
  • Binary UTF-8 decode ("01000001 01000010 01000011 00100000 11100010 10000010 10100100" ⇒ "ABC ₤")
  • Unicode code point encode ("ABC ₤" ⇒ "41 42 43 20 20A4") - Unicode code point encode hex (Z10785): Takes a Unicode string and returns a space-separated list of hexadecimal Unicode code points.
  • Unicode code point decode ("41 42 43 20 20A4" ⇒ "ABC ₤")
  • Create regular expression object/string (i.e: "test" & "i" to /test/i)

Natural language functions

Cryptographic functions

(would be better with types representing a stream of bytes)

Date, time, and calendric functions

Discussion of types: WF:type#Calendar types

Bengali calendar

Gregorian to Bengali date (Bangladesh) (Z12926): Converts a Gregorian date to Bangla date per Bangladeshi calendar. Inputs: Year, Month, Day.

Chinese calendar

French Republican Calendar

decimalises and secularises the Gregorian

Gregorian

widely used calendar derived from the Julian, basis for ISO 8601


Named Day from Date or day of year ; Input type : Date ; Output Type : String. ; The initial use case was automated population of On The Day, based on various collections of Holidays, festival days and observances. ? ShakespeareFan00 (talk) 19:35, 26 March 2025 (UTC)[reply]

So If you gave it 2025-05-01 It said "All Fools Day" etc.. Possibly an additional input of enumrated type to indicate which data set to pull holidays, fesitvals and observances from.

ShakespeareFan00 (talk) 19:35, 26 March 2025 (UTC)[reply]

Diary/calander Header function - Using the above and other date functions, generates a data set from a given date. Hence if you give it 2003-05-01 you get back a JOSN set contianing the {Day of week:String, Day in the Month, Observances} etc. ShakespeareFan00 (talk) 19:35, 26 March 2025 (UTC)[reply]

Holocene calendar

Indian national calendar

Islamic

a Lunar calendar, also called Hijri

Julian

mostly used by astronomers, some historians, and some Orthodox Christian denominations

Mesoamerican calendars

including civil and clerical forms

Persian

also called Jalali

Thai calendar

Hebrew calendar

Darian calendar

Proposed time-keeping system for Mars, requires Julian Date/Time to calculate and a month enumeration: WF:type proposals#Something to think about

Basic numerical functions

Data serialization functions

Basic list/iterable functions requiring numeric types

Geodetics functions

w:en:planetary coordinate system, w:en:well-known text representation of coordinate reference systems

Earth

  • convert coordinates outside of the ranges (-180, 180) for longitude and (-90, 90) for latitude to a canonical form
  • Plus Codes to/from geocoordinates
    • functions should match the semantics of the expected API: is valid Plus Code?, is shortened Plus Code?, is full Plus Code?, Plus Code from co-ordinates (Z25963): only works with WGS84, co-ordinates from Plus Code (SW corner), shorten Plus Code, recover nearest Plus Code
    • implementations for JS and Python are provided, Apache 2.0 licenced, not sure how self-contained they are
    • most of the functions could also be implemented by composition
    • sample data is provided for testing (it's ~500 cases for each of encode/decode and ~50 cases for each of the others, but they're grouped nicely so maybe take 1 from each)

Mars

w:en:areography#Cartography and geodesy

  • convert coordinates outside of the ranges [0, 360) for longitude and (-90, 90) for latitude to a canonical form

Moon

w:en:selenography#Lunar cartography and toponymy

Unit conversion functions

Conversion function : 2D Cartesian to 2D Polar

Input : matrix [x,y] Output: matrix [θ,r] Short text : Polar conversion of x,y to a polar space centred at 0,0 in the Cartesian. Constraints: x,y,r are reals (float64), θ lies in the range -π<0<π (Sign determined in relation to standards used in STEM applications. ShakespeareFan00 (talk) 14:30, 26 March 2025 (UTC)[reply]

The companion could also be provided. As I never did Geodetic functions, I am not sure how Lat, Long to map projection would work , but useful. ShakespeareFan00 (talk) 14:30, 26 March 2025 (UTC)[reply]
See also WF:Type proposals/complex128. YoshiRulz (talk) 10:17, 1 December 2025 (UTC)[reply]

Trigonometric functions

ShakespeareFan00 (talk) 19:40, 26 March 2025 (UTC)[reply]

WrenFalcon (talk) 22:05, 31 July 2025 (UTC)[reply]


Function proposal : Decimalise angle of the form ('1:x' or '1 in x') to % (in 100) or ‰ (in 1000)

  • Suggested name: gardient_decimal.
  • Input type: Integer ( The 1 is implied.). Lower Bound +1: Upper Bound: 1000 (for most practical situations?)
  • Output type: Real/float 64.

Proposer: ShakespeareFan00 (talk) 19:05, 28 March 2025 (UTC)[reply]

Color Functions

Colorspace Conversion

x,y,Y to sRGB (Illuminant D65). Input : 3tuple of float64, Output: 3 tuple of integer, where 0>=r<=255, 0>=g<=255 0>=b<=255.

Convert a color specfied as 3 float64 values, from x,y,Y colorspace to sRGB or raise an "Out of Gaumt" exception. ShakespeareFan00 (talk) 19:09, 7 April 2025 (UTC)[reply]

Spectral Approximate from sRGB or XYZ values.

I'd like to see the techniques detailed here: http://scottburns.us/reflectance-curves-from-srgb/ implemented in Wikifunctions as the provided spreadhseet later in the paper doesn't appear to work with Libre Office. ShakespeareFan00 (talk) 19:32, 2 June 2025 (UTC)[reply]

Subtractive color mix (Pigment style)

Implement the mixing function from Spectral.js (https://github.com/rvanwijnen/spectral.js/blob/3.0.0/spectral.js )(MIT license), to allow 2 or more sRGB triplets to be mixed like pigment colors. This is different from the subtract colors function implemented previously.

Music Functions

It would be nice to have 12 equal temperament pitch class and 12 equal temperament pitch types, as they would be useful for calculating harmonies and melodies. The pitch classes could be stored as natural numbers from 0 to 11, and represented with symbols C, C♯, D, ..., B. The pitches could be stored as integers with -1 being B3, 0 being C4, 1 being C♯4, etc. Over time, we could expand the pitch class and pitch types to other temperaments and just intonation. As I'm new to Wikifunctions and my coding skills are next to zero, this is just a suggestion to the community. (edited) CaffeineP (talk) 14:48, 9 April 2025 (UTC)[reply]

Yes… There are some notational challenges because of enharmonics as well as naming conventions varying by language/culture, so English A♯ is equivalent to German B and English B♭, for example. Ideally, I would want the (English) pitch class that is five semitones higher than G♭ to be displayed as C♭ rather than B.
Also, given some reference pitch like A4 = 440 Hz, we should be able to return the frequency in hertz of a given pitch and, conversely, the nearest pitch for a given frequency and its offset in cents (or whatever). The computation is a lot simpler than representing the result (or capturing how the result should be represented)! GrounderUK (talk) 20:08, 9 April 2025 (UTC)[reply]
If you use the cardinal values for the pitches from the MIDI standard (or an extension to such, since they're limited to 0..<128) then you could make some of these functions already, no type proposal needed. Granted a lot of them would just be addition/subtraction. And if you semi-arbitrarily map A = 0, A# = 1, etc. then you could do all of them. YoshiRulz (talk) 10:33, 1 December 2025 (UTC)[reply]

SVG Functions

I would be nice to generate SVG (a XML-based vector image format which is basically a long string), it could allow to replace a lot of images on Commons or templates/tools. Here some examples:

  • create simple forms,
  • create graphs (line graph/bar graph for population or for production, elections diagrams like File:1900Hawaii.svg, etc.),
  • create more complex visualisation like genealogical trees,
  • create coat of arms (?),
  • etc.

Cheers, VIGNERON (talk) 10:47, 23 April 2025 (UTC)[reply]

@VIGNERON: Eventually that is something we might support, but there'll be nothing any time soon. It has a number of complex security and scalability concerns, sadly. Jdforrester (WMF) (talk) 13:21, 23 April 2025 (UTC)[reply]
@Jdforrester (WMF): thanks. I talked about it for the last Corner but I wanted to leave a record here, if we have time, maybe I'll use that time to write some things to prepare (like listing templates and tools on the Wikimedia projects that generate SVG or visualisations). Cheers, VIGNERON (talk) 15:28, 23 April 2025 (UTC)[reply]
Of course! I've explicitly added a section on this here: Wikifunctions:Embedded function calls#Non-text output — hope that helps assure you that we're thinking about it. Jdforrester (WMF) (talk) 21:40, 23 April 2025 (UTC)[reply]

Biology

Taxon functions

A taxon type could be useful, as could a taxon rank enum (instance of (P31) taxonomic rank (Q427626)). --WrenFalcon (talk) 16:49, 22 September 2025 (UTC)[reply]


Object / type / function functions

External function lists