From 5040709312891b9c6b130baa82f66e7959fb6cb8 Mon Sep 17 00:00:00 2001
From: torset
Date: Wed, 18 Feb 2009 09:48:12 +0000
Subject: Add min and max in statisticsFunctions

---
 src/statisticsFunctions/min/testFloatMin.c | 92 ++++++++++++++++++++++++++++++
 1 file changed, 92 insertions(+)
 create mode 100644 src/statisticsFunctions/min/testFloatMin.c

(limited to 'src/statisticsFunctions/min/testFloatMin.c')

diff --git a/src/statisticsFunctions/min/testFloatMin.c b/src/statisticsFunctions/min/testFloatMin.c
new file mode 100644
index 00000000..28540d64
--- /dev/null
+++ b/src/statisticsFunctions/min/testFloatMin.c
@@ -0,0 +1,92 @@
+/*
+ *  Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
+ *  Copyright (C) 2008-2008 - INRIA - Arnaud Torset
+ *
+ *  This file must be used under the terms of the CeCILL.
+ *  This source file is licensed as described in the file COPYING, which
+ *  you should have received as part of this distribution.  The terms
+ *  are also available at
+ *  http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
+ *
+ */
+
+
+
+#include "statMin.h"
+#include "assert.h"
+#include "stdio.h"
+
+static void sminaTest(void){
+	float in[12]={4,5,7,1,2,6,4,1,2,5,4,3};
+	float out;
+	
+	out = smina(in,12);
+	assert(out-1==0);
+	
+}
+
+
+static void srowminaTest(void){
+	float in[12]={4,5,7,1,2,6,4,1,2,5,4,3};
+	float out1[1],out2[2],out3[3],out4[4],out6[6],out12[12];
+	float result2[2]={1,1};
+	float result3[3]={1,1,2};
+	float result4[4]={4,1,1,3};
+	float result6[6]={4,1,2,1,2,3};
+	int i;
+	
+	
+	srowmina(in,12,1,out1);
+	srowmina(in,6,2,out2);
+	srowmina(in,4,3,out3);
+	srowmina(in,3,4,out4);
+	srowmina(in,2,6,out6);
+	srowmina(in,1,12,out12);
+	
+	assert(out1[0]-1==0);
+	for (i=0;i<2;i++) 	assert(out2[i]-result2[i]==0);
+	for (i=0;i<3;i++) 	assert(out3[i]-result3[i]==0);
+	for (i=0;i<4;i++) 	assert(out4[i]-result4[i]==0);
+	for (i=0;i<6;i++) 	assert(out6[i]-result6[i]==0);
+	for (i=0;i<12;i++) 	assert(out12[i]-in[i]==0);
+}
+
+
+static void scolumnminaTest(void){
+	float in[12]={4,5,7,1,2,6,4,1,2,5,4,3};
+	float out1[1],out2[2],out3[3],out4[4],out6[6],out12[12];
+	float result2[2]={1,1};
+	float result3[3]={1,1,2};
+	float result4[4]={4,1,1,3};
+	float result6[6]={4,1,2,1,2,3};
+	int i;
+	
+	
+	
+	scolumnmina(in,12,1,out12);
+	scolumnmina(in,6,2,out6);
+	scolumnmina(in,4,3,out4);
+	scolumnmina(in,3,4,out3);
+	scolumnmina(in,2,6,out2);
+	scolumnmina(in,1,12,out1);
+	
+	assert(out1[0]-1==0);
+	for (i=0;i<2;i++) 	assert(out2[i]-result2[i]==0);
+	for (i=0;i<3;i++) 	assert(out3[i]-result3[i]==0);
+	for (i=0;i<4;i++) 	assert(out4[i]-result4[i]==0);
+	for (i=0;i<6;i++) 	assert(out6[i]-result6[i]==0);
+	for (i=0;i<12;i++) 	assert(out12[i]-in[i]==0);
+}
+
+static int minTest(void){
+	sminaTest();
+	srowminaTest();
+	scolumnminaTest();
+	return 0;
+}
+
+
+int main(void){
+	assert(minTest()==0);
+	return 0;
+}
-- 
cgit