// @(#)root/quadp:$Name:  $:$Id: TQpDataSparse.cxx,v 1.4 2004/06/09 12:23:16 brun Exp $
// Author: Eddy Offermann   May 2004

/*************************************************************************
 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

/*************************************************************************
 * Parts of this file are copied from the OOQP distribution and          *
 * are subject to the following license:                                 *
 *                                                                       *
 * COPYRIGHT 2001 UNIVERSITY OF CHICAGO                                  *
 *                                                                       *
 * The copyright holder hereby grants you royalty-free rights to use,    *
 * reproduce, prepare derivative works, and to redistribute this software*
 * to others, provided that any changes are clearly documented. This     *
 * software was authored by:                                             *
 *                                                                       *
 *   E. MICHAEL GERTZ      gertz@mcs.anl.gov                             *
 *   Mathematics and Computer Science Division                           *
 *   Argonne National Laboratory                                         *
 *   9700 S. Cass Avenue                                                 *
 *   Argonne, IL 60439-4844                                              *
 *                                                                       *
 *   STEPHEN J. WRIGHT     swright@cs.wisc.edu                           *
 *   Computer Sciences Department                                        *
 *   University of Wisconsin                                             *
 *   1210 West Dayton Street                                             *
 *   Madison, WI 53706   FAX: (608)262-9777                              *
 *                                                                       *
 * Any questions or comments may be directed to one of the authors.      *
 *                                                                       *
 * ARGONNE NATIONAL LABORATORY (ANL), WITH FACILITIES IN THE STATES OF   *
 * ILLINOIS AND IDAHO, IS OWNED BY THE UNITED STATES GOVERNMENT, AND     *
 * OPERATED BY THE UNIVERSITY OF CHICAGO UNDER PROVISION OF A CONTRACT   *
 * WITH THE DEPARTMENT OF ENERGY.                                        *
 *************************************************************************/

#include "Riostream.h"
#include "TQpDataSparse.h"

//////////////////////////////////////////////////////////////////////////
//                                                                      //
// TQpDataSparse                                                        //
//                                                                      //
// Data for the sparse QP formulation                                   //
//                                                                      //
//////////////////////////////////////////////////////////////////////////

ClassImp(TQpDataSparse)

//______________________________________________________________________________
 TQpDataSparse::TQpDataSparse(Int_t nx,Int_t my,Int_t mz)
  : TQpDataBase(nx,my,mz)
{
  fQ.ResizeTo(fNx,fNx);
  fA.ResizeTo(fMy,fNx);
  fC.ResizeTo(fMz,fNx);
}

//______________________________________________________________________________
 TQpDataSparse::TQpDataSparse(TVectorD       &c_in,   TMatrixDSparse &Q_in,
                             TVectorD       &xlow_in,TVectorD       &ixlow_in,
                             TVectorD       &xupp_in,TVectorD       &ixupp_in,
                             TMatrixDSparse &A_in,   TVectorD       &bA_in,
                             TMatrixDSparse &C_in,
                             TVectorD       &clow_in,TVectorD       &iclow_in,
                             TVectorD       &cupp_in,TVectorD       &icupp_in)
{
  fG       .ResizeTo(c_in)    ; fG        = c_in;
  fBa      .ResizeTo(bA_in)   ; fBa       = bA_in;
  fXloBound.ResizeTo(xlow_in) ; fXloBound = xlow_in;
  fXloIndex.ResizeTo(ixlow_in); fXloIndex = ixlow_in;
  fXupBound.ResizeTo(xupp_in) ; fXupBound = xupp_in;
  fXupIndex.ResizeTo(ixupp_in); fXupIndex = ixupp_in;
  fCloBound.ResizeTo(clow_in) ; fCloBound = clow_in;
  fCloIndex.ResizeTo(iclow_in); fCloIndex = iclow_in;
  fCupBound.ResizeTo(cupp_in) ; fCupBound = cupp_in;
  fCupIndex.ResizeTo(icupp_in); fCupIndex = icupp_in;

  fNx = fG.GetNrows();
  fQ.Use(Q_in);

  if (A_in.GetNrows() > 0) {
    fA.Use(A_in);
    fMy = fA.GetNrows();
  } else
    fMy = 0;

  if (C_in.GetNrows()) {
    fC.Use(C_in);
    fMz = fC.GetNrows();
  } else
    fMz = 0;
  fQ.Print();
  fA.Print();
  fC.Print();
  printf("fNx: %dn",fNx);
  printf("fMy: %dn",fMy);
  printf("fMz: %dn",fMz);
}

