Haversine सूत्र (PHP, Python, MySQL, MSSQL उदाहरणहरू) प्रयोग गरेर अक्षांश र देशान्तरका बिन्दुहरू बीचको ठूलो सर्कल दूरी गणना गर्नुहोस् वा क्वेरी गर्नुहोस्।

Haversine सूत्र - ठूलो सर्कल दूरी - PHP, पाइथन, MySQL

यस महिना म GIS लाई सम्मान गर्दै PHP र MySQL मा केहि थोरै कार्यक्रम गर्दैछु। नेटको वरिपरि स्नुप गर्दै, मलाई वास्तवमै केहि भेट्टाउन गाह्रो भयो भौगोलिक गणना दुई स्थानहरूको बीच दूरी पत्ता लगाउनको लागि म तिनीहरूलाई यहाँ सेयर गर्न चाहान्छु।

उडान नक्शा यूरोप महान सर्कल दूरी संग

दुई पोइन्ट बीचको दूरी हिसाब गर्ने सरल तरिका भनेको पायथागोरियन सूत्र प्रयोग गर्दै त्रिकोण (A² + B² = C²) का काल्पनिक गणना गर्न। यो यस रूपमा चिनिन्छ युक्लिडियन दूरी.

त्यो चाखलाग्दो सुरुवात हो तर यो भूगोलसँग लागू हुँदैन किनकि अक्षांश र देशान्तर रेखा बीचको दूरी छ बराबर दूरी छैन अलग भूमध्यरेखाको नजिक पुग्ने बित्तिकै अक्षांशका रेखाहरू टाढा जान्छ। यदि तपाईं कुनै प्रकारको साधारण त्रिकोणीय समीकरण प्रयोग गर्नुहुन्छ भने, यो एक स्थानमा दूरी सहि मापन गर्न सक्दछ र अर्को ठाउँमा एकदमै गलत, पृथ्वीको वक्रताको कारण।

महान सर्कल दूरी

पृथ्वीको चारैतिर लामो दूरी यात्रा गर्ने मार्गहरू लाई चिनिन्छ महान सर्कल दूरी। त्यो हो... एउटा गोलामा दुई बिन्दुहरू बीचको सबैभन्दा छोटो दूरी समतल नक्साको बिन्दुहरू भन्दा फरक छ। अक्षांश र देशान्तर रेखाहरू समतुल्य छैनन् भन्ने तथ्यसँग मिलाउनुहोस्... र तपाईंले कठिन गणना पाउनुभएको छ।

यहाँ कसरी उत्तम सर्कलहरू काम गर्दछन् बारे एक शानदार भिडियो विवरण।

Haversine फॉर्मूला

पृथ्वीको घुमाव प्रयोग गरेर दूरी मा समेटिएको छ Haversine सूत्र, जसले पृथ्वीको वक्रतालाई अनुमति दिनको लागि त्रिकोणमिती प्रयोग गर्दछ। जब तपाईं पृथ्वीमा २ स्थानहरू बीच दूरी खोज्नुहुन्छ (काग जस्तै उडेर जान्छ), एक सीधा रेखा वास्तवमा चाप हो।

यो हवाको उडानमा लागू हुन्छ - के तपाईंले कहिल्यै उडानहरूको वास्तविक नक्सालाई हेर्नुभयो र याद गर्नुभयो कि तिनीहरू क्रमबद्ध छन्? त्यो किनभने स्थानमा सिधा भन्दा दुई पोइन्टहरूका बीचमा एउटा सानामा उडान गर्न छोटो छ।

PHP: अक्षांश र देशान्तरको दुई पोइन्टहरू बीच दूरी गणना गर्नुहोस्

यहाँ दुई बिन्दुहरू बीचको दूरी (माइल बनाम किलोमिटर रूपान्तरणको साथ) गणना गर्नको लागि दुई दशमलव स्थानहरूमा राउन्ड गरिएको PHP सूत्र छ।

function getDistanceBetweenPointsNew($latitude1, $longitude1, $latitude2, $longitude2, $unit = 'miles') {
  $theta = $longitude1 - $longitude2; 
  $distance = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta))); 
  $distance = acos($distance); 
  $distance = rad2deg($distance); 
  $distance = $distance * 60 * 1.1515; 
  switch($unit) { 
    case 'miles': 
      break; 
    case 'kilometers' : 
      $distance = $distance * 1.609344; 
  } 
  return (round($distance,2)); 
}

चरहरू हुन्:

  • $Latitude1 - तपाईंको पहिलो स्थानको अक्षांशको लागि एक चर।
  • $Longitude1 - तपाईंको पहिलो स्थानको देशान्तरको लागि एक चर
  • $Latitude2 - तपाईंको दोस्रो स्थानको अक्षांशको लागि एक चर।
  • $Longitude2 - तपाईंको दोस्रो स्थानको देशान्तरको लागि एक चर।
  • $ युनिट - पूर्वनिर्धारित अस्तित्व हजारौँ। यो रूपमा अद्यावधिक वा पारित गर्न सकिन्छ किलोमिटर.

पाइथन: अक्षांश र देशान्तरका २ बिन्दुहरू बीचको दूरी गणना गर्नुहोस्

जे भए पनि, यहाँ दुई बिन्दुहरू (माइल बनाम किलोमिटर रूपान्तरणको साथमा) दुई दशमलव स्थानहरूमा राउन्ड गरिएको दूरीको गणना गर्नको लागि पाइथन सूत्र छ। मेरो छोरा, बिल कररलाई श्रेय जो डेटा वैज्ञानिक हो OpenINSightTS, कोडको लागि।

from numpy import sin, cos, arccos, pi, round

def rad2deg(radians):
    degrees = radians * 180 / pi
    return degrees

def deg2rad(degrees):
    radians = degrees * pi / 180
    return radians

def getDistanceBetweenPointsNew(latitude1, longitude1, latitude2, longitude2, unit = 'miles'):
    
    theta = longitude1 - longitude2
    
    distance = 60 * 1.1515 * rad2deg(
        arccos(
            (sin(deg2rad(latitude1)) * sin(deg2rad(latitude2))) + 
            (cos(deg2rad(latitude1)) * cos(deg2rad(latitude2)) * cos(deg2rad(theta)))
        )
    )
    
    if unit == 'miles':
        return round(distance, 2)
    if unit == 'kilometers':
        return round(distance * 1.609344, 2)

चरहरू हुन्:

  • अक्षांश 1 - तपाइँको पहिलो स्थान को लागी एक चर अक्षांश.
  • देशान्तर १ - तपाइँको पहिलो स्थान को लागी एक चर देशान्तरण
  • अक्षांश 2 - तपाइँको दोस्रो स्थान को लागी एक चर अक्षांश.
  • देशान्तर १ - तपाइँको दोस्रो स्थान को लागी एक चर देशान्तरण.
  • एकाइ - पूर्वनिर्धारित अस्तित्व हजारौँ। यो रूपमा अद्यावधिक वा पारित गर्न सकिन्छ किलोमिटर.

MySQL: अक्षांश र देशान्तर प्रयोग गरेर माइलहरूमा दूरी गणना गरेर दायरा भित्र सबै रेकर्डहरू पुन: प्राप्त गर्दै

यो एक विशेष दूरी भित्र सबै रेकर्डहरू पत्ता लगाउन गणना गर्न SQL को उपयोग गर्न पनि सम्भव छ। यस उदाहरणको लागि, म MySQL मा MyTable क्वेरी जाँदैछु सबै रेकर्डहरू भेट्टाउन जुन चर - दूरी (माइलमा) भन्दा मेरो स्थानमा $ अक्षांश र itude देशान्तरमा कम:

विशिष्ट भित्र सबै रेकर्डहरू पुन: प्राप्त गर्नका लागि प्रश्न दूरी माईलमा दूरी हिसाब गरेर अक्षांश र देशान्तरका दुई पोइन्टहरू बीच हुन्:

$query = "SELECT *, (((acos(sin((".$latitude."*pi()/180)) * sin((`latitude`*pi()/180)) + cos((".$latitude."*pi()/180)) * cos((`latitude`*pi()/180)) * cos(((".$longitude."- `longitude`)*pi()/180)))) * 180/pi()) * 60 * 1.1515) as distance FROM `table` WHERE distance <= ".$distance."

तपाईंले यसलाई अनुकूलित गर्नु पर्छ:

  • itude देशान्तर - यो एक PHP भ्यारीएबल हो जहाँ म पोइन्टको देशान्तर पार गर्दैछु।
  • itude अक्षांश - यो एक PHP भ्यारीएबल हो जहाँ म पोइन्टको देशान्तर पार गर्दैछु।
  • । दूरी - यो दूरी हो जुन तपाईं सबै रेकर्डहरू कम वा बराबर फेला पार्न चाहानुहुन्छ।
  • तालिका - यो टेबल हो ... तपाईं यसलाई तपाईंको टेबलको नामसँग बदल्न चाहानुहुन्छ।
  • अक्षांश - यो तपाईंको अक्षांशको क्षेत्र हो।
  • देशान्तरण - यो तपाईंको देशान्तरको क्षेत्र हो।

MySQL: अक्षांश र देशान्तर प्रयोग गरेर किलोमिटरमा दूरी गणना गरेर दायरा भित्र सबै रेकर्डहरू पुन: प्राप्त गर्दै

र SQL क्वेरी यहाँ MySQL मा किलोमिटर प्रयोग गरीरहेको छ:

