I am trying to program a noise reduction algorithm that works with a set of datapoints in a VB.NET DataTable after being helped with my other question. Basically, I want to take two integers, a coordinate value (yCoord for example) and a threshold smoothing value (NoiseThresh), and take the average of the values in the range of (yCoord - NoiseThresh, yCoord + NoiseThresh) and store that number into an array. I’d repeat that process for each column (in this example) and end up with a one-dimensional array of average values. My questions are:
1) Did anything I just say make any sense ;), and
2) Can anyone help me with the code? I’ve got very little experience working with databases.
Thanks!
An example of what I’m trying to do:
//My data (pretend it's a database)
1 4 4 9 2 //yCoord would equal 5
6 3 8 12 3 //yCoord = 4
8 3 -2 2 0 //yCoord = 3
9 17 3 7 5 //yCoord = 2
4 1 0 9 7 //yCoord = 1
//In this example, my yCoord will equal 3 and NoiseThresh = 1
//For the first column
Array(column1) = //average of the set of numbers centered at yCoord = 3 _
//(in this case 8) and the NoiseThresh=1 number on either side (here 6 & 9)
//For the second column
Array(column2) = //average of the numbers 3,3,17 for example
//etc., etc.,
This would be performed on a large data set (typical numbers would be yCoord=500, NoiseThresh = 50, Array length = 1092) so there is no possibility of manually entering the numbers.
I hope this helps clarify my question!
P.S.: yes, I know that // isn’t a VB.NET comment.
I must admit that i’ve yet not understood the range part (NoiseThresh etc.), but this is a start:
It calculates every average of each column in the
DataTableand creates aDouble()from the result (average can result in decimal places even if used on integers).Edit: With your example i’ve now understood the range part. So basically
yCordis the row-index(+1) andnoiseThreasis the row-range (+/- n rows).Then this gives you the correct result(made some code comments):
The most important part of this this
LINQquery is theWhere. It applies your range on theIEnumerable(of DataRow). Then i’m calculating the average of these rows for every column. The last step is materializing the query to aDouble().Result:
Edit2:
It’s not that simple. But have a look yourself:
Result: