Abstract

Device-to-device (D2D) offloading has been shown to be a highly effective technique to enhance the performance of wireless networks. Yet, for any two mobile users to share data efficiently and reliably via D2D links, they should be in close proximity for long enough period of time, share similar content interests, and have some level of incentive and trust to cooperate. In this work, we focus on the practical implementation aspects of D2D data sharing taking into account realistic operational conditions. To this end, we design and conduct an experimental study to collect location and neighbor discovery data from 38 mobile users in a university campus over several weeks using our own customized crowdsourcing Android mobile application. The collected data is then processed and utilized to empirically model mobility-related parameters that include contact frequency, contact duration, and inter-contact duration. The participating users did also fill a user interest survey in order to correlate mobility and connectivity patterns with content interests and social network relations. The obtained insights are then used to develop a practical implementation framework for designing effective D2D data sharing strategies. To test the proposed ideas under realistic operational constraints, we design and implement a social-aware D2D data sharing Android mobile application and demonstrate its functionality and effectiveness using an example case study scenario.

1. Introduction

The computing and communications capabilities and the user-friendly interfaces of smartphones are facilitating the creation and sharing of content between devices without relying on existing wireless infrastructure, such as WiFi access points or cellular base stations [13]. Data sharing over device-to-device (D2D) links has been shown to provide a multitude of performance gains in terms of throughput and spectral efficiency enhancement [46], energy consumption reduction [710], and end user cost savings and incentives [1113]. However, reliable and efficient D2D data sharing in practice hinges on several factors that include content availability, users’ proximity and ability to connect to each other, users’ mobility patterns, and contact intervals [14], in addition to other aspects such as cooperation incentives and trust establishment [15, 16].

Supporting D2D communications in wireless networks can be achieved with different levels of network operator assistance ranging from full to partial to none; for example, see [17, 18]. We focus on a fully device-centric approach which requires direct coordination and communication between the devices over short-range wireless links (e.g., Bluetooth or WiFi-Direct) via mobile application solutions. This makes the proposed ideas and techniques independent from existing long-range wireless technologies such as WiFi or cellular networks and, thus, does not require any modification to existing wireless standards.

The main objective of this work is to address practical aspects of D2D data sharing following an experimental approach using our own developed crowdsourcing Android mobile application in order to capture realistic system and performance constraints. We model empirically key metrics for effective D2D data sharing including the number of contacts, contact duration, and inter-contact duration among a set of mobile users in a bounded geographical environment. We complement these empirical models with data collected via user surveys on content similarity and social networking relations. We then overlay the contact models, content similarity, and social relationship links to generate novel insights that can help in designing efficient and reliable D2D data sharing strategies. Finally, we demonstrate the practical feasibility of the various presented ideas by performing experiments using our own developed social-aware D2D data sharing solution based on an Android mobile application. The key novelty of our work is twofold: (i) holistic approach by jointly capturing within one framework the users’ mobility and inter-contact statistics, content interests, and social relations; (ii) experimental methodology with empirical models in order to obtain practical results that can bridge a gap between theoretical studies and real wireless devices, systems, and technologies.

In the literature, there have been several experimental studies focused on mobility and contact modeling for D2D data sharing. In [19], location data was collected by using LifeMap application on mobile devices carried by four graduate students for eight weeks in a 15 × 20 km2 area in Seoul, Korea; mobility information was used to devise an efficient routing algorithm that learns the users’ mobility patterns and predicts future interactions. In [20], the authors gathered traces on a university campus using HYCCUPS tracer [21], a mobile application running in the background that collects information about a device’s encounters with other nodes or access points. Information was gathered via Bluetooth and AllJoyn. This experiment spanned 64 days and involved 66 participants. A node’s past encounters were analyzed and their time series was approximated as a Poisson distribution, representing the probability that a node will make a given number of distinct contacts within a specific time frame. The authors show that the Poisson distribution prediction is accurate if computed as an average per hour per day of the week, since academic schedules are repetitive and have an hour as a unit of time. In [22], six different traces were analyzed to study smartphone mobility. Data was gathered via WiFi, GPS, GSM, and Bluetooth. Analysis of these traces showed a power-law distribution of inter-contact time between smartphones up to a characteristic time, then an exponential decay. In [23], the number of connected pairs over time was evaluated, taking into consideration multihop contacts; it was observed that number of nodes in -contact is much larger than the number of nodes in direct contact. All these references do relate to the scope of our work, yet they are mostly focused on mobility and contact duration modeling and analysis without capturing the other dimensions of content similarity and social relations. Moreover, they demonstrate the importance of relatively small-scale experimental studies in a bounded geographical areas as they can provide insights into use cases with hot spot locations and homogenous communities (e.g., university campuses, schools, factory facilities, and enterprises).

