/[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

revision 2802 by torben, Wed Jan 13 10:44:59 2016 UTC revision 2821 by torben, Tue Jan 19 10:02:51 2016 UTC
# Line 6  import java.util.ArrayList; Line 6  import java.util.ArrayList;
6  import java.util.Collections;  import java.util.Collections;
7  import java.util.Date;  import java.util.Date;
8  import java.util.HashMap;  import java.util.HashMap;
 import java.util.HashSet;  
9  import java.util.List;  import java.util.List;
10  import java.util.Map;  import java.util.Map;
11  import java.util.Map.Entry;  import java.util.Map.Entry;
# Line 216  public class AddressSearch { Line 215  public class AddressSearch {
215                  Address addr = litraList.get( result.splitResult.litra );                  Address addr = litraList.get( result.splitResult.litra );
216                                    
217                  if (addr == null) { //litra ikke fundet                  if (addr == null) { //litra ikke fundet
218                          if (config.nearestLitra == true) {                          if (config.nearestLitra == true || naermesteHusnr == true) {
219                                  result.nearestLitra = true;                                  result.nearestLitra = true;
220                                  addr = litraList.values().iterator().next();                                                              addr = litraList.values().iterator().next();                            
221                          } else {                          } else {
# Line 311  public class AddressSearch { Line 310  public class AddressSearch {
310                  searchGadeidentAdresser = new HashMap<Integer,  Map<Short, Map<String,Address>>>();                  searchGadeidentAdresser = new HashMap<Integer,  Map<Short, Map<String,Address>>>();
311                  helperCache = new ConcurrentHashMap<String,Integer>();                  helperCache = new ConcurrentHashMap<String,Integer>();
312                                    
313                    // //////////////////////
314                    // Start stage1
315                    
316                  long start1 = System.currentTimeMillis();                  long start1 = System.currentTimeMillis();
317                  System.out.println("Build -- stage 1");                  System.out.println("Build -- stage 1");
318                                    
319                  alleAdresser = db.getAllAdresses();                  alleAdresser = db.getAllAdresses();
320                                    
321                                    
322                  /* Mapper mellem db Row ID og adresse noden */                  /* Mapper mellem db Row ID og adresse noden - skal bruges i stage3*/
323                  Map<Integer,Address> idAddressMap = new HashMap<Integer,Address>( alleAdresser.size() );                  Map<Integer,Address> idAddressMap = new HashMap<Integer,Address>( alleAdresser.size() );
324                  DeduplicateHelper<String> aliasHelper = new DeduplicateHelper<String>();                  
325                                    
326                  DeduplicateHelper<Short> shortHelper = new DeduplicateHelper<Short>();                  DeduplicateHelper<Short> shortHelper = new DeduplicateHelper<Short>();
327                  DeduplicateHelper<Integer> intHelper = new DeduplicateHelper<Integer>();                  DeduplicateHelper<Integer> intHelper = new DeduplicateHelper<Integer>();
328                                    
329                    AliasGenerator aliasGenerator = new AliasGenerator();
330                    
331                                    
332                  for (Address a : alleAdresser) {                  for (Address a : alleAdresser) {
333                          idAddressMap.put(a.id, a);                          idAddressMap.put(a.id, a);
# Line 345  public class AddressSearch { Line 349  public class AddressSearch {
349                                                                    
350                                  gadeident = intHelper.getInstance( a.gadeid );                                  gadeident = intHelper.getInstance( a.gadeid );
351                                                                    
352                                  Set<String> aliaser = findVejAliaser(a.vejnavn);                                  Set<String> aliaser = aliasGenerator.findVejAliaser(a.vejnavn);
353                                  for(String alias : aliaser) {                                  for(String alias : aliaser) {                                  
354                                          String vasketAlias = AddressUtils.vaskVejnavn(alias);                                          postnrVeje.put(alias, gadeident);      
                                         vasketAlias = aliasHelper.getInstance(vasketAlias);  
                                           
                                         postnrVeje.put(vasketAlias, gadeident);  
355                                  }                                  }
356                                                                    
357                          }                          }
# Line 370  public class AddressSearch { Line 371  public class AddressSearch {
371                                                    
372                          litraList.put(a.husnrbogstav, a);                                                litraList.put(a.husnrbogstav, a);                      
373                  }                  }
374                    
375                    
376                    aliasGenerator.clear();  //frigiv hukommelse inden stage2
377                    aliasGenerator = null;
378                    shortHelper.clear();
379                    shortHelper = null;
380                    intHelper.clear();
381                    intHelper = null;
382                                    
383    
384                  ////////////////////////////////////////////////////////////////////////////////////////                  ////////////////////////////////////////////////////////////////////////////////////////
385                  long start2 = System.currentTimeMillis();                  long start2 = System.currentTimeMillis();
# Line 405  public class AddressSearch { Line 415  public class AddressSearch {
415                  }                  }
416                  System.out.println("Anvendte " + vaskCount + " aliaser fra databasen");                  System.out.println("Anvendte " + vaskCount + " aliaser fra databasen");
417                                    
418                    aliasList.clear();//cleanup inden stage3
419                    
420                                    
421                  ////////////////////////////////////////////////////////////////////////////////////////                  ////////////////////////////////////////////////////////////////////////////////////////
422                  long start3 = System.currentTimeMillis();                  long start3 = System.currentTimeMillis();
# Line 447  public class AddressSearch { Line 459  public class AddressSearch {
459    
460                          boolean covered = false;                          boolean covered = false;
461                          if (targetAddress.distributor.equals("DAO")) {                          if (targetAddress.distributor.equals("DAO")) {
462                                  orgAddress.rute = calculateExtendedDaoRoute(eb,orgAddress,targetAddress);                                        orgAddress.ruteMandag = calculateExtendedDaoRoute(eb,orgAddress,targetAddress);
463                                  orgAddress.rute = ruteHelper.getInstance(orgAddress.rute);                                  orgAddress.ruteMandag = ruteHelper.getInstance(orgAddress.ruteMandag);
464                                                                    
465                                  if (orgAddress.rute != null) {                                  if (orgAddress.ruteMandag != null) {
466                                          orgAddress.koreliste = targetAddress.koreliste;                                          orgAddress.korelisteMandag = targetAddress.korelisteMandag;
467                                          covered = true;                                          covered = true;
468                                  }                                  }
469                          }                          }
470                                                    
471                          if (targetAddress.distributor.equals("BK")) {                          if (targetAddress.distributor.equals("BK")) {
472                                  orgAddress.koreliste = calculateExtendedBkKoreliste(eb,orgAddress,targetAddress);                                  orgAddress.korelisteMandag = calculateExtendedBkKoreliste(eb,orgAddress,targetAddress);
473                                  orgAddress.koreliste = korelisteHelper.getInstance(orgAddress.koreliste);                                  orgAddress.korelisteMandag = korelisteHelper.getInstance(orgAddress.korelisteMandag);
474                                                                    
475                                  if (orgAddress.koreliste != null) {                                  if (orgAddress.korelisteMandag != null) {
476                                          orgAddress.rute = targetAddress.rute;                                          orgAddress.ruteMandag = targetAddress.ruteMandag;
477                                          covered = true;                                          covered = true;
478                                  }                                  }
479                          }                          }
# Line 480  public class AddressSearch { Line 492  public class AddressSearch {
492                          }                          }
493                  }                  }
494                                    
495                  // nu skal vi ikke bruge idAddressMap længere                  // cleanup inden stage 4
496                  idAddressMap = null;                  idAddressMap = null;
497                    ruteHelper = null;
498                    korelisteHelper = null;
499                                    
500                  //////////////////////////////////////////////////////////////////////////////////////                  //////////////////////////////////////////////////////////////////////////////////////
501                  long start4 = System.currentTimeMillis();                  long start4 = System.currentTimeMillis();
# Line 505  public class AddressSearch { Line 519  public class AddressSearch {
519                          }                          }
520                                                    
521                          addr.daekningsType = DaekningsType.DAEKNING_100PCT;                          addr.daekningsType = DaekningsType.DAEKNING_100PCT;
522                          addr.rute = bean.rute;                          addr.ruteMandag = bean.rute;
523                          addr.koreliste = bean.koreliste;                          addr.korelisteMandag = bean.koreliste;
524                          addr.dbkBane = bean.dbkBane;                          addr.dbkBane = bean.dbkBane;
525                          addr.distributor = bean.distributor;                          addr.distributor = bean.distributor;
526                  }                  }
# Line 565  public class AddressSearch { Line 579  public class AddressSearch {
579                    
580                    
581          private String calculateExtendedDaoRoute(ExtendedBean eb, Address orgAddress, Address targetAddress) {          private String calculateExtendedDaoRoute(ExtendedBean eb, Address orgAddress, Address targetAddress) {
582                  if (targetAddress.rute == null) { //hvis targetAdress.rute er null så er adressen ikke dækket alligevel                  if (targetAddress.ruteMandag == null) { //hvis targetAdress.rute er null så er adressen ikke dækket alligevel
583                          return null;                          return null;
584                  }                  }
585    
# Line 573  public class AddressSearch { Line 587  public class AddressSearch {
587                  switch( eb.transport) {                  switch( eb.transport) {
588                  case "cykel":                  case "cykel":
589                          if (eb.afstand < 0.151) {                          if (eb.afstand < 0.151) {
590                                  return "." + targetAddress.rute;                                  return "." + targetAddress.ruteMandag;
591                          } else if (eb.afstand < 0.501) {                          } else if (eb.afstand < 0.501) {
592                                  return ".." + targetAddress.rute;                                  return ".." + targetAddress.ruteMandag;
593                          } else if (eb.afstand < 0.701) {                          } else if (eb.afstand < 0.701) {
594                                  return "..." + targetAddress.rute;                                  return "..." + targetAddress.ruteMandag;
595                          } else if (eb.afstand < 1.001) {                          } else if (eb.afstand < 1.001) {
596                                  return "...." + targetAddress.rute;                                  return "...." + targetAddress.ruteMandag;
597                          }                          }
598                          break;                                            break;                  
599                  case "scooter":                  case "scooter":
600                          if (eb.afstand < 0.151) {                          if (eb.afstand < 0.151) {
601                                  return "." + targetAddress.rute;                                  return "." + targetAddress.ruteMandag;
602                          } else if (eb.afstand < 0.801) {                          } else if (eb.afstand < 0.801) {
603                                  return ".." + targetAddress.rute;                                  return ".." + targetAddress.ruteMandag;
604                          } else if (eb.afstand < 1.201) {                          } else if (eb.afstand < 1.201) {
605                                  return "..." + targetAddress.rute;                                  return "..." + targetAddress.ruteMandag;
606                          } else if (eb.afstand < 2.101) {                          } else if (eb.afstand < 2.101) {
607                                  return "...." + targetAddress.rute;                                  return "...." + targetAddress.ruteMandag;
608                          }                          }
609                          break;                                                    break;                          
610                  case "bil":                  case "bil":
611                          if (eb.afstand < 0.151) {                          if (eb.afstand < 0.151) {
612                                  return "." + targetAddress.rute;                                  return "." + targetAddress.ruteMandag;
613                          } else if (eb.afstand < 1.001) {                          } else if (eb.afstand < 1.001) {
614                                  return ".." + targetAddress.rute;                                  return ".." + targetAddress.ruteMandag;
615                          } else if (eb.afstand < 1.601) {                          } else if (eb.afstand < 1.601) {
616                                  return "..." + targetAddress.rute;                                  return "..." + targetAddress.ruteMandag;
617                          } else if (eb.afstand < 2.601) {                          } else if (eb.afstand < 2.601) {
618                                  return "...." + targetAddress.rute;                                  return "...." + targetAddress.ruteMandag;
619                          }                          }
620                          break;                          break;
621                  default:                  default:
# Line 640  public class AddressSearch { Line 654  public class AddressSearch {
654                  } else {                  } else {
655                          inject = "..";                          inject = "..";
656                  }                  }
657                  return AddressUtils.injectIntoBk(targetAddress.koreliste, inject);                  return AddressUtils.injectIntoBk(targetAddress.korelisteMandag, inject);
658          }          }
659                    
         private Set<String> findVejAliaser(String vejnavn) {  
                 vejnavn = vejnavn.toLowerCase();  
                 HashSet<String> aliasSet = new HashSet<String>();  
                 aliasSet.add(vejnavn);  
                                   
                 aliasSet.add(vejnavn.replace("alle", "allé") );  
                 aliasSet.add(vejnavn.replace("allé", "alle") );                  
                   
                   
                 // forkortelser  
                 aliasSet.add(vejnavn.replace("dronningens", "dr") );  
                 aliasSet.add(vejnavn.replace("dr.", "dronningens") );  
                 aliasSet.add(vejnavn.replace("dr ", "dronningens") );  
                   
                 aliasSet.add(vejnavn.replace("dronning", "dr") );  
                 aliasSet.add(vejnavn.replace("dr.", "dronning") );  
                 aliasSet.add(vejnavn.replace("dr ", "dronning") );  
                   
                 aliasSet.add(vejnavn.replace("kng", "kongen") );  
                 aliasSet.add(vejnavn.replace("kongen", "kng") );  
                   
                 aliasSet.add(vejnavn.replace("kvt", "kvarter") );  
                 aliasSet.add(vejnavn.replace("kvarter", "kvt") );  
                   
                 aliasSet.add(vejnavn.replace("gl", "gammel") );  
                 aliasSet.add(vejnavn.replace("gammel", "gl") );  
                   
                 aliasSet.add(vejnavn.replace("gl", "gamle") );  
                 aliasSet.add(vejnavn.replace("gamle", "gl") );  
                   
                 aliasSet.add(vejnavn.replace("lille", "ll") );  
                 aliasSet.add(vejnavn.replace("ll ", "lille") );  
                 aliasSet.add(vejnavn.replace("ll.", "lille") );  
                   
                 aliasSet.add(vejnavn.replace("store", "st") );  
                 aliasSet.add(vejnavn.replace("st ", "store") );  
                 aliasSet.add(vejnavn.replace("st.", "store") );  
                   
                 aliasSet.add(vejnavn.replace("søndre", "sdr") );  
                 aliasSet.add(vejnavn.replace("sdr", "søndre") );                
                 aliasSet.add(vejnavn.replace("sønder", "sdr") );  
                 aliasSet.add(vejnavn.replace("sdr", "sønder") );  
   
                   
                 aliasSet.add(vejnavn.replace("nørre", "nr") );  
                 aliasSet.add(vejnavn.replace("nr", "nørre") );  
                   
                 aliasSet.add(vejnavn.replace("nordre", "ndr") );  
                 aliasSet.add(vejnavn.replace("ndr", "nordre") );  
                   
                   
                 aliasSet.add(vejnavn.replace("vestre", "vester") );  
                 aliasSet.add(vejnavn.replace("vester", "vestre") );  
                   
                 aliasSet.add(vejnavn.replace("søndre", "sønder") );  
                 aliasSet.add(vejnavn.replace("sønder", "søndre") );  
                   
                 aliasSet.add(vejnavn.replace("østre", "øster") );  
                 aliasSet.add(vejnavn.replace("øster", "østre") );  
                   
                 aliasSet.add(vejnavn.replace("borgmester", "borgm") );  
                 aliasSet.add(vejnavn.replace("borgm", "borgmester") );  
                   
                                   
                 aliasSet.add(vejnavn.replace("sankt", "skt") );  
                 aliasSet.add(vejnavn.replace("sankt", "sct") );  
                 aliasSet.add(vejnavn.replace("skt", "sankt") );  
                   
                 aliasSet.add(vejnavn.replace("skt", "sct") );  
                 aliasSet.add(vejnavn.replace("sct", "skt") );            
                   
                   
                   
                 // fornavn forkortelser  
                 aliasSet.add(vejnavn.replace("john", "j") );  
                 aliasSet.add(vejnavn.replace("thomas", "th") );  
                 aliasSet.add(vejnavn.replace("thorvald", "th") );  
                 aliasSet.add(vejnavn.replace("frederik", "fr") );  
                 aliasSet.add(vejnavn.replace("frederiks", "fr") );  
                   
                   
                 aliasSet.add(vejnavn.replace("christian", "chr") );  
                 aliasSet.add(vejnavn.replace("christians", "chr") );  
                 aliasSet.add(vejnavn.replace("kristian", "kr") );  
                 aliasSet.add(vejnavn.replace("kristians", "kr") );  
   
                 aliasSet.add(vejnavn.replace("mylius", "myl") );  
                 aliasSet.add(vejnavn.replace("myl", "mylius") );  
                   
                 aliasSet.add(vejnavn.replace("ludvig", "ludv") );  
                 aliasSet.add(vejnavn.replace("ludv", "ludvig") );  
                   
                   
                 // alternative stavninger  
                 aliasSet.add(vejnavn.replace("peder", "peter") );  
                 aliasSet.add(vejnavn.replace("peter", "peder") );  
                   
   
                   
                 // Romertal  
                 aliasSet.add(vejnavn.replace("1", "i") );  
                 aliasSet.add(vejnavn.replace("i", "1") );  
                   
                 aliasSet.add(vejnavn.replace("2", "ii") );  
                 aliasSet.add(vejnavn.replace("ii", "2") );  
                   
                 aliasSet.add(vejnavn.replace("3", "iii") );  
                 aliasSet.add(vejnavn.replace("iii", "3") );  
                   
                 aliasSet.add(vejnavn.replace("4", "iv") );  
                 aliasSet.add(vejnavn.replace("iv", "4") );  
                   
                 aliasSet.add(vejnavn.replace("5", "v") );  
                 aliasSet.add(vejnavn.replace("v", "5") );  
                   
                 aliasSet.add(vejnavn.replace("6", "vi") );  
                 aliasSet.add(vejnavn.replace("vi", "6") );  
                   
                 aliasSet.add(vejnavn.replace("7", "vii") );  
                 aliasSet.add(vejnavn.replace("vii", "7") );  
                   
                 aliasSet.add(vejnavn.replace("8", "viii") );  
                 aliasSet.add(vejnavn.replace("viii", "8") );  
                   
                 aliasSet.add(vejnavn.replace("9", "ix") );  
                 aliasSet.add(vejnavn.replace("ix", "9") );  
                   
                 aliasSet.add(vejnavn.replace("10", "x") );  
                 aliasSet.add(vejnavn.replace("x", "10") );                
   
                   
                 //alternative måder at stave vej/gade/alle  
                 aliasSet.add(vejnavn.replace("vej", "ve") );  
                 aliasSet.add(vejnavn.replace("vej", "vj") );  
                 aliasSet.add(vejnavn.replace("vej", "v") );  
                 aliasSet.add(vejnavn.replace("vej", "vejen") );  
                 aliasSet.add(vejnavn.replace("vejen", "vej") );  
                   
                 aliasSet.add(vejnavn.replace("v", "vej") );//Vi kan have vejnavne i DB der bare slutter på v istedet for vej  
                   
                 aliasSet.add(vejnavn.replace("alle", "all") );  
                 aliasSet.add(vejnavn.replace("allé", "all") );  
                 aliasSet.add(vejnavn.replace("alle", "allú") ); //Fundet i logs.hentruteinfo  
                 aliasSet.add(vejnavn.replace("allé", "allú") );  
                   
                 aliasSet.add(vejnavn.replace("gade", "gaed") ); //Fundet i logs.hentruteinfo  
                 aliasSet.add(vejnavn.replace("gade", "gde") );  
                   
                 aliasSet.add(vejnavn.replace("plads", "pl") );  
                 aliasSet.add(vejnavn.replace("vænget", "vænge") );  
   
                 aliasSet.add(vejnavn.replace("boulevard", "blvd") );  
                 aliasSet.add(vejnavn.replace("blvd", "boulevard") );  
   
                 aliasSet.add(vejnavn.replace("boulevard", "boule") );  
                 aliasSet.add(vejnavn.replace("boule", "boulevard") );  
                                   
                 aliasSet.add(vejnavn.replace("kronborg", "krbg") ); //Krbg ladegårdsvej, 3000  
                 aliasSet.add(vejnavn.replace("krbg", "kronborg") );  
                   
                 // Opbyg æøå varianter over alle fundne aliaser  
                   
                 @SuppressWarnings("unchecked")  
                 HashSet<String> variants = (HashSet<String>) aliasSet.clone();  
                   
                 for (String vVejnavn : variants) {                                        
                         // danske tegn 1  
                         aliasSet.add( vVejnavn.replace("æ", "ae") );  
                         aliasSet.add( vVejnavn.replace("ø", "oe") );  
                         aliasSet.add( vVejnavn.replace("å", "aa") );  
                         aliasSet.add( vVejnavn.replace("ae", "æ") );  
                         aliasSet.add( vVejnavn.replace("oe", "ø") );  
                         aliasSet.add( vVejnavn.replace("aa", "å") );  
                           
                         //danske tegn 2  
                         aliasSet.add( vVejnavn.replace("æ", "ae").replace("ø", "oe") );  
                         aliasSet.add( vVejnavn.replace("æ", "ae").replace("å", "aa") );  
                         aliasSet.add( vVejnavn.replace("ø", "oe").replace("å", "aa") );  
                         aliasSet.add( vVejnavn.replace("ae", "æ").replace("oe","ø") );  
                         aliasSet.add( vVejnavn.replace("ae", "æ").replace("aa","å") );  
                         aliasSet.add( vVejnavn.replace("oe", "ø").replace("aa", "å") );  
                           
                         //danske tegn 3  
                         aliasSet.add( vVejnavn.replace("æ", "ae").replace("ø", "oe").replace("å", "aa") );  
                         aliasSet.add( vVejnavn.replace("ae", "æ").replace("oe", "ø").replace("aa", "å") );  
                           
                           
                         //udenlandsketegn  
                         aliasSet.add( vVejnavn.replace("u", "ü") );  
                         aliasSet.add( vVejnavn.replace("ü", "u") );  
                           
                         aliasSet.add( vVejnavn.replace("ä", "æ") );  
                         aliasSet.add( vVejnavn.replace("æ", "ä") );  
                           
                         aliasSet.add( vVejnavn.replace("ö", "ø") );  
                         aliasSet.add( vVejnavn.replace("ø", "ö") );  
                 }  
                   
                 return aliasSet;  
         }  
660                    
661          public Set<Short> getPostnumre() {          public Set<Short> getPostnumre() {
662                  return new TreeSet<Short>( searchPostnrVejnavnGadeid.keySet() );                  return new TreeSet<Short>( searchPostnrVejnavnGadeid.keySet() );

Legend:
Removed from v.2802  
changed lines
  Added in v.2821

  ViewVC Help
Powered by ViewVC 1.1.20