summaryrefslogtreecommitdiffstats
path: root/kpovmodeler/pmpolynom.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'kpovmodeler/pmpolynom.cpp')
-rw-r--r--kpovmodeler/pmpolynom.cpp238
1 files changed, 238 insertions, 0 deletions
diff --git a/kpovmodeler/pmpolynom.cpp b/kpovmodeler/pmpolynom.cpp
new file mode 100644
index 00000000..93555a58
--- /dev/null
+++ b/kpovmodeler/pmpolynom.cpp
@@ -0,0 +1,238 @@
+/*
+**************************************************************************
+ description
+ --------------------
+ copyright : (C) 2002 by Andreas Zehender
+**************************************************************************
+
+**************************************************************************
+* *
+* This program is free software; you can redistribute it and/or modify *
+* it under the terms of the GNU General Public License as published by *
+* the Free Software Foundation; either version 2 of the License, or *
+* (at your option) any later version. *
+* *
+**************************************************************************/
+
+
+#include "pmpolynom.h"
+#include "pmpolynomedit.h"
+
+#include "pmxmlhelper.h"
+#include "pmmemento.h"
+
+#include <klocale.h>
+
+const double c_defaultCoefficients[10] =
+{ // Hyperboloid_Y
+ 1.0, 0.0, 0.0,
+ 0.0, -1.0, 0.0,
+ 0.0, 1.0, 0.0,
+ -1.0
+};
+const int c_defaultOrder = 2;
+const bool c_defaultSturm = true;
+const int c_polynomSize[8] = { 0, 0, 10, 20, 35, 56, 84, 120 };
+
+PMDefinePropertyClass( PMPolynom, PMPolynomProperty );
+
+class PMCoefficientProperty : public PMPropertyBase
+{
+public:
+ PMCoefficientProperty( )
+ : PMPropertyBase( "coefficients", PMVariant::Double )
+ {
+ m_index = 0;
+ }
+ virtual int dimensions( ) const { return 1; }
+ virtual void setIndex( int /*dimension*/, int index )
+ {
+ m_index = index;
+ }
+ virtual int size( PMObject* object, int /*dimension*/ ) const
+ {
+ return c_polynomSize[ ( ( PMPolynom* ) object )->polynomOrder( ) ];
+ }
+protected:
+ virtual bool setProtected( PMObject* obj, const PMVariant& var )
+ {
+ PMPolynom* p = ( PMPolynom* ) obj;
+ PMVector v = p->coefficients( );
+ v[m_index] = var.doubleData( );
+ p->setCoefficients( v );
+
+ return true;
+ }
+ virtual PMVariant getProtected( const PMObject* obj )
+ {
+ PMPolynom* p = ( PMPolynom* ) obj;
+ return PMVariant( p->coefficients( )[m_index] );
+ }
+
+private:
+ int m_index;
+};
+
+PMMetaObject* PMPolynom::s_pMetaObject = 0;
+PMObject* createNewPolynom( PMPart* part )
+{
+ return new PMPolynom( part );
+}
+
+PMPolynom::PMPolynom( PMPart* part )
+ : Base( part )
+{
+ int i;
+ m_order = c_defaultOrder;
+ m_coefficients = PMVector( 10 );
+ for( i = 0; i < 10; i++ )
+ m_coefficients[i] = c_defaultCoefficients[i];
+ m_sturm = c_defaultSturm;
+}
+
+PMPolynom::PMPolynom( const PMPolynom& p )
+ : Base( p )
+{
+ m_order = p.m_order;
+ m_coefficients = p.m_coefficients;
+ m_sturm = p.m_sturm;
+}
+
+PMPolynom::~PMPolynom( )
+{
+}
+
+QString PMPolynom::description( ) const
+{
+ if( m_order == 2 )
+ return i18n( "quadric" );
+ else if( m_order == 3 )
+ return i18n( "cubic" );
+ else if( m_order == 4 )
+ return i18n( "quartic" );
+ return i18n( "polynom" );
+}
+
+void PMPolynom::serialize( QDomElement& e, QDomDocument& doc ) const
+{
+ e.setAttribute( "order", m_order );
+ e.setAttribute( "coefficients", m_coefficients.serializeXML( ) );
+ e.setAttribute( "sturm", m_sturm );
+ Base::serialize( e, doc );
+}
+
+void PMPolynom::readAttributes( const PMXMLHelper& h )
+{
+ m_order = h.intAttribute( "order", c_defaultOrder );
+ m_coefficients = h.vectorAttribute( "coefficients", m_coefficients );
+ m_sturm = h.boolAttribute( "sturm", c_defaultSturm );
+ Base::readAttributes( h );
+}
+
+PMMetaObject* PMPolynom::metaObject( ) const
+{
+ if( !s_pMetaObject )
+ {
+ s_pMetaObject = new PMMetaObject( "Polynom", Base::metaObject( ),
+ createNewPolynom );
+ s_pMetaObject->addProperty(
+ new PMPolynomProperty( "polynomOrder", &PMPolynom::setPolynomOrder,
+ &PMPolynom::polynomOrder ) );
+ s_pMetaObject->addProperty(
+ new PMPolynomProperty( "sturm", &PMPolynom::setSturm,
+ &PMPolynom::sturm ) );
+
+ s_pMetaObject->addProperty( new PMCoefficientProperty( ) );
+ }
+ return s_pMetaObject;
+}
+
+void PMPolynom::cleanUp( ) const
+{
+ if( s_pMetaObject )
+ {
+ delete s_pMetaObject;
+ s_pMetaObject = 0;
+ }
+ Base::cleanUp( );
+}
+
+PMDialogEditBase* PMPolynom::editWidget( QWidget* parent ) const
+{
+ return new PMPolynomEdit( parent );
+}
+
+void PMPolynom::setPolynomOrder( int o )
+{
+ if( ( o < 2 ) || ( o > 7 ) )
+ {
+ kdError( PMArea ) << "Invalid order in PMPolynom::setPolynomOrder\n";
+ o = 2;
+ }
+ if( o != m_order )
+ {
+ if( m_pMemento )
+ {
+ m_pMemento->addData( s_pMetaObject, PMOrderID, m_order );
+ if( ( o <= 4 ) || ( m_order <= 4 ) )
+ m_pMemento->setDescriptionChanged( );
+ }
+ m_order = o;
+ }
+}
+
+void PMPolynom::setCoefficients( const PMVector& c )
+{
+ if( c.size( ) != ( unsigned ) c_polynomSize[m_order] )
+ kdError( PMArea ) << "Wrong vector size in PMPolynom::setCoefficients\n";
+
+ if( c != m_coefficients )
+ {
+ if( m_pMemento )
+ m_pMemento->addData( s_pMetaObject, PMCoefficientsID, m_coefficients );
+ m_coefficients = c;
+ m_coefficients.resize( c_polynomSize[m_order] );
+ //setViewStructureChanged( );
+ }
+}
+
+void PMPolynom::setSturm( bool s )
+{
+ if( m_sturm != s )
+ {
+ if( m_pMemento )
+ m_pMemento->addData( s_pMetaObject, PMSturmID, m_sturm );
+ m_sturm = s;
+ }
+}
+
+void PMPolynom::restoreMemento( PMMemento* s )
+{
+ PMMementoDataIterator it( s );
+ PMMementoData* data;
+
+ for( ; it.current( ); ++it )
+ {
+ data = it.current( );
+ if( data->objectType( ) == s_pMetaObject )
+ {
+ switch( data->valueID( ) )
+ {
+ case PMOrderID:
+ setPolynomOrder( data->intData( ) );
+ break;
+ case PMCoefficientsID:
+ setCoefficients( data->vectorData( ) );
+ break;
+ case PMSturmID:
+ setSturm( data->boolData( ) );
+ break;
+ default:
+ kdError( PMArea ) << "Wrong ID in PMPolynom::restoreMemento\n";
+ break;
+ }
+ }
+ }
+ Base::restoreMemento( s );
+}