Another line of related work in the literature has focused on content similarity among mobile users. For example, in [24], data was collected from various services to obtain the distribution characteristics of requests across videos, the evolution of viewer’s focus, and the shifts in content popularity; data was collected by crawling the websites of four different online video providers. User generated content was modeled using a power law with a truncated tail probability distribution due to the fetch-at-most-once user behavior in peer-to-peer environments. The effect of this behavior is amplified when the number of videos is small and/or the average number of requests per user is large. The authors in [25] collected a list of shared iTunes songs from 239 users in 2006 at University of Missouri School of Journalism. The popularity distribution of song names proved to follow a Zipf-like distribution in a log-log scale, indicating that few objects are extremely popular while many objects are rare. User availability information was also collected and the number of unique users seen daily was plotted. The authors in [26] measured a file’s popularity by its replication degree. They observed that few files are highly replicated, while most are not replicated at all. Another observation was the correlation between geographical clustering and video files: peers requesting a certain video file are more liable to download it from peers in their own country, thus reducing the delay and download time. In our work, we consider content interests within a given community in a university campus environment which will lead to new perspectives that do complement insights generated from the large-scale studies discussed above.

Recently, there has been increased interest in utilizing social networking relations among users to leverage content downloading and sharing for improved quality of experience. In [27], the authors presented interesting observations on the benefits of exploring social relations to enhance the performance of D2D communication systems and used simulation studies based on real traces. In [28], the authors proposed a novel framework to extract useful information from social networks and utilize it to improve the performance of D2D communications; they applied their framework to the problem of spectrum sharing for in-band D2D communications and presented numerical results to show significant improvements in spectrum utilization efficiency. The authors in [29] defined social spreading impact and mobility patterns of users to evaluate one’s significance in propagating posts and sharing content via encounters; several factors were integrated in a social-aware D2D sharing framework to achieve major offloading of mobile traffic while satisfying users’ delay requirements. From a different perspective, the authors in [30] used social relationship among users to address the problem of optimal peer selection in cooperative D2D communications to enhance data privacy in dynamic scenarios where users move within a given area. Users that suffer from poor channel quality opt to use nearby users with close social relation as relays to protect their privacy. Simulation results demonstrated the effectiveness of the proposed physical-social model to provide better data rates while protecting privacy. In [31], the authors considered social relations and user mobility attributes to select core users that may reliably and effectively assist base stations in distributing video content through D2D multicast. In [32], the authors utilized user mobility, opportunistic encounters, and social relations to build D2D data dissemination model based on a three-phase approach with analytical and simulation based performance analysis. In [11], the authors proposed the integration of a social networking layer to enhance the efficiency of physical D2D communications using an analytical approach based on Indian Buffet Process with evaluation using simulation results based on real traces. This summary of selected recent works from the literature demonstrates the benefits of utilizing metrics based on social networks’ relationships in the design of D2D data sharing mechanisms; this is one of the key components of our proposed framework and analysis.

