Tzolkin 0.9.24

There is a newer version of this package available.
See the version list below for details.
dotnet add package Tzolkin --version 0.9.24
NuGet\Install-Package Tzolkin -Version 0.9.24
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Tzolkin" Version="0.9.24" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Tzolkin --version 0.9.24
#r "nuget: Tzolkin, 0.9.24"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Tzolkin as a Cake Addin
#addin nuget:?package=Tzolkin&version=0.9.24

// Install Tzolkin as a Cake Tool
#tool nuget:?package=Tzolkin&version=0.9.24

Tzolkin Icon Tzolkin

This cross platform - Linux, Mac OS X and Windows - F# .Net library and smartphone app converts Maya Tzolk’in dates to Gregorian dates and vice versa.

Smartphone app screenshot 1 Smartphone app screenshot 2

If you want to know more about the Maya calendar systems, see Links.

Information about the smart-phone app is at Usage of the Smartphone App

A video of the smart-phone app is at YouTube.

To interactively try out the F# NuGet package Tzolkin, go to the Jupyter Notebook at Binder badge

Full documentation can be found at Read the Docs

MIT license badge F# 5.0 badge OS badge Nuget Package badge Documentation Status Binder badge more badges ...

Table of Content

Smithsonian Museo Nacional del Indígena Americano: Viviendo El Tiempo Maya

Website of the Smithsonian National Museum of the American Indian on Mayas Living Maya Time.

Online general Maya (not only Tzolk’in) calendar converter: Maya Converter of the Smithsonian NMAI

Convertidor Al Calendario Maya Smithsonian NMIA

Meaning of the Tzolk’in day glyphs Arqueología Mexicana

Mayan Glyphs and Unicode: Roadmap to the SMP and the PDF Updated List of Characters for Mayan Codices

Download

Link to the latest release

List of changes: CHANGELOG.md

Android

Install the package for your smart-phone (.apk for Android) onto your phone - search the web on how you can do that, this depends on your phone

iOS

I can’t generate an iPhone package myself, so you have to build the project IOS for yourself and provision the app to your phone. Microsoft has a how-to here

NuGet Package

Download an install the Tzolkin Nuget package using your IDE (Visual Studio or JetBrains Rider) or one of the command-line possibilities: Tzolkin Package at NuGet

In an interactive F# FSI session, you can use the command #r "nuget: Tzolkin" to download and use the NuGet package LunaZodiaco.

Installation and Usage

Usage of the Smartphone App

See YouTube video of the smart-phone app for a video.

Android Screenshot 1 Android Screenshot 2 Android Screenshot 3 Android Screenshot 4 Android Screenshot 5 Android Screenshot 6 Android Screenshot 7 Android Screenshot 8 Android Screenshot 9 Android Screenshot 10 Android Screenshot 11 Android Screenshot 12 Android Screenshot 13 Android Screenshot 14 Android Screenshot 15 Android Screenshot 16

Tzolkin NuGet Package

A F# Maya Tzolk’in date converter and calculator library.

Install Package & Basic Usage

Download an install the Tzolkin Nuget package using your IDE (Visual Studio or JetBrains Rider) or one of the command-line possibilities: Tzolkin Package at NuGet

In an interactive F# FSI session, you can use the command #r "nuget: NUGET_PACKAGE" to download and use the nuget package NUGET_PACKAGE.

To use Tzolkin in this interactive session:

#r "nuget: Tzolkin"
>>  Installed package Tzolkin version 0.9.16

Everything is contained in the namespace RC.Maya, so let's open that

open RC.Maya

To check if everything's working, we call TzolkinDate.today to get todays (today is the 23th of April, 2021) Tzolk’in date - 7 Chikchan.

TzolkinDate.today
>>  Number  Glyph
>>      7   Chikchan
Create Tzolk’in Dates

A Tzolk’in date consists of a Tzolk’in day number and a Tzolk’in day glyph. A day number is a int between 1 and 13 (including 1 and 13). A day glyph is one of the 20 names "Imix", "Ikʼ", "Akʼbʼal", "Kʼan", "Chikchan", "Kimi", "Manikʼ", "Lamat", "Muluk", "Ok", "Chuwen", "Ebʼ", "Bʼen", "Ix", "Men", "Kʼibʼ", "Kabʼan", "Etzʼnabʼ", "Kawak" and "Ajaw".