$query = "SELECT *, (((acos(sin((".$latitude."*pi()/180)) * sin((`latitude`*pi()/180)) + cos((".$latitude."*pi()/180)) * cos((`latitude`*pi()/180)) * cos(((".$longitude."- `longitude`) * pi()/180)))) * 180/pi()) * 60 * 1.1515 * 1.609344) as distance FROM `table` WHERE distance <= ".$distance."

तपाईंले यसलाई अनुकूलित गर्नु पर्छ:

  • itude देशान्तर - यो एक PHP भ्यारीएबल हो जहाँ म पोइन्टको देशान्तर पार गर्दैछु।
  • itude अक्षांश - यो एक PHP भ्यारीएबल हो जहाँ म पोइन्टको देशान्तर पार गर्दैछु।
  • । दूरी - यो दूरी हो जुन तपाईं सबै रेकर्डहरू कम वा बराबर फेला पार्न चाहानुहुन्छ।
  • तालिका - यो टेबल हो ... तपाईं यसलाई तपाईंको टेबलको नामसँग बदल्न चाहानुहुन्छ।
  • अक्षांश - यो तपाईंको अक्षांशको क्षेत्र हो।
  • देशान्तरण - यो तपाईंको देशान्तरको क्षेत्र हो।

मैले यो कोड ईन्टरप्राइज म्यापि। प्लेटफर्ममा प्रयोग गर्‍यो जुन हामीले उत्तर अमेरिकामा १,००० भन्दा बढी स्थानहरूसहितको खुद्रा स्टोरको लागि प्रयोग गर्‍यौं र यसले राम्रोसँग काम गर्यो।

माइक्रोसफ्ट SQL सर्भर भौगोलिक दूरी: STD दूरी

यदि तपाइँ Microsoft SQL सर्भर प्रयोग गर्दै हुनुहुन्छ भने, तिनीहरूले आफ्नै प्रकार्य प्रस्ताव गर्छन्, STD दूरी भूगोल डेटा प्रकार प्रयोग गरी दुई बिन्दुहरू बीचको दूरी गणना गर्न।

DECLARE @g geography;  
DECLARE @h geography;  
SET @g = geography::STGeomFromText('LINESTRING(-122.360 47.656, -122.343 47.656)', 4326);  
SET @h = geography::STGeomFromText('POINT(-122.34900 47.65100)', 4326);  
SELECT @g.STDistance(@h);  

मनश साहू, उपाध्यक्ष र वास्तुकारलाई टोपी टिप Highbridge.