The rest of the paper is organized as follows. We describe in Section 2 the experimental study design and tools including the data collection process. We summarize in Section 3 the obtained mobility and content similarity related results, in addition to the derivation of empirical models with discussion and analysis. We then present in Section 4 a practical framework for designing effective D2D data sharing strategies, in addition to the architecture, implementation, and evaluation of a social-aware mobile solution for dynamic D2D data sharing using Android devices. Finally, conclusions are drawn in Section 5.

2. Experimental Study: Design

Our experimental study design consists of two independent and complementary phases: a mobility-related data collection phase and a content similarity data collection phase.

2.1. Mobility-Related Data Collection

Mobility-related data is collected using our own crowdsourcing mobile application called Context Aware Resource Management App, or CARMA for short (see Figure 1 for snapshots of the graphical user interface). CARMA runs in the background on Android smartphones and collects seamlessly device location and neighbor discovery information and then uploads the data points periodically to a database at a remote server.

This database contains two tables: Data and Neighbors. The information stored in the Data table is as follows: time stamp (msec), device ID, number of bytes sent and received, battery percentage, latitude, longitude, accuracy, and location provider. As for the Neighbors table, the data stored includes the following: time stamp (msec), device ID, discovered device name and MAC address, latitude, longitude, and accuracy.

The aim of this experimental study is to collect data in a confined and controlled environment, with a pool of participants having different pairwise contact frequencies; the scale of the study is similar to [19], yet the dynamics of the environment are different. Data collection was done in two stages on the 60.9 acre campus of the American University of Beirut (AUB): the first stage during the 2015 spring semester and the second stage during the 2015 summer semester. The first stage started on March 9, 2015, and ended on May 20, 2015, for a duration of 11 weeks with 37 mobile user participants. Data collection frequency for both neighbor discovery and location information were set to 10 minutes, resulting in 21,289 Neighbors table entries and 354,528 Data table entries stored in our database. The second stage started on June 11, 2015, and ended on July 6, 2015, for a duration of approximately 4 weeks with 13 mobile user participants. Neighbor discovery interval was set to one minute, while location information was logged every two minutes. Consequently, 34,920 Neighbors table entries and 326,539 Data table entries were stored in the database. In Section 3, we will use this collected data to derive empirically the cumulative distribution function (CDF) of various mobility-related metrics that include number of pairwise contacts with respect to day and time interval aggregated over all device pairs, in addition to contact and inter-contact durations.

2.2. Content Similarity Data Collection

Due to privacy limitations, it was not possible to activate the tracking of users’ stored content and download activity on their devices using the CARMA mobile application. To deal with this constraint, we designed and deployed an online survey to collect relevant content similarity data from mobile users including a subset who participated in the mobility-related data collection experiment. The survey has 28 questions that focus on users’ interests and content stored on their smartphones, downloaded or shared, as well as on social network activity.

The survey questions were divided into five groups, each centered around a certain aspect that relates to D2D data sharing. The first group of questions focused on the type of files stored on the user devices, as well as on the user interests in the five categories of files mentioned. The second group inquired about the users’ sources of media files. The third group concentrated on the number of files stored and streamed on the users’ devices. The fourth group served to assess the users’ willingness to download and share their files via direct D2D data sharing. The final group captured the users’ social activity regarding four social networks: Facebook, Instagram, Twitter, and LinkedIn. Using the data collected, content similarity level between any two users can be calculated. To correlate the survey’s results with the mobility and contact data analysis, participants were asked to include their names along with their responses. We received 31 responses in total for the survey, including 12 who included their names and participated in the mobility-related data collection experiments.

Table 1 summarizes key parameters related to the experimental study for both stages. In the data collection stage during the summer, we decreased the location data collection frequency and the neighbor discovery frequency since the duration of the summer term is shorter than the spring term and the number of participants is relatively lower. This facilitated the collection of enough data to generate reliable models and helped capture user mobility at a faster rate.

