/[projects]/dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/AddressSearch.java
ViewVC logotype

Diff of /dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/AddressSearch.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

dao/DaoAdresseService/src/dk/daoas/daoadresseservice/AdressSearch.java revision 2274 by torben, Fri Feb 13 11:48:23 2015 UTC dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/AddressSearch.java revision 2492 by torben, Tue Mar 24 20:33:35 2015 UTC
# Line 1  Line 1 
1  package dk.daoas.daoadresseservice;  package dk.daoas.daoadresseservice;
2    
3  import java.sql.SQLException;  import java.sql.SQLException;
4    import java.text.SimpleDateFormat;
5    import java.util.ArrayList;
6    import java.util.Collections;
7    import java.util.Date;
8  import java.util.HashMap;  import java.util.HashMap;
9    import java.util.HashSet;
10  import java.util.List;  import java.util.List;
11  import java.util.Map;  import java.util.Map;
12    import java.util.Map.Entry;
13    import java.util.Set;
14    import java.util.TreeMap;
15    import java.util.TreeSet;
16  import java.util.concurrent.ConcurrentHashMap;  import java.util.concurrent.ConcurrentHashMap;
17    
18  import dk.daoas.daoadresseservice.AddressUtils.SplitResult;  import org.apache.commons.lang3.StringUtils;
19  import dk.daoas.daoadresseservice.SearchResult.Status;  
20    import dk.daoas.daoadresseservice.admin.ServiceConfig;
21    import dk.daoas.daoadresseservice.beans.Address;
22    import dk.daoas.daoadresseservice.beans.AliasBean;
23    import dk.daoas.daoadresseservice.beans.DataStatisticsBean;
24    import dk.daoas.daoadresseservice.beans.ExtendedBean;
25    import dk.daoas.daoadresseservice.beans.HundredePctBean;
26    import dk.daoas.daoadresseservice.beans.SearchRequest;
27    import dk.daoas.daoadresseservice.beans.SearchResult;
28    import dk.daoas.daoadresseservice.beans.SearchResult.Status;
29  import dk.daoas.daoadresseservice.db.DatabaseLayer;  import dk.daoas.daoadresseservice.db.DatabaseLayer;
30    import dk.daoas.daoadresseservice.util.DeduplicateHelper;
31    
32  public class AdressSearch {  public class AddressSearch {
33    
34          Map<Integer, Map<String,Long>> searchPostnrVejnavnGadeid;                private Map<Short, Map<String,Integer>> searchPostnrVejnavnGadeid;      
35          Map<Long,  Map<String,Address>> searchGadeidentAdresser;          private Map<Integer,  Map<String,Address>> searchGadeidentAdresser;
36    
37          List<Address> alleAdresser;          private List<Address> alleAdresser;
38            
39            private Map<String,Integer> helperCache;
40            
41            private DataStatisticsBean stats = new DataStatisticsBean();
42            
43            ServiceConfig config;
44            
45            StreetnameHelper levenshteinHelper;
46            StreetnameHelper googleHelper;
47            StreetnameHelper osmHelper;
48            
49                    
50          /* Mapper mellem db Row ID og adresse noden */          public AddressSearch(ServiceConfig config) {
51          Map<Integer,Address> idAddressMap;                  this.config = config;
52                    
53                    levenshteinHelper = new LevenshteinStreetnameHelper( this );
54                    googleHelper = new GoogleStreetnameHelper( config );
55                    osmHelper = new OSMStreetnameHelper( config );
56            }
57                    
58                    
59          public SearchResult search(String postnrStr, String adresse)  {          public SearchResult search(String postnrStr, String adresse)  {
60                  int postnr=0;                  SearchRequest request = new SearchRequest();
61                    SearchResult result = new SearchResult();
62                    
63    
64                    String helperSearchKey = "";
65                                    
66                  try {                  try {
67                          postnr = Integer.parseInt(postnrStr);                          request.postnr = Integer.parseInt(postnrStr);
68                  } catch (Exception E) {                  } catch (Exception E) {
69                          return new SearchResult(Status.ERROR_UNKNOWN_POSTAL);                          result.status = Status.ERROR_UNKNOWN_POSTAL;
70                            return result;
71                  }                                }              
72                                    
                 Map<String,Long> postnrVeje = searchPostnrVejnavnGadeid.get(postnr);                      
73                                    
74                  if (postnrVeje == null) {                  request.streetNames = searchPostnrVejnavnGadeid.get(request.postnr);                    
75                          return new SearchResult(Status.ERROR_UNKNOWN_POSTAL);                  
76                    if (request.streetNames == null) {
77                            result.status = Status.ERROR_UNKNOWN_POSTAL;
78                            return result;
79                  }                  }
80                                    
                 SplitResult split = AddressUtils.splitAdresse(adresse);  
                 String vasketVejnavn = AddressUtils.vaskVejnavn( split.vej );  
81                                    
82                  if (split.husnr.length() == 0) {                  result.splitResult = AddressUtils.splitAdresse(adresse);
83                          return new SearchResult(Status.ERROR_MISSING_HOUSENUMBER);                                        request.vejnavn = result.splitResult.vej;
84                    
85                                                    
86                    
87                    if (result.splitResult.husnr.length() == 0) {
88                            result.status = Status.ERROR_MISSING_HOUSENUMBER;
89                            return result;
90                    }
91                    
92                    request.vasketVejnavn = AddressUtils.vaskVejnavn( request.vejnavn );
93                    
94    
95                    if (request.vasketVejnavn.indexOf("pakkebo") > -1
96                                    || request.vasketVejnavn.indexOf("døgnpost") > -1
97                                    || request.vasketVejnavn.indexOf("døgnbo") > -1
98                                    || request.vasketVejnavn.equals("id")
99                                    ) {
100                            result.status = Status.ERROR_POSTBOX;
101                            return result;                  
102                    }
103                    
104                    Integer gadeident =  request.streetNames.get(request.vasketVejnavn);
105                    
106                    
107                    if ( gadeident == null) {
108                            helperSearchKey = "" + request.postnr + "/" + request.vasketVejnavn;
109                            gadeident = helperCache.get(helperSearchKey);
110                  }                  }
111                                    
                 Long gadeident =  postnrVeje.get(vasketVejnavn);  
112                  if (gadeident == null) {                  if (gadeident == null) {
113                          return new SearchResult(Status.ERROR_UNKNOWN_STREETNAME);                          String vej = levenshteinHelper.proposeStreetName(request, result);
114                  }                                if (vej != null) {
115                                    gadeident =  request.streetNames.get(vej);
116                            }
117                    }
118                                    
119                  Map<String, Address> gade =  searchGadeidentAdresser.get(gadeident); //Denne søgning må ikke fejle                  
120                    // Brug OpenStreetMap før vi prøver google
121                    // For google har en request limit, det har OSM ikke!
122                    if ( gadeident == null) {
123                            String vej = osmHelper.proposeStreetName(request, result);              
124                            gadeident = helperWrapper(vej, request.streetNames, helperSearchKey);
125                    }
126                    
127                    if ( gadeident == null) {
128                            String vej = googleHelper.proposeStreetName(request, result);          
129                            gadeident = helperWrapper(vej, request.streetNames, helperSearchKey);
130                    }
131                    
132    
133                    
134                    if (gadeident == null) {                        
135                            result.status = Status.ERROR_UNKNOWN_STREETNAME;
136                            return result;
137                    }
138                    
139                    result.gadeident = gadeident;
140                    
141                    
142                    Map<String, Address> gade = searchGadeidentAdresser.get(gadeident);
143                    if (gade == null) { //Denne søgning må ikke fejle
144                            result.status = Status.ERROR_INTERNAL;
145                            return result;                  
146                    }
147                                    
148                                    
149                  String husnrSearch = "" + split.husnr + split.litra;                  //Kunne evt klares med Iterables.get fra Guava/Collections
150                    Address firstAddress = gade.values().iterator().next();
151                    result.vej = firstAddress.vejnavn;
152                    
153                    String husnrSearch = "" + result.splitResult.husnr + result.splitResult.litra;
154                  Address addr = gade.get(husnrSearch);                  Address addr = gade.get(husnrSearch);
155    
156                  if (addr == null) {                  if (addr == null) {
157                          return new SearchResult(Status.ERROR_UNKNOWN_ADDRESSPOINT);                          result.status = Status.ERROR_UNKNOWN_ADDRESSPOINT;
158                            return result;
159                  }                  }
                                   
160                                    
161                  return new SearchResult(addr);                  result.address = addr;
162                    
163                    
164                    if ( StringUtils.equals(addr.distributor, "LUKKET") ) {                
165                            result.status = Status.STATUS_NOT_COVERED; //Skal vi have en special status til Lukkede adresser ?
166                            return result;
167                    }                              
168                    
169                    if (addr.daekningsType == DaekningsType.DAEKNING_IKKEDAEKKET) {
170                            result.status = Status.STATUS_NOT_COVERED;
171                            return result;
172                    }
173    
174                    
175                    result.status = Status.STATUS_OK;
176    
177                    return result;
178          }          }
179                    
180            private Integer helperWrapper(String vej, Map<String,Integer> postnrVeje, String helperSearchKey) {
181                    if (vej == null)
182                            return null;
183                    
184                    String vejVasket = AddressUtils.vaskVejnavn( vej );
185                    Integer gadeident =  postnrVeje.get(vejVasket);
186                    
187                    if (gadeident != null) {
188                            helperCache.put(helperSearchKey, gadeident);
189                    }
190                    return gadeident;
191                    
192            }
193            
194            public Map<String,Integer> getStretsByPostal(int zip) {
195                    return searchPostnrVejnavnGadeid.get(zip);
196            }
197    
198            
199                    
200          public void buildSearchStructures() throws SQLException{          public void buildSearchStructures() throws SQLException{
201                  searchPostnrVejnavnGadeid = new HashMap<Integer, Map<String,Long>>();                  searchPostnrVejnavnGadeid = new HashMap<Short, Map<String,Integer>>();
202                  searchGadeidentAdresser = new HashMap<Long,  Map<String,Address>>();                  searchGadeidentAdresser = new HashMap<Integer,  Map<String,Address>>();
203                  idAddressMap = new HashMap<Integer,Address>();                  helperCache = new ConcurrentHashMap<String,Integer>();
204                    
205                    long start1 = System.currentTimeMillis();
206                    System.out.println("Build -- stage 1");
207                                    
208                  alleAdresser = DatabaseLayer.getAllAdresses();                  alleAdresser = DatabaseLayer.getAllAdresses();
209                    
210                    
211                    /* Mapper mellem db Row ID og adresse noden */
212                    Map<Integer,Address> idAddressMap = new HashMap<Integer,Address>( alleAdresser.size() );
213                    DeduplicateHelper<String> aliasHelper = new DeduplicateHelper<String>();
214                    DeduplicateHelper<String> husnrHelper = new DeduplicateHelper<String>();
215                    
216                  for (Address a : alleAdresser) {                  for (Address a : alleAdresser) {
217                          idAddressMap.put(a.id, a);                          idAddressMap.put(a.id, a);
218                                                    
219                          Map<String,Long> postnrVeje = searchPostnrVejnavnGadeid.get(a.postnr);                                    Map<String,Integer> postnrVeje = searchPostnrVejnavnGadeid.get(a.postnr);              
220                                                    
221                          if (postnrVeje == null) {                          if (postnrVeje == null) {
222                                  postnrVeje = new ConcurrentHashMap<String,Long>();                                  postnrVeje = new ConcurrentHashMap<String,Integer>();
223                                  searchPostnrVejnavnGadeid.put(a.postnr, postnrVeje);                                  searchPostnrVejnavnGadeid.put(a.postnr, postnrVeje);
224                          }                          }
225                                    
226                                                    
227                          Long gadeident = postnrVeje.get(a.vasketVejnavn);                          String vasketVejnavn = AddressUtils.vaskVejnavn(a.vejnavn);
228                          if (gadeident == null) {                          Integer gadeident = postnrVeje.get(vasketVejnavn);
229                                  postnrVeje.put(a.vasketVejnavn, a.gadeid);                          if (gadeident == null) {                                
230                                    //postnrVeje.put(vasketVejnavn, a.gadeid);
231                                    
232                                    gadeident = a.gadeid;
233                                    
234                                    Set<String> aliaser = findVejAliaser(a.vejnavn);
235                                    for(String alias : aliaser) {
236                                            String vasketAlias = AddressUtils.vaskVejnavn(alias);
237                                            vasketAlias = aliasHelper.getInstance(vasketAlias);
238                                            
239                                            postnrVeje.put(vasketAlias, gadeident);
240                                    }                              
241                          }                          }
242                                                    
243                          Map<String, Address> gade =  searchGadeidentAdresser.get(a.gadeid);                          Map<String, Address> gade =  searchGadeidentAdresser.get(gadeident);
244                          if (gade == null) {                          if (gade == null) {
245                                  gade = new HashMap<String, Address>();                                  gade = new HashMap<String, Address>();
246                                  searchGadeidentAdresser.put(a.gadeid, gade);                                  searchGadeidentAdresser.put(gadeident, gade);
247                          }                          }
248                          String husnrSearch = "" + a.husnr + a.husnrbogstav;                          String husnrSearch = "" + a.husnr + a.husnrbogstav;
249                          gade.put(husnrSearch, a);                          husnrSearch = husnrHelper.getInstance(husnrSearch);
250                                                                                                    gade.put(husnrSearch, a);                      
251                    }
252                    
253                    ////////////////////////////////////////////////////////////////////////////////////////
254                    long start2 = System.currentTimeMillis();
255                    System.out.println("Build, stage1 elapsed: " + (start2-start1) );
256                    System.out.println("Build -- stage 2 alias tabel");
257                    
258                    int vaskCount = 0;
259                    List<AliasBean> aliasList = DatabaseLayer.getAliasList();
260                    for (AliasBean alias : aliasList) {
261                            Map<String,Integer> postnrVeje = searchPostnrVejnavnGadeid.get(alias.postnr);
262                            
263                            if (postnrVeje == null) {
264                                    //Burde ikke kunne ske - men better safe than sorry
265                                    continue;
266                            }
267                            
268                            String vasketVej = AddressUtils.vaskVejnavn(alias.vejnavn);
269                            String vasketAlias = AddressUtils.vaskVejnavn(alias.aliasVejnavn);
270                            
271                            Integer gadeident = postnrVeje.get(vasketVej);
272                            if (gadeident == null) {
273                                    //Kender ikke den oprindelige vej
274                                    continue;
275                            }
276                            
277                            Integer aliasIdent = postnrVeje.get(vasketAlias);
278                            
279                            if (aliasIdent == null) { //Vi kender ikke denne variant af vejnavnet
280                                    postnrVeje.put(vasketAlias, gadeident);
281                                    vaskCount++;
282                            }
283                            
284                    }
285                    System.out.println("Anvendte " + vaskCount + " aliaser fra databasen");
286                    
287                    
288                    ////////////////////////////////////////////////////////////////////////////////////////
289                    long start3 = System.currentTimeMillis();
290                    System.out.println("Build, stage2 elapsed: " + (start3-start2) );
291                    System.out.println("Build -- stage 3 udvidet dækning");
292                    
293                    DeduplicateHelper<String> ruteHelper = new DeduplicateHelper<String>();
294                    DeduplicateHelper<String> korelisteHelper = new DeduplicateHelper<String>();
295                    
296                    List<ExtendedBean> extDao = DatabaseLayer.getExtendedAdresslist();
297                    for (ExtendedBean eb : extDao) {
298                            
299                            Address orgAddress = idAddressMap.get(eb.orgId);                        
300                            if (orgAddress == null)
301                                    continue;
302                            
303                            Address targetAddress = idAddressMap.get(eb.targetId);
304                            if (targetAddress == null)
305                                    continue;
306                            
307                            if (orgAddress.distributor != null && orgAddress.distributor.equals("LUKKET")) {
308                                    continue;
309                            }                      
310                            
311                            if (targetAddress.distributor.equals("LUKKET")) {
312                                    continue;
313                            }
314                            
315                            orgAddress.extTarget = targetAddress;
316                            orgAddress.extAfstand = eb.afstand;
317    
318                            boolean covered = false;
319                            if (targetAddress.distributor.equals("DAO")) {
320                                    orgAddress.rute = calculateExtendedDaoRoute(eb,orgAddress,targetAddress);      
321                                    orgAddress.rute = ruteHelper.getInstance(orgAddress.rute);
322                                    
323                                    if (orgAddress.rute != null) {
324                                            orgAddress.koreliste = targetAddress.koreliste;
325                                            covered = true;
326                                    }
327                            }
328                            
329                            if (targetAddress.distributor.equals("BK")) {
330                                    orgAddress.koreliste = calculateExtendedBkKoreliste(eb,orgAddress,targetAddress);
331                                    orgAddress.koreliste = korelisteHelper.getInstance(orgAddress.koreliste);
332                                    
333                                    if (orgAddress.koreliste != null) {
334                                            orgAddress.rute = targetAddress.rute;
335                                            covered = true;
336                                    }
337                            }
338                                                    
339                            if (covered) { //Kopier resten af felterne
340                                    orgAddress.daekningsType = DaekningsType.DAEKNING_UDVIDET;
341                                    orgAddress.dbkBane = targetAddress.dbkBane;
342                                    
343                                    /* Sådan gør den gamle service */
344                                    orgAddress.kommunekode = targetAddress.kommunekode;
345                                    orgAddress.vejkode = targetAddress.vejkode;
346                                    
347                                    orgAddress.distributor = targetAddress.distributor;
348                            }
349                  }                  }
350                                    
351                    // nu skal vi ikke bruge idAddressMap længere
352                    idAddressMap = null;
353                    
354                    //////////////////////////////////////////////////////////////////////////////////////
355                    long start4 = System.currentTimeMillis();
356                    System.out.println("Build, stage3 elapsed: " + (start4-start3) );
357                    System.out.println("Build -- stage 4 - 100pct");
358                    
359                    Map<Short,HundredePctBean> hundredePct = DatabaseLayer.get100PctList();
360                    for (Address addr : alleAdresser) {
361                            if (addr.daekningsType != DaekningsType.DAEKNING_IKKEDAEKKET) {                        
362                                    continue;
363                            }
364                            
365                            if (addr.distributor != null && addr.distributor.equals("LUKKET")) {
366                                    continue;
367                            }
368                            
369                            
370                            HundredePctBean bean = hundredePct.get(addr.postnr);
371                            if (bean == null) {
372                                    continue;
373                            }
374                            
375                            addr.daekningsType = DaekningsType.DAEKNING_100PCT;
376                            addr.rute = bean.rute;
377                            addr.koreliste = bean.koreliste;
378                            addr.dbkBane = bean.dbkBane;
379                            addr.distributor = bean.distributor;
380                    }
381                    
382                    ////////////////////////////////////////////////////////////////////////////////////
383                    long stop = System.currentTimeMillis();
384                    System.out.println("Build, stage3 elapsed: " + (stop-start4) );
385                    System.out.println("Build -- Gathering statistics");
386                                    
387                    for (Address addr : alleAdresser) {
388                            switch (addr.daekningsType) {
389                            case DAEKNING_DIREKTE:
390                                    stats.direkteCount++;
391                                    break;
392                            case DAEKNING_UDVIDET:
393                                    stats.extendedCount++;
394                                    break;
395                            case DAEKNING_100PCT:
396                                    stats.hundredePctCount++;
397                                    break;
398                            default:
399                                    stats.ikkeDaekketCount++;
400                            }
401                    }              
402                    
403                    
404                    stats.elapsed = stop-start1;            
405                    stats.buildTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format( new Date() );
406                    
407                    System.out.println("Build: direkteCount: " + stats.direkteCount);
408                    System.out.println("Build: extendedCount: " + stats.extendedCount);
409                    System.out.println("Build: hundredePctCount: " + stats.hundredePctCount);
410                    System.out.println("Build: ikkeDaekketCount: " + stats.ikkeDaekketCount);
411                    
412                    System.out.println("Build: Total Elapsed: " + (stop-start1) );
413                    System.out.println("Build Completed");
414                    
415            }
416            
417            public DataStatisticsBean getStatistics() {
418                    return stats;
419            }
420            
421            public void clear() {
422                    searchPostnrVejnavnGadeid.clear();
423                    searchGadeidentAdresser.clear();
424                    alleAdresser.clear();
425                    helperCache.clear();
426            }
427            
428            
429            private String calculateExtendedDaoRoute(ExtendedBean eb, Address orgAddress, Address targetAddress) {
430                    if (targetAddress.rute == null) { //hvis targetAdress.rute er null så er adressen ikke dækket alligevel
431                            return null;
432                    }
433    
434                    // ///////////////////////////////////////////////////////////////////
435                    switch( eb.transport) {
436                    case "cykel":
437                            if (eb.afstand < 0.151) {
438                                    return "." + targetAddress.rute;
439                            } else if (eb.afstand < 0.501) {
440                                    return ".." + targetAddress.rute;
441                            } else if (eb.afstand < 0.701) {
442                                    return "..." + targetAddress.rute;
443                            } else if (eb.afstand < 0.501) {
444                                    return "...." + targetAddress.rute;
445                            }
446                            break;                  
447                    case "scooter":
448                            if (eb.afstand < 0.151) {
449                                    return "." + targetAddress.rute;
450                            } else if (eb.afstand < 0.801) {
451                                    return ".." + targetAddress.rute;
452                            } else if (eb.afstand < 1.201) {
453                                    return "..." + targetAddress.rute;
454                            } else if (eb.afstand < 2.101) {
455                                    return "...." + targetAddress.rute;
456                            }
457                            break;                          
458                    case "bil":
459                            if (eb.afstand < 0.151) {
460                                    return "." + targetAddress.rute;
461                            } else if (eb.afstand < 1.001) {
462                                    return ".." + targetAddress.rute;
463                            } else if (eb.afstand < 1.601) {
464                                    return "..." + targetAddress.rute;
465                            } else if (eb.afstand < 2.601) {
466                                    return "...." + targetAddress.rute;
467                            }
468                            break;
469                    }              
470                    return null;
471          }          }
472                    
473            public List<Address> getNonCoveredAddresses() {
474                    List<Address> result = new ArrayList<Address>(60000);
475                    for (Address a : alleAdresser) {
476                            if ( a.daekningsType == DaekningsType.DAEKNING_IKKEDAEKKET) {
477                                    result.add(a);
478                            }
479                    }
480                    Collections.sort(result );
481                    return result;
482            }
483            
484            ///////////////////////////////////////////////////////////
485            private String calculateExtendedBkKoreliste(ExtendedBean eb, Address orgAddress, Address targetAddress) {
486                    String inject;
487                    if (eb.afstand <= 0.500) {
488                            inject = ".";
489                    } else {
490                            inject = "..";
491                    }
492                    return AddressUtils.injectIntoBk(targetAddress.koreliste, inject);
493            }
494            
495            private Set<String> findVejAliaser(String vejnavn) {
496                    vejnavn = vejnavn.toLowerCase();
497                    HashSet<String> aliasSet = new HashSet<String>();
498                    aliasSet.add(vejnavn);
499                    
500                    aliasSet.add(vejnavn.replace("u", "ü") );
501                    aliasSet.add(vejnavn.replace("ü", "u") );
502                    
503                    aliasSet.add(vejnavn.replace("alle", "allé") );
504                    aliasSet.add(vejnavn.replace("allé", "alle") );                
505                    
506                    aliasSet.add(vejnavn.replace("dronningens", "dr") );
507                    aliasSet.add(vejnavn.replace("dr.", "dronningens") );
508                    aliasSet.add(vejnavn.replace("dr ", "dronningens") );
509                    
510                    aliasSet.add(vejnavn.replace("dronning", "dr") );
511                    aliasSet.add(vejnavn.replace("dr.", "dronning") );
512                    aliasSet.add(vejnavn.replace("dr ", "dronning") );
513                    
514                    aliasSet.add(vejnavn.replace("kng", "kongen") );
515                    aliasSet.add(vejnavn.replace("kongen", "kng") );
516                    
517                    aliasSet.add(vejnavn.replace("kvt", "kvarter") );
518                    aliasSet.add(vejnavn.replace("kvarter", "kvt") );
519                    
520                    aliasSet.add(vejnavn.replace("gl", "gammel") );
521                    aliasSet.add(vejnavn.replace("gammel", "gl") );
522                    
523                    aliasSet.add(vejnavn.replace("lille", "ll") );
524                    aliasSet.add(vejnavn.replace("ll ", "lille") );
525                    aliasSet.add(vejnavn.replace("ll.", "lille") );
526                    
527                    aliasSet.add(vejnavn.replace("store", "st") );
528                    aliasSet.add(vejnavn.replace("st ", "store") );
529                    aliasSet.add(vejnavn.replace("st.", "store") );
530                    
531                    aliasSet.add(vejnavn.replace("søndre", "sdr") );
532                    aliasSet.add(vejnavn.replace("sdr", "søndre") );
533    
534                    
535                    aliasSet.add(vejnavn.replace("nørre", "nr") );
536                    aliasSet.add(vejnavn.replace("nr", "nørre") );
537                    
538                    aliasSet.add(vejnavn.replace("nordre", "ndr") );
539                    aliasSet.add(vejnavn.replace("ndr", "nordre") );
540                                    
541                    aliasSet.add(vejnavn.replace("sankt", "skt") );
542                    aliasSet.add(vejnavn.replace("sankt", "sct") );
543                    aliasSet.add(vejnavn.replace("skt", "sankt") );
544                    
545                    aliasSet.add(vejnavn.replace("skt", "sct") );
546                    aliasSet.add(vejnavn.replace("sct", "skt") );
547                    
548                    
549                    // fornavn forkortelser
550                    aliasSet.add(vejnavn.replace("john", "j") );
551                    aliasSet.add(vejnavn.replace("thomas", "th") );
552                    aliasSet.add(vejnavn.replace("thorvald", "th") );
553    
554                    
555                    // Romertal
556                    aliasSet.add(vejnavn.replace("1", "i") );
557                    aliasSet.add(vejnavn.replace("i", "1") );
558                    
559                    aliasSet.add(vejnavn.replace("2", "ii") );
560                    aliasSet.add(vejnavn.replace("ii", "2") );
561                    
562                    aliasSet.add(vejnavn.replace("3", "iii") );
563                    aliasSet.add(vejnavn.replace("iii", "3") );
564                    
565                    aliasSet.add(vejnavn.replace("4", "iv") );
566                    aliasSet.add(vejnavn.replace("iv", "4") );
567                    
568                    aliasSet.add(vejnavn.replace("5", "v") );
569                    aliasSet.add(vejnavn.replace("v", "5") );
570                    
571                    aliasSet.add(vejnavn.replace("6", "vi") );
572                    aliasSet.add(vejnavn.replace("vi", "6") );
573                    
574                    aliasSet.add(vejnavn.replace("7", "vii") );
575                    aliasSet.add(vejnavn.replace("vii", "7") );
576                    
577                    aliasSet.add(vejnavn.replace("8", "viii") );
578                    aliasSet.add(vejnavn.replace("viii", "8") );
579                    
580                    aliasSet.add(vejnavn.replace("9", "ix") );
581                    aliasSet.add(vejnavn.replace("ix", "9") );
582                    
583                    aliasSet.add(vejnavn.replace("10", "x") );
584                    aliasSet.add(vejnavn.replace("x", "10") );              
585    
586                    
587                    //alternative måder at stave vej/gade/alle
588                    aliasSet.add(vejnavn.replace("vej", "ve") );
589                    aliasSet.add(vejnavn.replace("vej", "vj") );
590                    aliasSet.add(vejnavn.replace("vej", "v") );
591                    aliasSet.add(vejnavn.replace("vej", "vejen") );
592                    aliasSet.add(vejnavn.replace("vejen", "vej") );
593                    
594                    aliasSet.add(vejnavn.replace("alle", "all") );
595                    aliasSet.add(vejnavn.replace("allé", "all") );
596                    aliasSet.add(vejnavn.replace("alle", "allú") ); //Fundet i logs.hentruteinfo
597                    aliasSet.add(vejnavn.replace("allé", "allú") );
598                    
599                    aliasSet.add(vejnavn.replace("gade", "gaed") ); //Fundet i logs.hentruteinfo
600                    aliasSet.add(vejnavn.replace("gade", "gde") );
601                    
602                    aliasSet.add(vejnavn.replace("plads", "pl") );
603                    aliasSet.add(vejnavn.replace("vænget", "vænge") );
604                    
605                    
606                    // Opbyg æøå varianter over alle fundne aliaser
607                    
608                    @SuppressWarnings("unchecked")
609                    HashSet<String> variants = (HashSet<String>) aliasSet.clone();
610                    
611                    for (String vVejnavn : variants) {                                      
612                            // danske tegn 1
613                            aliasSet.add( vVejnavn.replace("æ", "ae") );
614                            aliasSet.add( vVejnavn.replace("ø", "oe") );
615                            aliasSet.add( vVejnavn.replace("å", "aa") );
616                            aliasSet.add( vVejnavn.replace("ae", "æ") );
617                            aliasSet.add( vVejnavn.replace("oe", "ø") );
618                            aliasSet.add( vVejnavn.replace("aa", "å") );
619                            
620                            //danske tegn 2
621                            aliasSet.add( vVejnavn.replace("æ", "ae").replace("ø", "oe") );
622                            aliasSet.add( vVejnavn.replace("æ", "ae").replace("å", "aa") );
623                            aliasSet.add( vVejnavn.replace("ø", "oe").replace("å", "aa") );
624                            aliasSet.add( vVejnavn.replace("ae", "æ").replace("oe","ø") );
625                            aliasSet.add( vVejnavn.replace("ae", "æ").replace("aa","å") );
626                            aliasSet.add( vVejnavn.replace("oe", "ø").replace("aa", "å") );
627                            
628                            //danske tegn 3
629                            aliasSet.add( vejnavn.replace("æ", "ae").replace("ø", "oe").replace("å", "aa") );
630                            aliasSet.add( vejnavn.replace("ae", "æ").replace("oe", "ø").replace("aa", "å") );
631                    }
632                    
633                    return aliasSet;
634            }
635            
636            public Set<Short> getPostnumre() {
637                    return new TreeSet<Short>( searchPostnrVejnavnGadeid.keySet() );
638            }
639            
640            public Set<Entry<String,Integer>> getVejnavne(int postnr) {
641                    Map<String,Integer> map = searchPostnrVejnavnGadeid.get(postnr);
642                    TreeMap<String,Integer> newMap = new TreeMap<String,Integer>();
643                    for (Entry<String,Integer> entry : map.entrySet() ) {
644                            newMap.put(entry.getKey(), entry.getValue());
645                    }
646                    
647                    return newMap.entrySet();
648            }
649            
650            public Set<String> getHusnumre(long gadeid) {
651                                    
652                    Map<String, Address> gade = searchGadeidentAdresser.get(gadeid);
653                    return new TreeSet<String>( gade.keySet() );            
654            }
655            
656            public Address getAdresse(long gadeid, String husnr) {
657                    
658                    Map<String, Address> gade = searchGadeidentAdresser.get(gadeid);
659                    return gade.get(husnr);
660                    
661            }
662                    
663  }  }

Legend:
Removed from v.2274  
changed lines
  Added in v.2492

  ViewVC Help
Powered by ViewVC 1.1.20