Hi,
I am trying to build a large array using concatenate function in
python.
So as I loop over the number of arrays, of which there are 12 (4 down
and 3 across), I create 3 long arrays by concatenating them at the
bottom and then concatenating them side by side:
for ind in range(num_arrays):
if ind == 0:
bias_down1 = array(bias)
ppslon1 = array(ppslon)
ppslat1 = array(ppslat)
elif ind 0 and <= 3:
bias_down1 = concatenate((bias_down1,bias),0)
ppslon1 = concatenate((ppslon1,ppslon),0)
ppslat1 = concatenate((ppslat1,ppslat),0)
elif ind == 4:
bias_down2 = array(bias)
ppslon2 = array(ppslon)
ppslat2 = array(ppslat)
elif ind 4 and ind <= 7:
bias_down2 = concatenate((bias_down2,bias),0)
ppslon2 = concatenate((ppslon2,ppslon),0)
ppslat2 = concatenate((ppslat2,ppslat),0)
elif ind == 8:
bias_down3 = array(bias)
ppslon3 = array(ppslon)
ppslat3 = array(ppslat)
elif ind 8:
bias_down3 = concatenate((bias_down3,bias),0)
ppslon3 = concatenate((ppslon3,ppslon),0)
ppslat3 = concatenate((ppslat3,ppslat),0)
bias_a = concatenate((bias_down1,bias_down2),1) # joining the arrays
side by side
bias_all = concatenate((bias_a,bias_down3),1)
ppslat_a = concatenate((ppslat1,ppslat2),1)
ppslat_all = concatenate((ppslat_a,ppslat3),1)
ppslon_a = concatenate((ppslon1,ppslon2),1)
ppslon_all = concatenate((ppslon_a,ppslon3),1)
print 'Max lat', max(max(ppslat_all)), '\t','Min lat',
min(min(ppslat_all))
print 'Max lon', max(max(ppslon_all)), '\t','Min lon',
min(min(ppslon_all))
*****************
Now this works, the array size is correct but the longitude values
given for max and min are wrong. What is even stranger to me is that
when I write the array in binary format to a file and read it with
Matlab, the max and min are correct but when I read it back with python
the max and min are again incorrect for only the longitude data. I
saved the max and min for the longitude for each array and then check
it in the python program and they are correct at the end but the
max(max(ppslon)) values is incorrect. Does anyone knows why this is
so?
If I was doing something wrong then Matlab would not have returned
correct values.
Any help is appreciated!
/Sheldon 6 4284
Sheldon skrev:
Hi,
I am trying to build a large array using concatenate function in
python.
So as I loop over the number of arrays, of which there are 12 (4 down
and 3 across), I create 3 long arrays by concatenating them at the
bottom and then concatenating them side by side:
for ind in range(num_arrays):
if ind == 0:
bias_down1 = array(bias)
ppslon1 = array(ppslon)
ppslat1 = array(ppslat)
elif ind 0 and <= 3:
bias_down1 = concatenate((bias_down1,bias),0)
ppslon1 = concatenate((ppslon1,ppslon),0)
ppslat1 = concatenate((ppslat1,ppslat),0)
elif ind == 4:
bias_down2 = array(bias)
ppslon2 = array(ppslon)
ppslat2 = array(ppslat)
elif ind 4 and ind <= 7:
bias_down2 = concatenate((bias_down2,bias),0)
ppslon2 = concatenate((ppslon2,ppslon),0)
ppslat2 = concatenate((ppslat2,ppslat),0)
elif ind == 8:
bias_down3 = array(bias)
ppslon3 = array(ppslon)
ppslat3 = array(ppslat)
elif ind 8:
bias_down3 = concatenate((bias_down3,bias),0)
ppslon3 = concatenate((ppslon3,ppslon),0)
ppslat3 = concatenate((ppslat3,ppslat),0)
bias_a = concatenate((bias_down1,bias_down2),1) # joining the arrays
side by side
bias_all = concatenate((bias_a,bias_down3),1)
ppslat_a = concatenate((ppslat1,ppslat2),1)
ppslat_all = concatenate((ppslat_a,ppslat3),1)
ppslon_a = concatenate((ppslon1,ppslon2),1)
ppslon_all = concatenate((ppslon_a,ppslon3),1)
print 'Max lat', max(max(ppslat_all)), '\t','Min lat',
min(min(ppslat_all))
print 'Max lon', max(max(ppslon_all)), '\t','Min lon',
min(min(ppslon_all))
*****************
Now this works, the array size is correct but the longitude values
given for max and min are wrong. What is even stranger to me is that
when I write the array in binary format to a file and read it with
Matlab, the max and min are correct but when I read it back with python
the max and min are again incorrect for only the longitude data. I
saved the max and min for the longitude for each array and then check
it in the python program and they are correct at the end but the
max(max(ppslon)) values is incorrect. Does anyone knows why this is
so?
If I was doing something wrong then Matlab would not have returned
correct values.
Any help is appreciated!
/Sheldon
Sorry, there is a small error when I wrote this part of the program:
should say "ind <= 3"
/sheldon
Sheldon wrote:
Hi,
I am trying to build a large array using concatenate function in
python.
So as I loop over the number of arrays, of which there are 12 (4 down
and 3 across), I create 3 long arrays by concatenating them at the
bottom and then concatenating them side by side:
[snip]
print 'Max lat', max(max(ppslat_all)), '\t','Min lat',
min(min(ppslat_all))
print 'Max lon', max(max(ppslon_all)), '\t','Min lon',
min(min(ppslon_all))
*****************
Now this works, the array size is correct but the longitude values
given for max and min are wrong. What is even stranger to me is that
when I write the array in binary format to a file and read it with
Matlab, the max and min are correct but when I read it back with python
the max and min are again incorrect for only the longitude data. I
saved the max and min for the longitude for each array and then check
it in the python program and they are correct at the end but the
max(max(ppslon)) values is incorrect. Does anyone knows why this is
so?
If I was doing something wrong then Matlab would not have returned
correct values.
Don't use min() and max() on multidimensional arrays. They won't give sensible
answers.
In [11]: a = RA.random([3,5])
In [12]: a
Out[12]:
array([[ 0.01721657, 0.64291363, 0.33210659, 0.89887972, 0.24437849],
[ 0.88205348, 0.00839329, 0.35999039, 0.9966411 , 0.54957126],
[ 0.59983864, 0.18983323, 0.13727718, 0.8987289 , 0.05425076]])
In [13]: min(a)
Out[13]: array([ 0.59983864, 0.18983323, 0.13727718, 0.8987289 , 0.05425076])
The builtin min() and max() compare the values in the sequence. In this case,
those values are the rows of the arrays. Numeric uses rich comparisons, so the
result of a comparison is a boolean array. Numeric also has the convention that
if any of the elements of an array are considered to be True, then the whole
array is.
In [16]: a[1] < a[2]
Out[16]: array([0, 1, 0, 0, 0])
In [17]: bool(_)
Out[17]: True
In [18]: a[2] < a[1]
Out[18]: array([1, 0, 1, 1, 1])
In [19]: bool(_)
Out[19]: True
This makes min(a) incorrect when len(a.shape) 1. Instead, use the minimum and
maximum ufuncs provided with Numeric:
In [21]: N.minimum.reduce(a.flat)
Out[21]: 0.0083932917161983426
In [22]: N.maximum.reduce(a.flat)
Out[22]: 0.99664110397663608
--
Robert Kern
"I have come to believe that the whole world is an enigma, a harmless enigma
that is made terrible by our own mad attempt to interpret it as though it had
an underlying truth."
-- Umberto Eco
Robert Kern skrev:
Sheldon wrote:
Hi,
I am trying to build a large array using concatenate function in
python.
So as I loop over the number of arrays, of which there are 12 (4 down
and 3 across), I create 3 long arrays by concatenating them at the
bottom and then concatenating them side by side:
[snip]
print 'Max lat', max(max(ppslat_all)), '\t','Min lat',
min(min(ppslat_all))
print 'Max lon', max(max(ppslon_all)), '\t','Min lon',
min(min(ppslon_all))
*****************
Now this works, the array size is correct but the longitude values
given for max and min are wrong. What is even stranger to me is that
when I write the array in binary format to a file and read it with
Matlab, the max and min are correct but when I read it back with python
the max and min are again incorrect for only the longitude data. I
saved the max and min for the longitude for each array and then check
it in the python program and they are correct at the end but the
max(max(ppslon)) values is incorrect. Does anyone knows why this is
so?
If I was doing something wrong then Matlab would not have returned
correct values.
Don't use min() and max() on multidimensional arrays. They won't give sensible
answers.
In [11]: a = RA.random([3,5])
In [12]: a
Out[12]:
array([[ 0.01721657, 0.64291363, 0.33210659, 0.89887972, 0.24437849],
[ 0.88205348, 0.00839329, 0.35999039, 0.9966411 , 0.54957126],
[ 0.59983864, 0.18983323, 0.13727718, 0.8987289 , 0.05425076]])
In [13]: min(a)
Out[13]: array([ 0.59983864, 0.18983323, 0.13727718, 0.8987289 , 0.05425076])
The builtin min() and max() compare the values in the sequence. In this case,
those values are the rows of the arrays. Numeric uses rich comparisons, so the
result of a comparison is a boolean array. Numeric also has the convention that
if any of the elements of an array are considered to be True, then the whole
array is.
In [16]: a[1] < a[2]
Out[16]: array([0, 1, 0, 0, 0])
In [17]: bool(_)
Out[17]: True
In [18]: a[2] < a[1]
Out[18]: array([1, 0, 1, 1, 1])
In [19]: bool(_)
Out[19]: True
This makes min(a) incorrect when len(a.shape) 1. Instead, use the minimum and
maximum ufuncs provided with Numeric:
In [21]: N.minimum.reduce(a.flat)
Out[21]: 0.0083932917161983426
In [22]: N.maximum.reduce(a.flat)
Out[22]: 0.99664110397663608
--
Robert Kern
"I have come to believe that the whole world is an enigma, a harmless enigma
that is made terrible by our own mad attempt to interpret it as though it had
an underlying truth."
-- Umberto Eco
Thanks a million!!!!!!!!!!!!!!!!!!!!!!!
Now I can sleep better.
/Sheldon
Robert Kern wrote:
Sheldon wrote:
Hi,
I am trying to build a large array using concatenate function in
python.
So as I loop over the number of arrays, of which there are 12 (4 down
and 3 across), I create 3 long arrays by concatenating them at the
bottom and then concatenating them side by side:
[snip]
print 'Max lat', max(max(ppslat_all)), '\t','Min lat',
min(min(ppslat_all))
print 'Max lon', max(max(ppslon_all)), '\t','Min lon',
min(min(ppslon_all))
*****************
Now this works, the array size is correct but the longitude values
given for max and min are wrong. What is even stranger to me is that
when I write the array in binary format to a file and read it with
Matlab, the max and min are correct but when I read it back with python
the max and min are again incorrect for only the longitude data. I
saved the max and min for the longitude for each array and then check
it in the python program and they are correct at the end but the
max(max(ppslon)) values is incorrect. Does anyone knows why this is
so?
If I was doing something wrong then Matlab would not have returned
correct values.
Don't use min() and max() on multidimensional arrays. They won't give sensible
answers.
In [11]: a = RA.random([3,5])
In [12]: a
Out[12]:
array([[ 0.01721657, 0.64291363, 0.33210659, 0.89887972, 0.24437849],
[ 0.88205348, 0.00839329, 0.35999039, 0.9966411 , 0.54957126],
[ 0.59983864, 0.18983323, 0.13727718, 0.8987289 , 0.05425076]])
In [13]: min(a)
Out[13]: array([ 0.59983864, 0.18983323, 0.13727718, 0.8987289 , 0.05425076])
The builtin min() and max() compare the values in the sequence. In this case,
those values are the rows of the arrays. Numeric uses rich comparisons, so the
result of a comparison is a boolean array. Numeric also has the convention that
if any of the elements of an array are considered to be True, then the whole
array is.
In [16]: a[1] < a[2]
Out[16]: array([0, 1, 0, 0, 0])
In [17]: bool(_)
Out[17]: True
In [18]: a[2] < a[1]
Out[18]: array([1, 0, 1, 1, 1])
In [19]: bool(_)
Out[19]: True
This makes min(a) incorrect when len(a.shape) 1. Instead, use the minimum and
maximum ufuncs provided with Numeric:
In [21]: N.minimum.reduce(a.flat)
Out[21]: 0.0083932917161983426
In [22]: N.maximum.reduce(a.flat)
Out[22]: 0.99664110397663608
--
Robert Kern
"I have come to believe that the whole world is an enigma, a harmless enigma
that is made terrible by our own mad attempt to interpret it as though it had
an underlying truth."
-- Umberto Eco
Hi Robert,
Thanks again for showing me this. I have been trying to read up on
reduce() as I have never used it before. I would like to know what it
does. So far my search has found nothing that I can grasp. The
reference library notes are estoteric at best.
Can you enlighten me on this matter?'
/Sheldon
Sheldon wrote:
Thanks again for showing me this. I have been trying to read up on
reduce() as I have never used it before. I would like to know what it
does. So far my search has found nothing that I can grasp. The
reference library notes are estoteric at best.
Can you enlighten me on this matter?'
The .reduce() method on ufuncs works pretty much like the reduce() builtin
function. It applies the binary ufunc along the given axis of the array (the
first one by default) cumulatively.
a = [3, 2, 1, 0]
minimum.reduce(a) == minimum(minimum(minimum(a[0], a[1]), a[2]), a[3])
I will note, in the form of enticement to get you to try the currently active
array package instead of Numeric, that in numpy, arrays have methods to do
minimums and maximum rather more conveniently.
>>import numpy as N a = N.rand(3, 5) a
array([[ 0.49892358, 0.11931907, 0.37146848, 0.07494308, 0.91973863],
[ 0.92049698, 0.35016683, 0.01711571, 0.59542456, 0.49897077],
[ 0.57449315, 0.99592033, 0.20549262, 0.25135288, 0.04111402]])
>>a.min()
0.017115711878847639
>>a.min(axis=0)
array([ 0.49892358, 0.11931907, 0.01711571, 0.07494308, 0.04111402])
>>a.min(axis=1)
array([ 0.07494308, 0.01711571, 0.04111402])
--
Robert Kern
"I have come to believe that the whole world is an enigma, a harmless enigma
that is made terrible by our own mad attempt to interpret it as though it had
an underlying truth."
-- Umberto Eco
Robert Kern skrev:
Sheldon wrote:
Thanks again for showing me this. I have been trying to read up on
reduce() as I have never used it before. I would like to know what it
does. So far my search has found nothing that I can grasp. The
reference library notes are estoteric at best.
Can you enlighten me on this matter?'
The .reduce() method on ufuncs works pretty much like the reduce() builtin
function. It applies the binary ufunc along the given axis of the array (the
first one by default) cumulatively.
a = [3, 2, 1, 0]
minimum.reduce(a) == minimum(minimum(minimum(a[0], a[1]), a[2]), a[3])
I will note, in the form of enticement to get you to try the currently active
array package instead of Numeric, that in numpy, arrays have methods to do
minimums and maximum rather more conveniently.
>>import numpy as N
>>a = N.rand(3, 5)
>>a
array([[ 0.49892358, 0.11931907, 0.37146848, 0.07494308, 0.91973863],
[ 0.92049698, 0.35016683, 0.01711571, 0.59542456, 0.49897077],
[ 0.57449315, 0.99592033, 0.20549262, 0.25135288, 0.04111402]])
>>a.min()
0.017115711878847639
>>a.min(axis=0)
array([ 0.49892358, 0.11931907, 0.01711571, 0.07494308, 0.04111402])
>>a.min(axis=1)
array([ 0.07494308, 0.01711571, 0.04111402])
--
Robert Kern
"I have come to believe that the whole world is an enigma, a harmless enigma
that is made terrible by our own mad attempt to interpret it as though it had
an underlying truth."
-- Umberto Eco
Thanks for the explanation! Super.
I am trying to get my bosses to purchase the Numpy documentation and
upgrade to Numpy as well as matplotlib and other necessary scientific
modules. But it is not entirely up to me. Still I need to learn more
about Python and installing these modules myself. This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics
by: SABmore |
last post by:
I have a table that I populate with an array using ASP. As each row is
created, the form object names are appended a numeric, such as:
i = 1
<select name="select<%=i%>">
...
...
...
i = i+1...
|
by: Rico |
last post by:
Hello,
I'm wondering if there is a way to concatenate two fields or a field and a
string value in a single field in a view?
Where in Access I might write;
& " (m3)" as TotalVolume
is...
|
by: metamorphiq |
last post by:
Hello,
I'm a Java programmer, so I'm probably asking a very simple question
here, but I have trouble solving it :)
I'd like to know how you concatenate multiple (4, in my case) char* in
C++,...
|
by: exapplerep |
last post by:
I've seen how to use VBA code to concatenate two fields into a third by
using an expression in the "After Update" property in fields 1 & 2.
field3 = field1 + field2
The above code would go...
|
by: Dan |
last post by:
Hi all, I am creating a search table where the keywords field is made
up of several text fields and this is causing me some problems. I can
concatentate the text ok but i can't seem to concatenate...
|
by: parth |
last post by:
Hi
I want to achieve the following transformation of data using a stored
procedure.
Source
col1 col2(varchar)
-------------------------
|
by: sinbad |
last post by:
hi,
how to concatenate a "hash defined" constant value to another "hash
defined" constant string. For example
#define ABC 100
#define MYSTR "The value of ABC is"
Now i need a string that...
|
by: Aaron Hoffman |
last post by:
Hello,
I'm hoping someone might be able to offer some guidance to my problem.
I have one query in MS Access which consists of 2 tables joined by a
SEQUENCE_ID. By joining the two tables I am...
|
by: Zamdrist |
last post by:
I have a need to make a group of records 'unique' by concatenating a
foreign key value to another field, the two are float and varchar
type. Now, I'll have to cast the float column, but then I end...
|
by: taylorcarr |
last post by:
A Canon printer is a smart device known for being advanced, efficient, and reliable. It is designed for home, office, and hybrid workspace use and can also be used for a variety of purposes. However,...
|
by: ryjfgjl |
last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
|
by: emmanuelkatto |
last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud.
Please let me know.
Thanks!
Emmanuel
|
by: BarryA |
last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
|
by: nemocccc |
last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
|
by: Sonnysonu |
last post by:
This is the data of csv file
1 2 3
1 2 3
1 2 3
1 2 3
2 3
2 3
3
the lengths should be different i have to store the data by column-wise with in the specific length.
suppose the i have to...
|
by: Hystou |
last post by:
There are some requirements for setting up RAID:
1. The motherboard and BIOS support RAID configuration.
2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
|
by: marktang |
last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
|
by: Oralloy |
last post by:
Hello folks,
I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>".
The problem is that using the GNU compilers,...
| |