合肥生活安徽新聞合肥交通合肥房產生活服務合肥教育合肥招聘合肥旅游文化藝術合肥美食合肥地圖合肥社保合肥醫院企業服務合肥法律

        CS305程序代做、代寫Python程序語言
        CS305程序代做、代寫Python程序語言

        時間:2024-12-25  來源:合肥網hfw.cc  作者:hfw.cc 我要糾錯



        CS305 Computer Networks Project:
        Remote Meeting
        Introduction
        Video meetings have become essential in today’s digital landscape, transforming how people
        connect, collaborate, and communicate. With the rise of remote work, online learning, and global
        partnerships, video meeting allows individuals and teams to interact across vast distances,
        fostering real-time collaboration without the need for physical presence. The implementation of a
        video meeting project relies heavily on core computer networking principles and protocols,
        making it an ideal opportunity to consolidate and apply the knowledge gained throughout the
        course. 
        Requirements
        In this project, you are required to construct a simple video meeting system in Python that
        enables participants to communicate over the network using video, audio, and text in real time.
        This project emphasizes building network frameworks and utilizing network protocols. The system
        framework is divided into two parts: Client-Server (CS) and Peer-to-Peer (P2P). Implementing the
        system with the CS framework forms the basis component, while implementing it with the P2P
        framework is an optional bonus (details provided later). Meanwhile, a video meeting system relies
        on several key network protocols that enable real-time audio, video, and text communication,
        such as TCP, UDP, SIP, RTP, RTCP, STUN, and TURN. These protocols facilitate the smooth
        transmission of media streams, ensure security, and manage connectivity between participants. 
        Determining how to choose and implement these protocols is the primary challenge you will address.
        Alternatively, you have the option to design your own protocol.
        Basic Part (85%)
        In the basic part, you are required to implement a video meeting system based on Client-Server
        (CS) framework. In this system, the server manages and records multiple conference rooms and
        user operations, while users can act as clients to communicate with the server by creating,
        joining, and exiting meetings.
        In a detail, functions of server:
        Manage and record meeting statuses (such as creating and terminating meetings) and track
        client actions (such as joining and leaving).
        Forward client data to facilitate communication among participants.
        Functions of client (Clients are divided into creators and participants):
        Creators: request to create and terminate meeting.
        Participant: join and exit meetings.
        All clients: communicate with the server.
        In each meeting, all users can send video, audio, and text messages at the same time. The server
        is responsible for handling the broadcast of this information and ensuring that each client can
        correctly receive and display content from other users. The specific requirements are as follows:
        Basic transmission function (25%)
        Text transmission(such as chat messages) function (5%)
        Each client can send the text messages to server.
        The server forwards the text messages to all other participants in the meeting.
        The client should display all text messages from senders.
        Each message should include the sender's name and the time-stamp to help
        participants quickly identify the source of the information.
        Video transmission function (10%)
        Each user can choose to turn their camera on or off. Once the camera is activated, the
        client should send the video stream to the server.
        The server forwards the video stream to all other participants in the meeting.
        The client should display the screens of all users who have their cameras turned on and
        can show real-time video from multiple users using a split-screen or similar methods.
        Audio transmission function (10%)
        Each user can choose to turn their microphone on or off. Once the microphone is
        activated, the client should send the audio stream to the server.
        The server must receive and mix the audio streams from multiple users, distributing the
        combined audio stream to all participants.
        The client should play audio from other users and be capable of handling the play of
        multiple audio streams simultaneously.
        Note: Streaming data processing is a difficult aspect of the project. Grades will be assigned based on
        performance, with smoother display and play resulting in higher scores during the presentation.
        Meeting function(60%)
        Single meeting mode (20%)
        In this mode, two client will interact with a server: one client requests to create a meeting and
        joins it, while the other client also joins the same meeting.
        Create a Meeting (5 points): The client can send a request to the server to create a new
        meeting. Once the meeting is successfully created, other users will be allowed to join.
        Join a Meeting (5 points): The client can view a list of currently available meetings and
        choose to join any of them. After joining, the client will participate in the meeting.
        Exit the Meeting (5 points): The client can exit the current meeting at any time. Leaving the
        meeting will not affect the ability of other client to continue participating.
        Cancel the Meeting (5 points): The creator of the meeting can cancel it at any time. Once
        the meeting is canceled, no new clients will be able to join, and those already in the meeting
        will be removed. Additionally, the meeting will automatically end when all participants,
        including the creator, have exited.
        Complex Meeting Scenarios (40%)
        1. Multiple participants participate in a meeting (20%). The meeting system must support
        the simultaneous participation of multiple clients(at least 3 clients) to ensure smooth
        communication through audio, video, and text. This extended version of the single meeting
        mode emphasizes that each meeting must be capable of supporting multiple client
        participants (tips: asynchronous io or multi-thread).
        2. Multiple conferences in parallel (20%). The server should support multiple meetings
        occurring at the same time. The founders of each meeting can be different, allowing various
        users to create independent meetings. The specific requirements are as follows:
        Independent Meeting Life Cycle (10%): The start and end of each meeting should be
        independent of one another, ensuring that the status of one meeting does not affect
        other meetings. All meetings should be able to proceed normally.
        Content Isolation (10%): The content of each meeting should be completely isolated
        from others; no meeting should receive audio or video data from other conferences.
        The server must ensure that audio and video streams are transmitted exclusively
        between users in the same meeting, thereby maintaining the privacy and independence
        of each conference.
        Bonus Part (20%)
        In the bonus part, you are required to implement a video meeting system based on Peer-to-Peer
        (P2P) framework. This system is similar to the Client-Server (CS) system, but in this case, the
        server's role is limited to managing and recording meetings without forwarding data. The
        specific requirements are as follows:
        Two clients scenarios(10%): The client can request to create a meeting. In this meeting, two
        clients communicate directly with each other.
        Mode switch(10%): The server can determine the most suitable mode for different meetings
        and switch accordingly between Client-Server (CS) and Peer-to-Peer (P2P) (For instance,
        when two clients are in a meeting, it operates in P2P mode, and when three clients are in a
        meeting, it switches to CS mode.).
        Note: The bonus part is relatively loose, and you can do it yourself. But at the same time, how to show
        that your data is not forwarded by server in P2P scenarios and whether the mode is switched in
        different scenarios are also issues you need to consider.
        Presentation (5%)
        You will present your project in the lab class after December 20. Each group has a maximum of 
        10 minutes to showcase their work. TAs may ask questions about your project during the
        presentation, so a thorough understanding of your implemented functions is essential.
        Provided Code
        We have provided demo code for you to further understand the fucntions of server and client, as
        well as the system structure (see Demo for Video Conference). It includes four files 
        conf_client.py , conf_server.py , config.py , util.py . 
        Note that this demo is just a reference. You don't need to follow it exactly and are encouraged
        to implement a more efficient video conference service.
        conf_client.py
        There is a ConferenceClient class, with necessary fields to record client status or meeting
        information. Following are some necessary function for client, each with description for its
        functionality. All a client need to do are create connections, and do transmission (sending and
        receiving).
        In the start() method, we have provided a simple command line user interface to execute
        certain function. But we won't mind that some of you can provide a better GUI for your clients.
        conf_server.py
        This is a simple demo for server with original implementation of asynchronized IO ( asyncio ).
        There are two classes MainServer and ConferenceServer for possible multi-conference
        implementation, where ConferenceServer handles clients within a single conference and 
        MainConference manages multiple conference by handling multiple instances of 
        ConferenceServer .
        Note that any conference (with mode C-S or P2P) should be managed by server, while the
        data transmission among clients depends on the mode of conference.
        config.py
        This file stores some necessary configuration of the conference service, including but not limited
        to the service ports, server's IP address and other parameters to control the stream data and its
        transmission.
        util.py
        This file includes some useful functions for data capture and image processing.

        請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp



         

        掃一掃在手機打開當前頁
      1. 上一篇:CS209A代做、Java程序設計代寫
      2. 下一篇:URBA6006代寫、Java/c++編程語言代做
      3. 無相關信息
        合肥生活資訊

        合肥圖文信息
        挖掘機濾芯提升發動機性能
        挖掘機濾芯提升發動機性能
        戴納斯帝壁掛爐全國售后服務電話24小時官網400(全國服務熱線)
        戴納斯帝壁掛爐全國售后服務電話24小時官網
        菲斯曼壁掛爐全國統一400售后維修服務電話24小時服務熱線
        菲斯曼壁掛爐全國統一400售后維修服務電話2
        美的熱水器售后服務技術咨詢電話全國24小時客服熱線
        美的熱水器售后服務技術咨詢電話全國24小時
        海信羅馬假日洗衣機亮相AWE  復古美學與現代科技完美結合
        海信羅馬假日洗衣機亮相AWE 復古美學與現代
        合肥機場巴士4號線
        合肥機場巴士4號線
        合肥機場巴士3號線
        合肥機場巴士3號線
        合肥機場巴士2號線
        合肥機場巴士2號線
      4. 幣安app官網下載 短信驗證碼

        關于我們 | 打賞支持 | 廣告服務 | 聯系我們 | 網站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

        Copyright © 2024 hfw.cc Inc. All Rights Reserved. 合肥網 版權所有
        ICP備06013414號-3 公安備 42010502001045

        主站蜘蛛池模板: 国产亚洲福利精品一区| 亚洲乱色熟女一区二区三区丝袜| 亚洲av乱码一区二区三区按摩| 国产精品乱码一区二区三| 国产成人高清视频一区二区 | 国精品无码一区二区三区左线| 色噜噜狠狠一区二区| 中文字幕无码一区二区免费 | 天码av无码一区二区三区四区| 日韩人妻一区二区三区蜜桃视频| 国产成人一区二区三区高清| 糖心vlog精品一区二区三区| 人妻天天爽夜夜爽一区二区| 久久久国产一区二区三区| 国产伦一区二区三区免费| 伊人无码精品久久一区二区| 国产成人无码一区二区在线播放| 成人免费av一区二区三区| 精品亚洲一区二区三区在线播放| 国产精品亚洲一区二区三区| 国产日韩综合一区二区性色AV| 日本一区二区三区久久| 欧洲精品码一区二区三区| 精品一区二区三区3d动漫| 国产在线观看一区二区三区| 麻豆一区二区三区蜜桃免费| 国产日韩高清一区二区三区 | 精品亚洲AV无码一区二区三区 | 亚洲一区二区三区电影| 国产大秀视频在线一区二区 | 狠狠做深爱婷婷久久综合一区| 日韩精品一区在线| 日韩人妻无码一区二区三区综合部| 奇米精品一区二区三区在| 精品成人乱色一区二区| 一区二区三区高清在线 | 精品人妻一区二区三区毛片| 亚洲国产日韩一区高清在线| 国产午夜精品一区二区三区极品 | 国产A∨国片精品一区二区| 国产成人无码一区二区三区|