ClassNames.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. /**
  2. * @file ClassNames.h
  3. * @brief simple interface for class name confusion
  4. * @author Erik Rodner
  5. * @date 02/08/2008
  6. */
  7. #ifndef CLASSNAMESINCLUDE
  8. #define CLASSNAMESINCLUDE
  9. #include "core/image/ImageT.h"
  10. #include "core/vector/VectorT.h"
  11. #include "core/vector/MatrixT.h"
  12. #include <string>
  13. #include <map>
  14. // in future we should replace this with
  15. // unordered_map, but it is still experimental but standard c++
  16. // #include <ext/hash_map>
  17. #include <tr1/unordered_map>
  18. #include "core/basics/Config.h"
  19. #include "core/basics/Persistent.h"
  20. namespace OBJREC {
  21. /** simple interface for class name confusion */
  22. class ClassNames : public NICE::Persistent
  23. {
  24. protected:
  25. std::map<std::string, std::string> tbl_code_text;
  26. std::map<std::string, std::string> tbl_text_code;
  27. std::map<int, std::string> tbl_classno_code;
  28. std::map<std::string, int> tbl_code_classno;
  29. // __gnu_cxx::hash_map<long, int> tbl_color_classno;
  30. std::tr1::unordered_map<long, int> tbl_color_classno;
  31. std::map<int, long> tbl_classno_color;
  32. int maxClassNo;
  33. public:
  34. /** simple constructor */
  35. ClassNames();
  36. /** copy constructor */
  37. ClassNames ( const ClassNames & cn );
  38. /** create sub selection */
  39. ClassNames ( const ClassNames & cn,
  40. const std::string & classselection );
  41. /** simple destructor */
  42. virtual ~ClassNames();
  43. /** get the readable class number of a class number */
  44. std::string text ( int classno ) const;
  45. /** get the class code (e.g. ascii code) of a class number */
  46. std::string code ( int classno ) const;
  47. /** get the class number corresponding to the code */
  48. int classno ( std::string code ) const;
  49. /** get the class number corresponding to the name */
  50. int classnoFromText ( std::string text ) const;
  51. /** number of classes */
  52. int numClasses () const;
  53. void getSelection ( const std::string & classselection,
  54. std::set<int> & classnos ) const;
  55. /** add new class information
  56. * @param classno class number
  57. * @param code class code (such as ascii number or just the name)
  58. * @param text class name as readable ascii representation
  59. */
  60. void addClass ( int classno, const std::string & code,
  61. const std::string & text );
  62. bool readFromConfig ( const NICE::Config & datasetconf,
  63. const std::string & classselection );
  64. /** is there any class with this class number */
  65. bool existsClassno ( int classno ) const;
  66. /** is there any class with this class code */
  67. bool existsClassCode ( const std::string & classcode ) const;
  68. int getMaxClassno () const;
  69. void getRGBColor ( int classno, int & r, int & g, int & b ) const;
  70. void getClassnoFromColor ( int & classno, int r, int g, int b ) const;
  71. /** colorize a labeled image using color information given in the class
  72. * information file */
  73. void labelToRGB ( const NICE::Image & img, NICE::ColorImage & rgb ) const;
  74. int getBackgroundClass () const;
  75. /** restore classnames in the format <classtext> <classcode> <classno> */
  76. void restore ( std::istream & is, int format = 0 );
  77. /** store classnames in the format <classtext> <classcode> <classno> */
  78. void store ( std::ostream & os, int format = 0 ) const;
  79. /** clear class information */
  80. void clear ();
  81. };
  82. } // namespace
  83. #endif