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

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

  ViewVC Help
Powered by ViewVC 1.1.20