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