As in [19, 20], even though the data collected is of relatively limited size and focused on a hot spot geographical area, it provides important insights as dynamic and effective D2D data sharing is expected to be more feasible in closed communities with low mobility and high level of trust; in addition, it can lead to useful observations on how to scale up to wider geographical regions with larger density of mobile users. Having existing similar published experimental studies does not diminish the value of our experimental work as every study focuses on different goals and has its own specificities due to the variations in the environment and users’ mobility patterns. The outcomes of these various studies provide real traces that can be valuable to other researchers for evaluation purposes.

3. Experimental Study: Results and Analysis

In this section, we present a summary of the obtained results from the two stages (spring semester experiment and summer semester experiment) of data collection using CARMA; we use this data to derive several empirical models for mobility-related metrics that would be useful for future studies and enhancements related to D2D communications. Moreover, we analyze the user survey results and social network relations to correlate content similarity and social links with mobility and contact data in the context of D2D data sharing between mobile users in a given geographical area.

3.1. Mobility-Related Parameters
3.1.1. Number of Contacts

The number of contacts between two devices is a key measure to determine whether D2D data sharing is likely between them. The CDF of the normalized number of contacts per day and that of the normalized number of contacts per time interval are derived empirically using the collected data. The empirical aggregated CDF for the normalized number of contacts per day, as well as per time interval, are shown in Figures 2 and 3 to follow a Gamma distribution with an acceptable accuracy level. The Gamma distribution is given by the following:where is the shape parameter, the scale parameter, and the incomplete Gamma function. The Gamma distribution parameters for the data collected from both semesters are presented in Table 2.

Referring to Figure 2, 80% of the number of contacts recorded are less than 61 contacts per day during the sample results from the spring data collection stage, and less than 2,118 contacts per day during the summer data collection stage. The disparity in scale between these two numbers is due to the different neighbor discovery data collection frequencies between spring and summer stages (set to 10 minutes in the spring compared to 1 minute in the summer). Referring to Figure 3, 80% of the number of contacts recorded are less than 15 every four hours during the spring, and less than 125 every four hours during the summer, provided that these four-hour time intervals fall during workdays. We notice that the distribution of the number of contacts is steeper in the summer in comparison with the spring. This means that, during the spring, the number of contacts is well distributed within the ranges 1 to 61 per day or 1 to 15 per time interval. On the other hand, during the summer, the number of contacts is distributed unevenly with values having mostly small or large values and with few values being in the middle of the ranges (1 to 2118 contacts per day and 1 to 125 contacts) per time interval. These results demonstrate the notable variability in users’ group behavior during different time periods (spring versus summer) even with a homogenous group of users in the same geographical area.

Additionally, we investigate how the number of users in a study affects the statistics of the total number of contacts. Thus, we arbitrarily select different sets of users of size ranging from 5 to 25. We start with a set of 5 users and then incrementally increase by 5 additional users up to 25. The total and average number of contacts with respect to day and time interval are plotted in Figures 4 and 5. As expected, the larger the set of users, the higher the number of contacts obtained, yet the relation is not necessarily linear. In addition, the average number of contacts per user is dependent on the selected set of users.

We also calculate the pairwise number of contacts, defined as the number of contacts between a specific user pair, for both semesters (see Figure 6). We obtain an average of 155 contacts per pair, with a minimum of 1 contact per pair and a maximum of 1867 contacts per pair during the spring. During this semester, the following five pairs show an exceptionally high number of contacts: , , , , and . As for the summer, the maximum pairwise number of contacts is 1965, the minimum is 2, and the average is 265. Three pairs show an exceptionally high number of contacts: , , and . For example, user device 3, which participated in both data collection phases, is shown to have consistently a high number of contacts with its neighbors. Thus, device 3 can be considered as a reliable source for D2D data sharing use cases and, thus, can be labeled as reliable collaborator and provided with incentives to help offload network traffic; it can be also targeted for mobile caching services.

3.1.2. Contact Duration

The pairwise contact duration CDF aggregated over all users is studied with respect to day and time (see Figures 7 and 8). In both cases, the CDF is shown to follow accurately a lognormal distribution:where and are the location and scale parameters, respectively. The obtained empirical parameter values for selected time windows during spring and summer stages are summarized in Table 3.