//______________________________________________________________________________
 TQpDataSparse::TQpDataSparse(const TQpDataSparse &another) : TQpDataBase(another)
{
  *this = another;
} 

//______________________________________________________________________________
 void TQpDataSparse::SetNonZeros(Int_t nnzQ,Int_t nnzA,Int_t nnzC)
{
  fQ.SetSparseIndex(nnzQ);
  fA.SetSparseIndex(nnzA);
  fC.SetSparseIndex(nnzC);
}

//______________________________________________________________________________
 void TQpDataSparse::Qmult(Double_t beta,TVectorD &y,Double_t alpha,const TVectorD &x )
{
  y *= beta;
  if (fQ.GetNoElements() > 0)
    y += alpha*(fQ*x);
}

//______________________________________________________________________________
 void TQpDataSparse::Amult(Double_t beta,TVectorD &y,Double_t alpha,const TVectorD &x)
{ 
  y *= beta;
  if (fA.GetNoElements() > 0)
    y += alpha*(fA*x);
}

//______________________________________________________________________________
 void TQpDataSparse::Cmult(Double_t beta,TVectorD &y,Double_t alpha,const TVectorD &x)
{ 
  y *= beta;
  if (fC.GetNoElements() > 0)
    y += alpha*(fC*x);
}

//______________________________________________________________________________
 void TQpDataSparse::ATransmult(Double_t beta,TVectorD &y,Double_t alpha,const TVectorD &x)
{ 
  y *= beta;
  if (fA.GetNoElements() > 0)
    y += alpha*(TMatrixDSparse(TMatrixDSparse::kTransposed,fA)*x);
}

//______________________________________________________________________________
 void TQpDataSparse::CTransmult(Double_t beta,TVectorD &y,Double_t alpha,const TVectorD &x)
{ 
  y *= beta;
  if (fC.GetNoElements() > 0)
    y += alpha*(TMatrixDSparse(TMatrixDSparse::kTransposed,fC)*x);
}

//______________________________________________________________________________
 Double_t TQpDataSparse::DataNorm()
{
  Double_t norm = 0.0;

  Double_t componentNorm = fG.NormInf();
  if (componentNorm > norm) norm = componentNorm;

  TMatrixDSparse fQ_abs(fQ);
  componentNorm = (fQ_abs.Abs()).Max();
  if (componentNorm > norm) norm = componentNorm;
 
  componentNorm = fBa.NormInf();
  if (componentNorm > norm) norm = componentNorm;

  TMatrixDSparse fA_abs(fQ);
  componentNorm = (fA_abs.Abs()).Max();
  if (componentNorm > norm) norm = componentNorm;

  TMatrixDSparse fC_abs(fQ);
  componentNorm = (fC_abs.Abs()).Max();
  if (componentNorm > norm) norm = componentNorm;

  Assert(fXloBound.MatchesNonZeroPattern(fXloIndex));
  componentNorm = fXloBound.NormInf();
  if (componentNorm > norm) norm = componentNorm;

  Assert(fXupBound.MatchesNonZeroPattern(fXupIndex));
  componentNorm = fXupBound.NormInf();
  if (componentNorm > norm) norm = componentNorm;

  Assert(fCloBound.MatchesNonZeroPattern(fCloIndex));
  componentNorm = fCloBound.NormInf();
  if (componentNorm > norm) norm = componentNorm;

  Assert(fCupBound.MatchesNonZeroPattern(fCupIndex));
  componentNorm = fCupBound.NormInf();
  if (componentNorm > norm) norm = componentNorm;

  return norm;
}

