2 tie-formatting-problem.hh -- declare Tie_formatting_problem
4 source file of the GNU LilyPond music typesetter
6 (c) 2005--2006 Han-Wen Nienhuys <hanwen@xs4all.nl>
10 #ifndef TIE_FORMATTING_PROBLEM_HH
11 #define TIE_FORMATTING_PROBLEM_HH
13 #include "drul-array.hh"
14 #include "std-vector.hh"
16 #include "lily-proto.hh"
17 #include "tie-configuration.hh"
18 #include "tie-details.hh"
23 template<class T, int N>
29 for (int i = 0; i < N; i++)
34 template<class T, int N>
36 operator<(Tuple<T, N> const &t1,
37 Tuple<T, N> const &t2)
39 for (int i = 0; i < N ; i++)
41 if (t1.t_array[i] > t2.t_array[i])
43 if (t1.t_array[i] < t2.t_array[i])
51 typedef map< Tuple<int,4>, Tie_configuration *> Tie_configuration_map;
53 struct Tie_specification
56 Drul_array<Grob*> note_head_drul_;
57 Drul_array<int> column_ranks_;
59 bool has_manual_position_;
62 Real manual_position_;
63 Direction manual_dir_;
66 int column_span () const;
69 struct Tie_configuration_variation
72 Tie_configuration *suggestion_;
73 Tie_configuration_variation ();
76 typedef map <int, vector<Skyline_entry> > Chord_outline_map;
77 typedef map <int, Box> Column_extent_map;
78 class Tie_formatting_problem
80 Chord_outline_map chord_outlines_;
81 Column_extent_map stem_extents_;
82 Column_extent_map head_extents_;
84 set<int> dot_positions_;
86 vector<Tie_specification> specifications_;
88 Tie_configuration_map possibilities_;
93 Tie_configuration *get_configuration (int position, Direction dir, Drul_array<int> cols) const;
94 Tie_configuration *generate_configuration (int position, Direction dir, Drul_array<int> cols) const;
95 vector<Tie_configuration_variation> generate_collision_variations (Ties_configuration const &ties) const;
96 vector<Tie_configuration_variation> generate_extremal_tie_variations (Ties_configuration const &ties) const;
98 void score_configuration (Tie_configuration *) const;
99 Real score_aptitude (Tie_configuration *, Tie_specification const &,
100 Ties_configuration *, int) const;
101 void score_ties_aptitude (Ties_configuration *ties) const;
102 void score_ties_configuration (Ties_configuration *ties) const;
103 void set_ties_config_standard_directions (Ties_configuration *tie_configs_ptr);
104 void score_ties (Ties_configuration *) const;
106 Ties_configuration generate_base_chord_configuration ();
107 Ties_configuration find_best_variation (Ties_configuration const &base,
108 vector<Tie_configuration_variation> vars);
111 Tie_details details_;
112 void print_ties_configuration (Ties_configuration const *);
114 Interval get_stem_extent (int, Axis) const;
115 Interval get_head_extent (int, Axis) const;
118 Tie_formatting_problem ();
119 ~Tie_formatting_problem ();
121 Tie_specification get_tie_specification (int) const;
122 Ties_configuration generate_optimal_chord_configuration ();
123 Ties_configuration generate_ties_configuration (Ties_configuration const &);
124 Tie_configuration find_optimal_tie_configuration (Tie_specification const &) const;
126 void from_ties (vector<Grob*> const &ties);
127 void from_tie (Grob *tie);
128 void from_semi_ties (vector<Grob*> const &, Direction head_dir);
129 void set_chord_outline (vector<Item*>, Direction);
130 void set_column_chord_outline (vector<Item*>, Direction, int rank);
131 void set_manual_tie_configuration (SCM);
132 Interval get_attachment (Real, Drul_array<int>) const;
133 Grob *common_x_refpoint () const;
136 #endif /* TIE_FORMATTING_PROBLEM_HH */