For example, results show that 80% of the pairwise contact duration values recorded are less than 125 minutes per the selected day during the spring and less than 20 minutes during the summer. On the other hand, 80% of the pairwise contact duration values recorded are less than eight minutes per the selected four-hour interval during the spring and less than 12 minutes during the summer. The contact duration is a critical factor in D2D data sharing applications as it determines the time needed to download a given content (or parts of it) as a function of the communications bit rate quality between the cooperating devices.

3.1.3. Inter-Contact Duration

We have also analyzed the inter-contact duration statistics per day and time interval. The inter-contact duration is defined as the time period between two contact events for given a pair of users; that is, it captures the time during which the users are not in proximity with respect to each other. For example, results show that, during the spring, 479 inter-contacts occurred during the whole trace, with a minimum duration of 10 minutes, a maximum duration of approximately 58 days, and an average duration of approximately 26 hours. However, during the summer, 1111 inter-contacts occurred during the whole trace, with a minimum duration of 1 minute, a maximum duration of approximately 5 days, and an average duration of around 46 minutes. Note that the minimum durations are determined by the neighbor discovery frequency parameter which was set to 10 minutes and 1 minute during the spring and summer data collection stages, respectively (see Table 1).

3.2. Content-Related Parameters

The content similarity analysis is solely based on the survey responses. Based on the 31 responses received, statistics show that the majority of the responders store about four to six media files per day on their hand-held devices. The files they store are distributed to include all seven categories considered (personal documents, public documents, personal images, public images, personal videos, public videos, and music) with high percentages. Even though personal files occupy the majority of files stored by the participants, public media files also occupy a high percentage of user storage with the most popular file type being images, followed by music. Table 4 presents a summary of the survey results relating to users’ interests. When asked about their source of music, responders mostly use online sharing (download) websites such as Rapidgator, rather than streaming websites. However, the majority of responders prefer streaming videos rather than downloading and storing them on their devices. In general, most responders stream less than 10 music and/or video files per week. As for the total number of music files stored on their devices, the majority of our responders have less than 50 files; the same applies to document and video files. As for image files, the majority of the responders (83.9%) have more than 300 files stored on their devices.

Furthermore, when asked about D2D data sharing, responders indicated that they are willing to share and/or download all file categories over direct D2D links, that is, documents, images, videos, and music, with music (90.32%) and videos (87.1%) being the most popular choices. As for incentives to share files with neighboring devices using D2D links, 61.3% were favorable without any incentives and 96.8% were favorable when incentives are offered. The most popular incentives were extra 3G/4G cellular data quota (90.3%), followed by free call minutes for each file exchanged (58.1%) and credits for online shopping (54.9%).

For the content similarity analysis, two parts of the survey are relevant: the one related to user interest and the one related to the device content. A weight is calculated for each part by taking the number of common answers between any two participants divided by the corresponding total number of questions as follows:The final content similarity weight is then calculated as the average between these two weights as follows:These have been only calculated for the responders who participated in the CARMA data collection phase during the spring semester. Responses are available for eight CARMA participants, since the rest did not include their names in their survey responses. The ID of these participants are .

The similarity matrix of the content similarity between the spring participants’ devices is calculated according to (4) as follows:

3.3. Social Network Relationships

The social relationship strength is analyzed using the survey participants’ Facebook friends lists. In order to correlate mobility and content similarity results with participants’ social network relationships, the number of mutual friends is considered to assess the strength level between any two participants. The number of mutual Facebook friends between participants is presented in the matrix for the eight spring semester participants who also filled the user survey. The number of mutual friends compared to oneself is set to zero to simplify the graph construction.

3.4. Correlation between Mobility Parameters, Content Similarity, and Social Network Links

