TableData.st
author Claus Gittinger <cg@exept.de>
Mon, 18 Mar 2019 16:24:14 +0100
changeset 4885 f23f8cf58b0c
parent 4789 4daaaab89349
child 4971 0bfb49cbcd3d
permissions -rw-r--r--
mingw
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4789
4daaaab89349 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4781
diff changeset
     1
"{ Encoding: utf8 }"
4daaaab89349 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4781
diff changeset
     2
4781
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"{ Package: 'stx:libbasic2' }"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
"{ NameSpace: Smalltalk }"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
Object subclass:#TableData
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	instanceVariableNames:'rowData columnNames columnTypes tableName'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
	classVariableNames:''
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
	poolDictionaries:''
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
	category:'Collections-Tables'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
!TableData class methodsFor:'documentation'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
documentation
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
    Ongoing work to support some algorithms on table data (such as CSV files).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
    Snippets to read and process tabular (CSV) data
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
    [author:]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
        Claus Gittinger
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
    [instance variables:]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
        rowData                 the actual data
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
        columnNames             name per column 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
        columnTypes             type per column (default is String)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
        tableName               name - only used for labeling graphs
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
    [class variables:]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
    [see also:]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
!TableData class methodsFor:'instance creation'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
fromFile:filename
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
    ^ self new readCSV:filename
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
     self fromFile:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    "Created: / 06-01-2019 / 13:28:53 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
    "Modified: / 09-01-2019 / 12:08:02 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
rows:rowData columnNames:names
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
    ^ self new rows:rowData columnNames:names
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
    "Created: / 06-01-2019 / 13:25:37 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
rows:rowData columnNames:names tableName:tableName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
    ^ self new rows:rowData columnNames:names tableName:tableName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
    "Created: / 06-01-2019 / 19:24:47 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
!TableData methodsFor:'accessing'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
getColumn:index
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
    "return a column as  a vector"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
    ^ rowData collect:[:row | row at:index].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
        getColumn:1.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    "Created: / 06-01-2019 / 19:04:08 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
    "Modified (comment): / 09-01-2019 / 12:14:35 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
getColumnNamed:name
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
    ^ self getColumn:(self indexOfColumnNamed:name)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
        getColumnNamed:'TXK'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
    "Created: / 06-01-2019 / 19:04:24 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
    "Modified (comment): / 09-01-2019 / 12:14:41 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
getColumns:indexCollection
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
    ^ rowData collect:[:row | 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
        indexCollection collect:[:eachColIdx | row at:eachColIdx] as:Array.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
    ].        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
        getColumns:#(1 2 3).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
    "Created: / 06-01-2019 / 19:04:47 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
    "Modified (comment): / 09-01-2019 / 12:14:44 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
getColumnsNamed:names
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
    |colsIndices|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
    colsIndices := names collect:[:eachName | self indexOfColumnNamed:eachName].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
    ^ self getColumns:colsIndices
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
        getColumnsNamed:#('MESS_DATUM' 'TXK' 'TNK').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
    "Created: / 06-01-2019 / 19:04:56 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
    "Modified (comment): / 09-01-2019 / 12:14:48 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
tableName:aString
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
    tableName := aString.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
    "Modified (format): / 06-01-2019 / 21:12:39 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
tableNamePrefix:aString
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
    tableName := aString,tableName.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
    "Created: / 06-01-2019 / 21:13:12 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
tableNameSuffix:aString
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
    tableName := tableName,aString.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
    "Created: / 06-01-2019 / 21:13:01 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
