X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fsimple-spacer.hh;h=39d9a3f853062cfd3eab5f0654fddd30f9e01fd2;hb=b5a990d1282e2f3a16d9ab9e3622dd784f7bdeb4;hp=80f7a32904e504633d5e8e80a4b18e742949fc48;hpb=998986bbd15afaafb24904a777e8be9ba1233799;p=lilypond.git diff --git a/lily/include/simple-spacer.hh b/lily/include/simple-spacer.hh index 80f7a32904..39d9a3f853 100644 --- a/lily/include/simple-spacer.hh +++ b/lily/include/simple-spacer.hh @@ -1,88 +1,81 @@ -/* +/* simple-spacer.hh -- declare Simple_spacer - + source file of the GNU LilyPond music typesetter - - (c) 1999 Han-Wen Nienhuys - - */ + + (c) 1999--2006 Han-Wen Nienhuys +*/ #ifndef SIMPLE_SPACER_HH #define SIMPLE_SPACER_HH -#include "parray.hh" -#include "line-spacer.hh" - +#include "std-vector.hh" +#include "lily-proto.hh" +#include "smobs.hh" struct Spring_description { - Real ideal_f_; - Real hooke_f_; - bool active_b_; - - Real block_force_f_; + Real ideal_; + Real inverse_hooke_; + Real block_force_; Real length (Real force) const; Spring_description (); - Real energy_f (Real) const; -}; - -/** - A simple spacing constraint solver. The approach: - - Stretch the line uniformly until none of the constraints (rods) - block. It then is very wide. - - - Compress until the next constraint blocks, - - Mark the springs over the constrained part to be non-active. - - Repeat with the smaller set of non-active constraints, until all - constraints blocked, or until the line is as short as desired. - This is much simpler, and much much faster than full scale - Constrained QP. On the other hand, a situation like this will not - be typeset as dense as possible, because + bool is_sane () const; - c4 c4 c4 c4 - veryveryverylongsyllable2 veryveryverylongsyllable2 - " "4 veryveryverylongsyllable2 syllable4 - - - can be further compressed to - - - c4 c4 c4 c4 - veryveryverylongsyllable2 veryveryverylongsyllable2 - " "4 veryveryverylongsyllable2 syllable4 + bool operator> (const Spring_description &s) const + { + return block_force_ > s.block_force_; + } + bool operator< (const Spring_description &s) const + { + return block_force_ < s.block_force_; + } +}; - Perhaps this is not a bad thing, because the 1st looks better anyway. */ -struct Simple_spacer: public Line_spacer +class Simple_spacer { - Array springs_; - Real force_f_; - +public: Simple_spacer (); - - virtual void solve (Column_x_positions *) const; - virtual void lower_bound_solution (Column_x_positions *) const; - virtual void add_columns (Link_array); - - void my_solve_linelen (); - void my_solve_natural_len (); - Real active_springs_stiffness () const; - Real range_stiffness (int, int) const; - void add_rod (int l, int r, Real dist); - Real range_ideal_len (int l, int r)const; - Real active_blocking_force ()const; - Real configuration_length ()const; - void set_active_states (); - Real energy_f () const; - bool active_b () const; + void solve (Real line_len, bool ragged); + void add_rod (int l, int r, Real dist); + void add_spring (Real, Real); + Real range_ideal_len (int l, int r) const; + Real range_stiffness (int l, int r) const; + Real configuration_length (Real) const; + vector spring_positions () const; + + Real force () const; + bool fits () const; + + DECLARE_SIMPLE_SMOBS (Simple_spacer,); + +private: + Real expand_line (); + Real compress_line (); + Real rod_force (int l, int r, Real dist); + + vector springs_; + Real line_len_; + Real force_; + bool ragged_; + bool fits_; }; +/* returns a vector of dimensions breaks.size () * breaks.size () */ +vector get_line_forces (vector const &columns, + vector breaks, + Real line_len, + Real indent, + bool ragged); + +Column_x_positions get_line_configuration (vector const &columns, + Real line_len, + Real indent, + bool ragged); + #endif /* SIMPLE_SPACER_HH */