00001
00002
00003
00004
00005
00006 #include <math.h>
00007 #include "Blinn.h"
00008
00009 REGISTER_IMPLICIT(Blinn,"UnaryOp:Blob:Blinn");
00010
00011
00012
00013
00014
00015 void Blinn::init(Quadric *f, double b, double r)
00016 {
00017 m_f = f;
00018 m_r = r;
00019 m_b = b;
00020 }
00021
00022
00023 Blinn::Blinn()
00024 {
00025 init(NULL,1.0,1.0);
00026 }
00027
00028
00029
00030
00031
00032
00033
00034 Blinn::Blinn(Quadric *f)
00035 {
00036 init(f,1.0,1.0);
00037 }
00038
00039
00040
00041
00042
00043
00044
00045 Blinn::Blinn(Quadric *f, double b)
00046 {
00047 init(f,b,1.0);
00048 }
00049
00050
00051
00052
00053
00054
00055
00056 Blinn::Blinn(Quadric *f, double b, double r)
00057 {
00058 init(f,b,r);
00059 }
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070 double Blinn::kernel(double r2)
00071 {
00072 double blob;
00073
00074
00075 blob = exp ((-1.0f * (m_b / (m_r * m_r)) * r2 + m_b));
00076
00077 return blob;
00078 }
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090 double Blinn::dkernel(double r2)
00091 {
00092 double c = -1.0f * m_b / (m_r * m_r);
00093 return c * kernel(r2);
00094 }
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104 double Blinn::d2kernel(double r2)
00105 {
00106 double c = -1.0f * m_b / (m_r * m_r);
00107 return c * dkernel(r2);
00108 }
00109
00110 Intervald Blinn::kernel(Intervald r2)
00111 {
00112 Intervald blob;
00113
00114 blob = Intervald(-1.0) * Intervald(m_b / (m_r * m_r)) * r2 + Intervald(m_b);
00115 return blob.exp();
00116 }
00117
00118 Intervald Blinn::dkernel(Intervald r2)
00119 {
00120 double c = -1.0f * m_b / (m_r * m_r);
00121 return kernel(r2) * Intervald(c);
00122 }
00123
00124 Intervald Blinn::d2kernel(Intervald r2)
00125 {
00126 double c = -1.0f * m_b / (m_r * m_r);
00127 return dkernel(r2) * Intervald(c);
00128 }
00129
00130
00131
00132
00133
00134 int Blinn::qlen(void)
00135 {
00136
00137
00138
00139 int retval = 2;
00140 if (m_f)
00141 retval += m_f->qlen();
00142 return retval;
00143 }
00144
00145
00146
00147
00148
00149
00150
00151 void Blinn::_setq(double *q)
00152 {
00153 m_r = q[0];
00154 m_b = q[1];
00155
00156 if (m_f == NULL)
00157 return;
00158
00159 double *m_fq = new double[m_f->qlen()];
00160
00161
00162
00163 for (int i = 2; i < qlen (); i++)
00164 m_fq[i - 2] = q[i];
00165
00166 m_f->_setq(m_fq);
00167
00168 delete[] m_fq;
00169 }
00170
00171
00172
00173
00174
00175
00176
00177
00178
00179 void Blinn::getq(double *q)
00180 {
00181 q[0] = m_r;
00182 q[1] = m_b;
00183
00184 if (m_f == NULL)
00185 return;
00186
00187 double *m_fq = new double[m_f->qlen()];
00188 m_f->getq(m_fq);
00189
00190
00191
00192 for (int i = 2; i < qlen (); i++)
00193 q[i] = m_fq[i - 2];
00194
00195 delete[] m_fq;
00196 }
00197
00198
00199
00200
00201
00202
00203
00204
00205
00206 void Blinn::getqname(char** qn)
00207 {
00208 qn[0] = "Rest radius R";
00209 qn[1] = "Blobbiness B";
00210
00211 if (m_f != NULL)
00212 {
00213 char **m_fqname = new char*[m_f->qlen()];
00214 m_f->getqname(m_fqname);
00215
00216 for (int i = 2; i < qlen (); i++)
00217 qn[i] = m_fqname[i - 2];
00218
00219 delete[] m_fqname;
00220 }
00221 }
00222
00223
00224
00225
00226
00227
00228
00229
00230
00231
00232
00233
00234 void Blinn::procq(gmVector3 x, double* dfdq)
00235 {
00236
00237 if (m_f != NULL)
00238 {
00239 double R2 = m_r * m_r;
00240 double r2 = m_f->proc(x);
00241 double blob = m_f->proc(x);
00242
00243 dfdq[0] = blob * (( 2.0f * r2 * m_b) / (R2 * m_r));
00244 dfdq[1] = blob * ((-1.0f * r2) / R2+ 1.0f);
00245
00246 double *m_fdfdq = new double[m_f->qlen ()];
00247 m_f->procq (x, m_fdfdq);
00248
00249 for (int i = 2; i < qlen (); i++)
00250 dfdq[i] = blob * ((-1.0f * m_fdfdq[i - 2] * m_b) / R2);
00251
00252 delete[] m_fdfdq;
00253 }
00254 }
00255