In this section, the social relationship strength, the content similarity, and the number of pairwise contacts are correlated to identify favorable quantifiable conditions for successful D2D file sharing. The correlation between mobility, content, and social networks is done only for the spring semester, with results being summarized using graphs in Figure 9. Note that the thicker the edges connecting any two vertices, the higher the layer-respective measure. Looking at this figure, for each user pair one can roughly determine whether they have the potential to successfully share files via D2D links. When the edges connecting a pair of users are thickest on the three levels simultaneously, a D2D link has the highest chance of being successful while keeping in mind the constraints pertaining to the contact and inter-contact durations.

The aggregation of the three layers is visualized in Figure 10; the thicker the edges connecting any two vertices, the higher the correlation between the pairwise social relationship strength, content similarity, and number of contacts. Dotted edges indicate a correlation that allows only opportunistic or limited D2D data sharing, due to the low pairwise number of contacts. For example, according to Figure 10, pairs , , , and have the highest chance of success in D2D data sharing as they meet the various conditions needed for successful cooperation. It is interesting to note that several edges are correlated across the three layers which reflects the potential for direct D2D data sharing mobile applications in practice.

4. Social-Aware D2D Data Sharing Mobile Solution

In this section, we use the insights derived from the mobility and content similarity experimental measurements and models from Section 3 in order to shed light on the design of practical D2D data sharing strategies. Even though our experimental study was confined to a limited geographical area, it does provide important information for similar hot spot scenarios and can serve as a best case for larger scale scenarios where mobile users are more spread geographically with high mobility and belong to diverse communities.

4.1. Practical Design Considerations

The following is a summary of key factors to design practical D2D data sharing strategies:(1)Social network relationship between users is a prerequisite enabler for D2D data sharing, as its strength is an indicator of the users’ level of trustworthiness with respect to each other; for example, see [14, 15, 27]. The importance of using social network relationship as a trust level indicator is that it can be implemented seamlessly within D2D data sharing mobile solutions without the need for direct user intervention or dedicated server authentication. Mobile applications can extract and aggregate this information using existing social media APIs.(2)For a user to download a data file over a direct D2D connection, the content of interest should be available in one of its neighboring devices. This requires running service and peer discovery procedures to identify devices that are willing to cooperate and within radio range from the requesting device; this will be followed by content discovery phase to check if any of the trusted devices has the content locally cached. The user survey results presented in Section 3.2 demonstrated that users in hub locations (such as university campus and factory facility) do indeed have common interests when it comes to types of content stored on their devices; yet, the survey also confirmed the need to provide attractive incentives for users to accept to participate.(3)In addition to trust, incentives, and content availability, D2D data sharing success depends on the number and duration of contacts between a pair of users over time and space. Let represent the pairwise number of contacts, the pairwise contact duration, and the pairwise inter-contact duration over a given period of time where and are device indices. The five cases in Table 5 summarize a set of conditions for designing decision making strategies in D2D data sharing mobile solutions.

The experimental measurements and derived empirical models in Section 3 can be utilized for multiple purposes. First, they can be used to derive theoretical performance results quantifying the probability of successful content sharing over D2D links in a given hub location as a function of parameters such as content size, content availability probability, and content download delay target; the models are generic and parameterized which allows for customization to various network scenarios. Second, they can be used to develop effective mobile application solutions for direct D2D data sharing based on historical mobility and content similarity data. It is important to note that initiating service and device discovery functions and setting up connections with nearby devices to request content are time and resource consuming functions which can deplete energy and overload devices. Therefore, these activities need to be initiated only when the probability of successful D2D data sharing is high enough; this success probability is a function of various parameters that can be monitored through a sliding window over time, such as , , and . Finally, D2D data sharing can be highly effective even if different parts of the same data content are downloaded from different peer devices as long as they are aggregated properly and the total cumulative download delay meets any end user target constraints. In the following section, we demonstrate how such ideas can be realized in practice using our own developed mobile application solution.

4.2. Mobile Solution: Design and Implementation

We have developed and implemented a social-aware D2D data sharing mobile solution for Android smartphones based on the architecture in Figure 11. The application is divided into the following five inter-connected modules that include back-end components and an interactive user interface.

