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

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

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

revision 2365 by torben, Tue Feb 24 12:16:10 2015 UTC revision 2389 by torben, Thu Feb 26 15:47:07 2015 UTC
# Line 12  import java.util.Map; Line 12  import java.util.Map;
12  import java.util.Set;  import java.util.Set;
13  import java.util.concurrent.ConcurrentHashMap;  import java.util.concurrent.ConcurrentHashMap;
14    
15    import org.apache.commons.lang3.StringUtils;
16    
17  import dk.daoas.daoadresseservice.admin.ServiceConfig;  import dk.daoas.daoadresseservice.admin.ServiceConfig;
18  import dk.daoas.daoadresseservice.beans.Address;  import dk.daoas.daoadresseservice.beans.Address;
19  import dk.daoas.daoadresseservice.beans.DataStatisticsBean;  import dk.daoas.daoadresseservice.beans.DataStatisticsBean;
# Line 62  public class AdressSearch { Line 64  public class AdressSearch {
64                  }                  }
65                                    
66                                    
67                  result.splitReult = AddressUtils.splitAdresse(adresse);                  result.splitResult = AddressUtils.splitAdresse(adresse);
68                                                                                                    
69                                    
70                  if (result.splitReult.husnr.length() == 0) {                  if (result.splitResult.husnr.length() == 0) {
71                          result.status = Status.ERROR_MISSING_HOUSENUMBER;                          result.status = Status.ERROR_MISSING_HOUSENUMBER;
72                          return result;                          return result;
73                  }                  }
74                                    
75                  String vasketVejnavn = AddressUtils.vaskVejnavn( result.splitReult.vej );                  String vasketVejnavn = AddressUtils.vaskVejnavn( result.splitResult.vej );
76                                    
77                  Long gadeident =  postnrVeje.get(vasketVejnavn);                  Long gadeident =  postnrVeje.get(vasketVejnavn);
78                                    
# Line 80  public class AdressSearch { Line 82  public class AdressSearch {
82                          gadeident = helperCache.get(helperSearchKey);                          gadeident = helperCache.get(helperSearchKey);
83                  }                  }
84                                    
85                    if (gadeident == null) {
86                            String best = getbestLevenshteinDistance(vasketVejnavn, postnrVeje);
87                            if (best != null) {
88                                    result.levenshtein = true;
89                                    gadeident =  postnrVeje.get(best);
90                            }
91                    }
92                                    
93                    
94                    // Brug OpenStreetMap før vi prøver google
95                    // For google har en request limit, det har OSM ikke!
96                  if ( gadeident == null) {                  if ( gadeident == null) {
97                          if (config.useGoogle) {                          if (config.useOpenStreetMaps) {
98                                  result.googleVej = GeocodeHelper.googleHelper(config, postnr, result.splitReult.vej );                                  result.osmVej = GeocodeHelper.openstreetmapHelper(config, postnr, result.splitResult.vej );
99                                  result.google = true;                                  result.osm = true;
100                                                                    
101                                  if (result.googleVej != null) {                                  if (result.osmVej != null) {
102                                          String googleVasket = AddressUtils.vaskVejnavn( result.googleVej );                                          String osmVasket = AddressUtils.vaskVejnavn( result.osmVej );
103                                          gadeident =  postnrVeje.get(googleVasket);                                          gadeident =  postnrVeje.get(osmVasket);
104                                                                                    
105                                          if (gadeident != null) {                                          if (gadeident != null) {
106                                                  helperCache.put(helperSearchKey, gadeident);                                                  helperCache.put(helperSearchKey, gadeident);
# Line 98  public class AdressSearch { Line 110  public class AdressSearch {
110                  }                  }
111                                    
112                  if ( gadeident == null) {                  if ( gadeident == null) {
113                          if (config.useOpenStreetMaps) {                          if (config.useGoogle) {
114                                  result.osmVej = GeocodeHelper.openstreetmapHelper(config, postnr, result.splitReult.vej );                                  result.googleVej = GeocodeHelper.googleHelper(config, postnr, result.splitResult.vej );
115                                  result.osm = true;                                  result.google = true;
116                                                                    
117                                  if (result.osmVej != null) {                                  if (result.googleVej != null) {
118                                          String osmVasket = AddressUtils.vaskVejnavn( result.osmVej );                                          String googleVasket = AddressUtils.vaskVejnavn( result.googleVej );
119                                          gadeident =  postnrVeje.get(osmVasket);                                          gadeident =  postnrVeje.get(googleVasket);
120                                                                                    
121                                          if (gadeident != null) {                                          if (gadeident != null) {
122                                                  helperCache.put(helperSearchKey, gadeident);                                                  helperCache.put(helperSearchKey, gadeident);
# Line 113  public class AdressSearch { Line 125  public class AdressSearch {
125                          }                          }
126                  }                  }
127                                    
128    
129                    
130                  if (gadeident == null) {                                          if (gadeident == null) {                        
131                          result.status = Status.ERROR_UNKNOWN_STREETNAME;                          result.status = Status.ERROR_UNKNOWN_STREETNAME;
132                          return result;                          return result;
# Line 125  public class AdressSearch { Line 139  public class AdressSearch {
139                  }                  }
140                                    
141                                    
142                  String husnrSearch = "" + result.splitReult.husnr + result.splitReult.litra;                  String husnrSearch = "" + result.splitResult.husnr + result.splitResult.litra;
143                  Address addr = gade.get(husnrSearch);                  Address addr = gade.get(husnrSearch);
144    
145                  if (addr == null) {                  if (addr == null) {
# Line 135  public class AdressSearch { Line 149  public class AdressSearch {
149                                    
150                  result.address = addr;                  result.address = addr;
151                                    
152                  if (addr.distributor.equals("LUKKET")) {                                          
153                    if ( StringUtils.equals(addr.distributor, "LUKKET") ) {                
154                          result.status = Status.STATUS_NOT_COVERED; //Skal vi have en special status til Lukkede adresser ?                          result.status = Status.STATUS_NOT_COVERED; //Skal vi have en special status til Lukkede adresser ?
155                          return result;                          return result;
156                  }                                                }                              
# Line 333  public class AdressSearch { Line 348  public class AdressSearch {
348          }          }
349                    
350                    
351            private String getbestLevenshteinDistance(String vasketVejnavn, Map<String,Long> postnrVeje) {
352                    for(String vej : postnrVeje.keySet()) {
353                            if ( StringUtils.getLevenshteinDistance(vasketVejnavn, vej) == 1) {
354                                    System.out.println("Levenstein: " + vasketVejnavn + "->" + vej);
355                                    return vej;
356                            }
357                    }
358                    
359                    return null;
360            }
361            
362          private String calculateExtendedDaoRoute(ExtendedBean eb, Address orgAddress, Address targetAddress) {          private String calculateExtendedDaoRoute(ExtendedBean eb, Address orgAddress, Address targetAddress) {
363    
364                  // ///////////////////////////////////////////////////////////////////                  // ///////////////////////////////////////////////////////////////////
# Line 442  public class AdressSearch { Line 468  public class AdressSearch {
468                  aliasSet.add(vejnavn.replace("skt", "sct") );                  aliasSet.add(vejnavn.replace("skt", "sct") );
469                  aliasSet.add(vejnavn.replace("sct", "skt") );                  aliasSet.add(vejnavn.replace("sct", "skt") );
470                                    
471                    
472                    //alternative måder at stave vej/gade/alle
473                  aliasSet.add(vejnavn.replace("vej", "ve") );                  aliasSet.add(vejnavn.replace("vej", "ve") );
474                  aliasSet.add(vejnavn.replace("vej", "vj") );                  aliasSet.add(vejnavn.replace("vej", "vj") );
475                    aliasSet.add(vejnavn.replace("vej", "v") );
476                                    
477                  aliasSet.add(vejnavn.replace("alle", "all") );                  aliasSet.add(vejnavn.replace("alle", "all") );
478                  aliasSet.add(vejnavn.replace("allé", "all") );                  aliasSet.add(vejnavn.replace("allé", "all") );
479                    aliasSet.add(vejnavn.replace("alle", "allú") ); //Fundet i logs.hentruteinfo
480                    aliasSet.add(vejnavn.replace("allé", "allú") );
481                    
482                    aliasSet.add(vejnavn.replace("gade", "gaed") ); //Fundet i logs.hentruteinfo
483                    
484                                    
485                  // Opbyg æøå varianter over alle fundne aliaser                  // Opbyg æøå varianter over alle fundne aliaser
486                                    

Legend:
Removed from v.2365  
changed lines
  Added in v.2389

  ViewVC Help
Powered by ViewVC 1.1.20