A Tzolk’in day number is represented by the type TzolkinNumber.T with a constructor TzolkinNumber.T.TzolkinNumber.

let tzolkinN = TzolkinNumber.T.TzolkinNumber 5
tzolkinN
     Item
        5

But as only certain ints are allowed Tzolk’in day numbers, we have the constructor TzolkinNumber.create, that returns a TzolkinNumber option: None if the given int is non-positive (0 or negative) and values modulo 13 else, but with 13 instead of 0 if n ≡ 0 (mod 13).

TzolkinNumber.create 3
    Value
        3
TzolkinNumber.create 56
    Value
        4
TzolkinNumber.create -8
    None
TzolkinNumber.create 26
     Value
        13

Same for Tzolk’in day glyphs TzolkinGlyph:

let tzolkinG = TzolkinGlyph.T.TzolkinGlyph 5
tzolkinG.ToString ()
    Chikchan
TzolkinGlyph.create 14
     Value
        Ix
TzolkinGlyph.create -7
    None
TzolkinGlyph.create 232
      Value
        Ebʼ

We can also construct a TzolkinGlyph from a string using either TzolkinGlyph.fromString:

TzolkinGlyph.fromString "Kabʼan"
     Value
    Kabʼan
TzolkinGlyph.fromString "Kab'an"
    None

or TzolkinGlyph.parseString to also allow non-exact strings.

TzolkinGlyph.parseString "Kabʼan"
     Value
    Kabʼan
TzolkinGlyph.parseString "Kab'an"
     Value
    Kabʼan
TzolkinGlyph.parseString "K-a'b++AN"
     Value
    Kabʼan

TzolkinGlyph.parseString ignores most punctuation characters, and is suitable to parse user input.

The list TzolkinGlyph.glyphNames contains all Tzolk’in day glyph names as string:

TzolkinGlyph.glyphNames
    index     value
        0      Imix
        1       Ikʼ
        2   Akʼbʼal
        3      Kʼan
        4  Chikchan
        5      Kimi
        6    Manikʼ
        7     Lamat
        8     Muluk
        9        Ok
        10   Chuwen
        11      Ebʼ
        12     Bʼen
        13       Ix
        14      Men
        15    Kʼibʼ
        16   Kabʼan
        17 Etzʼnabʼ
        18    Kawak
        19     Ajaw

A Tzolk’in day TzolkinDate is a record with two fields, Number and Glyph:

let tzolkin = { TzolkinDate.Number = TzolkinNumber.T.TzolkinNumber 13; TzolkinDate.Glyph = TzolkinGlyph.T.TzolkinGlyph 17 }
tzolkin
>>    Number  Glyph
>>       13  Kabʼan

It can be created with a TzolkinNumber and a TzolkinGlyph:

let tzolkinN = TzolkinNumber.T.TzolkinNumber 13
let tzolkinG = TzolkinGlyph.T.TzolkinGlyph 17

TzolkinDate.create tzolkinN tzolkinG
>>    Number  Glyph
>>       13  Kabʼan

But this does not check the input, so invalid dates can be a result.

let tzolkinN = TzolkinNumber.T.TzolkinNumber 65
let tzolkinG = TzolkinGlyph.T.TzolkinGlyph 6

TzolkinDate.create tzolkinN tzolkinG
>>    Number  Glyph
>>       65    Kimi

The constructor TzolkinDate.fromInts checks the input and returns an TzolkinDate option:

TzolkinDate.fromInts 13 17
        Value
    13 Kabʼan
TzolkinDate.fromInts -3 14
        None
TzolkinDate.fromInts 13 -6
        None

There exists two constructor to create a TzolkinDate from strings.

TzolkinDate.fromStrings creates a TzolkinDate option from 2 strings:

TzolkinDate.fromStrings "13" "Kabʼan"
        Value
    13 Kabʼan
TzolkinDate.fromStrings "-3" "Kabʼan"
        None
