00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00107
00108
00109
00110
00111
00112 #include <lal/LALHough.h>
00113
00114 NRCSID (DRIVEHOUGHC, "$Id: DriveHough.c,v 1.19 2007/11/14 15:49:54 bema Exp $");
00115
00116 #define rint(x) floor((x)+0.5)
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131
00132 void LALHOUGHConstructSpacePHMD (LALStatus *status,
00133 PHMDVectorSequence *phmdVS,
00134 HOUGHPeakGramVector *pgV,
00135 HOUGHptfLUTVector *lutV )
00136 {
00137
00138 UINT4 k,j;
00139 UINT4 nfSize;
00140 UINT4 length;
00141 UINT8 fBinMin;
00142 UINT8 fBin;
00143 REAL8 deltaF;
00144
00145
00146
00147 INITSTATUS (status, "LALHOUGHConstructSpacePHMD", DRIVEHOUGHC);
00148 ATTATCHSTATUSPTR (status);
00149
00150
00151
00152 ASSERT (phmdVS, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00153 ASSERT (pgV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00154 ASSERT (lutV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00155
00156
00157 ASSERT (phmdVS->phmd, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00158 ASSERT (pgV->pg, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00159 ASSERT (lutV->lut, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00160
00161
00162
00163 ASSERT (pgV->length == lutV->length, status,
00164 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00165 ASSERT (pgV->length == phmdVS->length, status,
00166 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00167
00168
00169
00170 ASSERT (phmdVS->length, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00171 ASSERT (phmdVS->nfSize, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00172
00173
00174 phmdVS->breakLine = 0;
00175
00176
00177 length = phmdVS->length;
00178 nfSize = phmdVS->nfSize;
00179 fBinMin = phmdVS->fBinMin;
00180 deltaF = phmdVS->deltaF = lutV->lut[0].deltaF;
00181
00182
00183 for ( k=0; k<length; ++k ){
00184
00185
00186 ASSERT (deltaF == lutV->lut[k].deltaF,
00187 status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00188
00189 fBin = fBinMin;
00190
00191 for ( j=0; j< nfSize; ++j ){
00192 phmdVS->phmd[ j*length+k ].fBin = fBin;
00193
00194 TRY( LALHOUGHPeak2PHMD(status->statusPtr,
00195 &(phmdVS->phmd[ j*length+k ]),
00196 &(lutV->lut[k]), &(pgV->pg[k]) ), status);
00197 ++fBin;
00198 }
00199 }
00200
00201
00202 DETATCHSTATUSPTR (status);
00203
00204 RETURN (status);
00205 }
00206
00207
00208
00209
00210
00211
00212 void LALHOUGHupdateSpacePHMDup (LALStatus *status,
00213 PHMDVectorSequence *phmdVS,
00214 HOUGHPeakGramVector *pgV,
00215 HOUGHptfLUTVector *lutV)
00216 {
00217 UINT4 k,breakLine;
00218 UINT4 nfSize;
00219 UINT4 length;
00220 UINT8 fBinMin;
00221 UINT8 fBin;
00222 REAL8 deltaF;
00223
00224
00225
00226 INITSTATUS (status, "LALHOUGHupdateSpacePHMDup", DRIVEHOUGHC);
00227 ATTATCHSTATUSPTR (status);
00228
00229
00230
00231 ASSERT (phmdVS, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00232 ASSERT (pgV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00233 ASSERT (lutV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00234
00235
00236 ASSERT (phmdVS->phmd, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00237 ASSERT (pgV->pg, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00238 ASSERT (lutV->lut, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00239
00240
00241
00242 ASSERT (pgV->length == lutV->length, status,
00243 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00244 ASSERT (pgV->length == phmdVS->length, status,
00245 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00246
00247
00248
00249 ASSERT (phmdVS->length, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00250 ASSERT (phmdVS->nfSize, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00251
00252
00253
00254 length = phmdVS->length;
00255 nfSize = phmdVS->nfSize;
00256 deltaF = phmdVS->deltaF;
00257
00258 breakLine = phmdVS->breakLine;
00259 fBinMin = phmdVS->fBinMin;
00260
00261
00262 ASSERT ( breakLine < nfSize, status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00263
00264
00265
00266
00267
00268 fBin = fBinMin + nfSize;
00269
00270 for ( k=0; k<length; ++k ){
00271
00272 ASSERT (deltaF == lutV->lut[k].deltaF,
00273 status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00274
00275 phmdVS->phmd[ breakLine*length+k ].fBin = fBin;
00276 TRY( LALHOUGHPeak2PHMD(status->statusPtr,
00277 &(phmdVS->phmd[ breakLine*length+k ]),
00278 &(lutV->lut[k]), &(pgV->pg[k]) ), status);
00279 }
00280
00281
00282 ++phmdVS->fBinMin;
00283
00284 phmdVS->breakLine = (breakLine +1) % nfSize;
00285
00286
00287
00288 DETATCHSTATUSPTR (status);
00289
00290 RETURN (status);
00291 }
00292
00293
00294
00295
00296
00297
00298 void LALHOUGHupdateSpacePHMDdn (LALStatus *status,
00299 PHMDVectorSequence *phmdVS,
00300 HOUGHPeakGramVector *pgV,
00301 HOUGHptfLUTVector *lutV)
00302 {
00303 UINT4 k,breakLine;
00304 UINT4 nfSize;
00305 UINT4 length;
00306
00307 UINT8 fBin;
00308 REAL8 deltaF;
00309
00310
00311
00312 INITSTATUS (status, "LALHOUGHupdateSpacePHMDdn", DRIVEHOUGHC);
00313 ATTATCHSTATUSPTR (status);
00314
00315
00316
00317 ASSERT (phmdVS, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00318 ASSERT (pgV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00319 ASSERT (lutV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00320
00321
00322 ASSERT (phmdVS->phmd, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00323 ASSERT (pgV->pg, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00324 ASSERT (lutV->lut, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00325
00326
00327
00328 ASSERT (pgV->length == lutV->length, status,
00329 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00330 ASSERT (pgV->length == phmdVS->length, status,
00331 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00332
00333
00334
00335 ASSERT (phmdVS->length, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00336 ASSERT (phmdVS->nfSize, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00337
00338
00339 length = phmdVS->length;
00340 nfSize = phmdVS->nfSize;
00341 deltaF = phmdVS->deltaF;
00342
00343 breakLine = phmdVS->breakLine;
00344
00345
00346 ASSERT ( breakLine < nfSize, status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00347
00348
00349
00350
00351
00352
00353 fBin = --phmdVS->fBinMin;
00354
00355 phmdVS->breakLine = (breakLine + nfSize- 1) % nfSize;
00356
00357
00358
00359 breakLine = phmdVS->breakLine;
00360
00361 for ( k=0; k<length; ++k ){
00362
00363 ASSERT (deltaF == lutV->lut[k].deltaF,
00364 status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00365
00366 phmdVS->phmd[ breakLine*length+k ].fBin = fBin;
00367 TRY( LALHOUGHPeak2PHMD(status->statusPtr,
00368 &(phmdVS->phmd[ breakLine*length+k ]),
00369 &(lutV->lut[k]), &(pgV->pg[k]) ), status);
00370 }
00371
00372
00373
00374 DETATCHSTATUSPTR (status);
00375
00376 RETURN (status);
00377 }
00378
00379
00380
00381
00382
00383
00384
00385 void LALHOUGHConstructHMT (LALStatus *status,
00386 HOUGHMapTotal *ht,
00387 UINT8FrequencyIndexVector *freqInd,
00388 PHMDVectorSequence *phmdVS )
00389 {
00390
00391
00392 UINT4 k,j;
00393 UINT4 breakLine;
00394 UINT4 nfSize;
00395 UINT4 length;
00396 UINT8 fBinMin;
00397 INT8 fBin;
00398 UINT2 xSide,ySide;
00399
00400 HOUGHMapDeriv hd;
00401
00402
00403 INITSTATUS (status, "LALHOUGHConstructHMT", DRIVEHOUGHC);
00404 ATTATCHSTATUSPTR (status);
00405
00406
00407 ASSERT (phmdVS, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00408 ASSERT (ht, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00409 ASSERT (freqInd, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00410
00411
00412 ASSERT (phmdVS->phmd, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00413 ASSERT (freqInd->data, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00414
00415
00416
00417 ASSERT (freqInd->length == phmdVS->length, status,
00418 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00419 ASSERT (freqInd->deltaF == phmdVS->deltaF, status,
00420 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00421
00422
00423
00424 ASSERT (phmdVS->length, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00425 ASSERT (phmdVS->nfSize, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00426
00427
00428
00429 ASSERT (ht->xSide, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00430 ASSERT (ht->ySide, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00431
00432 length = phmdVS->length;
00433 nfSize = phmdVS->nfSize;
00434
00435 fBinMin = phmdVS->fBinMin;
00436
00437 breakLine = phmdVS->breakLine;
00438
00439
00440 xSide = ht->xSide;
00441 ySide = ht->ySide;
00442
00443
00444 ASSERT ( breakLine < nfSize, status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00445
00446
00447
00448
00449 hd.xSide = xSide;
00450 hd.ySide = ySide;
00451 hd.map = (HoughDT *)LALMalloc(ySide*(xSide+1)*sizeof(HoughDT));
00452 if (hd. map == NULL) {
00453 ABORT( status, LALHOUGHH_EMEM, LALHOUGHH_MSGEMEM);
00454 }
00455
00456
00457
00458 TRY( LALHOUGHInitializeHD(status->statusPtr, &hd), status);
00459 for ( k=0; k<length; ++k ){
00460
00461 fBin =freqInd->data[k] -fBinMin;
00462
00463 ASSERT ( fBin < nfSize, status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00464 ASSERT ( fBin >= 0, status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00465
00466
00467 j = (fBin + breakLine) % nfSize;
00468
00469
00470 TRY( LALHOUGHAddPHMD2HD(status->statusPtr,
00471 &hd, &(phmdVS->phmd[j*length+k]) ), status);
00472 }
00473
00474 TRY( LALHOUGHIntegrHD2HT(status->statusPtr, ht, &hd), status);
00475
00476
00477 LALFree(hd.map);
00478
00479 DETATCHSTATUSPTR (status);
00480
00481 RETURN (status);
00482 }
00483
00484
00485
00486
00487 void LALHOUGHComputeFBinMap (LALStatus *status,
00488 UINT8 *fBinMap,
00489 UINT8 *f0Bin,
00490 HOUGHResidualSpinPar *rs)
00491 {
00492
00493 UINT4 i;
00494 INT4 shiftFBin;
00495 REAL8 shiftF;
00496
00497 UINT4 spinOrder;
00498 REAL8 *spinF;
00499 REAL8 timeDiff;
00500 REAL8 timeDiffProd;
00501 REAL8 deltaF;
00502
00503 INITSTATUS (status, "LALHOUGHComputeFBinMap", DRIVEHOUGHC);
00504 ATTATCHSTATUSPTR (status);
00505
00506
00507 ASSERT (fBinMap, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00508 ASSERT (f0Bin, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00509 ASSERT (rs, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00510
00511
00512
00513 ASSERT (fBinMap != f0Bin, status, LALHOUGHH_ESAME, LALHOUGHH_MSGESAME);
00514
00515 shiftFBin = 0;
00516 shiftF = 0.0;
00517
00518 spinOrder = rs->spinRes.length;
00519
00520 if(spinOrder){
00521 ASSERT (rs->spinRes.data , status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00522 timeDiff = rs->timeDiff;
00523 timeDiffProd = timeDiff;
00524
00525 deltaF = rs->deltaF;
00526 spinF = rs->spinRes.data;
00527
00528 for (i=0; i<spinOrder; ++i ){
00529 shiftF += spinF[i] * timeDiffProd;
00530 timeDiffProd *= timeDiff;
00531 }
00532 shiftFBin = rint( shiftF/deltaF) ;
00533 }
00534
00535 *fBinMap = *f0Bin + shiftFBin;
00536
00537 DETATCHSTATUSPTR (status);
00538
00539 RETURN (status);
00540 }
00541
00542
00543
00544
00545
00546
00547
00548
00549
00550
00551 void LALHOUGHConstructHMT_W (LALStatus *status,
00552 HOUGHMapTotal *ht,
00553 UINT8FrequencyIndexVector *freqInd,
00554 PHMDVectorSequence *phmdVS )
00555 {
00556
00557
00558 UINT4 k,j;
00559 UINT4 breakLine;
00560 UINT4 nfSize;
00561 UINT4 length;
00562 UINT8 fBinMin;
00563 INT8 fBin;
00564 UINT2 xSide,ySide;
00565
00566 HOUGHMapDeriv hd;
00567
00568
00569 INITSTATUS (status, "LALHOUGHConstructHMT_W", DRIVEHOUGHC);
00570 ATTATCHSTATUSPTR (status);
00571
00572
00573 ASSERT (phmdVS, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00574 ASSERT (ht, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00575 ASSERT (freqInd, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00576
00577
00578 ASSERT (phmdVS->phmd, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00579 ASSERT (freqInd->data, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00580
00581
00582
00583 ASSERT (freqInd->length == phmdVS->length, status,
00584 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00585 ASSERT (freqInd->deltaF == phmdVS->deltaF, status,
00586 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00587
00588
00589
00590 ASSERT (phmdVS->length, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00591 ASSERT (phmdVS->nfSize, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00592
00593
00594
00595 ASSERT (ht->xSide, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00596 ASSERT (ht->ySide, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00597
00598 length = phmdVS->length;
00599 nfSize = phmdVS->nfSize;
00600
00601 fBinMin = phmdVS->fBinMin;
00602
00603 breakLine = phmdVS->breakLine;
00604
00605
00606 xSide = ht->xSide;
00607 ySide = ht->ySide;
00608
00609
00610 ASSERT ( breakLine < nfSize, status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00611
00612
00613
00614
00615 hd.xSide = xSide;
00616 hd.ySide = ySide;
00617 hd.map = (HoughDT *)LALMalloc(ySide*(xSide+1)*sizeof(HoughDT));
00618 if (hd. map == NULL) {
00619 ABORT( status, LALHOUGHH_EMEM, LALHOUGHH_MSGEMEM);
00620 }
00621
00622
00623
00624 TRY( LALHOUGHInitializeHD(status->statusPtr, &hd), status);
00625 for ( k=0; k<length; ++k ){
00626
00627 fBin =freqInd->data[k] -fBinMin;
00628
00629 ASSERT ( fBin < nfSize, status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00630 ASSERT ( fBin >= 0, status, LALHOUGHH_EVAL, LALHOUGHH_MSGEVAL);
00631
00632
00633 j = (fBin + breakLine) % nfSize;
00634
00635
00636 TRY( LALHOUGHAddPHMD2HD_W(status->statusPtr,
00637 &hd, &(phmdVS->phmd[j*length+k]) ), status);
00638 }
00639
00640 TRY( LALHOUGHIntegrHD2HT(status->statusPtr, ht, &hd), status);
00641
00642
00643 LALFree(hd.map);
00644
00645 DETATCHSTATUSPTR (status);
00646
00647 RETURN (status);
00648 }
00649
00650
00651
00652
00653
00654
00655 void LALHOUGHWeighSpacePHMD (LALStatus *status,
00656 PHMDVectorSequence *phmdVS,
00657 REAL8Vector *weightV )
00658 {
00659
00660 UINT4 k,j;
00661 UINT4 nfSize;
00662 UINT4 length;
00663
00664
00665 INITSTATUS (status, "LALHOUGHWeighSpacePHMD", DRIVEHOUGHC);
00666 ATTATCHSTATUSPTR (status);
00667
00668
00669
00670 ASSERT (phmdVS, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00671 ASSERT (weightV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00672
00673
00674 ASSERT (phmdVS->phmd, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00675 ASSERT (weightV->data,status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00676
00677
00678
00679 ASSERT (weightV->length == phmdVS->length, status,
00680 LALHOUGHH_ESZMM, LALHOUGHH_MSGESZMM);
00681
00682
00683
00684 ASSERT (phmdVS->length, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00685 ASSERT (phmdVS->nfSize, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00686
00687
00688 length = phmdVS->length;
00689 nfSize = phmdVS->nfSize;
00690
00691
00692 for ( k=0; k<length; ++k ){
00693 for ( j=0; j< nfSize; ++j ){
00694 phmdVS->phmd[ j*length+k ].weight = (HoughDT)weightV->data[k];
00695 }
00696 }
00697
00698
00699 DETATCHSTATUSPTR (status);
00700
00701 RETURN (status);
00702 }
00703
00704
00705
00706
00707
00708 void LALHOUGHInitializeWeights (LALStatus *status,
00709 REAL8Vector *weightV )
00710 {
00711
00712 UINT4 j, length;
00713
00714
00715 INITSTATUS (status, "LALHOUGHInitializeWeights", DRIVEHOUGHC);
00716 ATTATCHSTATUSPTR (status);
00717
00718
00719
00720 ASSERT (weightV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00721 ASSERT (weightV->data,status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00722
00723
00724
00725 ASSERT (weightV->length, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00726
00727 length = weightV->length;
00728
00729 for (j=0; j<length; j++) {
00730 weightV->data[j] = 1.0;
00731 }
00732
00733 DETATCHSTATUSPTR (status);
00734
00735 RETURN (status);
00736 }
00737
00738
00739
00740
00741
00742
00743 void LALHOUGHNormalizeWeights (LALStatus *status,
00744 REAL8Vector *weightV )
00745 {
00746
00747 UINT4 j, length;
00748 REAL8 sum;
00749
00750
00751 INITSTATUS (status, "LALHOUGHNormalizeWeights", DRIVEHOUGHC);
00752 ATTATCHSTATUSPTR (status);
00753
00754
00755
00756 ASSERT (weightV, status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00757 ASSERT (weightV->data,status, LALHOUGHH_ENULL, LALHOUGHH_MSGENULL);
00758
00759
00760
00761 ASSERT (weightV->length, status, LALHOUGHH_ESIZE, LALHOUGHH_MSGESIZE);
00762
00763 length = weightV->