77 टिप्पणिहरु

  1. 1

    साझा गर्नुभएकोमा धेरै धेरै धन्यवाद। यो एक सजिलो प्रतिलिपि र टाँस्ने काम थियो र राम्रो काम गर्दछ। तपाईंले मलाई धेरै समय बचाउनु भयो।
    C मा पोर्ट गर्ने जो कोहीको लागि FYI:
    डबल deg2rad (डबल डिग्री) { रिटर्न डिग्री*(३.१४१५९२६५३५८९७९३२३८४६/१८०.०); }

  2. 2

    पोस्टिङको धेरै राम्रो टुक्रा - धेरै राम्रो काम गर्यो - मैले मात्र लामो-लामो समात्ने टेबलको नाम परिवर्तन गर्नुपर्‍यो। यसले धेरै छिटो काम गर्छ.. मसँग ल्याट-लांग्स (< 400) को यथोचित सानो संख्या छ तर मलाई लाग्छ कि यो राम्रो मापन हुनेछ। राम्रो साइट पनि - मैले भर्खरै यसलाई मेरो del.icio.us खातामा थपेको छु र नियमित रूपमा जाँच गर्नेछु।

  3. 4
  4. 5

    मैले पूरै दिन दूरी गणनाको लागि खोजी गरें र हार्भर्साइन एल्गोरिथ्म फेला पारे, यसलाई sql स्टेटमेन्टमा कसरी राख्ने भन्ने उदाहरण दिनु भएकोमा धन्यवाद। धन्यवाद र अभिवादन, डेनियल

  5. 8

    मलाई लाग्छ तपाईको SQL लाई कथन चाहिन्छ।
    जहाँ दूरी <= $distance तपाईंलाई आवश्यक हुन सक्छ
    HAVING दूरी <= $distance प्रयोग गर्नुहोस्

    अन्यथा मलाई धेरै समय र ऊर्जा बचत गर्नुभएकोमा धन्यवाद।

    • 9

      नमस्ते डेभिड,

      यदि तपाइँ कुनै पनि प्रकारको GROUP BY कथन गर्दै हुनुहुन्छ भने, तपाइँलाई HAVING आवश्यक पर्दछ। मैले माथिको उदाहरणमा त्यो गरिरहेको छैन।

      डग

  6. 10
  7. 11
  8. 12

    यो कोड साझा गर्नुभएकोमा धेरै धेरै धन्यवाद। यसले मलाई धेरै विकास समय बचत गर्यो। साथै, MySQL 5.x को लागि HAVING कथन आवश्यक छ भनी औंल्याएकोमा तपाईका पाठकहरूलाई धन्यवाद। धेरै उपयोगी।

  9. 14

    माथिको सूत्रले मेरो धेरै समय बचत गरिरहेको छ। मुरी मुरी धन्यवाद।
    मैले NMEA ढाँचा र डिग्रीहरू बीच पनि स्विच गर्नुपर्छ। मैले पृष्ठको तलको यो URL मा एउटा सूत्र फेला पारे। http://www.errorforum.com/knowledge-base/16273-converting-nmea-sentence-latitude-longitude-decimal-degrees.html

    कसैलाई यो कसरी प्रमाणित गर्ने थाहा छ?

    धन्यवाद!
    हैरी

  10. 15
  11. 16

    मैले कहाँ मेरो लागि काम गरेन भनेर पनि फेला पारे। यसलाई HAVING मा परिवर्तन गरियो र सबै कुरा सही काम गर्दछ। सुरुमा मैले टिप्पणीहरू पढिन र नेस्टेड चयन प्रयोग गरेर यसलाई पुन: लेखे। दुबैले राम्रोसँग काम गर्नेछन्।

  12. 17
  13. 18

    अविश्वसनीय सहयोगी, धेरै धेरै धन्यवाद! मलाई "कहाँ" को सट्टा नयाँ "HAVING" को साथ केहि समस्या भइरहेको थियो, तर एकचोटि मैले यहाँ टिप्पणीहरू पढे (निराशामा दाँत किटेको लगभग आधा घण्टा पछि =P), मैले राम्रोसँग काम गरें। धन्यवाद ^_^

  14. 19
  15. 20

    मनमा राख्नुहोस् कि त्यस्ता छनौट कथन धेरै कम्प्युटेसनली तीव्र र त्यसैले ढिलो हुनेछ। यदि तपाइँसँग ती धेरै प्रश्नहरू छन् भने, यसले चीजहरू चाँडै बिगार्न सक्छ।

    धेरै कम तीव्र दृष्टिकोण भनेको गणना गरिएको दूरी द्वारा परिभाषित स्क्वायर क्षेत्र प्रयोग गरेर पहिलो (क्रूड) चयन चलाउनु हो जस्तै "टेबलनामबाट चयन गर्नुहोस् जहाँ lat1 र lat2 बीचको अक्षांश र lon1 र lon2 बीचको देशान्तर"। lat1 = targetlatitude – latdiff, lat2 = targetlatitude + latdiff, lon सँग मिल्दोजुल्दो। latdiff ~= दूरी / 111 (किमिको लागि), वा दूरी / 69 माइलको लागि 1 डिग्री अक्षांश देखि ~ 111 किमी (पृथ्वी थोरै अण्डाकार भएकोले थोरै भिन्नता, तर यस उद्देश्यको लागि पर्याप्त)। londiff = दूरी / (abs(cos(deg2rad(latitude))*111)) — वा माइलको लागि 69 (तपाईले भिन्नताहरूको लागि खाता गर्नको लागि वास्तवमा अलिकति ठूलो वर्ग लिन सक्नुहुन्छ)। त्यसपछि त्यसको नतिजा लिनुहोस् र यसलाई रेडियल चयनमा फिड गर्नुहोस्। केवल सीमा बाहिरका समन्वयहरूको लागि खाता गर्न नबिर्सनुहोस् - जस्तै स्वीकार्य देशान्तरको दायरा -180 देखि +180 हो र स्वीकार्य अक्षांशको दायरा -90 देखि +90 हो - यदि तपाईंको latdiff वा londiff यस दायरा बाहिर चल्छ भने। । ध्यान दिनुहोस् कि प्रायजसो अवस्थामा यो लागू नहुन सक्छ किनभने यसले ध्रुवबाट ध्रुवमा प्रशान्त महासागर हुँदै एक रेखामा गणनालाई मात्र असर गर्छ, यद्यपि यसले चुकोटकाको भाग र अलास्काको भागलाई काट्छ।

    यसबाट हामीले के हासिल गर्छौं जुन बिन्दुहरूको संख्यामा तपाईंले यो गणना गर्नुहुन्छ भन्नेमा उल्लेखनीय कमी हो। यदि तपाइँसँग डाटाबेसमा एक मिलियन ग्लोबल बिन्दुहरू लगभग समान रूपमा वितरित छन् र तपाइँ 100 किमी भित्र खोज्न चाहनुहुन्छ भने, तपाइँको पहिलो (छिटो) खोज एक क्षेत्र 10000 वर्ग किलोमिटर हो र सम्भवतः लगभग 20 नतिजाहरू दिनेछ (एक भन्दा बढी वितरणमा आधारित। लगभग 500M वर्ग किलोमिटरको सतह क्षेत्र), जसको मतलब यो हो कि तपाईंले यो प्रश्नको लागि लाखौं पटकको सट्टा जटिल दूरी गणना 20 पटक चलाउनुहुन्छ।

    • 21

      उदाहरणमा सानो गल्ती... त्यो ५० किलोमिटर भित्रको हुनेछ (१०० होइन) किनकि हामीले हाम्रो... वर्गको "त्रिज्या" हेरिरहेका छौं।

      • 22

        शानदार सल्लाह! मैले वास्तवमा एक विकासकर्तासँग काम गरें जसले एक प्रकार्य लेख्यो जसले भित्री वर्गलाई तान्यो र त्यसपछि एक पुनरावर्ती प्रकार्य जसले परिधिको वरिपरि 'वर्ग' बनाउँछ बाँकी बिन्दुहरू समावेश गर्न र बहिष्कार गर्न। नतिजा अविश्वसनीय रूपमा छिटो परिणाम थियो - उसले माइक्रोसेकेन्डमा लाखौं अंकहरू मूल्याङ्कन गर्न सक्छ।

        माथिको मेरो दृष्टिकोण निश्चित रूपमा 'कच्चा' तर सक्षम छ। फेरि पनि धन्यबाद!

        • 23

          डग,

          म ल्याट लामो बिन्दु बहुभुज भित्र छ कि छैन भनेर मूल्याङ्कन गर्न mysql र php प्रयोग गर्ने प्रयास गरिरहेको छु। के तपाईलाई थाहा छ यदि तपाईको विकासकर्ता साथीले यो कार्य कसरी पूरा गर्ने बारे कुनै उदाहरण प्रकाशित गर्नुभयो। वा तपाईंलाई कुनै राम्रो उदाहरणहरू थाहा छ। अग्रिम धन्यवाद।

  16. 24

    नमस्ते सबैलाई यो मेरो परीक्षण SQL कथन हो:

    SELECT DISTINCT area_id, (
    (
    (
    acos( sin( ( 13.65 * pi( ) /180 ) ) * sin( (
    `lat_dec` * pi( ) /180 ) ) + cos( ( 13.65 * pi( ) /180 ) ) * cos( (
    `lat_dec` * pi( ) /180 )
    ) * cos( (
    ( 51.02 - `lon_dec` ) * pi( ) /180 )
    )
    )
    ) *180 / pi( )
    ) *60 * 1.1515 * 1.609344
    ) AS distance
    FROM `post_codes` WHERE distance <= 50

    र Mysql ले मलाई त्यो दूरी बताइरहेको छ, स्तम्भको रूपमा अवस्थित छैन, म अर्डर प्रयोग गर्न सक्छु, म यसलाई कहाँ बिना गर्न सक्छु, र यसले काम गर्दछ, तर यसको साथ होइन ...

  17. 26

    यो महान छ, यद्यपि यो चराहरू उड्ने जस्तै हो। गुगल नक्सा एपीआईलाई यसमा कुनै न कुनै तरिकाले (सडक आदि प्रयोग गरेर) सम्मिलित गर्ने प्रयास गर्नु राम्रो हुनेछ। मैले अझै पनि PHP मा सिमुलेटेड एनेलिङ प्रकार्य बनाउन बाँकी छ जुन यात्रा सेल्सम्यान समस्याको कुशल समाधान प्रस्ताव गर्न सक्षम हुनेछ। तर मलाई लाग्छ कि म त्यसो गर्नको लागि तपाइँको केहि कोड पुन: प्रयोग गर्न सक्षम हुन सक्छु।

  18. 27

    नमस्ते डगलस,
    यस लेखको लागि धेरै धेरै धन्यवाद - तपाईंले भर्खर मलाई धेरै समय बचाउनु भयो।
    ख्याल राख,
    nimrod @Israel

  19. 28

    राम्रो लेख! मैले दुई बिन्दुहरू बीचको दूरी कसरी गणना गर्ने भनेर वर्णन गर्ने धेरै लेखहरू फेला पारे तर म वास्तवमै SQL स्निपेट खोज्दै थिएँ।

  20. 29
  21. 30
  22. 31
  23. 32
  24. 36

    2 दिनको अनुसन्धान अन्ततः मेरो समस्या समाधान गर्ने यो पृष्ठ फेला पार्न। यस्तो देखिन्छ कि मैले मेरो वोल्फ्राम अल्फालाई राम्रोसँग बस्ट गरें र मेरो गणितमा ब्रश गर्नुहोस्। WHERE बाट HAVING मा परिवर्तन मेरो लिपि कार्य क्रममा छ। धन्यवाद

  25. 37
  26. 39

    म चाहन्छु कि यो पहिलो पृष्ठ हो जुन मैले यसमा फेला पारेको थिएँ। धेरै फरक आदेशहरू प्रयास गरिसकेपछि यो ठीकसँग काम गर्ने एक मात्र थियो, र मेरो आफ्नै डाटाबेसमा फिट गर्न आवश्यक न्यूनतम परिवर्तनहरूको साथ।
    धन्यवाद धेरै!

  27. 40

    म चाहन्छु कि यो पहिलो पृष्ठ हो जुन मैले यसमा फेला पारेको थिएँ। धेरै फरक आदेशहरू प्रयास गरिसकेपछि यो ठीकसँग काम गर्ने एक मात्र थियो, र मेरो आफ्नै डाटाबेसमा फिट गर्न आवश्यक न्यूनतम परिवर्तनहरूको साथ।
    धन्यवाद धेरै!

  28. 41
  29. 42
  30. 43
  31. 45
  32. 46
  33. 47

    मलाई थाहा छ यो सूत्रले काम गर्छ, तर पृथ्वीको त्रिज्या कहाँ लिइन्छ भनेर म देख्न सक्दिन। कृपया मलाई कसैले बुझाउन सक्नुहुन्छ?

  34. 49
  35. 50
  36. 52

    धन्यवाद डगलस, SQL क्वेरी ठ्याक्कै मलाई चाहिने कुरा हो, र मैले सोचे कि यो आफैले लेख्नुपर्छ। तपाईंले मलाई सम्भवतः घण्टा अक्षांश देशान्तर सिक्ने वक्रबाट बचाउनु भएको छ!

  37. 53

    म त्रुटि सन्देश प्राप्त गरिरहन्छु: MySQL क्वेरीमा 'जहाँ क्लज' मा अज्ञात स्तम्भ 'दूरी'।

  38. 55
  39. 56

    डगलस, यो अद्भुत कोड को लागी धन्यवाद। मेरो जीपीएस समुदाय पोर्टलमा यो कसरी गर्ने भन्ने बारे मेरो टाउको क्र्याक गर्दै। तपाईंले मलाई घण्टा बचत गर्नुभयो।

  40. 58

    यो उपयोगी लेख पोस्ट गर्नुभएकोमा धन्यवाद,  
    तर केही कारणले म सोध्न चाहन्छु
    Mysql db भित्रको coords र प्रयोगकर्ता द्वारा php मा सम्मिलित coords बीचको दूरी कसरी प्राप्त गर्ने?
    थप स्पष्ट रूपमा वर्णन गर्न को लागी:
    1. प्रयोगकर्ताले db र प्रयोगकर्ताको आफ्नै coords बाट निर्दिष्ट डाटा चयन गर्न [id] सम्मिलित गर्नुपर्छ
    2. php फाइलले [id] प्रयोग गरेर लक्ष्य डेटा (कोर्डहरू) प्राप्त गर्दछ र त्यसपछि प्रयोगकर्ता र लक्ष्य बिन्दु बीचको दूरी गणना गर्दछ।

    वा तलको कोडबाट मात्र दूरी प्राप्त गर्न सक्नुहुन्छ?

    $qry = "SELECT *,((acos(sin((“.$latitude।"*pi()/180)) * sin((`Latitude`*pi()/180))+cos((“। $अक्षांश। )))*180/pi())*180*180*180) दूरीको रूपमा `MyTable` बाट जहाँ दूरी >= ".$ दूरी।" >>>>के म यहाँबाट दूरी "बाहिर निकाल्न" सक्छु?
    फेरि पनि धन्यबाद,
    टिमी एस

  41. 60

    ठीक छ, मैले प्रयास गरेको सबै काम गरिरहेको छैन। मेरो मतलब, मसँग के काम छ, तर दुरीहरू टाढा छन्।

    के कसैले यो कोडमा के गलत छ भनेर देख्न सक्छ?

    if(isset($_POST['submitted'])){ $z = $_POST['zipcode']; $r = $_POST['त्रिज्या']; प्रतिध्वनि "".$z को लागि परिणाम; $sql = mysql_query("SELECT DISTINCT m.zipcode, m.MktName,m.LocAddSt,m.LocAddCity,m.LocAddState,m.x1,m.y1,m.verified,z1.lat,z2.lon,z1। mrk m, zip z1, zip z1 बाट city,z2.state जहाँ m.zipcode = z1.zipcode र z2.zipcode = $z AND (3963 * acos( truncate( sin( z2.lat / 57.2958 ) * sin(m। y1 / 57.2958 ) + cos( z2.lat / 57.2958 ) * cos( m.y1 / 57.2958 ) * cos( m.x1 / 57.2958 – z2.lon / 57.2958 ) , 8 ) = ) die < ) (mysql_error()); जबकि($row = mysql_fetch_array($sql )) { $store1 = $row['MktName']।""; $store = $row['LocAddSt']।""; $store .= $row['LocAddCity']।", ".$row['LocAddState']।" $row['zipcode']; $latitude1 = $row['lat']; $longitude1 = $row ['lon']; $latitude2 = $row['y1']; $longitude2 = $row['x1']; $city = $row ['शहर']; $state = $row['state']; $dis = नयाँ ($ अक्षांश1, $longitude1, $latitude2, $longitude2, $unit = 'Mi'); // $dis = दूरी($lat1, $lon1, $lat2, $lon2); $verified = $row['verified']; यदि ($प्रमाणित == '1'){ इको ""; इको ""। $store।""; echo $dis। "माइल(हरू) टाढा"; प्रतिध्वनि ""; } else { इको ""। $store।""; echo $dis। "माइल(हरू) टाढा"; प्रतिध्वनि ""; } }}

    मेरो functions.php कोड
    प्रकार्य प्राप्त भयो ($latitude1, $longitude1, $latitude2, $longitude2, $unit = 'Mi') { $theta = $longitude1 – $longitude2; $distance = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta)) ); $distance = acos($distance); $distance = rad2deg($distance); $distance = $distance * 60 * 1.1515; switch($unit) { केस 'Mi': ब्रेक; केस 'Km' : $distance = $distance * 1.609344; } फिर्ता (गोल ($ दूरी, 2)); }

    अग्रिम धन्यवाद

  42. 61
  43. 62

    हे डगलस, उत्कृष्ट लेख। मैले भौगोलिक अवधारणा र कोडको तपाईंको व्याख्या साँच्चै रोचक पाएँ। मेरो मात्र सुझाव स्पेस र प्रदर्शनको लागि कोड इन्डेन्ट हुनेछ (जस्तै Stackoverflow, उदाहरणका लागि)। म बुझ्छु कि तपाईं ठाउँ संरक्षण गर्न चाहनुहुन्छ, तर परम्परागत कोड स्पेसिङ / इन्डेन्टेशनले मलाई प्रोग्रामरको रूपमा पढ्न र विच्छेदन गर्न धेरै सजिलो बनाउँदछ। जे होस्, यो सानो कुरा हो। महान कार्य जारी राख्नुहोस्।

  44. 64
  45. 65

    यहाँ प्रकार्यको साथ प्रयोग गर्दा हामी एक प्रकारको दूरी पाउँदैछौं।तै बेला क्वेरी प्रयोग गरेर आउँदैछ भने अन्य प्रकारको दूरी

  46. 66
  47. 67
  48. 68
  49. 69
  50. 70

    यो छिटो देखिन्छ (mysql 5.9) चयनमा दुई पटक सूत्र प्रयोग गर्न र कहाँ:
    $formula = “(((acos(sin((“.$latitude।"*pi()/180))* sin((`Latitude`*pi()/180))+cos((“.$ अक्षांश। ”*pi()/180)) * cos((`Latitude`*pi()/180)) * cos((“.$longitude।”- `Longitude`)*pi()/180)))) *180/pi()*60*1.1515*1.609344)”;
    $sql = 'SELECT *, '.$ सूत्र।' तालिकाबाट दूरीको रूपमा जहाँ '..$ सूत्र।' <= '।$ दूरी;

  51. 71
  52. 72

    यो लेख सुन्नु भएकोमा धेरै धेरै धन्यवाद।यो धेरै उपयोगी छ।
    PHP लाई पहिले "व्यक्तिगत गृह पृष्ठ" भनिने सरल स्क्रिप्टिङ प्लेटफर्मको रूपमा सिर्जना गरिएको थियो। आजकल PHP (हाइपरटेक्स्ट प्रिप्रोसेसरको लागि छोटो) माइक्रोसफ्टको एक्टिभ सर्भर पृष्ठहरू (एएसपी) प्रविधिको विकल्प हो।

    PHP एक खुला स्रोत सर्भर-साइड भाषा हो जुन गतिशील वेब पृष्ठहरू सिर्जना गर्न प्रयोग गरिन्छ। यसलाई HTML मा सम्मिलित गर्न सकिन्छ। PHP लाई सामान्यतया Linux/UNIX वेब सर्भरहरूमा MySQL डाटाबेससँग संयोजनमा प्रयोग गरिन्छ। यो सायद सबैभन्दा लोकप्रिय स्क्रिप्टिङ भाषा हो।

  53. 73

    मैले माथिको समाधान ठीकसँग काम नगरेको फेला पारे।
    मलाई परिवर्तन गर्न आवश्यक छ:

    $qqq = "SELECT *,(((acos(sin((“.$latitude।"*pi()/180)) * sin((`latt`*pi()/180))+cos((”। $अक्षांश। "*pi()/180)) * cos((`latt`*pi()/180)) * cos((" . $longitude . "- `longt`)*pi()/180) )))*180/pi())*60*1.1515) `दर्ता` बाट दूरीको रूपमा;

  54. 75

    धन्यवाद सर एकदम राम्रो काम गर्दै हुनुहुन्छ .. तर मसँग एउटा प्रश्न छ यदि म दशमलव बिन्दु बिना आउटपुट गर्न चाहन्छु भने म के गर्न सक्छु ..?

    अग्रिम धन्यवाद।

  55. 76

    नमस्ते, कृपया मलाई यसमा तपाईंको मद्दत चाहिन्छ।

    मैले मेरो वेब सर्भरमा प्राप्त अनुरोध गरें http://localhost:8000/users/findusers/53.47792/-2.23389/20/
    ५३.४७७९२ = $अक्षांश
    -2.23389 = $देशान्तर
    र 20 = मैले पुन: प्राप्त गर्न चाहेको दूरी

    यद्यपि तपाइँ सूत्र प्रयोग गरेर, यसले मेरो db मा सबै पङ्क्तिहरू पुन: प्राप्त गर्दछ

    $results = DB::select( DB::raw("SELECT*, (((acos(sin((“.$latitude।"*pi()/180))* sin((lat*pi()/180 ))+cos((“.$ अक्षांश।”*pi()/180)) * cos((lat*pi()/180)) * cos((“.$देशान्तर।”- lng)*pi( )/180))))*180/pi())*60*1.1515*1.609344) मार्करहरूबाट दूरीको रूपमा दूरी >= “.$ दूरी));

    [{"id":1,"नाम":"Frankie Johnnie & Luigo Too","ठेगाना":"939 W El Camino Real, Mountain View, CA","lat":37.386337280273,"lng":-122.08582305908, "दूरी":16079.294719663},{"id":2,"नाम":"Amici's East Coast Pizzeria","ठेगाना":"790 Castro St, Mountain View, CA","lat":37.387138366699,"lng": -१२२.०८३२३६६९४३४,"दूरी":१६०७९.१७५९४०१५२},{"आईडी":३,"नाम":"कपको पिज्जा बार र ग्रिल","ठेगाना":"१९१ क्यास्ट्रो सेन्ट, माउन्टेन भ्यू, सीए","लाट":३७.३९३८६८६, "lng":-122.08323669434,"distance":16079.175940152},{"id":3,"name":"Round Table Pizza: Mountain View","ठेगाना":"191 N Shoreline Blvd, Mountain View, CA", "lat":37.393886566162,"lng":-122.07891845703,"दूरी":16078.381373826},{"id":4,"नाम":"टोनी र अल्बाको पिज्जा र पास्ता","ठेगाना":"570 एकुटेन View, CA","lat":37.402652740479,"lng":-122.07935333252,"distance":16077.420540582},{"id":5,"name":"Oregano's Wood-Fire Pizza","619""ठेगाना":37.394012451172 El Camino Real, Los Altos, CA","lat":122.09552764893,"lng":-16078.563225154,"दूरी":6},{" id":4546,"नाम":"द बार र ग्रिलहरू","ठेगाना":"37.401725769043 व्हाइटली स्ट्रीट, म्यानचेस्टर","लाट":122.11464691162,"lng":-16077.937560795,"दूरी":7}

    म 20 माइलको साथ पङ्क्तिहरू पुन: प्राप्त गर्न चाहन्छु तर यसले सबै पङ्क्तिहरू ल्याउँछ। कृपया म के गल्ती गर्दैछु

  56. 77

    म उस्तै प्रश्न खोज्दै छु तर अलिकति बढेको छु - संक्षेपमा यो प्रत्येक समन्वयको 2 माईल भित्र सबै समन्वयहरूलाई समूहबद्ध गर्ने हो र त्यसपछि प्रत्येक समूहमा कतिवटा समन्वयहरू गणना गर्नुहोस् र सबैभन्दा बढी समन्वय भएको एउटा समूह मात्र आउटपुट गर्नुहोस् - भले पनि तपाईसँग समूहहरू मध्ये एक भन्दा बढी समूहहरू छन् जसमा धेरै संख्यामा समन्वयहरू छन् - केवल एउटै ठूलो संख्या भएका समूहहरूबाट अनियमित समूह आउटपुट गर्नुहोस् -

तिम्रो के बिचार छ?

यो साइट स्प्याम कम गर्न Akismet को उपयोग गर्दछ। जान्नुहोस् कि तपाईंको डेटा कसरी संसाधित छ.