PIPS
scalaires.c
Go to the documentation of this file.
1 /*
2 
3  $Id: scalaires.c 1641 2016-03-02 08:20:19Z coelho $
4 
5  Copyright 1989-2016 MINES ParisTech
6 
7  This file is part of Linear/C3 Library.
8 
9  Linear/C3 Library is free software: you can redistribute it and/or modify it
10  under the terms of the GNU Lesser General Public License as published by
11  the Free Software Foundation, either version 3 of the License, or
12  any later version.
13 
14  Linear/C3 Library is distributed in the hope that it will be useful, but WITHOUT ANY
15  WARRANTY; without even the implied warranty of MERCHANTABILITY or
16  FITNESS FOR A PARTICULAR PURPOSE.
17 
18  See the GNU Lesser General Public License for more details.
19 
20  You should have received a copy of the GNU Lesser General Public License
21  along with Linear/C3 Library. If not, see <http://www.gnu.org/licenses/>.
22 
23 */
24 
25 /* package vecteur - operations vecteur x scalaire */
26 
27 /*LINTLIBRARY*/
28 
29 #ifdef HAVE_CONFIG_H
30  #include "config.h"
31 #endif
32 #include <stdio.h>
33 #include <stdlib.h>
34 
35 #include "boolean.h"
36 #include "arithmetique.h"
37 #include "vecteur.h"
38 
39 #define FREE(p,t,f) free(p)
40 
41 /* Pvecteur vect_div(Pvecteur v, Value x): division du vecteur v
42  * par le scalaire x, si x est different de 0.
43  *
44  * -> ->
45  * v := v / x;
46  * -> ->
47  * Si x vaut 0, la procedure aborte meme si v == 0
48  * ->
49  * Attention, si x ne divise pas le pgcd des coefficients de v, la valeur
50  * retournee n'est pas colineaire a la valeur initiale
51  */
53 Pvecteur v;
54 Value x;
55 {
56  if(value_zero_p(x)) {
57  vect_error("vect_div","vector zero divide\n");
58  }
59  else if (value_one_p(x))
60  ;
61  else if(value_mone_p(x))
62  vect_chg_sgn(v);
63  else {
64  Pvecteur coord;
65 
66  for (coord = v ;coord!=NULL;coord=coord->succ) {
67  value_pdivision(val_of(coord),x);
68  }
69  }
70  return vect_clean(v);
71 }
72 
73 /* Pvecteur vect_clean(Pvecteur v): elimination de tous les couples dont le
74  * coefficient vaut 0 dans le vecteur v et renvoie de v
75  *
76  * Ne devrait JAMAIS etre utilise en dehors de la bibliotheque vecteur. Ne sert
77  * qu'a corriger le resultat de vect_div quand la division entiere fait apparaitre
78  * un 0. Dans ces cas, vect_div n'est pas lineaire.
79  */
81 Pvecteur v;
82 {
83  Pvecteur v1,v2;
84  Pvecteur pred = v;
85  Pvecteur result=v;
86 
87  for (v1 = v; ((v1!= NULL) && (v1->val != 0)); pred = v1,v1=v1->succ);
88 
89  for (v2 = v1;v2 != NULL; v2 = v2->succ)
90  {
91  if (v2->val == 0)
92  {
93  if (v2 == v)
94  {
95  result = v2->succ;
96  pred = v;
97 
98  }
99  else {
100  pred->succ = v2->succ;
101  v2->succ = NULL;
102  FREE((char*)v2,VECTEUR,"vect_clean");
103  v2 = pred;
104  }
105  }
106  else
107  pred = v2;
108 
109  }
110  return (result);
111 }
112 
113 /* Pvecteur vect_multiply(Pvecteur v, Value x): multiplication du vecteur v
114  * par le scalaire x, si x est different de 0.
115  *
116  * -> ->
117  * v := x v;
118  *
119  * Ancien nom: vect_mult()
120  * Ancien profil: void vect_mult(); ne permettait pas de renvoyer un vecteur
121  * nul en cas de multiplication par zero d'un vecteur non nul
122  */
124 Pvecteur v;
125 Value x;
126 {
127  Pvecteur coord;
128 
129  if (value_zero_p(x))
130  {
131  vect_rm(v);
132  return VECTEUR_NUL;
133  }
134  else if (value_one_p(x))
135  return v;
136  else if (value_mone_p(x))
137  vect_chg_sgn(v);
138  else
139  for(coord = v; coord!=NULL; coord=coord->succ)
140  value_product(val_of(coord), x);
141 
142  return v;
143 }
144 
145 /* void vect_chg_sgn(Pvecteur v): multiplie v par -1
146  *
147  * -> ->
148  * v := - v
149  *
150  */
152 Pvecteur v;
153 {
154  for( ;v != NULL; v = v->succ)
155  value_oppose(val_of(v));
156 }
#define value_mone_p(val)
#define value_oppose(ref)
#define value_one_p(val)
#define value_zero_p(val)
int Value
#define value_product(v, w)
#define value_pdivision(ref, val)
Pvecteur vect_clean(Pvecteur v)
Pvecteur vect_clean(Pvecteur v): elimination de tous les couples dont le coefficient vaut 0 dans le v...
Definition: scalaires.c:80
#define FREE(p, t, f)
package vecteur - operations vecteur x scalaire
Definition: scalaires.c:39
void vect_chg_sgn(Pvecteur v)
void vect_chg_sgn(Pvecteur v): multiplie v par -1
Definition: scalaires.c:151
Pvecteur vect_div(Pvecteur v, Value x)
Pvecteur vect_div(Pvecteur v, Value x): division du vecteur v par le scalaire x, si x est different d...
Definition: scalaires.c:52
Pvecteur vect_multiply(Pvecteur v, Value x)
Pvecteur vect_multiply(Pvecteur v, Value x): multiplication du vecteur v par le scalaire x,...
Definition: scalaires.c:123
static char * x
Definition: split_file.c:159
le type des coefficients dans les vecteurs: Value est defini dans le package arithmetique
Definition: vecteur-local.h:89
Value val
Definition: vecteur-local.h:91
struct Svecteur * succ
Definition: vecteur-local.h:92
#define val_of(varval)
#define VECTEUR_NUL
DEFINITION DU VECTEUR NUL.
#define VECTEUR
package sur les vecteurs creux et les bases
Definition: vecteur-local.h:51
void vect_rm(Pvecteur v)
void vect_rm(Pvecteur v): desallocation des couples de v;
Definition: alloc.c:78
void vect_error(char *name, char *fmt,...)
package vecteur
Definition: error.c:50