TzolkinDate.fromStrings "13" "FOO"
        None

TzolkinDate.fromString creates a TzolkinDate from a combined date. The day number and day glyph can be separated by whitespace, by a punctuation character or not at all:

TzolkinDate.fromString "13 Kabʼan"
        Value
    13 Kabʼan
TzolkinDate.fromString "13-Kabʼan"
        Value
    13 Kabʼan
TzolkinDate.fromString "13Kabʼan"
        Value
    13 Kabʼan

Both TzolkinDate.fromString and TzolkinDate.fromStrings parse the glyph name string and ignore almost all punctuation characters in it. So these functions are suitable to parse user input.

TzolkinDate.fromString "13 kA*b`aN"
        Value
    13 Kabʼan
TzolkinDate.fromStrings "13" "k*a-b´`^aN#"
        Value
    13 Kabʼan
Conversion to Integers and Strings

All Tzolk’in types can be converted to int and string, using int (only TzolkinNumberand TzolkinGlyph) or toInt (all 3) and either the function toString or the member function ToString:

let tzolkinG = TzolkinGlyph.T.TzolkinGlyph 17

TzolkinGlyph.toString tzolkinG
        Kabʼan
tzolkinG.ToString ()
        Kabʼan
int tzolkinG
        17

A TzolkinNumber can be converted to an int using int:

let tzolkinN = TzolkinNumber.T.TzolkinNumber 13

int tzolkinN
        13

A TzolkinDate can be converted to an int using TzolkinDate.toInt, returning the number of the day in the Tzolk’in year of 260 days:

let tzolkin = TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)

TzolkinDate.toInt tzolkin
    117

A TzolkinDate can be converted to a string using it's member function ToString:

let tzolkin = TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)

tzolkin.ToString ()
        13 Kabʼan

Or using the function TzolkinDate.toString:

let tzolkin = TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)

TzolkinDate.toString tzolkin
        13 Kabʼan
Convert Gregorian Dates to Tzolk’in Dates

We can get the Tzolk’in date of the current day using TzolkinDate.today (today is the 23th of April, 2021, 7 Chikchan)

TzolkinDate.today
>>    Number    Glyph
>>         7 Chikchan

To get the Tzolk’in date of a given Gregorian date, there are the functions TzolkinDate.fromDate - to convert from a DateTime. We use the 25th of May, 2021.

TzolkinDate.fromDate (DateTime (2021, 05, 25))
>>    Number  Glyph
>>       13  Kabʼan

TzolkinDate.fromDateString to convert from a date string given and a date format string

TzolkinDate.fromDateString "25.05.2021" "dd.MM.yyyy"
>>    Number  Glyph
>>       13  Kabʼan

TzolkinDate.fromISOString to convert from a ISO date string, the format is "yyyy-MM-dd"

TzolkinDate.fromISOString "2021-05-25"
>>    Number  Glyph
>>       13  Kabʼan

We can also get the Tzolk’in day number of a Gregorian date by using TzolkinNumber.fromDate:

TzolkinNumber.fromDate (DateTime (2021, 05, 25))
    Item
      13

The Tzolk’in day glyph we can get using TzolkinGlyph.fromDate.

let tzolkin = TzolkinGlyph.fromDate (DateTime (2021, 05, 25))
tzolkin
    Item
      17

A TzolkinGlyph is an int between 1 and 20 (including 1 and 20), so we need to use toString or the member function ToString to get the name.

TzolkinGlyph.toString tzolkin
       Kabʼan
tzolkin.ToString ()
        Kabʼan
Find Tzolk’in Dates

To find a Tzolk’in date before or after a given Gregorian Date, there exist the functions getNext and getLast.

To get the next day after the given Gregorian date with the Tzolk’in date we search for, we use getNext. To get the next Gregorian date with a Tzolk’in date of 13 Kabʼan after the 23th of April, 2021. We should get the 25th of May, 2021 as a result.

let tzolkin = TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)

TzolkinDate.getNext tzolkin (DateTime (2021, 04, 23))
    '2021-05-25 00:00:00Z'