//______________________________________________________________________________
 void TQpDataSparse::Print(Option_t * /*opt*/) const
{
  fQ.Print("Q");
  fG.Print("c");

  fXloBound.Print("xlow");
  fXloIndex.Print("ixlow");

  fXupBound.Print("xupp");
  fXupIndex.Print("ixupp");

  fA.Print("A");
  fBa.Print("b");
  fC.Print("C");

  fCloBound.Print("clow");
  fCloIndex.Print("iclow");

  fCupBound.Print("cupp");
  fCupIndex.Print("icupp");
}

//______________________________________________________________________________
 void TQpDataSparse::PutQIntoAt(TMatrixDBase &m,Int_t row,Int_t col)
{
  m.SetSub(row,col,fQ);
}

//______________________________________________________________________________
 void TQpDataSparse::PutAIntoAt(TMatrixDBase &m,Int_t row,Int_t col)
{
  m.SetSub(row,col,fA);
}

//______________________________________________________________________________
 void TQpDataSparse::PutCIntoAt(TMatrixDBase &m,Int_t row,Int_t col)
{
  m.SetSub(row,col,fC);
}

//______________________________________________________________________________
 void TQpDataSparse::GetDiagonalOfQ(TVectorD &dq)
{
  const Int_t n = TMath::Min(fQ.GetNrows(),fQ.GetNcols());
  dq.ResizeTo(n);
  dq = TMatrixDSparseDiag(fQ);
}

//______________________________________________________________________________
 Double_t TQpDataSparse::ObjectiveValue(TQpVar *vars)
{
  TVectorD tmp(fG);
  this->Qmult(1.0,tmp,0.5,vars->fX);

  return tmp*vars->fX;
}

//______________________________________________________________________________
 void TQpDataSparse::DataRandom(TVectorD &x,TVectorD &y,TVectorD &z,TVectorD &s)
{
  Double_t ix = 3074.20374;

  TVectorD xdual(fNx);
  this->RandomlyChooseBoundedVariables(x,xdual,fXloBound,fXloIndex,fXupBound,fXupIndex,ix,.25,.25,.25);

  TVectorD sprime(fMz);
  this->RandomlyChooseBoundedVariables(sprime,z,fCloBound,fCloIndex,fCupBound,fCupIndex,ix,.25,.25,.5);

  fQ.RandomizePD(0.0,1.0,ix);
  fA.Randomize(-10.0,10.0,ix);
  fC.Randomize(-10.0,10.0,ix);
  y .Randomize(-10.0,10.0,ix);

  // fG = - fQ x + A^T y + C^T z + xdual

  fG = xdual;
  fG -= fQ*x;

  fG += TMatrixDSparse(TMatrixDSparse::kTransposed,fA)*y;
  fG += TMatrixDSparse(TMatrixDSparse::kTransposed,fC)*z;

  fBa = fA*x;
  s   = fC*x;

  // Now compute the real q = s-sprime
  const TVectorD q = s-sprime;

  // Adjust fCloBound and fCupBound appropriately
  Add(fCloBound,1.0,q);
  Add(fCupBound,1.0,q);

  fCloBound.SelectNonZeros(fCloIndex);
  fCupBound.SelectNonZeros(fCupIndex);
}

//______________________________________________________________________________
TQpDataSparse &TQpDataSparse::operator=(const TQpDataSparse &source)
{                                                                        
  if (this != &source) {
    TQpDataBase::operator=(source);                                      
    fQ.ResizeTo(source.fQ); fQ = source.fQ;
    fA.ResizeTo(source.fA); fA = source.fA;
    fC.ResizeTo(source.fC); fC = source.fC;
  }
  return *this;
}


ROOT page - Class index - Class Hierarchy - Top of the page

This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.