Optimizing Grouping of People for Teamwork

  • #1
Frank Einstein
170
1
TL;DR Summary
I wan to group some people based on a compatibility score. Each group has a maximum size. I must maximize the compatibility within each group
I have a matrix of dimension 56*56, each row and column represent the compatibility of one person with the rest of the people.

A sample matrix could be

Compatibility sample:
              Alejandro Ana  Beatriz    Jose    Juan     Luz   Maria   Ruben                                                         
Alejandro        0.0     0.0   1000.0     0.0  1037.0  1014.0   100.0     0.0
Ana              0.0     0.0     15.0     0.0   100.0     0.0    16.0  1100.0
Beatriz       1000.0    15.0      0.0   100.0  1000.0  1100.0    15.0     0.0
Jose             0.0     0.0    100.0     0.0     0.0   100.0  1000.0    14.0
Juan          1037.0   100.0   1000.0     0.0     0.0  1014.0     0.0   100.0
Luz           1014.0     0.0   1100.0   100.0  1014.0     0.0     0.0     0.0
Maria          100.0    16.0     15.0  1000.0     0.0     0.0     0.0     0.0
Ruben            0.0  1100.0      0.0    14.0   100.0     0.0     0.0     0.0

Represented in python as

Data as dataframe:
data = {
    'Alejandro': [0.0, 0.0, 1000.0, 0.0, 1037.0, 1014.0, 100.0, 0.0],
    'Ana': [0.0, 0.0, 15.0, 0.0, 100.0, 0.0, 16.0, 1100.0],
    'Beatriz': [1000.0, 15.0, 0.0, 100.0, 1000.0, 1100.0, 15.0, 0.0],
    'Jose': [0.0, 0.0, 100.0, 0.0, 0.0, 100.0, 1000.0, 14.0],
    'Juan': [1037.0, 100.0, 1000.0, 0.0, 0.0, 1014.0, 0.0, 100.0],
    'Luz': [1014.0, 0.0, 1100.0, 100.0, 1014.0, 0.0, 0.0, 0.0],
    'Maria': [100.0, 16.0, 15.0, 1000.0, 0.0, 0.0, 0.0, 0.0],
    'Ruben': [0.0, 1100.0, 0.0, 14.0, 100.0, 0.0, 0.0, 0.0]
}
df = pd.DataFrame(
    data,
    index=['Alejandro', 'Ana', 'Beatriz', 'Jose', 'Juan', 'Luz', 'Maria', 'Ruben']
)

I want to group the people in groups of two or three people and I want to maximize the total compatibility within each group since I want them to do some teamwork.

One solution could be [Alejandro-Juan], [Ana-Ruben], [Beatriz-Luz] and [Maria-Jose]. The punctuation would be the sum of the element of the matrix corresponding to each pair. If I had chosen [Alejandro-Juan-Ana], [Ruben-Beatriz-Luz], [Maria-Jose], I would sum the scores of Alejandro-Juan, Alejandro-Ana, Juan-Ana and so on.

I have already asked this question in Stack Overflow, but the code doesn't find clusters for the real data. In reality, I must group people in groups of 8-10 people.

I have tough on using a genetic algorithm, where chromosomes are the groups of people, as an example,

AlejandroJuanAnaRubenBeatrizLuzMariaJose
11122233
12312312

However, I am clueless about how to do the crossing and the mutation.

Can someone please help me obtain a solution to this problem?
Any answer is appreciated.

Best regards and thanks for reading.
 
Physics news on Phys.org
  • #2
The edited stack overflow solution is supposed to nature groups of 2-3, all you need to do is edit those numbers to be 8 and 10? If the code as written doesn't work I feel like you should keep up the discussion there rather than have more Internet strangers do the same work again.
 
  • #3
Office_Shredder said:
The edited stack overflow solution is supposed to nature groups of 2-3, all you need to do is edit those numbers to be 8 and 10? If the code as written doesn't work I feel like you should keep up the discussion there rather than have more Internet strangers do the same work again.
The code doesn't seem to work since it never returns a feasible solution, it doesn't matter hoy much extra iterations I add. That is why I came here to ask if someone could propose an alternative method.

Shoul I delete the post?
 

FAQ: Optimizing Grouping of People for Teamwork

What factors should be considered when forming teams for optimal performance?

When forming teams for optimal performance, consider factors such as individual skill sets, personality types, past collaboration experiences, communication styles, and the diversity of perspectives. Balancing these elements can enhance team synergy and productivity.

How does diversity impact team performance?

Diversity in a team can lead to more innovative solutions and better decision-making by bringing a variety of perspectives and ideas. However, it can also present challenges in communication and cohesion. Effective management of diversity is crucial to harness its benefits.

What role does team size play in optimizing teamwork?

Team size significantly impacts performance. Smaller teams (typically 4-6 members) are generally more agile and easier to manage, facilitating better communication and coordination. Larger teams might benefit from a broader range of skills but can face challenges in maintaining cohesion and effective communication.

How can we measure the effectiveness of a team?

Team effectiveness can be measured using various metrics such as the achievement of goals, quality of output, team member satisfaction, and the efficiency of processes. Regular feedback, performance reviews, and assessments of team dynamics also provide insights into team effectiveness.

What strategies can be employed to improve team dynamics?

Strategies to improve team dynamics include promoting open communication, establishing clear roles and responsibilities, encouraging collaboration, providing team-building activities, and fostering a positive and inclusive team culture. Regularly addressing conflicts and providing support for team members also contribute to healthier team dynamics.

Back
Top