!TableData methodsFor:'analysis'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
addBincoSlidingMean3ForColumnNamed:colName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
    "add a column with the sliding binco mean (1/4 + 1/2 + 1/4).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
     As binco:3 is quite common,
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
     that is a tuned version of addBincoSlidingMean:3 forColumnNamed:colName"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
    | outRows valColIdx prevRow firstIndex lastIndex meanColIdx|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
    valColIdx := self indexOfColumnNamed:colName.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
    outRows := OrderedCollection new.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
    prevRow := nil.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
    firstIndex := 1. lastIndex := rowData size.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
    rowData := rowData collectWithIndex:[:row :idx|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
        |slidingSum|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
        ((idx > firstIndex) and:[idx < lastIndex]) ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
            slidingSum := (
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
                               ((rowData at:idx-1) at:valColIdx)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
                             + (((rowData at:idx) at:valColIdx)*2)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
                             + ((rowData at:idx+1) at:valColIdx)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
                          ) / 4.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
        ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
        row copyWith:slidingSum.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
    meanColIdx := columnNames size+1.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
    (rowData at:firstIndex) at:meanColIdx put:((rowData at:firstIndex+1) at:meanColIdx).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
    (rowData at:lastIndex) at:meanColIdx put:((rowData at:lastIndex-1) at:meanColIdx).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
    columnNames := columnNames copyWith:('Sliding_Binco_Mean_of_',colName).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
    ^ self 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
            meanPerYearOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
                addBincoSlidingMean3ForColumnNamed:'Mean_Per_Year_TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
                    tableName:'Feldberg/Schwarzwald';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
                    plot:{ #x -> 'MESS_DATUM' . #y -> { 'Mean_Per_Year_TXK' . 'Sliding_Binco_Mean_of_Mean_Per_Year_TXK' .  }}.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
    "Created: / 08-01-2019 / 00:10:16 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
    "Modified (comment): / 09-01-2019 / 12:32:34 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
addBincoSlidingMean:n forColumnNamed:colName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
    "add a column with the sliding binco mean (1/2^n + ... + 1/4 + 1/2 + 1/4 + ... + 1/2^n)"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
    |nH outRows valColIdx prevRow firstIndex lastIndex meanColIdx wAll|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
    self assert:(n odd).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
    nH := n // 2.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
    valColIdx := self indexOfColumnNamed:colName.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
    outRows := OrderedCollection new.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
    prevRow := nil.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
    firstIndex := 1+nH. lastIndex := rowData size-nH.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
    wAll := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
    1 to:nH do:[:delta |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
        wAll := wAll + (1 / (2 raisedTo:delta)).    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
        wAll := wAll + (1 / (2 raisedTo:delta)).    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
    wAll := wAll + 1.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
    rowData := rowData collectWithIndex:[:row :idx|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
        |slidingSum|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
        ((idx >= firstIndex) and:[idx <= lastIndex]) ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
            slidingSum := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
            "/ ... /8 /4 /2 /1 /2 /4 /8 ...
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
            1 to:nH do:[:delta |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
                slidingSum := slidingSum + (((rowData at:idx-delta) at:valColIdx) / (2 raisedTo:delta)).    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
                slidingSum := slidingSum + (((rowData at:idx+delta) at:valColIdx) / (2 raisedTo:delta)).    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
            ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
            slidingSum := slidingSum + ((rowData at:idx) at:valColIdx).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
            slidingSum := slidingSum / wAll.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
        ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   227
        row copyWith:slidingSum.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   228
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   229
    meanColIdx := columnNames size+1.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
    1 to:nH do:[:delta |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
        (rowData at:0+delta) at:meanColIdx put:((rowData at:nH+1) at:meanColIdx)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   233
    1 to:nH do:[:delta |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   234
        (rowData at:rowData size+1-delta) at:meanColIdx put:((rowData at:rowData size-nH-1) at:meanColIdx)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   235
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
    columnNames := columnNames copyWith:('Sliding_Binco_Mean_of_',colName).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   237
    ^ self 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   240
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   242
            meanPerYearOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
                addBincoSlidingMean:5 forColumnNamed:'Mean_Per_Year_TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
                    tableName:'Feldberg/Schwarzwald';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
                    plot:{ #x -> 'MESS_DATUM' . 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
                           #y -> { 'Mean_Per_Year_TXK' . 'Sliding_Binco_Mean_of_Mean_Per_Year_TXK' .  }}.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   247
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   249
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   250
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   251
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   252
    "Created: / 07-01-2019 / 15:37:16 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   253
    "Modified (comment): / 09-01-2019 / 12:22:31 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   254
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   255
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   256
addSlidingMean:n forColumnNamed:colName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
    "add a column with the sliding mean.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
     The sliding mean looks meaner, but may introduce lag (phase shift),
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
     which binco avoids."
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
    |slidingValues slidingSum outRows valColIdx prevYear sum countDaysPerYear|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
    valColIdx := self indexOfColumnNamed:colName.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   265
    "/ take the the first n values as initial sliding mean
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   266
    slidingValues := (1 to:n) collect:[:rowIdx | (rowData at:rowIdx) at:valColIdx] as:OrderedCollection.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
    slidingSum := slidingValues sum.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
    outRows := OrderedCollection new.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
    prevYear := nil.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
    sum := countDaysPerYear := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
    rowData := rowData collect:[:row |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   273
        | rowsDate rowsYear val|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   274
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   275
        slidingSum := slidingSum - slidingValues first.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   276
        slidingValues removeFirst.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   277
        slidingValues add:(row at:valColIdx).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
        slidingSum := slidingSum + slidingValues last.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
        row copyWith:(slidingSum / n).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   280
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   281
    columnNames := columnNames copyWith:('Sliding_Mean_of_',colName).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   282
    ^ self 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   283
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   284
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   285
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   286
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   287
            meanPerYearOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   288
                addSlidingMean:11 forColumnNamed:'Mean_Per_Year_TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   289
                    tableName:'Feldberg/Schwarzwald';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   290
                    plot:{ #x -> 'MESS_DATUM' . #y -> { 'Mean_Per_Year_TXK' . 'Sliding_Mean_of_Mean_Per_Year_TXK' .  }}.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   291
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   292
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   293
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   295
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   296
    "Created: / 06-01-2019 / 20:05:42 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   297
    "Modified (comment): / 09-01-2019 / 12:33:16 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   298
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   299
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   300
extractMonth:monthIndex columnName:monthColumnName format:dateFormat
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   301
    "return a new table containing only rows for that month.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   302
     This is specific to DWD data"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   303
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   304
    |dateColIdx|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   305
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   306
    dateColIdx := self indexOfColumnNamed:monthColumnName.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
    ^ (self 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
        extractRowsWhere:[:row | 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   309
            | rowsDate rowsYearAndMonth val|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   310
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   311
            rowsDate := Date readFrom:(row at:dateColIdx) format:dateFormat.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   312
            rowsDate month = monthIndex
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   313
        ])
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   314
        tableName:(Date nameOfMonth:monthIndex),' Mean'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   315
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   316
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   317
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   318
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   319
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   320
                extractMonth:1 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   321
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   322
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   323
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   324
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   325
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   326
                extractMonth:2 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   327
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   328
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   329
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   330
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   331
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   332
                extractMonth:8 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   333
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   334
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   335
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   337
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   338
                extractMonth:9 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   339
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   340
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   341
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   342
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   343
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   344
                extractMonth:10 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   345
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   346
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   348
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19530101_20171231_04931.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   350
                extractMonth:10 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
                    tableNameSuffix:'-Echterdingen';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   353
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   354
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   355
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19530101_20171231_04931.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   356
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   357
                extractMonth:3 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   358
                    tableNameSuffix:'-Echterdingen';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   359
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   360
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   361
     |table|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   362
     table := (self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   363
            readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19530101_20171231_04931.txt').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   364
     1 to:12 do:[:month |        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   365
         ((table
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   366
                meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   367
                    extractMonth:month columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   368
                        tableNameSuffix:'-Echterdingen';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   369
                        plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   370
     ]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   371
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   372
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   373
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   374
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   375
    "Created: / 09-01-2019 / 18:27:28 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   376
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   377
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   378
extractMonth:month day:day columnName:monthColumnName format:dateFormat
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   379
    "return a new table containing only rows for that day in month"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   380
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   381
    |outRows dateColIdx|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   382
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   383
    dateColIdx := self indexOfColumnNamed:monthColumnName.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   384
    outRows := rowData select:[:row |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   385
        |rowsDate|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   386
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   387
        rowsDate := Date readFrom:(row at:dateColIdx) format:dateFormat.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   388
        (rowsDate month = month) and:[rowsDate day = day].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   389
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   390
    ^ self class rows:outRows columnNames:columnNames
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   391
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   392
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   393
     ((self fromFile:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   394
        extractMonth:1 day:1 columnName:'MESS_DATUM' format:'%4y%2m%2d')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   395
            plot:{ #x -> 'MESS_DATUM' . #y -> { 'TXK' . 'TNK' }}
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   396
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   397
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   398
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   399
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   400
    "Created: / 10-01-2019 / 16:14:29 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   401
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   402
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   403
extractRowsWhere:filterBlock
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   404
    "return a new table containing only rows for which filterBlock evaluates to true"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   405
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   406
    |outRows|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   407
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   408
    outRows := rowData select:filterBlock.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   409
    ^ self class 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   410
        rows:outRows columnNames:columnNames
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   411
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   412
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   413
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   414
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   415
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   416
                extractRowsWhere:[:row | (row at:1) startsWith:'1945'])
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   417
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   418
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   419
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   420
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   421
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   422
                extractRowsWhere:[:row | ((row at:1) from:5 to:6) = '01'])
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   423
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   424
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   425
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   426
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   427
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
                extractMonth:8)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   429
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   430
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   431
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   432
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   433
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   434
                extractMonth:9)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   435
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   436
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   437
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   438
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   439
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   440
                extractMonth:10)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   441
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   442
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   443
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   444
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19530101_20171231_04931.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   445
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   446
                extractMonth:10)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   447
                    tableNameSuffix:'-Echterdingen';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   448
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   449
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   450
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   451
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   452
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   453
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   454
    "Created: / 09-01-2019 / 12:35:44 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   455
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   456
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   457
meanPerMonthOfColumnNamed:colName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   458
    "return a new table containing the arithmetic mean per month of a column"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   459
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   460
    |outRows valColIdx dateColIdx prevYearAndMonth sum countDaysPerMonth|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   461
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   462
    dateColIdx := self indexOfColumnNamed:'MESS_DATUM'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   463
    valColIdx := self indexOfColumnNamed:colName.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   464
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   465
    outRows := OrderedCollection new.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   466
    prevYearAndMonth := nil.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   467
    sum := countDaysPerMonth := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   468
    rowData do:[:row |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   469
        | rowsDate rowsYearAndMonth val|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   470
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   471
        rowsDate := row at:dateColIdx.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   472
        "/ yyyymmdd
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   473
        rowsYearAndMonth := rowsDate copyTo:6.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   474
        prevYearAndMonth isNil ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   475
            prevYearAndMonth := rowsYearAndMonth.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   476
            sum := countDaysPerMonth := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   477
        ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   478
        (rowsYearAndMonth = prevYearAndMonth) ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   479
            val := Number readFrom:(row at:valColIdx).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   480
            sum := sum + val.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   481
            countDaysPerMonth := countDaysPerMonth + 1.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   482
        ] ifFalse:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   483
            outRows add:{ prevYearAndMonth . (sum / countDaysPerMonth) }.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   484
            sum := countDaysPerMonth := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   485
            prevYearAndMonth := rowsYearAndMonth.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   486
        ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   487
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   488
    ^ self class 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   489
        rows:outRows columnNames:{ 'MESS_DATUM' . 'Mean per month of ',colName }
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   490
        tableName:('Mean Per Month of ',colName)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   491
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   492
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   493
     ((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   494
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   495
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   496
                plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   497
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   498
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   499
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   500
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   501
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   502
    "Created: / 06-01-2019 / 19:06:36 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   503
    "Modified (comment): / 09-01-2019 / 12:24:34 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   504
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   505
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   506
meanPerYearOfColumnNamed:colName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   507
    "return a new table containing the arithmetic mean per year of a column"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   508
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   509
    |outRows valColIdx dateColIdx prevYear sum countDaysPerYear|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   510
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   511
    dateColIdx := self indexOfColumnNamed:'MESS_DATUM'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   512
    valColIdx := self indexOfColumnNamed:colName.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   513
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   514
    outRows := OrderedCollection new.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   515
    prevYear := nil.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   516
    sum := countDaysPerYear := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   517
    rowData do:[:row |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   518
        | rowsDate rowsYear val|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   519
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   520
        rowsDate := row at:dateColIdx.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   521
        "/ yyyymmdd
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   522
        rowsYear := rowsDate copyTo:4.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   523
        prevYear isNil ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   524
            prevYear := rowsYear.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   525
            sum := countDaysPerYear := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   526
        ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   527
        (rowsYear = prevYear) ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   528
            val := Number readFrom:(row at:valColIdx).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   529
            sum := sum + val.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   530
            countDaysPerYear := countDaysPerYear + 1.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   531
        ] ifFalse:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   532
            outRows add:{ prevYear . (sum / countDaysPerYear) }.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   533
            sum := countDaysPerYear := 0.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   534
            prevYear := rowsYear.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   535
        ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   536
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   537
    ^ self class 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   538
        rows:outRows columnNames:{ 'MESS_DATUM' . 'Mean_Per_Year_',colName }
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   539
        tableName:('Mean Per Year of ',colName)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   540
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   541
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   542
     ((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   543
        read:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   544
            meanPerYearOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   545
                plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   546
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   547
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   548
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   549
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   550
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   551
    "Created: / 06-01-2019 / 19:40:34 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   552
    "Modified: / 06-01-2019 / 22:34:06 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   553
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   554
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   555
!TableData methodsFor:'analysis - DWD'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   556
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   557
extractMonth:monthIndex
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   558
    "return a new table containing only rows for that month.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   559
     This is specific to DWD data"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   560
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   561
    ^ self extractMonth:monthIndex columnName:'MESS_DATUM' format:'%4y%2m%2d'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   562
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   563
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   564
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   565
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   566
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   567
                extractMonth:1 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   568
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   569
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   570
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   571
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   572
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   573
                extractMonth:2 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   574
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   575
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   576
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   577
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   578
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   579
                extractMonth:8 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   580
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   581
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   582
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   583
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   584
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   585
                extractMonth:9 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   586
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   587
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   588
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   589
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   590
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   591
                extractMonth:10 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   592
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   593
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   594
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   595
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19530101_20171231_04931.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   596
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   597
                extractMonth:10 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   598
                    tableNameSuffix:'-Echterdingen';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   599
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   600
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   601
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   602
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   603
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   604
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   605
    "Created: / 06-01-2019 / 19:00:52 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   606
    "Modified (comment): / 09-01-2019 / 18:30:09 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   607
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   608
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   609
extractMonth:monthIndex columnName:monthColumnName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   610
    "return a new table containing only rows for that month.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   611
     This is specific to DWD data"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   612
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   613
    ^ self extractMonth:monthIndex columnName:monthColumnName format:'%4y%2m%2d'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   614
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   615
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   616
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   617
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   618
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   619
                extractMonth:1 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   620
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   621
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   622
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   623
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   624
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   625
                extractMonth:2 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   626
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   627
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   628
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   629
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   630
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   631
                extractMonth:8 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   632
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   633
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   634
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   635
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   636
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   637
                extractMonth:9 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   638
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   639
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   640
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   641
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   642
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   643
                extractMonth:10 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   644
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   645
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   646
     (((self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   647
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19530101_20171231_04931.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   648
            meanPerMonthOfColumnNamed:'TXK')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   649
                extractMonth:10 columnName:'MESS_DATUM' format:'%4y%2m')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   650
                    tableNameSuffix:'-Echterdingen';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   651
                    plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   652
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   653
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   654
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   655
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   656
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   657
    "Created: / 09-01-2019 / 14:42:05 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   658
    "Modified (comment): / 09-01-2019 / 18:31:31 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   659
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   660
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   661
extractMonth:month day:day
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   662
    "return a new table containing only rows for that day in month"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   663
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   664
    ^ self extractMonth:month day:day columnName:'MESS_DATUM' format:'%4y%2m%2d'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   665
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   666
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   667
     ((self fromFile:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   668
        extractMonth:1 day:1)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   669
            tableName:'1st Januar, Feldberg';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   670
            plot:{ #x -> 'MESS_DATUM' . #y -> { 'TXK' . 'TNK' }}
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   671
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   672
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   673
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   674
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   675
    "Created: / 06-01-2019 / 13:15:46 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   676
    "Modified (comment): / 10-01-2019 / 16:20:48 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   677
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   678
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   679
!TableData methodsFor:'helpers'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   680
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   681
indexOfColumnNamed:name
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   682
    ^ columnNames indexOf:name ifAbsent:[self error:'no such column'].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   683
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   684
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   685
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   686
        read:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   687
        indexOfColumnNamed:'MESS_DATUM'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   688
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   689
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   690
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   691
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   692
    "Created: / 06-01-2019 / 13:20:47 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   693
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   694
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   695
!TableData methodsFor:'instance creation'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   696
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   697
rows:rowDataArg columnNames:columnNamesArg
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   698
    rowData := rowDataArg.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   699
    columnNames := columnNamesArg.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   700
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   701
    "Created: / 06-01-2019 / 13:26:01 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   702
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   703
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   704
rows:rowDataArg columnNames:columnNamesArg tableName:tableNameArg
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   705
    rowData := rowDataArg.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   706
    columnNames := columnNamesArg.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   707
    tableName := tableNameArg.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   708
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   709
    "Created: / 06-01-2019 / 19:25:10 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   710
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   711
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   712
!TableData methodsFor:'plotting'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   713
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   714
plot
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   715
    self plot:nil
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   716
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   717
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   718
     |data tmax|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   719
     
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   720
     data := self fromFile:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   721
     tmax := data withColumnsNamed:#('MESS_DATUM' 'TXK' 'TNK').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   722
     tmax plot:{ #x -> 'MESS_DATUM' . #y -> { 'TXK' 'TNK' }} .
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   723
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   724
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   725
    "Created: / 06-01-2019 / 18:47:27 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   726
    "Modified: / 06-01-2019 / 21:32:22 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   727
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   728
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   729
plot:optionalSpec
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   730
    |tmpFile|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   731
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   732
    [
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   733
        tmpFile := Filename newTemporary.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   734
        tmpFile writingFileDo:[:s |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   735
            self writeCSVToStream:s.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   736
        ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   737
        "/ FileBrowserV2 openOn:tmpFile.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   738
        self plot:optionalSpec file:tmpFile.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   739
    ] ensure:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   740
        tmpFile delete
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   741
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   742
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   743
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   744
     |data tmax|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   745
     
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   746
     data := self fromFile:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   747
     tmax := data withColumnsNamed:#('MESS_DATUM' 'TXK' 'TNK').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   748
     tmax plot:{ #x -> 'MESS_DATUM' . #y -> { 'TXK' 'TNK' }} .
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   749
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   750
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   751
    "Created: / 06-01-2019 / 21:32:09 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   752
    "Modified: / 09-01-2019 / 18:40:16 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   753
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   754
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   755
plot:optionalSpec file:fileName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   756
    |script scriptFile outFile width height spec xCol yCols|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   757
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   758
    scriptFile := Filename newTemporary .
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   759
    outFile := '/tmp/plot3.png'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   760
    outFile asFilename contents:''.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   761
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   762
    width := 1200.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   763
    height := 400.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   764
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   765
    optionalSpec notNil ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   766
        spec := optionalSpec isDictionary 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   767
                    ifTrue:[optionalSpec] 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   768
                    ifFalse:[Dictionary withAssociations:optionalSpec].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   769
        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   770
        yCols := spec at:#y.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   771
        xCol := spec at:#x.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   772
        script := '
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   773
png(filename="%1", height=%3, width=%2)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   774
Data <- read.csv(file="%4", header=TRUE, sep=";")
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   775
',xCol,' <- Data$',xCol,'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   776
',((yCols collect:[:col | col,' <- Data$',col]) asStringWith:Character cr),
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   777
"/'plot(',xCol,', ' 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   778
"/       ,((yCols collect:[:col | col,', ']) asStringWith:''),
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   779
"/' type="l", main = "%5")'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   780
'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   781
',('plot(%1, %2, type="b", col=2, main = "%%5")' bindWith:xCol with:yCols first),'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   782
',((yCols from:2 collect:[:ycol | 'lines(%1, %2, type="l", col=3)' bindWith:xCol with:ycol]) asStringWith:Character cr)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   783
,'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   784
# dev.off()
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   785
'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   786
            bindWith:outFile 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   787
            with:width 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   788
            with:height
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   789
            with:fileName asFilename pathName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   790
            with:(tableName ? '').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   791
        "/ self halt.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   792
    ] ifFalse:[        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   793
        script := '
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   794
# library(ggplot2)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   795
# library(ggfortify)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   796
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   797
png(filename="%1", height=%3, width=%2)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   798
Data <- read.csv(file="%4", header=TRUE, sep=";")
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   799
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   800
# theme_set(theme_classic())
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   801
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   802
# Plot 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   803
# autoplot(Data) + 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   804
#   labs(title="Data") + 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   805
#   theme(plot.title = element_text(hjust=0.1))
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   806
plot(Data, type="l", main = "%5")
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   807
# plot(Data, cex = .4)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   808
dev.off()
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   809
'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   810
            bindWith:outFile 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   811
            with:width 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   812
            with:height
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   813
            with:fileName asFilename pathName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   814
            with:(tableName ? '').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   815
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   816
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   817
    scriptFile contents:script.        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   818
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   819
    OSProcess new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   820
        command:('r --silent --vanilla --slave -f %1' bindWith:scriptFile);
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   821
        execute.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   822
    "/ self halt.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   823
    "/ outFile asFilename exists.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   824
    (Image fromFile:outFile asFilename) inspect.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   825
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   826
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   827
     |data tmax|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   828
     
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   829
     data := self fromFile:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   830
     tmax := data withColumnsNamed:#('MESS_DATUM' 'TXK').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   831
     tmax tableName:'Feldberg'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   832
     tmax plot:{ #x -> 'MESS_DATUM' . #y -> { 'TXK' . 'TNK' }}.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   833
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   834
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   835
    "Created: / 06-01-2019 / 21:32:43 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   836
    "Modified: / 07-01-2019 / 15:28:26 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   837
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   838
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   839
plotFile:fileName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   840
    self plot:nil file:fileName
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   841
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   842
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   843
     |data tmax|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   844
     
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   845
     data := self fromFile:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   846
     tmax := data withColumnsNamed:#('MESS_DATUM' 'TXK').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   847
     tmax tableName:'Test'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   848
     tmax plot.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   849
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   850
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   851
    "Created: / 06-01-2019 / 15:59:47 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   852
    "Modified: / 06-01-2019 / 21:32:59 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   853
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   854
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   855
writeCSVToStream:aStream
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   856
    "save myself as CSV onto a stream"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   857
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   858
    columnNames 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   859
        do:[:nm | 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   860
            (nm includes:$;) ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   861
                aStream nextPut:$"; nextPutAll:nm; nextPut:$".
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   862
            ] ifFalse:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   863
                aStream nextPutAll:nm
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   864
            ]]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   865
        separatedBy:[aStream nextPut:$;].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   866
    aStream cr.        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   867
    rowData do:[:row |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   868
        row
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   869
            do:[:col | 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   870
                |s|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   871
                s := col printString.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   872
                (s includes:$;) ifTrue:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   873
                    aStream nextPut:$"; nextPutAll:s; nextPut:$".
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   874
                ] ifFalse:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   875
                    aStream nextPutAll:s
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   876
                ]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   877
            ]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   878
            separatedBy:[aStream nextPut:$;].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   879
        aStream cr.        
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   880
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   881
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   882
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   883
     |data tmax|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   884
     
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   885
     data := self fromFile:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   886
     tmax := data withColumnsNamed:#('MESS_DATUM' 'TXK' 'TNK').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   887
     String streamContents:[:s | tmax writeCSVToStream:s]
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   888
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   889
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   890
    "Created: / 09-01-2019 / 17:48:25 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   891
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   892
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   893
!TableData methodsFor:'processing'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   894
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   895
removeColumn:index
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   896
    "destructively remove a column"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   897
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   898
    columnNames := columnNames copyWithoutIndex:index.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   899
    rowData := rowData collect:[:row | row copyWithoutIndex:index].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   900
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   901
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   902
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   903
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   904
        removeColumn:1;
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   905
        inspect.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   906
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   907
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   908
    "Created: / 06-01-2019 / 13:05:41 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   909
    "Modified (comment): / 09-01-2019 / 12:13:50 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   910
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   911
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   912
removeColumnNamed:name
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   913
    "destructively remove a column"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   914
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   915
    self removeColumn:(self indexOfColumnNamed:name)
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   916
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   917
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   918
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   919
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   920
        removeColumnNamed:'STATIONS_ID';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   921
        removeColumnNamed:'QN_3';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   922
        removeColumnNamed:'FX';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   923
        removeColumnNamed:'FM';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   924
        removeColumnNamed:'RSK';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   925
        removeColumnNamed:'RSKF';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   926
        removeColumnNamed:'SDK';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   927
        removeColumnNamed:'SHK_TAG';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   928
        removeColumnNamed:'NM';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   929
        removeColumnNamed:'VPM';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   930
        removeColumnNamed:'PM';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   931
        removeColumnNamed:'TMK';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   932
        removeColumnNamed:'UPM';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   933
        removeColumnNamed:'eor';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   934
        inspect.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   935
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   936
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   937
    "/ StringCollection('MESS_DATUM' 'QN_3' 'FX' 'FM' 'QN_4' 'RSK' 'RSKF' 'SDK' 'SHK_TAG' 'NM' 'VPM' 'PM' 'TMK' 'UPM' 'TXK' 'TNK' 'TGK' 'eor')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   938
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   939
    "Created: / 06-01-2019 / 13:06:50 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   940
    "Modified (comment): / 09-01-2019 / 12:13:53 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   941
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   942
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   943
withColumns:indexCollection
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   944
    "return a new TableData instance, containing only the given columns"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   945
    
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   946
    |remainingNames|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   947
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   948
    remainingNames := indexCollection collect:[:colIdx | columnNames at:colIdx] as:Array.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   949
    ^ self class
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   950
        rows:(rowData collect:[:row | 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   951
                indexCollection collect:[:colIdx | row at:colIdx] as:Array
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   952
                ])
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   953
        columnNames:remainingNames.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   954
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   955
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   956
     (self fromFile:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   957
        withColumns:#(1 2 3).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   958
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   959
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   960
    "Created: / 06-01-2019 / 14:35:11 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   961
    "Modified (comment): / 09-01-2019 / 12:13:57 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   962
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   963
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   964
withColumnsNamed:nameCollection
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   965
    "return a new TableData instance, containing only the given columns"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   966
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   967
    ^ self withColumns:(nameCollection collect:[:nm |self indexOfColumnNamed:nm])
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   968
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   969
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   970
     (self fromFile:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   971
        withColumnsNamed:#('MESS_DATUM' 'TXK').
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   972
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   973
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   974
    "Created: / 06-01-2019 / 14:36:16 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   975
    "Modified (comment): / 09-01-2019 / 12:13:45 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   976
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   977
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   978
withoutColumn:index
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   979
    "return a new TableData instance, without the given columns"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   980
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   981
    ^ self class
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   982
        rows:(rowData collect:[:row | row copyWithoutIndex:index])
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   983
        columnNames:(columnNames copyWithoutIndex:index).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   984
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   985
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   986
     self new 
4789
4daaaab89349 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4781
diff changeset
   987
        readCSV:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
4781
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   988
        withoutColumn:1.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   989
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   990
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   991
    "Created: / 06-01-2019 / 13:27:11 / Claus Gittinger"
4789
4daaaab89349 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4781
diff changeset
   992
    "Modified (comment): / 10-01-2019 / 16:25:56 / Claus Gittinger"
4781
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   993
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   994
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   995
withoutColumns:indexCollection
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   996
    "return a new TableData instance, without the given columns"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   997
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   998
    |remainingColIndices remainingNames|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   999
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1000
    remainingColIndices := (1 to:columnNames size) asNewOrderedCollection removeAll:indexCollection; yourself.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1001
    remainingNames := remainingColIndices collect:[:colIdx | columnNames at:colIdx] as:Array.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1002
    ^ self class
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1003
        rows:(rowData collect:[:row | 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1004
                remainingColIndices collect:[:colIdx | row at:colIdx] as:Array
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1005
                ])
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1006
        columnNames:remainingNames.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1007
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1008
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1009
     (self fromFile:'~/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt')
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1010
        withoutColumns:#(1 2 3).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1011
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1012
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1013
    "Created: / 06-01-2019 / 14:32:08 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1014
    "Modified (comment): / 09-01-2019 / 12:14:29 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1015
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1016
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1017
!TableData methodsFor:'reading'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1018
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1019
readCSV:filename
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1020
    ^ self readCSV:filename separator:$;
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1021
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1022
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1023
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1024
        readCSV:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1025
        inspect.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1026
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1027
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1028
    "Created: / 09-01-2019 / 12:07:27 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1029
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1030
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1031
readCSV:filename separator:separatorCharacter
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1032
    |headLine numCols dataLine ls word row rows|
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1033
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1034
    filename asFilename readingFileDo:[:s |
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1035
        rows := OrderedCollection new.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1036
        headLine := s nextLine.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1037
        numCols := (headLine occurrencesOf:separatorCharacter)+1.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1038
        columnNames := (headLine splitBy:separatorCharacter) collect:#withoutSeparators.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1039
        [s atEnd] whileFalse:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1040
            dataLine := s nextLine.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1041
            ls := dataLine readStream.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1042
            row := OrderedCollection new:numCols.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1043
            [ls atEnd] whileFalse:[
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1044
                ls skipSeparators.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1045
                word := (ls upTo:separatorCharacter) withoutSeparators.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1046
                row add:word.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1047
            ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1048
            rows add:(row asArray).
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1049
        ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1050
    ].
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1051
    rowData := rows.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1052
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1053
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1054
     self new 
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1055
        readCSV:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt';
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1056
        inspect.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1057
    "
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1058
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1059
    "Created: / 09-01-2019 / 12:11:11 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1060
!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1061
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1062
readDemoCSV
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1063
    self readCSV:'/Users/cg/Documents/klima/data/DWD/daily/kl/historical/produkt_klima_tag_19450101_20171231_01346.txt'.
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1064
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1065
    "Created: / 09-01-2019 / 12:07:52 / Claus Gittinger"
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1066
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1067
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1068
!TableData class methodsFor:'documentation'!
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1069
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1070
version_CVS
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1071
    ^ '$Header$'
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1072
! !
a4d11bd443dc initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1073