getLast returns the Gregorian date before the start date.

TzolkinDate.getLast tzolkin (DateTime (2021, 05, 30))
    '2021-05-25 00:00:00Z'

TzolkinGlpyh and TzolkinNumber have both getNext and getLast too:

let tzolkinG = TzolkinGlyph.T.TzolkinGlyph 17

TzolkinGlyph.getNext tzolkinG (DateTime (2021, 05, 16))
    '2021-05-25 00:00:00Z'
let tzolkinN = TzolkinNumber.T.TzolkinNumber 13

TzolkinNumber.getLast tzolkinN (DateTime (2021, 05, 30))
    '2021-05-25 00:00:00Z'

We can get lists of Gregorian dates with the same Tzolk’in date after or before a start date by using getNextList and getLastList.

Get the list of 10 dates with a Tzolk’in date of 13 Kabʼan after the 23th of April, 2021:

let tzolkin =  TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)

TzolkinDate.getNextList 10 tzolkin (DateTime (2021, 04, 23))
     index          value
         0   '2021-05-25 00:00:00Z'
         1   '2022-02-09 00:00:00Z'
         2   '2022-10-27 00:00:00Z'
         3   '2023-07-14 00:00:00Z'
         4   '2024-03-30 00:00:00Z'
         5   '2024-12-15 00:00:00Z'
         6   '2025-09-01 00:00:00Z'
         7   '2026-05-19 00:00:00Z'
         8   '2027-02-03 00:00:00Z'
         9   '2027-10-21 00:00:00Z'

getLastList includes the start date, if the start date has a Tzolk’in date that we are searching for, getNextList does not incllude the start that in that case.

TzolkinDate.getLastList 5 tzolkin (DateTime (2021, 05, 25))
     index          value
         0   '2021-05-25 00:00:00Z'
         1   '2020-09-07 00:00:00Z'
         2   '2019-12-22 00:00:00Z'
         3   '2019-04-06 00:00:00Z'
         4   '2018-07-20 00:00:00Z'
         5   '2017-11-02 00:00:00Z'

TzolkinNumber and TzolkinGlyph have these functions too:

let tzolkinN = TzolkinNumber.T.TzolkinNumber 13

TzolkinNumber.getNextList 5 tzolkinN (DateTime (2021, 05, 16))
     index          value
         0   '2021-05-25 00:00:00Z'
         1   '2021-06-07 00:00:00Z'
         2   '2021-06-20 00:00:00Z'
         3   '2021-07-03 00:00:00Z'
         4   '2021-07-16 00:00:00Z'
let tzolkinG = TzolkinGlyph.T.TzolkinGlyph 17

TzolkinGlyph.getLastList 10 tzolkinG (DateTime (2021, 05, 30))
     index          value
         0   '2021-05-25 00:00:00Z'
         1   '2021-05-05 00:00:00Z'
         2   '2021-04-15 00:00:00Z'
         3   '2021-03-26 00:00:00Z'
         4   '2021-03-06 00:00:00Z'
         5   '2021-02-14 00:00:00Z'
         6   '2021-01-25 00:00:00Z'
         7   '2021-01-05 00:00:00Z'
         8   '2020-12-16 00:00:00Z'
         9   '2020-11-26 00:00:00Z'
Calculations with Tzolk’in Dates

We can add ints - meaning days - and TimeSpans to the 3 Tzolk’in types:

let tzolkinN = TzolkinNumber.T.TzolkinNumber 13

tzolkinN + -6
    Item
       7
let tzolkinG = TzolkinGlyph.T.TzolkinGlyph 17

8 + tzolkinG
    Item
       5
let tzolkin =  TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)

tzolkin + TimeSpan.FromDays -7.0
>>    Number  Glyph
>>         6     Ok
TimeSpan.FromDays 186. + tzolkinN
    Item
       4

And we can calculate the difference in days between two TzolkinDates, TzolkinNumbers or TzolkinGlyphs by subtracting them.

let tzolkinN1 = TzolkinNumber.T.TzolkinNumber 13
let tzolkinN2 = TzolkinNumber.T.TzolkinNumber 7

