100 lines
3.3 KiB
C
Raw Permalink Normal View History

2020-07-31 11:31:32 +08:00
//===============================================================================
// Copyright (c) 2007-2016 Advanced Micro Devices, Inc. All rights reserved.
// Copyright (c) 2004-2006 ATI Technologies Inc.
//===============================================================================
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files(the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions :
//
2020-07-31 11:31:32 +08:00
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
2020-07-31 11:31:32 +08:00
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
#ifndef RECONSTRUCT_H_INCLUDED
#define RECONSTRUCT_H_INCLUDED
2020-07-31 11:31:32 +08:00
#include "bc7_definitions.h"
2020-07-31 11:31:32 +08:00
// continious recoustruction unclumped
2020-07-31 11:31:32 +08:00
/*********************************/
double reconstruct(
2020-07-31 11:31:32 +08:00
double data[MAX_ENTRIES][DIMENSION], // input
int numEntries, // input
int index_[MAX_ENTRIES], // input
double out[MAX_ENTRIES][DIMENSION], // output
int ns, // input
double direction [DIMENSION], // output
double *step // output
);
2020-07-31 11:31:32 +08:00
/*********************************/
double reconstruct_rnd(
double data[MAX_ENTRIES][DIMENSION],
2020-07-31 11:31:32 +08:00
int numEntries, int index_[MAX_ENTRIES],
double out[MAX_ENTRIES][DIMENSION],int ns,
double direction [DIMENSION],double *step
);
int block_mean_rnd(
double data_[MAX_ENTRIES][DIMENSION],
int numEntries,
2020-07-31 11:31:32 +08:00
int partition[MAX_ENTRIES],
int ns,
double mean[MAX_SUBSETS][DIMENSION],
double *clip,
double mm[DIMENSION],
double ni[MAX_SUBSETS] // norm
);
2020-07-31 11:31:32 +08:00
/*****************************************/
double ep_shaker_2(
double data[MAX_ENTRIES][DIMENSION],
2020-07-31 11:31:32 +08:00
int numEntries,
int index_[MAX_ENTRIES],
double out[MAX_ENTRIES][DIMENSION],
double direction [DIMENSION],
double *step,
int epo_code[2][DIMENSION],
int bits[3],
int bcc,
int nClusters,
int size
) ;
2020-07-31 11:31:32 +08:00
/*****************************************/
double ep_shaker_2__(
double data[MAX_ENTRIES][DIMENSION],
2020-07-31 11:31:32 +08:00
int numEntries, int index_[MAX_ENTRIES],
double out[MAX_ENTRIES][DIMENSION],int ns,
double direction [DIMENSION],double *step
);
2020-07-31 11:31:32 +08:00
// good but broken (first one) ?????????????????????
double ep_shaker(
double data[MAX_ENTRIES][DIMENSION],
2020-07-31 11:31:32 +08:00
int numEntries, int index_[MAX_ENTRIES],
double out[MAX_ENTRIES][DIMENSION],int ns,
double direction [DIMENSION],double *step,
int lock
);
2020-07-31 11:31:32 +08:00
void printStep (void);
void printCnt (void);
void printStepHisto (void);
2020-07-31 11:31:32 +08:00
#endif