4.2.1. Authentication Service

This module is responsible for authenticating the device by connecting the mobile application to the user’s social networking profile which includes list of friends or contacts; we used Facebook in our implementation, without loss of generality. This process starts by the user providing her/his Facebook credentials which are then authenticated with a Facebook server. If valid, the Facebook server will return a unique identifier for the user’s profile along with the user’s friends list. The user’s friends list is then saved in a local database while the user’s ID and D2D wireless link MAC address are saved in a remote global database; the wireless link can be either WiFi-Direct or Bluetooth as both provide the needed discovery and connectivity features to facilitate stable direct D2D connections. In our implementation, we used Bluetooth.

4.2.2. Database Service

This module is responsible for a background task whose job is to synchronize a global database of files and devices whenever feasible; for instance, whenever the device connects to the Internet. The database contains only the meta-data about the files that are being shared by the devices. More precisely, for each file that is shared by some mobile device, we maintain the following information: the file’s unique signature (md5 hash), file size, user-friendly file name, and a list of device identifiers that have the file available for sharing; we assume the device identifier is the MAC address of its WiFi-Direct or Bluetooth interface. In addition, the database is used to map between Facebook user identifiers and device MAC addresses. The database contains a tuple (MAC_ADD, FB_UID) for each device with a WiFi-Direct/Bluetooth interface having MAC_ADD as a MAC address and authenticated with a Facebook profile having FB_UID as identifier.

4.2.3. Discovery Service

This module is intermittently launched in the background, at predetermined intervals, to discover nearby devices. The device discovery mechanism is implemented as a standard Bluetooth discovery procedure. A list containing the MAC addresses of discovered devices is sent to the File Server Service module.

4.2.4. File Server Service

This module runs periodically in the background and can operate in two modes: either as a file server or as a fetcher. By default, this module is in the file server mode waiting for incoming requests from other devices. This is implemented using a standard TCP file transfer procedure; the device listens on a specific TCP port for incoming file transfer requests. A request is composed of two parameters: the unique signature of the requested file along with a byte offset; the byte offset is needed to allow a device to download different parts of the content from multiple devices. Whenever such request is received, the device file server will begin sending the requested file after skipping to the specified offset.

In the file fetcher mode, this module keeps a lookout for files that are requested by the user. Whenever a new list of nearby devices is received from the device discovery module and the device is not actively transmitting a file, the file fetcher module checks whether it can obtain one of the files requested by the user by the following:(i)Filtering the list of discovered devices and keeping only those that meet a set of conditions, for example, as discussed in Section 4.1 and Table 5(ii)Fetching the list of requested files and cross-matching it to the list of filtered discovered devices to check whether any of the selected devices has a file of interest.

If such a device is found, a Bluetooth connection request is sent to the device. If the connection is successfully established, the file fetcher service connects to the file server running on the other device and the file transfer process begins (see Figure 12 for interaction flowchart). When a file is fully fetched, it will be removed from the list of requested files and the WiFi-Direct connection will be terminated. Otherwise, if the transfer was interrupted for any reason, the current download progress (number of bytes downloaded so far) is saved in a local database so that download may resume when the opportunity presents itself again.

4.2.5. Front-End Graphical User Interface

Figures 13 and 14 present snapshots from the user interface of the mobile application demonstrating different features. Figure 13(a) shows the list of files that the user would like to download with a symbol indicating the size and location of each file; Figure 13(b) shows the list of Facebook friends; Figure 14(a) shows the list of nearby discovered WiFi-Direct devices; and Figure 14(b) demonstrates initiation of a download process for the file “Wonders_of_Nature.mp4” starting at position 91.5 MB from a user nearby who belongs to the friends list. We ran several test cases using our developed application and were able to demonstrate the validity of social-aware D2D data sharing with a given file downloaded to completeness from multiple devices over a window of time. Our implementation fits under the scope of the general area of delay tolerant networks whereby content download allows for a certain level of delay to benefit from D2D connectivity and reduce overhead on existing wireless infrastructure.

