ts.bottom() | Teradata Package for R - ts.bottom() - Teradata Package for R

Teradata® Package for R User Guide

Product
Teradata Package for R
Release Number
17.00
Published
July 2021
Language
English (United States)
Last Update
2023-08-08
dita:mapPath
yih1585763700215.ditamap
dita:ditavalPath
ayr1485454803741.ditaval
dita:id
B700-4005
Product Category
Teradata Vantage

The aggregate function ts.bottom() returns the smallest number of values in the argument "value.expression" for each group, with or without ties.

  • This function is valid only on columns with numeric types.
  • Nulls are not included in the result computation.
Arguments:
  • value.expression: Specifies the column from which bottom values are to be returned.
  • number.of.values: Specifies the integer value representing the number of values to return.
  • with.ties: Specifies a flag to decide whether to run bottom function with ties or not.

    Default value is FALSE.

Example 1: Get the smallest 2 values without ties of a sequenced PTI table

This example gets the smallest 2 values of the 'temperature' column for each group without ties of the sequenced PTI table.

  • Retrieve the smallest values.
    > df_seq_bottom <- df_seq_grp %>% summarise(bottom_temp = ts.bottom(temperature, 2))
    
  • Print the results.
    > df_seq_bottom %>% arrange(TIMECODE_RANGE, buoyid, bottom_temp)
    # Source:     lazy query [?? x 4]
    # Database:   [Teradata 16.20.50.01] [Teradata Native Driver 17.0.0.2]
    #   [TDAPUSER@<hostname>/TDAPUSERDB]
    # Ordered by: TIMECODE_RANGE, buoyid, bottom_temp
       TIMECODE_RANGE                                  `GROUP BY TIME(MINUTES~ buoyid bottom_temp
       <chr>                                           <int64>                  <int>       <int>
     1 2014-01-06 08:00:00.000000+00:00,2014-01-06 08~ 35345                        0          10
     2 2014-01-06 08:00:00.000000+00:00,2014-01-06 08~ 35345                        0          10
     3 2014-01-06 09:00:00.000000+00:00,2014-01-06 09~ 35347                        1          70
     4 2014-01-06 09:00:00.000000+00:00,2014-01-06 09~ 35347                        1          71
     5 2014-01-06 10:00:00.000000+00:00,2014-01-06 10~ 35349                       44          43
     6 2014-01-06 10:00:00.000000+00:00,2014-01-06 10~ 35349                       44          43
     7 2014-01-06 10:30:00.000000+00:00,2014-01-06 11~ 35350                       22          23
     8 2014-01-06 10:30:00.000000+00:00,2014-01-06 11~ 35350                       44          43
     9 2014-01-06 10:30:00.000000+00:00,2014-01-06 11~ 35350                       44          43
    10 2014-01-06 21:00:00.000000+00:00,2014-01-06 21~ 35371                        2          80
    # ... with more rows

Example 2: Get the smallest 2 values with ties of a non-PTI table

This example gets the smallest 2 values of the 'temperature' column for each group with ties of the non-PTI table.

  • Retrieve the smallest values.
    > df_nonpti_bottom <- df_nonpti_grp %>% summarise(bottom_temp = ts.bottom(temperature, 2, TRUE))
  • Print the results.
    > df_nonpti_bottom %>% arrange(TIMECODE_RANGE, bottom_temp)
    # Source:     lazy query [?? x 3]
    # Database:   [Teradata 16.20.50.01] [Teradata Native Driver 17.0.0.2]
    #   [TDAPUSER@<hostname>/TDAPUSERDB]
    # Ordered by: TIMECODE_RANGE, bottom_temp
       TIMECODE_RANGE                                        `GROUP BY TIME(MINUTES(~ bottom_temp
       <chr>                                                 <int64>                        <int>
     1 2014-01-06 08:00:00.000000+00:00,2014-01-06 08:01:00~ 23149921                          10
     2 2014-01-06 08:01:00.000000+00:00,2014-01-06 08:02:00~ 23149922                          10
     3 2014-01-06 08:02:00.000000+00:00,2014-01-06 08:03:00~ 23149923                          10
     4 2014-01-06 08:03:00.000000+00:00,2014-01-06 08:04:00~ 23149924                          10
     5 2014-01-06 08:04:00.000000+00:00,2014-01-06 08:05:00~ 23149925                          10
     6 2014-01-06 08:05:00.000000+00:00,2014-01-06 08:06:00~ 23149926                          10
     7 2014-01-06 08:06:00.000000+00:00,2014-01-06 08:07:00~ 23149927                          10
     8 2014-01-06 08:07:00.000000+00:00,2014-01-06 08:08:00~ 23149928                          10
     9 2014-01-06 08:08:00.000000+00:00,2014-01-06 08:09:00~ 23149929                          NA
    10 2014-01-06 08:09:00.000000+00:00,2014-01-06 08:10:00~ 23149930                          99
    # ... with more rows