International Journal of Interactive Mobile Technologies (iJIM) – eISSN: 1865-7923 – Vol. 14, No. 7, 2020 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… Design and Implementation of P2P Based Mobile App for Collaborative Learning in Higher Education https://doi.org/10.3991/ijim.v14i07.13167 Asmae Blilat (), Abdelali Ibriz Sidi Mohamed Ben Abdellah University, Fez, Morocco asmae.blilat@usmba.ac.ma Abstract—Within the recent years, mobile technologies have made major progress in its development. They have become an integral part of our daily life. Therefore, the big interest of using mobile technology in education process is comprehensible. A new technology was born called mobile learning (m-learn- ing). The main benefits of this technology are sharing three important dimensions of learning resources namely learning contents, learning collaborators and learn- ing services. In university courses, different forms of collaborative and peer learning are progressively used in order to assist students meet an assortment of learning outcomes. Therefore, the use of mobile technologies in education has become a crucial topic for research. Because mobile phone is the first choice of everyone to communicate, our research is focused on the use of smartphones as learning resources. In this paper, we propose an implementation of a new mobile application-based peer-to-peer learning system named "EachOther" and a sce- nario for its usage applied on students of an IT course at the High School of Technology of Fez (ESTF). The aim of this work consists of the conception, the development and the implementation of the mobile application based on Android system to support collaborative learning, by applying an object-oriented model- ing language which is Unified Modeling Language (UML). Keywords—Mobile technologies, E-learning, Mobile learning, Peer to peer, collaborative learning, Android system. 1 Introduction Mobile technologies have emerged as facilitators in the learning process, affording new methods to access and use learning materials and defining the mobile learning model [1]. The term mobile learning designates the use of mobile applications installed on a mobile device (smartphone, PDA, tablets) that are used in the education process at universities and schools. Thereby, with mobile devices, learning is getting to be more and more personal and connected to the environment at the same time with more po- tential for connected collaborative activities [2]. Among the different forms of learning that exist, we have focused in this article on peer learning. Peer learning has always been a part of students’ university experience. Traditionally this has meant students interacting informally with each other outside formal teaching iJIM ‒ Vol. 14, No. 7, 2020 115 https://doi.org/10.3991/ijim.v14i07.13167 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… sessions, but in more recent times peer learning has been included as part of an orga- nized learning process with students being asked to work in pairs or in groups to achieve a variety of learning outcomes [3]. In all courses, students share useful information and learning experiences. When students encounter problems, they often seek help from other students rather than from teachers. Learning from peers usually occurs informally without teacher involvement, and it particularly benefits the students who are effective learners [4]. In terms of technology, peer learning is based on P2P communication which is considered as one of the most important and suitable networking technologies for ubiquitous communications, i.e. allows direct communication between devices, free and extensible distribution of resources and distributed search for enormous amount of resources [5]. Due to the growing perception of Android-based smartphones, many researchers and academics are increasingly interested in developing applications for P2P communica- tion in these devices. In addition, the increasing applications for P2P communication in these smartphones are imputed to the reason that Android Operating System is a free and open source for developers to build their applications using the Android SDK and adding them to the Android libraries. Therefore, the aim of this paper is to implement an android application-based peer- to-peer learning which provides a platform for students to share their outcomes, knowledge and learning resources. The paper is organized as follows: the background and related works are reviewed in section 2; in section 3, general requirements and methods are discussed and our mo- bile application is proposed; in section 4, we provided materials and tools used in de- veloping and implementing the application; section 5 was devoted to the evaluation and validation of the application, and in section 6, we summarize our work with conclusion and perspectives for future work. 2 Background and Related Works E-learning emerged not so long ago and, due to its novelty, it incorporates the best methodological practices and modern educational technology. These technologies such as collaborative learning, peer learning, dynamic cognitive process are currently con- sidered as the most beneficial and appropriate methods for e-learning. The aforemen- tioned technologies are active methods of training and employ a wide range of research and problem-solving techniques, application of obtained knowledge in cooperative and individual activities, development of independent critical reasoning, communication standards and the ability to perform diverse social roles in collaborative activities [6]. 2.1 Peer learning Within university courses, different forms of collaborative and peer learning are pro- gressively used in order to assist students meet an assortment of learning outcomes. According to many researchers, peer learning refers to the use of teaching and learning 116 http://www.i-jim.org Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… strategies in which students learn with and from each other without the immediate in- tervention of a teacher [7]. It allows participants to help each other to understand as well as encourage each other to work hard to promote [8]. Some examples of peer learn- ing include student-led workshops, study groups, team projects, student-to-student learning partnerships and peer feedback sessions in class [7]. The potential benefits of peer learning have long been recognized and are especially relevant today. In the literature, several research studies have been carried out. The research of [9] had an objective to enhance the protocol for mobile P2P middleware on Android Oper- ating Systems. The mobile middleware used wireless technologies such as Bluetooth, WiFi and Direct Wifi. This middleware can allow the students and staffs to communi- cate into the university campus and to share files and data without any cost. [10] maked a study about a developed social media enhanced web service called “TUT Circle”, that was dedicated for students at Tampere University of Technology (TUT). TUT Circle is built on Drupal, a content management framework, and was de- veloped by the Hypermedia Laboratory at TUT. TUT Circle promotes networking, col- laboration, and communications of small groups by allowing users to form friendships with each other, send private messages, chat, create, contribute, and comment on con- tent, exchange opinions, and share resources within and between the groups. The ob- jectives of this study were to determine if the students voluntarily utilized peer learning in order to learn with and from each other without immediate teacher intervention uti- lizing TUT Circle, the possible benefits of social media that support peer learning for students and how students experienced the use of social media in small groups. On the other hand, [11] designs a network teaching system based on P2P and stream- ing media technology. This system combines the advantages of P2P technology and Client/Server mode. [11] proposed an algorithm based on a P2P architecture to solve the problem of lack of targeted orientation for learners in the community learning pro- cess. With the improvement of learning rules, learners with similar interests have been grouped together. The case study of this self-organizing community learning system based on p2p network was applied on university computer basic courses. 2.2 Collaborative learning The modern educational community considers collaborative learning as a key ele- ment in the process of acquiring knowledge and successful practical experiences. The term “collaborative learning” refers to students’ mutual learning that encourages them to work together collectively thereby producing new scholastic achievements, ra- ther than absorbing the knowledge provided by the teacher. This learning model implies the use of small groups of students in a real or virtual class. In this context, classroom assignments are designed in such a way that all team members become interdependent, but sufficiently autonomous to master the learning materials and solve specific prob- lems [6]. In a comparison of Collaborative learning vis-à-vis traditional classroom learning, [12][13] found that a collaborative approach increases student involvement with the course as well as with each other. Also, several researchers [14][15][16] found that it increases the level of critical and active thinking, promotes problem-solving skills and iJIM ‒ Vol. 14, No. 7, 2020 117 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… increases student satisfaction. More recent analysis also supports these outcomes [17][18]. 3 Requirements and Methods In spite of P2P growth, much of P2P research and literature has focused only on explaining the technology instead of focusing on software applications. This is true across sectors, including education [19] [20], business [21] [22] and computer science [23] [24]. When applications are discussed they tend to focus on a single application [25] [26]. We are interested in exploring the potential of P2P technology for learning, particularly for developing Collaborative Learning (CL) capabilities. The purpose of this paper is to develop a new mobile application based on android system and using Java, xml and Firebase that will be detailed in next sections. Mobile applications are currently growing rapidly thanks to the success of Smartphones, including those running Android. In fact, Android, Apple and Windows Phone are the main Operating Systems for mobile phones. Nevertheless, Android has become the most used smartphone Operating System worldwide, as shown in Fig.1. In the following subsection, we will detail the architecture of the android system in order to help us understand how it works. Fig. 1. Evolution of mobile OS used in the world from 2009 to 2018 3.1 Android operating system architecture Android is an open source Linux based operating system and software platform for mobile devices. It is developed by GOOGLE. It allows developers to write code in java language [27]. There are millions of devices currently using android operating system 118 http://www.i-jim.org Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… because of its open source feature, and millions of applications currently available on app store [28]. As shown in Fig.2, the Android operating system is based on a four-tier architecture. Fig. 2. Android Operating system Architecture Linux kernel: The Android operating system is based on a Linux kernel, regularly updated according to the system versions: if the first versions used version 2.6.x of the Linux kernel the current latest versions (Android 5.x) are based on version 3.4.x of Linux. This first layer supports the management of the lower layers (process, memory, hardware layer management) as well as user rights [29]. Above the kernel is a layer of native user space, consisting of the init binary (the first process started, which runs all the other processes), several daemons and a few hundred native libraries are used throughout the system [30]. Libraries and android runtime: This level includes the layer of main system li- braries provided by third parties. These are low-level and written in C and/or C++. They provide essential services such as the 2D display library (SGL), the 3D graphic display library (OpenGL), the database library (SQLite), audio and video playback and record- ing (Media Framework), a web browser engine (WebKit) and so on [31]. At the same level as this set of libraries is Android's functional environment, based on Java technol- ogy with a unique specificity: its virtual machine optimized for mobile applications. This virtual machine, called Dalvik, is initialized by each application when it is launched and opens, for each one, a specific Dalvik that makes the OS completely mul- titasking. Dalvik comes with its specific development kit or Application Programming iJIM ‒ Vol. 14, No. 7, 2020 119 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… Interface (API) written in Java; Android applications are therefore written in Java. The Java Development Kit (JDK) for Android is, in fact, a subset of the SUN JDK and integrates part of the JDK SUN and JDK SWING classes, plus Android-specific classes [32]. Android framework: The functionalities offered by these libraries are then taken over and used by this layer as Java libraries. These provide reusable libraries and spe- cific components to particular domains. These include, for example, database libraries, telephone libraries, geographical location libraries and near-field communication li- braries [31]. The applications: Finally, applications are the last layer that completes this struc- ture. These applications can be third-party applications downloaded from the official application store, but also applications installed by default, such as the host application (also called Launcher), web browser, SMS, contacts, etc. All these applications are commonly developed in Java [31]. The next section will be devoted to the specification and needs analysis phase. 3.2 Design of function module The basic steps of mobile application development are: requirements, design, pro- gramming, testing, and implementation. Before developing our application, we must collect it needs. UML is one of the most popular traditional tools used for detailed soft- ware development planning. It helps us capturing various requirements of the users. The representation done by UML is independent of the platform and language used [33]. In this section, we will identify all the functionalities of the application according to functional and non-functional requirements. Starting with functional needs, non-func- tional needs, and finally the different use cases and their modeling with diagrams. 3.3 Functional requirements Functional or business requirements represent the actions that the system must per- form to become an operational system. They can be summarized as follows: 120 http://www.i-jim.org Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… Fig. 3. Functional requirements of our mobile app 3.4 Non-functional requirements These are the needs that characterize the system. These are performance needs, type of equipment or design type. These needs may include implementation constraints (pro- gramming language, DBMS type, operating system type, etc.). As part of this work, the application will have to be extensible, i.e. there may be have the ability to add or modify new features. • Authentication: The application will have to be highly secure because the infor- mation should not be accessible to everyone. • Ergonomics: The application must offer a user-friendly, explicit and simple inter- face to be used. • Field control: The application must have an input field controller, to avoid entering information that does not match the field types. 3.5 Identification of use cases A use case represents a set of sequences of actions performed by the system that produce an observable result of interest to a particular actor. A use case models a service provided by the system. It expresses actor/system inter- actions and provides "significant" added value to the actor concerned [34]. iJIM ‒ Vol. 14, No. 7, 2020 121 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… With reference to our application, Fig.4 shows the global UML use cases diagram of our developed application. There are seven use cases and one actor in the diagram of “EachOther” application. Through the application, actor User have to register (Sign in) by filling some basic informations such as his email, phone number, gender and pass- word). After registration, the user can log in to the application by entering his email and password. Once connected to the platform, the user can benefit from the functionalities available on our application, namely to search for collaborators by name or by compe- tencies. He can then send messages to these collaborators, as well as add them to his friends list. The user also has an interface allowing him to access the help library and search for books or links that will be useful to him in his course. Fig. 4. Representation of global Use Case Diagram of our developed application “EachOther” In what follows, we have divided this diagram into sub diagrams that describe each Use Case separately as shown in Fig.5, Fig.6, Fig.7, Fig.8 and Fig.9. Fig. 5. Use case “Authentication 122 http://www.i-jim.org Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… Fig. 6. Use case “Registration” Fig. 7. Use case “Disconnection ” Fig. 8. Use case “Search and Add ” Fig. 9. Use case “Library use ” iJIM ‒ Vol. 14, No. 7, 2020 123 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… In order to describe each Use Case in detail, we used the use case reports that are represented in Tables 1, 2, 3, 4 and 5. Use case reports convert the graphical represen- tation of use cases into a detailed report. It is easy to understand the details of the actors and the events they have carried out through this report. Table 1. Use case description for « Registration » Use case name Registration Executive Summary Allows the user to register Scenario description • Request for registration form • The system displays the registration form (user request an email, phone number, gender, password) • The user enters his information and then validates • The system checks the conformity of the information provided (A1) Precondition None Alternative (A1) In case the information provided is incomplete or incorrect, the system redis- plays the registration form and waits for the user to re-enter his information Table 2. Use case description for « Authentication » Use case name Authentication Executive Summary Allows the user to log in Scenario description • Connection request; • The system displays the authentication form (email request and pass- word); • The user enters his login and password and then validates; • The system checks the conformity of the information provided (A1); • The system gives access to the corresponding interface Precondition To be registered Alternative (A1) In case the information provided is incomplete or incorrect, the system re- displays the authentication form and waits for the user to re-enter his infor- mation Table 3. Use case description for « Disconnection » Use case name Disconnection Executive Summary Allows the user to log out Scenario description • Access to the application • Access to the application menu • Click on the "disconnect" button • The application automatically returns the home page Precondition To be logged in Table 4. Use case description for « Search and Add» Use case name Search and Add Executive Summary Allows the user to add people from a list after making a search Scenario description • The user does a search by name or by competency • Add to friends list Precondition None 124 http://www.i-jim.org Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… Table 5. Use case description for « Library use » Use case name Library use Executive Summary Allows the user to search for books or links Scenario description • Search for books • Search for links Precondition None 3.6 Application class diagram The class diagram is considered the most important part of object-oriented modeling. It is mandatory when such modeling is performed. It shows the internal structure and provides an abstract representation of the system objects that will interact to realize the use cases. The class diagram of our application is shown in Fig.10. Fig. 10. Class Diagram of the application “EachOther” 4 Materials and Tools This section is dedicated to the study of our "Each Other" application, we will present the development tools adopted, namely the environment used which is Android, as well as the programming languages (JAVA, XML). 4.1 Development tools In the development of this application, we have used Android and Java, as well as XML for establishing the user interface properly. This app is built on Android Studio and we used Firebase as database server which is a real-time database allowing authen- tication, storage, crash reporting, analytics and cloud messaging. Firebase is a NoSQL database hosted “in the cloud" allowing the storage and synchronization of users’ data. As a developer, we can manage this database in real time. It is delivered with mobile and web SDKs and allows creating applications without using servers. iJIM ‒ Vol. 14, No. 7, 2020 125 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… Each version of Android is associated with a version of an emulator, allowing the developer to see exactly what its application will look like on real hardware. For our mobile application we used the emulator Nexus 4 API 27. Fig. 11. An extract from the java code of the application 4.2 The implementation of P2P based mobile app for collaborative learning (EachOther App) This section is dedicated to the production and implementation of our application of peer learning. We will present the main interfaces of the application, as well as the description of each one. Fig.12. The main interfaces of our application « EachOther » 126 http://www.i-jim.org Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… • Home interface: this is the first view that user will see when he enters the app. It shows the icon of the app and the button to register “Sign in”. • Registration interface: This is the interface for creating a new account. On this inter- face, the user has to enter a name, an email, a password and define his gender, then click on the "Sign in" button. • Authentication interface: after registration, the user can enter his email and password and click on the “login” button in order to access to the functionalities of the appli- cation. • Suggestion list interface: When the user logs into his account, this interface displays and shows him a list of suggestions of collaborators. Once he clicks on a collabora- tor, it displays to him the collaborator’s name and skills and then the user can add these collaborators to his list of friends. • Skill search interface: the user can search by skills on people and then add them to his friend list. • Friend list interface: this interface displays the list of the user's friends added by search by skill or by name. • Profile editing interface: This interface offers the possibility to modify and edit the user's profile such us changing the name, the email and adding or removing compe- tencies. • Suggestion book interface: this interface contains books with the ability to open each book that the user can read. • Links suggestion interface: it offers the possibility to search on links of books and open them on the server. 5 Evaluation and Validation of the Application Regarding our developed mobile application, it was tested by 40 undergraduate stu- dents in second year of "Database Administration" class, at the High School of Tech- nologies of SMBAU. The students were requested to install and use the mobile appli- cation during semester 4 (8 weeks course). We used a questionnaire to evaluate our application and its impact on academic performance of students. iJIM ‒ Vol. 14, No. 7, 2020 127 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… The results of the above survey show that the majority of students are interested in peer learning. Only a few students are not interested in peer learning. However, some students reported that most students who achieve good grades do not take a full interest in peer learning because they feel they can easily help students who are lazy and who get low grades. All students of “Database Administration” class have used the mobile application for P2P learning. The majority of students (95%) find the application easy and simple to use. While (5%) encountered some difficulties in use mainly related to the Internet connection. Performance of student is also influenced by the frequency of use of the P2P learning mobile app. So, from the above results, students said that majority of them use the mo- bile app about 2 hours per week. 128 http://www.i-jim.org Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… To make peer learning be more effective, it is better for students to schedule their use of the mobile app. The analytical result revealed that the majority of students plan to use the mobile application for P2P learning. While other categories of students use the application when necessary, for example if they cannot understand concepts in their class session or when solving exercises or homework. Students were asked if their participation in P2P learning through the mobile appli- cation had a positive impact on their academic performance. Indeed, almost all students believe that participation in P2P learning can improve their academic performance. In addition, the majority of students reported that their academic performance had im- proved significantly by using the mobile app for P2P learning. Through the scores obtained by the students in their assessment, we have noticed an improvement in academic performance of the majority of students (90%) who have used the application. While some students (10%) have kept the same level before using the application. So, our application does not cause any degradation of the level of the students who use it, rather, it often allows an improvement of their academic perfor- mance. The major purpose of using “EachOther” for the majority of students (65%) was to get better marks in their exams, while 15% of students use the application in order to better understand their courses. The rest of students wants to enrich their knowledge and so on. 6 Conclusion and Future Work For many students at university, the opportunity to learn with and from others is a preferred learning method. Peer learning give the students the ability to develop skills iJIM ‒ Vol. 14, No. 7, 2020 129 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… and competences such as teamwork. Our developed application is used as a learning tool for the purpose of enhancing students’ collaboration, communication and network- ing skills as well as promoting peer learning in small groups. In this paper, we present the design and implementation of P2P based mobile app for collaborative learning in Higher Education and especially the High School of Technol- ogy of Sidi Mohamed Ben Abdellah University (ESTF) as a case study. We started by collecting the needs of the mobile application and identifying all its functionalities. For this step, we used Unified Modeling Language (UML). Then, we described the devel- opment of the mobile app, in which we used the Android mobile platform, Java and xml for programming languages and FireBase for data management. After that, we showed some interfaces resulting from the implementation of the mobile app. We tested our developed application on 40 participants representing undergraduate students of "Database Administration" class, at the ESTF. The experimental results re- veal that the proposed mobile app is able to improve the academic performance of stu- dents and to enhance collaboration between them. As future work, we aim to integrate learning analytics tools which gives possibilities to check student interaction and collaboration activities, and observe the evolution of student participation. These tools may also help students to monitor and evaluate their performance processes and learning outcomes, thereby increasing their motivation, and make strategic directives to improve their performance. 7 References [1] M.Sharples, J.Taylor, and G. Vavoula, “Towards a theory of mobile learning”, Proc. mLearn 2005, vol. 1, no. 1, pp. 1–9, 2005. [2] Blilat A., Ibriz A. (2020) A New Architecture of Service Composition-Based Context- Aware Mobile Learning System. In: Ezziyyani M. (eds) Advanced Intelligent Systems for Sustainable Development (AI2SD’2019). AI2SD 2019. Advances in Intelligent Systems and Computing, vol 1102. Springer, Cham, https://doi.org/10.1007/978-3-030-36653-7_3 [3] J.Sampson, D.Boud, R.Cohen and F.Gaynor, “Designing peer learning”, HERDSA Annual International Conference, Melbourne, 12-15 July 1999 [4] A-M. Tervakari, K. Silius, T. Tebest, J. Marttila, M Kailanto and J. Huhtamäki, “Peer Learn- ing in Social Media Enhanced Learning Environment”, iJET – Volume 7, Issue 3, September 2012. https://doi.org/10.3991/ijet.v7i3.2173 [5] T. Kato, N.Ishikawa, H.Sumino, J.Hjelm, Y.Yu, S.Murakami, “A Platform And Applica- tions for Mobile Peer-to-Peer Communications”, ( 2000). [6] O.V. Sumtsova, T.Y.Aikina, L.M. Bolsunovskaya, C.Phillips, O.M. Zubkova, P.J. Mitchell, “Collaborative Learning at Engineering Universities: Benefits and Challenges”, iJET ‒ Vol. 13, No. 1, 2018. https://online-journals.org/index.php/i-jet/article/view/7811. https:// doi.org/10.3991/ijet.v13i01.7811 [7] D.Boud, R.Cohen and J.Sampson, “Peer learning and assessment, Assessment and Evalua- tion in Higher Education”, 24, 4, 413-426. https://doi.org/10.1080/0260293990240405 [8] V.Allee, “Knowledge networks and communities of practice”, OD Practitioner, Journal of the Organization Development Network, Vol. 32, (2000). http://www.odnetwork.org/od- ponline/vol32n4/knowledgenets.html (accessed 20 November 2002). 130 http://www.i-jim.org https://doi.org/10.1007/978-3-030-36653-7_3 https://doi.org/10.3991/ijet.v7i3.2173 https://online-journals.org/index.php/i-jet/article/view/7811 https://doi.org/10.3991/ijet.v13i01.7811 https://doi.org/10.3991/ijet.v13i01.7811 https://doi.org/10.1080/0260293990240405 ).%20http:/www.odnetwork.org/odponline/vol32n4/knowledgenets.html ).%20http:/www.odnetwork.org/odponline/vol32n4/knowledgenets.html Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… [9] W.A. Jabbar, M. Ismail and R. Nordin, “Framework for Enhancing P2P Communication Protocol on Mobile Platform”, The International Conference on Informatics & Applications (ICIA 2012), June 2012, Malaysia [10] A.-M. Tervakari et al., “Developing Learning Analytics for TUT Circle”, IFIP International Federation for Information Processing 2013, pp. 101–110, 2013, https://doi.org/ 10.1007/978-3-642-37285-8_11 [11] Zumin Liu , Shiying Zhang , “Self-organizing Community Learning Based on P2P Network in a University Computer Foundation Course”, International Journal of Emerging Technol- ogies in Learning (iJET), Vol 13, No 07, (2018), https://doi.org/10.3991/ijet. v13i07.8787 [12] K.G.Collier, “Peer-group learning in higher education – the development of higher-order skills”, Studies in Higher Education, (1980) Vol. 5, pp.55–62. https://doi.org/10.1080/030 75078012331377306 [13] J.Cooper, S.Prescott, L.Cock, and L.Smith, “Cooperative learning and college instruction’, Cooperative Learning Users”, Group, Dominguez Hills, CA: The California State Univer- sity. [14] D.A.Bligh, (1972), “What’s the Use of Lectures?”, Harmondsworth, England: Penguin. [15] W.J.McKeackie,” Learning, Cognition, and College Teaching”, San Francisco, CA: Jossey- Bass. [16] J.A.Kulik, and C.L.C.Kulik, “College teaching”, in P.L. Peterson and H.J. Walberg (Eds.) Research on Teaching: Concepts, Findings, and Implications, Berkeley, CA: McCutcheon. [17] Y.Lou, P.C.Abrami, J.C.Spence, C.Poulsen, B.Chanbers, and S.D’Apollonia, “Within-class grouping: a meta-analysis”, Review of Educational Research, Vol. 66, pp.423–458. https://doi.org/10.3102/00346543066004423 [18] C.A.Rohrbeck, M.D.Ginsburg-Block, J.W.Fantuzzo, and T.R.Miller, “Peer-assisted learn- ing interventions with elementary school students: a meta-analytic review”, Journal of Ed- ucational Psychology, Vol. 95, pp.240–257, (2003). https://doi.org/10.1037/00220663. 95.2.240 [19] K.M.Fletcher, “Peer-to-peer networks and opportunities for alignment of pedagogy and technology”, AACE Journal, Vol. 12, pp.301–313, (2004). [20] J.Kook, “The internet and peer-to-peer computer networking: the principal attributes of P2P learning”, WebNet Journal: Internet Technologies, Applications & Issues, Vol. 3, pp.39–44, (2001). [21] Gartner, “Forecast: e-learning software, worldwide, 2002–2008”, Gartner report, (Executive Summary), Gartner, http://www.gartner.com/. [22] R.B.Kini, “Peer-to-peer technology: a technology reborn”, Information Systems Manage- ment, (2002) , Vol. 19, pp.74–85. https://doi.org/10.1201/1078/43201.19.3.20020601/ 37173.10 [23] H.M. Fattah,” P2P: How Peer-to-Peer Technology Is Revolutionizing the Way We Do Busi- ness”, (2002), Chicago, IL: Dearborn Trade Pub. [24] M.D.Lytras, A.A.Tsilira, and M .Themistocleous, “Technology classification framework for e-learning purposes from a knowledge management perspective”, Americas Conference on Information Systems, Tampa, Florida, (2003b). [25] K.Curran, “Peer-to-peer networking collaboration within education”, Journal of Educa- tional Multimedia and Hypermedia, (2002), Vol. 11, pp.21–30. [26] G.Leighton, and T. Müldner, “Applying peer-to-peer technology to the building of distributed educational systems”, Journal of Interactive Learning Research, (2005), Vol. 16, pp.295– 315. iJIM ‒ Vol. 14, No. 7, 2020 131 https://doi.org/10.1007/978-3-642-37285-8_11 https://doi.org/10.1007/978-3-642-37285-8_11 https://doi.org/10.3991/ijet.v13i07.8787 https://doi.org/10.3991/ijet.v13i07.8787 https://doi.org/10.1080/03075078012331377306 https://doi.org/10.1080/03075078012331377306 https://doi.org/10.3102/00346543066004423 https://doi.org/10.1037/00220663.95.2.240 https://doi.org/10.1037/00220663.95.2.240 https://doi.org/10.1201/1078/43201.19.3.20020601/37173.10 https://doi.org/10.1201/1078/43201.19.3.20020601/37173.10 Paper—Design and Implementation of P2P Based Mobile App for Collaborative Learning… [27] P. Khanna, A.Singh,” Google Android Operating System: A Review”, International Journal of Computer Applications, 147(4), pp.26-29, 2016. https://doi.org/10.5120/ijca20169 11008 [28] A.Nazeeh, W.Isam, “Comparison of Android and iPhone Operating System”, International Journal of Computer Applications, 167(2), pp.6-11, 2017. https://doi.org/10.5120/ijca2017 914173 [29] H. Sylvain, Développez une application Android programmation en Java sous Android Stu- dio. Septembre 2015. [30] N. Elenkov, Android Security Internals An in-Depth Guide to Android’s Security Architec- ture. 2015. [31] S.P.Hébuterne Sylvain, Android Guide de développement d’applications Java pour Smart- phones et Tablettes. 2ème édition, 2014. [32] U.Serge, Développez une application Android Programmation en Java sous Eclipse. 2ème édition, juin 2013. [33] Z.Wang, “The Study of Smart Phone Development Based on UML”, June 2011, DOI:10.1109/CSSS.2011.5973939 [34] B.Dhupia, S.Rubab, N.Litayem, “Extracting use Cases from Mobile Educational Applica- tions Requirements”, International Journal of Engineering Research & Technology, Vol. 4 Issue 04, April-2015, pp.883–887. https://doi.org/10.17577/ijertv4is041151 8 Authors Asmae Blilat (corresponding author) is a Networks and Telecommunication Engi- neer, from the National School of Applied Sciences of Fez, Morocco (ENSA), and cur- rently a Phd student at Transmission and Information Processing Laboratory LTTI, Sidi Mohamed Ben Abdellah University (SMBAU), Fez, Morocco, and a part time lecturer in the Department of Electrical Engineering and Computer Science at the Higher School of Technology, SMBAU, Fez, Morocco. Abdelali Ibriz is an HDR professor (French Acronym: Habilité à Diriger des Re- cherches) in the Department of Computer Science at the Higher School of Technology, Sidi Mohamed Ben Abdellah University (SMBAU), Fez, Morocco. Dr. Ibriz's research interests include Computer Systems Design, Cloud Computing, Resource Allocation and Scheduling and Real-time Distributed Systems, Elearning and Pedagogical Ap- proaches. Professor Ibriz has authored and co-authored several technical papers and book chapters including paper that earned best paper awards at international confer- ence. Currently, he is a member of the Laboratory of Innovative Technologies and Di- rector of the Elearning Center of the Sidi Mohamed Ben Abdellah University. Article submitted 2020-01-13. Resubmitted 2020-02-04. Final acceptance 2020-02-05. Final version pub- lished as submitted by the authors. 132 http://www.i-jim.org https://doi.org/10.5120/ijca2016911008 https://doi.org/10.5120/ijca2016911008 https://doi.org/10.5120/ijca2017914173 https://doi.org/10.5120/ijca2017914173 https://doi.org/10.17577/ijertv4is041151