4.3. Mobile Solution: Case Study Validation

In order to validate the functionality of the developed mobile solution, we present in this section an example scenario using six Android smartphones to download a 5000 KB file; all devices are running the mobile application based on the architecture explained in Section 4.2. Five devices serve as potential collaborators for D2D data sharing and are positioned equidistantly along a hallway while in file server mode (see description of File Server Service in Figure 11). The sixth device is serving as a data requester (file fetch mode) and is moving along the hallway and, thus, crossing the radio range boundaries of the five devices sequentially. Figure 15 presents real measurement results showing the download progress versus time. In this scenario, it is assumed that all five devices have the content available but only devices 1, 3, and 5 have a trusted social network relation with the requesting device. As the mobile solution is social-aware, devices 2 and 4 were excluded from the cooperation; that is, they will filtered out after being discovered by the requesting device.

Figure 15 demonstrates how the download process progresses as the requesting device moves along the hallway; around 1000 KB were downloaded from device 1, next 3500 KB downloaded from device 3, and last 500 KB downloaded from device 5. The figure also quantifies the time spent by the device to perform device discovery and connection setup before it can proceed with D2D data transfer; this time is shown to be around five seconds on average and it adds to the total delay overhead of D2D mobile solutions in practice. The total time needed to download the content ended up to be around 125 seconds. We conducted similar experiments for other configurations and parameters, and the obtained results provided coherent insights and validated the robustness and effectiveness of our implementation under practical operational constraints.

5. Conclusion

In this work, we addressed several aspects related to the practical design and implementation of direct D2D data sharing mobile solutions without relying on intelligence or coordination from any existing radio access network. We performed an experimental study using our own developed crowdsourcing Android application CARMA in order to collect data and derive empirical models for several user mobility and contact parameters. To this end, we managed two data collection stages, the first including 37 mobile user participants over a period of 11 weeks and the second including 13 mobile user participants over a period of 4 weeks. Our focus was on use cases with bounded geographical location (university campus) and homogenous community (university students). We also designed and managed a user survey after obtaining the needed IRB (Institutional Research Board) approval in order to collect data related to content stored on users’ mobile devices and their willingness to participate in D2D data sharing applications. Then, we collected data on the social network relationships among the users and presented a set of conditions necessary for successful D2D file sharing based on joint consideration and correlation of mobility parameters (e.g., number of contacts and contact duration per time period), content similarity level, and social network relationship strength. Finally, we presented an architecture, implementation, and validation of a mobile solution for social-aware D2D data sharing using Android mobile application with several back-end module and a friendly user interface.

Even though the conclusions derived in the course of our work are specific to a university environment, they provide valuable insights that can guide the development of D2D data sharing solutions. The research outcomes illustrate clearly the dynamic nature of inter-user interactions whether in terms of contact and mobility, social connectivity, or mobile content. They also shed light on the temporal variability of all these factors (e.g., by comparing summer versus spring or comparing different days within the week) even by a homogenous group of users in a bounded geographical area, which somehow mimics a best case scenario when compared to dynamic variations over the scale of a city or country. Regarding the number of participants in our crowdsourcing experiments, it is similar to other interesting studies reported in the literature, for example, [19, 20]. Finally, all the collected data traces will be added as supplementary material with this paper to be openly accessible by the research community, as they can be utilized as inputs for evaluating the performance of new proposed D2D related enhancement techniques. In addition, the data traces can be used by researchers interested in predictive analytics using big data techniques, whereby devices or some centralized intelligence unit can predict future performance based on historical data in order to optimize the D2D offloading experience.

Disclosure

The statements made herein are solely the responsibility of the authors.

Conflicts of Interest

The authors declare that there are no conflicts of interest regarding the publication of this paper.

Acknowledgments

This work was made possible by Qatar National Research Fund (a member of the Qatar Foundation), NPRP Grant 7-1529-2-555.