tzolkinN2 - tzolkinN1
    -6
let tzolkinG1 = TzolkinGlyph.T.TzolkinGlyph 6
let tzolkinG2 = TzolkinGlyph.T.TzolkinGlyph 17

tzolkinG2 - tzolkinG1
    11

The difference between 2 TzolkinDates is always non-negative and between 0 and 260 (including 0 and 260). So, given tz1 - tz2, the result is int tz1 - int tz2 if tz1 > tz2 and is 260 - int tz2 + int tz1 (260 - (int tz2 - int tz1)) else.

let tzolkin1 =  TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)
let tzolkin2 =  TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 6) (TzolkinGlyph.T.TzolkinGlyph 2)

tzolkin2 - tzolkin1
    45
tzolkin1 - tzolkin2
    215
Tzolk’in Year, Glyph descriptions and Unicode Glyphs

We get a F# map of all 260 days to the Tzolk’in days in the Tzolk’in year using TzolkinDate.yearMap, the same map as strings we get by using TzolkinDate.yearStringMap.

TzolkinDate.yearStringMap ()
      key      value
        1     1 Imix
        2     2 Ikʼ
        3     3 Akʼbʼal
        4     4 Kʼan
        5     5 Chikchan
        6     6 Kimi
        7     7 Manikʼ
        8     8 Lamat
        9     9 Muluk
       10    10 Ok
       11    11 Chuwen
       12    12 Ebʼ
       13    13 Bʼen
       14     1 Ix
       15     2 Men
       16     3 Kʼibʼ
       17     4 Kabʼan
       18     5 Etzʼnabʼ
       19     6 Kawak
       20     7 Ajaw
         (240 more)

TzolkinDate.dayInYear returns the number of the Tzolk’in date in the Tzolk’in year, an inte between 1 and 260 (including 1 and 260). 13 Kabʼan is the 117th day of the Tzolk’in year:

let tzolkin =  TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)

TzolkinDate.dayInYear tzolkin
    117

This is the same as the function toInt:

TzolkinDate.toInt tzolkin
    117

You can get the description contained in a TzolkinGlyph.GlyphDescription record of a Tzolk’in day glyph in spanish using the function TzolkinGlyph.getDescription:

let tzolkinG = TzolkinGlyph.T.TzolkinGlyph 17

TzolkinGlyph.getDescription tzolkinG
    Meaning:          Tierra
    ElementOrAnimal:  Tierra y los temblores
    Direction:        sur
    Color:            amarillo
    God:              diosa I o diosa de la sensualidad y el amor
    Url:              https://arqueologiamexicana.mx/dias-mayas

TzolkinNumber and TzolkinGlyph contain a function toUnicode, that returns the Unicode code point for the Tzolk’in day number or Tzolk’in day glyph. As of now, these code points are not yet part of the Unicode standard, but will be included in the future. I made a TTF font containing these numbers and glyphs, that you can use under the CC BY-SA 4.0 license at GitHub.

let tzolkin =  TzolkinDate.create (TzolkinNumber.T.TzolkinNumber 13) (TzolkinGlyph.T.TzolkinGlyph 17)

TzolkinNumber.toUnicode tzolkin.Number
    𕎱
TzolkinGlyph.toUnicode tzolkin.Glyph
    𕐖

Contributing

Any help is welcome!

If you encounter a problem using Tzolkin, a task it not as easy as you'd like it to be or you'd like something added to it: open an issue at GitHub, see section Report Issues.

See page Contributing at Read the Docs for a detailed description.

License

All content except some images of Tzolkin is licensed under the MIT license, see file LICENSE.

Privacy Policy

Tzolkin does not collect or share any personal information, it does not contain any ads, trackers or in-app-payments. See: Privacy Policy

Badges

Code coverage

codecov

GitHub Actions/Workflows

Tests Mac OS X latest Tests Ubuntu 20.04 Tests Windows 2019

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.9.25 439 2/19/2022
0.9.24 2,184 6/15/2021
0.9.22 2,154 5/7/2021
0.9.20 270 4/27/2021
0.9.19 296 4/25/2021
0.9.16 303 4/23/2021

Initial Release