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

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

  ViewVC Help
Powered by ViewVC 1.1.20